*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul[role=list],ol[role=list]{list-style:none}:root{--color-black:#000;--color-neutral-900:#171717;--color-neutral-700:#404040;--color-neutral-500:#737373;--color-neutral-300:#d4d4d4;--color-neutral-100:#f5f5f5;--color-white:#fff;--color-error-light:#fef2f2;--color-error-base:#ef4444;--color-error-dark:#b91c1c;--color-success-light:#f0fdf4;--color-success-base:#22c55e;--color-success-dark:#15803d;--color-warning-light:#fffbeb;--color-warning-base:#f59e0b;--color-warning-dark:#b45309;--color-info-light:#eff6ff;--color-info-base:#0051ff;--color-info-dark:#0051ff;--color-primary-light:#eff6ff;--color-primary-base:#0051ff;--color-primary-dark:#0051ff;--color-spotlight-cta:#0051ff;--color-spotlight-cta-hover:#0051ff;--color-secondary-light:#f5f3ff;--color-secondary-base:#8b5cf6;--color-secondary-dark:#6d28d9;--font-family-base:"Outfit", system-ui, sans-serif;--font-family-secondary:"Syne", system-ui, sans-serif;--font-family-mono:"Fira Code", monospace;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:1rem;--radius-full:9999px;--border-width:1px;--border-color:#e5e5e5;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--text-primary:var(--color-black);--text-secondary:var(--color-neutral-500);--text-inverse:var(--color-white);--text-link:var(--color-primary-base);--bg-page:var(--color-white);--bg-surface:var(--color-neutral-100);--bg-elevated:var(--color-white);--bg-spotlight-cta:var(--color-spotlight-cta);--bg-spotlight-cta-hover:var(--color-black);--text-spotlight-cta:var(--color-white);--text-spotlight-cta-hover:var(--color-white);--spotlight-scroll-hint-hover:var(--color-spotlight-cta-hover);--border:var(--color-neutral-300);--shadow:var(--shadow-md);--primary-light:var(--color-primary-light);--primary-base:var(--color-primary-base);--primary-dark:var(--color-primary-dark);--secondary-light:var(--color-secondary-light);--secondary-base:var(--color-secondary-base);--secondary-dark:var(--color-secondary-dark);--error-light:var(--color-error-light);--error-base:var(--color-error-base);--error-dark:var(--color-error-dark);--success-light:var(--color-success-light);--success-base:var(--color-success-base);--success-dark:var(--color-success-dark);--warning-light:var(--color-warning-light);--warning-base:var(--color-warning-base);--warning-dark:var(--color-warning-dark);--info-light:var(--color-info-light);--info-base:var(--color-info-base);--info-dark:var(--color-info-dark)}[data-theme=dark]{--text-primary:var(--color-neutral-100);--text-secondary:var(--color-neutral-500);--text-inverse:var(--color-black);--text-link:var(--color-primary-base);--bg-page:#0a0a0a;--bg-surface:var(--color-neutral-900);--bg-elevated:#262626;--bg-spotlight-cta-hover:#fff;--text-spotlight-cta-hover:var(--color-black);--border:#333;--shadow:0 4px 6px #0006;--primary-light:#1e2a4a;--primary-base:#0051ff;--primary-dark:#bfdbfe;--secondary-light:#2e1a47;--secondary-base:#a78bfa;--secondary-dark:#ddd6fe;--error-light:#451a1a;--error-base:#f87171;--error-dark:#fecaca;--success-light:#14332a;--success-base:#4ade80;--success-dark:#bbf7d0;--warning-light:#422006;--warning-base:#fbbf24;--warning-dark:#fef3c7;--info-light:#1e2a4a;--info-base:#0051ff;--info-dark:#bfdbfe}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}html[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--bg-page);background-image:url(/images/img/lightmode.png);background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:fixed}html[data-theme=dark] body{background-image:url(/images/img/darkmode.png)}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}a:focus-visible{outline:2px solid var(--text-link);outline-offset:2px}img{height:auto}button{cursor:pointer}:focus-visible{outline:2px solid var(--text-link);outline-offset:2px}.skip-link{width:1px;height:1px;position:absolute;top:auto;left:-9999px;overflow:hidden}.skip-link:focus{background:var(--bg-elevated);width:auto;height:auto;color:var(--text-primary);border:2px solid var(--border);z-index:9999;outline:2px solid var(--text-link);outline-offset:2px;border-radius:.375rem;padding:.75rem 1.5rem;position:fixed;top:1rem;left:1rem}:is(html:has(body.page-home),html:has(body.page-about)){scroll-snap-type:y mandatory;scroll-behavior:smooth;scroll-padding-block-end:calc(5.25rem + env(safe-area-inset-bottom,0px))}@media (prefers-reduced-motion:reduce){:is(html:has(body.page-home),html:has(body.page-about)){scroll-behavior:auto;scroll-snap-type:y proximity}}.portfolio-page{min-height:100vh}body.portfolio-page .snap-section{scroll-snap-align:start;scroll-snap-stop:always;box-sizing:border-box;flex-direction:column;width:100%;height:100dvh;min-height:100dvh;display:flex;overflow:hidden auto}body.portfolio-page .snap-section__fill{flex-direction:column;flex:auto;width:100%;min-height:0;display:flex}body.portfolio-page .home-hero{box-sizing:border-box;width:100%;min-height:0;padding-top:calc(max(.75rem, env(safe-area-inset-top,0px)) + clamp(3.5rem, 11vh, 9rem));padding-inline:var(--space-xl);padding-bottom:max(5.75rem, calc(5rem + env(safe-area-inset-bottom,0px)));flex-direction:column;flex:auto;justify-content:center;align-items:center;gap:0;display:flex}body.portfolio-page .home-hero__main{box-sizing:border-box;flex-direction:column;flex:0 auto;align-items:center;width:100%;min-height:0;display:flex}body.portfolio-page .home-hero__intro{flex-direction:column;flex:none;justify-content:flex-start;align-items:center;width:100%;display:flex}body.portfolio-page .home-hero__name{font-family:var(--font-family-secondary);letter-spacing:-.04em;color:var(--text-primary);text-align:center;text-transform:uppercase;width:100%;max-width:100%;margin:0 0 clamp(1.5rem,4vw,3rem);font-size:clamp(3rem,12.5vw,min(8rem,16vw));font-weight:800;line-height:.95}body.portfolio-page .home-hero__row{align-items:center;row-gap:var(--space-md);grid-template-columns:minmax(0,1fr) minmax(14rem,clamp(20rem,45vw,36rem)) minmax(0,1fr);width:100%;max-width:72rem;margin-top:clamp(.5rem,2vw,1.25rem);display:grid}body.portfolio-page .home-hero__side{font-family:var(--font-family-secondary);letter-spacing:-.02em;color:var(--text-primary);text-transform:uppercase;--word-travel:clamp(8rem, 18vw, 18rem);will-change:transform;margin:0;font-size:clamp(1.35rem,3.2vw,2.25rem);font-weight:700;line-height:1.05;transition:transform 50ms linear}body.portfolio-page .home-hero__side--left{text-align:right;transform:translateX(calc(var(--home-scroll,0) * var(--word-travel)))}body.portfolio-page .home-hero__side--right{text-align:left;transform:translateX(calc(var(--home-scroll,0) * var(--word-travel) * -1))}@media (prefers-reduced-motion:reduce){body.portfolio-page .home-hero__side--left,body.portfolio-page .home-hero__side--right{transform:none}}body.portfolio-page .home-hero__center{flex-direction:column;align-items:stretch;width:min(100%,500px);margin-inline:auto;display:flex}body.portfolio-page .home-hero__meta{justify-content:space-between;align-items:baseline;gap:var(--space-md);width:min(100%,500px);margin-inline:auto;margin-bottom:var(--space-sm);font-size:var(--font-size-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);font-weight:600;display:flex}body.portfolio-page .home-hero__meta-item--right{text-align:right}body.portfolio-page .home-hero__meta-item{--meta-travel:clamp(2rem, 6vw, 6rem);will-change:transform;transition:transform 50ms linear}body.portfolio-page .home-hero__meta-item--left{transform:translateX(calc(var(--home-scroll,0) * var(--meta-travel)))}body.portfolio-page .home-hero__meta-item--right{transform:translateX(calc(var(--home-scroll,0) * var(--meta-travel) * -1))}@media (prefers-reduced-motion:reduce){body.portfolio-page .home-hero__meta-item--left,body.portfolio-page .home-hero__meta-item--right{transform:none}}body.portfolio-page .home-hero__frame{aspect-ratio:500/280;background-color:var(--bg-surface);background-image:url(/images/img/placeholder.png);background-position:50%;background-repeat:no-repeat;background-size:cover;border:none;border-radius:0;width:min(100%,500px);height:auto;margin-inline:auto;overflow:hidden}html[data-theme=dark] body.portfolio-page .home-hero__frame{background-color:var(--bg-surface);background-image:url(/images/img/placeholder.png)}body.portfolio-page .home-hero__scroll-hint{padding:var(--space-sm);flex-shrink:0;justify-content:center;align-self:center;align-items:center;margin-top:clamp(1.25rem,4vw,2.5rem);text-decoration:none;display:inline-flex}body.portfolio-page .home-hero__scroll-hint:focus-visible{outline:2px solid var(--text-link);outline-offset:4px;border-radius:var(--radius-sm)}body.portfolio-page .home-hero__scroll-hint-arrow{color:var(--bg-spotlight-cta);margin-inline:auto;line-height:0;animation:1.8s ease-in-out infinite home-hero-scroll-hint-nudge;display:block}body.portfolio-page .home-hero__scroll-hint-arrow svg{width:clamp(1.625rem,4.5vw,2rem);height:auto;display:block}body.portfolio-page .home-hero__scroll-hint:hover .home-hero__scroll-hint-arrow{color:var(--spotlight-scroll-hint-hover)}@keyframes home-hero-scroll-hint-nudge{0%,to{opacity:.85;transform:translateY(0)}50%{opacity:1;transform:translateY(8px)}}@media (prefers-reduced-motion:reduce){body.portfolio-page .home-hero__scroll-hint-arrow{animation:none}}body.page-home .home-hero-flight{z-index:3;pointer-events:none;opacity:0;visibility:hidden;will-change:top, left, width, height, opacity, border-radius;border:none;width:0;height:0;position:fixed;top:0;left:0;overflow:hidden}body.page-home .home-hero-flight__swatch{background-color:var(--bg-surface);background-image:url(/images/img/placeholder.png);background-position:50%;background-repeat:no-repeat;background-size:cover;width:100%;height:100%}html[data-theme=dark] body.page-home .home-hero-flight__swatch{background-color:var(--bg-surface);background-image:url(/images/img/placeholder.png)}body.portfolio-page .home-billboard{justify-content:center;align-items:center;width:100%;height:100%;padding:0;display:flex}body.portfolio-page .home-billboard__image{background-color:var(--bg-surface);opacity:0;background-image:url(/images/img/placeholder.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:100%;height:100%;transition:opacity .2s ease-out}body.portfolio-page.billboard-landed .home-billboard__image{opacity:1}body.portfolio-page .featured-works{width:100%;height:100%;padding-inline:var(--space-xl);box-sizing:border-box;justify-content:center;align-items:center;padding-block:clamp(2rem,5vw,4rem);display:flex;position:relative;overflow:hidden}body.portfolio-page .featured-works__title{z-index:1;font-family:var(--font-family-secondary);letter-spacing:-.04em;color:var(--text-primary);text-align:center;text-transform:uppercase;pointer-events:none;margin:0;font-size:clamp(2.25rem,11vw,min(8rem,16vw));font-weight:800;line-height:.95;position:relative}body.portfolio-page .featured-works__pills{z-index:2;pointer-events:none;margin:0;padding:0;list-style:none;position:absolute;inset:0}body.portfolio-page .featured-works__slot{--parallax-y:0px;--parallax-x:0px;transform:translate(-50%, -50%) translate(var(--parallax-x), var(--parallax-y));will-change:transform;transition:transform .1s linear;position:absolute}body.portfolio-page .featured-works__pill{object-fit:contain;will-change:transform;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:90%;display:block}body.portfolio-page .featured-works__pill--dark,html[data-theme=dark] body.portfolio-page .featured-works__pill--light{display:none}html[data-theme=dark] body.portfolio-page .featured-works__pill--dark{display:block}body.portfolio-page .featured-works__slot--1{--parallax-y:calc(var(--scroll-y,0px) * .05);--parallax-x:calc(var(--scroll-y,0px) * .018);top:18%;left:15%}body.portfolio-page .featured-works__slot--2{--parallax-y:calc(var(--scroll-y,0px) * -.06);--parallax-x:calc(var(--scroll-y,0px) * .012);top:28%;left:42%}body.portfolio-page .featured-works__slot--3{--parallax-y:calc(var(--scroll-y,0px) * -.07);--parallax-x:calc(var(--scroll-y,0px) * -.022);top:25%;left:82%}body.portfolio-page .featured-works__slot--4{--parallax-y:calc(var(--scroll-y,0px) * .04);--parallax-x:calc(var(--scroll-y,0px) * .025);top:50%;left:12%}body.portfolio-page .featured-works__slot--5{--parallax-y:calc(var(--scroll-y,0px) * -.06);--parallax-x:calc(var(--scroll-y,0px) * -.02);top:50%;left:88%}body.portfolio-page .featured-works__slot--6{--parallax-y:calc(var(--scroll-y,0px) * .07);--parallax-x:calc(var(--scroll-y,0px) * .015);top:72%;left:15%}body.portfolio-page .featured-works__slot--7{--parallax-y:calc(var(--scroll-y,0px) * .05);--parallax-x:calc(var(--scroll-y,0px) * -.015);top:72%;left:58%}body.portfolio-page .featured-works__slot--8{--parallax-y:calc(var(--scroll-y,0px) * -.05);--parallax-x:calc(var(--scroll-y,0px) * -.028);top:82%;left:82%}body.portfolio-page .featured-works__slot--9{--parallax-y:calc(var(--scroll-y,0px) * .08);--parallax-x:calc(var(--scroll-y,0px) * .02);top:8%;left:60%}body.portfolio-page .featured-works__slot--1 .featured-works__pill{animation:5.5s ease-in-out infinite pill-float-a}body.portfolio-page .featured-works__slot--2 .featured-works__pill{animation:6.2s ease-in-out -.8s infinite pill-float-b}body.portfolio-page .featured-works__slot--3 .featured-works__pill{animation:7s ease-in-out -1.6s infinite pill-float-c}body.portfolio-page .featured-works__slot--4 .featured-works__pill{animation:5.8s ease-in-out -2.4s infinite pill-float-d}body.portfolio-page .featured-works__slot--5 .featured-works__pill{animation:6.5s ease-in-out -3.2s infinite pill-float-a}body.portfolio-page .featured-works__slot--6 .featured-works__pill{animation:6.8s ease-in-out -.4s infinite pill-float-b}body.portfolio-page .featured-works__slot--7 .featured-works__pill{animation:5.4s ease-in-out -2s infinite pill-float-c}body.portfolio-page .featured-works__slot--8 .featured-works__pill{animation:6s ease-in-out -1.2s infinite pill-float-d}body.portfolio-page .featured-works__slot--9 .featured-works__pill{animation:7.2s ease-in-out -2.8s infinite pill-float-a}@keyframes pill-float-a{0%{transform:translate(0)rotate(0)}33%{transform:translate(6px,-10px)rotate(1.2deg)}66%{transform:translate(-4px,-6px)rotate(-.8deg)}to{transform:translate(0)rotate(0)}}@keyframes pill-float-b{0%{transform:translate(0)rotate(0)}33%{transform:translate(-7px,-8px)rotate(-1.4deg)}66%{transform:translate(5px,-4px)rotate(.6deg)}to{transform:translate(0)rotate(0)}}@keyframes pill-float-c{0%{transform:translate(0)rotate(0)}25%{transform:translate(8px,-6px)rotate(.9deg)}50%{transform:translate(2px,-12px)rotate(-1.1deg)}75%{transform:translate(-6px,-4px)rotate(.4deg)}to{transform:translate(0)rotate(0)}}@keyframes pill-float-d{0%{transform:translate(0)rotate(0)}50%{transform:translate(3px,-14px)rotate(1.5deg)}to{transform:translate(0)rotate(0)}}@media (prefers-reduced-motion:reduce){body.portfolio-page .featured-works__pill{animation:none}body.portfolio-page .featured-works__slot{--parallax-y:0px;--parallax-x:0px}}@media (width<=1024px){body.portfolio-page .featured-works__pills{display:none}}@media (width<=900px){body.portfolio-page .home-hero__row{column-gap:var(--space-lg);grid-template:"center center""left right"/1fr 1fr;row-gap:clamp(1.25rem,4vw,2rem);max-width:min(100%,36rem);margin-inline:auto;display:grid}body.portfolio-page .home-hero__center{grid-area:center;justify-self:center;width:min(100%,500px);margin-inline:auto}body.portfolio-page .home-hero__side--left{text-align:center;grid-area:left;padding:0}body.portfolio-page .home-hero__side--right{text-align:center;grid-area:right;padding:0}}body.portfolio-page .projects-showcase--single{min-height:0;padding-inline:var(--space-xl);flex-direction:column;flex:auto;gap:0;padding-block:clamp(.75rem,2vw,1.25rem);display:flex}body.portfolio-page .project-spotlight--snap{--spotlight-visual-h:calc(100cqw * (1.35 / 2.35) * 9 / 16);flex:auto;align-content:center;align-items:start;height:100%;min-height:0;max-height:100%;container:spotlight/inline-size}body.portfolio-page .project-spotlight--snap .project-spotlight__visual{aspect-ratio:16/9;align-self:start;width:100%;height:auto;min-height:0}body.portfolio-page .project-spotlight--snap .project-spotlight__panel{box-sizing:border-box;height:var(--spotlight-visual-h);justify-content:flex-start;align-self:start;min-height:0;padding-block:0;padding-inline:clamp(1.25rem,3vw,2.5rem);overflow-y:auto}body.portfolio-page .site-footer--snap{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;height:40dvh;min-height:40dvh;display:flex}body.portfolio-page .snap-section.section{padding:0}.dock-nav{bottom:max(var(--space-lg), calc(env(safe-area-inset-bottom,0px) + var(--space-sm)));z-index:var(--z-sticky);align-items:center;gap:var(--space-sm);max-width:calc(100vw - var(--space-xl) * 2);padding:var(--space-sm) var(--space-md);background:color-mix(in srgb, var(--bg-elevated) 92%, transparent);-webkit-backdrop-filter:blur(16px);border:var(--border-width) solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);transition:transform .3s ease-out,opacity .3s ease-out;display:flex;position:fixed;left:50%;transform:translate(-50%)}body.no-scroll .dock-nav,.dock-nav.dock-nav--hidden{transform:translateX(-50%) translateY(calc(100% + var(--space-2xl)));opacity:0;pointer-events:none}.dock-nav__divider{background:var(--border);flex-shrink:0;width:1px;height:1.25rem}.dock-nav a{font-size:var(--font-size-sm);color:var(--text-secondary);border-radius:var(--radius-full);white-space:nowrap;transition:color var(--transition-fast), background var(--transition-fast);padding:.4rem .65rem;font-weight:500}.dock-nav a:hover{color:var(--text-primary);background:color-mix(in srgb, var(--bg-surface) 80%, transparent);text-decoration:none}.dock-nav .theme-toggle{flex-shrink:0}.theme-toggle{border:var(--border-width) solid transparent;border-radius:var(--radius-full);background:color-mix(in srgb, var(--bg-surface) 70%, transparent);width:2.5rem;height:2.5rem;color:var(--text-primary);transition:background var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;padding:0;display:inline-flex}.theme-toggle:hover{background:var(--bg-surface);border-color:var(--border)}.theme-toggle .icon{font-size:1.125rem;line-height:1}.theme-toggle .theme-icon-dark,html[data-theme=dark] .theme-toggle .theme-icon-light{display:none}html[data-theme=dark] .theme-toggle .theme-icon-dark{display:inline-block}.hero{padding:clamp(3rem, 12vw, 7rem) var(--space-xl) clamp(4rem, 10vw, 6rem);position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(ellipse 80% 50% at 20% 40%, var(--primary-light), transparent 55%), radial-gradient(ellipse 60% 45% at 85% 30%, var(--secondary-light), transparent 50%);pointer-events:none;opacity:.85;height:85%;position:absolute;inset:-40% -20% auto}[data-theme=dark] .hero:before{opacity:.45}.about-page .hero:before{display:none}.hero__inner{max-width:72rem;margin-inline:auto;position:relative}.about-hero__inner{grid-template-columns:minmax(14rem,.8fr) minmax(0,1.2fr);align-items:center;gap:clamp(2rem,6vw,5rem);display:grid}.about-hero__media{justify-self:center;width:min(100%,24rem)}.about-hero__image{aspect-ratio:4/5;object-fit:cover;border-radius:9999px;width:100%;display:block}@media (width<=720px){.about-hero__inner{text-align:center;grid-template-columns:1fr}.about-hero__media{width:min(78vw,20rem)}.hero__title,.hero__lede{margin-inline:auto}.hero__actions{justify-content:center}}.about-focus{padding:clamp(3rem, 12vw, 7rem) var(--space-xl) clamp(4rem, 10vw, 6rem);box-sizing:border-box;justify-content:center;align-items:center}.about-focus__inner{width:100%;max-width:72rem;margin-inline:auto}.about-focus .hero__skills{margin-bottom:var(--space-xl)}.about-focus .hero__skills-label{font-family:var(--font-family-secondary);letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-lg);text-transform:none;font-size:clamp(2.25rem,5.5vw,3.75rem);font-weight:700;line-height:1.12}.hero__label{font-size:var(--font-size-sm);letter-spacing:.12em;text-transform:uppercase;color:var(--primary-base);margin-bottom:var(--space-md);font-weight:600;display:inline-block}html[data-theme=dark] .hero__label{color:#0051ff}.hero__title{font-family:var(--font-family-secondary);letter-spacing:-.03em;color:var(--text-primary);max-width:14ch;margin-bottom:var(--space-lg);font-size:clamp(2.25rem,5.5vw,3.75rem);font-weight:700;line-height:1.12}.hero__lede{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:36rem;margin-bottom:var(--space-xl);line-height:1.6}.hero__skills{margin-bottom:var(--space-2xl);max-width:42rem}.hero__skills-label{font-family:var(--font-family-base);font-size:var(--font-size-sm);letter-spacing:.1em;text-transform:uppercase;color:var(--primary-base);margin-bottom:var(--space-md);font-weight:600}.hero__actions{gap:var(--space-md);flex-wrap:wrap;display:flex}.btn-primary{font-size:var(--font-size-sm);color:#fff;border-radius:var(--radius-md);transition:background var(--transition-fast), color var(--transition-fast);background:#0051ff;border:none;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-weight:600;display:inline-flex}.btn-primary:hover{color:#fff;background:#000;text-decoration:none}html[data-theme=dark] .btn-primary:hover{color:#000;background:#fff}.btn-ghost{font-size:var(--font-size-sm);color:var(--text-primary);border:var(--border-width) solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), background var(--transition-fast);background:0 0;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-weight:600;display:inline-flex}.btn-ghost:hover{border-color:var(--text-secondary);background:var(--bg-surface);color:var(--text-primary);text-decoration:none}.section{padding:clamp(3rem, 8vw, 5rem) var(--space-xl)}.section__inner{max-width:72rem;margin-inline:auto}.section__header{margin-bottom:var(--space-2xl)}.section__eyebrow{font-size:var(--font-size-sm);letter-spacing:.1em;text-transform:uppercase;color:var(--primary-base);margin-bottom:var(--space-sm);font-weight:600}.section__title{font-family:var(--font-family-secondary);letter-spacing:-.02em;color:var(--text-primary);font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700}.section--work{padding-inline:0;padding-bottom:0}.work-head-shell{padding-inline:var(--space-xl)}.projects-showcase{padding-inline:var(--space-xl);flex-direction:column;gap:clamp(3rem,8vw,5.5rem);padding-bottom:clamp(2rem,5vw,3.5rem);display:flex}.project-spotlight{grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);align-items:stretch;min-height:min(72vh,38rem);display:grid}body.portfolio-page .project-spotlight--snap{min-height:0}.project-spotlight__visual{aspect-ratio:16/9;background-position:50%;background-size:cover;align-self:start;width:100%;min-height:0}.project-spotlight__panel{justify-content:flex-start;gap:var(--space-md);background:0 0;flex-direction:column;padding:clamp(1.5rem,4vw,2.75rem) clamp(1.25rem,3vw,2.5rem);display:flex}.project-spotlight__eyebrow{font-size:var(--font-size-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);margin:0;font-weight:600}.project-spotlight__index{color:var(--text-primary);margin:0;line-height:1}.project-spotlight__index-num{font-family:var(--font-family-secondary);letter-spacing:-.03em;font-size:clamp(2rem,4vw,2.75rem);font-weight:700}.project-spotlight__index-slash{font-size:var(--font-size-lg);opacity:.45;margin:0 .2em;font-weight:400}.project-spotlight__index-total{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.project-spotlight__title{font-family:var(--font-family-secondary);letter-spacing:-.03em;color:var(--text-primary);margin:0;font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:700;line-height:1.12}.project-spotlight__cta{border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--text-spotlight-cta);background:var(--bg-spotlight-cta);transition:background var(--transition-fast), color var(--transition-fast);border:none;justify-content:center;align-self:flex-start;align-items:center;padding:.55rem 1.35rem;font-weight:600;text-decoration:none;display:inline-flex}.project-spotlight__cta:hover{background:var(--bg-spotlight-cta-hover);color:var(--text-spotlight-cta-hover);text-decoration:none}.project-spotlight__lede{max-width:28rem;font-size:var(--font-size-sm);color:var(--text-secondary);flex-shrink:0;margin:auto 0 0;line-height:1.6}@media (width<=900px){.project-spotlight{grid-template-columns:1fr;min-height:auto}body.portfolio-page .project-spotlight--snap{grid-template-rows:auto minmax(0,1fr);min-height:0}.project-spotlight__visual{aspect-ratio:16/9;min-height:0}body.portfolio-page .project-spotlight--snap .project-spotlight__visual{aspect-ratio:16/9;align-self:stretch;width:100%;height:auto;min-height:0}body.portfolio-page .project-spotlight--snap{--spotlight-visual-h:auto}.project-spotlight__panel{padding-bottom:clamp(1.5rem,4vw,2.5rem)}body.portfolio-page .project-spotlight--snap .project-spotlight__panel{padding-block:0;justify-content:flex-start;height:auto;max-height:none;padding-bottom:0;overflow-y:visible}}.thumb-a{background-color:var(--bg-surface);background-image:url(/images/img/project1.png);background-position:50%;background-repeat:no-repeat;background-size:cover}.thumb-b{background-color:var(--bg-surface);background-image:url(/images/img/project2.png);background-position:50%;background-repeat:no-repeat;background-size:cover}.thumb-c{background-color:var(--bg-surface);background-image:url(/images/img/project3.png);background-position:50%;background-repeat:no-repeat;background-size:cover}.thumb-d{background-color:var(--bg-surface);background-image:url(/images/img/project4.png);background-position:50%;background-repeat:no-repeat;background-size:cover}.thumb-e{background:linear-gradient(#f5f5f5 0%,#d4d4d4 100%)}[data-theme=dark] .thumb-e{background:linear-gradient(#262626 0%,#404040 100%)}.thumb-f{background:linear-gradient(90deg,#22c55e 0%,#15803d 100%)}.project-detail{max-width:72rem;padding:clamp(2rem, 6vw, 4rem) var(--space-xl) clamp(4rem, 10vw, 6rem);margin-inline:auto}.project-detail__body{--detail-rail:clamp(6.5rem, 14vw, 10rem);--detail-gutter:clamp(1.5rem, 3.5vw, 2.75rem);--detail-rule-pad:.65rem;width:100%;margin-inline:0;padding:0}.project-detail__head{width:100%;margin-bottom:var(--space-xl)}.project-detail__nav{align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.project-detail__back{font-size:var(--font-size-sm);color:var(--text-secondary);align-items:center;font-weight:600;display:inline-flex}.project-detail__back:hover{color:var(--primary-base);text-decoration:none}.project-detail__next{font-size:var(--font-size-sm);color:var(--text-secondary);align-items:center;font-weight:600;display:inline-flex}.project-detail__next:hover{color:var(--primary-base);text-decoration:none}.project-detail__title{font-family:var(--font-family-secondary);letter-spacing:-.03em;color:#0051ff;margin:0 0 var(--space-md);font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15}.project-detail__overview{width:100%;margin:0 0 var(--space-lg);font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.7}.project-detail__meta{place-items:start;column-gap:1vw;row-gap:var(--space-lg);width:100%;margin:0 0 var(--space-2xl);border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1.4fr) minmax(0,1.4fr);padding:clamp(1.25rem,2.5vw,2rem) 0;display:grid}.project-detail__meta-item{text-align:left;min-width:0;max-width:100%}.project-detail__meta-item dt{font-size:var(--font-size-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin:0;font-weight:500;line-height:1.4}.project-detail__meta-item dd{font-size:var(--font-size-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:.375rem 0 0;font-weight:700;line-height:1.4;overflow:hidden}@media (width<=640px){.project-detail__meta{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=380px){.project-detail__meta{grid-template-columns:1fr}}.project-detail__hero-media{aspect-ratio:16/9;width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-bottom:var(--space-2xl);background-position:50%;background-size:cover;border-radius:0}.project-detail__body .project-detail__split{grid-template-columns:var(--detail-rail) minmax(0, 1fr);column-gap:var(--detail-gutter);margin-bottom:var(--space-2xl);align-items:start;display:grid}.project-detail__body .project-detail__split-label{min-width:0}.project-detail__body .project-detail__split-heading{padding-top:var(--detail-rule-pad);border-top:1px solid var(--text-primary);box-sizing:border-box;width:fit-content;max-width:100%;font-family:var(--font-family-base);font-size:var(--font-size-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--text-primary);margin:0;font-weight:600;line-height:1.35}.project-detail__body .project-detail__split-content{min-width:0;display:flow-root}.project-detail__body .project-detail__split-content>p:not(.project-detail__outcome-summary){font-size:var(--font-size-lg);color:var(--text-secondary);margin:0 0 var(--space-lg);line-height:1.7}.project-detail__body .project-detail__split-content>p:not(.project-detail__outcome-summary):last-child{margin-bottom:0}.project-detail__body .project-detail__split-content .project-detail__outcome-summary{font-size:var(--font-size-lg);color:var(--text-secondary);margin:0 0 var(--space-xl);line-height:1.65}.project-detail__body .project-detail__outcome-panel{border:var(--border-width) solid var(--text-primary);background:0 0;border-radius:0;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;margin:0;display:grid;overflow:hidden}.project-detail__body .project-detail__outcome-stat{border-right:var(--border-width) solid var(--text-primary);background:0 0;flex-direction:column;align-items:flex-start;gap:0;min-width:0;min-height:100%;margin:0;padding:clamp(1.25rem,3vw,1.75rem);display:flex}.project-detail__body .project-detail__outcome-stat:last-child{border-right:none}.project-detail__body .project-detail__outcome-stat-value{font-family:var(--font-family-secondary);font-size:var(--font-size-3xl);letter-spacing:-.04em;color:var(--primary-base);margin:0;font-weight:800;line-height:1}.project-detail__body .project-detail__outcome-stat-label{font-family:var(--font-family-base);font-size:var(--font-size-base);padding-top:var(--space-sm);color:var(--text-primary);margin:0;padding-bottom:0;font-weight:700;line-height:1.35}.project-detail__body .project-detail__outcome-stat-detail{font-family:var(--font-family-base);font-size:var(--font-size-sm);padding-top:var(--space-sm);color:var(--text-secondary);margin:0;font-weight:400;line-height:1.5}@media (width<=900px){.project-detail__body .project-detail__outcome-panel{grid-template-columns:1fr}.project-detail__body .project-detail__outcome-stat{border-right:none;border-bottom:var(--border-width) solid var(--text-primary)}.project-detail__body .project-detail__outcome-stat:last-child{border-bottom:none}}.project-detail__body-aside{padding-left:calc(var(--detail-rail) + var(--detail-gutter));margin-top:var(--space-2xl)}@media (width<=680px){.project-detail__body .project-detail__split{grid-template-columns:1fr}.project-detail__body-aside{padding-left:0}}.skills-list{gap:var(--space-sm);flex-wrap:wrap;margin:0;padding:0;list-style:none;display:flex}.skills-list li{font-size:var(--font-size-sm);border-radius:var(--radius-full);background:var(--bg-elevated);border:var(--border-width) solid var(--border);color:var(--text-primary);padding:.35rem .75rem;font-weight:500}.contact-block{text-align:center;border-radius:var(--radius-lg);border:var(--border-width) solid var(--border);background:linear-gradient(135deg, var(--bg-surface) 0%, color-mix(in srgb, var(--primary-light) 50%, var(--bg-surface)) 100%);padding:clamp(2.5rem,6vw,4rem)}.contact-block p{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:28rem;margin:0 auto var(--space-xl);line-height:1.6}.contact-email{font-size:var(--font-size-xl);color:var(--primary-base);font-weight:600}.contact-email:hover{color:var(--primary-dark);text-decoration:none}.site-footer{border-top:var(--border-width) solid var(--border);padding:var(--space-xl);text-align:center}.site-footer p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.social-row{justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-md);display:flex}.social-row a{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.social-row a:hover{color:var(--primary-base);text-decoration:none}.social-marquee{width:100%;margin-bottom:var(--space-lg);display:flex;overflow:hidden}.social-marquee__track{will-change:transform;flex-shrink:0;align-items:center;gap:clamp(1.5rem,3vw,3rem);padding-right:clamp(1.5rem,3vw,3rem);animation:30s linear infinite social-marquee-scroll;display:flex}.social-marquee__track a{font-family:var(--font-family-secondary);letter-spacing:-.02em;color:inherit;white-space:nowrap;font-size:clamp(3rem,8vw,6rem);font-weight:700;line-height:1;text-decoration:none;transition:color .2s ease-out}.social-marquee__track a:hover{color:var(--primary-base);text-decoration:none}.social-marquee__dot{opacity:.5;font-size:clamp(2rem,5vw,4rem);line-height:1}@keyframes social-marquee-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}@media (prefers-reduced-motion:reduce){.social-marquee__track{animation:none}}body.page-home #footer.site-footer--home{isolation:isolate;border-top-color:#0000;position:relative;overflow:hidden}body.page-home #footer.site-footer--home:before{content:"";z-index:0;pointer-events:none;background:0 0;position:absolute;inset:0}body.page-home #footer.site-footer--home.site-footer--fill-visible:before{background:0 0}body.page-home #footer.site-footer--home .social-row,body.page-home #footer.site-footer--home .social-marquee,body.page-home #footer.site-footer--home>p{z-index:1;position:relative}body.page-home #footer.site-footer--home.site-footer--fill-visible .social-row a,body.page-home #footer.site-footer--home.site-footer--fill-visible .social-marquee__track a,body.page-home #footer.site-footer--home.site-footer--fill-visible .social-marquee__dot,body.page-home #footer.site-footer--home.site-footer--fill-visible p{color:var(--text-primary);transition:color .55s .15s}body.page-home #footer.site-footer--home.site-footer--fill-visible .social-row a:hover,body.page-home #footer.site-footer--home.site-footer--fill-visible .social-marquee__track a:hover{color:var(--primary-base)}@media (prefers-reduced-motion:reduce){body.page-home #footer.site-footer--home:before,body.page-home #footer.site-footer--home.site-footer--fill-visible .social-row a,body.page-home #footer.site-footer--home.site-footer--fill-visible p{transition-duration:.01ms}}@media (width<=639px){.dock-nav{gap:var(--space-xs);padding:var(--space-xs) var(--space-sm)}.dock-nav a{font-size:var(--font-size-xs);padding:.35rem .5rem}.dock-nav__divider{height:1rem}.dock-nav .theme-toggle{width:2.25rem;height:2.25rem}}.project-detail__gallery{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-top:var(--space-2xl);grid-template-columns:1fr;gap:0;display:grid}.project-detail__gallery-item{aspect-ratio:4/3;cursor:zoom-in;background-color:var(--bg-surface);background-position:50%;background-repeat:no-repeat;background-size:cover;border:none;width:100%;padding:0;position:relative;overflow:hidden}.project-detail__gallery-item__overlay{padding:var(--space-lg);color:#fff;font-family:var(--font-family-secondary);text-align:center;opacity:1;pointer-events:none;background-color:#000c;justify-content:center;align-items:center;font-size:clamp(1.25rem,2vw,1.75rem);font-weight:700;transition:opacity .2s ease-out;display:flex;position:absolute;inset:0}.project-detail__gallery-item:nth-child(2) .project-detail__gallery-item__overlay,.project-detail__gallery-item:nth-child(3) .project-detail__gallery-item__overlay{background-color:#0051ffcc}.project-detail__gallery-item:hover .project-detail__gallery-item__overlay,.project-detail__gallery-item:focus-visible .project-detail__gallery-item__overlay{opacity:0}.project-detail__gallery-item img{object-fit:cover;width:100%;height:100%;display:block}.image-modal{z-index:100;opacity:0;visibility:hidden;padding:var(--space-xl);background-color:#000000d9;justify-content:center;align-items:center;transition:opacity .2s ease-out,visibility .2s ease-out;display:flex;position:fixed;inset:0}.image-modal--open{opacity:1;visibility:visible}.image-modal__img{object-fit:contain;width:auto;max-width:90vw;height:auto;max-height:90vh;box-shadow:0 20px 60px #00000080}.image-modal__close{top:var(--space-lg);right:var(--space-lg);color:#000;cursor:pointer;background-color:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;font-size:1.75rem;line-height:1;transition:background-color .15s ease-out;display:inline-flex;position:absolute}.image-modal__close:hover,.image-modal__close:focus-visible{background-color:#fff}.image-modal__nav{color:#000;cursor:pointer;background-color:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:1.5rem;line-height:1;transition:background-color .15s ease-out;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%)}.image-modal__nav:hover,.image-modal__nav:focus-visible{background-color:#fff}.image-modal__nav--prev{left:var(--space-lg)}.image-modal__nav--next{right:var(--space-lg)}body.no-scroll{overflow:hidden}.projects-grid{border-top:var(--border-width) solid var(--border);flex:auto;grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:0;width:100%;min-height:0;display:grid}.project-card{background-color:var(--bg-page);border-right:var(--border-width) solid var(--border);border-bottom:var(--border-width) solid var(--border);cursor:pointer;flex-direction:column;justify-content:flex-start;min-width:0;padding:clamp(1.5rem,3vw,2.5rem);transition:background-color .25s ease-out,color .25s ease-out;display:flex;position:relative}.project-card:nth-child(2n){border-right:none}.project-card:nth-child(n+3){border-bottom:none}.project-card:first-child:hover,.project-card:nth-child(4):hover{background-color:#000}.project-card:nth-child(2):hover,.project-card:nth-child(3):hover{background-color:#0051ff}.project-card:hover .project-card__eyebrow,.project-card:hover .project-card__index,.project-card:hover .project-card__index-total,.project-card:hover .project-card__title,.project-card:hover .project-card__lede{color:#fff}.project-card:hover .project-card__cta{color:#000;background:#fff}html[data-theme=dark] .project-card:first-child:hover,html[data-theme=dark] .project-card:nth-child(4):hover{background-color:#fff}html[data-theme=dark] .project-card:first-child:hover .project-card__eyebrow,html[data-theme=dark] .project-card:first-child:hover .project-card__index,html[data-theme=dark] .project-card:first-child:hover .project-card__index-total,html[data-theme=dark] .project-card:first-child:hover .project-card__title,html[data-theme=dark] .project-card:first-child:hover .project-card__lede,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__eyebrow,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__index,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__index-total,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__title,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__lede{color:#000}html[data-theme=dark] .project-card:first-child:hover .project-card__cta,html[data-theme=dark] .project-card:nth-child(4):hover .project-card__cta{color:#fff;background:#000}.project-card__eyebrow{margin:0 0 var(--space-sm);font-size:var(--font-size-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);font-weight:600}.project-card__index{margin:0 0 var(--space-md);color:var(--text-primary);line-height:1}.project-card__index-num{font-family:var(--font-family-secondary);letter-spacing:-.03em;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700}.project-card__index-slash{font-size:var(--font-size-base);opacity:.45;margin:0 .2em;font-weight:400}.project-card__index-total{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.project-card__title{margin:0 0 var(--space-md);font-family:var(--font-family-secondary);letter-spacing:-.03em;color:var(--text-primary);font-size:clamp(1.5rem,2.5vw,2.25rem);font-weight:700;line-height:1.12}.project-card__lede{margin:0 0 var(--space-lg);font-size:var(--font-size-sm);color:var(--text-secondary);max-width:32rem;line-height:1.55}.project-card__cta{border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--text-spotlight-cta);background:var(--bg-spotlight-cta);transition:background var(--transition-fast), color var(--transition-fast);border:none;justify-content:center;align-self:flex-start;align-items:center;margin-top:auto;padding:.55rem 1.35rem;font-weight:600;text-decoration:none;display:inline-flex}.project-card__cta:hover{background:var(--bg-spotlight-cta-hover);color:var(--text-spotlight-cta-hover);text-decoration:none}@media (width<=500px){.projects-grid{flex:none;grid-template-rows:repeat(4,auto);grid-template-columns:1fr;height:auto}.project-card{border-right:none;border-bottom:var(--border-width) solid var(--border);min-height:60vh}.project-card:last-child{border-bottom:none}}.mobile-nav-toggle{border:var(--border-width) solid transparent;border-radius:var(--radius-full);background:color-mix(in srgb, var(--bg-surface) 70%, transparent);width:2.5rem;height:2.5rem;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0;display:none}.mobile-nav-toggle:hover{background:var(--bg-surface);border-color:var(--border)}.mobile-nav-toggle__bar{width:1.1rem;height:2px;transition:transform var(--transition-fast), opacity var(--transition-fast);background:currentColor;border-radius:2px;display:block}.mobile-nav-toggle--open .mobile-nav-toggle__bar:first-child{transform:translateY(6px)rotate(45deg)}.mobile-nav-toggle--open .mobile-nav-toggle__bar:nth-child(2){opacity:0}.mobile-nav-toggle--open .mobile-nav-toggle__bar:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.mobile-nav{display:none}.mobile-nav__panel{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:var(--border-width) solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;min-width:14rem;display:flex}.mobile-nav__panel a{font-family:var(--font-family-secondary);font-size:var(--font-size-xl);color:var(--text-primary);text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast), color var(--transition-fast);font-weight:600;text-decoration:none}.mobile-nav__panel a:hover{background:var(--bg-surface);text-decoration:none}.mobile-nav__panel a[aria-current=page]{color:var(--primary-base)}@media (width<=900px){.mobile-nav-toggle{display:inline-flex}.dock-nav>a,.dock-nav__divider{display:none}.mobile-nav{z-index:var(--z-modal);padding:var(--space-xl);background-color:color-mix(in srgb, var(--bg-page) 70%, transparent);-webkit-backdrop-filter:blur(8px);opacity:0;visibility:hidden;justify-content:center;align-items:center;transition:opacity .2s ease-out,visibility .2s ease-out;display:flex;position:fixed;inset:0}.mobile-nav--open{opacity:1;visibility:visible}}
