@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap";.export-pdf-btn{font-family:var(--font-sans);border-radius:var(--radius-sm);transition:color var(--duration-fast), background var(--duration-fast), border-color var(--duration-fast), transform var(--duration-normal) var(--ease-out);white-space:nowrap;justify-content:center;align-items:center;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.export-pdf-btn--md{gap:.4375rem;padding:.625rem 1rem;font-size:.875rem}.export-pdf-btn--sm{gap:.3125rem;padding:.4375rem .6875rem;font-size:.8125rem}.export-pdf-btn__icon{flex-shrink:0}.export-pdf-btn__label{letter-spacing:-.01em}.export-pdf-btn--secondary{color:var(--text);border:1px solid var(--border);background:0 0}.export-pdf-btn--secondary:hover{border-color:var(--text-muted);background:var(--surface-raised)}.export-pdf-btn--ghost{color:var(--text-muted);border:1px solid var(--border-subtle);background:0 0}.export-pdf-btn--ghost:hover{color:var(--text);border-color:var(--border);background:var(--surface)}.export-pdf-btn--primary{background:var(--accent);color:#fff;border:1px solid #0000}.export-pdf-btn--primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.header__actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.header__cv-btn{flex-shrink:0}.header__mobile-actions{gap:var(--space-md);flex-direction:column;width:100%;display:flex}.header__mobile-actions .export-pdf-btn{width:100%}@media (width<=900px){.header__actions .export-pdf-btn:not(.header__mobile-actions *){display:none}}@media (width>=768px){.header__cv-btn{margin-right:var(--space-xs)}}.header{z-index:100;height:var(--nav-height);transition:background var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out);border-bottom:1px solid #0000;position:fixed;top:0;left:0;right:0}.header--scrolled{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom-color:var(--border-subtle);background:#0c1220e6}.header__inner{align-items:center;gap:var(--space-lg);height:100%;display:flex}.header__logo{align-items:center;gap:var(--space-md);flex-shrink:0;display:flex}.header__logo-mark{width:36px;height:36px;font-family:var(--font-sans);color:#fff;background:var(--accent);border-radius:var(--radius-sm);justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.header__logo-text{font-family:var(--font-sans);letter-spacing:-.01em;font-size:1.125rem;font-weight:600}.header__nav{align-items:center;gap:var(--space-xl);margin-left:auto;display:none}.header__nav-link{color:var(--text-muted);transition:color var(--duration-fast);font-size:.875rem;position:relative}.header__nav-link:after{content:"";background:var(--accent);width:0;height:1px;transition:width var(--duration-normal) var(--ease-out);position:absolute;bottom:-4px;left:0}.header__nav-link:hover{color:var(--text)}.header__nav-link:hover:after{width:100%}.header__cta{padding:.625rem 1.25rem;font-size:.875rem;display:none}.header__menu-btn{flex-direction:column;justify-content:center;gap:6px;width:40px;height:40px;margin-left:auto;padding:8px;display:flex}.header__menu-btn span{background:var(--text);width:100%;height:2px;transition:transform var(--duration-normal) var(--ease-out), opacity var(--duration-fast);display:block}.header__menu-btn--open span:first-child{transform:translateY(4px)rotate(45deg)}.header__menu-btn--open span:last-child{transform:translateY(-4px)rotate(-45deg)}.header__mobile{inset:var(--nav-height) 0 0 0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);opacity:0;visibility:hidden;transition:opacity var(--duration-normal), visibility var(--duration-normal);background:#0c1220f7;position:fixed}.header__mobile--open{opacity:1;visibility:visible}.header__mobile-nav{padding:var(--space-2xl) var(--space-lg);gap:var(--space-sm);flex-direction:column;display:flex}.header__mobile-link{font-family:var(--font-sans);padding:var(--space-md) 0;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);transition:color var(--duration-fast);font-size:2rem;font-weight:600}.header__mobile-link:hover{color:var(--text)}.header__mobile-cta{margin-top:var(--space-xl);width:100%}@media (width>=768px){.header__nav{display:flex}.header__cta{display:inline-flex}.header__menu-btn,.header__mobile{display:none}}@media (width>=1024px){.header__logo{margin-right:var(--space-2xl)}.header__nav{margin-left:0}.header__cta{margin-left:auto}}.footer{border-top:1px solid var(--border-subtle);padding:var(--space-3xl) 0 var(--space-xl);margin-top:var(--space-4xl)}.footer__inner{gap:var(--space-xl);display:grid}.footer__logo{font-family:var(--font-sans);font-size:1.25rem;font-weight:600}.footer__tagline{margin-top:var(--space-sm);color:var(--text-muted);font-size:.875rem}.footer__nav{gap:var(--space-lg);flex-wrap:wrap;display:flex}.footer__nav a{color:var(--text-muted);transition:color var(--duration-fast);font-size:.875rem}.footer__nav a:hover{color:var(--text)}.footer__copy{color:var(--text-subtle);font-size:.8125rem}@media (width>=768px){.footer__inner{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:start}.footer__copy{grid-column:1/-1}}.layout{flex-direction:column;min-height:100vh;display:flex}#main-content{padding-top:var(--nav-height);flex:1}.stat-counter{gap:var(--space-xs);flex-direction:column;display:flex}.stat-counter__value{font-family:var(--font-sans);letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;line-height:1}.stat-counter__suffix{color:var(--accent)}.stat-counter__label{color:var(--text-muted);max-width:12ch;font-size:.8125rem;line-height:1.4}.featured-ticker{height:var(--ticker-height);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0c1220cc;border-top:1px solid #ffffff14;align-items:stretch;display:flex;overflow:hidden}.featured-ticker__label{align-items:center;gap:var(--space-sm);padding:0 var(--space-lg);font-family:var(--font-sans);letter-spacing:.14em;text-transform:uppercase;color:var(--text-subtle);border-right:1px solid var(--border-subtle);white-space:nowrap;flex-shrink:0;font-size:.625rem;font-weight:600;display:none}.featured-ticker__dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite tickerPulse}@keyframes tickerPulse{0%,to{opacity:1}50%{opacity:.4}}.featured-ticker__track-wrap{flex:1;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.featured-ticker__track{align-items:center;width:max-content;height:100%;animation:40s linear infinite tickerScroll;display:flex}.featured-ticker__track-wrap:hover .featured-ticker__track{animation-play-state:paused}.featured-ticker__item{align-items:center;gap:var(--space-sm);padding:0 var(--space-xl);color:var(--text-muted);white-space:nowrap;transition:color var(--duration-fast);border-right:1px solid var(--border-subtle);height:100%;font-size:.8125rem;display:inline-flex}.featured-ticker__item:hover{color:var(--accent)}.featured-ticker__title{font-weight:500}.featured-ticker__metric{font-family:var(--font-sans);color:var(--text-subtle);font-size:.6875rem;font-weight:500}.featured-ticker__item:hover .featured-ticker__metric{color:var(--accent-dim)}@keyframes tickerScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (width>=768px){.featured-ticker__label{display:flex}}@media (prefers-reduced-motion:reduce){.featured-ticker__track{flex-wrap:wrap;justify-content:center;gap:0;width:100%;animation:none}.featured-ticker__track-wrap{overflow-x:auto;-webkit-mask-image:none;mask-image:none}.featured-ticker__dot{animation:none}}.parallax-hero{min-height:calc(100vh - var(--nav-height));padding-bottom:var(--ticker-height);flex-direction:column;justify-content:flex-end;display:flex;position:relative;overflow:hidden}.parallax-hero__media{z-index:0;position:absolute;inset:0}.parallax-hero__image-wrap{will-change:transform;position:absolute;inset:-15% 0 0}.parallax-hero__image{object-fit:cover;object-position:center 30%;width:100%;height:100%}.parallax-hero__overlay{background:linear-gradient(to bottom, #0c122059 0%, #0c12208c 40%, #0c1220f2 85%, var(--bg) 100%), linear-gradient(135deg, #4d9fff0f 0%, transparent 50%);position:absolute;inset:0}.parallax-hero__grain{opacity:.04;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.parallax-hero__content{z-index:1;width:100%;padding:var(--space-4xl) 0 var(--space-2xl);will-change:transform, opacity;flex:1;align-items:flex-end;display:flex;position:relative}.parallax-hero__ticker{z-index:2;position:absolute;bottom:0;left:0;right:0}@media (prefers-reduced-motion:reduce){.parallax-hero__image-wrap{inset:0;transform:none!important}.parallax-hero__content{opacity:1!important;transform:none!important}}@media (width>=1024px){.parallax-hero{min-height:calc(100vh - var(--nav-height) + 2rem)}.parallax-hero__content{padding-bottom:var(--space-3xl)}}.project-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--duration-normal), transform var(--duration-normal) var(--ease-out);overflow:hidden}.project-card:hover{border-color:var(--border);transform:translateY(-2px)}.project-card__link{flex-direction:column;height:100%;display:flex}.project-card__visual{height:160px;position:relative;overflow:hidden}.project-card__image{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out)}.project-card:hover .project-card__image{transform:scale(1.05)}.project-card__visual-overlay{opacity:.55;mix-blend-mode:multiply;transition:opacity var(--duration-normal);position:absolute;inset:0}.project-card:hover .project-card__visual-overlay{opacity:.4}.project-card__visual-grid{background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 40%,#0000);mask-image:linear-gradient(#000 40%,#0000)}.project-card__visual-index{bottom:var(--space-md);right:var(--space-md);font-family:var(--font-sans);color:#fff6;font-size:.75rem;font-weight:600;position:absolute}.project-card__body{padding:var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.project-card__meta{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.project-card__year{font-family:var(--font-sans);color:var(--text-subtle);font-size:.6875rem;font-weight:500}.project-card__title{font-family:var(--font-sans);letter-spacing:-.01em;font-size:1.125rem;font-weight:600;line-height:1.2}.project-card__tagline{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.875rem;line-height:1.45;display:-webkit-box;overflow:hidden}.project-card__tech{gap:var(--space-sm);flex-wrap:wrap;margin-top:auto;display:flex}.project-card__cta{align-items:center;gap:var(--space-sm);color:var(--accent);margin-top:var(--space-xs);transition:gap var(--duration-normal) var(--ease-out);font-size:.8125rem;font-weight:500;display:inline-flex}.project-card:hover .project-card__cta{gap:var(--space-md)}@media (width>=768px){.project-card__visual{height:180px}.project-card__title{font-size:1.25rem}}.project-grid-section{gap:var(--space-2xl);flex-direction:column;display:flex}.project-grid__filters{gap:var(--space-sm);flex-wrap:wrap;display:flex}.project-grid__filter{align-items:center;gap:var(--space-sm);color:var(--text-muted);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:all var(--duration-fast);padding:.5rem 1rem;font-size:.8125rem;font-weight:500;display:inline-flex}.project-grid__filter:hover{color:var(--text);border-color:var(--border)}.project-grid__filter--active{color:#fff;background:var(--accent);border-color:var(--accent)}.project-grid__filter-count{font-family:var(--font-sans);opacity:.7;font-size:.6875rem;font-weight:600}.project-grid__filter--active .project-grid__filter-count{opacity:.6}.project-grid{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.project-grid__empty{text-align:center;color:var(--text-muted);padding:var(--space-3xl);grid-column:1/-1}@media (width<=540px){.project-grid{grid-template-columns:1fr}}@media (width>=1024px){.project-grid{gap:var(--space-xl)}}.timeline{border-left:1px solid var(--border-subtle);flex-direction:column;margin-left:11px;display:flex}.timeline__item{position:relative}.timeline__header{align-items:flex-start;gap:var(--space-lg);width:100%;padding:var(--space-lg) 0 var(--space-lg) var(--space-xl);text-align:left;transition:background var(--duration-fast);border-radius:var(--radius-md);display:flex}.timeline__header:hover{background:var(--surface)}.timeline__marker{left:-12px;top:calc(var(--space-lg) + 6px);justify-content:center;align-items:center;width:23px;height:23px;display:flex;position:absolute}.timeline__marker:before{content:"";background:var(--bg);border:2px solid var(--accent);width:9px;height:9px;transition:background var(--duration-fast);border-radius:50%}.timeline__header--active .timeline__marker:before{background:var(--accent)}.timeline__pulse{background:var(--accent);border-radius:50%;width:9px;height:9px;animation:2s ease-in-out infinite pulse;position:absolute}@keyframes pulse{0%,to{box-shadow:0 0 #4d9fff66}50%{box-shadow:0 0 0 8px #4d9fff00}}.timeline__summary{flex:1;min-width:0}.timeline__top{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.timeline__company{font-family:var(--font-sans);letter-spacing:-.01em;font-size:1.375rem;font-weight:600}.timeline__role{margin-top:var(--space-xs);color:var(--text-muted);font-size:.9375rem}.timeline__period{margin-top:var(--space-xs);font-family:var(--font-sans);color:var(--text-subtle);font-size:.75rem;font-weight:500}.timeline__chevron{color:var(--text-subtle);transition:transform var(--duration-normal) var(--ease-out);flex-shrink:0;margin-top:6px}.timeline__chevron--open{transform:rotate(180deg)}.timeline__content{overflow:hidden}.timeline__content-inner{padding:0 0 var(--space-xl) calc(var(--space-xl) + 35px)}.timeline__description{color:var(--text-muted);margin-bottom:var(--space-lg);font-size:.9375rem;line-height:1.7}.timeline__highlights{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;list-style:none;display:flex}.timeline__highlights li{padding-left:var(--space-lg);color:var(--text);font-size:.875rem;line-height:1.5;position:relative}.timeline__highlights li:before{content:"";background:var(--accent);width:6px;height:1px;position:absolute;top:.55em;left:0}.timeline__tech{gap:var(--space-sm);flex-wrap:wrap;display:flex}@media (width>=768px){.timeline__header{padding-left:var(--space-2xl)}.timeline__content-inner{padding-left:calc(var(--space-2xl) + 35px)}}@media (prefers-reduced-motion:reduce){.timeline__pulse{animation:none}}.awards{background:var(--surface);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.awards .section-header{margin-top:var(--space-md);margin-bottom:var(--space-3xl)}.awards__grid{gap:var(--space-lg);margin-bottom:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.awards__featured{gap:var(--space-2xl);padding:var(--space-2xl);margin-bottom:var(--space-2xl);background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:grid}.awards__featured-badge{padding:var(--space-lg);border-radius:var(--radius-md);background:#fff;justify-content:center;align-items:center;display:flex}.awards__featured-image{width:100%;max-width:520px;height:auto}.awards__featured-meta{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.awards__issuer{color:var(--text-muted);font-size:.8125rem}.awards__featured-title{font-family:var(--font-sans);letter-spacing:-.02em;margin-bottom:var(--space-md);font-size:1.5rem;font-weight:600}.awards__featured-desc{color:var(--text-muted);margin-bottom:var(--space-lg);max-width:56ch;font-size:1rem;font-weight:300;line-height:1.65}.awards__card{padding:var(--space-xl);background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--duration-fast)}.awards__card:hover{border-color:var(--border)}.awards__card-header{justify-content:space-between;align-items:baseline;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.awards__year{font-family:var(--font-sans);color:var(--accent);font-size:.875rem;font-weight:600}.awards__card-title{font-family:var(--font-sans);margin-bottom:var(--space-sm);font-size:1.125rem;font-weight:600;line-height:1.25}.awards__card-desc{color:var(--text-muted);font-size:.875rem;font-weight:300;line-height:1.6}.awards__link{align-items:center;gap:var(--space-sm);color:var(--accent);margin-top:var(--space-md);transition:color var(--duration-fast), gap var(--duration-normal);font-size:.875rem;font-weight:500;display:inline-flex}.awards__link--sm{margin-top:var(--space-sm);font-size:.8125rem}.awards__link:hover{color:var(--accent-hover);gap:var(--space-md)}@media (width>=768px){.awards__featured{padding:var(--space-2xl) var(--space-3xl);grid-template-columns:auto 1fr;align-items:center}.awards__featured-badge{padding:var(--space-xl)}}@media (width<=540px){.awards__grid{grid-template-columns:1fr}}.hero__inner{gap:var(--space-3xl);display:grid}.hero__label{margin-bottom:var(--space-lg)}.hero__title{font-family:var(--font-sans);letter-spacing:-.04em;margin-bottom:var(--space-xl);font-size:clamp(3.25rem,8.5vw,6rem);font-weight:700;line-height:1.02}.hero__tagline{color:#f4f4f5d9;max-width:38ch;margin-bottom:var(--space-md);font-size:clamp(1.125rem,2.5vw,1.5rem);font-weight:300;line-height:1.55}.hero__location{font-family:var(--font-sans);color:var(--text-subtle);margin-bottom:var(--space-2xl);font-size:.8125rem;font-weight:500}.hero__actions{gap:var(--space-md);flex-wrap:wrap;display:flex}.hero__stats{gap:var(--space-xl) var(--space-2xl);padding:var(--space-2xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#131c2ecc;grid-template-columns:repeat(2,1fr);display:grid}.section{padding:var(--space-4xl) 0}.section-header{margin-bottom:var(--space-3xl);max-width:680px}.section-header--row{gap:var(--space-2xl);align-items:end;max-width:none;display:grid}.section-header .section-label{margin-bottom:var(--space-lg)}.section-desc{margin-top:var(--space-xl);color:var(--text-muted);max-width:52ch;font-size:1.0625rem;font-weight:300;line-height:1.65}.about__grid{gap:var(--space-3xl);display:grid}.about__visual{gap:var(--space-lg);flex-direction:column;display:flex}.about__image-wrap{border-radius:var(--radius-lg);aspect-ratio:4/5;position:relative;overflow:hidden}.about__image{object-fit:cover;width:100%;height:100%}.about__image-accent{border:1px solid var(--accent-border);border-radius:var(--radius-lg);pointer-events:none;position:absolute;inset:0}.about__image-caption{align-items:baseline;gap:var(--space-md);padding:var(--space-lg);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex}.about__image-years{font-family:var(--font-sans);color:var(--accent);font-size:2rem;font-weight:700;line-height:1}.about__image-caption-text{color:var(--text-muted);font-size:.875rem;line-height:1.4}.about__content{gap:var(--space-2xl);flex-direction:column;display:flex}.about__text{gap:var(--space-xl);color:var(--text-muted);flex-direction:column;font-size:1.0625rem;font-weight:300;line-height:1.8;display:flex}.about__closing{color:var(--text);font-weight:400}.about__skills{gap:var(--space-xl);padding:var(--space-2xl);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;display:flex}.about__skill-label{font-family:var(--font-sans);letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);margin-bottom:var(--space-md);font-size:.6875rem;font-weight:600}.about__skill-tags{gap:var(--space-sm);flex-wrap:wrap;display:flex}.about__edu-title{margin-bottom:var(--space-xs);font-weight:500}.about__edu-detail{color:var(--text-muted);font-size:.875rem}.experience{background:var(--surface);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.experience__photos{flex-shrink:0;width:200px;height:120px;display:none;position:relative}.experience__photo{object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--surface);width:120px;height:80px;position:absolute;box-shadow:0 8px 24px #0000004d}.experience__photo--1{z-index:2;top:0;left:0;transform:rotate(-3deg)}.experience__photo--2{z-index:1;bottom:0;right:0;transform:rotate(4deg)}.contact__inner{gap:var(--space-3xl);display:grid}.contact__desc{margin-top:var(--space-xl);color:var(--text-muted);max-width:48ch;font-size:1.0625rem;font-weight:300;line-height:1.65}.contact__actions{gap:var(--space-lg);flex-direction:column;display:flex}.contact__email{font-family:var(--font-sans);width:fit-content;font-size:.9375rem;font-weight:500}.contact__links{gap:var(--space-md);flex-wrap:wrap;display:flex}.contact__reference{padding:var(--space-2xl);background:var(--surface);border:1px solid var(--border-subtle);border-left:3px solid var(--accent);border-radius:var(--radius-md);max-width:520px}.contact__reference p{font-family:var(--font-sans);margin-bottom:var(--space-lg);font-size:1.25rem;font-style:italic;font-weight:400;line-height:1.5}.contact__reference footer{flex-direction:column;gap:2px;font-size:.875rem;display:flex}.contact__reference cite{font-style:normal;font-weight:500}.contact__reference span{color:var(--text-muted)}@media (width>=768px){.hero__inner{align-items:end;gap:var(--space-4xl);grid-template-columns:1.15fr 1fr}.hero__stats{padding:var(--space-2xl) var(--space-3xl);grid-template-columns:1fr 1fr}.about__grid{gap:var(--space-4xl);grid-template-columns:.85fr 1.15fr;align-items:start}.section-header--row{grid-template-columns:1fr auto}.experience__photos{display:block}}@media (width>=1024px){.hero__stats{gap:var(--space-2xl) var(--space-3xl)}.contact__inner{grid-template-columns:1fr auto;align-items:start}.contact__reference{grid-column:1/-1}}.not-found{min-height:calc(100vh - var(--nav-height));text-align:center;justify-content:center;align-items:center;display:flex}.not-found__inner{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.not-found__title{font-family:var(--font-sans);font-size:clamp(2rem,5vw,3rem);font-weight:700}.not-found__desc{color:var(--text-muted);max-width:36ch}.project-page{padding-bottom:var(--space-4xl)}.project-hero{min-height:calc((100vh - var(--nav-height)) * .5);padding:var(--space-2xl) 0 var(--space-3xl);align-items:center;display:flex;position:relative;overflow:hidden}.project-hero__inner{z-index:1;width:100%;padding-top:var(--space-lg);padding-bottom:var(--space-lg);position:relative}.project-hero__media{position:absolute;inset:0}.project-hero__image{object-fit:cover;object-position:center;width:100%;height:100%}.project-hero__overlay{opacity:.72;mix-blend-mode:multiply;position:absolute;inset:0;background:linear-gradient(to bottom, #0c122033 0%, #0c1220d9 70%, var(--bg) 100%)!important}.project-hero__grid{background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 30%,#0000 90%);mask-image:linear-gradient(#000 30%,#0000 90%)}.project-hero__back{align-items:center;gap:var(--space-sm);color:#ffffffb3;margin-bottom:var(--space-3xl);transition:color var(--duration-fast);font-size:.875rem;display:inline-flex}.project-hero__back:hover{color:#fff}.project-hero__meta{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.project-hero__year{font-family:var(--font-sans);color:#ffffff80;font-size:.75rem;font-weight:500}.project-hero__title{font-family:var(--font-sans);letter-spacing:-.035em;margin-bottom:var(--space-md);font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.08}.project-hero__tagline{color:#ffffffbf;max-width:48ch;margin-bottom:var(--space-sm);font-size:clamp(1.125rem,2vw,1.375rem)}.project-hero__role{font-family:var(--font-sans);color:var(--accent);font-size:.8125rem;font-weight:600}.project-metrics{background:var(--surface);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-2xl)}.project-metrics__inner{gap:var(--space-xl) var(--space-2xl);padding:var(--space-2xl) 0;grid-template-columns:repeat(2,1fr);display:grid}.project-metrics__item{gap:var(--space-xs);flex-direction:column;display:flex}.project-metrics__value{font-family:var(--font-sans);color:var(--accent);font-size:1.75rem;font-weight:700}.project-metrics__label{color:var(--text-muted);font-size:.8125rem}.project-body{padding:var(--space-5xl) 0 var(--space-5xl);margin-top:var(--space-xl)}.project-body__grid{gap:var(--space-4xl);align-items:start;display:grid}.project-body__main{gap:var(--space-3xl);flex-direction:column;display:flex}.project-summary{color:var(--text-muted);max-width:65ch;padding-bottom:var(--space-2xl);border-bottom:1px solid var(--border-subtle);font-size:1.3125rem;font-weight:300;line-height:1.75}.project-section{padding-top:var(--space-md)}.project-section+.project-section{padding-top:var(--space-2xl);border-top:1px solid var(--border-subtle)}.project-section__title{font-family:var(--font-sans);margin-bottom:var(--space-lg);letter-spacing:-.01em;font-size:1.75rem;font-weight:600}.project-section__body{color:var(--text-muted);margin-bottom:var(--space-lg);max-width:65ch;font-size:1rem;line-height:1.75}.project-section__link{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);color:var(--accent);transition:color var(--duration-fast), gap var(--duration-normal) var(--ease-out);font-size:.9375rem;font-weight:500;display:inline-flex}.project-section__link:hover{color:var(--accent-hover);gap:var(--space-md)}.project-section__list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.project-section__list li{padding-left:var(--space-lg);font-size:.9375rem;line-height:1.6;position:relative}.project-section__list li:before{content:"";background:var(--accent);width:8px;height:1px;position:absolute;top:.6em;left:0}.project-gallery{padding-top:var(--space-3xl);margin-top:var(--space-lg);border-top:1px solid var(--border-subtle)}.project-gallery__note{color:var(--text-subtle);margin-bottom:var(--space-lg);font-size:.875rem}.project-gallery__grid{gap:var(--space-lg);display:grid}.project-gallery__item{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);margin:0;overflow:hidden}.project-gallery__item--hero{aspect-ratio:21/9}.project-gallery__item:not(.project-gallery__item--hero){aspect-ratio:16/10}.project-gallery__image{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out);display:block}.project-gallery__item:hover .project-gallery__image{transform:scale(1.03)}.project-sidebar__cover{padding:0;overflow:hidden}.project-sidebar__cover-image{aspect-ratio:16/10;object-fit:cover;width:100%;display:block}.project-sidebar{gap:var(--space-xl);flex-direction:column;display:flex}.project-sidebar__block{padding:var(--space-xl);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.project-sidebar__label{font-family:var(--font-sans);letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);margin-bottom:var(--space-md);font-size:.6875rem;font-weight:600}.project-sidebar__highlights{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.project-sidebar__highlights li{padding-left:var(--space-md);font-size:.875rem;line-height:1.5;position:relative}.project-sidebar__highlights li:before{content:"→";color:var(--accent);font-size:.75rem;position:absolute;left:0}.project-sidebar__tech{gap:var(--space-sm);flex-wrap:wrap;display:flex}.project-sidebar__cta-text{color:var(--text-muted);margin-bottom:var(--space-md);font-size:.875rem}.project-sidebar__cta{width:100%}.project-nav{border-top:1px solid var(--border-subtle);padding:var(--space-3xl) 0;margin-top:var(--space-xl)}.project-nav__inner{gap:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.project-nav__link{gap:var(--space-sm);padding:var(--space-xl);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--duration-fast), transform var(--duration-fast);flex-direction:column;display:flex}.project-nav__link:hover{border-color:var(--border);transform:translateY(-1px)}.project-nav__link--next{text-align:right}.project-nav__direction{font-family:var(--font-sans);letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);font-size:.6875rem;font-weight:600}.project-nav__title{font-family:var(--font-sans);font-size:1.125rem;font-weight:600}@media (width>=768px){.project-hero{padding:var(--space-3xl) 0}.project-hero__back{margin-bottom:var(--space-2xl)}.project-metrics{margin-bottom:var(--space-3xl)}.project-metrics__inner{padding:var(--space-3xl) 0;grid-template-columns:repeat(4,1fr)}.project-body{padding-top:var(--space-5xl);margin-top:var(--space-2xl)}.project-gallery__grid{grid-template-columns:repeat(2,1fr)}.project-gallery__item:first-child{grid-column:span 2}}@media (width>=1024px){.project-body__grid{gap:var(--space-5xl);grid-template-columns:1fr 340px}.project-body__main{gap:var(--space-4xl)}.project-sidebar{top:calc(var(--nav-height) + var(--space-2xl));gap:var(--space-xl);position:sticky}}:root{--bg:#0c1220;--surface:#131c2e;--surface-raised:#1a2740;--surface-hover:#223352;--border:#2d3f5c;--border-subtle:#1e2d45;--text:#e8eef7;--text-muted:#8fa3bf;--text-subtle:#5c7291;--accent:#4d9fff;--accent-dim:#2f7fd4;--accent-hover:#6db1ff;--accent-glow:#4d9fff1f;--accent-border:#4d9fff47;--success:#34d399;--danger:#f87171;--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-display:var(--font-sans);--font-body:var(--font-sans);--font-mono:var(--font-sans);--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:5rem;--space-4xl:7rem;--space-5xl:9rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--max-width:1240px;--nav-height:72px;--ticker-height:40px;--ease-out:cubic-bezier(.16, 1, .3, 1);--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.6s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:1rem;font-weight:400;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(80% 50% at 50% -20%,#4d9fff12,#0000),radial-gradient(60% 40% at 100% 100%,#2d3f5c33,#0000);position:fixed;inset:0}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}img{max-width:100%;display:block}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}::selection{background:var(--accent-glow);color:var(--text)}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}@media (width>=768px){.container{padding:0 var(--space-xl)}}.section-label{font-family:var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:.6875rem;font-weight:600}.section-title{font-family:var(--font-sans);letter-spacing:-.03em;font-size:clamp(2.125rem,5vw,3.25rem);font-weight:600;line-height:1.12}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font-sans);border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-out);white-space:nowrap;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{color:var(--text);border:1px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--text-muted);background:var(--surface-raised)}.btn-ghost{color:var(--text-muted);padding:.5rem .75rem}.btn-ghost:hover{color:var(--text)}.tag{font-family:var(--font-sans);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);align-items:center;padding:.25rem .625rem;font-size:.6875rem;font-weight:600;display:inline-flex}.tag-accent{color:var(--accent);border-color:var(--accent-border);background:var(--accent-glow)}.divider{background:var(--border-subtle);border:none;height:1px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page-enter{animation:pageEnter var(--duration-slow) var(--ease-out) forwards}@keyframes pageEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes countPulse{0%,to{opacity:1}50%{opacity:.7}}
