*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{color-scheme:dark;--color-bg-primary:#131313;--color-bg-secondary:#1c1b1b;--color-bg-tertiary:#201f1f;--color-bg-elevated:#2a2a2a;--color-bg-surface:rgba(255, 255, 255, 0.03);--color-bg-surface-hover:rgba(255, 255, 255, 0.06);--color-accent-warm:#f5c518;--color-accent-warm-hover:#ffd740;--color-accent-warm-muted:rgba(245, 197, 24, 0.14);--color-accent-cool:#00dbe9;--color-accent-cool-hover:#7df4ff;--color-accent-cool-muted:rgba(0, 219, 233, 0.12);--color-text-primary:#e5e2e1;--color-text-secondary:#c6c9ab;--color-text-tertiary:#909378;--color-text-inverse:#1a1400;--color-border:rgba(255, 255, 255, 0.08);--color-border-hover:rgba(255, 255, 255, 0.15);--color-border-accent:rgba(0, 219, 233, 0.28);--color-success:#8a9e8f;--color-error:#b87070;--color-warning:#d4a84a;--color-nav-scrolled:rgba(19, 19, 19, 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(245, 197, 24, 0.14);--shadow-glow-cool:0 0 30px rgba(0, 219, 233, 0.10)}[data-theme=light]{color-scheme:light;--color-bg-primary:#f2f0e8;--color-bg-secondary:#f9f7f1;--color-bg-tertiary:#e8e5dc;--color-bg-elevated:#fdfcf9;--color-bg-surface:rgba(0, 0, 0, 0.025);--color-bg-surface-hover:rgba(0, 0, 0, 0.05);--color-accent-warm:#1a1a14;--color-accent-warm-hover:#2e2e20;--color-accent-warm-muted:rgba(26, 26, 20, 0.08);--color-accent-cool:#004f54;--color-accent-cool-hover:#006870;--color-accent-cool-muted:rgba(0, 79, 84, 0.09);--color-text-primary:#1a1b14;--color-text-secondary:#524f45;--color-text-tertiary:#7a7670;--color-text-inverse:#f9f7f1;--color-border:rgba(0, 0, 0, 0.08);--color-border-hover:rgba(0, 0, 0, 0.15);--color-border-accent:rgba(0, 79, 84, 0.28);--color-success:#5e8464;--color-error:#a85a50;--color-warning:#9a8438;--color-nav-scrolled:rgba(242, 240, 232, 0.60);--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(26, 26, 20, 0.08);--shadow-glow-cool:0 0 30px rgba(58, 74, 77, 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.4vw, 1.0625rem);--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, 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;--leading-heading:1.15;--tracking-tighter:-0.05em;--tracking-tight:-0.04em;--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);--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;scrollbar-gutter:stable;overflow-x:hidden}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);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:32px;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);position:relative;overflow:hidden;transition:background var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.btn-primary::before,.navbar-pill__contact::before{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--glow-x,50%) var(--glow-y,50%),color-mix(in srgb,var(--color-text-primary) 45%,transparent) 0%,transparent 65%);opacity:0;transition:opacity .15s ease;pointer-events:none;z-index:1}.btn-primary:hover::before,.navbar-pill__contact:hover::before{opacity:1}.btn-primary:hover{background:var(--color-accent-warm-hover);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0);background:var(--color-accent-warm)}.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)}.btn-secondary:active{transform:translateY(0)}.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);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden}@media(max-width:768px){.project-card__tagline{-webkit-line-clamp:unset;line-clamp:unset;overflow:visible;display:block}}.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-body);text-align:center;outline:none;transition:border-color 200ms ease}.project-card__password:focus{border-color:var(--color-accent-warm);outline:2px solid color-mix(in srgb,var(--color-accent-warm) 40%,transparent);outline-offset:2px}.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)}}.protected-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-16)0}.protected-page__inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.protected-page__lock{color:var(--color-text-tertiary);margin-bottom:var(--space-2)}.protected-page__title{font-size:var(--text-2xl);font-weight:var(--weight-semibold)}.protected-page__subtitle{color:var(--color-text-secondary);font-size:var(--text-base)}.protected-page__password{width:240px;padding:12px 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-base);font-family:var(--font-body);text-align:center;outline:none;transition:border-color 200ms ease;margin-top:var(--space-2)}.protected-page__password:focus{border-color:var(--color-accent-warm);outline:2px solid color-mix(in srgb,var(--color-accent-warm) 40%,transparent);outline-offset:2px}.protected-page__password.shake{animation:shake 400ms ease}.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:start}.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)}.about-intro__list{margin:var(--space-3)0 var(--space-4)var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.about-intro__list li{color:var(--color-text-secondary);font-size:var(--text-base);line-height:var(--leading-relaxed)}.about-intro__outside{margin-top:var(--space-8);padding-top:var(--space-8);border-top:1px solid var(--color-border);font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.about-intro__outside-label{display:block;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-3)}.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-16)}.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;gap:var(--space-4);margin-bottom:var(--space-3)}.timeline__meta{display:flex;align-items:baseline;gap:var(--space-2);flex-wrap:wrap;font-size:var(--text-lg);line-height:var(--leading-heading)}.timeline__company-name{font-family:var(--font-heading);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.timeline__location{font-family:var(--font-heading);font-weight:var(--weight-regular);color:var(--color-text-secondary)}.timeline__role{font-family:var(--font-heading);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.timeline__period{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-regular);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0}.timeline__description{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.timeline__body{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.timeline__body p{font-size:var(--text-base);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-social{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-10);max-width:600px}.contact-social__link{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);background:var(--color-bg-secondary);transition:color var(--duration-fast)var(--ease-out-quart),border-color var(--duration-fast)var(--ease-out-quart),background var(--duration-fast)var(--ease-out-quart)}.contact-social__link svg{width:16px;height:16px;flex-shrink:0}.contact-social__link:hover{color:var(--color-text-primary);border-color:var(--color-border-hover);background:var(--color-bg-tertiary)}.contact-or{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);max-width:600px}.contact-or__line{flex:1;height:1px;background:var(--color-border)}.contact-or__label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.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:2px solid color-mix(in srgb,var(--color-accent-warm) 40%,transparent);outline-offset:2px;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:var(--color-success)}.contact-form__status--error{color:var(--color-error)}.project-detail__header{padding:calc(var(--nav-height) + var(--space-32))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:clamp(36px,3.5vw,56px);font-weight:var(--weight-bold);line-height:var(--leading-heading);letter-spacing:var(--tracking-tighter);color:var(--color-text-primary);margin-bottom:var(--space-5)}.project-detail__tagline{font-size:var(--text-lg);color:var(--color-text-secondary);line-height:var(--leading-relaxed);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__meta-tags{margin-left:auto;display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;justify-content:flex-end}.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-semibold);color:var(--color-text-primary);margin:var(--space-12)0 var(--space-4);letter-spacing:-.01em}.project-detail__content h3{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin:var(--space-8)0 var(--space-3);letter-spacing:-.005em}.project-detail__content p+p{margin-top:var(--space-4)}.project-detail__content strong{color:var(--color-text-primary);font-weight:var(--weight-semibold)}.project-detail__content mark{background:linear-gradient(transparent 60%,color-mix(in srgb,var(--color-accent-warm) 35%,transparent) 60%);color:var(--color-text-primary);font-weight:var(--weight-semibold);padding:0 .1em}.project-detail__content blockquote{margin:var(--space-10)0;padding:var(--space-2)var(--space-6);border-left:3px solid var(--color-accent-warm);font-family:var(--font-heading);font-size:var(--text-xl);font-style:italic;line-height:var(--leading-snug);color:var(--color-text-primary)}.project-detail__content blockquote p{margin:0}.project-detail__content blockquote p+p{margin-top:var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-style:normal;color:var(--color-text-secondary);letter-spacing:.02em}.project-detail__content p.lead,.project-detail__content>p:first-of-type{font-size:var(--text-xl);line-height:var(--leading-snug);color:var(--color-text-primary);margin-bottom:var(--space-6)}.project-detail__content p:has(>em:only-child){font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;margin-top:calc(-1 * var(--space-4));margin-bottom:var(--space-8)}.project-detail__content p:has(>em:only-child) em{font-style:italic}.project-detail__content li{margin-bottom:var(--space-2)}.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:12px;margin-top:32px;margin-bottom:32px}.project-detail__content img.image-contained{width:100%;max-width:100%;margin-left:0}.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:12px;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:12px;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);background:var(--color-bg-primary);position:relative;z-index:1}.footer__inner{display:flex;justify-content:space-between;align-items:center}.footer__copyright{font-size:var(--text-sm);color:var(--color-text-tertiary)}.footer__made{font-size:var(--text-sm);color:var(--color-text-tertiary)}.footer__made-link{color:var(--color-text-tertiary);text-decoration:underline;text-underline-offset:2px;transition:color var(--duration-fast)}.footer__made-link:hover{color:var(--color-text-secondary)}.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}.project-detail__header{padding:calc(56px + 36px + var(--space-8))0 var(--space-6)}.project-detail__title{font-size:clamp(36px,10vw,48px)}.project-detail__tagline{font-size:var(--text-lg)}.project-detail__content{margin:var(--space-8)auto;font-size:var(--text-base)}.project-detail__content h2{font-size:var(--text-xl);margin:var(--space-8)0 var(--space-3)}.about-intro{gap:var(--space-6)}.about-intro__image{max-height:280px}.about-intro__title{font-size:var(--text-3xl)}.footer{padding:var(--space-8)0}}.is-home main{padding-top:0!important;flex:1!important;height:auto!important;overflow:visible!important}.is-home footer{display:block}.top-fade{position:fixed;top:0;left:0;right:0;height:var(--nav-height);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);mask-image:linear-gradient(to top,transparent,black 60%);-webkit-mask-image:linear-gradient(to top,transparent,black 60%);pointer-events:none;z-index:999}.bottom-fade{position:fixed;bottom:0;left:0;right:0;height:calc(40px + env(safe-area-inset-bottom,0px));backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);mask-image:linear-gradient(to bottom,transparent,black);-webkit-mask-image:linear-gradient(to bottom,transparent,black);pointer-events:none;z-index:2;transition:opacity .4s ease}.homepage-canvas{position:relative;width:100%;height:auto;overflow:visible;isolation:isolate}.dot-grid-canvas{position:fixed;inset:0;z-index:-1;pointer-events:none;width:100%;height:100%}[data-theme=dark] .dot-grid-canvas{opacity:.6}.homepage-canvas::before{display:none}.home-logo{position:fixed;top:28px;left:max(40px,calc(50vw - var(--container-xl)/2));z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4)28px;background:var(--color-nav-scrolled);border:1px solid var(--color-border);border-radius:var(--radius-full);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);box-shadow:var(--shadow-lg);transition:border-color var(--duration-fast)var(--ease-out-quart),box-shadow var(--duration-fast)var(--ease-out-quart)}.home-logo:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-xl)}.home-hero{position:relative;left:auto;top:auto;max-width:var(--container-xl);margin:0 auto;width:100%;padding:calc(var(--nav-height) + var(--space-32))var(--space-6)calc(var(--space-12) + var(--space-16));pointer-events:auto;z-index:1}.home-hero__title{font-family:var(--font-heading);font-size:clamp(36px,3.5vw,56px);font-weight:var(--weight-bold);line-height:var(--leading-heading);letter-spacing:var(--tracking-tighter);color:var(--color-text-primary);margin-bottom:var(--space-5)}.home-hero__accent{color:var(--color-accent-warm)}.home-hero__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);line-height:var(--leading-relaxed);max-width:380px;margin-bottom:var(--space-8)}.char-reveal{display:inline-block;opacity:0;animation:typeChar .01s forwards}@keyframes typeChar{to{opacity:1}}@keyframes heroBtnReveal{to{opacity:1;transform:translateY(0)}}.home-stack{position:relative;width:100%;overflow:visible;pointer-events:auto}.stack-container{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)var(--space-24);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);position:relative;height:auto}.home-cta{max-width:var(--container-xl);margin:0 auto;padding:var(--space-24)var(--space-6);text-align:center}.home-cta__title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--weight-bold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);color:var(--color-text-primary);margin-bottom:var(--space-4)}.home-cta__sub{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.home-bottom{display:flex;align-items:center;justify-content:space-between;max-width:var(--container-xl);margin:0 auto;padding:var(--space-8)var(--space-6)var(--space-16);border-top:1px solid var(--color-border)}.home-badge{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.home-badge__dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-success);flex-shrink:0;animation:pulse 2s ease-in-out infinite}.home-nav{display:flex;align-items:center;gap:var(--space-6)}.home-nav__link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);letter-spacing:var(--tracking-wide);text-transform:uppercase;transition:color var(--duration-fast)var(--ease-out-quart)}.home-nav__link:hover{color:var(--color-text-primary)}.home-nav__contact{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-inverse);background:var(--color-accent-warm);padding:var(--space-2)var(--space-5);border-radius:var(--radius-full);letter-spacing:var(--tracking-wider);text-transform:uppercase;position:relative;overflow:hidden;transition:background var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.home-nav__contact:hover{background:var(--color-accent-warm-hover);transform:translateY(-1px)}.stack-card{position:relative;width:100%;height:auto;aspect-ratio:486/554;border-radius:12px;overflow:hidden;cursor:pointer;opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease-out-expo),transform .5s var(--ease-out-expo),box-shadow .3s var(--ease-out-quart),border-color .3s var(--ease-out-quart);text-decoration:none;display:flex;flex-direction:column;align-items:flex-start;padding:var(--space-4);gap:var(--space-5);isolation:isolate;background:var(--card-color,#FFFFFF);border:1px solid transparent;box-shadow:var(--shadow-md)}.stack-card.is-placed{opacity:1;transform:translateY(0)}.stack-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--color-border-hover)}.stack-card--wide{grid-column:1/-1;aspect-ratio:16/7}.project-card--stack{display:flex;flex-direction:column;width:100%;height:100%;gap:var(--space-5)}.project-card--stack__image-wrap{flex:1;width:100%;position:relative;overflow:hidden;border-radius:var(--radius-sm);background:var(--color-bg-tertiary)}.project-card--stack__image-wrap::after{content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;box-shadow:inset 0 2px 12px rgba(0,0,0,.15);z-index:1}.project-card--stack__image{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.project-card--stack__footer{display:flex;flex-direction:column;justify-content:flex-start;gap:12px}.project-card--stack__title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--stack-title-color,var(--color-text-primary));line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.project-card--stack__tagline{font-family:var(--font-body);font-size:var(--text-sm);color:var(--stack-tagline-color,var(--color-text-secondary));line-height:var(--leading-normal)}[data-theme=dark] .stack-card{--card-color:#201f1f !important;--stack-title-color:#F9F7F1;--stack-tagline-color:rgba(249, 247, 241, 0.8)}.stack-card--construction{overflow:hidden}.stack-card--construction::after{content:'UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  UNDER CONSTRUCTION  ·  ';position:absolute;top:34%;left:0;width:max-content;padding:var(--space-3)0;background:var(--color-accent-warm);color:var(--color-bg-primary);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;white-space:nowrap;text-shadow:none;z-index:20;box-shadow:0 2px 6px rgba(0,0,0,.4);animation:belt-marquee 36s linear infinite}@keyframes belt-marquee{from{transform:rotate(-3deg)translateY(-50%)translateX(0)}to{transform:rotate(-3deg)translateY(-50%)translateX(-50%)}}@keyframes page-slide-in{from{opacity:0}to{opacity:1}}@keyframes page-slide-out{from{opacity:1}to{opacity:0}}main,footer{animation:page-slide-in .22s cubic-bezier(.25,1,.5,1)both}body.page-exiting main,body.page-exiting footer{animation:page-slide-out .18s cubic-bezier(.55,0,1,.45)forwards}.nav-cluster{position:fixed;top:28px;right:max(28px,calc(50vw - var(--container-xl)/2));z-index:1000;display:flex;align-items:center;gap:10px}.navbar-pill{position:static;display:flex;align-items:center;padding:var(--space-3);background:var(--color-nav-scrolled);border:1px solid var(--color-border);border-radius:var(--radius-full);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);box-shadow:var(--shadow-lg);transition:border-color var(--duration-fast)var(--ease-out-quart),box-shadow var(--duration-fast)var(--ease-out-quart)}.navbar-pill:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-xl)}.navbar-pill__links{display:flex;align-items:center;gap:var(--space-5)}.navbar-pill__link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);letter-spacing:var(--tracking-wide);text-transform:uppercase;transition:color var(--duration-fast)var(--ease-out-quart)}.navbar-pill__link:hover,.navbar-pill__link--active{color:var(--color-text-primary)}.navbar-pill__contact{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-4);border-radius:var(--radius-full);letter-spacing:var(--tracking-wide);text-transform:uppercase;position:relative;overflow:hidden;transition:background var(--duration-fast)var(--ease-out-quart),transform var(--duration-fast)var(--ease-out-quart)}.navbar-pill__contact:hover{background:var(--color-accent-warm-hover);transform:translateY(-1px)}.navbar-pill__divider{width:1px;height:18px;background:var(--color-border);flex-shrink:0;margin:0 var(--space-1)}@media(max-width:767px){.nav-cluster{top:0;left:0;right:0;transform:none;flex-direction:column;align-items:stretch;gap:0;background:color-mix(in srgb,var(--color-bg-primary) 85%,transparent);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);box-shadow:var(--shadow-sm)}.navbar-pill{width:100%;height:64px;border-radius:0;border:none;background:0 0;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none;padding:0 16px;justify-content:flex-end}.navbar-pill:hover{box-shadow:none}.home-logo{top:0;left:0;height:64px;padding:0 16px;display:flex;align-items:center;z-index:1001;background:0 0;border:none;border-radius:0;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none}.home-logo:hover{border-color:transparent;box-shadow:none}.theme-toggle{display:none}.navbar-pill__links{gap:var(--space-3);white-space:nowrap}.navbar-pill__link,.navbar-pill__contact{font-size:var(--text-xs)}.home-hero{padding:var(--space-4)var(--space-5)calc(var(--space-8) + 56px);padding-top:calc(56px + 36px + var(--space-8))}.project-detail__header{padding-top:calc(56px + 36px + var(--space-8))}.home-hero__title{font-size:clamp(40px,10vw,56px)}.project-detail__title{font-size:clamp(40px,10vw,56px)}.home-hero .btn-primary{font-size:var(--text-xs);padding:var(--space-2)var(--space-4)}.stack-container{grid-template-columns:1fr;gap:var(--space-4);padding-bottom:var(--space-12)}.stack-card{aspect-ratio:auto}.stack-card--wide{aspect-ratio:auto}.project-card--stack__image-wrap{min-height:240px}.project-card--stack__footer{flex-shrink:0}}@media(max-width:480px){.home-hero__title{font-size:clamp(36px,10vw,48px)}}@media(min-width:768px) and (max-width:1280px){.container{max-width:100%;padding:0 calc(40px + var(--space-5))}.home-hero{padding-top:calc(var(--nav-height) + var(--space-24))}.project-detail__header{padding-top:calc(var(--nav-height) + var(--space-24))}}@media(max-width:767px){.project-detail__meta-tags{margin-left:0;justify-content:flex-start;width:100%}.contact-social{grid-template-columns:repeat(2,1fr);max-width:none}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}.project-detail__content img,.project-detail__content .image-grid img{opacity:1;transform:none}}.project-detail__content img{cursor:zoom-in}.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:rgba(0,0,0,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out-quart)}.lightbox.is-open{opacity:1;pointer-events:auto}.lightbox__img{max-width:min(92vw,1400px);max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 32px 80px rgba(0,0,0,.6);transform:scale(.92);transition:transform .3s var(--ease-out-expo);user-select:none}.lightbox.is-open .lightbox__img{transform:scale(1)}.lightbox__close{position:fixed;top:var(--space-6);right:var(--space-6);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);color:#fff;cursor:pointer;transition:background .2s ease,transform .2s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.lightbox__close:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.lightbox__close svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;stroke-linecap:round}.outline-wrap{position:fixed;left:32px;top:50%;transform:translateY(-50%);z-index:200;display:none;align-items:center;gap:12px;pointer-events:none}.outline-wrap.is-active{display:flex;opacity:0;pointer-events:none;transition:opacity .35s ease}@media(min-width:1100px){.outline-wrap.is-active.is-scrolled{opacity:1;pointer-events:auto}.outline-wrap.is-active.is-at-bottom{opacity:0;pointer-events:none}}@media(max-width:1099px){.outline-wrap.is-active{opacity:1;pointer-events:auto}}.outline-pill,.outline-panel,.outline-panel__link{cursor:none}.outline-panel{position:relative;order:1;width:180px;max-height:72vh;overflow-y:auto;padding:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);box-shadow:0 8px 32px rgba(0,0,0,.15);opacity:0;transform:translateX(-10px);pointer-events:none;transition:opacity .22s ease,transform .22s ease;scrollbar-width:none}.outline-panel::-webkit-scrollbar{display:none}.outline-wrap.panel-hover .outline-panel{opacity:1;transform:translateX(0);pointer-events:auto}.outline-wrap.drawer-open .outline-panel{opacity:1;transform:translateX(0);pointer-events:auto}.outline-pill{order:0;flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--color-nav-scrolled);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-medium);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);box-shadow:var(--shadow-lg);transition:border-color .2s ease,color .2s ease,box-shadow .2s ease;white-space:nowrap;gap:7px}.outline-pill svg{flex-shrink:0;stroke:currentColor}.outline-pill__label{display:none}@media(max-width:1099px){.outline-pill__label{display:inline}}.outline-pill:hover{border-color:var(--color-accent-warm);color:var(--color-text-primary);box-shadow:0 6px 24px rgba(0,0,0,.18)}.outline-wrap.drawer-open .outline-pill{border-color:var(--color-accent-warm);color:var(--color-text-primary)}.outline-panel__label{font-family:var(--font-mono,monospace);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary);margin:0 0 var(--space-3);padding-left:var(--space-2)}.outline-panel__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.outline-panel__link{display:block;font-size:var(--text-xs);line-height:1.4;color:var(--color-text-secondary);text-decoration:none;padding:5px var(--space-2);border-left:2px solid transparent;border-radius:0 4px 4px 0;transition:color .18s ease,border-color .18s ease,background .18s ease;word-break:break-word}.outline-panel__link:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary,rgba(128,128,128,8%))}.outline-panel__link.is-active{color:var(--color-accent-warm);border-left-color:var(--color-accent-warm)}.outline-panel__link--sub{padding-left:calc(var(--space-2) + 14px);font-size:11px;opacity:.8}.outline-backdrop{position:fixed;inset:0;z-index:199;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .25s ease;display:none}.outline-backdrop.is-visible{opacity:1;pointer-events:auto}@media(max-width:1099px){.outline-wrap{left:auto;right:32px;top:auto;bottom:24px;transform:none;flex-direction:column;align-items:flex-end}.outline-wrap.is-active{pointer-events:none}.outline-pill{width:auto;height:auto;padding:9px 20px;border-radius:var(--radius-full);pointer-events:auto}.outline-panel{pointer-events:auto}}@media(min-width:768px) and (max-width:1099px){.outline-pill{order:1}.outline-panel{order:0;width:220px;margin-bottom:12px;border:1px solid var(--color-border);border-radius:12px;padding:var(--space-4);background:var(--color-bg-secondary);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);transform:translateY(8px);transition:opacity .25s ease,transform .25s ease}.outline-wrap.drawer-open .outline-panel{opacity:1;transform:translateY(0)}.outline-backdrop{display:block;background:0 0}}@media(max-width:767px){.outline-wrap{left:0;right:0;width:100%;align-items:center}.outline-wrap.drawer-open .outline-pill{opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease}.outline-pill{transition:opacity .2s ease,transform .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease}.outline-panel{position:fixed;inset:auto 0 0;width:100%;max-height:65vh;border-radius:20px 20px 0 0;border-left:none;border-right:none;border-bottom:none;padding:0 var(--space-5)calc(var(--space-5) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;transform:translateY(100%);transition:opacity .25s ease,transform .3s var(--ease-out-expo);overflow-y:auto}.outline-panel::before{content:'';display:block;width:36px;height:4px;background:var(--color-border);border-radius:var(--radius-full);margin:var(--space-4)auto;flex-shrink:0}.outline-wrap.drawer-open .outline-panel{opacity:1;transform:translateY(0)}.outline-backdrop{display:block}.outline-panel__link{font-size:var(--text-sm);padding:10px var(--space-2)}.outline-panel__link--sub{font-size:var(--text-xs);padding-left:calc(var(--space-2) + 16px)}}