@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,800&family=Inter:wght@400;500&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg: #0a0a0a;--bg-raise: #100f0e;--fg: #f2f0ea;--muted: #8a8780;--muted-dim: #5c5a54;--hair: rgba(242, 240, 234, .13);--hair-strong: rgba(242, 240, 234, .3);--invert-fg: #0a0a0a;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--gut: clamp(20px, 5vw, 72px);--sp-sec: clamp(96px, 13vw, 200px);--radius: 0px;--topbar-h: 66px;--ease: cubic-bezier(.16, .84, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::selection{background:var(--fg);color:var(--invert-fg)}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none;opacity:.05;mix-blend-mode:soft-light;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.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.preloader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--bg);display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .65s ease}.preloader.is-leaving{opacity:0}.preloader .preloader-logo{height:160px;color:var(--fg)}.draw-loop{animation:afFade 2.4s ease infinite}.draw-loop path{fill:none;stroke-dasharray:1;stroke-dashoffset:1;animation-duration:2.4s;animation-iteration-count:infinite;animation-timing-function:cubic-bezier(.7,0,.2,1)}.draw-loop path:nth-child(1){animation-name:afD1}.draw-loop path:nth-child(2){animation-name:afD2}.draw-loop path:nth-child(3){animation-name:afD3}.draw-loop path:nth-child(4){animation-name:afD4}@keyframes afD1{0%{stroke-dashoffset:1}4%{stroke-dashoffset:1}19%{stroke-dashoffset:0}to{stroke-dashoffset:0}}@keyframes afD2{0%{stroke-dashoffset:1}17%{stroke-dashoffset:1}32%{stroke-dashoffset:0}to{stroke-dashoffset:0}}@keyframes afD3{0%{stroke-dashoffset:1}30%{stroke-dashoffset:1}45%{stroke-dashoffset:0}to{stroke-dashoffset:0}}@keyframes afD4{0%{stroke-dashoffset:1}43%{stroke-dashoffset:1}58%{stroke-dashoffset:0}to{stroke-dashoffset:0}}@keyframes afFade{0%{opacity:0}4%{opacity:1}78%{opacity:1}90%{opacity:0}to{opacity:0}}.draw-once path{fill:none}.draw-once.go path{stroke-dasharray:1;stroke-dashoffset:1;animation:afDraw .7s cubic-bezier(.7,0,.2,1) forwards}.draw-once.go path:nth-child(2){animation-delay:.12s}.draw-once.go path:nth-child(3){animation-delay:.24s}.draw-once.go path:nth-child(4){animation-delay:.36s}@keyframes afDraw{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}.slash-label{font-family:var(--font-mono);font-size:12px;letter-spacing:.02em;color:var(--muted);text-transform:none}.logo{width:auto;height:26px;color:var(--fg);display:block}.reveal-text .rt-line{display:block;overflow:hidden;padding-bottom:.04em}.reveal-text .rt-inner{display:block}.btn{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:13px;letter-spacing:.04em;padding:15px 22px;border:1px solid var(--fg);background:var(--fg);color:var(--invert-fg);transition:background .4s var(--ease),color .4s var(--ease)}.btn svg{width:16px;height:16px;transition:transform .4s var(--ease)}.btn:hover{background:transparent;color:var(--fg)}.btn:hover svg{transform:translate(4px,-4px)}.btn.ghost{background:transparent;color:var(--fg)}.btn.ghost:hover{background:var(--fg);color:var(--invert-fg)}.sec-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:18px 30px;padding-bottom:30px;border-bottom:1px solid var(--hair);margin-bottom:clamp(40px,6vw,84px)}.sec-head .kicker{grid-column:1;font-size:12px}.sec-title{grid-column:1;font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5.5vw,4.6rem);line-height:.95;letter-spacing:-.025em;text-transform:uppercase}.sec-index{grid-column:2;grid-row:1 / span 2;font-family:var(--font-mono);font-size:12px;color:var(--muted-dim);align-self:start}.img-placeholder{position:relative;width:100%;height:100%;background:var(--bg-raise);border:1px dashed var(--hair-strong);display:flex;align-items:center;justify-content:center;overflow:hidden}.img-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(-45deg,transparent 0,transparent 13px,var(--hair) 13px,var(--hair) 14px);opacity:.5}.img-placeholder .ph-note{position:relative;z-index:1;max-width:78%;text-align:center;font-family:var(--font-mono);font-size:12px;line-height:1.6;color:var(--muted);letter-spacing:.01em}.media-img{width:100%;height:100%;object-fit:cover}.topbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--gut);border-bottom:1px solid transparent;background:color-mix(in srgb,var(--bg) 72%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:border-color .4s ease,background .4s ease}.topbar.scrolled{border-bottom-color:var(--hair)}.topbar-brand{display:flex;align-items:center;gap:14px}.topbar-brand .logo{height:34px}.topbar-brand .wordmark{font-family:var(--font-display);font-weight:800;font-size:17px;letter-spacing:-.01em}.topbar-brand .year{font-family:var(--font-mono);font-size:11px;color:var(--muted-dim);align-self:flex-start;margin-top:1px}.topbar-nav{display:flex;gap:26px}.topbar-nav a{font-family:var(--font-mono);font-size:13px;color:var(--muted);position:relative;transition:color .3s ease}.topbar-nav a:after{content:"";position:absolute;left:0;bottom:-4px;height:1px;width:0;background:var(--fg);transition:width .35s var(--ease)}.topbar-nav a:hover{color:var(--fg)}.topbar-nav a:hover:after{width:100%}.hero{position:relative;min-height:100vh;min-height:100dvh;padding:calc(var(--topbar-h) + clamp(30px,6vw,70px)) var(--gut) 0;display:flex;flex-direction:column}.hero-grid{flex:1;display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.95fr);gap:clamp(28px,5vw,72px);align-items:stretch;padding-bottom:34px}.hero-main{display:flex;flex-direction:column;justify-content:center}.hero-eyebrow{display:flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:clamp(18px,2.6vw,30px)}.hero-eyebrow:before{content:"";width:30px;height:1px;background:var(--muted-dim)}.hero-title{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,8.5vw,8.5rem);line-height:.98;letter-spacing:.005em;text-transform:uppercase}.hero-tagline{margin-top:clamp(24px,3vw,40px);max-width:42ch;font-size:clamp(15px,1.4vw,19px);color:var(--muted);line-height:1.55}.hero-actions{margin-top:clamp(28px,3.5vw,46px);display:flex;gap:16px;align-items:center;flex-wrap:wrap}.hero-portrait{position:relative;display:flex;flex-direction:column;min-height:60vh}.portrait-panel{flex:1;overflow:hidden;background:var(--bg-raise);border:1px solid var(--hair)}.portrait-panel .ph-note{font-size:12.5px}.portrait-img{filter:grayscale(1) contrast(1.03);object-position:top center}.portrait-foot{display:flex;justify-content:space-between;align-items:baseline;padding-top:12px}.hero-meta{display:flex;gap:30px;flex-wrap:wrap;padding:18px 0;border-top:1px solid var(--hair)}.marquee{overflow:hidden;white-space:nowrap;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:0}.marquee-track{display:inline-flex;align-items:center;padding:16px 0;animation:marquee 30s linear infinite}.marquee-item{font-family:var(--font-display);font-weight:800;font-size:clamp(15px,1.7vw,22px);text-transform:uppercase;letter-spacing:.01em;padding:0 26px;display:inline-flex;align-items:center;gap:26px}.marquee-item:after{content:"/";color:var(--muted-dim);font-family:var(--font-mono);font-weight:400}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.section{padding:var(--sp-sec) var(--gut)}.section.hairtop{border-top:1px solid var(--hair)}.about-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.85fr);gap:clamp(36px,6vw,90px);align-items:start}.about-lead{font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,3.4vw,3rem);line-height:1.06;letter-spacing:-.02em}.about-body{margin-top:30px;max-width:56ch}.about-body p{color:var(--muted);font-size:clamp(15px,1.2vw,17px)}.about-body p+p{margin-top:18px}.about-meta{display:flex;flex-direction:column}.about-meta .row{display:flex;flex-direction:column;gap:5px;padding:18px 0;border-top:1px solid var(--hair)}.about-meta .row:last-child{border-bottom:1px solid var(--hair)}.about-meta .k{font-family:var(--font-mono);font-size:11px;color:var(--muted-dim);letter-spacing:.04em}.about-meta .v{font-size:15px}.projects-list{display:flex;flex-direction:column}.project{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(24px,4vw,56px);align-items:center;padding:clamp(36px,5vw,64px) 0;border-top:1px solid var(--hair)}.projects-list .project:last-child{border-bottom:1px solid var(--hair)}.project.featured{grid-template-columns:minmax(0,1.25fr) minmax(0,1fr)}.project-media{aspect-ratio:16 / 10;order:2}.project.featured .project-media{aspect-ratio:16 / 9.5}.project-media .img-placeholder,.project-media .media-img{filter:grayscale(1);transition:filter .6s var(--ease)}.project:hover .project-media .img-placeholder,.project:hover .project-media .media-img{filter:grayscale(0)}.project-body{order:1;display:flex;flex-direction:column;align-items:flex-start}.project-top{display:flex;gap:16px;align-items:center;font-family:var(--font-mono);font-size:12px;color:var(--muted-dim);margin-bottom:16px}.project-title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4.4vw,3.8rem);line-height:.96;letter-spacing:-.025em;text-transform:uppercase}.project-client{font-family:var(--font-mono);font-size:13px;color:var(--muted);margin-top:8px}.project-desc{margin-top:18px;color:var(--muted);max-width:46ch;font-size:15px}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}.project-tags span{font-family:var(--font-mono);font-size:11px;color:var(--muted);padding:6px 11px;border:1px solid var(--hair)}.project-cta{display:inline-flex;align-items:center;gap:9px;margin-top:26px;font-family:var(--font-mono);font-size:13px;color:var(--fg);border-bottom:1px solid var(--hair-strong);padding-bottom:3px;transition:gap .35s var(--ease),border-color .35s ease}.project-cta svg{width:14px;height:14px;transition:transform .35s var(--ease)}.project:hover .project-cta{gap:14px;border-color:var(--fg)}.project:hover .project-cta svg{transform:translate(3px,-3px)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));border-left:1px solid var(--hair);border-top:1px solid var(--hair)}.skill{display:flex;align-items:baseline;gap:12px;padding:22px 24px;border-right:1px solid var(--hair);border-bottom:1px solid var(--hair);transition:background .35s ease,color .35s ease}.skill .n{font-family:var(--font-mono);font-size:11px;color:var(--muted-dim)}.skill .name{font-family:var(--font-display);font-weight:800;font-size:clamp(1.1rem,1.8vw,1.6rem);letter-spacing:-.01em}.skill:hover{background:var(--fg);color:var(--invert-fg)}.skill:hover .n{color:var(--invert-fg)}.exp-list{display:flex;flex-direction:column}.exp-row{display:grid;grid-template-columns:minmax(180px,.5fr) minmax(0,1.5fr);gap:clamp(20px,4vw,56px);align-items:start;padding:clamp(30px,4vw,52px) 0;border-top:1px solid var(--hair)}.exp-list .exp-row:last-child{border-bottom:1px solid var(--hair)}.exp-when{font-family:var(--font-mono);font-size:13px;color:var(--muted);letter-spacing:.02em}.exp-company{display:block;margin-top:10px;font-family:var(--font-mono);font-size:12px;color:var(--muted-dim)}.exp-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1;letter-spacing:-.02em;text-transform:uppercase}.exp-desc{margin-top:16px;color:var(--muted);max-width:60ch;font-size:15px}.exp-points{margin-top:18px;display:flex;flex-direction:column;gap:9px}.exp-points li{list-style:none;position:relative;padding-left:22px;font-family:var(--font-mono);font-size:12.5px;color:var(--muted);line-height:1.5}.exp-points li:before{content:"/";position:absolute;left:0;color:var(--muted-dim)}.edu-row{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:20px 30px;padding:clamp(28px,4vw,44px) 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}.edu-list .edu-row{border-bottom:none}.edu-list .edu-row:last-child{border-bottom:1px solid var(--hair)}.edu-row .e-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.6rem,3.2vw,2.6rem);letter-spacing:-.02em;text-transform:uppercase}.edu-row .e-sub{color:var(--muted);font-size:15px}.edu-row .e-date{font-family:var(--font-mono);font-size:13px;color:var(--muted)}.quotes-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-top:1px solid var(--hair);border-left:1px solid var(--hair)}.quote{display:flex;flex-direction:column;justify-content:space-between;gap:clamp(28px,4vw,48px);padding:clamp(28px,4vw,50px);border-right:1px solid var(--hair);border-bottom:1px solid var(--hair)}.quote-body{font-family:var(--font-display);font-weight:400;font-size:clamp(1.15rem,1.9vw,1.6rem);line-height:1.32;letter-spacing:-.01em}.quote-foot{display:flex;flex-direction:column;gap:4px}.quote-name{font-size:15px;color:var(--fg)}.quote-role{font-family:var(--font-mono);font-size:11.5px;color:var(--muted-dim);letter-spacing:.02em}.quote-foot a:hover .quote-name{color:var(--muted)}.contact{text-align:left}.contact-big{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,9vw,8.5rem);line-height:.98;letter-spacing:.005em;text-transform:uppercase}.contact-sub{margin-top:24px;color:var(--muted);max-width:44ch}.contact-actions{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap}.footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:34px var(--gut);border-top:1px solid var(--hair);font-family:var(--font-mono);font-size:12px;color:var(--muted-dim)}.footer .f-brand{display:flex;align-items:center;gap:12px;color:var(--muted)}.footer .f-links{display:flex;gap:22px}.footer .f-brand .logo{height:18px}.footer a:hover{color:var(--fg)}@media (max-width: 860px){.topbar-nav{gap:18px}.hero-grid{grid-template-columns:1fr}.hero-portrait{min-height:52vh;order:2}.about-grid,.project,.project.featured{grid-template-columns:1fr}.project-media{order:1}.project-body{order:2}.exp-row{grid-template-columns:1fr;gap:14px}.edu-row,.quotes-grid{grid-template-columns:1fr}}@media (max-width: 540px){.topbar-nav a:not(:last-child){display:none}.topbar-brand .year{display:none}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.reveal-text .rt-inner{transform:none!important}[data-reveal]{opacity:1!important;transform:none!important}.marquee-track{animation:none!important}.draw-loop,.draw-loop path{animation:none!important;opacity:1!important}.draw-loop path{stroke-dashoffset:0!important}.draw-once path{animation:none!important;stroke-dashoffset:0!important}}
