:root{--bg: #0a0a0a;--bg-2: #100f0e;--bg-3: #161513;--fg: #e8e6e1;--muted: rgba(232, 230, 225, .52);--faint: rgba(232, 230, 225, .55);--line: rgba(232, 230, 225, .13);--line-2: rgba(232, 230, 225, .07);--accent: oklch(.88 .2 124);--accent-ink: #0a0a0a;--display: "Clash Display", sans-serif;--sans: "General Sans", sans-serif;--mono: "JetBrains Mono", monospace;--ease: cubic-bezier(.16, 1, .3, 1);--maxw: 1500px;--gut: clamp(20px, 5vw, 80px)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg);transition:background-color .6s var(--ease)}body{background:transparent;color:var(--fg);font-family:var(--sans);font-size:17px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}:focus:not(:focus-visible){outline:none}.skip-link{position:fixed;top:10px;left:10px;z-index:10002;transform:translateY(-160%);background:var(--accent);color:var(--accent-ink);padding:10px 18px;border-radius:8px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;transition:transform .25s var(--ease)}.skip-link:focus{transform:none}#view:focus{outline:none}#view{position:relative;z-index:1}@media (max-width: 820px){body{cursor:auto}}::selection{background:var(--accent);color:var(--accent-ink)}a{color:inherit;text-decoration:none}img,canvas{display:block}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.vignette{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8999;pointer-events:none;box-shadow:inset 0 0 240px 40px #0009}.cursor{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;width:9px;height:9px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .2s;mix-blend-mode:difference}.cursor-ring{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;width:38px;height:38px;border-radius:50%;border:1px solid rgba(232,230,225,.5);transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),border-color .3s,opacity .2s}body.cursor-hover .cursor{width:4px;height:4px}body.cursor-hover .cursor-ring{width:64px;height:64px;border-color:var(--accent)}@media (max-width: 820px){.cursor,.cursor-ring{display:none}}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}section{position:relative}.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:12px}.eyebrow:before{content:"";width:28px;height:1px;background:var(--accent);display:inline-block}.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:28px;margin-bottom:56px}.sec-num{font-family:var(--mono);color:var(--accent);font-size:13px;letter-spacing:.1em}.sec-title{font-family:var(--display);font-weight:600;font-size:clamp(2rem,5.5vw,4.5rem);line-height:.95;letter-spacing:-.02em}.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}.reveal.in{opacity:1;transform:none}.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}html{scroll-behavior:auto}.reveal{opacity:1!important;transform:none!important}.line-mask>span{transform:none!important}.marquee-track,.hero-status .pulse,.scroll-cue .bar:after,.holo.aurora,.title-underline path,.trail-dot{animation:none!important}}.line-mask{overflow:hidden;display:block}.line-mask>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}.line-mask.in>span{transform:none}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:18px var(--gut);background:transparent;border-bottom:1px solid transparent;transition:border-color .35s var(--ease)}body.scrolled .nav{background:color-mix(in oklch,var(--bg) 86%,transparent);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-bottom-color:var(--line)}.nav .brand{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}.nav .brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent)}.nav-links{display:flex;gap:30px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.nav-links a{position:relative;color:var(--fg);opacity:.85}.nav-links a:after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--fg);transition:width .35s var(--ease)}.nav-links a:hover:after{width:100%}.nav .clock{font-family:var(--mono);font-size:12px;letter-spacing:.05em}.nav-toggle,.mobile-menu{display:none}@media (max-width: 820px){.nav-links,.nav .clock{display:none}.nav-toggle{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:5px;width:44px;height:44px;background:none;border:none;padding:0;cursor:pointer;z-index:1002}.nav-toggle span{display:block;width:24px;height:2px;background:var(--fg);transition:transform .3s var(--ease),opacity .25s}body.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}body.menu-open .nav-toggle span:nth-child(2){opacity:0}body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1001;background:color-mix(in oklch,var(--bg) 97%,transparent);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);display:flex;flex-direction:column;justify-content:center;gap:6px;padding:0 var(--gut);transform:translateY(-100%);transition:transform .5s var(--ease);pointer-events:none}body.menu-open .mobile-menu{transform:none;pointer-events:auto}.mobile-menu .mm-link{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:-.02em;font-size:clamp(2.4rem,13vw,4rem);line-height:1.1;color:var(--fg);padding:8px 0;border-bottom:1px solid var(--line)}.mobile-menu .mm-link.active{color:var(--accent)}.mobile-menu .mm-foot{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:40px;letter-spacing:.05em}}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(96px,15vh,168px) 0 clamp(36px,7vh,84px);position:relative;overflow:hidden}#hero-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;width:100%;height:100%}.hero .wrap{position:relative;z-index:2;width:100%}.hero-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative;z-index:2}.hero-meta{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--muted);max-width:320px;line-height:1.7}.hero-meta b{color:var(--fg);font-weight:500}.hero-status{font-family:var(--mono);font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:9px}.hero-status .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in oklch,var(--accent) 70%,transparent)}70%{box-shadow:0 0 0 12px transparent}to{box-shadow:0 0 0 0 transparent}}.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,min(13.5vw,17vh),13rem);line-height:.84;letter-spacing:-.035em;text-transform:uppercase}.hero h1 .ln{display:block}.hero h1 .outline{-webkit-text-stroke:1.4px var(--fg);color:transparent}.hero h1.mode-magnet .ch{will-change:transform}.hero h1.mode-weight .ch{will-change:font-variation-settings}.hero h1.mode-tilt .ln{will-change:transform}.hero h1.mode-weight{font-family:Archivo,sans-serif;font-weight:500;letter-spacing:-.02em}.hero h1.mode-weight .ch{transition:font-variation-settings .12s linear}.hero h1.mode-weight .outline{-webkit-text-stroke:1.2px var(--fg)}.hero h1.mode-tilt .ln{transition:transform .15s var(--ease);transform-style:preserve-3d;transform-origin:left center}.hero h1.mode-magnet .ch{display:inline-block;transition:transform .04s linear}.hero-sub{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-top:clamp(14px,3vh,30px);flex-wrap:wrap;border-top:1px solid var(--line);padding-top:clamp(12px,2.4vh,22px)}.hero-sub p{max-width:440px;color:var(--muted);font-size:17px}.hero-sub p b{color:var(--fg);font-weight:500}.scroll-cue{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}.scroll-cue .bar{width:1px;height:34px;background:var(--line);position:relative;overflow:hidden}.scroll-cue .bar:after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--accent);animation:scrolldn 1.8s var(--ease) infinite}@keyframes scrolldn{0%{transform:translateY(-100%)}to{transform:translateY(250%)}}.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:16px 0;background:var(--bg-2)}.marquee-track{display:flex;gap:60px;white-space:nowrap;width:max-content;animation:marq 32s linear infinite}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-track span{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,3.5vw,2.6rem);letter-spacing:-.01em;display:inline-flex;align-items:center;gap:60px;color:var(--faint)}.marquee-track span:after{content:"✳︎";color:var(--accent);font-size:.7em}.marquee-track .hot{color:var(--fg)}@keyframes marq{to{transform:translate(-50%)}}.block{padding:clamp(80px,13vh,170px) 0}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,100px);align-items:start}.about-lead{font-family:var(--display);font-weight:400;font-size:clamp(1.6rem,3.2vw,2.7rem);line-height:1.15;letter-spacing:-.02em}.about-lead em{font-style:normal;color:var(--accent)}.about-body{color:var(--muted);font-size:17px;line-height:1.7;display:flex;flex-direction:column;gap:18px;padding-top:8px}.about-body b{color:var(--fg);font-weight:500}.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:30px}.fact{background:var(--bg);padding:22px 20px}.fact .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}.fact .v{font-family:var(--display);font-weight:600;font-size:1.5rem;margin-top:6px}@media (max-width: 820px){.about-grid{grid-template-columns:1fr}}@media (max-width: 600px){.sec-head{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:40px}.sec-title{font-size:clamp(1.7rem,8vw,2.6rem)}.facts{grid-template-columns:1fr}}.feat{display:flex;flex-direction:column}.feat-item{display:grid;grid-template-columns:64px 1.1fr 1fr;gap:clamp(20px,4vw,60px);align-items:center;padding:clamp(28px,4vw,52px) 0;border-top:1px solid var(--line);position:relative;transition:padding-left .5s var(--ease)}.feat-item:last-child{border-bottom:1px solid var(--line)}.feat-item .fnum{font-family:var(--mono);font-size:13px;color:var(--faint)}.feat-item:hover{padding-left:18px}.feat-item:hover .fnum{color:var(--accent)}.feat-name{font-family:var(--display);font-weight:600;font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1;letter-spacing:-.02em;transition:color .3s}.feat-item:hover .feat-name{color:var(--accent)}.feat-meta{display:flex;flex-direction:column;gap:14px}.feat-desc{color:var(--muted);font-size:16px;line-height:1.6;max-width:460px}.feat-tags{display:flex;flex-wrap:wrap;gap:8px}.tag{font-family:var(--mono);font-size:11px;letter-spacing:.05em;padding:5px 11px;border:1px solid var(--line);border-radius:100px;color:var(--muted)}.feat-arrow{position:absolute;right:0;top:50%;transform:translateY(-50%) translate(-10px);opacity:0;transition:all .4s var(--ease);font-size:26px;color:var(--accent)}.feat-item:hover .feat-arrow{opacity:1;transform:translateY(-50%) translate(0)}.feat-preview{position:fixed;z-index:500;width:320px;height:220px;border-radius:6px;overflow:hidden;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.85);transition:opacity .3s var(--ease),transform .3s var(--ease);border:1px solid var(--line)}.feat-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.feat-preview.portrait{width:200px;height:420px}.feat-preview img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:none}.feat-preview.has-img img{display:block}.feat-preview.has-img .ph{position:absolute;left:10px;bottom:10px;right:auto;width:auto;height:auto;background:#0a0a09b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--fg);padding:5px 11px;border:1px solid var(--line);border-radius:100px}@media (max-width: 820px){.feat-item{grid-template-columns:1fr;gap:16px}.feat-item .fnum,.feat-preview{display:none}}.ph{background:repeating-linear-gradient(45deg,var(--bg-3) 0 10px,var(--bg-2) 10px 20px);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);width:100%;height:100%}.timeline{display:flex;flex-direction:column}.tl-item{display:grid;grid-template-columns:180px 1fr auto;gap:clamp(16px,4vw,60px);padding:34px 0;border-top:1px solid var(--line);align-items:baseline}.tl-item:last-child{border-bottom:1px solid var(--line)}.tl-when{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.04em}.tl-role{font-family:var(--display);font-weight:600;font-size:clamp(1.3rem,2.6vw,1.9rem);letter-spacing:-.01em}.tl-co{color:var(--muted);margin-top:6px;font-size:15px}.tl-desc{color:var(--muted);font-size:15px;line-height:1.6;max-width:420px;margin-top:12px}.tl-place{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.05em;text-align:right}@media (max-width: 820px){.tl-item{grid-template-columns:1fr;gap:8px}.tl-place{text-align:left}}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}.skill-cat{background:var(--bg);padding:34px 30px;transition:background .4s}.skill-cat:hover{background:var(--bg-2)}.skill-cat h4{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:20px}.skill-cat ul{list-style:none;display:flex;flex-direction:column;gap:12px}.skill-cat li{display:flex;align-items:center;justify-content:space-between;font-size:16px;border-bottom:1px dashed var(--line-2);padding-bottom:12px}.skill-cat li:last-child{border-bottom:none}.skill-cat li span{font-family:var(--mono);font-size:12px;color:var(--faint)}@media (max-width: 820px){.skills-grid{grid-template-columns:1fr}}.gh-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:56px}.gh-stat{background:var(--bg);padding:30px 26px}.gh-stat .num{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;letter-spacing:-.02em}.gh-stat .num .suf{color:var(--accent)}.gh-stat .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:10px}@media (max-width: 820px){.gh-grid{grid-template-columns:repeat(2,1fr)}}.contrib{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,1fr);gap:3px;padding:26px;border:1px solid var(--line);overflow-x:auto}.contrib i{width:12px;height:12px;border-radius:2px;background:var(--bg-3);display:block}.contrib i.l1{background:color-mix(in oklch,var(--accent) 25%,var(--bg-3))}.contrib i.l2{background:color-mix(in oklch,var(--accent) 50%,var(--bg-3))}.contrib i.l3{background:color-mix(in oklch,var(--accent) 75%,var(--bg-3))}.contrib i.l4{background:var(--accent)}.repos{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:30px}.repo{background:var(--bg);padding:26px;display:flex;flex-direction:column;gap:12px;transition:background .35s}.repo:hover{background:var(--bg-2)}.repo .rtop{display:flex;align-items:center;justify-content:space-between}.repo .rname{font-family:var(--mono);font-weight:500;font-size:15px}.repo .rname:before{content:"◇ ";color:var(--accent)}.repo .rdesc{color:var(--muted);font-size:14.5px;line-height:1.55}.repo .rmeta{display:flex;gap:20px;font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:auto}.repo .rmeta .lang:before{content:"●";color:var(--accent);margin-right:6px}@media (max-width: 820px){.repos{grid-template-columns:1fr}}.writing{display:flex;flex-direction:column}.post{display:grid;grid-template-columns:120px 1fr auto;gap:clamp(16px,4vw,50px);align-items:center;padding:26px 0;border-top:1px solid var(--line);transition:padding-left .45s var(--ease)}.post:last-child{border-bottom:1px solid var(--line)}.post:hover{padding-left:16px}.post .pdate{font-family:var(--mono);font-size:12px;color:var(--faint)}.post .ptitle{font-family:var(--display);font-weight:500;font-size:clamp(1.2rem,2.6vw,1.7rem);letter-spacing:-.01em;transition:color .3s}.post:hover .ptitle{color:var(--accent)}.post .pread{font-family:var(--mono);font-size:12px;color:var(--muted)}@media (max-width: 820px){.post{grid-template-columns:1fr;gap:6px}}.contact{padding:clamp(90px,16vh,200px) 0;border-top:1px solid var(--line)}.contact h2{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,11vw,11rem);line-height:.85;letter-spacing:-.03em;text-transform:uppercase}.contact h2 a{display:inline-flex;align-items:center;gap:.1em;transition:color .3s}.contact h2 a:hover{color:var(--accent)}.contact-row{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-top:50px;border-top:1px solid var(--line);padding-top:30px}#cta .contact-row{padding-bottom:30px}.contact-links{display:flex;gap:26px;flex-wrap:wrap;font-family:var(--mono);font-size:13px;letter-spacing:.04em}.contact-links a{display:inline-flex;align-items:center;gap:7px;color:var(--muted);transition:color .3s}.contact-links a:hover{color:var(--fg)}.contact-links a:before{content:"↗︎";color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:15px 24px;border:1px solid var(--fg);border-radius:100px;position:relative;overflow:hidden;color:var(--fg);transition:color .4s var(--ease);-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:inherit}.btn span{position:relative;z-index:2}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);transform:translateY(101%);transition:transform .5s var(--ease);z-index:1}.btn:hover{color:var(--accent-ink);border-color:var(--accent)}.btn:hover:before{transform:translateY(0)}.btn.solid{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn.solid:before{background:var(--bg)}.btn.solid:hover{color:var(--fg)}.footer{padding:40px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.04em}.rail{position:fixed;right:22px;top:50%;transform:translateY(-50%);z-index:800;display:flex;flex-direction:column;gap:4px}.rail a{display:flex;align-items:center;justify-content:flex-end;width:52px;height:22px;cursor:pointer}.rail a:before{content:"";width:46px;height:2px;border-radius:1px;background:var(--fg);opacity:.32;transform:scaleX(.61);transform-origin:right center;transition:transform .4s var(--ease),opacity .3s,background .3s}.rail a:hover:before{transform:scaleX(1);opacity:.8}.rail a.active:before{transform:scaleX(1);opacity:1;background:var(--accent)}@media (max-width: 1200px){.rail{display:none}}.progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:1001;width:0}#holo-mesh{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none;opacity:0}[data-holo=mesh] #holo-mesh{opacity:.75}.holo{position:fixed;top:0;right:0;bottom:0;left:0;z-index:6;pointer-events:none;opacity:0;transition:opacity .6s var(--ease)}.holo.sheen{mix-blend-mode:color-dodge;opacity:1;background:radial-gradient(circle 420px at var(--mx, 50%) var(--my, 50%),hsl(var(--holohue, 200) 95% 62% / .3),hsl(calc(var(--holohue, 200) + 70) 95% 58% / .14) 38%,transparent 68%)}.holo.aurora{opacity:1;mix-blend-mode:screen;filter:blur(70px);background-size:220% 220%;background:radial-gradient(40% 50% at 20% 30%,hsl(280 90% 55% / .5),transparent 70%),radial-gradient(45% 55% at 80% 40%,hsl(190 95% 55% / .45),transparent 70%),radial-gradient(40% 45% at 50% 80%,hsl(330 90% 58% / .4),transparent 70%);animation:auroraShift 16s linear infinite}@keyframes auroraShift{0%{filter:blur(70px) hue-rotate(0deg);background-position:0% 0%}to{filter:blur(70px) hue-rotate(360deg);background-position:100% 100%}}body.cur-glow .cursor{width:30px;height:30px;filter:blur(8px);mix-blend-mode:screen;transition:width .3s var(--ease),height .3s var(--ease)}body.cur-glow .cursor-ring{opacity:0}body.cur-glow.cursor-hover .cursor{width:70px;height:70px}.cross{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;mix-blend-mode:difference;opacity:0;transition:opacity .25s;transform:translate(-50%,-50%)}.cross:before,.cross:after{content:"";position:absolute;background:var(--fg)}.cross:before{left:-16px;top:-.5px;width:32px;height:1px}.cross:after{top:-16px;left:-.5px;height:32px;width:1px}.cross i{position:absolute;left:-3px;top:-3px;width:6px;height:6px;border:1px solid var(--accent);transform:rotate(45deg)}body.cur-crosshair .cursor,body.cur-crosshair .cursor-ring{opacity:0}body.cur-crosshair .cross{opacity:1}.spotlight{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8998;pointer-events:none;opacity:0;transition:opacity .5s var(--ease);background:radial-gradient(circle 200px at var(--mx, 50%) var(--my, 50%),transparent 0,transparent 26%,rgba(4,4,4,.42) 55%,rgba(2,2,2,.9) 100%)}body.cur-spotlight .spotlight{opacity:1}@media (max-width: 820px){.cross,.spotlight{display:none!important}}.trail-dot{position:fixed;top:0;left:0;z-index:9990;width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;background:var(--accent);pointer-events:none;opacity:0;mix-blend-mode:screen}.trail-dot.on{animation:trailFade .62s ease-out forwards}@keyframes trailFade{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(.2)}}.ripple{position:fixed;z-index:9500;pointer-events:none;border:1.5px solid var(--accent);border-radius:50%;transform:translate(-50%,-50%);animation:rippleAnim .7s var(--ease) forwards;mix-blend-mode:screen}@keyframes rippleAnim{0%{width:6px;height:6px;opacity:.95}to{width:300px;height:300px;opacity:0}}.spark{position:fixed;z-index:9500;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:screen}.glitch-bar{position:fixed;z-index:9500;pointer-events:none;height:3px;mix-blend-mode:screen}#pt{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9600;pointer-events:none;background:var(--pt-color, var(--accent));display:flex;align-items:center;justify-content:center;transition:transform var(--pt-dur, .52s) var(--ease),opacity var(--pt-dur, .52s) var(--ease)}#pt .pt-name{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(2rem,7vw,5rem);letter-spacing:-.025em;color:#080808d1}#pt.pt-wipe{transform:translateY(105%)}#pt.pt-wipe.cover{transform:translateY(0)}#pt.pt-wipe.out{transform:translateY(-105%)}#pt.pt-slide{transform:translate(105%)}#pt.pt-slide.cover{transform:translate(0)}#pt.pt-slide.out{transform:translate(-105%)}#pt.pt-fade{transform:none;opacity:0}#pt.pt-fade.cover{opacity:1}#pt.pt-fade.out{opacity:0}#pt.noanim{transition:none!important}body:not([data-page=home]) .rail{display:none}.nav-links a.active{color:var(--accent)}.nav-links a.active:after{width:100%;background:var(--accent)}.page-hero{padding:clamp(120px,20vh,230px) 0 clamp(50px,8vh,90px)}.page-hero h1{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(3rem,12vw,11rem);line-height:.86;letter-spacing:-.03em;margin-top:18px}.page-hero .lead{color:var(--muted);font-size:clamp(1.05rem,2vw,1.4rem);max-width:620px;margin-top:28px;line-height:1.5}.page-hero .lead b{color:var(--fg);font-weight:500}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}.proj-card{background:var(--bg);padding:clamp(26px,3vw,46px);display:flex;flex-direction:column;gap:18px;min-height:320px;position:relative;overflow:hidden;transition:background .4s}.proj-card:hover{background:var(--bg-2)}.proj-card .pc-num{font-family:var(--mono);font-size:12px;color:var(--faint)}.proj-card .pc-name{font-family:var(--display);font-weight:600;font-size:clamp(1.8rem,4vw,3rem);line-height:1;letter-spacing:-.02em;transition:color .3s}.proj-card:hover .pc-name{color:var(--accent)}.proj-card .pc-tag{color:var(--muted);font-size:15px}.proj-card .pc-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.proj-card .pc-arrow{font-size:22px;color:var(--accent);transform:translate(-6px);opacity:0;transition:all .4s var(--ease)}.proj-card:hover .pc-arrow{opacity:1;transform:none}@media (max-width: 820px){.proj-grid{grid-template-columns:1fr}}.detail{padding:clamp(96px,14vh,170px) 0 clamp(70px,12vh,150px)}.detail .wrap,.post-detail .wrap{width:100%}.back{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);display:inline-block;margin-bottom:40px;transition:color .3s}.back:hover{color:var(--accent)}.back.big{margin-top:70px}.detail-head{border-bottom:1px solid var(--line);padding-bottom:36px}.detail-title{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(3rem,11vw,10rem);line-height:.85;letter-spacing:-.03em;margin-top:16px}.detail-tag{color:var(--muted);font-size:clamp(1.1rem,2.4vw,1.7rem);margin-top:20px}.detail-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:34px 0;border-bottom:1px solid var(--line)}.detail-meta .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:10px}.detail-meta .v{font-size:16px}.detail-meta .stackcell .feat-tags{margin-top:2px}.detail-hero{aspect-ratio:16 / 7;margin:50px 0;border:1px solid var(--line);overflow:hidden}.detail-hero img,.detail-hero video{width:100%;height:100%;object-fit:cover;display:block}.detail-lead{font-family:var(--display);font-weight:400;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.18;letter-spacing:-.02em;max-width:1000px;margin-bottom:50px}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:60px}.metric{background:var(--bg);padding:30px 26px}.metric .num{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4.5vw,3.4rem);line-height:1;color:var(--accent);letter-spacing:-.02em}.metric .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:12px}.detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(30px,6vw,90px);align-items:start}.detail-body{display:flex;flex-direction:column;gap:20px;color:var(--muted);font-size:17px;line-height:1.7}.detail-features h4{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}.detail-features ul{list-style:none;display:flex;flex-direction:column;gap:14px}.detail-features li{padding-left:22px;position:relative;font-size:16px;border-bottom:1px dashed var(--line-2);padding-bottom:14px}.detail-features li:before{content:"→︎";position:absolute;left:0;color:var(--accent)}.detail-shots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:60px 0}.detail-shots .ph{aspect-ratio:4 / 3}.detail-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:60px 0}.detail-gallery .shot-lead{grid-column:1 / -1}figure.shot{margin:0;border:1px solid var(--line);border-radius:6px;overflow:hidden}figure.shot img,figure.shot video{width:100%;display:block;transition:transform .5s var(--ease)}figure.shot:hover img,figure.shot:hover video{transform:scale(1.025)}figure.shot figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--faint);padding:10px 12px;border-top:1px solid var(--line)}@media (prefers-reduced-motion: reduce){figure.shot:hover img,figure.shot:hover video{transform:none}}.next-proj{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--line);padding-top:40px;transition:padding-left .4s var(--ease)}.next-proj:hover{padding-left:16px}.next-proj .np-k{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}.next-proj .np-name{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,7vw,5.5rem);line-height:1;letter-spacing:-.02em;transition:color .3s}.next-proj:hover .np-name{color:var(--accent)}@media (max-width: 820px){.detail-meta,.metrics,.detail-grid,.detail-shots,.detail-gallery{grid-template-columns:1fr}}.post-detail{padding:clamp(96px,14vh,170px) 0 clamp(70px,12vh,150px)}.wrap.narrow{max-width:820px}.post-head{border-bottom:1px solid var(--line);padding-bottom:34px}.post-title{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,6vw,4.4rem);line-height:1.02;letter-spacing:-.025em;margin-top:16px}.post-byline{font-family:var(--mono);font-size:13px;color:var(--muted);margin-top:22px;letter-spacing:.04em}.post-cover{aspect-ratio:16 / 8;margin:44px 0;border:1px solid var(--line);overflow:hidden}.post-body{display:flex;flex-direction:column;gap:26px;font-size:19px;line-height:1.75;color:var(--fg)}.post-body p{color:#e8e6e1d1}.post-body>*{min-width:0}.post-body :is(h2,h3,h4){font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1.18}.post-body h2{font-size:clamp(1.5rem,3.4vw,2.1rem)}.post-body h3{font-size:clamp(1.25rem,2.6vw,1.6rem)}.post-body :not(pre)>code{font-family:var(--mono);font-size:.88em;background:#ffffff12;border:1px solid var(--line);border-radius:6px;padding:.12em .4em}.post-body pre.shiki{font-family:var(--mono);font-size:14px;line-height:1.6;padding:20px 22px;border:1px solid var(--line);border-radius:12px;overflow-x:auto;-moz-tab-size:2;tab-size:2;max-width:100%}.post-body pre.shiki code{background:none;border:0;padding:0}.post-body img{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:12px}.post-body ul,.post-body ol{padding-left:1.3em;display:flex;flex-direction:column;gap:8px;color:#e8e6e1d1}.post-body li{line-height:1.7}.post-body blockquote{margin:0;padding-left:22px;border-left:2px solid var(--accent);color:var(--muted);font-style:italic}.post-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.post-cover img{width:100%;height:100%;object-fit:cover;display:block}.post .psum{display:block;font-family:var(--sans);font-size:14px;font-weight:400;letter-spacing:0;color:var(--faint);margin-top:6px}.post-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}.post-links a{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:10px 16px;border:1px solid var(--line);border-radius:999px;color:var(--muted);transition:color .3s,border-color .3s}.post-links a:hover{color:var(--accent);border-color:var(--accent)}.cform{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:10px}.cform .fld{background:var(--bg);display:flex;flex-direction:column}.cform .fld.full{grid-column:1 / -1}.cform label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:18px 20px 0}.cform input,.cform textarea{background:transparent;border:none;color:var(--fg);font-family:var(--sans);font-size:17px;padding:10px 20px 20px;resize:none;outline:none}.cform textarea{min-height:120px}.cform input:focus,.cform textarea:focus{color:var(--accent)}.cform input:focus-visible,.cform textarea:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.cform .fld:focus-within{background:var(--bg-2)}.cform .btn{align-self:flex-start}.cform-status{font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:14px;min-height:1.2em;letter-spacing:.02em}.cform-status:empty{margin-top:0}@media (max-width: 820px){.cform{grid-template-columns:1fr}}:root{--scrollhue: 0deg}body[data-textfx=chromatic] :is(.sec-title,.page-hero h1,.detail-title,.post-title,.next-proj .np-name,.contact h2 a){text-shadow:-.7px 0 rgba(255,0,92,.45),.7px 0 rgba(0,226,255,.45)}body[data-textfx=chromatic] :is(.sec-title,.page-hero h1,.detail-title,.post-title,.next-proj .np-name,.contact h2 a):hover{text-shadow:-3px 0 rgba(255,0,92,.85),3px 0 rgba(0,226,255,.85);animation:chromaJitter .32s steps(2,end) infinite}@keyframes chromaJitter{0%,to{text-shadow:-3px 0 rgba(255,0,92,.85),3px 0 rgba(0,226,255,.85)}50%{text-shadow:3px 0 rgba(255,0,92,.85),-3px 0 rgba(0,226,255,.85)}}body[data-textfx=holo] :is(.sec-title,.page-hero h1,.detail-title,.post-title,.next-proj .np-name,.contact h2 a):hover{background:linear-gradient(110deg,var(--accent) 0%,#00e9ff 28%,#ff2bd1 56%,var(--accent) 100%);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:holoShine 1.8s linear infinite}@keyframes holoShine{to{background-position:300% 0}}body[data-textfx=glitch] :is(.sec-title,.page-hero h1,.detail-title,.post-title,.next-proj .np-name,.contact h2 a):hover{animation:glitchTxt .42s steps(2,end) infinite}@keyframes glitchTxt{0%,to{text-shadow:2px 0 #00e9ff,-2px 0 #ff2bd1;transform:translate(0)}33%{text-shadow:-2px 0 #00e9ff,2px 0 #ff2bd1;transform:translate(1px);clip-path:inset(8% 0 62% 0)}66%{text-shadow:2px 0 #ff2bd1,-2px 0 #00e9ff;transform:translate(-1px);clip-path:inset(58% 0 12% 0)}}body[data-textfx=scrollhue] :is(.sec-title,.page-hero h1,.detail-title,.post-title,.next-proj .np-name){color:var(--accent);filter:hue-rotate(var(--scrollhue))}.title-underline{display:block;width:min(440px,62%);height:14px;margin-top:20px;overflow:visible}.title-underline path{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:0;animation:drawUnderline 1.1s var(--ease) .15s both}@keyframes drawUnderline{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}body[data-svgfx=off] .title-underline{display:none}.tweaks-fab{position:fixed;right:18px;bottom:18px;z-index:9400;display:inline-flex;align-items:center;gap:9px;padding:10px 16px 10px 13px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);cursor:pointer;background:color-mix(in oklch,var(--bg) 78%,transparent);-webkit-backdrop-filter:blur(14px) saturate(1.4);backdrop-filter:blur(14px) saturate(1.4);border:1px solid var(--line);border-radius:100px;box-shadow:0 8px 30px #00000059;transition:transform .35s var(--ease),border-color .3s,color .3s,opacity .35s var(--ease)}.tweaks-fab svg{color:var(--accent);flex-shrink:0}.tweaks-fab:hover{transform:translateY(-2px);border-color:var(--accent)}body.tweaks-open .tweaks-fab{opacity:0;pointer-events:none;transform:translateY(14px)}@media (max-width: 820px){.tweaks-fab{right:14px;bottom:14px;padding:12px}.tweaks-fab span{display:none}}.footer-tweaks{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;padding:0;cursor:pointer;font:inherit;color:var(--fg);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent);transition:color .3s}.footer-tweaks:hover{color:var(--accent)}@media (max-width: 1024px) and (min-width: 821px){.detail-meta,.metrics{grid-template-columns:repeat(2,1fr)}}@media (max-width: 820px){.marquee-track{animation-duration:22s}.contrib{display:none}}.twk-panel{position:fixed;right:16px;bottom:16px;z-index:2147483646;width:280px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;background:#faf9f7d1;color:#29261b;-webkit-backdrop-filter:blur(24px) saturate(160%);backdrop-filter:blur(24px) saturate(160%);border:.5px solid rgba(255,255,255,.6);border-radius:14px;box-shadow:0 1px #ffffff80 inset,0 12px 40px #00000047;font:11.5px/1.4 ui-sans-serif,system-ui,-apple-system,sans-serif;overflow:hidden;transform-origin:bottom right;animation:twkIn .22s cubic-bezier(.16,1,.3,1)}@keyframes twkIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.twk-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 8px 10px 14px;-webkit-user-select:none;user-select:none}.twk-hd b{font-size:12px;font-weight:600;letter-spacing:.01em}.twk-x{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:#29261b8c;width:22px;height:22px;border-radius:6px;cursor:pointer;font-size:13px;line-height:1}.twk-x:hover{background:#0000000f;color:#29261b}.twk-body{padding:2px 14px 14px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;overflow-x:hidden;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.twk-body::-webkit-scrollbar{width:8px}.twk-body::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px;border:2px solid transparent;background-clip:content-box}.twk-row{display:flex;flex-direction:column;gap:5px}.twk-row-h{flex-direction:row;align-items:center;justify-content:space-between;gap:10px}.twk-lbl{display:flex;justify-content:space-between;align-items:baseline;color:#29261bb8}.twk-lbl>span:first-child{font-weight:500}.twk-sect{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#29261b73;padding:10px 0 0}.twk-sect:first-child{padding-top:0}.twk-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box;width:100%;min-width:0;height:26px;padding:0 8px;border:.5px solid rgba(0,0,0,.1);border-radius:7px;background:#fff9;color:inherit;font:inherit;outline:none}.twk-field:focus{border-color:#00000040;background:#ffffffd9}select.twk-field{padding-right:22px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='rgba(0,0,0,.5)' d='M0 0h10L5 6z'/></svg>");background-repeat:no-repeat;background-position:right 8px center}.twk-seg{position:relative;display:flex;padding:2px;border-radius:8px;background:#0000000f;-webkit-user-select:none;user-select:none}.twk-seg-thumb{position:absolute;top:2px;bottom:2px;border-radius:6px;background:#ffffffe6;box-shadow:0 1px 2px #0000001f;transition:left .15s cubic-bezier(.3,.7,.4,1),width .15s}.twk-seg button{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;z-index:1;flex:1;border:0;background:transparent;color:inherit;font:inherit;font-weight:500;min-height:22px;border-radius:6px;cursor:pointer;padding:4px 6px;line-height:1.2;text-transform:capitalize}.twk-toggle{position:relative;width:32px;height:18px;border:0;border-radius:999px;background:#00000026;transition:background .15s;cursor:pointer;padding:0;flex-shrink:0}.twk-toggle[data-on="1"]{background:#34c759}.twk-toggle i{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #00000040;transition:transform .15s}.twk-toggle[data-on="1"] i{transform:translate(14px)}
