*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--color-bg-primary:#15160f;--color-bg-secondary:#1b1c14;--color-bg-tertiary:#22261e;--color-bg-elevated:#2b3335;--color-bg-surface:rgba(255, 255, 255, 0.025);--color-bg-surface-hover:rgba(255, 255, 255, 0.05);--color-accent-warm:#d4b96e;--color-accent-warm-hover:#e2ca82;--color-accent-warm-muted:rgba(212, 185, 110, 0.14);--color-accent-cool:#6a868b;--color-accent-cool-hover:#7d9ca1;--color-accent-cool-muted:rgba(106, 134, 139, 0.12);--color-text-primary:#e4dfd4;--color-text-secondary:#9a9688;--color-text-tertiary:#636058;--color-text-inverse:#15160f;--color-border:rgba(255, 255, 255, 0.06);--color-border-hover:rgba(255, 255, 255, 0.12);--color-border-accent:rgba(106, 134, 139, 0.25);--color-success:#8a9e8f;--color-error:#b87070;--color-warning:#d4b96e;--color-nav-scrolled:rgba(21, 22, 15, 0.55);--shadow-sm:0 1px 2px rgba(0, 0, 0, 0.3);--shadow-md:0 4px 12px rgba(0, 0, 0, 0.4);--shadow-lg:0 8px 30px rgba(0, 0, 0, 0.5);--shadow-xl:0 16px 50px rgba(0, 0, 0, 0.6);--shadow-glow-warm:0 0 30px rgba(212, 185, 110, 0.10);--shadow-glow-cool:0 0 30px rgba(106, 134, 139, 0.08)}[data-theme=light]{--color-bg-primary:#f2f0e8;--color-bg-secondary:#f9f7f1;--color-bg-tertiary:#e6e3da;--color-bg-elevated:#fdfcf9;--color-bg-surface:rgba(0, 0, 0, 0.02);--color-bg-surface-hover:rgba(0, 0, 0, 0.04);--color-accent-warm:#15160f;--color-accent-warm-hover:#1f2a22;--color-accent-warm-muted:rgba(21, 22, 15, 0.08);--color-accent-cool:#15160f;--color-accent-cool-hover:#1f2a22;--color-accent-cool-muted:rgba(21, 22, 15, 0.06);--color-text-primary:#1c1d16;--color-text-secondary:#555348;--color-text-tertiary:#85827a;--color-text-inverse:#f9f7f1;--color-border:rgba(0, 0, 0, 0.07);--color-border-hover:rgba(0, 0, 0, 0.13);--color-border-accent:rgba(72, 101, 106, 0.25);--color-success:#6a8a70;--color-error:#a86055;--color-warning:#9e8840;--color-nav-scrolled:rgba(242, 240, 232, 0.55);--shadow-sm:0 1px 3px rgba(0, 0, 0, 0.05);--shadow-md:0 4px 12px rgba(0, 0, 0, 0.07);--shadow-lg:0 8px 30px rgba(0, 0, 0, 0.09);--shadow-xl:0 16px 50px rgba(0, 0, 0, 0.11);--shadow-glow-warm:0 0 30px rgba(158, 136, 64, 0.08);--shadow-glow-cool:0 0 30px rgba(72, 101, 106, 0.08)}:root{--font-heading:'Space Grotesk', system-ui, sans-serif;--font-body:'Inter', system-ui, sans-serif;--font-mono:'JetBrains Mono', monospace;--text-xs:clamp(0.7rem, 0.65rem + 0.2vw, 0.8rem);--text-sm:clamp(0.8rem, 0.75rem + 0.25vw, 0.9rem);--text-base:clamp(0.9rem, 0.85rem + 0.3vw, 1rem);--text-lg:clamp(1rem, 0.9rem + 0.5vw, 1.2rem);--text-xl:clamp(1.2rem, 1rem + 0.8vw, 1.5rem);--text-2xl:clamp(1.5rem, 1.2rem + 1.2vw, 2rem);--text-3xl:clamp(2rem, 1.5rem + 2vw, 3rem);--text-4xl:clamp(2.5rem, 1.8rem + 3vw, 4rem);--text-5xl:clamp(3rem, 2rem + 4vw, 5.5rem);--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--leading-tight:1.1;--leading-snug:1.25;--leading-normal:1.5;--leading-relaxed:1.7;--tracking-tight:-0.03em;--tracking-normal:0;--tracking-wide:0.05em;--tracking-wider:0.1em;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-2xl:48px;--radius-full:9999px;--ease-out-expo:cubic-bezier(0.16, 1, 0.3, 1);--ease-out-quart:cubic-bezier(0.25, 1, 0.5, 1);--ease-in-out:cubic-bezier(0.65, 0, 0.35, 1);--ease-spring:cubic-bezier(0.34, 1.56, 0.64, 1);--duration-fast:150ms;--duration-normal:300ms;--duration-slow:500ms;--duration-slower:800ms;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1200px;--container-2xl:1400px;--nav-height:72px}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow-x:hidden;transition:background-color .5s var(--ease-out-quart),color .5s var(--ease-out-quart)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:0 0}ul,ol{list-style:none}.container{width:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.section{padding:var(--space-24)0}.section-heading{margin-bottom:var(--space-12)}.section-heading__label{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent-warm);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-4)}.section-heading__label::before{content:'';width:24px;height:1px;background:var(--color-accent-warm)}.section-heading__title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-primary)}.section-heading__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);margin-top:var(--space-4);max-width:600px}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);border-bottom:1px solid transparent;transition:background var(--duration-normal)var(--ease-out-quart),border-color var(--duration-normal)var(--ease-out-quart)}.navbar.scrolled{background:var(--color-nav-scrolled);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom-color:var(--color-border)}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding-top:4px;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.navbar__logo{display:flex;align-items:center;color:var(--color-text-primary);position:relative;padding-bottom:var(--space-2)}.navbar__logo::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-accent-warm);transition:width var(--duration-normal)var(--ease-out-expo)}.navbar__logo:hover::after{width:100%}.navbar__logo-svg{height:40px;width:auto;color:var(--color-text-primary)}.footer__logo{display:inline-flex;align-items:center;vertical-align:middle}.footer__logo .navbar__logo-svg{height:20px;margin:0 var(--space-1)}.navbar__links{display:flex;align-items:center;gap:var(--space-8)}.navbar__link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);letter-spacing:var(--tracking-wide);text-transform:uppercase;position:relative;padding:var(--space-2)0;transition:color var(--duration-fast)var(--ease-out-quart)}.navbar__link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-accent-warm);transition:width var(--duration-normal)var(--ease-out-expo)}.navbar__link:hover,.navbar__link--active{color:var(--color-text-primary)}.navbar__link:hover::after,.navbar__link--active::after{width:100%}.navbar__contact-btn{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text-inverse);background:var(--color-accent-warm);padding:var(--space-2)var(--space-6);border-radius:var(--radius-full);letter-spacing:var(--tracking-wide);text-transform:uppercase;transition:background var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.navbar__contact-btn:hover{background:var(--color-accent-warm-hover);transform:translateY(-1px)}.navbar__menu-toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-2);z-index:1001}.navbar__menu-toggle span{display:block;width:24px;height:2px;background:var(--color-text-primary);transition:transform var(--duration-normal)var(--ease-out-expo),opacity var(--duration-fast)}.navbar__menu-toggle.open span:nth-child(1){transform:rotate(45deg)translate(5px,5px)}.navbar__menu-toggle.open span:nth-child(2){opacity:0}.navbar__menu-toggle.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--duration-fast)var(--ease-out-quart),background var(--duration-fast)var(--ease-out-quart),color var(--duration-fast)var(--ease-out-quart)}.theme-toggle:hover{border-color:var(--color-border-hover);background:var(--color-bg-surface-hover);color:var(--color-text-primary)}.theme-toggle__icon{width:18px;height:18px;transition:opacity var(--duration-normal)var(--ease-out-quart),transform var(--duration-normal)var(--ease-out-expo)}.theme-toggle__icon--sun{display:block}.theme-toggle__icon--moon{display:none}[data-theme=light] .theme-toggle__icon--sun{display:none}[data-theme=light] .theme-toggle__icon--moon{display:block}.hero{min-height:calc(85vh - var(--nav-height));display:flex;align-items:center;position:relative;overflow:hidden;padding:var(--space-24)0}.is-home .hero::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:128px 128px;opacity:.04;pointer-events:none;z-index:1;mix-blend-mode:overlay}.is-home .hero{background:linear-gradient( 180deg,#f2f0e8 0%,#eae7dd 15%,#dddad0 25%,#c8d0c5 40%,#a8b5aa 55%,#d4c99d 68%,#e9d491 78%,#d8d1b8 88%,#c5cbc6 100% );background-size:100% 300%;animation:heroGradientDrift 30s ease-in-out infinite alternate}@keyframes heroGradientDrift{0%{background-position:50% 0}100%{background-position:50% 100%}}.hero__bg{position:absolute;top:0;right:0;width:50%;height:100%;background:linear-gradient(135deg,var(--color-accent-cool-muted),var(--color-accent-warm-muted));opacity:.4;border-radius:0 0 0 40%;pointer-events:none;will-change:transform;transition:transform .1s linear}.is-home .hero__bg{display:none}.hero__content{position:relative;z-index:2;max-width:700px}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent-warm);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-8)}.hero__badge-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent-warm);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero__title{font-family:var(--font-heading);font-size:var(--text-5xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-primary);margin-bottom:var(--space-4)}.hero__title-accent{color:var(--color-accent-warm)}.hero__title-muted{color:var(--color-text-primary)}.hero__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:500px;margin-bottom:var(--space-10)}.hero__actions{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.is-home .hero__badge{color:#15160f}.is-home .hero__badge-dot{background:#15160f}.is-home .hero__title{color:#1c1d16}.is-home .hero__title-accent{color:#15160f}.is-home .hero__title-muted{color:#1c1d16}.is-home .hero__subtitle{color:#555348}.is-home .hero .btn-primary{background:#15160f;color:#f2f0e8}.is-home .hero .btn-primary:hover{background:#1f2a22}.is-home .hero .btn-secondary{color:#1c1d16;border-color:rgba(0,0,0,.12)}.is-home .hero .btn-secondary:hover{border-color:rgba(0,0,0,.25)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4)var(--space-8);text-align:center;background:var(--color-accent-warm);color:var(--color-text-inverse);font-weight:var(--weight-semibold);font-size:var(--text-sm);letter-spacing:var(--tracking-wide);border-radius:var(--radius-full);transition:background var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.btn-primary:hover{background:var(--color-accent-warm-hover);transform:translateY(-2px)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-4)var(--space-8);background:0 0;color:var(--color-text-primary);font-weight:var(--weight-medium);font-size:var(--text-base);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:border-color var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.btn-secondary:hover{border-color:var(--color-border-hover);transform:translateY(-2px)}.hero__stats{display:flex;gap:var(--space-12);margin-top:var(--space-16);padding-top:var(--space-10);border-top:1px solid var(--color-border)}.hero__stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary)}.hero__stat-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-top:var(--space-1)}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.project-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:transform 200ms ease-out,outline-color 200ms ease-out,border-color 200ms ease-out;outline:1px solid transparent;outline-offset:-1px;display:flex;flex-direction:column}.project-card__link,.project-card__inner{flex:1}.project-card:hover{transform:translateY(-8px);outline-color:var(--color-border-hover);border-color:var(--color-border-hover)}.project-card:hover .project-card__image img{transform:scale(1.03)}.project-card__image img{transition:transform .5s var(--ease-out-expo)}.project-card__image{width:100%;aspect-ratio:16/10;object-fit:cover;overflow:hidden;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);font-family:var(--font-mono);font-size:var(--text-sm)}.project-card__image img{width:100%;height:100%;object-fit:cover}.project-card__body{padding:var(--space-6)}.project-card__category{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent-warm);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-2)}.project-card__title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.project-card__tagline{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);height:48px;overflow:hidden}.project-card__image--locked{position:relative}.project-card__lock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-tertiary)}.project-card__lock svg{width:24px;height:24px}.project-card__password{width:200px;padding:8px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--text-sm);font-family:var(--font-sans);text-align:center;outline:none;transition:border-color 200ms ease}.project-card__password:focus{border-color:var(--color-text-tertiary)}.project-card__password.shake{animation:shake 400ms ease}@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}.project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:0 var(--space-6)var(--space-6)}.project-card__tag{font-size:var(--text-xs);color:var(--color-text-tertiary);background:var(--color-bg-surface);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);border:1px solid var(--color-border);text-decoration:none;transition:border-color var(--duration-fast)var(--ease-out-quart),color var(--duration-fast)var(--ease-out-quart)}a.project-card__tag:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.category-filter{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-10)}.category-filter__btn{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);padding:var(--space-2)var(--space-5);border-radius:var(--radius-full);border:1px solid var(--color-border);background:0 0;transition:all var(--duration-fast)var(--ease-out-quart)}.category-filter__btn:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.category-filter__btn--active{background:var(--color-accent-warm);color:var(--color-text-inverse);border-color:var(--color-accent-warm)}.tag-filter{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-10)}.tag-filter__btn{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);padding:var(--space-2)var(--space-5);border-radius:var(--radius-full);border:1px solid var(--color-border);background:0 0;transition:all var(--duration-fast)var(--ease-out-quart)}.tag-filter__btn:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.tag-filter__btn--active{background:var(--color-accent-warm);color:var(--color-text-inverse);border-color:var(--color-accent-warm)}.cta{text-align:center;padding:var(--space-24)0}.contact-page{padding:var(--space-24)0}.cta__title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-4)}.cta__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:500px;margin:0 auto var(--space-10)}.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}.about-intro__image{aspect-ratio:3/4;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-bg-tertiary)}.about-intro__image img{width:100%;height:100%;object-fit:cover}.about-intro__title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-6)}.about-intro__bio{font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.about-intro__bio p+p{margin-top:var(--space-4)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.skill-tag{padding:var(--space-3)var(--space-5);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);text-align:center;transition:border-color var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.skill-tag:hover{border-color:var(--color-accent-warm);transform:translateY(-2px)}.timeline{position:relative;padding-left:var(--space-10)}.timeline::before{content:'';position:absolute;left:4px;top:0;bottom:0;width:1px;background:var(--color-border)}.timeline__item{position:relative;padding-bottom:var(--space-10)}.timeline__item:last-child{padding-bottom:0}.timeline__dot{position:absolute;left:calc(-1 * var(--space-10) + 1px);top:6px;width:8px;height:8px;border-radius:50%;background:var(--color-text-tertiary);border:2px solid var(--color-bg-primary)}.timeline__item--current .timeline__dot{background:var(--color-accent-warm);box-shadow:0 0 12px rgba(212,137,26,.4)}.timeline__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-2)}.timeline__role{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.timeline__period{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);letter-spacing:var(--tracking-wide)}.timeline__company{font-size:var(--text-sm);color:var(--color-accent-warm);margin-bottom:var(--space-2)}.timeline__description{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.timeline__bullets{padding-left:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1);list-style:disc}.timeline__bullets li{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);list-style:disc}.timeline__bullets li::marker{color:var(--color-border)}.contact-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-16)}.contact-layout--single{grid-template-columns:1fr;max-width:600px}.contact-info__title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-4)}.contact-info__text{font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-8)}.contact-info__links{display:flex;flex-direction:column;gap:var(--space-4)}.contact-info__link{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--duration-fast)}.contact-info__link:hover{color:var(--color-accent-warm)}.contact-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary)}.form-group input,.form-group textarea{padding:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:border-color var(--duration-fast)var(--ease-out-quart)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent-warm)}.form-group textarea{resize:vertical;min-height:150px}.form-submit{align-self:flex-start}.contact-form__status{font-size:var(--text-sm);margin-top:var(--space-4);min-height:1.5em}.contact-form__status--success{color:#4a8c5c}.contact-form__status--error{color:#c44d4d}.project-detail__header{padding:var(--space-16)0 var(--space-10)}.project-detail__category{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent-warm);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-4)}.project-detail__title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);color:var(--color-text-primary);margin-bottom:var(--space-4)}.project-detail__tagline{font-size:var(--text-xl);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.project-detail__meta{display:flex;gap:var(--space-8);padding:var(--space-6)0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.project-detail__meta-item{display:flex;flex-direction:column;gap:var(--space-1)}.project-detail__meta-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.project-detail__meta-value{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:var(--weight-medium)}.project-detail__content{max-width:800px;margin:var(--space-12)auto;font-size:var(--text-lg);color:var(--color-text-secondary);line-height:var(--leading-relaxed);overflow:visible}.project-detail__content h2{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:var(--space-10)0 var(--space-4)}.project-detail__content p+p{margin-top:var(--space-4)}.project-detail__content ul,.project-detail__content ol{list-style:disc;padding-left:var(--space-6);margin:var(--space-4)0}.project-detail__content ol{list-style:decimal}.project-detail__content hr{display:none}.overview-meta{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin:var(--space-8)0;padding:var(--space-6)0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.overview-meta .meta-item{display:flex;flex-direction:column;gap:4px}.overview-meta .meta-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);opacity:.7}.overview-meta .meta-value{font-size:var(--text-base);color:var(--color-text-primary);line-height:var(--leading-relaxed)}@media(max-width:480px){.overview-meta{grid-template-columns:1fr;gap:var(--space-4)}}.project-detail__content img{display:block;width:calc(100% + 200px);max-width:calc(100vw - 2 * var(--space-6));margin-left:-100px;height:auto;border-radius:var(--radius-xl);margin-top:32px;margin-bottom:32px}.project-detail__content .image-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-top:32px;margin-bottom:32px;width:calc(100% + 200px);max-width:calc(100vw - 2 * var(--space-6));margin-left:-100px;box-sizing:border-box}.project-detail__content .image-grid--2x2{grid-template-columns:1fr 1fr}.project-detail__content .image-grid img{margin:0;border-radius:var(--radius-lg);width:100%;margin-left:0}.project-detail__content .image-full{margin:32px calc(-1 * var(--space-8))}.project-detail__content .image-full img{border-radius:var(--radius-xl);margin:0;transform:none;margin-left:0;width:100%}@media(max-width:768px){.project-detail__content .image-full{margin:32px 0}}.project-detail__nav{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);padding:var(--space-12)0;border-top:1px solid var(--color-border)}.project-detail__nav-link{padding:var(--space-6);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.project-detail__nav-link:hover{border-color:var(--color-border-hover);transform:translateY(-2px)}.project-detail__nav-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-2);display:block}.project-detail__nav-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.project-detail__nav-link--next{text-align:right}.footer{padding:var(--space-12)0;border-top:1px solid var(--color-border)}.footer__inner{display:flex;justify-content:space-between;align-items:center}.footer__copyright{font-size:var(--text-sm);color:var(--color-text-tertiary)}.footer__links{display:flex;gap:var(--space-6)}.footer__link{font-size:var(--text-sm);color:var(--color-text-tertiary);transition:color var(--duration-fast)}.footer__link:hover{color:var(--color-accent-warm)}.reveal{opacity:0;transform:translateY(30px);transition:opacity var(--duration-slower)var(--ease-out-expo),transform var(--duration-slower)var(--ease-out-expo)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:100ms}.reveal-delay-2{transition-delay:200ms}.reveal-delay-3{transition-delay:300ms}.reveal-delay-4{transition-delay:400ms}.project-detail__content img,.project-detail__content .image-grid img{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}.project-detail__content img.visible,.project-detail__content .image-grid img.visible{opacity:1;transform:translateY(0)}.project-detail__content hr{transition:width .8s var(--ease-out-expo);width:0}.project-detail__content hr.visible{width:100%}@media(max-width:768px){.container{padding:0 var(--space-5)}.hero__title{font-size:var(--text-4xl)}.hero__bg{opacity:.3;width:70%}.hero__actions{flex-direction:column;align-items:flex-start}.hero__stats{flex-direction:column;gap:var(--space-6)}.project-grid{grid-template-columns:1fr}.about-intro{grid-template-columns:1fr;gap:var(--space-8)}.about-intro__image{max-height:400px}.timeline{padding-left:var(--space-6)}.contact-layout{grid-template-columns:1fr;gap:var(--space-8)}.project-detail__meta{flex-wrap:wrap;gap:var(--space-4)}.project-detail__nav{grid-template-columns:1fr}.project-detail__content img{width:100%;margin-left:0}.project-detail__content .image-grid{width:100%;margin-left:0}.project-detail__content .image-grid--2x2{grid-template-columns:1fr}.btn-primary{min-height:44px}.contact-form input,.contact-form textarea{min-height:44px}.navbar__links{display:none}.navbar__menu-toggle{display:flex}.navbar__links.open{display:flex;flex-direction:column;position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--color-bg-secondary);padding:calc(var(--nav-height) + var(--space-8))var(--space-8)var(--space-8);border-left:1px solid var(--color-border);z-index:999;gap:var(--space-6)}.footer__inner{flex-direction:column;gap:var(--space-4);text-align:center}}@media(max-width:480px){.container{padding:0 var(--space-4)}.section{padding:var(--space-10)0}.hero__bg{display:none}.timeline{padding-left:var(--space-4)}.skills-grid{grid-template-columns:repeat(2,1fr)}.project-card__password{width:160px}}