﻿:root{--color-bg: #FFFFFF;--color-surface: #F7F7F7;--color-text: #1A1A1A;--color-accent: #E8503A;--color-muted: #6b7280;--color-border: #CCCCCC;--font-serif: 'Jost', sans-serif;--font-sans: 'Jost', sans-serif;--space-xs: 0.25rem;--space-sm: 0.5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 5rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--transition: 0.25s ease;--transition-slow: 0.5s ease;--container-max: 1200px;--container-pad: var(--space-lg)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.7;font-weight:300;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);line-height:1.2;font-weight:400}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,3.5vw,2.5rem)}h3{font-size:clamp(1.125rem,2.5vw,1.5rem)}h4{font-size:1.125rem}p{color:var(--color-muted);max-width:65ch}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--color-text)}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}::selection{background-color:var(--color-accent);color:#fff}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--space-md) 0;transition:background-color var(--transition),box-shadow var(--transition)}.site-header.is-scrolled{background-color:hsla(0,0%,100%,.95);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--color-border)}.site-header .container{display:flex;align-items:center;justify-content:space-between}.site-header__logo{display:flex;align-items:center;text-decoration:none}.site-header__logo img{width:36px;height:36px;display:block}.site-header__logo:hover{opacity:.8}.site-nav__list{display:flex;align-items:center;gap:var(--space-xl)}.site-nav__link{font-size:.875rem;font-weight:500;color:var(--color-muted);letter-spacing:.05em;text-transform:uppercase;transition:color var(--transition);position:relative}.site-nav__link::after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background-color:var(--color-accent);transition:width var(--transition)}.site-nav__link:hover,.site-nav__link.is-active{color:var(--color-text)}.site-nav__link:hover::after,.site-nav__link.is-active::after{width:100%}.site-nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:4px;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:none}.site-nav__toggle span{display:block;width:100%;height:1.5px;background-color:var(--color-text);transition:transform var(--transition),opacity var(--transition);transform-origin:center}.site-nav__toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.site-nav__toggle.is-open span:nth-child(2){opacity:0}.site-nav__toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.site-main{padding-top:80px}.page-hero{padding:var(--space-3xl) 0 var(--space-2xl);border-bottom:1px solid var(--color-border)}.page-hero__label{font-size:.8rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-md)}.page-hero__title{margin-bottom:var(--space-lg);color:var(--color-text)}.page-hero__desc{font-size:1.125rem;line-height:1.7;max-width:55ch}.section{padding:var(--space-3xl) 0}.section__header{margin-bottom:var(--space-2xl)}.section__label{font-size:.8rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-sm)}.section__title{color:var(--color-text);margin-bottom:var(--space-md)}.section__desc{font-size:1rem;max-width:55ch}.site-footer{padding:var(--space-2xl) 0;border-top:1px solid var(--color-border);margin-top:var(--space-3xl)}.site-footer .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md)}.site-footer__copy{font-size:.875rem;color:var(--color-muted)}.site-footer__links{display:flex;gap:var(--space-lg)}.site-footer__links a{font-size:.875rem;color:var(--color-muted)}.site-footer__links a:hover{color:var(--color-text)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;letter-spacing:.03em;border-radius:var(--radius-md);transition:all var(--transition);text-decoration:none;cursor:pointer;white-space:nowrap}.btn--primary{background-color:var(--color-accent);color:#fff;border:1px solid rgba(0,0,0,0)}.btn--primary:hover{background-color:#c93d28;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,80,58,.35)}.btn--outline{background-color:rgba(0,0,0,0);color:var(--color-text);border:1px solid var(--color-border)}.btn--outline:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}.btn--ghost{background-color:rgba(0,0,0,0);color:var(--color-accent);border:1px solid rgba(0,0,0,0);padding-inline:var(--space-sm)}.btn--ghost:hover{color:var(--color-text)}.badge{display:inline-block;padding:.2rem .6rem;font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;border-radius:100px;background-color:rgba(232,80,58,.1);color:var(--color-accent);border:1px solid rgba(232,80,58,.25)}.project-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.4);border-color:rgba(232,80,58,.4)}.project-card__img{width:100%;height:200px;object-fit:cover;object-position:top center;display:block;border-bottom:1px solid var(--color-border)}.project-card__img-placeholder{width:100%;height:200px;background:linear-gradient(135deg, rgba(91, 108, 240, 0.08), rgba(91, 108, 240, 0.02));display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--color-border);color:var(--color-muted);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase}.project-card__img-placeholder::before{content:"[ image ]"}.project-card__body{padding:var(--space-lg);flex:1;display:flex;flex-direction:column;gap:var(--space-sm)}.project-card__meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.project-card__title{font-family:var(--font-serif);font-size:1.125rem;color:var(--color-text);line-height:1.3}.project-card__stack{font-size:.85rem;font-weight:500;color:var(--color-muted);font-family:var(--font-sans);letter-spacing:.02em}.project-card__desc{font-size:.9rem;line-height:1.6;color:var(--color-muted);flex:1;max-width:none}.project-card__footer{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.project-card__link{font-size:.8rem;font-weight:600;color:var(--color-accent);display:flex;align-items:center;gap:4px;transition:gap var(--transition),color var(--transition)}.project-card__link::after{content:"→"}.project-card__link:hover{color:var(--color-text);gap:8px}.project-card[hidden]{display:none}.project-card.is-hidden{display:none}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:var(--space-xl)}.filter-bar{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-2xl)}.filter-bar__btn{padding:.5rem 1rem;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--color-border);border-radius:100px;color:var(--color-muted);background-color:rgba(0,0,0,0);transition:all var(--transition);cursor:pointer}.filter-bar__btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.filter-bar__btn.is-active{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));gap:var(--space-lg)}.skills-category{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.skills-category__title{font-family:var(--font-sans);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-md)}.skills-category__items{display:flex;flex-direction:column;gap:var(--space-sm)}.skills-category__item{font-size:.9rem;color:var(--color-text);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-sm)}.skills-category__item:last-child{border-bottom:none}.skills-category__item::before{content:"";width:6px;height:6px;border-radius:50%;background-color:var(--color-accent);flex-shrink:0}.timeline{display:flex;flex-direction:column;gap:0;position:relative}.timeline::before{content:"";position:absolute;left:120px;top:0;bottom:0;width:1px;background-color:var(--color-border)}.timeline__item{display:grid;grid-template-columns:120px 1fr;gap:var(--space-xl);padding:var(--space-xl) 0;position:relative}.timeline__item::before{content:"";position:absolute;left:120px;top:calc(var(--space-xl) + .4rem);width:9px;height:9px;border-radius:50%;background-color:var(--color-accent);transform:translateX(-4px);box-shadow:0 0 0 3px rgba(232,80,58,.2)}.timeline__date{font-size:.8rem;font-weight:600;color:var(--color-accent);text-align:right;padding-top:.15rem;letter-spacing:.03em}.timeline__content{padding-left:var(--space-xl)}.timeline__content h3{font-family:var(--font-sans);font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:var(--space-xs)}.timeline__content .timeline__org{font-size:.85rem;color:var(--color-accent);margin-bottom:var(--space-sm);max-width:none}.timeline__content p{font-size:.875rem;line-height:1.6;max-width:55ch}.contact-form{display:flex;flex-direction:column;gap:var(--space-lg)}.contact-form__group{display:flex;flex-direction:column;gap:var(--space-xs)}.contact-form__label{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.contact-form__input,.contact-form__textarea{width:100%;padding:.875rem var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition)}.contact-form__input::placeholder,.contact-form__textarea::placeholder{color:var(--color-muted);opacity:.6}.contact-form__input:focus,.contact-form__textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(232,80,58,.15)}.contact-form__input.is-error,.contact-form__textarea.is-error{border-color:#e05b5b}.contact-form__textarea{resize:vertical;min-height:160px;line-height:1.6}.contact-form__error{font-size:.75rem;color:#e05b5b;display:none}.contact-form__error.is-visible{display:block}.contact-form__submit{align-self:flex-start}.contact-aside{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl)}.contact-aside__title{font-family:var(--font-sans);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-lg)}.contact-aside__items{display:flex;flex-direction:column;gap:var(--space-lg)}.contact-aside__item{display:flex;flex-direction:column;gap:var(--space-xs)}.contact-aside__item-label{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.contact-aside__item-value{font-size:.95rem;color:var(--color-text);text-decoration:none;transition:color var(--transition)}.contact-aside__item-value:hover{color:var(--color-accent)}.hero{min-height:calc(100vh - 80px);display:flex;align-items:center;padding:var(--space-3xl) 0}.hero__inner{max-width:700px}.hero__label{font-size:.75rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.hero__label::before{content:"";display:block;width:24px;height:1px;background-color:var(--color-accent)}.hero__title{font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:var(--space-xl);color:var(--color-text)}.hero__title em{font-style:normal;color:var(--color-accent)}.hero__desc{font-size:1.125rem;line-height:1.7;margin-bottom:var(--space-2xl);max-width:55ch}.hero__ctas{display:flex;gap:var(--space-md);flex-wrap:wrap}.featured-projects{padding:var(--space-3xl) 0;border-top:1px solid var(--color-border)}.contact-teaser{padding:var(--space-3xl) 0;border-top:1px solid var(--color-border);text-align:center}.contact-teaser__title{color:var(--color-text);margin-bottom:var(--space-md)}.contact-teaser__desc{margin:0 auto var(--space-2xl);font-size:1.125rem}.bio-blocks{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:var(--space-xl);margin-bottom:var(--space-3xl)}.bio-block{padding:var(--space-xl);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.bio-block__icon{font-size:1.5rem;margin-bottom:var(--space-md);display:block}.bio-block__title{font-family:var(--font-sans);font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:var(--space-sm)}.bio-block__text{font-size:.9rem;line-height:1.7;max-width:none}.section-cta{margin-top:var(--space-2xl);display:flex;justify-content:center}@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.reveal{opacity:0;transform:translateY(24px);transition:opacity var(--transition-slow),transform var(--transition-slow)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal--delay-1{transition-delay:.1s}.reveal--delay-2{transition-delay:.2s}.reveal--delay-3{transition-delay:.3s}.reveal--delay-4{transition-delay:.4s}.hero__inner>*{opacity:0;animation:fadeInUp .7s ease forwards}.hero__inner>*:nth-child(1){animation-delay:.1s}.hero__inner>*:nth-child(2){animation-delay:.25s}.hero__inner>*:nth-child(3){animation-delay:.4s}.hero__inner>*:nth-child(4){animation-delay:.55s}@media(prefers-reduced-motion: reduce){.reveal,.hero__inner>*{opacity:1;transform:none;animation:none;transition:none}}@media(max-width: 767px){:root{--container-pad: var(--space-md)}.site-nav__toggle{display:flex}.site-nav__list{position:fixed;top:0;right:0;bottom:0;width:min(280px,85vw);background-color:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;align-items:flex-start;justify-content:center;padding:var(--space-2xl);gap:var(--space-xl);transform:translateX(100%);transition:transform var(--transition-slow);z-index:200}.site-nav__list.is-open{transform:translateX(0)}.site-nav__link{font-size:1.125rem}.hero{min-height:auto;padding:var(--space-2xl) 0 var(--space-3xl)}.timeline::before{left:0}.timeline__item{grid-template-columns:1fr;padding-left:var(--space-xl)}.timeline__item::before{left:0}.timeline__date{text-align:left;padding-top:0}.timeline__content{padding-left:0}.contact-layout{flex-direction:column}.projects-grid{grid-template-columns:1fr}.bio-blocks{grid-template-columns:1fr}.site-footer .container{flex-direction:column;align-items:flex-start}}@media(min-width: 768px){:root{--container-pad: var(--space-xl)}.projects-grid{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){:root{--container-pad: var(--space-2xl)}.projects-grid{grid-template-columns:repeat(3, 1fr)}.contact-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--space-2xl);align-items:start}}@media(min-width: 1440px){.hero__inner{max-width:800px}}@media(max-width: 320px){h1{font-size:1.75rem}h2{font-size:1.375rem}.hero__ctas{flex-direction:column}.hero__ctas .btn{width:100%;justify-content:center}}
