*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #08090d;--bg-deep: #050609;--surface: rgba(255, 255, 255, .04);--surface-2: rgba(255, 255, 255, .07);--surface-solid: #0f1117;--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--text: #eceef3;--text-strong: #ffffff;--muted: #969daa;--accent: #7c5cff;--accent-2: #22d3ee;--accent-grad: linear-gradient(120deg, #8b5cff 0%, #22d3ee 100%);--glow: rgba(124, 92, 255, .35);--shadow: 0 24px 60px -20px rgba(0, 0, 0, .7);--shadow-lift: 0 34px 80px -24px rgba(0, 0, 0, .85);--radius: 20px;--radius-sm: 14px;--maxw: 1120px;--ease: cubic-bezier(.22, 1, .36, 1);color-scheme:dark}html.light{--bg: #f5f6f9;--bg-deep: #eceef4;--surface: rgba(12, 16, 28, .035);--surface-2: rgba(12, 16, 28, .06);--surface-solid: #ffffff;--border: rgba(12, 16, 28, .1);--border-strong: rgba(12, 16, 28, .18);--text: #161922;--text-strong: #05070c;--muted: #5b6373;--glow: rgba(124, 92, 255, .22);--shadow: 0 24px 60px -28px rgba(20, 24, 40, .4);--shadow-lift: 0 34px 80px -28px rgba(20, 24, 40, .5);color-scheme:light}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-deep);color:var(--text);line-height:1.55;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;user-select:none;transition:background-color .5s var(--ease),color .5s var(--ease)}h1,h2,h3,h4{font-family:Space Grotesk,Inter,sans-serif;font-weight:600;letter-spacing:-.02em;line-height:1.05;color:var(--text-strong)}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}.icon{width:1em;height:1em;display:inline-block;vertical-align:middle}::selection{background:var(--accent);color:#fff}#bg-canvas{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;display:block;touch-action:none}.bg-overlay{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(90% 60% at 78% 8%,transparent 0%,transparent 38%,var(--bg-deep) 100%),radial-gradient(120% 90% at 50% 120%,color-mix(in srgb,var(--accent) 16%,transparent) 0%,transparent 55%);transition:background .5s var(--ease)}.bg-grain{position:fixed;inset:0;z-index:2;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")}.loader{position:fixed;inset:0;z-index:300;display:grid;place-content:center;gap:1.2rem;background:var(--bg-deep);transition:opacity .7s var(--ease),visibility .7s var(--ease)}.loader.is-done{opacity:0;visibility:hidden}.loader-mark{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:clamp(1.4rem,4vw,2rem);letter-spacing:-.03em;color:var(--text-strong)}.loader-mark span{color:var(--accent)}.loader-bar{width:min(240px,60vw);height:3px;border-radius:99px;background:var(--surface-2);overflow:hidden;justify-self:center}.loader-bar span{display:block;height:100%;width:40%;border-radius:99px;background:var(--accent-grad);transform:translate(-100%);animation:loaderSlide 1.1s var(--ease) infinite}@keyframes loaderSlide{0%{transform:translate(-110%)}to{transform:translate(360%)}}.nav{position:fixed;top:1.1rem;left:50%;transform:translate(-50%);z-index:50;width:calc(100% - 2rem);max-width:640px}.nav-inner{position:relative;display:flex;align-items:center;gap:.6rem;padding:.45rem .55rem;border-radius:999px;background:color-mix(in srgb,var(--surface-solid) 70%,transparent);border:1px solid var(--border);box-shadow:var(--shadow);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%)}.nav-inner:before{content:"";position:absolute;inset:-1px;border-radius:999px;padding:1px;background:linear-gradient(120deg,transparent,var(--glow),transparent);background-size:220% 100%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:navGlow 5s linear infinite;pointer-events:none}@keyframes navGlow{0%{background-position:0% 50%}to{background-position:220% 50%}}.brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0;padding-left:.25rem}.brand-img{width:2.1rem;height:2.1rem;border-radius:999px;object-fit:cover;border:1px solid var(--border-strong);background:var(--surface-2);flex-shrink:0}.brand-text{font-family:Space Grotesk,sans-serif;font-weight:600;font-size:.92rem;letter-spacing:-.02em}.brand-text .dim{color:var(--muted)}.tabs{position:relative;flex:1;display:flex;gap:.1rem;padding:.2rem;border-radius:999px;background:var(--surface)}.tab-indicator{position:absolute;top:.2rem;left:0;height:calc(100% - .4rem);width:0;border-radius:999px;background:#fff;box-shadow:0 6px 18px -8px #0000008c;transition:transform .45s var(--ease),width .45s var(--ease);z-index:0}html.light .tab-indicator{box-shadow:0 2px 10px -2px #14182847;border:1px solid rgba(20,24,40,.08)}.tab{position:relative;z-index:1;flex:1;padding:.4rem .3rem;font-size:.74rem;font-weight:500;color:var(--muted);border-radius:999px;white-space:nowrap;transition:color .3s var(--ease)}.tab:hover{color:var(--text)}.tab.is-active{color:#0b0d12;font-weight:600}.theme-toggle{flex-shrink:0;width:2.1rem;height:2.1rem;border-radius:999px;display:grid;place-content:center;color:var(--text);font-size:1rem;transition:background .3s var(--ease),transform .3s var(--ease)}.theme-toggle:hover{background:var(--surface-2);transform:rotate(15deg)}.theme-toggle .moon,html.light .theme-toggle .sun{display:none}html.light .theme-toggle .moon{display:inline-block}main{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:9rem 1.5rem 4rem}.panel{display:none}.panel.is-active{display:block}.block{margin-top:clamp(4rem,9vw,7rem)}.block-head{margin-bottom:2rem}.section-title{font-size:clamp(1.6rem,4vw,2.3rem)}.section-sub{color:var(--muted);margin-top:.4rem;font-size:1rem}.hero{position:relative;min-height:min(82vh,720px);display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.85fr);align-items:center;gap:2rem}.hero-copy{max-width:40rem}.eyebrow{font-size:1rem;color:var(--muted);margin-bottom:1.4rem;max-width:34rem}.eyebrow strong{color:var(--text-strong);font-weight:600}.wave{display:inline-block;animation:wave 2.4s ease-in-out infinite;transform-origin:70% 70%}@keyframes wave{0%,60%,to{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}}.hero-title{font-size:clamp(2.6rem,8vw,5rem);font-weight:700;margin-bottom:1.4rem}.hero-title .line{display:block;overflow:hidden}.grad{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-points{list-style:none;color:var(--muted);font-size:clamp(1rem,2.5vw,1.2rem);margin-bottom:1.4rem;display:grid;gap:.3rem}.hero-points .spark{color:var(--text-strong);margin-right:.4rem}.hero-desc{font-size:1.1rem;color:var(--text);max-width:34rem;margin-bottom:2rem}.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2.4rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;border-radius:999px;font-weight:500;font-size:.95rem;border:1px solid transparent;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease)}.btn .icon{font-size:1.05rem}.btn-primary{background:#fff;color:#0b0d12;box-shadow:0 10px 28px -14px #00000073}.btn-primary:hover{background:#fff;color:#0b0d12;transform:translateY(-2px);box-shadow:0 16px 36px -14px #00000080}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text);backdrop-filter:blur(8px)}.btn-ghost:hover{transform:translateY(-3px);border-color:var(--border-strong);background:var(--surface-2)}.btn-ghost .icon{transition:transform .3s var(--ease)}.btn-ghost:hover .icon{transform:translate(3px)}.hero-stack{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .8rem .35rem .6rem;border-radius:999px;font-size:.78rem;font-weight:500;color:var(--text);background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(8px);transition:transform .25s var(--ease),border-color .25s var(--ease)}.chip:hover{transform:translateY(-2px);border-color:var(--border-strong)}.chip .dot{width:.55rem;height:.55rem;border-radius:999px;box-shadow:0 0 10px currentColor}.grid{display:grid;gap:1.2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.card{position:relative;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);overflow:hidden;transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);will-change:transform}.card:after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--card-accent, var(--accent)),transparent 45%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s var(--ease);pointer-events:none}.card:hover{transform:translateY(-6px);border-color:var(--border-strong);box-shadow:var(--shadow-lift)}.card:hover:after{opacity:1}.project{display:flex;flex-direction:column}.project-media{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:linear-gradient(135deg,color-mix(in srgb,var(--card-accent, var(--accent)) 40%,transparent),transparent 70%)}.project-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}.card:hover .project-media img{transform:scale(1.06)}.project-body{padding:1.25rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.55rem;flex:1}.project-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.views{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0}.views svg{width:.95rem;height:.95rem}.project-title{font-size:1.25rem;display:flex;align-items:center;gap:.45rem}.project-title .ext{opacity:0;transform:translate(-4px,4px);color:var(--muted);transition:all .3s var(--ease)}.card:hover .project-title .ext{opacity:1;transform:translate(0)}.ext svg{width:1.05rem;height:1.05rem}.project-desc{color:var(--muted);font-size:.92rem;margin-top:auto}.soon-pill{align-self:flex-start;font-size:.68rem;color:var(--muted);border:1px dashed var(--border-strong);padding:.15rem .55rem;border-radius:999px}.timeline{position:relative;display:grid;gap:1rem;padding-left:1.6rem}.timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--text-strong),transparent);opacity:.5}.work{position:relative;padding:1.3rem 1.5rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(12px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;transition:border-color .3s var(--ease),transform .3s var(--ease)}.work:hover{border-color:var(--border-strong);transform:translate(4px)}.work:before{content:"";position:absolute;left:-1.6rem;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:999px;background:var(--bg-deep);border:2px solid var(--text-strong)}.work.is-current:before{background:var(--text-strong);box-shadow:0 0 0 4px color-mix(in srgb,var(--text-strong) 16%,transparent)}.work-title{font-size:1.1rem;font-weight:600;font-family:Space Grotesk,sans-serif;color:var(--text-strong)}.work-company{color:var(--muted);font-size:.92rem;margin-top:.15rem}.work-period{font-size:.85rem;color:var(--text-strong);white-space:nowrap}.work.is-current .work-period{color:var(--text-strong)}.connect-text{color:var(--muted);font-size:1.1rem;max-width:40rem;margin-bottom:2rem}.connect-text a{color:var(--text-strong);border-bottom:2px solid var(--accent);transition:color .3s var(--ease)}.connect-text a:hover{color:var(--accent)}.social{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem}.social-icon{width:3rem;height:3rem;border-radius:14px;display:grid;place-content:center;background:var(--surface-2);color:#fff;flex-shrink:0}.social-icon svg{width:1.5rem;height:1.5rem;display:block}a.social.card:hover,a.social.card:focus-visible{transform:none;border-color:var(--border);box-shadow:none}a.social.card:hover:after,a.social.card:focus-visible:after{opacity:0}a.social.card:hover .social-icon,a.social.card:focus-visible .social-icon{transform:none;background:var(--surface-2);color:#fff}a.social.card:hover .ext,a.social.card:focus-visible .ext{opacity:0;transform:translate(-4px,4px)}.social-meta{flex:1;min-width:0}.social-name{font-size:1.05rem;font-weight:600;font-family:Space Grotesk,sans-serif;color:var(--text-strong)}.social-handle{color:var(--muted);font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.social .ext{color:var(--muted);opacity:0;transform:translate(-4px,4px);transition:all .3s var(--ease)}.card:hover .social .ext{opacity:1;transform:translate(0)}.dev-state{min-height:58vh;display:grid;place-content:center;text-align:center;gap:1rem}.dev-badge{justify-self:center;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);padding:.35rem .9rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.dev-title{font-size:clamp(2.4rem,8vw,4.5rem);color:var(--text-strong)}.dev-sub{color:var(--muted)}.footer{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:2.5rem 1.5rem 3rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:var(--muted);font-size:.85rem;border-top:1px solid var(--border)}.footer-dim{opacity:.7}.reveal{opacity:0;transform:translateY(28px);filter:blur(8px)}.anim-fallback .reveal{opacity:1;transform:none;filter:none}@media(max-width:900px){.hero{grid-template-columns:1fr;min-height:auto;padding-top:1rem}main{padding-top:8rem}#bg-canvas{opacity:.4}.hero-title{text-shadow:0 2px 24px var(--bg-deep)}}@media(max-width:620px){.brand-text{display:none}.nav-inner{gap:.4rem}.tab{font-size:.68rem;padding:.4rem .2rem}.work{flex-direction:column;align-items:flex-start}.footer{flex-direction:column}}@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none;filter:none}}
