:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--hud-bg:#06111f;--hud-panel:#091727c7;--hud-panel-strong:#0d1f34eb;--hud-border:#6ed0ff47;--hud-border-strong:#6ed0ffa8;--hud-text:#ebf6ff;--hud-text-muted:#ebf6ffb8;--hud-accent:#6ed0ff;--hud-accent-soft:#6ed0ff24;--hud-grid:#6ed0ff14;--hud-shadow:0 24px 80px #0000006b;--hud-radius:1.5rem;--hud-gap:clamp(1rem, 2vw, 1.5rem);--hud-max-width:1200px;--hud-font-sans:"AlibabaPuHuiTi-2-55-Regular", "Alibaba PuHuiTi 2", "Inter", "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--hud-font-display:"AlibabaPuHuiTi-2-75-SemiBold", "AlibabaPuHuiTi-2-55-Regular", "Alibaba PuHuiTi 2", "Inter", "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--hud-font-mono:"JetBrains Mono", "SFMono-Regular", "SFMono-Regular", Consolas, "Liberation Mono", monospace}@font-face{font-family:AlibabaPuHuiTi-2-55-Regular;src:url(/fonts/alibaba-puhuiti-2/regular/KUxSeKaz9CEyVwOxgR5XI.woff2)format("woff2");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:AlibabaPuHuiTi-2-75-SemiBold;src:url(/fonts/alibaba-puhuiti-2/semibold/ySDx8a6paQSQ7n2m8wcJR.woff2)format("woff2");font-style:normal;font-weight:600;font-display:swap}:root{color:#1d2433;font-family:var(--hud-font-sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#ebe8e1;line-height:1.6}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;font-size:clamp(15px,.2vw + 14px,18px)}body{min-width:320px;min-height:100vh;font-family:var(--hud-font-sans);color:#1d2433;background:#ebe8e1;margin:0;font-weight:400;line-height:1.6;position:relative;overflow-x:hidden}button,input,textarea,select{font:inherit}#root{isolation:isolate;border:0;width:100%;max-width:none;min-height:100vh;margin:0}a{color:inherit;text-decoration:none;transition:color .18s,opacity .18s}a:hover{color:#2d41b5}::selection{color:#fff;background:#2d41b5e6}@media (width<=720px){html{font-size:15px}body{background-size:20px 20px,20px 20px,auto,auto}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition:none!important;animation:none!important}}.app-shell{width:min(calc(100% - 2rem), var(--hud-max-width));margin:0 auto;padding:clamp(1.25rem,3vw,2rem) 0 clamp(2.5rem,6vw,3.5rem)}.app-shell__grid{gap:var(--hud-gap);grid-template-columns:repeat(12,minmax(0,1fr));display:grid}.section-frame{border:1px solid var(--hud-border);border-radius:var(--hud-radius);background:var(--hud-panel);min-height:19rem;box-shadow:var(--hud-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform-origin:top;will-change:transform, box-shadow;grid-column:span 6;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;animation:.48s cubic-bezier(.22,1,.36,1) both section-enter;position:relative;overflow:hidden}.section-frame:before{content:"";opacity:.8;pointer-events:none;background:linear-gradient(135deg,#6ed0ff1a,#0000 40%),linear-gradient(#0000,#6ed0ff0f);transition:opacity .18s;position:absolute;inset:0}.section-frame--hero,.section-frame--projects{grid-column:span 12}.section-frame__surface{z-index:1;flex-direction:column;justify-content:space-between;gap:clamp(1rem,2vw,1.5rem);min-height:100%;padding:clamp(1rem,2vw,1.5rem);display:flex;position:relative}.section-frame__header{gap:.9rem;display:grid}.section-frame__eyebrow{color:var(--hud-accent);font:.76rem/1.4 var(--hud-font-mono);letter-spacing:.26em;text-transform:uppercase;margin:0}.section-frame__title{color:var(--hud-text);font-family:var(--hud-font-display);letter-spacing:-.04em;margin:0;font-weight:600;line-height:1.05}.section-frame--hero .section-frame__title{font-size:clamp(3rem,8vw,5rem)}.section-frame:not(.section-frame--hero) .section-frame__title{font-size:clamp(1.55rem,3vw,2.2rem)}.section-frame__description{max-width:60ch;color:var(--hud-text-muted);margin:0;line-height:1.7}.section-frame__content{gap:1rem;display:grid}.hud-decoration{pointer-events:none;position:absolute;inset:0}.hud-decoration__corner,.hud-decoration__axis{opacity:.9;display:block;position:absolute}.hud-decoration__corner{border-color:var(--hud-border-strong);border-style:solid;width:1.15rem;height:1.15rem}.hud-decoration__corner--top-left{border-width:1px 0 0 1px;top:.8rem;left:.8rem}.hud-decoration__corner--top-right{border-width:1px 1px 0 0;top:.8rem;right:.8rem}.hud-decoration__corner--bottom-left{border-width:0 0 1px 1px;bottom:.8rem;left:.8rem}.hud-decoration__corner--bottom-right{border-width:0 1px 1px 0;bottom:.8rem;right:.8rem}.hud-decoration__axis--horizontal{inset-inline:2rem;border-top:1px solid #6ed0ff29;top:1.15rem}.hud-decoration__axis--vertical{border-right:1px solid #6ed0ff1f;top:2rem;bottom:2rem;right:1.15rem}.hero-panel,.hero-panel__actions,.hero-panel__keywords,.panel-grid,.project-panel,.skill-panel,.contact-panel{gap:.85rem;display:grid}.hero-panel{gap:1rem}.hero-panel__actions{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-panel__actions a{border:1px solid var(--hud-border);min-height:3rem;font-family:var(--hud-font-display);color:var(--hud-text);will-change:transform;cursor:pointer;background:#6ed0ff14;border-radius:1rem;justify-content:center;align-items:center;padding:.9rem 1rem;transition:border-color .18s,transform .18s,background .18s,box-shadow .18s;display:inline-flex;box-shadow:inset 0 1px #ffffff08}.hero-panel__actions a:hover{border-color:var(--hud-border-strong);background:#6ed0ff24;transform:translateY(-1px);box-shadow:0 12px 30px #03080f52}.hero-panel__actions a:focus-visible{outline-offset:2px;outline:2px solid #6ed0ffe6}.hero-panel__keywords,.skill-panel__group ul{grid-template-columns:repeat(auto-fit,minmax(8rem,1fr));margin:0;padding:0;list-style:none}.hero-panel__keywords li,.panel-card,.project-panel__card,.skill-panel__group,.contact-panel__card{background:var(--hud-panel-strong);border:1px solid #6ed0ff24}.hero-panel__keywords li{color:var(--hud-text-muted);text-align:center;border-radius:999px;padding:.75rem .9rem}.project-panel__experience-card{background:var(--hud-panel-strong);border:1px solid #6ed0ff24;border-radius:1.1rem}.project-panel__experience-meta span,.project-panel__gallery-intro span,.contact-panel__card span,.project-panel__meta span,.skill-panel__group span{color:var(--hud-accent);font:.74rem/1.4 var(--hud-font-mono);letter-spacing:.18em;text-transform:uppercase}.project-panel--experience{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:.75rem}.project-panel__experience-card{gap:.75rem;padding:1rem;display:grid}.project-panel__experience-meta{gap:.6rem;display:grid}.project-panel__experience-meta h3{color:var(--hud-text);font-family:var(--hud-font-display);margin:0;font-size:1.05rem;font-weight:600}.project-panel__experience-card p{color:var(--hud-text-muted);margin:0;line-height:1.7}.panel-grid,.project-panel,.skill-panel{grid-template-columns:repeat(auto-fit,minmax(13rem,1fr))}.panel-card,.project-panel__card,.skill-panel__group,.contact-panel__card{border-radius:1.1rem;padding:1rem}.panel-card p,.project-panel__meta p,.project-panel__body p,.skill-panel__group li,.contact-panel__card strong{color:var(--hud-text-muted);line-height:1.65}.panel-card strong,.project-panel__body h3,.skill-panel__group h3{color:var(--hud-text);font-family:var(--hud-font-display);margin-bottom:.45rem;display:block}.project-panel__card-stack{gap:.75rem;display:grid}.project-panel__card{background:linear-gradient(180deg, #6ed0ff14, #6ed0ff08), var(--hud-panel-strong);align-content:space-between;gap:1rem;min-height:auto;display:grid;position:relative;overflow:hidden}.project-panel__card:after{content:"";border-radius:inherit;pointer-events:none;border:1px solid #6ed0ff2e;position:absolute;inset:0}.project-panel__gallery-intro{justify-content:flex-end;display:flex}.project-panel__gallery{scroll-snap-type:x proximity;grid-auto-columns:minmax(16rem,24rem);grid-auto-flow:column;gap:.9rem;padding-bottom:.35rem;display:grid;overflow-x:auto}.project-panel__gallery-image{aspect-ratio:16/10;object-fit:cover;background:var(--hud-panel-strong);scroll-snap-align:start;border:1px solid #6ed0ff29;border-radius:1rem;width:100%}.project-panel__meta,.project-panel__body{z-index:1;gap:.45rem;display:grid;position:relative}.project-panel__meta p,.project-panel__body h3,.project-panel__body p,.skill-panel__group h3,.contact-panel__card strong{margin:0}.skill-panel__group ul{gap:.6rem}.skill-panel__group li{border-radius:.8rem;padding:.7rem .8rem}.contact-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-panel__card{background:linear-gradient(180deg, #6ed0ff1f, #6ed0ff0a), var(--hud-panel-strong);align-content:center;gap:.35rem;min-height:7.5rem;display:grid}.app-shell__grid>.section-frame:nth-child(2){animation-delay:40ms}.app-shell__grid>.section-frame:nth-child(3){animation-delay:80ms}.app-shell__grid>.section-frame:nth-child(4){animation-delay:.12s}.app-shell__grid>.section-frame:nth-child(5){animation-delay:.16s}.app-shell__grid>.section-frame:nth-child(6){animation-delay:.2s}.contact-panel__card a{color:var(--hud-text);font-size:1.05rem;font-family:var(--hud-font-display);word-break:break-word;text-decoration:none}.contact-panel__card a:hover{color:var(--hud-accent)}@media (hover:hover) and (pointer:fine){.section-frame:hover{border-color:#6ed0ff6b;transform:translateY(-4px);box-shadow:0 28px 90px #0000007a}.section-frame:hover:before{opacity:1}.project-panel__card:hover{transform:translateY(-4px)scale(1.01)}}@keyframes section-enter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (width<=1100px){.panel-grid,.project-panel,.skill-panel{grid-template-columns:repeat(auto-fit,minmax(12rem,1fr))}}@media (width<=900px){.app-shell{width:min(calc(100% - 1rem), var(--hud-max-width));padding-block:1rem 2rem}.section-frame,.section-frame--hero,.section-frame--projects{grid-column:span 12}.hero-panel__actions,.project-panel--experience,.contact-panel{grid-template-columns:1fr}.section-frame__surface{padding:clamp(1rem,2.8vw,1.25rem)}.experience-panel__line{display:none}}@media (width<=680px){.section-frame{min-height:auto}.section-frame--hero .section-frame__title{font-size:clamp(2.4rem,12vw,3.4rem)}.section-frame:not(.section-frame--hero) .section-frame__title{font-size:clamp(1.35rem,6vw,1.8rem)}.hero-panel__keywords,.skill-panel__group ul{grid-template-columns:repeat(auto-fit,minmax(7rem,1fr))}.project-panel__gallery{grid-auto-columns:minmax(14rem,18rem)}.project-panel,.skill-panel,.panel-grid{grid-template-columns:repeat(auto-fit,minmax(11rem,1fr))}.project-panel__card,.contact-panel__card{min-height:auto}}@media (width<=560px){.app-shell{width:min(calc(100% - .75rem), var(--hud-max-width))}.section-frame__surface{padding:1rem}.section-frame__eyebrow{letter-spacing:.22em}.project-panel,.skill-panel,.panel-grid{grid-template-columns:1fr}}@media (width<=420px){.app-shell{width:min(calc(100% - .5rem), var(--hud-max-width))}.hero-panel__keywords,.skill-panel__group ul{grid-template-columns:1fr}.hero-panel__actions a,.panel-card,.project-panel__card,.skill-panel__group,.contact-panel__card{padding-inline:.9rem}}@media (prefers-reduced-motion:reduce){.section-frame,.project-panel__card,.hero-panel__actions a{animation:none!important;transform:none!important}}.app-shell__grid{grid-template-columns:1fr;gap:clamp(2.25rem,5vw,4rem)}.section-frame.section-frame--editorial{min-height:auto;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:#f1f1ef;border:1px solid #1d243314;border-radius:1.25rem;grid-column:span 12;animation:none}.section-frame.section-frame--editorial:before,.section-frame.section-frame--editorial .hud-decoration{display:none}.section-frame.section-frame--editorial .section-frame__surface{text-align:left;background:#f1f1ef;align-items:start;gap:1.25rem;padding:clamp(1.2rem,2.6vw,2rem)}.section-frame.section-frame--editorial .section-frame__eyebrow{color:#1d243385;letter-spacing:.22em}.section-frame.section-frame--editorial .section-frame__title{font-family:var(--hud-font-display);letter-spacing:-.02em;color:#2d41b5}.section-frame.section-frame--editorial .section-frame__description{color:#1d2433b8}.editorial-hero{text-align:left;justify-items:start;gap:1rem;display:grid}.editorial-hero__subtitle{color:#1d2433bd;font-family:var(--hud-font-display);margin:0}.editorial-hero__intro{color:#1d2433d1;text-align:left;margin:0;padding-left:1.2rem;line-height:1.8}.editorial-hero__nav{flex-wrap:wrap;justify-content:flex-start;gap:1rem;display:flex}.editorial-hero__nav--top{margin-bottom:.25rem}.editorial-hero__nav a{color:#1d2433d1;border-bottom:1px solid #1d24333d;padding-bottom:.15rem;text-decoration:none}.editorial-hero__nav a:hover{color:#2d41b5;border-bottom-color:#2d41b58c}.work-list{gap:clamp(1.9rem,3.5vw,2.6rem);display:grid}.work-item{text-align:left;border-top:1px solid #1d24331f;gap:.72rem;padding-top:1.75rem;display:grid}.work-item__header{gap:.18rem;display:grid}.work-item__header h3{font-family:var(--hud-font-display);letter-spacing:-.02em;color:#2d41b5;margin:0;font-size:clamp(1.4rem,3.2vw,2rem)}.work-item__intro{color:#1d2433bd;white-space:normal;overflow-wrap:normal;word-break:break-word;text-wrap:wrap;max-width:96ch;margin:.55rem 0 0;line-height:1.75}.work-item__meta{flex-wrap:wrap;align-items:baseline;gap:.35rem .9rem;display:flex}.work-item__meta ul{flex-wrap:wrap;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.work-item__meta li{font:.68rem/1.35 var(--hud-font-mono);color:#1d243378;letter-spacing:.12em}.work-item__tags li{text-transform:uppercase}.work-item__bullets{color:#1d24338f;font:.72rem/1.45 var(--hud-font-mono);letter-spacing:.04em;flex-wrap:wrap;gap:.25rem .85rem;margin:0;padding-left:0;list-style:none;display:flex}.work-item__bullets li{padding-left:.72rem;position:relative}.work-item__bullets li:before{content:"/";color:#1d243357;position:absolute;top:0;left:0}.work-item__gallery-label{justify-content:space-between;align-items:center;gap:1rem;display:flex}.work-item__gallery-label span{font:.72rem/1.4 var(--hud-font-mono);color:#1d243385;letter-spacing:.2em;text-transform:uppercase}.work-item__gallery{scroll-snap-type:x proximity;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;cursor:grab;touch-action:pan-x;gap:1.2rem;width:100%;padding-bottom:.25rem;display:flex;overflow:auto hidden}.work-item__gallery img{aspect-ratio:16/9;object-fit:cover;scroll-snap-align:start;background:#ffffffa6;border:1px solid #1d24331a;border-radius:.9rem;flex:none;width:min(72vw,52rem);min-width:min(72vw,52rem)}.work-item__gallery:active{cursor:grabbing}.work-item__gallery::-webkit-scrollbar{height:10px}.work-item__gallery::-webkit-scrollbar-track{background:#1d243314;border-radius:999px}.work-item__gallery::-webkit-scrollbar-thumb{background:#2d41b559;border-radius:999px}.work-item__gallery-controls{opacity:.72;align-items:center;gap:.45rem;display:inline-flex}.work-item__gallery-controls button{color:#2d41b5e0;width:1.8rem;height:1.8rem;font:600 .84rem/1 var(--hud-font-display);cursor:pointer;background:#ffffffb3;border:1px solid #1d24331a;border-radius:999px}.work-item__gallery-controls button:hover{background:#2d41b514}.resume-appendix{grid-template-columns:1fr;gap:1.1rem;display:grid}.resume-appendix__block{grid-column:span 12;gap:.5rem;display:grid}.resume-appendix__block h3{font-family:var(--hud-font-display);color:#2d41b5;margin:0;font-size:1.1rem}.resume-appendix__block ul{color:#1d2433c2;margin:0;padding-left:0;line-height:1.75;list-style:none}.resume-appendix__block li{margin:0}.resume-appendix__location{align-items:center;gap:.45rem;display:inline-flex}.resume-appendix__location-icon{border-radius:999px;flex:none;width:.85rem;height:.85rem}.resume-appendix__groups{gap:.45rem;display:grid}.resume-appendix__group{border-top:1px solid #1d243314;gap:.18rem;padding-top:.45rem;display:grid}.resume-appendix__group:first-child{border-top:none;padding-top:0}.resume-appendix__group h4{color:#1d24338a;font:.7rem/1.45 var(--hud-font-mono);letter-spacing:.18em;text-transform:uppercase;margin:0}.resume-appendix__group ul{gap:.14rem;padding-left:0;display:grid}.resume-appendix__group li{color:#1d2433bd;font-size:.94rem;line-height:1.55}.resume-appendix__group li a,.resume-appendix__group li span a{color:#2d41b5;border-bottom:1px solid #2d41b533;text-decoration:none}.resume-appendix__group li a:hover,.resume-appendix__group li span a:hover{border-bottom-color:#2d41b58c}.section-frame--contact.section-frame--editorial .contact-panel{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem 1.8rem}.section-frame--contact.section-frame--editorial .contact-panel__card{background:0 0;border:none;border-top:1px solid #1d24331f;border-radius:0;align-content:start;gap:.22rem;min-height:auto;padding:.72rem 0 .78rem}.section-frame--contact.section-frame--editorial .contact-panel__card a{color:#2d41b5;font-size:.98rem;line-height:1.35}.contact-panel__label{color:#1d24338a;font:.72rem/1.3 var(--hud-font-mono);letter-spacing:.14em;align-items:center;gap:.36rem;display:inline-flex}.contact-panel__icon{object-fit:cover;border-radius:999px;flex:none;width:.78rem;height:.78rem}@media (width<=900px){.work-item__gallery{gap:.9rem}.section-frame--contact.section-frame--editorial .contact-panel{grid-template-columns:1fr}}@media (width<=560px){.work-item__gallery img{width:min(86vw,26rem);min-width:min(86vw,26rem)}}
