:root{--bg: #060A12;--bg-surface: #0D1628;--bg-raised: #0F1E35;--accent: #2563EB;--accent-dim: rgba(37, 99, 235, .08);--accent-line: rgba(37, 99, 235, .22);--text: #F8FAFC;--text-2: #94A3B8;--text-3: #4A5E78;--text-4: #253047;--rule: rgba(148, 163, 184, .13);--rule-strong: rgba(148, 163, 184, .22);--font: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", "Fira Mono", monospace;--r: 6px;--r2: 12px;--max-w: 1280px;--pad: clamp(24px, 5vw, 80px);--section: clamp(80px, 10vw, 140px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:1rem;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}img,video,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;background:none;border:none}ul,ol{list-style:none}.wrap{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--pad)}.section{padding-block:var(--section);position:relative}.eyebrow{font-family:var(--mono);font-size:.6875rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:20px}.eyebrow:before{content:"";display:block;width:28px;height:1px;background:var(--accent);flex-shrink:0}.display{font-size:clamp(52px,8.5vw,128px);font-weight:800;line-height:.93;letter-spacing:-.045em;color:var(--text)}.heading{font-size:clamp(36px,4.5vw,64px);font-weight:700;line-height:1.05;letter-spacing:-.035em;color:var(--text)}.subheading{font-size:clamp(20px,2vw,28px);font-weight:500;line-height:1.3;letter-spacing:-.02em;color:var(--text-2)}.body-lg{font-size:clamp(16px,1.2vw,18px);line-height:1.8;color:var(--text-2)}.mono-sm{font-family:var(--mono);font-size:.75rem;letter-spacing:.04em;color:var(--text-3)}.rule{width:100%;height:1px;background:var(--rule)}.tag{display:inline-flex;font-family:var(--mono);font-size:.6875rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-line);padding:4px 10px;border-radius:3px}.stack-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:28px;padding-top:28px;border-top:1px solid var(--rule)}.stack-tag{font-family:var(--mono);font-size:.6875rem;color:var(--text-3);background:#ffffff08;border:1px solid var(--rule);padding:3px 9px;border-radius:3px;letter-spacing:.04em;transition:color .2s,border-color .2s}.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font);font-size:.9375rem;font-weight:500;padding:13px 26px;border-radius:var(--r);letter-spacing:-.01em;transition:background .2s,color .2s,border-color .2s,transform .15s;cursor:pointer}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.btn-fill{background:var(--accent);color:#fff;border:1px solid transparent}.btn-fill:hover{background:#1d51c8;transform:translateY(-1px)}.btn-line{background:transparent;color:var(--text-2);border:1px solid var(--rule-strong)}.btn-line:hover{color:var(--text);border-color:var(--rule-strong);background:#ffffff0a;transform:translateY(-1px)}.btn-arrow{display:inline-block;transition:transform .2s}.btn:hover .btn-arrow{transform:translate(4px)}.nav{position:fixed;top:0;inset-inline:0;z-index:200;transition:background .4s,border-color .4s;border-bottom:1px solid transparent}.nav.is-scrolled{background:#060a12eb;backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border-bottom-color:var(--rule)}.nav-inner{height:64px;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:10px;font-size:.875rem;font-weight:600;color:var(--text);letter-spacing:-.01em;transition:opacity .2s}.nav-logo:hover{opacity:.65}.nav-mark{width:30px;height:30px;border:1px solid var(--rule-strong);border-radius:4px;display:grid;place-items:center;font-family:var(--mono);font-size:.7rem;color:var(--text-2);letter-spacing:0}.nav-links{display:flex;align-items:center;gap:32px}.nav-link{font-size:.8125rem;font-weight:500;color:var(--text-2);transition:color .2s;letter-spacing:.005em}.nav-link:hover{color:var(--text)}.nav-contact{font-size:.8125rem;font-weight:500;color:var(--text);background:#ffffff12;border:1px solid var(--rule-strong);padding:7px 18px;border-radius:var(--r);transition:background .2s,border-color .2s}.nav-contact:hover{background:#ffffff1f}.nav-burger{display:none;flex-direction:column;gap:5px;width:22px}.nav-burger span{display:block;height:1px;background:var(--text-2);transition:all .3s;transform-origin:center}.nav-burger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.nav-mobile{display:none;position:fixed;top:64px;right:0;bottom:0;left:0;background:#060a12fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:32px var(--pad);gap:2px;z-index:199;border-top:1px solid var(--rule)}.nav-mobile.is-open{display:flex}.nav-mobile-link{font-size:1.375rem;font-weight:600;letter-spacing:-.025em;color:var(--text-2);padding:14px 0;border-bottom:1px solid var(--rule);transition:color .2s}.nav-mobile-link:hover{color:var(--text)}.nav-mobile-link:last-child{border-bottom:none}.hero{height:100svh;min-height:600px;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.hero-grid{position:absolute;top:-20%;right:0;bottom:-20%;left:0;background-image:linear-gradient(to right,rgba(148,163,184,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(148,163,184,.04) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}.hero-corner{position:absolute;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-4);line-height:1.5}.hero-corner-tl{top:80px;left:var(--pad)}.hero-corner-tr{top:80px;right:var(--pad);text-align:right}.hero-corner-br{bottom:48px;right:var(--pad);text-align:right}.hero-body{padding-inline:var(--pad)}.hero-title{font-size:clamp(72px,13vw,190px);font-weight:900;line-height:.87;letter-spacing:-.055em;color:var(--text);display:block}.hero-rule{height:1px;background:var(--rule);margin-block:clamp(24px,3vw,40px);width:100%}.hero-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}.hero-roles{display:flex;flex-direction:column;gap:4px}.hero-role{font-size:clamp(15px,1.4vw,19px);font-weight:400;color:var(--text-2);letter-spacing:-.01em}.hero-ctas{display:flex;align-items:center;gap:12px}.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-4)}.hero-scroll-line{width:1px;height:40px;background:var(--rule);position:relative;overflow:hidden}.hero-scroll-line:after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent,var(--accent));animation:scroll-drip 2.2s ease-in-out infinite}@keyframes scroll-drip{0%{top:-100%}to{top:100%}}.profile{padding-block:var(--section);border-top:1px solid var(--rule)}.profile-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start}.profile-left{position:sticky;top:100px}.profile-bio{font-size:clamp(16px,1.2vw,18px);line-height:1.85;color:var(--text-2);margin-top:28px}.profile-bio strong{color:var(--text);font-weight:500}.profile-svg-container{margin-top:48px;opacity:.4}.profile-right{padding-top:clamp(40px,5vw,80px)}.profile-keywords-label{font-family:var(--mono);font-size:.6875rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-4);margin-bottom:28px}.profile-keyword{font-size:clamp(22px,3vw,40px);font-weight:600;letter-spacing:-.025em;color:var(--text);padding-block:12px;border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;opacity:0;transform:translateY(16px)}.profile-keyword:first-of-type{border-top:1px solid var(--rule)}.profile-keyword-num{font-family:var(--mono);font-size:.65rem;color:var(--text-4);letter-spacing:.08em}.expertise{padding-block:var(--section);border-top:1px solid var(--rule)}.expertise-layout{display:grid;grid-template-columns:1fr 2fr;gap:clamp(40px,5vw,80px);align-items:start}.expertise-left{position:sticky;top:100px}.expertise-progress-track{margin-top:40px;width:1px;height:200px;background:var(--rule);position:relative}.expertise-progress-fill{position:absolute;top:0;left:0;width:100%;background:var(--accent);height:0%;transition:height .1s}.expertise-list{display:flex;flex-direction:column}.expertise-item{display:grid;grid-template-columns:3ch 1fr 2fr;gap:24px;align-items:start;padding-block:28px;border-top:1px solid var(--rule);opacity:0;transform:translateY(20px)}.expertise-item:last-child{border-bottom:1px solid var(--rule)}.expertise-num{font-family:var(--mono);font-size:.65rem;color:var(--text-4);letter-spacing:.08em;padding-top:4px}.expertise-name{font-size:.9375rem;font-weight:600;color:var(--text);letter-spacing:-.01em;line-height:1.35}.expertise-desc{font-size:.875rem;color:var(--text-2);line-height:1.7}.projects-section{border-top:1px solid var(--rule)}.projects-header{padding-top:var(--section);padding-inline:var(--pad);padding-bottom:0;max-width:var(--max-w);margin-inline:auto}.projects-viewport{position:relative;overflow:hidden}.projects-track{display:flex;will-change:transform}.project-panel{width:100vw;min-height:100vh;flex-shrink:0;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0;padding:120px var(--pad) 80px;position:relative;opacity:.45;transition:opacity .5s ease}.project-panel.is-active{opacity:1}.project-panel-left{padding-right:clamp(24px,4vw,64px)}.project-panel-right{display:flex;align-items:center;justify-content:center;height:100%;position:relative;border-left:1px solid var(--rule);padding-left:clamp(24px,4vw,64px)}.project-category-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}.project-panel-num{font-family:var(--mono);font-size:.65rem;color:var(--text-4);letter-spacing:.1em}.project-panel-name{font-size:clamp(30px,4vw,54px);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text);margin-bottom:8px}.project-panel-role{font-family:var(--mono);font-size:.75rem;color:var(--accent);letter-spacing:.06em;margin-bottom:24px;text-transform:uppercase}.project-panel-desc{font-size:.9375rem;line-height:1.8;color:var(--text-2);margin-bottom:28px}.project-highlights{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.project-highlight{display:flex;align-items:flex-start;gap:12px;font-size:.875rem;line-height:1.6;color:var(--text-2)}.project-highlight:before{content:"";display:block;width:4px;height:4px;min-width:4px;background:var(--accent);border-radius:50%;margin-top:7px}.projects-mobile{display:none;flex-direction:column;gap:2px;padding-inline:var(--pad);padding-bottom:var(--section)}.project-card-mobile{background:var(--bg-surface);border:1px solid var(--rule);border-radius:var(--r2);padding:36px 32px}.project-card-mobile-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.project-card-mobile-num{font-family:var(--mono);font-size:.6rem;color:var(--text-4);letter-spacing:.1em;padding-top:3px}.project-card-mobile-name{font-size:clamp(22px,3vw,32px);font-weight:700;letter-spacing:-.03em;color:var(--text);margin-bottom:6px;line-height:1.1}.project-card-mobile-role{font-family:var(--mono);font-size:.7rem;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px}.project-card-mobile-desc{font-size:.9rem;line-height:1.75;color:var(--text-2);margin-bottom:20px}.arch-diagram{width:100%;max-width:480px;height:auto;opacity:.09}.experience{padding-block:var(--section);border-top:1px solid var(--rule)}.experience-inner{display:grid;grid-template-columns:260px 1fr;gap:clamp(40px,5vw,80px);align-items:start}.experience-left{position:sticky;top:100px}.experience-progress{margin-top:40px;width:1px;height:160px;background:var(--rule);position:relative;overflow:hidden}.experience-progress-fill{position:absolute;top:0;left:0;width:100%;background:var(--accent);height:0%}.experience-timeline{position:relative;padding-left:28px}.experience-timeline:before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:1px;background:var(--rule)}.exp-entry{position:relative;padding-bottom:56px;opacity:0;transform:translate(24px)}.exp-entry:last-child{padding-bottom:0}.exp-dot{position:absolute;left:-34px;top:18px;width:9px;height:9px;border:1.5px solid var(--accent);background:var(--bg);border-radius:50%;box-shadow:0 0 10px #2563eb59}.exp-company{font-size:1.25rem;font-weight:700;letter-spacing:-.025em;color:var(--text);margin-bottom:4px}.exp-meta{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.exp-role{font-size:.875rem;font-weight:500;color:var(--accent)}.exp-sep{color:var(--text-4);font-size:.75rem}.exp-period{font-family:var(--mono);font-size:.75rem;color:var(--text-3);letter-spacing:.04em}.exp-resp-list{display:flex;flex-direction:column;gap:7px}.exp-resp{font-size:.875rem;line-height:1.65;color:var(--text-2);padding-left:18px;position:relative}.exp-resp:before{content:"—";position:absolute;left:0;color:var(--text-4);font-size:.75rem;line-height:1.9}.process-outer{position:relative;border-top:1px solid var(--rule)}.process-sticky{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden}.process-steps-container{width:100%;padding-inline:var(--pad);max-width:var(--max-w);margin-inline:auto;position:relative}.process-step{position:absolute;top:50%;left:var(--pad);right:var(--pad);transform:translateY(-50%);opacity:0;pointer-events:none;will-change:opacity,transform;max-width:860px}.process-step.first-step{opacity:1;pointer-events:auto}.process-step-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-4);margin-bottom:16px;display:flex;align-items:center;gap:12px}.process-step-num{font-size:clamp(100px,16vw,180px);font-weight:900;letter-spacing:-.07em;line-height:.85;color:#f8fafc08;position:absolute;right:0;top:-20px;pointer-events:none;-webkit-user-select:none;user-select:none}.process-step-title{font-size:clamp(28px,4vw,52px);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:var(--text);margin-bottom:20px}.process-step-desc{font-size:clamp(16px,1.3vw,19px);line-height:1.8;color:var(--text-2);max-width:580px}.process-progress{position:absolute;bottom:40px;left:var(--pad);display:flex;align-items:center;gap:8px}.process-pip{width:24px;height:2px;background:var(--rule);border-radius:2px;transition:background .3s,width .3s}.process-pip.active{background:var(--accent);width:40px}.contact{padding-block:var(--section);border-top:1px solid var(--rule)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,100px);align-items:start}.contact-heading{font-size:clamp(32px,4.5vw,58px);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:var(--text);margin-top:20px;margin-bottom:20px}.contact-copy{font-size:clamp(15px,1.1vw,17px);line-height:1.85;color:var(--text-2);margin-bottom:36px}.contact-avail{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.75rem;color:var(--text-3);letter-spacing:.05em}.contact-avail-dot{width:6px;height:6px;background:#22c55e;border-radius:50%;box-shadow:0 0 8px #22c55e80}.contact-links{display:flex;flex-direction:column;gap:2px;padding-top:clamp(40px,4vw,68px)}.contact-link{display:flex;align-items:center;gap:20px;padding:22px 0;border-bottom:1px solid var(--rule);transition:background .2s;text-decoration:none;position:relative}.contact-link:first-child{border-top:1px solid var(--rule)}.contact-link:hover .contact-link-label{color:var(--text)}.contact-link-icon{width:36px;height:36px;border:1px solid var(--rule-strong);border-radius:var(--r);display:grid;place-items:center;flex-shrink:0;color:var(--text-3);transition:border-color .2s,color .2s}.contact-link:hover .contact-link-icon{border-color:var(--accent-line);color:var(--accent)}.contact-link-type{font-family:var(--mono);font-size:.6875rem;color:var(--text-4);letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}.contact-link-label{font-size:1rem;font-weight:500;color:var(--text-2);letter-spacing:-.01em;transition:color .2s}.contact-link-arrow{margin-left:auto;color:var(--text-4);font-size:1.1rem;transition:transform .2s,color .2s}.contact-link:hover .contact-link-arrow{transform:translate(3px,-3px);color:var(--text-2)}.footer{border-top:1px solid var(--rule);padding-block:28px}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-name{font-size:.875rem;font-weight:500;color:var(--text-3);letter-spacing:-.01em}.footer-stack{font-family:var(--mono);font-size:.6875rem;color:var(--text-4);letter-spacing:.04em}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}.profile-keyword,.expertise-item,.exp-entry{opacity:1!important;transform:none!important}.process-step{position:static!important;transform:none!important;opacity:1!important;pointer-events:auto!important}.hero-scroll-line:after{display:none}}@media(max-width:1024px){.expertise-layout{grid-template-columns:1fr;gap:48px}.expertise-left{position:static}.expertise-item{grid-template-columns:3ch 1fr}.expertise-desc{display:none}.experience-inner{grid-template-columns:1fr;gap:48px}.experience-left{position:static}.contact-inner,.profile-inner{grid-template-columns:1fr;gap:48px}.profile-left{position:static}}@media(max-width:768px){.nav-links,.nav-contact{display:none}.nav-burger{display:flex}.projects-viewport{display:none!important}.projects-mobile{display:flex!important}.project-panel{grid-template-columns:1fr}.project-panel-right,.hero-corner-tr,.hero-corner-br{display:none}.hero-ctas{flex-direction:column;align-items:flex-start}.footer-inner{flex-direction:column;text-align:center}}@media(max-width:480px){.hero-title{font-size:clamp(60px,20vw,100px)}.expertise-item{grid-template-columns:1fr;gap:6px}.expertise-num{display:none}}
