*,: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:#3b82f6;--color-info-dark:#1d4ed8;--color-primary-light:#eff6ff;--color-primary-base:#06f;--color-primary-dark:#04c;--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);--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;--border:#333;--shadow:0 4px 6px #0006;--primary-light:#1e2a4a;--primary-base:#60a5fa;--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:#60a5fa;--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)}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}.portfolio-page{min-height:100vh;padding-bottom:calc(5.25rem + env(safe-area-inset-bottom,0px))}.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);display:flex;position:fixed;left:50%;transform:translate(-50%)}.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}.hero__inner{max-width:72rem;margin-inline:auto;position:relative}.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}.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:var(--text-inverse);background:var(--primary-base);border-radius:var(--radius-md);transition:background var(--transition-fast), transform var(--transition-fast);border:none;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--primary-dark);color:var(--text-inverse);text-decoration:none;transform:translateY(-1px)}.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-mosaic{grid-template-columns:1fr;width:100%;margin:0;padding:0;list-style:none;display:grid}@media (width>=640px){.projects-mosaic{grid-template-columns:repeat(2,1fr)}}.project-tile{min-height:0;margin:0;padding:0}.project-tile__link{aspect-ratio:1;color:inherit;text-decoration:none;display:block;position:relative;overflow:hidden}@media (width<=639px){.project-tile__link{aspect-ratio:4/3}}.project-tile__link:hover{text-decoration:none}.project-tile__link:focus-visible{z-index:1;box-shadow:inset 0 0 0 3px var(--primary-base);outline:none}.project-tile__media{transition:transform var(--transition-slow);background-position:50%;background-size:cover;position:absolute;inset:0;transform:scale(1.02)}.project-tile__link:hover .project-tile__media,.project-tile__link:focus-visible .project-tile__media{transform:scale(1.06)}.project-tile__overlay{padding:var(--space-lg) var(--space-xl);background:radial-gradient(ellipse 85% 70% at 50% 50%, color-mix(in srgb, var(--color-black) 72%, transparent) 0%, color-mix(in srgb, var(--color-black) 40%, transparent) 65%, transparent 100%);opacity:0;transition:opacity var(--transition-base);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.project-tile__link:hover .project-tile__overlay,.project-tile__link:focus-visible .project-tile__overlay{opacity:1}.project-tile__text{text-align:center;max-width:22rem;transition:transform var(--transition-base);transform:translateY(.35rem)}.project-tile__link:hover .project-tile__text,.project-tile__link:focus-visible .project-tile__text{transform:translateY(0)}.project-tile__meta{font-size:var(--font-size-xs);letter-spacing:.1em;text-transform:uppercase;color:color-mix(in srgb, var(--color-white) 75%, transparent);margin-bottom:var(--space-xs);font-weight:600}.project-tile__title{font-family:var(--font-family-secondary);letter-spacing:-.02em;color:var(--color-white);text-shadow:0 1px 2px color-mix(in srgb, var(--color-black) 40%, transparent);font-size:clamp(1.125rem,2.5vw,1.5rem);font-weight:700;line-height:1.2}@media (hover:none){.project-tile__overlay{opacity:1}.project-tile__text{transform:translateY(0)}.project-tile__link:hover .project-tile__media{transform:scale(1.02)}}.thumb-a{background:linear-gradient(135deg,#06f 0%,#8b5cf6 100%)}.thumb-b{background:linear-gradient(145deg,#404040 0%,#171717 100%)}.thumb-c{background:linear-gradient(160deg,#f5f3ff 0%,#ddd6fe 50%,#8b5cf6 100%)}[data-theme=dark] .thumb-c{background:linear-gradient(160deg,#2e1a47 0%,#5b21b6 50%,#a78bfa 100%)}.thumb-d{background:linear-gradient(120deg,#eff6ff 0%,#bfdbfe 45%,#06f 100%)}[data-theme=dark] .thumb-d{background:linear-gradient(120deg,#1e2a4a 0%,#1d4ed8 45%,#60a5fa 100%)}.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__back{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-lg);align-items:center;font-weight:600;display:inline-flex}.project-detail__back:hover{color:var(--primary-base);text-decoration:none}.project-detail__title{font-family:var(--font-family-secondary);letter-spacing:-.03em;color:var(--text-primary);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:repeat(4,minmax(0,1fr));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-lg);color:var(--text-primary);margin:.375rem 0 0;font-weight:700;line-height:1.4}@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);border-radius:var(--radius-md);background:0 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{text-decoration:underline}.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}@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}}
