@import"https://fonts.googleapis.com/css2?family=Zhi+Mang+Xing&display=swap";:root{--light-theme-border-color: #2c3e50;--dark-theme-border-color: #4b5563;--border-color: var(--light-theme-border-color);--light-theme-text-color: #333;--dark-theme-text-color: #f8f8f8;--text-color: var(--light-theme-text-color);--light-theme-background-color: #fff;--dark-theme-background-color: #222;--background-color: var(--light-theme-background-color);--light-theme-sidebar-color: #f7f7f7;--dark-theme-sidebar-color: #2a2a2a;--sidebar-color: var(--light-theme-sidebar-color);--light-theme-header-and-footer-color: #2c3e50;--dark-theme-header-and-footer-color: #1b1b1b;--header-and-footer-color: var(--light-theme-header-and-footer-color);--light-theme-hover-color: #e7f5ff;--dark-theme-hover-color: #37474F;--hover-color: var(--light-theme-hover-color);--font-family-base: 'Source Serif 4', 'Noto Serif SC', serif;--font-family-handwritten: 'Zhi Mang Xing', cursive;--accent: #2563eb;--accent-600: #1d4ed8;--link-color: var(--accent);--link-hover-color: var(--accent-600);--hljs-background: #f8f9fa;--hljs-color: #4d4d4d;--hljs-keyword-color: #d73a49;--hljs-string-color: #0366d6;--hljs-comment-color: #22863a;--hljs-function-color: #005cc5}.dark-theme{--border-color: var(--dark-theme-border-color);--text-color: var(--dark-theme-text-color);--background-color: var(--dark-theme-background-color);--sidebar-color: var(--dark-theme-sidebar-color);--hover-color: var(--dark-theme-hover-color);--header-and-footer-color: var(--dark-theme-header-and-footer-color);--link-hover-color: #9ecbff;--hljs-background: #1e1e1e;--hljs-color: #c9d1d9;--hljs-keyword-color: #ff6c6b;--hljs-string-color: #79b8ff;--hljs-comment-color: #34d058;--hljs-function-color: #58a6ff}.chinese{--font-family-base: 'Noto Serif SC', serif}*{margin:0;padding:0;box-sizing:border-box;font-family:var(--font-family-base);color:var(--text-color);scroll-behavior:smooth}body,html{background-color:var(--background-color)}[hidden]{display:none !important}@media(prefers-reduced-motion: reduce){*{scroll-behavior:auto !important}}a{color:var(--link-color);text-decoration:none}a:hover,a:focus{color:var(--link-hover-color);text-decoration:underline;text-underline-offset:.18em;text-decoration-thickness:1.5px}a:visited{color:color-mix(in srgb, var(--accent), transparent 20%)}img{display:block;margin-top:1.5em;margin-bottom:1.5em}.wrapper{display:flex;flex-direction:column;min-height:100vh;margin:0 auto;padding:0;max-width:70rem;width:100%;background-color:var(--background-color)}#container{display:flex;flex:1;margin:0 auto;padding:0;max-width:70rem;width:100%;background-color:var(--background-color)}#sidebar{flex-shrink:0;width:15em;background-color:var(--sidebar-color);color:var(--text-color);position:sticky;top:1vh;height:98vh;max-height:50em;padding:1.5em;text-align:center;border:1px solid var(--border-color);border-radius:12px;margin:.5em;overflow-y:auto;overflow-x:hidden;box-shadow:0 4px 8px rgba(0,0,0,.1);display:flex;flex-direction:column;align-items:center;gap:1em}#sidebar.sidebar-auto-height{height:auto !important}#sidebar.sidebar-near-footer{height:94vh}#sidebar{-ms-overflow-style:none;scrollbar-width:none}#sidebar::-webkit-scrollbar{display:none}#sidebar>*{margin-bottom:0;width:100%}#sidebar .theme-toggle.main-page-style,#sidebar .language-toggle.main-page-style{width:auto;height:auto}#sidebar h2{margin-bottom:0;font-size:1.5em}#sidebar-my-current-status{font-size:.9em;color:var(--text-color);margin-top:0;margin-bottom:.5em;font-weight:bold}#sidebar h3,#sidebar a{color:var(--text-color);text-decoration:none;line-height:2;display:block}#sidebar p{font-size:.8em;margin-bottom:.6em;margin-top:.2em;white-space:nowrap}#sidebar-bio{display:block;font-size:1em;margin-top:0;margin-bottom:.5em;font-style:italic}#sidebar-navbar{display:flex;flex-direction:column;justify-content:flex-start;flex-grow:1;margin-bottom:-0.5em}#sidebar-navbar ul{list-style-type:none;width:100%;display:flex;flex-direction:column;height:100%;justify-content:space-between;margin:0;padding:0;gap:.5em}#sidebar-navbar li{border:.1em solid var(--border-color);border-radius:10px;width:100%;flex-grow:1;flex-shrink:1;flex-basis:auto;margin:0;display:flex;align-items:center;justify-content:center;padding:.4em 0}#sidebar-navbar a{text-decoration:none;display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.1em;margin:0}#sidebar-navbar li{background:rgba(0,0,0,0);border-color:color-mix(in srgb, var(--border-color), transparent 70%)}#sidebar-navbar li:hover,#sidebar-navbar li:focus-within{background-color:color-mix(in srgb, var(--accent), transparent 92%);cursor:pointer;transition:background-color .18s ease,color .18s ease}#sidebar-logos{display:flex;justify-content:center;align-items:center;flex-wrap:wrap}#sidebar-logos ul{display:flex;padding:0;margin:0;align-items:center;justify-content:center;gap:.75em}#sidebar-logos li{display:inline-block;transition:transform .3s ease}#sidebar-logos img.logo{display:block;max-width:35px;max-height:35px;width:auto;height:auto;vertical-align:middle;margin:0}#sidebar-logos li:hover,#sidebar i:hover{transform:scale(1.03)}#main-content{flex:1;padding:2em 2em;width:100%;line-height:1.7;background-color:var(--background-color)}#main-content h1{font-family:"Playfair Display",serif;font-size:3em;margin-bottom:.5em;color:var(--text-color);border-bottom:.2em solid var(--border-color);padding-bottom:.2em}h2,h3{font-family:"Playfair Display",serif;letter-spacing:-0.01em}#main-content>p{max-width:70ch;margin:0 0 1em}#main-content a{text-decoration:none}.content-image{display:block;width:100%;border-radius:12px;margin:1.5em 0;border:1px solid color-mix(in srgb, var(--border-color), transparent 70%);box-shadow:0 2px 8px rgba(0,0,0,.04)}#main-content p{margin-bottom:1.2em;text-align:justify}#main-content #projects-grid p{margin-bottom:1.2em;text-align:justify}#publications-list{padding-left:20px}#publications-list li{margin-bottom:10px}#projects-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1.25rem}.project-item{text-align:justify;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s,box-shadow .3s;border:.2em solid var(--border-color);border-radius:1.3em;box-sizing:border-box;background:color-mix(in srgb, var(--background-color), #000 4%)}.project-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.1)}.project-item a{text-align:justify;color:inherit;text-decoration:none;display:block;padding:.8em;height:100%}.project-item a:hover,.project-item a:focus{background-color:var(--hover-color);box-shadow:0 4px 8px rgba(0,0,0,.2)}.project-item .image-container{display:flex;justify-content:center;align-items:center;flex-grow:1}.project-item img{width:100%;height:auto;margin:0;aspect-ratio:16/9;object-fit:cover}.project-item h2{font-size:clamp(1.5em,5vw,2.5em);margin:.1em 0;text-align:center;word-wrap:break-word;overflow-wrap:break-word}#individual-content,main#main-content:not([data-page]){padding:.3em 1em 1em 1em;text-align:justify}#individual-content p,#individual-content li,main#main-content:not([data-page]) p,main#main-content:not([data-page]) li{font-family:"Roboto",sans-serif}#writings-directory{font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;margin-left:1em}[data-page=writings] h1,[data-page=publications] h1{text-align:left;font-size:2.5em;margin-bottom:.5em;margin-left:.3em}#writing-filter-controls{margin-left:1em;margin-bottom:1em}#writing-filter-controls select{display:block;width:100%;max-width:20em;padding:.25em .5em;font-size:1em;border:1px solid var(--border-color);border-radius:4px;background-color:var(--background-color);color:var(--text-color)}.dark-theme #writing-filter-controls select{background-color:var(--sidebar-color)}#writings-directory .writing-item{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1em;border-bottom:1px solid color-mix(in srgb, var(--border-color), transparent 70%);padding-bottom:1em}#writings-directory a{color:var(--link-color);font-size:clamp(1em,2vw,1.5em);font-weight:700;margin-bottom:.5em;padding:0;border-radius:0;background:rgba(0,0,0,0);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:.12em;white-space:normal;overflow-wrap:anywhere}#writings-directory a:hover,#writings-directory a:focus{color:var(--accent);background:rgba(0,0,0,0);text-decoration:underline}#writings-directory .explanatory-text{font-size:1em;margin-left:.25em;margin-top:.5em;font-style:italic}#writings-directory .writing-meta{flex-shrink:0}#writings-directory .date{font-size:.9em;color:#6b7280;text-align:right;margin-left:1em;margin-right:.5em;font-variant-numeric:tabular-nums}#writings-directory .month-day,#writings-directory .year{display:block}#writings-directory .writing-image{width:5em;height:auto;margin-right:.5em;order:-1}header{background-color:var(--header-and-footer-color);color:#fff;padding:1em 0;position:relative;border-bottom:1px solid color-mix(in srgb, var(--border-color), transparent 60%);box-shadow:0 1px 0 rgba(0,0,0,.06)}header ul{list-style:none;padding:0;margin:0 2.5em;text-align:center}header li{display:inline;margin:0 1em}header a{color:#fff;text-decoration:none}header a:hover,header a:focus{color:var(--link-hover-color);cursor:pointer}#sidebar-navbar a[aria-current=page],header a[aria-current=page]{font-weight:700;text-decoration:underline;text-underline-offset:.2em;text-decoration-thickness:2px}#sidebar-navbar a[aria-current=page]{border-left:.25em solid var(--accent);padding-left:.5em}.theme-toggle.main-page-style,.language-toggle.main-page-style,.theme-toggle.content-page-style,.language-toggle.content-page-style{border:0;background:rgba(0,0,0,0);padding:0;line-height:1;-webkit-appearance:none;appearance:none}.theme-toggle.main-page-style,.language-toggle.main-page-style{position:absolute;top:.5em;cursor:pointer;width:1em;height:1em;font-size:1.3em;font-style:normal;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;z-index:2}.theme-toggle.main-page-style{left:.5em}.language-toggle.main-page-style{right:.5em}.theme-toggle.content-page-style{cursor:pointer;width:1.5em;height:1.5em;font-size:1.3em;font-style:normal;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;position:absolute;top:50%;left:1em;transform:translateY(-50%);color:#fff}.theme-toggle.content-page-style i,.language-toggle.content-page-style i{color:#fff}.theme-toggle.content-page-style:hover,.language-toggle.content-page-style:hover,.theme-toggle.content-page-style:focus,.language-toggle.content-page-style:focus{transform:translateY(-50%) scale(1.1);outline:none}.theme-toggle.main-page-style:focus-visible,.language-toggle.main-page-style:focus-visible,.theme-toggle.content-page-style:focus-visible,.language-toggle.content-page-style:focus-visible{outline:2px solid var(--link-hover-color);outline-offset:2px;border-radius:4px}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:1000}.skip-link:focus,.skip-link:focus-visible{left:.75em;top:.75em;width:auto;height:auto;overflow:visible;background:var(--header-and-footer-color);color:#fff;padding:.5em .9em;border-radius:4px;outline:2px solid var(--border-color);outline-offset:2px}.language-toggle.content-page-style{cursor:pointer;width:1.5em;height:1.5em;font-size:1.3em;font-style:normal;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;position:absolute;top:50%;right:1em;transform:translateY(-50%)}.language-toggle i.language-english,.language-toggle i.language-chinese{font-style:normal;display:grid;place-items:center;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;line-height:1;letter-spacing:0}.language-toggle i.language-english{font-size:.72rem}.language-toggle i.language-chinese{font-size:.9rem}@media(max-width: 60em){header{padding:.8em 0}header li{margin:0 .8em}header ul{margin:0 2.2em}.theme-toggle.main-page-style,.language-toggle.main-page-style,.theme-toggle.content-page-style,.language-toggle.content-page-style{width:1.2em;height:1.2em;font-size:1.1em}}@media(max-width: 600px){#main-content,#main-content p,#main-content #projects-grid p{text-align:left}}@media screen and (min-height: 501px)and (max-height: 770px)and (min-width: 501px){#sidebar{height:90vh;display:flex;flex-direction:column;justify-content:center}#sidebar h2{margin-top:.2em;font-size:2em}#sidebar-navbar li{margin:.1em 0}#sidebar-logos{margin-bottom:1.5em;margin-top:0em}}@media screen and (min-height: 501px)and (max-height: 630px)and (min-width: 501px){#sidebar-bio{display:none}}@media screen and (max-width: 500px),screen and (max-height: 500px),screen and (pointer: none),screen and (pointer: coarse){header{display:flex;align-items:center;justify-content:space-between;padding:.8em .5em}header nav{flex:1}header ul{margin:0}header li{margin:0 .5em}.theme-toggle.content-page-style,.language-toggle.content-page-style{position:static;transform:none}#writings-directory{width:100%;margin-left:0}#writings-directory .writing-item{flex-direction:column;align-items:flex-start}#writings-directory .writing-meta{margin-top:.5em;text-align:left}#writing-filter-controls select{max-width:100%}#writing-filter-controls{margin-left:0}#container{flex-direction:column}#sidebar{display:block;background-color:var(--sidebar-color);color:var(--text-color);width:100%;position:static;border:none;margin:0 0 1em 0;font-size:1.05em;padding:1em .5em .5em 1em;border-radius:0em;height:100vh;max-height:none}#sidebar-logos{margin-bottom:1.5em}#main-content{text-align:justify}#sidebar-navbar{flex-grow:0}#sidebar-navbar ul{flex-direction:column;height:auto;justify-content:flex-start}#sidebar-navbar li{padding:10px 0;flex-grow:0}h1,h2,h3,h4,h5,h6{text-align:center}#projects-grid{grid-template-columns:1fr}}footer{background-color:var(--header-and-footer-color);font-size:1em;text-align:center;line-height:1.2;display:flex;justify-content:center;align-items:center;border-top:.2em solid var(--border-color);border-left:.2em solid var(--border-color);border-right:.2em solid var(--border-color);border-bottom:none;width:100%;margin:0 auto}footer p{color:#fff;padding:.3em 0}#last-updated{color:inherit}@media(max-width: 60em){#projects-grid{grid-template-columns:1fr;gap:20px}}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background-color:var(--sidebar-color)}::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:6px;border:3px solid var(--background-color)}pre code{display:block;overflow-x:auto;padding:1em;background:var(--hljs-background);color:var(--hljs-color);border-radius:.5em}.hljs-keyword{color:var(--hljs-keyword-color);font-weight:bold}.hljs-string{color:var(--hljs-string-color)}.hljs-comment{color:var(--hljs-comment-color);font-style:italic}.hljs-function{color:var(--hljs-function-color)}.dark-theme pre code{background:var(--hljs-background);color:var(--hljs-color)}.dark-theme .hljs-keyword{color:var(--hljs-keyword-color);font-weight:bold}.dark-theme .hljs-string{color:var(--hljs-string-color)}.dark-theme .hljs-comment{color:var(--hljs-comment-color);font-style:italic}.dark-theme .hljs-function{color:var(--hljs-function-color)}.hljs-copy-button{--hljs-theme-color: var(--hljs-color);--hljs-theme-background: var(--hljs-background)}.gallery.collage{display:flex;flex-direction:column;gap:10px}.collage-row{display:flex;gap:10px}.collage-row img{width:48%;height:auto;margin:0}.gallery.original-image{margin-bottom:20px}#projects-grid,.gallery{margin-block:2rem}.dark-theme .project-item{background:#111}#scroll-to-top-btn{position:fixed;bottom:40px;right:40px;width:50px;height:50px;background-color:var(--header-and-footer-color);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 6px rgba(0,0,0,.3);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:-1000}#scroll-to-top-btn.show{opacity:1;visibility:visible;z-index:1000}#scroll-to-top-btn:hover{background-color:var(--header-and-footer-color)}#scroll-to-top-btn i{color:#fff}#scroll-to-top-btn:hover i{color:var(--accent)}#writings-directory .writing-themes{font-size:.9em;margin-left:.25em;margin-top:.25em;color:#555}:root{--page-bg-top: #f9f2de;--page-bg-bottom: #f3e7c8;--surface-1: #fffaf0;--surface-2: #f8edd1;--surface-soft: #fffaf0;--text-color: #3b352b;--muted-text: #665f4f;--border-color: #d7c9a7;--border-strong: #b9a783;--accent: #857153;--accent-strong: #6f5e45;--accent-soft: #f4e7c4;--link-color: #4c6d8f;--link-hover-color: #385878;--link-visited-color: #71587a;--link-hover-bg: rgba(76, 109, 143, 0.14);--link-focus-ring: rgba(76, 109, 143, 0.36);--code-bg: #fff7e3;--code-fg: #3a342b;--code-border: #d5c39d;--code-keyword: #7b5297;--code-string: #5f7f47;--code-comment: #8b8373;--code-function: #385f83;--code-number: #9a5e3a;--code-type: #5f5f9d;--code-operator: #6f6a61}.dark-theme{--page-bg-top: #1b1f25;--page-bg-bottom: #161920;--surface-1: #21262f;--surface-2: #272d37;--surface-soft: #21262f;--text-color: #e2e7ee;--muted-text: #b7c0cb;--border-color: #606a78;--border-strong: #7d8898;--accent: #8c9aa8;--accent-strong: #758391;--accent-soft: #313843;--link-color: #b9cde0;--link-hover-color: #dde8f3;--link-visited-color: #d8c9e5;--link-hover-bg: rgba(185, 205, 224, 0.2);--link-focus-ring: rgba(185, 205, 224, 0.4);--code-bg: #1b222c;--code-fg: #d9e2ed;--code-border: #465264;--code-keyword: #c6a7e1;--code-string: #9fc990;--code-comment: #8e98a7;--code-function: #8cb5df;--code-number: #d3ae85;--code-type: #b4c4ef;--code-operator: #c3ccd7}body{background:linear-gradient(180deg, var(--page-bg-top), var(--page-bg-bottom)) !important}.wrapper{max-width:80rem;padding:.88rem .92rem 0}#container{max-width:80rem;gap:.96rem;grid-template-columns:minmax(15.8rem, 17.8rem) minmax(0, 1fr)}#sidebar,.wrapper #main-content,.contentHeader-placeholder header,#footer-placeholder footer,footer{border-radius:14px !important;border:1px solid var(--border-color) !important;background:var(--surface-1) !important}#sidebar{padding:1.02rem .92rem .92rem;gap:.6rem}#sidebar h2{margin-top:1.68rem;font-weight:600;font-size:clamp(1.32rem,2vw,1.76rem);line-height:1.14}#sidebar-my-current-status{font-size:.84rem;letter-spacing:.08em}#sidebar-bio{border:1px solid color-mix(in srgb, var(--border-color), #ffffff 12%);border-radius:10px;background:color-mix(in srgb, var(--surface-2), #ffffff 34%);padding:.4rem .62rem}#sidebar p{font-size:.78rem;line-height:1.52}#sidebar-logos ul{gap:.42rem}#sidebar-logos li a{width:1.84rem;height:1.84rem;border-radius:999px;border:1px solid var(--border-color);background:var(--surface-2);display:grid;place-items:center;padding:0}#sidebar-logos li:hover a,#sidebar-logos li:focus-within a{border-color:var(--border-strong);background:color-mix(in srgb, var(--surface-2), #ffffff 40%)}#sidebar-logos img.logo{max-width:.84rem;max-height:.84rem;margin:0}#sidebar-navbar{margin-top:.36rem}#sidebar-navbar ul{gap:.2rem}#sidebar-navbar li{border:0;background:rgba(0,0,0,0);padding:0;min-height:0}#sidebar-navbar a{display:block;border:1px solid rgba(0,0,0,0);border-radius:999px;padding:.42rem .58rem;font-size:.9rem;line-height:1.2;font-weight:600;color:var(--muted-text)}#sidebar-navbar a:hover,#sidebar-navbar a:focus{background:var(--accent-soft);border-color:var(--border-color);color:var(--text-color)}#sidebar-navbar a[aria-current=page]{background:var(--accent-soft);border-color:var(--border-color);color:var(--text-color)}.theme-toggle.main-page-style,.language-toggle.main-page-style,.theme-toggle.content-page-style,.language-toggle.content-page-style{width:1.8rem;height:1.8rem;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-color)}.contentHeader-placeholder{margin-bottom:.72rem}.contentHeader-placeholder header{padding:.48rem .64rem;gap:.56rem}header ul{gap:.28rem}header a{border:1px solid rgba(0,0,0,0);border-radius:999px;color:var(--muted-text);font-size:.88rem;padding:.34rem .66rem}header a:hover,header a:focus{background:var(--accent-soft);border-color:var(--border-color);color:var(--text-color);text-decoration:none}header a[aria-current=page]{background:var(--accent-soft);border-color:var(--border-color);color:var(--text-color)}.wrapper #main-content{padding:clamp(1.08rem,2.8vw,1.92rem)}.wrapper #main-content h1{font-size:clamp(2.04rem,4.4vw,3.02rem);font-weight:600;margin-bottom:.95rem;padding-bottom:.5rem}.wrapper #main-content h2{font-size:clamp(1.38rem,2.8vw,1.9rem);margin-top:1.42rem;margin-bottom:.46rem}.wrapper #main-content h3{font-size:clamp(1.12rem,2vw,1.36rem);margin-top:1.02rem;margin-bottom:.36rem}.wrapper #main-content :is(p,li,dd,blockquote,figcaption){color:var(--muted-text);line-height:1.68}.wrapper #main-content :is(p,ul,ol,blockquote){max-width:72ch}.wrapper #main-content p{margin-bottom:1.02rem}.content-image,.project-item img{border-radius:10px;border:1px solid color-mix(in srgb, var(--border-color), #ffffff 12%)}#projects-grid{gap:.86rem}.project-item{border-radius:14px;border:1px solid var(--border-color);background:linear-gradient(180deg, var(--surface-1), var(--surface-2))}.project-item:hover{border-color:var(--border-strong);background:color-mix(in srgb, var(--surface-2), #ffffff 34%)}.project-item a{padding:.88rem;gap:.56rem}.project-item h2{font-size:clamp(1.26rem,2.1vw,1.62rem);line-height:1.16}.project-item p{line-height:1.58}.directory-toolbar{gap:.62rem;grid-template-columns:repeat(auto-fit, minmax(12rem, 1fr));margin-bottom:.92rem}.toolbar-field label{font-size:.72rem;letter-spacing:.08em}.toolbar-field select,.toolbar-field input[type=search],#writing-filter-controls select{border-radius:8px;border:1px solid var(--border-color);background:var(--surface-2)}.directory-group,.directory-card,.directory-empty-state{border-radius:12px;border:1px solid var(--border-color)}.directory-group{padding:.82rem;background:var(--surface-1)}.directory-card{padding:.64rem .74rem;background:var(--surface-2)}.directory-card-title{color:var(--text-color)}.directory-card-title:hover,.directory-card-title:focus{color:var(--link-hover-color);text-decoration:none}.directory-badge{border:1px solid color-mix(in srgb, var(--border-color), #ffffff 8%);border-radius:999px;padding:.18rem .52rem;background:color-mix(in srgb, var(--surface-2), #ffffff 30%);color:var(--muted-text)}#writings-directory .writing-item{gap:.72rem}#writings-directory .writing-themes,.publication-meta,#writings-directory .explanatory-text{line-height:1.52}main#main-content[data-page=about-me] :is(p,li,dd,blockquote,figcaption) a,main#main-content:not([data-page]) :is(p,li,dd,blockquote,figcaption) a,#main-content a.content-link{color:var(--link-color) !important;text-decoration:none !important;border-radius:.2rem;padding:0 .08em;margin:0 -0.08em;box-decoration-break:clone;-webkit-box-decoration-break:clone;transition:color 120ms ease,background-color 120ms ease}main#main-content[data-page=about-me] :is(p,li,dd,blockquote,figcaption) a:hover,main#main-content[data-page=about-me] :is(p,li,dd,blockquote,figcaption) a:focus-visible,main#main-content:not([data-page]) :is(p,li,dd,blockquote,figcaption) a:hover,main#main-content:not([data-page]) :is(p,li,dd,blockquote,figcaption) a:focus-visible,#main-content a.content-link:hover,#main-content a.content-link:focus-visible{color:var(--link-hover-color) !important;text-decoration:none !important;background-color:var(--link-hover-bg);outline:1px solid rgba(0,0,0,0)}main#main-content[data-page=about-me] :is(p,li,dd,blockquote,figcaption) a:focus-visible,main#main-content:not([data-page]) :is(p,li,dd,blockquote,figcaption) a:focus-visible,#main-content a.content-link:focus-visible{outline-color:var(--link-focus-ring)}main#main-content[data-page=about-me] :is(p,li,dd,blockquote,figcaption) a:visited,main#main-content:not([data-page]) :is(p,li,dd,blockquote,figcaption) a:visited,#main-content a.content-link:visited{color:var(--link-visited-color) !important;text-decoration:none !important}#footer-placeholder footer,footer{border-radius:12px 12px 0 0 !important;margin-top:.78rem;padding:.38rem .72rem;background:var(--surface-2) !important}#footer-placeholder footer p,footer p{color:var(--muted-text);font-size:.84rem}#scroll-to-top-btn{width:2.34rem;height:2.34rem;right:.95rem;bottom:.95rem;border-radius:999px;border:1px solid var(--border-color);background:var(--surface-1)}#scroll-to-top-btn:hover{border-color:var(--border-strong);background:var(--surface-2)}#scroll-to-top-btn i{color:var(--muted-text)}@media(max-width: 58rem){.wrapper{padding:.56rem .56rem 0}#container{gap:.56rem;grid-template-columns:1fr}#sidebar{padding:.9rem .8rem .82rem;border-radius:12px !important}#sidebar h2{margin-top:1.48rem;font-size:clamp(1.46rem,7vw,1.82rem)}#sidebar p{font-size:.8rem}#sidebar-navbar a{font-size:1rem;padding:.42rem .56rem}.contentHeader-placeholder{top:.32rem;margin-bottom:.58rem}.contentHeader-placeholder header{padding:.42rem .5rem}header a{font-size:.82rem;padding:.3rem .56rem}.wrapper #main-content{border-radius:12px !important;padding:1rem .95rem 1.08rem}.wrapper #main-content h1{font-size:clamp(1.82rem,8.1vw,2.42rem)}.directory-toolbar{grid-template-columns:1fr}#scroll-to-top-btn{width:2.2rem;height:2.2rem;right:.78rem;bottom:.78rem}}#container{display:block !important;grid-template-columns:1fr !important;max-width:80rem}#sidebar-placeholder,#sidebar{display:none !important}pre code,.hljs{background:var(--code-bg) !important;color:var(--code-fg) !important;border:1px solid var(--code-border) !important;border-radius:10px !important;padding:1rem 1.05rem !important;line-height:1.58;box-shadow:none !important}.hljs-keyword,.hljs-selector-tag,.hljs-meta,.hljs-doctag{color:var(--code-keyword) !important;font-weight:600}.hljs-string,.hljs-attr,.hljs-template-tag,.hljs-template-variable{color:var(--code-string) !important}.hljs-comment,.hljs-quote{color:var(--code-comment) !important;font-style:italic}.hljs-function,.hljs-title,.hljs-title.function_,.hljs-title.class_{color:var(--code-function) !important}.hljs-number,.hljs-literal,.hljs-symbol,.hljs-bullet{color:var(--code-number) !important}.hljs-type,.hljs-built_in,.hljs-class .hljs-title{color:var(--code-type) !important}.hljs-operator,.hljs-punctuation{color:var(--code-operator) !important}.hljs-copy-button{--hljs-theme-color: var(--code-fg);--hljs-theme-background: var(--code-bg);border:1px solid var(--code-border) !important;border-radius:8px !important}.hljs-copy-button:hover{background:color-mix(in srgb, var(--code-bg), #ffffff 10%) !important}main#main-content[data-page=projects] #projects-grid{grid-template-columns:repeat(2, minmax(0, 1fr)) !important}@media(max-width: 58rem){main#main-content[data-page=projects] #projects-grid{grid-template-columns:1fr !important}}.contentHeader-placeholder header{display:grid !important;grid-template-columns:auto minmax(0, 1fr) auto !important;align-items:center;column-gap:.56rem}.contentHeader-placeholder header nav{min-width:0}.contentHeader-placeholder header ul{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.22rem;margin:0 !important;padding:0}.contentHeader-placeholder header li{display:block;margin:0}.contentHeader-placeholder .theme-toggle.content-page-style,.contentHeader-placeholder .language-toggle.content-page-style{position:static !important;top:auto !important;right:auto !important;left:auto !important;transform:none !important;margin:0 !important;line-height:1;align-self:center;justify-self:auto}.contentHeader-placeholder .theme-toggle.content-page-style{justify-self:start}.contentHeader-placeholder .language-toggle.content-page-style{justify-self:end}.contentHeader-placeholder .theme-toggle.content-page-style:hover,.contentHeader-placeholder .theme-toggle.content-page-style:focus,.contentHeader-placeholder .theme-toggle.content-page-style:focus-visible,.contentHeader-placeholder .theme-toggle.content-page-style:active,.contentHeader-placeholder .language-toggle.content-page-style:hover,.contentHeader-placeholder .language-toggle.content-page-style:focus,.contentHeader-placeholder .language-toggle.content-page-style:focus-visible,.contentHeader-placeholder .language-toggle.content-page-style:active{transform:none !important}.contentHeader-placeholder .theme-toggle.content-page-style i,.contentHeader-placeholder .language-toggle.content-page-style i{width:1em;height:1em;line-height:1;display:grid;place-items:center;pointer-events:none}.language-toggle.main-page-style i.language-english,.language-toggle.main-page-style i.language-chinese,.contentHeader-placeholder .language-toggle.content-page-style i.language-english,.contentHeader-placeholder .language-toggle.content-page-style i.language-chinese{width:max-content;min-width:1em}.section-intro{max-width:74ch;margin:0 auto 1rem}.content-crosslinks{max-width:74ch;margin:1.2rem auto 0}.content-crosslinks h2{margin-top:0}.wrapper #main-content{max-width:78rem;margin-inline:auto}main#main-content[data-page=about-me],main#main-content:not([data-page]){--copy-measure: 72ch;--media-measure: 86ch}main#main-content[data-page=about-me]>h1,main#main-content:not([data-page])>h1,main#main-content:not([data-page])>section{max-width:var(--media-measure);margin-left:auto;margin-right:auto}main#main-content[data-page=about-me]>:is(p,h2,h3,ul,ol,blockquote),main#main-content:not([data-page])>:is(p,h2,h3,ul,ol,blockquote),main#main-content:not([data-page]) section>:is(p,h2,h3,ul,ol,blockquote){max-width:var(--copy-measure);margin-left:auto;margin-right:auto}main#main-content[data-page=about-me]>:is(pre,.gallery,figure,.content-image),main#main-content:not([data-page])>:is(pre,.gallery,figure,.content-image),main#main-content:not([data-page]) section>:is(pre,.gallery,figure,.content-image){max-width:var(--media-measure);margin-left:auto;margin-right:auto}main#main-content[data-page=about-me] .content-image,main#main-content:not([data-page]) .content-image{width:100%;height:auto}.writing-dummy-figure{margin-top:1.35rem;margin-bottom:1.55rem}.writing-dummy-media{display:block;width:100%;padding:0;border:0;background:rgba(0,0,0,0)}.writing-dummy-image{aspect-ratio:2339/1559;object-fit:cover;margin:0}.writing-dummy-figure figcaption{margin-top:.45rem;color:var(--muted-text) !important;font-size:.9rem}.writing-video-figure{margin-top:1.35rem;margin-bottom:1.55rem}.writing-video-frame{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--border-color);background:var(--surface-2)}.writing-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.writing-video-figure figcaption{margin-top:.45rem;color:var(--muted-text) !important;font-size:.9rem}main#main-content[data-page=projects] #projects-grid{max-width:66rem;margin-left:auto;margin-right:auto;align-items:start}main#main-content[data-page=projects] .project-item a{display:grid;grid-template-rows:auto 1fr auto;gap:.66rem;height:100%}main#main-content[data-page=projects] .project-item p{max-width:none !important;margin:0}main#main-content[data-page=projects] .project-item img{width:100%;height:clamp(10.5rem,18vw,13rem);object-fit:cover}@media(max-width: 58rem){main#main-content[data-page=about-me],main#main-content:not([data-page]){--copy-measure: 100%;--media-measure: 100%}main#main-content[data-page=projects] #projects-grid{max-width:100%}}main#main-content[data-page=about-me] :is(h1,h2,h3),main#main-content:not([data-page]) :is(h1,h2,h3){text-wrap:balance;letter-spacing:-0.01em}main#main-content[data-page=about-me]>h1,main#main-content:not([data-page])>h1{max-width:min(28ch,var(--copy-measure));margin-left:auto;margin-right:auto}main#main-content[data-page=about-me] h1,main#main-content:not([data-page]) h1{font-size:clamp(1.84rem,3.35vw,2.58rem);line-height:1.1;margin-bottom:.78rem;padding-bottom:.42rem}main#main-content[data-page=about-me] h2,main#main-content:not([data-page]) h2{font-size:clamp(1.3rem,2.15vw,1.68rem);line-height:1.2;margin-top:1.22rem;margin-bottom:.42rem}main#main-content[data-page=about-me] h3,main#main-content:not([data-page]) h3{font-size:clamp(1.08rem,1.6vw,1.28rem);line-height:1.24;margin-top:.92rem;margin-bottom:.28rem}@media(max-width: 58rem){main#main-content[data-page=about-me] h1,main#main-content:not([data-page]) h1{font-size:clamp(1.62rem,7.2vw,2.08rem)}main#main-content[data-page=about-me] h2,main#main-content:not([data-page]) h2{font-size:clamp(1.18rem,5.2vw,1.44rem)}main#main-content[data-page=about-me] h3,main#main-content:not([data-page]) h3{font-size:clamp(1.02rem,4.5vw,1.2rem)}}@media(max-width: 58rem){html,body{overflow-x:clip}.wrapper{max-width:100%;padding:.5rem .5rem 0;gap:.5rem}#container{max-width:100%;display:block !important}.contentHeader-placeholder{position:sticky;top:.3rem;z-index:120;margin-bottom:.5rem}.contentHeader-placeholder header{grid-template-columns:2rem minmax(0, 1fr) 2rem !important;column-gap:.36rem;row-gap:0;padding:.4rem .42rem;border-radius:12px !important}.contentHeader-placeholder .theme-toggle.content-page-style,.contentHeader-placeholder .language-toggle.content-page-style{width:1.72rem;height:1.72rem;min-width:1.72rem;min-height:1.72rem;border-radius:999px}.contentHeader-placeholder header nav{min-width:0;overflow:hidden}.contentHeader-placeholder header ul{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;white-space:nowrap;gap:.12rem;padding:0 .24rem;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.contentHeader-placeholder header ul::-webkit-scrollbar{display:none}.contentHeader-placeholder header li{flex:0 0 auto;scroll-snap-align:start}header a{display:inline-block;font-size:.82rem;line-height:1.1;padding:.3rem .54rem;border-radius:999px}.wrapper #main-content{border-radius:12px !important;padding:.98rem .86rem 1.05rem}.wrapper #main-content :is(p,li,dd,blockquote,figcaption){line-height:1.62}.wrapper #main-content p{margin-bottom:.92rem}.section-intro,.content-crosslinks{max-width:100%;margin-left:0;margin-right:0}#projects-grid{gap:.62rem}main#main-content[data-page=projects] .project-item,.directory-group,.directory-card,.directory-empty-state{border-radius:10px}main#main-content[data-page=projects] .project-item a{padding:.76rem;gap:.52rem}main#main-content[data-page=projects] .project-item img{height:clamp(8.9rem,46vw,10.8rem)}.directory-toolbar{grid-template-columns:1fr !important;gap:.5rem;margin-bottom:.74rem}.toolbar-field select,.toolbar-field input[type=search],#writing-filter-controls select{min-height:2.25rem}#writings-directory .writing-item{grid-template-columns:1fr !important;gap:.48rem}#writings-directory .date{text-align:left}pre code,.hljs{padding:.84rem .88rem !important;border-radius:8px !important;font-size:.91rem}.gallery.collage .collage-row{flex-direction:column;gap:.55rem}.collage-row img{width:100%}#scroll-to-top-btn{width:2.08rem;height:2.08rem;right:.66rem;bottom:.66rem}}@media(max-width: 40rem){.wrapper{padding:.42rem .4rem 0}.contentHeader-placeholder header{grid-template-columns:1.9rem minmax(0, 1fr) 1.9rem !important;padding:.34rem .34rem}.contentHeader-placeholder .theme-toggle.content-page-style,.contentHeader-placeholder .language-toggle.content-page-style{width:1.62rem;height:1.62rem;min-width:1.62rem;min-height:1.62rem}header a{font-size:.78rem;padding:.27rem .46rem}.wrapper #main-content{padding:.9rem .74rem .98rem}main#main-content[data-page=projects] .project-item img{height:clamp(8.2rem,50vw,9.8rem)}main#main-content[data-page=about-me] h1,main#main-content:not([data-page]) h1{font-size:clamp(1.48rem,8.3vw,1.92rem)}main#main-content[data-page=about-me] h2,main#main-content:not([data-page]) h2{font-size:clamp(1.12rem,6vw,1.34rem)}}.contentHeader-placeholder .nav-toggle{display:none}@media(max-width: 58rem){.contentHeader-placeholder header{grid-template-columns:2rem 2rem 1fr 2rem !important}.contentHeader-placeholder .theme-toggle.content-page-style{grid-column:1}.contentHeader-placeholder .nav-toggle{grid-column:2;display:grid;place-items:center;width:1.72rem;height:1.72rem;min-width:1.72rem;min-height:1.72rem;border-radius:999px;border:1px solid var(--border-color);background:var(--surface-2);color:var(--muted-text);cursor:pointer;line-height:1;-webkit-appearance:none;appearance:none}.contentHeader-placeholder .nav-toggle:hover,.contentHeader-placeholder .nav-toggle:focus-visible{border-color:var(--border-strong);background:var(--accent-soft);color:var(--text-color);outline:none}.contentHeader-placeholder .language-toggle.content-page-style{grid-column:4}.contentHeader-placeholder header nav{position:absolute;top:calc(100% + .34rem);left:0;right:0;z-index:130;display:none;background:var(--surface-1);border:1px solid var(--border-color);border-radius:12px;padding:.38rem}.contentHeader-placeholder header.nav-open nav{display:block}.contentHeader-placeholder header ul{display:grid;grid-template-columns:1fr;gap:.2rem;overflow:visible;white-space:normal;padding:0;margin:0 !important}.contentHeader-placeholder header li{width:100%}header a{display:block;width:100%;text-align:center;padding:.34rem .54rem}}@media(max-width: 40rem){.contentHeader-placeholder header{grid-template-columns:1.9rem 1.9rem 1fr 1.9rem !important}.contentHeader-placeholder .nav-toggle{width:1.62rem;height:1.62rem;min-width:1.62rem;min-height:1.62rem}}:root{--page-bg-top: #eef3f5;--page-bg-bottom: #f7f4ee;--surface-1: #fbfcfb;--surface-2: #eef4f5;--surface-3: #f6f8f6;--surface-soft: #edf3f5;--text-color: #1f2933;--muted-text: #4c5a66;--border-color: #c8d4da;--border-strong: #78909c;--accent: #2f6377;--accent-strong: #1e4d60;--accent-soft: #dcecef;--accent-warm: #a7633d;--accent-green: #426f5b;--link-color: #245f89;--link-hover-color: #174761;--link-visited-color: #6b5d8f;--link-hover-bg: rgba(36, 95, 137, 0.12);--link-focus-ring: rgba(36, 95, 137, 0.36);--code-bg: #17212b;--code-fg: #e7eef3;--code-border: #314352;--code-keyword: #b9d6ff;--code-string: #9fd3ad;--code-comment: #9aa9b4;--code-function: #f0c987;--code-number: #f1a37a;--code-type: #c8b9ff;--code-operator: #cbd5df}.dark-theme{--page-bg-top: #101820;--page-bg-bottom: #141b22;--surface-1: #18222c;--surface-2: #202c36;--surface-3: #151f28;--surface-soft: #1c2a34;--text-color: #ecf2f6;--muted-text: #b8c6cf;--border-color: #435765;--border-strong: #6f8797;--accent: #8bb9c6;--accent-strong: #c0dbe3;--accent-soft: #263c47;--accent-warm: #d39a75;--accent-green: #92c0a9;--link-color: #b5d8ee;--link-hover-color: #e2f2fb;--link-visited-color: #d4c8f1;--link-hover-bg: rgba(181, 216, 238, 0.16);--link-focus-ring: rgba(181, 216, 238, 0.42)}*{letter-spacing:0 !important}html,body{min-height:100%;background:linear-gradient(180deg, var(--page-bg-top) 0%, #f9faf8 42%, var(--page-bg-bottom) 100%) !important}body{color:var(--text-color)}a{color:var(--link-color);text-decoration-thickness:1px;text-underline-offset:.16rem}a:hover,a:focus-visible{color:var(--link-hover-color)}a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,.lightbox-trigger:focus-visible{outline:2px solid var(--link-focus-ring) !important;outline-offset:3px !important}.lightbox{display:none;position:fixed;z-index:1000;inset:0;width:100%;height:100%;background-color:rgba(0,0,0,.8);justify-content:center;align-items:center}.lightbox.is-open{display:flex}img.lightbox-content,video.lightbox-content{max-width:90%;max-height:90%;box-sizing:border-box;margin:0;border-radius:10px;box-shadow:0 16px 40px rgba(0,0,0,.4)}.lightbox-close{position:absolute;top:20px;right:30px;color:#fff;font-size:30px;font-weight:bold;cursor:pointer;z-index:1001;background:rgba(0,0,0,0);border:0;padding:0;line-height:1;-webkit-appearance:none;appearance:none}.lightbox-close:hover,.lightbox-close:focus{color:#ccc;text-decoration:none}.lightbox-caption{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:#fff;font-size:18px;text-align:center;max-width:90%;padding:.2em .6em;word-wrap:break-word;background:rgba(0,0,0,.35);border-radius:6px}.lightbox-help{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);color:#fff;font-size:14px;text-align:center}.lightbox-trigger{cursor:pointer}@media only screen and (max-width: 700px){.lightbox-close{font-size:25px;top:15px;right:20px}.lightbox-caption{font-size:16px;bottom:20px;max-width:95%}.lightbox-help{font-size:12px;bottom:5px}}.wrapper{max-width:82rem;padding:1rem 1rem 0;gap:.9rem;background:rgba(0,0,0,0) !important}#container{max-width:82rem;background:rgba(0,0,0,0) !important}.contentHeader-placeholder{margin-bottom:.2rem}.contentHeader-placeholder header{border-radius:8px !important;border:1px solid var(--border-color) !important;background:rgba(251,252,251,.92) !important;box-shadow:0 10px 28px rgba(31,41,51,.08);backdrop-filter:blur(10px)}.dark-theme .contentHeader-placeholder header{background:rgba(24,34,44,.92) !important}.theme-toggle.main-page-style,.language-toggle.main-page-style,.theme-toggle.content-page-style,.language-toggle.content-page-style,.contentHeader-placeholder .nav-toggle{border-radius:999px;border:1px solid var(--border-color);background:var(--surface-2);color:var(--text-color)}.theme-toggle.main-page-style i,.language-toggle.main-page-style i,.theme-toggle.content-page-style i,.language-toggle.content-page-style i,.contentHeader-placeholder .nav-toggle i{color:var(--text-color)}header a{color:var(--muted-text);font-size:.92rem;line-height:1.15;border-radius:999px}header a:hover,header a:focus-visible,header a[aria-current=page]{color:var(--text-color);background:var(--accent-soft);border-color:var(--border-color);text-decoration:none}.wrapper #main-content{max-width:82rem;width:100%;padding:2.2rem 1.8rem 2.6rem;margin-inline:auto;border:0 !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;box-shadow:none !important}.wrapper #main-content h1{font-size:2.9rem !important;line-height:1.05;font-weight:700;border-bottom:0;padding-bottom:0;margin-bottom:.9rem}.wrapper #main-content h2{font-size:1.58rem !important;line-height:1.2;margin-top:0}.wrapper #main-content h3{font-size:1.18rem !important;line-height:1.25}#main-content p,#main-content li,#main-content dd,#main-content figcaption{text-align:left !important}.wrapper #main-content :is(p,li,dd,blockquote,figcaption){color:var(--muted-text);line-height:1.64}.section-label,.project-kicker,.project-card-status{color:var(--accent-strong) !important;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.78rem !important;font-weight:700;line-height:1.2 !important;margin:0 0 .42rem !important;text-transform:uppercase}.section-heading{max-width:58rem;margin-bottom:1rem}.section-intro{max-width:62ch;margin:0 0 1.2rem}.button-link{display:inline-flex;align-items:center;justify-content:center;min-height:2.55rem;padding:.55rem .9rem;border:1px solid var(--border-color);border-radius:999px;background:var(--surface-1);color:var(--text-color) !important;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;text-decoration:none !important}.button-link:hover,.button-link:focus-visible{border-color:var(--border-strong);background:var(--accent-soft)}.button-link.primary{border-color:var(--accent);background:var(--accent);color:#fff !important}.button-link.primary:hover,.button-link.primary:focus-visible{background:var(--accent-strong)}.home-page{display:grid;gap:2rem}.home-hero{display:grid;grid-template-columns:minmax(0, 1.05fr) minmax(20rem, 0.95fr);gap:1.6rem;align-items:center;padding:1.5rem 0 1.2rem;border-bottom:1px solid var(--border-color)}.home-hero-copy{max-width:44rem}.home-lede{font-size:1.14rem;max-width:61ch !important}.home-actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.home-visual{min-height:23rem;border:1px solid var(--border-color);border-radius:8px;background:linear-gradient(145deg, rgba(47, 99, 119, 0.95), rgba(31, 41, 51, 0.96)),var(--accent);color:#fff;padding:1rem;box-shadow:0 24px 60px rgba(31,41,51,.16);display:grid;grid-template-rows:auto 1fr auto;overflow:hidden}.home-visual-header,.home-visual-stats{display:flex;justify-content:space-between;gap:.5rem;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.84rem;font-weight:700}.home-visual-header span,.home-visual-stats span{color:#fff}.home-visual-mesh{align-self:center;display:grid;grid-template-columns:repeat(5, 1fr);gap:.32rem;transform:skewY(-8deg)}.home-visual-mesh span{aspect-ratio:1;border:1px solid hsla(0,0%,100%,.36);background:linear-gradient(135deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.04))}.home-visual-mesh span:nth-child(4n),.home-visual-mesh span:nth-child(7),.home-visual-mesh span:nth-child(12){background:linear-gradient(135deg, rgba(230, 169, 103, 0.9), rgba(255, 255, 255, 0.12))}.home-focus-grid,.project-section-grid,.resume-summary-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:.9rem}.home-focus-grid article,.project-section-grid article,.directory-card,.project-item,.resume-summary-grid article,.publications-status{border:1px solid var(--border-color);border-radius:8px !important;background:var(--surface-1);box-shadow:0 12px 32px rgba(31,41,51,.07)}.home-focus-grid article,.project-section-grid article,.resume-summary-grid article{padding:1rem}.home-writing-note{display:block;padding-top:.4rem}.home-contact{max-width:62ch;padding-top:.4rem}.home-contact p{font-size:1.05rem}main#main-content[data-page=projects] #projects-grid{max-width:76rem;grid-template-columns:repeat(2, minmax(0, 1fr)) !important;gap:1rem}main#main-content[data-page=projects] .project-item{overflow:hidden;transition:transform 160ms ease,box-shadow 160ms ease,border-color 160ms ease}main#main-content[data-page=projects] .project-item:hover,main#main-content[data-page=projects] .project-item:focus-within{border-color:var(--border-strong);box-shadow:0 18px 42px rgba(31,41,51,.12);transform:translateY(-3px)}main#main-content[data-page=projects] .project-item a{display:grid;grid-template-rows:auto 1fr;gap:0;padding:0;height:100%;background:rgba(0,0,0,0) !important;box-shadow:none !important;text-decoration:none !important}.project-card-media{background:var(--surface-2);border-bottom:1px solid var(--border-color)}main#main-content[data-page=projects] .project-item img{width:100%;height:auto;aspect-ratio:5/3;object-fit:cover;margin:0;border:0;border-radius:0;box-shadow:none}.project-card-body{display:grid;align-content:start;gap:.54rem;padding:1rem}.project-card-body h2{margin:0 !important;font-size:1.55rem !important;text-align:left !important}.project-card-summary{margin:0 !important;max-width:none !important}.project-card-tags{display:flex;flex-wrap:wrap;gap:.35rem;list-style:none;padding:0;margin:.2rem 0 0}.project-card-tags li{border:1px solid var(--border-color);border-radius:999px;background:var(--surface-2);color:var(--muted-text);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.78rem;line-height:1.2;padding:.24rem .48rem}.directory-toolbar{display:grid !important;grid-template-columns:repeat(3, minmax(0, 1fr));gap:.75rem;padding:0;border:0;border-radius:0;background:rgba(0,0,0,0);box-shadow:none}.directory-toolbar .toolbar-field{display:grid;gap:.32rem;min-width:0}.directory-toolbar label{color:var(--accent-strong);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.82rem;font-weight:700}.toolbar-field select,.toolbar-field input[type=search],#writing-filter-controls select{width:100%;min-height:2.45rem;border-radius:8px;border:1px solid var(--border-color);background:var(--surface-1);color:var(--text-color);padding:.45rem .62rem}.directory-group{border:0;padding:0;background:rgba(0,0,0,0)}.directory-group>h2{margin:1.2rem 0 .6rem}.directory-list{gap:.75rem}.directory-card{padding:.95rem 1rem}.directory-card:hover,.directory-card:focus-within{transform:none;border-color:var(--border-strong);box-shadow:0 16px 36px rgba(31,41,51,.1)}#writings-directory{margin-left:0}#writings-directory .writing-item{display:grid;grid-template-columns:minmax(0, 1fr) auto;gap:1rem;border-bottom:0}#writings-directory a{font-size:1.35rem;color:var(--link-color)}#writings-directory .explanatory-text{font-style:normal}#writings-directory .date{color:var(--muted-text)}.publications-status{max-width:48rem;padding:1.1rem}.publications-status h2{margin-bottom:.45rem}.publication-status-links{display:flex;gap:.55rem;margin:.65rem 0 0 !important}.publication-status-links a{display:inline-flex;border:1px solid var(--border-color);border-radius:999px;padding:.32rem .62rem;background:var(--surface-2);text-decoration:none !important}.project-detail-page{display:grid;gap:1.6rem}.project-detail-page>section{max-width:76rem !important;width:100%;margin-inline:auto !important}.project-hero{display:grid;grid-template-columns:minmax(0, 0.95fr) minmax(21rem, 1.05fr);gap:1.4rem;align-items:center;padding-bottom:1.2rem;border-bottom:1px solid var(--border-color)}.project-lede{font-size:1.1rem;max-width:62ch !important}.project-facts{display:grid;gap:.6rem;margin:1rem 0 0}.project-facts div{border-left:3px solid var(--accent);padding-left:.75rem}.project-facts dt{color:var(--text-color);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.82rem;font-weight:800;margin-bottom:.15rem}.project-facts dd{margin:0}.project-figure{margin:0}.project-figure .content-image{width:100%;margin:0;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 20px 48px rgba(31,41,51,.14)}.project-figure figcaption{margin-top:.5rem;font-size:.9rem}.project-section-grid{grid-template-columns:repeat(3, minmax(0, 1fr))}.process-list{display:grid;gap:.65rem;max-width:72ch;padding-left:0;list-style:none;counter-reset:process}.process-list li{counter-increment:process;position:relative;padding:.85rem .85rem .85rem 3.2rem;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-1)}.process-list li::before{content:counter(process);position:absolute;left:.85rem;top:.9rem;width:1.65rem;height:1.65rem;border-radius:999px;display:grid;place-items:center;background:var(--accent);color:#fff;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.82rem;font-weight:800}.process-list span{display:block;color:var(--text-color);font-weight:800}pre code,.hljs{border-radius:8px !important;max-width:100%}.content-crosslinks{border-top:1px solid var(--border-color);padding-top:1rem}#footer-placeholder footer,footer{border-radius:8px 8px 0 0 !important;border:1px solid var(--border-color) !important;background:var(--surface-1) !important}#footer-placeholder footer p,footer p{color:var(--muted-text)}@media(max-width: 58rem){.wrapper{padding:.55rem .55rem 0}.wrapper #main-content{padding:1.15rem .2rem 1.5rem}.wrapper #main-content h1{font-size:2.05rem !important;line-height:1.08}.wrapper #main-content h2{font-size:1.36rem !important}.home-hero,.home-writing-note,.project-hero{grid-template-columns:1fr}.project-detail-page,.project-detail-page>section,.project-hero,.project-hero-copy,.project-figure,.project-section-grid,.project-section-grid article,.process-list,.process-list li,pre,pre code{min-width:0;max-width:100% !important}pre{overflow-x:auto}pre code,.hljs{white-space:pre-wrap;overflow-wrap:anywhere}.home-image{display:none}.home-hero{padding-top:.4rem}.home-visual{min-height:17rem}.home-focus-grid,.project-section-grid,.resume-summary-grid,main#main-content[data-page=projects] #projects-grid{grid-template-columns:1fr !important}.directory-toolbar{grid-template-columns:1fr}#writings-directory .writing-item{grid-template-columns:1fr}#writings-directory .date{text-align:left;margin-left:0}.project-section-grid{gap:.7rem}.project-facts{gap:.5rem}}@media(max-width: 40rem){.wrapper{padding:.45rem .4rem 0}.wrapper #main-content{padding:1rem .05rem 1.3rem}.home-lede,.project-lede{font-size:1rem}.button-link{width:100%}}[hidden]{display:none !important}:root{--page-bg-top: #ffffff;--page-bg-bottom: #ffffff;--surface-1: #ffffff;--surface-2: #f6f8f7;--surface-3: #fbfcfb;--surface-soft: #f1f6f4;--text-color: #1f2421;--muted-text: #56615b;--border-color: #d6ddd8;--border-strong: #8b9b92;--accent: #2f5d50;--accent-strong: #21463c;--accent-soft: #edf5f1;--link-color: #2f5d50;--link-hover-color: #21463c;--link-visited-color: #4d665e;--link-focus-ring: rgba(47, 93, 80, 0.34)}.dark-theme{--page-bg-top: #161616;--page-bg-bottom: #161616;--surface-1: #161616;--surface-2: #202020;--surface-3: #1b1b1b;--surface-soft: #202020;--text-color: #f2f2f2;--muted-text: #c4c4c4;--border-color: #4a4a4a;--border-strong: #888888;--accent: #8ab3a5;--accent-strong: #c2ddd5;--accent-soft: #1f2a27;--link-color: #9bc8e2;--link-hover-color: #cde8f7;--link-visited-color: #cabde5;--link-focus-ring: rgba(155, 200, 226, 0.42)}html,body{background:var(--background-color) !important}.wrapper,#container{max-width:76rem !important}.wrapper{padding:.7rem 1rem 0 !important}.contentHeader-placeholder header,#footer-placeholder footer,footer{border-radius:0 !important;box-shadow:none !important;backdrop-filter:none !important}.contentHeader-placeholder header{background:var(--surface-1) !important;border-width:0 0 1px !important}header a:hover,header a:focus-visible,header a[aria-current=page]{background:rgba(0,0,0,0) !important;border-color:rgba(0,0,0,0) !important;text-decoration:underline;text-underline-offset:.18rem}.wrapper #main-content{max-width:min(100%,44rem) !important;padding:2rem 0 2.4rem !important}.wrapper #main-content h1{font-family:"Playfair Display",serif;font-size:clamp(2rem,4vw,2.55rem) !important;margin-bottom:.75rem}.wrapper #main-content :is(h2,h3){font-family:var(--font-family-base);font-weight:700;letter-spacing:0}.wrapper #main-content h2{font-size:1.16rem !important;line-height:1.34}.wrapper #main-content h3{font-size:1.02rem !important;line-height:1.38}.wrapper #main-content :is(h1,h2,h3,h4,h5,h6){text-align:left !important}main#main-content:not([data-page]) p:not(.project-kicker),main#main-content:not([data-page]) li{font-family:var(--font-family-base) !important}.home-page{display:block !important}.wrapper #main-content.home-page{max-width:min(100%,66rem) !important;padding-bottom:1.35rem !important}.home-intro{max-width:min(100%,66rem);margin-inline:auto;padding:.6rem 0 1.6rem;border-bottom:1px solid var(--border-color)}.home-visual{display:none !important}.home-writing-note,.home-contact{max-width:min(100%,66rem);margin:1.6rem auto 0}.project-note-grid article{border:0 !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;padding:0 !important;box-shadow:none !important}.home-directory-title{font-weight:700}.home-directory{display:grid;gap:0;border-top:1px solid var(--border-color)}.home-directory-row{display:grid;grid-template-columns:minmax(8rem, 11rem) minmax(0, 1fr);gap:1.1rem;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.home-writing-row{grid-template-columns:minmax(5.2rem, 7rem) minmax(0, 1fr) minmax(11rem, 16rem);align-items:start;gap:1.25rem}.home-directory-body{display:grid;gap:.35rem;min-width:0}.home-directory-title{align-self:start;font-size:1.05rem;line-height:1.35;overflow-wrap:anywhere}.home-directory-summary,.home-directory-meta{margin:0 !important;max-width:none !important}.home-directory-meta,.home-directory-date,.home-directory-date .date{color:var(--muted-text) !important;font-size:.9rem}.home-directory-date .date{margin:0 !important;text-align:left !important}.home-directory-date .month-day,.home-directory-date .year{display:block}.home-writing-note{display:block !important}.home-writing-preview{display:block;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:var(--surface-1);aspect-ratio:4/3;align-self:start}.home-writing-preview:hover,.home-writing-preview:focus-visible{border-color:var(--link-color);text-decoration:none}.home-writing-preview:focus-visible{outline:2px solid var(--link-focus-ring);outline-offset:2px}.home-writing-preview img{width:100%;height:100%;margin:0;object-fit:cover;transform:scale(1.001);transition:transform .18s ease}.home-writing-preview:hover img,.home-writing-preview:focus-visible img{transform:scale(1.035)}@media(prefers-reduced-motion: reduce){.home-writing-preview img{transition:none}.home-writing-preview:hover img,.home-writing-preview:focus-visible img{transform:none}}.home-writing-preview:visited{color:inherit}.home-contact{margin-top:.65rem;padding-top:0}.home-contact p{margin-bottom:0 !important;color:var(--muted-text)}main#main-content[data-page=projects] #projects-grid{display:grid;grid-template-columns:1fr !important;gap:0;max-width:min(100%,48rem);margin-inline:auto;border-top:1px solid var(--border-color)}main#main-content[data-page=projects] .project-item{border:0 !important;border-bottom:1px solid var(--border-color) !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;overflow:visible;transition:none;box-shadow:none !important}main#main-content[data-page=projects] .project-item:hover,main#main-content[data-page=projects] .project-item:focus-within{border-color:var(--border-color) !important;box-shadow:none !important;transform:none !important}main#main-content[data-page=projects] .project-item a{display:block !important;padding:1rem 0 !important}.project-card-media,main#main-content[data-page=projects] .project-item img{display:none !important}.project-card-body{display:grid;gap:.4rem;padding:0 !important}.project-card-body h2{font-size:1.25rem !important}.project-card-summary{max-width:76ch !important}.project-card-metadata{color:var(--muted-text) !important;font-size:.92rem;margin:0 !important;max-width:none !important}.project-card-tags{display:none !important}main#main-content[data-page=projects],main#main-content.project-detail-page{max-width:min(100%,48rem) !important}.project-note-header,.project-note-grid,.project-detail-page>section,.content-crosslinks{max-width:min(100%,48rem) !important;margin-inline:auto !important}.project-note-header{padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.project-note-grid{display:grid;gap:1rem}.project-note-grid article{padding-top:.85rem !important;border-top:1px solid var(--border-color) !important}.project-facts{grid-template-columns:1fr !important;max-width:64ch}.project-facts div{border-left:2px solid var(--border-color)}.compact-list{padding-left:1.2rem}main#main-content.resume-page{max-width:56rem !important;padding-top:.8rem !important}.resume-pdf-only{display:grid;gap:.55rem;width:100%}.resume-sheet-link{display:block;width:min(100%,52rem);margin-inline:auto}.resume-sheet{display:block;width:100%;height:auto;margin:0;border:0;border-radius:0;box-shadow:none;background:#fff}.resume-actions,.resume-fallback{width:min(100%,52rem);max-width:52rem !important;margin:0 !important;margin-inline:auto !important;font-size:.92rem;text-align:left !important}.resume-actions{display:flex;flex-wrap:wrap;gap:.5rem}.resume-action{display:inline-flex;align-items:center;justify-content:center;min-height:2.35rem;padding:.55rem .95rem;border:1px solid var(--border-color);border-radius:.35rem;font-weight:700;line-height:1.2;text-decoration:none !important}.resume-action-primary{border-color:var(--accent-strong);background:var(--accent-strong);color:#fff !important}.resume-action-primary:hover,.resume-action-primary:focus-visible{background:var(--accent);border-color:var(--accent);color:#fff !important}.resume-action-secondary{background:var(--surface-1);color:var(--link-color) !important}.resume-action-secondary:hover,.resume-action-secondary:focus-visible{border-color:var(--border-strong);background:var(--accent-soft);color:var(--link-hover-color) !important}#footer-placeholder footer,footer{max-width:min(100%,44rem);border-width:1px 0 0 !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;margin:.8rem auto 0;padding:.55rem 0 0}main#main-content[data-page=writings],main#main-content[data-page=publications]{max-width:min(100%,46rem) !important}main#main-content[data-page=writings] .section-intro,main#main-content[data-page=publications] .section-intro,#writings-directory,.publications-status{max-width:min(100%,46rem) !important;margin-left:auto !important;margin-right:auto !important}#writings-directory .writing-item{border:0 !important;border-top:1px solid var(--border-color) !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;box-shadow:none !important;align-items:start !important;justify-content:start !important;row-gap:.45rem;padding:1rem 0 !important;text-align:left !important}#writings-directory .writing-item:last-child{border-bottom:1px solid var(--border-color) !important}#writings-directory a,#writings-directory .explanatory-text,#writings-directory .writing-themes,#writings-directory .writing-meta,#writings-directory .date{text-align:left !important}#writings-directory .explanatory-text,#writings-directory .writing-themes{margin:.45rem 0 0 !important}#writings-directory .writing-meta{margin-top:.2rem !important}#writings-directory .date{margin-top:0 !important}.publications-status,.directory-empty-state{border-width:1px 0 !important;border-radius:0 !important;background:rgba(0,0,0,0) !important;box-shadow:none !important}#footer-placeholder footer p,footer p{color:var(--muted-text);font-size:.82rem;padding:0}@media(max-width: 58rem){.wrapper{padding:.45rem .75rem 0 !important}.wrapper #main-content{padding:1.25rem 0 1.8rem !important}.home-writing-row{grid-template-columns:minmax(4.4rem, 5.2rem) minmax(0, 1fr) minmax(7.5rem, 9.5rem);gap:.75rem}.resume-sheet-link{width:100%}.resume-actions{display:grid;grid-template-columns:1fr;gap:.45rem;width:100%}.resume-action{width:100%}}@media(max-width: 40rem){.home-writing-row{grid-template-columns:minmax(3.8rem, 4.4rem) minmax(0, 1fr) minmax(6.5rem, 30vw) !important;gap:.6rem}.home-directory-summary,.home-directory-meta{grid-column:1/-1}.home-directory-title{font-size:1rem}}.home-directory-row,.home-directory-body,.home-directory-title,.home-directory-summary,.home-directory-meta,.home-directory-date,.home-directory-date .date{text-align:left !important}.home-directory-title{overflow-wrap:break-word;word-break:normal;hyphens:auto}@media(max-width: 58rem){.home-writing-preview img{transform:none}}
