:root{--bg: #eef1f4;--fg: #18261d;--muted: #7c857e;--accent: #10b981;--accent-2: #34d399;--accent-3: #6ee7b7;--grad: linear-gradient(0deg, var(--accent), var(--accent));--paper: rgba(255, 255, 255, .66);--paper-solid: #ffffff;--paper-green: #eaf4ee;--border: rgba(20, 40, 28, .1);--glass-border: rgba(255, 255, 255, .75);--glass-blur: 16px;--radius-lg: 26px;--radius-md: 18px;--shadow-soft: 0 14px 44px -16px rgba(20, 50, 35, .2);--shadow-card: 0 8px 30px -12px rgba(20, 50, 35, .14);--side-width: 220px;--max-content: 720px;--font-sans: "Avenir Next", "Helvetica Neue", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-serif: "Bodoni 72", Didot, "Bodoni 72 Smallcaps", Georgia, "Songti SC", serif;--font-display: "Avenir Next Condensed", "Helvetica Neue Condensed Black", "Arial Narrow", Impact, "PingFang SC", sans-serif;--nav-overlay-width: 68px;--content-safe-left: 86px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;color:var(--fg);font-family:var(--font-sans);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;background:#f3f8f4}body:before{content:"";position:fixed;inset:-20vmax;z-index:-2;pointer-events:none;background:radial-gradient(30% 34% at 20% 26%,rgba(110,231,183,.12),transparent 65%),radial-gradient(32% 36% at 74% 78%,rgba(134,239,172,.1),transparent 66%),linear-gradient(160deg,#fdfefe,#fbfdfc 55%,#f9fdfb);background-color:#fdfefe;filter:blur(8px);animation:bgFlow 30s ease-in-out infinite alternate}@keyframes bgFlow{0%{transform:translate3d(-2%,-1%,0) scale(1.05)}50%{transform:translate3d(2%,2%,0) scale(1.12)}to{transform:translate3d(1%,-2%,0) scale(1.06)}}body:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:linear-gradient(to right,color-mix(in srgb,var(--accent) 8%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--accent) 8%,transparent) 1px,transparent 1px);background-size:clamp(58px,6vw,84px) clamp(58px,6vw,84px);-webkit-mask-image:radial-gradient(135% 120% at 50% 42%,#000 58%,transparent 100%);mask-image:radial-gradient(135% 120% at 50% 42%,#000 58%,transparent 100%)}@media(prefers-reduced-motion:reduce){body:before{animation:none}}.device-gate{display:none}.device-gate-card{width:100%;max-width:340px;background:var(--paper-solid);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:38px 26px 30px;text-align:center;display:flex;flex-direction:column;align-items:center}.dg-brand{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:14px;color:var(--accent)}.dg-icon{width:56px;height:56px;color:var(--accent);margin:20px 0 2px}.dg-title{font-family:var(--font-serif);font-size:27px;line-height:1.2;margin:8px 0 12px;color:var(--fg)}.dg-text{font-size:15px;line-height:1.65;margin:0;color:color-mix(in srgb,var(--fg) 72%,var(--bg))}.dg-url{color:var(--accent);font-weight:600;white-space:nowrap}.dg-foot{font-size:13px;color:var(--accent);margin:18px 0 0;letter-spacing:.02em}@media(max-width:800px)and (pointer:coarse){.device-gate{display:flex;position:fixed;inset:0;z-index:2147483000;align-items:center;justify-content:center;padding:24px;background-color:#f3f8f4;background-image:linear-gradient(to right,color-mix(in srgb,var(--accent) 8%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--accent) 8%,transparent) 1px,transparent 1px);background-size:56px 56px}html,body{overflow:hidden}}a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s ease,color .15s ease}a:hover{border-bottom-color:var(--accent)}p{margin:0 0 1rem}h1,h2,h3{font-family:var(--font-serif);line-height:1.2;letter-spacing:0}.muted{color:var(--muted)}.side-nav{position:fixed;left:0;top:0;width:var(--nav-overlay-width);height:100vh;padding:calc(clamp(1.1rem,3vh,2rem) - .35rem) .75rem 1rem;display:flex;flex-direction:column;gap:1.15rem;border-right:none;background:transparent;z-index:80}.brand{display:flex;flex-direction:column;gap:.1rem;color:var(--fg);border-bottom:none;text-decoration:none;margin-left:.15rem;position:relative;width:34px;padding:.35rem .3rem;border-radius:14px;transition:background .2s ease,transform .2s ease}.brand-name{font-family:var(--font-display);font-size:1.05rem;font-weight:900;letter-spacing:-.01em;line-height:1.04;color:var(--accent);transition:opacity .25s ease}.brand-star{display:none}.brand-role{font-size:.62rem;color:var(--muted);letter-spacing:0;text-transform:uppercase;opacity:.8;transition:color .2s ease,opacity .2s ease,transform .2s ease}.brand:hover,.brand:focus-visible{background:color-mix(in srgb,var(--accent) 12%,transparent);transform:translate(1px)}.brand:hover .brand-name,.brand:focus-visible .brand-name{color:var(--accent)}.brand:hover .brand-role,.brand:focus-visible .brand-role{color:color-mix(in srgb,var(--accent),var(--muted) 40%);opacity:1;transform:translate(1px)}.side-nav-list{position:fixed;left:50%;bottom:clamp(1.6rem,5vh,3.5rem);transform:translate(-50%);display:flex;flex-direction:row;align-items:center;gap:.4rem;padding:.55rem;border-radius:28px;background:color-mix(in srgb,var(--paper) 90%,transparent);backdrop-filter:blur(var(--glass-blur)) saturate(1.1);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.1);border:1px solid var(--glass-border);box-shadow:0 20px 44px -16px color-mix(in srgb,var(--fg) 38%,transparent),var(--shadow-card);z-index:90}.nav-item{position:relative;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:16px;color:var(--accent);text-decoration:none;border-bottom:none;transition:background .2s ease,transform .2s ease}.nav-item:hover{background:color-mix(in srgb,var(--accent) 14%,transparent);transform:translateY(-3px)}.nav-item.is-active{background:var(--accent)}.nav-item.is-active .nav-ico{color:#fff}.nav-ico{font-family:var(--font-display);font-weight:900;font-size:2rem;line-height:1;color:var(--accent)}.nav-label{position:absolute;bottom:calc(100% + .5rem);left:50%;transform:translate(-50%) translateY(4px);padding:.3rem .65rem;border-radius:999px;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:800;font-size:.82rem;line-height:1;letter-spacing:-.01em;white-space:nowrap;box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 32%,transparent);opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease}.nav-item:hover .nav-label,.nav-item:focus-visible .nav-label{opacity:1;transform:translate(-50%) translateY(0)}.side-foot{margin-top:auto;font-size:.72rem;color:var(--muted);display:none}.side-email{color:var(--muted);border-bottom:none;word-break:break-all}.side-email:hover{color:var(--accent)}.side-copy{margin:0;font-size:.72rem;opacity:.7}.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.1;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}.spline-stage{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none;background:transparent}.hero-bigname{position:fixed;top:clamp(.8rem,4vh,3rem);left:clamp(1.2rem,3.5vw,3.5rem);z-index:-1;display:flex;flex-direction:column;align-items:flex-start;transform-origin:top left;will-change:transform,opacity;line-height:.82;font-family:var(--font-display);font-weight:900;font-size:clamp(5.6rem,18vw,21rem);letter-spacing:-.01em;-webkit-text-stroke:var(--bn-stroke, 0px) var(--accent);pointer-events:none;user-select:none}.hero-bigname .bn-line{display:block;white-space:nowrap}.hero-bigname .bn-ch{display:inline-block;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;will-change:transform,opacity}.cursor-square{position:fixed;top:0;left:0;width:26px;height:26px;border:1.5px solid var(--accent);border-radius:6px;pointer-events:none;z-index:200;opacity:0;mix-blend-mode:multiply;will-change:transform,width,height;transition:border-radius .28s ease,border-width .2s ease,background .15s ease}.cursor-square.is-pressed:not(.is-snapped){background:var(--accent);border-color:var(--accent);mix-blend-mode:normal}.cursor-square.is-on{opacity:.85}::view-transition-old(root){animation:pageFadeOut .32s ease both}::view-transition-new(root){animation:pageFadeIn .42s cubic-bezier(.22,1,.36,1) both}@keyframes pageFadeOut{0%{opacity:1}to{opacity:0}}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){::view-transition-old(root),::view-transition-new(root){animation:none}}.cursor-square.is-snapped{border-width:2px;border-radius:50%;background:color-mix(in srgb,var(--accent) 8%,transparent)}.cursor-square.is-navframe{border-radius:16px}@media(max-width:800px){.cursor-square{display:none}}@media(prefers-reduced-motion:reduce){.cursor-square{display:none}}@media(max-width:800px){.hero-bigname{display:none}}.disco-dim{position:fixed;inset:0;z-index:95;pointer-events:none;background:radial-gradient(circle 820px at var(--disco-x, 50vw) var(--disco-y, 50vh),rgba(34,36,44,0) 0%,rgba(34,36,44,0) 5%,rgba(34,36,44,.52) 34%,rgba(34,36,44,.56) 70%,rgba(34,36,44,.5) 100%);opacity:0;transition:opacity .5s ease}body.disco-on .disco-dim{opacity:1}.disco-tint{position:fixed;inset:0;z-index:96;pointer-events:none;opacity:0;transition:opacity .5s ease;mix-blend-mode:soft-light;overflow:hidden;-webkit-mask-image:radial-gradient(circle 150px at var(--disco-x, 50vw) var(--disco-y, 50vh),transparent 0%,transparent 42%,#000 78%);mask-image:radial-gradient(circle 150px at var(--disco-x, 50vw) var(--disco-y, 50vh),transparent 0%,transparent 42%,#000 78%)}.disco-tint:before{content:"";position:absolute;left:-50%;top:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,#ff5d7e,#ffd23a,#4ddf9a,#4aa8ff,#c78bff,#ff8fb8,#ff5d7e);filter:blur(46px);transform-origin:center center;animation:discoSpin 18s linear infinite}body.disco-on .disco-tint{opacity:.6}.disco-dots{position:fixed;inset:0;z-index:97;pointer-events:none;opacity:0;transition:opacity .5s ease;mix-blend-mode:screen;overflow:hidden;-webkit-mask-image:radial-gradient(circle 660px at var(--disco-x, 50vw) var(--disco-y, 50vh),transparent 0%,transparent 20%,#000 28%,rgba(0,0,0,.85) 45%,rgba(0,0,0,.35) 70%,transparent 90%);mask-image:radial-gradient(circle 660px at var(--disco-x, 50vw) var(--disco-y, 50vh),transparent 0%,transparent 20%,#000 28%,rgba(0,0,0,.85) 45%,rgba(0,0,0,.35) 70%,transparent 90%)}.disco-dots:before{content:"";position:absolute;left:-75%;top:-75%;width:250%;height:250%;background-image:radial-gradient(circle,rgba(255,255,255,.95) 1.5px,transparent 2.3px),radial-gradient(circle,rgba(255,255,255,.7) 1px,transparent 1.7px),radial-gradient(circle,rgba(214,230,255,.6) 1.2px,transparent 1.9px);background-size:64px 64px,41px 41px,97px 97px;background-position:0 0,19px 27px,33px 11px;transform-origin:center center;animation:discoSpin 28s linear infinite}body.disco-on .disco-dots{opacity:.9}@keyframes discoSpin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.disco-dots:before{animation:none}}.content{position:relative;z-index:1;margin-left:0;min-height:100vh}.section{padding:6rem 3rem 4rem calc(3rem + var(--content-safe-left));max-width:calc(var(--max-content) + 6rem);scroll-margin-top:1rem}.section+.section{border-top:1px solid color-mix(in srgb,var(--accent) 14%,transparent)}body.is-project{overflow:hidden}body.is-project .project-backdrop{position:fixed;inset:0;z-index:105;background:linear-gradient(to right,#08080e05,#08080e14);backdrop-filter:none;border-bottom:none}body.is-project .content{view-transition-name:project-drawer;position:fixed;inset:0;z-index:120;display:flex;justify-content:flex-end;pointer-events:none}body.is-project .section{width:min(75vw,1240px);max-width:none;height:100vh;margin-left:auto;border-left:1px solid var(--border);background:color-mix(in srgb,var(--bg),transparent 1%);padding:3rem clamp(2rem,3vw,3rem) 4rem;box-shadow:-16px 0 48px #0000003d;pointer-events:auto;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}body.is-embed-runtime .content{margin-left:0}body.is-embed-runtime .section{width:100%;max-width:min(980px,100%);min-height:auto;margin:0 auto;border:none;background:transparent;box-shadow:none;padding:2.4rem clamp(3rem,5.5vw,6rem) 3.2rem}body.is-embed-runtime .back-button,body.is-embed-runtime .side-nav,body.is-embed-runtime .project-backdrop{display:none}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slide-out-right{0%{transform:translate(0)}to{transform:translate(100%)}}::view-transition-old(project-drawer){animation:.28s cubic-bezier(.4,0,.2,1) both slide-out-right}::view-transition-new(project-drawer){animation:.32s cubic-bezier(.4,0,.2,1) both slide-in-right}h1{font-size:2.5rem;margin:0 0 .5rem}h2{font-size:1.5rem;margin:0 0 1rem}h3{font-size:1.15rem;margin:1.5rem 0 .5rem}.grad-text,.section-label{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.section-label{display:inline-block;font-family:var(--font-sans);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;margin-bottom:1rem}.lead{font-size:1.2rem;color:var(--muted);font-family:var(--font-sans);font-weight:500;margin:0 0 2.5rem;line-height:1.5;max-width:36em}.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-top:1.5rem}.work-card{display:flex;flex-direction:column;gap:.4rem;padding:1.5rem;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:inherit;background:var(--paper);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-card);transition:transform .2s,border-color .2s,box-shadow .2s;text-decoration:none}.work-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:var(--glass-border)}.work-card .card-year{font-size:.78rem;color:var(--accent);letter-spacing:.08em;font-weight:700}.work-card .card-title{font-family:var(--font-serif);font-size:1.05rem;margin:0;line-height:1.3;color:var(--fg)}.work-card .card-desc{font-size:.88rem;color:var(--muted);margin:0;line-height:1.5}.work-card .card-tags{font-size:.72rem;color:var(--muted);letter-spacing:.06em;margin-top:auto;padding-top:.5rem}.prose img{max-width:100%;height:auto;border-radius:4px}.prose blockquote{border-left:3px solid var(--accent);margin:1.5rem 0;padding:.25rem 1rem;color:var(--muted)}.prose code{background:#0000000f;padding:.1em .35em;border-radius:3px;font-size:.92em}.prose pre{padding:1rem;border-radius:6px;overflow-x:auto}.prose iframe{max-width:100%}.back-button{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--muted);border:1px solid var(--border);padding:.4rem .85rem;border-radius:4px;margin-bottom:2rem;background:var(--bg)}.back-button:hover{border-color:var(--accent);color:var(--accent)}@media(max-width:800px){:root{--content-safe-left: 0px;--nav-overlay-width: 0px}.side-nav{position:sticky;top:0;width:100%;height:auto;flex-direction:row;gap:.5rem;padding:.6rem 1rem;border-right:none;border-bottom:1px solid var(--border);align-items:center;overflow-x:visible;background:color-mix(in srgb,var(--bg),transparent 8%);backdrop-filter:blur(10px)}.brand{width:auto;flex-direction:row;align-items:baseline;gap:.4rem;margin-left:0}.brand-role{display:inline}.side-nav-list{gap:.3rem;padding:.45rem;bottom:clamp(1rem,3vh,2rem)}.nav-item{width:52px;height:52px}.nav-ico{font-size:1.7rem}.side-foot{display:none}.content{margin-left:0}.section{padding:2.5rem 1.5rem}body.is-project .content{display:block;position:relative;inset:auto;z-index:auto;pointer-events:auto}body.is-project .project-backdrop{display:none}body.is-project .section{width:auto;min-height:auto;margin-left:0;border-left:none;padding:1.5rem 1.5rem 3rem;background:transparent}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
