:root{color-scheme:light;--paper: #eef1f4;--paper-2: #f7f8f2;--ink: #171717;--muted: #5c626a;--soft: #8a929b;--line: #d8dde3;--line-strong: #b8c0c9;--white: #fcfbf7;--green: #16855e;--blue: #2f5fbe;--amber: #a76516;--rose: #b43c64;--grid-line: rgba(23, 23, 23, .045);--topbar-bg: rgba(238, 241, 244, .86);--nav-bg: rgba(252, 251, 247, .72);--surface: rgba(252, 251, 247, .72);--surface-strong: rgba(252, 251, 247, .82);--map-bg: rgba(252, 251, 247, .72);--button-bg: rgba(252, 251, 247, .56);--button-hover: #fcfbf7;--inverse-muted: rgba(244, 241, 234, .72);--shadow: 0 22px 55px rgba(23, 23, 23, .1);--max: 1160px;--radius: 8px}html[data-theme=dark]{color-scheme:dark;--paper: #111214;--paper-2: #18191d;--ink: #f4efe6;--muted: #bab1a4;--soft: #8e867b;--line: #343235;--line-strong: #4a4642;--white: #191a1f;--green: #63d79b;--blue: #8bb4ff;--amber: #f0b35a;--rose: #ff8aa8;--grid-line: rgba(255, 255, 255, .045);--topbar-bg: rgba(17, 18, 20, .86);--nav-bg: rgba(255, 255, 255, .055);--surface: rgba(255, 255, 255, .055);--surface-strong: rgba(255, 255, 255, .08);--map-bg: #15161a;--button-bg: rgba(255, 255, 255, .055);--button-hover: rgba(255, 255, 255, .11);--inverse-muted: rgba(17, 18, 20, .68);--shadow: 0 22px 65px rgba(0, 0, 0, .28)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:linear-gradient(116deg,rgba(47,95,190,.08),transparent 36%),linear-gradient(246deg,rgba(22,133,94,.07),transparent 44%),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),linear-gradient(var(--grid-line) 1px,transparent 1px),var(--paper);background-size:auto,auto,40px 40px,40px 40px,auto;color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;font-size:15px;line-height:1.58;letter-spacing:0;overflow-x:hidden}a{color:inherit}button,a{-webkit-tap-highlight-color:transparent}.scroll-progress{position:fixed;top:0;left:0;z-index:60;width:100%;height:3px;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--green),var(--blue),var(--amber))}.ambient-canvas{position:fixed;inset:0;z-index:0;width:100vw;height:100vh;pointer-events:none;opacity:.88}.topbar{position:sticky;top:0;z-index:50;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.8rem;min-height:64px;padding:0 clamp(1rem,4vw,2.5rem);border-bottom:1px solid var(--line);background:var(--topbar-bg);backdrop-filter:blur(18px)}.brand{display:inline-flex;align-items:center;gap:.7rem;width:fit-content;text-decoration:none}.brand span{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--paper);font-size:.72rem;font-weight:800}.brand strong{font-size:.9rem}.nav{display:flex;align-items:center;gap:.25rem;padding:.3rem;border:1px solid var(--line);border-radius:999px;background:var(--nav-bg)}.nav a{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 .66rem;border-radius:999px;color:var(--muted);text-decoration:none;font-size:.8rem;transition:color .18s ease,background .18s ease}.nav a:hover,.nav a.active{color:var(--paper);background:var(--ink)}.topbar-cta{display:inline-flex;align-items:center;min-height:34px;padding:0 .82rem;border:1px solid var(--ink);border-radius:999px;text-decoration:none;font-size:.82rem;font-weight:750;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.topbar-actions{justify-self:end;display:flex;align-items:center;justify-content:flex-end;gap:.45rem}.github-link,.control-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;border:1px solid var(--line);border-radius:999px;background:var(--nav-bg);color:var(--ink);text-decoration:none;font:inherit;font-size:.8rem;font-weight:800;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.github-link{gap:.45rem;padding:0 .74rem}.github-link svg{width:18px;height:18px}.control-button{min-width:34px;padding:0 .58rem;cursor:pointer}.github-link:hover,.control-button:hover,.topbar-cta:hover{transform:translateY(-1px);border-color:var(--ink);background:var(--button-hover)}main{position:relative;z-index:1;overflow:clip}.footer{position:relative;z-index:1}.hero{position:relative;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(340px,.82fr);gap:clamp(1.8rem,4.4vw,4.2rem);max-width:var(--max);min-height:calc(88vh - 64px);margin:0 auto;padding:clamp(3.4rem,7vw,5.8rem) clamp(1rem,4vw,2.5rem);align-items:center}.eyebrow,.section-title p,.rail-label,.contact-section>div>p{margin:0 0 .8rem;color:var(--green);font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.hero h1{max-width:680px;margin:0;font-size:clamp(2.45rem,4.25vw,4.65rem);line-height:1.04;letter-spacing:0}.lead{max-width:660px;margin:1.15rem 0 0;color:var(--muted);font-size:clamp(.98rem,1.28vw,1.1rem)}.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.55rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 .9rem;border:1px solid var(--line-strong);border-radius:999px;background:var(--button-bg);color:var(--ink);text-decoration:none;font-size:.88rem;font-weight:750;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.button:hover{transform:translateY(-2px);border-color:var(--ink);background:var(--button-hover)}.button-primary{border-color:var(--ink);background:var(--ink);color:var(--paper)}.button-primary:hover{background:var(--ink);color:var(--paper)}.brand-logo{display:grid;place-items:center;width:42px;height:42px;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,#ffffff9e,#ffffff2e),var(--surface-strong);box-shadow:0 10px 24px #17171714;flex:0 0 auto}.brand-logo img{display:block;width:74%;height:74%;object-fit:contain}.brand-logo-wide img{width:86%;height:54%}.hero-panel{position:relative;border:1px solid var(--line-strong);border-radius:var(--radius);background:color-mix(in srgb,var(--white) 88%,transparent);box-shadow:var(--shadow);overflow:hidden;backdrop-filter:blur(14px)}.profile-card{display:flex;align-items:center;gap:.85rem;padding:1rem;border-bottom:1px solid var(--line)}.avatar{display:grid;place-items:center;width:48px;height:48px;border-radius:var(--radius);background:var(--ink);color:var(--paper);font-size:1.12rem;font-weight:900}.profile-card p{margin:0;color:var(--muted)}.profile-card .profile-name{color:var(--ink);font-size:1.04rem;font-weight:900}.signal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-bottom:1px solid var(--line)}.signal-grid div{min-height:92px;padding:.95rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.signal-grid div:nth-child(2n){border-right:0}.signal-grid div:nth-last-child(-n+2){border-bottom:0}.signal-grid span{display:block;color:var(--soft);font-size:.76rem}.signal-grid strong{display:block;margin-top:.35rem;font-size:1.02rem;line-height:1.15}.system-map{position:relative;min-height:286px;padding:1rem;background:linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),linear-gradient(var(--grid-line) 1px,transparent 1px),var(--map-bg);background-size:24px 24px,24px 24px,auto}.map-canvas{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none}.system-map:before,.system-map:after{content:none}.map-node{position:absolute;z-index:1;min-width:104px;padding:.58rem .68rem;border:1px solid var(--line-strong);border-radius:var(--radius);background:color-mix(in srgb,var(--paper) 90%,transparent);font-size:.76rem;font-weight:800;box-shadow:0 10px 24px #1717170f;backdrop-filter:blur(8px);transition:border-color .18s ease,box-shadow .18s ease,filter .18s ease}.map-node.is-active-route{border-color:color-mix(in srgb,var(--blue) 58%,var(--ink));box-shadow:0 0 0 1px color-mix(in srgb,var(--blue) 24%,transparent),0 14px 34px color-mix(in srgb,var(--blue) 18%,transparent);filter:saturate(1.16)}.map-node-main.is-active-route{box-shadow:0 0 0 1px color-mix(in srgb,var(--amber) 38%,transparent),0 18px 42px color-mix(in srgb,var(--amber) 20%,transparent)}.map-node-main{left:50%;top:50%;min-width:168px;transform:translate(-50%,-50%);border-radius:var(--radius);background:var(--ink);color:var(--paper)}.map-node-main span{display:block;margin-top:.2rem;color:#f4f1eab8;font-size:.7rem;font-weight:600}.map-node[data-map-node="0"]{left:1.25rem;top:2rem;background:color-mix(in srgb,var(--green) 16%,var(--white))}.map-node[data-map-node="1"]{right:1.25rem;top:4.8rem;background:color-mix(in srgb,var(--blue) 15%,var(--white))}.map-node[data-map-node="2"]{left:1.25rem;bottom:3rem;background:color-mix(in srgb,var(--amber) 17%,var(--white))}.map-node[data-map-node="3"]{right:1.25rem;bottom:2rem;background:color-mix(in srgb,var(--rose) 14%,var(--white))}.proof-section,.page-grid{max-width:var(--max);margin:0 auto;padding-inline:clamp(1rem,4vw,2.5rem)}.proof-section{padding-bottom:3.8rem}.section-title{display:flex;align-items:end;justify-content:space-between;gap:1.4rem;margin-bottom:1.25rem}.section-title h2,.contact-section h2{max-width:680px;margin:0;font-size:clamp(1.45rem,2.7vw,2.4rem);line-height:1.12;letter-spacing:0}.proof-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));border:1px solid var(--line-strong);background:var(--line-strong);gap:1px;border-radius:var(--radius);overflow:hidden}.proof-grid article{min-height:112px;padding:.95rem;background:var(--surface-strong);backdrop-filter:blur(10px)}.proof-grid strong{display:block;font-size:clamp(1.55rem,2.7vw,2.35rem);line-height:1}.proof-grid span{display:block;margin-top:.72rem;color:var(--muted);font-size:.82rem;font-weight:650}.page-grid{display:grid;grid-template-columns:260px minmax(0,1fr);gap:clamp(1.6rem,4.2vw,4rem);align-items:start;padding-bottom:4rem}.resume-rail{position:sticky;top:88px;padding:1rem;border:1px solid rgba(23,23,23,.82);border-radius:var(--radius);background:var(--ink);color:var(--paper);box-shadow:var(--shadow)}.resume-rail h2{margin:0;font-size:1.5rem;line-height:1.15}.resume-rail p:not(.rail-label){margin:.52rem 0 1rem;color:var(--inverse-muted);font-size:.88rem}.resume-rail dl{display:grid;gap:1px;margin:0;overflow:hidden;border-radius:var(--radius);background:#f4f1ea29}.resume-rail dl div{padding:.74rem;background:#f4f1ea14}.resume-rail dt{color:#f4f1ea85;font-size:.74rem;text-transform:uppercase}.resume-rail dd{margin:.25rem 0 0;font-size:.86rem;font-weight:700;overflow-wrap:anywhere}.email-list{display:grid;gap:.35rem}.content-flow{min-width:0}.section{padding:3.4rem 0;border-top:1px solid var(--line-strong)}.section:first-child{padding-top:0;border-top:0}.strength-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.strength-grid article{min-height:132px;padding:1rem;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--surface);backdrop-filter:blur(10px);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.strength-grid article:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--green) 42%,var(--line-strong));box-shadow:0 16px 34px #17171712}.strength-grid span{color:var(--amber);font-weight:900;font-size:.82rem}.strength-grid p{margin:.82rem 0 0;color:var(--muted);font-size:.92rem}.skill-list{display:grid;border-top:1px solid var(--line-strong)}.skill-list article{display:grid;grid-template-columns:160px minmax(0,1fr);gap:1rem;padding:.9rem 0;border-bottom:1px solid var(--line-strong)}.skill-list h3{margin:0;font-size:.94rem}.skill-list article div,.tech-line,.filter-tabs{display:flex;flex-wrap:wrap;gap:.45rem}.skill-list span,.tech-line span{display:inline-flex;align-items:center;min-height:26px;padding:0 .6rem;border:1px solid var(--line);border-radius:999px;background:var(--surface-strong);color:var(--muted);font-size:.76rem;font-weight:700;transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.skill-list span:hover,.tech-line span:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--blue) 42%,var(--line));color:var(--ink)}.with-action{align-items:start}.filter-tabs{justify-content:flex-end;max-width:500px}.filter-tabs button{min-height:30px;padding:0 .64rem;border:1px solid var(--line-strong);border-radius:999px;background:var(--surface);color:var(--muted);cursor:pointer;font:inherit;font-size:.76rem;font-weight:800;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.filter-tabs button:hover,.filter-tabs button.active{transform:translateY(-1px);border-color:var(--ink);background:var(--ink);color:var(--paper)}.project-stack{display:grid;gap:.86rem}.project-row{display:grid;grid-template-columns:66px minmax(0,1fr);border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--surface-strong);overflow:hidden;box-shadow:0 16px 36px #17171712;backdrop-filter:blur(12px);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.project-row:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--blue) 42%,var(--line-strong));box-shadow:0 20px 42px #17171717}.project-row[hidden]{display:none}.project-index{display:flex;flex-direction:column;align-items:center;gap:.58rem;padding-top:1rem;border-right:1px solid var(--line);color:var(--soft);font-size:.82rem;font-weight:900}.project-index>span:not(.brand-logo){line-height:1}.project-main{padding:1rem}.project-head{display:flex;justify-content:space-between;gap:1rem}.project-head h3{margin:0;font-size:clamp(1.08rem,1.8vw,1.45rem);line-height:1.18}.project-head p{margin:.22rem 0 0;color:var(--muted);font-size:.86rem;font-weight:700}.project-head time{flex:0 0 auto;color:var(--rose);font-size:.78rem;font-weight:900}.project-summary{margin:.78rem 0 0;color:var(--muted);font-size:.9rem}.project-row ul{margin:.76rem 0;padding-left:1.15rem}.project-row li,.experience-list li{margin-bottom:.42rem;color:var(--muted);font-size:.88rem}.experience-list{display:grid;gap:1px;border:1px solid var(--line-strong);background:var(--line-strong)}.experience-list article{display:grid;grid-template-columns:166px minmax(0,1fr);gap:1rem;padding:1rem;background:var(--surface);backdrop-filter:blur(10px)}.experience-brand{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start}.experience-list time{color:var(--blue);font-size:.82rem;font-weight:900}.experience-list h3,.domain-strip strong{margin:0;font-size:1rem}.experience-list p{margin:.2rem 0 .68rem;color:var(--muted);font-size:.88rem;font-weight:700}.experience-list ul{margin:0;padding-left:1.15rem}.domain-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.domain-strip article{display:grid;gap:.4rem;min-height:120px;align-content:space-between;padding:.9rem;border:1px solid var(--line-strong);border-radius:var(--radius);background:linear-gradient(135deg,rgba(31,143,95,.14),transparent 48%),var(--surface-strong);backdrop-filter:blur(10px);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.domain-strip article:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--amber) 46%,var(--line-strong));box-shadow:0 16px 34px #17171712}.domain-strip .brand-logo{width:38px;height:38px}.domain-strip em{color:var(--muted);font-size:.84rem;font-style:normal}.contact-section{display:grid;grid-template-columns:minmax(0,.92fr) minmax(280px,.68fr);gap:clamp(1.2rem,4vw,2.2rem);align-items:stretch;margin-top:3.2rem;padding:clamp(1.2rem,3.6vw,2rem);border:1px solid rgba(23,23,23,.82);border-radius:var(--radius);background:var(--ink);color:var(--paper);box-shadow:var(--shadow)}.contact-section>div:first-child{display:grid;align-content:start}.contact-section h2{max-width:440px;font-size:clamp(1.65rem,3.2vw,2.55rem);line-height:1.1}.contact-section span{display:block;margin-top:.62rem;color:color-mix(in srgb,currentColor 62%,transparent);font-size:.88rem}.contact-actions{display:grid;gap:.6rem;align-content:center;min-width:0;margin-top:0;padding:.78rem;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:var(--radius);background:color-mix(in srgb,currentColor 5%,transparent)}.contact-section .button{width:100%;min-height:40px;justify-content:flex-start;padding-inline:.82rem;border-color:color-mix(in srgb,currentColor 16%,transparent);border-radius:var(--radius);background:color-mix(in srgb,currentColor 4%,transparent);color:currentColor;font-size:.82rem}.contact-section .button-primary{border-color:var(--paper);background:var(--paper);color:var(--ink)}.footer{padding:1.6rem 1rem;color:var(--soft);text-align:center;font-size:.8rem}.reveal{opacity:0;transform:translateY(18px);transition:opacity .52s ease,transform .52s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}.is-pressed{animation:press-feedback .42s ease}@keyframes press-feedback{0%{box-shadow:0 0 color-mix(in srgb,var(--amber) 36%,transparent);filter:saturate(1)}44%{box-shadow:0 0 0 5px color-mix(in srgb,var(--amber) 20%,transparent),0 0 22px color-mix(in srgb,var(--blue) 18%,transparent);filter:saturate(1.18)}to{box-shadow:0 0 color-mix(in srgb,var(--amber) 0%,transparent);filter:saturate(1)}}@media(max-width:1080px){.topbar{grid-template-columns:auto 1fr auto}.nav{justify-self:center}.hero{grid-template-columns:1fr;min-height:auto;gap:2rem}.hero-panel{max-width:580px}.proof-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.page-grid{grid-template-columns:1fr}.resume-rail{position:static}}@media(max-width:760px){.topbar{grid-template-columns:1fr auto;min-height:58px}.brand strong,.nav{display:none}.hero{padding-top:2.8rem}.hero h1{font-size:clamp(2.12rem,10.8vw,3.15rem)}.lead{font-size:.96rem}.hero-panel{box-shadow:var(--shadow)}.signal-grid,.proof-grid,.strength-grid,.domain-strip,.contact-section{grid-template-columns:1fr}.system-map{min-height:270px}.section-title,.section-title.with-action,.project-head,.contact-section{align-items:start;flex-direction:column}.section-title{display:block}.filter-tabs{justify-content:start;margin-top:1rem}.skill-list article,.project-row,.experience-list article{grid-template-columns:1fr}.project-index{flex-direction:row;align-items:center;padding:.68rem .9rem;border-right:0;border-bottom:1px solid var(--line)}.experience-brand{flex-direction:row;align-items:center}.contact-actions{width:100%;margin-top:0}}@media(max-width:460px){.button,.topbar-cta{width:100%}.topbar-cta{width:auto}.hero-actions,.contact-actions{flex-direction:column}.map-node{min-width:88px;font-size:.68rem}.map-node-main{min-width:146px}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.ambient-canvas,.map-canvas{display:none}.reveal,.button,.nav a,.topbar-cta,.github-link,.control-button,.filter-tabs button,.project-row,.strength-grid article,.domain-strip article,.skill-list span,.tech-line span,.map-node{transition:none}.is-pressed{animation:none}.reveal{opacity:1;transform:none}}
