:root{color-scheme:light;--bg: #f8f8f8;--paper: #ffffff;--ink: #111111;--ink-soft: #333333;--muted: #888888;--line: #e5e5e5;--line-strong: #d1d1d1;--accent: #1f2937;--content: 1120px;--reading: 760px;--font-sans: Inter, Roboto, Helvetica, "Source Han Sans SC", "Noto Sans SC", "Microsoft YaHei", sans-serif;--font-mono: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace}*{box-sizing:border-box}html{background:var(--bg);scroll-behavior:smooth}body{margin:0;color:var(--ink);background:var(--bg);font-family:var(--font-sans);font-size:16px;line-height:1.75;letter-spacing:0}img{display:block;max-width:100%}[hidden]{display:none!important}a{color:inherit;text-decoration-thickness:1px;text-underline-offset:.18em}a:hover{color:var(--accent)}a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:4px}h1,h2,h3,p,ul,ol,figure{margin:0}h1,h2,h3{color:var(--ink);font-weight:760;line-height:1.08}main{min-height:68vh}.site-header,.site-footer,.portfolio-hero,.home-section,.page-hero,.section{width:min(calc(100% - 48px),var(--content));margin-inline:auto}.site-header{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:32px 0}.brand{display:inline-flex;color:var(--ink);text-decoration:none}.brand__logo{width:30px;height:auto}.site-nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:28px;color:var(--muted);font-size:.86rem}.site-nav a{text-decoration:none}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--ink)}.portfolio-hero{display:grid;grid-template-columns:minmax(300px,.68fr) minmax(420px,1fr);gap:clamp(42px,8vw,104px);min-height:calc(100svh - 108px);align-items:center;padding:72px 0 104px;text-align:left}.hero-copy{max-width:480px}.eyebrow,.article-card__meta,.footer-kicker{color:var(--muted);font-size:.78rem;font-weight:650;letter-spacing:.12em;text-transform:uppercase}.portfolio-hero h1{margin-top:18px;font-size:clamp(2.25rem,4.2vw,4rem);letter-spacing:0;text-wrap:balance}.hero-text{max-width:620px;margin-top:24px;color:var(--muted);font-size:clamp(1rem,2vw,1.18rem)}.hero-media{justify-self:end;width:100%}.hero-media img{width:100%;aspect-ratio:4 / 5;object-fit:cover}.button{display:inline-flex;min-height:46px;align-items:center;justify-content:center;margin-top:34px;padding:12px 24px;border:1px solid var(--ink);background:transparent;color:var(--ink);font-size:.92rem;font-weight:650;text-decoration:none;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.button:hover{background:var(--ink);color:var(--paper);box-shadow:0 18px 34px #1111111f}.home-section{padding:112px 0;border-top:1px solid var(--line)}.about-section{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:72px;align-items:center}.about-copy h2,.section-head h2,.page-hero h1{margin-top:14px;font-size:clamp(2rem,4.8vw,3.5rem);letter-spacing:0}.about-copy p:not(.eyebrow),.page-hero p:not(.eyebrow),.article-hero p:not(.eyebrow){max-width:680px;margin-top:24px;color:#444;font-size:1.05rem;line-height:1.9}.about-image{width:100%;aspect-ratio:4 / 5;object-fit:cover;filter:grayscale(1)}.section-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:end;margin-bottom:34px}.section-head .eyebrow{grid-column:1 / -1}.text-link{color:var(--muted);font-size:.92rem;font-weight:650;text-decoration:none}.text-link:hover{color:var(--ink)}.work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.work-card{overflow:hidden;background:#ddd}.work-card a{position:relative;display:block;color:var(--paper);text-decoration:none}.work-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;filter:grayscale(1);transition:transform .32s ease,filter .32s ease}.work-card__overlay{position:absolute;inset:0;display:grid;align-content:end;gap:8px;padding:22px;background:linear-gradient(180deg,#1110,#111111ad);opacity:0;transition:opacity .22s ease}.work-card__overlay p{color:#ffffffb3;font-size:.82rem}.work-card__overlay h3{color:var(--paper);font-size:1.25rem}.work-card:hover img{transform:scale(1.04);filter:grayscale(1) contrast(1.08)}.work-card:hover .work-card__overlay{opacity:1}.article-list{display:grid;gap:26px}.article-list--home{max-width:860px}.article-card{padding-bottom:26px;border-bottom:1px solid var(--line)}.article-card__body{display:grid;gap:8px}.article-card h2{font-size:clamp(1.18rem,2.4vw,1.55rem)}.article-card h2 a{color:var(--ink);text-decoration:none}.article-card h2 a:hover{color:var(--accent);text-decoration:underline}.article-card p:not(.article-card__meta){max-width:760px;color:#555;font-size:.98rem;line-height:1.75}.page-hero{padding:72px 0 32px}.page-hero--visual{display:grid;gap:34px;padding-bottom:42px}.page-hero__copy{max-width:680px}.page-hero__image{width:100%;aspect-ratio:21 / 8;object-fit:cover}.section{padding:42px 0}.section--compact{padding-top:18px}.search-bar{display:grid;max-width:560px;gap:10px;margin-bottom:34px}.search-bar label{color:var(--muted);font-size:.78rem;font-weight:650;letter-spacing:.12em;text-transform:uppercase}.search-bar input{width:100%;min-height:48px;border:0;border-bottom:1px solid var(--line-strong);border-radius:0;background:transparent;color:var(--ink);font:inherit;outline:none}.search-bar input::placeholder{color:var(--muted)}.search-bar input:focus{border-color:var(--ink)}.empty-state{margin-top:28px;padding:24px 0;border-top:1px solid var(--line);color:var(--muted)}.article-page{width:min(calc(100% - 48px),var(--reading));margin:0 auto;padding:72px 0 0}.article-hero{padding-bottom:32px;border-bottom:1px solid var(--line)}.article-hero h1{margin-top:14px;font-size:clamp(2rem,5vw,3rem);letter-spacing:0}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 0;padding:0;list-style:none;color:var(--muted);font-size:.86rem}.tag-list a,.tag-list span{color:var(--muted);text-decoration:none}.tag-list a:before,.tag-list span:before{content:"#"}.tag-list a:hover{color:var(--ink)}.tag-cloud{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.95rem}.prose{padding-top:38px;color:var(--ink);font-size:clamp(1.08rem,2vw,1.2rem);line-height:1.95}.prose>*+*{margin-top:1.25em}.prose--hide-opening-heading>h1:first-child{display:none}.prose h2,.prose h3{margin-top:2.25em}.prose h2{font-size:1.55rem}.prose h3{font-size:1.25rem}.prose ul,.prose ol{padding-left:1.35em}.prose li+li{margin-top:.35em}.prose blockquote{margin-right:0;margin-left:0;padding-left:18px;border-left:3px solid var(--line-strong);color:var(--ink-soft)}.prose pre{overflow-x:auto;padding:18px;border:1px solid var(--line);background:var(--paper);font-family:var(--font-mono);font-size:.9rem;line-height:1.65}.prose code{font-family:var(--font-mono)}.prose :not(pre)>code{padding:2px 5px;background:var(--paper)}.prose a{color:var(--accent);text-decoration-thickness:1px;text-underline-offset:.18em}.prose mark{padding:.08em .22em;background:color-mix(in srgb,var(--accent-warm) 26%,transparent);color:inherit}.prose hr{margin:2.2em 0;border:0;border-top:1px solid var(--line)}.prose table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;font-size:.96rem;line-height:1.65}.prose th,.prose td{padding:10px 12px;border:1px solid var(--line);vertical-align:top}.prose th{background:var(--paper);color:var(--ink);font-weight:700}.prose img{max-width:100%;height:auto;border:1px solid var(--line);background:var(--paper)}.prose div[align=center]{text-align:center}.prose div[align=center] img{margin:0 8px;border:0;vertical-align:middle}.post-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-top:54px;padding-top:24px;border-top:1px solid var(--line)}.post-nav a{color:var(--ink);text-decoration:none}.post-nav a:last-child{text-align:right}.post-nav span{display:block;color:var(--muted);font-size:.9rem}.post-nav strong{display:block;margin-top:6px;font-size:1rem;line-height:1.45}.archive-list{display:grid;gap:38px}.archive-year{display:grid;grid-template-columns:90px minmax(0,1fr);gap:28px;padding-top:26px;border-top:1px solid var(--line)}.archive-year h2{color:var(--muted);font-size:1.2rem}.archive-year ol{display:grid;gap:20px;padding:0;list-style:none}.archive-year li{display:grid;gap:3px}.archive-year time,.archive-year span{color:var(--muted);font-size:.9rem}.archive-year a{color:var(--ink);font-weight:700;text-decoration:none}.archive-year a:hover{color:var(--accent);text-decoration:underline}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.project-card{display:grid;overflow:hidden;background:transparent}.project-card__media{display:block;overflow:hidden}.project-card__media img{width:100%;aspect-ratio:4 / 3;object-fit:cover;filter:grayscale(1);transition:transform .3s ease}.project-card:hover .project-card__media img{transform:scale(1.035)}.project-card__body{display:grid;gap:10px;padding:20px 0 0;border-top:1px solid transparent}.project-card h2{font-size:1.35rem}.project-card h2 a{color:var(--ink);text-decoration:none}.project-card h2 a:hover{text-decoration:underline}.project-card p:not(.eyebrow){color:#555;font-size:.96rem}.not-found{min-height:55vh}.about-contact{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:36px;align-items:end;padding-top:34px;border-top:1px solid var(--line)}.about-brief{display:grid;gap:26px;padding-top:58px;padding-bottom:82px}.about-brief__label{justify-self:center;padding:0 12px 4px;border-bottom:2px solid var(--line-strong);color:var(--muted);font-size:.78rem;font-weight:720;letter-spacing:.12em;line-height:1;text-transform:uppercase}.about-brief h1{margin-top:28px;font-size:clamp(2.15rem,4vw,3.25rem);font-weight:780;letter-spacing:0;line-height:1.18}.about-brief__body{display:grid;max-width:1120px;gap:4px;color:var(--ink);font-size:clamp(1.12rem,1.8vw,1.38rem);line-height:1.9}.about-contact h2{margin-top:10px;font-size:clamp(1.6rem,3vw,2.4rem)}.about-contact p:not(.eyebrow){margin-top:14px;color:#555}.about-contact a{color:var(--ink)}.site-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:28px;margin-top:72px;padding:56px 0;border-top:1px solid var(--line);color:var(--muted)}.site-footer h2{margin-top:10px;color:var(--ink);font-size:clamp(1.6rem,3vw,2.4rem)}.footer-note{max-width:620px;margin-top:14px}.footer-note a{color:var(--ink)}.footer-contact{display:flex;align-items:start;justify-content:end}.contact-links{display:flex;gap:10px;align-items:center}.contact-icon{display:grid;width:44px;height:44px;place-items:center;border:1px solid var(--line-strong);border-radius:0;color:var(--ink);background:transparent;cursor:pointer;text-decoration:none;transition:border-color .18s ease,background .18s ease,color .18s ease}.contact-icon:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}.contact-icon svg{width:21px;height:21px;fill:currentColor}.contact-icon svg path,.contact-icon svg rect,.contact-icon svg circle{vector-effect:non-scaling-stroke}.contact-icon:first-child svg path,.contact-icon:first-child svg circle,.contact-icon:last-child svg rect,.contact-icon:last-child svg path{fill:none;stroke:currentColor;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}.wechat-popover{width:min(calc(100vw - 36px),360px);padding:28px;border:1px solid var(--line-strong);background:var(--paper);color:var(--ink);box-shadow:0 24px 70px #1111112e;text-align:center}.wechat-popover::backdrop{background:#1111112e}.wechat-popover img{width:220px;aspect-ratio:1;margin:4px auto 18px;border:1px solid var(--line);background:var(--paper);object-fit:cover}.wechat-popover h2{font-size:1.15rem}.wechat-popover p{margin-top:8px;color:var(--muted);font-size:.92rem}.wechat-popover__close{position:absolute;top:12px;right:12px;display:grid;width:32px;height:32px;place-items:center;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer}.wechat-popover__close:hover{border-color:var(--ink);color:var(--ink)}.wechat-popover__close svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round}.copyright{grid-column:1 / -1;font-size:.86rem}.supports-reveal .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.supports-reveal .reveal.is-visible{opacity:1;transform:translateY(0)}@media(max-width:900px){.site-header,.site-footer,.portfolio-hero,.home-section,.page-hero,.section,.article-page{width:min(calc(100% - 32px),var(--content))}.site-header{display:block}.site-nav{justify-content:flex-start;gap:16px;margin-top:20px}.portfolio-hero{grid-template-columns:1fr;min-height:auto;padding:64px 0 92px}.portfolio-hero h1{font-size:clamp(2.1rem,10vw,3.5rem)}.hero-media{justify-self:start}.hero-media img{aspect-ratio:16 / 11}.about-section{grid-template-columns:1fr;gap:34px}.work-grid,.card-grid{grid-template-columns:1fr}.section-head{grid-template-columns:1fr;align-items:start}.site-footer{grid-template-columns:1fr}.footer-contact,.about-contact{grid-template-columns:1fr;justify-content:start}.about-brief{gap:22px}.footer-contact{align-items:start;justify-content:start}}@media(max-width:560px){body{font-size:15px}.portfolio-hero h1{font-size:2.55rem}.home-section{padding:76px 0}.page-hero{padding-top:48px}.page-hero__image{aspect-ratio:4 / 3}.article-hero h1{font-size:1.9rem}.prose{font-size:1.05rem}.about-brief{padding-top:40px;padding-bottom:58px}.about-brief h1{margin-top:18px}.about-brief__body{font-size:1.08rem}.post-nav{grid-template-columns:1fr}.post-nav a:last-child{text-align:left}.archive-year{grid-template-columns:1fr;gap:14px}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
