.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}*{margin:0;padding:0;box-sizing:border-box}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}:root{--bg-color: #fafcfd;--bg-secondary: #f5f5f5;--text-primary: #2f2f2f;--text-secondary: #5a5a5a;--accent-red: #4a0f1e;--link-color: #7a7a7a;--font-family-base: "Karla Variable", "Helvetica Neue", Arial, sans-serif;--font-family-serif: "Crimson Pro", Georgia, "Times New Roman", serif;--font-family-mono: "IBM Plex Mono", "SF Mono", "Monaco", monospace;--max-width: 1600px;--gap: 60px;--mobile-gap: 40px;--space-1: 8px;--space-2: 16px;--space-3: 24px;--space-4: 32px;--space-5: 40px;--space-6: 48px;--space-8: 64px;--space-10: 80px;--space-12: 96px;--space-15: 120px;--space-xs: var(--space-1);--space-sm: var(--space-2);--space-md: var(--space-4);--space-lg: var(--space-8);--font-name: 56px;--font-display: 64px;--font-h1: 48px;--font-h2: 32px;--font-h3: 24px;--font-body-lg: 20px;--font-body: 16px;--font-sm: 14px;--font-xs: 12px;--leading-tight: 1.1;--leading-normal: 1.5;--leading-relaxed: 1.7;--tracking-tight: -.04em;--tracking-normal: -.01em;--tracking-wide: .05em;--shadow-sm: 0 2px 8px rgba(26, 26, 26, .06);--shadow-md: 0 8px 24px rgba(26, 26, 26, .08);--shadow-lg: 0 12px 32px rgba(26, 26, 26, .12);--shadow-accent: 0 4px 12px rgba(74, 15, 30, .25);--font-display-lg: 64px;--font-subhead: 24px;--font-caption: 13px;--space-section: 80px;--space-content: 48px;--bg-grouped: rgba(0, 0, 0, .02);--content-width: 800px;--duration-fast: .2s;--duration-normal: .3s;--duration-slow: .5s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-linear: linear;--hover-lift: translateY(-2px);--hover-lift-large: translateY(-4px);--hover-shift: translateX(4px);--hover-scale-subtle: scale(1.02);--hover-scale-medium: scale(1.03);--hover-scale-emphasis: scale(1.05);--transition-color: color var(--duration-fast) var(--ease-out);--transition-transform: transform var(--duration-normal) var(--ease-out);--transition-background: background-color var(--duration-fast) var(--ease-out);--transition-shadow: box-shadow var(--duration-normal) var(--ease-out);--transition-opacity: opacity var(--duration-fast) var(--ease-out);--ease-out-expo: var(--ease-out)}body{font-family:var(--font-family-base);background-color:var(--bg-color);color:var(--text-primary);font-size:var(--font-body);line-height:var(--leading-relaxed);letter-spacing:var(--tracking-normal);transition:background-color var(--duration-normal) var(--ease-out);overflow-x:hidden;cursor:none}a,button,[role=button],.clickable,input,select,textarea{cursor:none}header{transition:opacity .25s ease}body.lightbox-open header{opacity:0;pointer-events:none}.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--accent-red);border-radius:50%;pointer-events:none;z-index:100000;transform:translate(-50%,-50%);transition:transform .15s var(--ease-out),opacity .2s var(--ease-out)}.cursor-ring{position:fixed;top:0;left:0;width:28px;height:28px;border:1px solid rgba(0,0,0,.2);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .2s var(--ease-out),height .2s var(--ease-out),border-width .15s var(--ease-out),border-color .15s var(--ease-out),background-color .15s var(--ease-out),transform .15s var(--ease-out),opacity .2s var(--ease-out)}.cursor-ring.hover{width:34px;height:34px;border-width:2px;border-color:var(--accent-red)}.cursor-ring.hover-fill{background:#a0283e0f}.cursor-text{position:fixed;pointer-events:none;z-index:100000;font-family:var(--font-family-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-primary);opacity:0;transform:translate(24px,-50%);transition:opacity .15s var(--ease-out);white-space:nowrap}.cursor-text.visible{opacity:1}@media(hover:none),(prefers-reduced-motion:reduce){.cursor-dot,.cursor-ring,.cursor-text{display:none!important}body{cursor:url(/cursor-star.png) 16 16,auto}a,button,[role=button],.clickable,input,select,textarea{cursor:url(/cursor-star.png) 16 16,pointer}}h1,h2,h3{font-family:var(--font-family-serif);font-weight:300;letter-spacing:var(--tracking-tight);text-transform:none;line-height:var(--leading-normal)}a{color:var(--link-color);text-decoration:underline;transition:var(--transition-color)}a:hover{color:var(--accent-red)}.hover-lift{transition:var(--transition-transform),var(--transition-shadow)}.hover-lift:hover{transform:var(--hover-lift)}.hover-lift-large{transition:var(--transition-transform),var(--transition-shadow)}.hover-lift-large:hover{transform:var(--hover-lift-large)}.hover-shift{transition:var(--transition-transform),var(--transition-color)}.hover-shift:hover{transform:var(--hover-shift);color:var(--accent-red)}.hover-scale{transition:var(--transition-transform)}.hover-scale:hover{transform:var(--hover-scale-subtle)}.hover-scale-medium{transition:var(--transition-transform)}.hover-scale-medium:hover{transform:var(--hover-scale-medium)}.hover-scale-emphasis{transition:var(--transition-transform)}.hover-scale-emphasis:hover{transform:var(--hover-scale-emphasis)}.hover-glow{transition:var(--transition-shadow),var(--transition-transform)}.hover-glow:hover{box-shadow:var(--shadow-md)}.animated-underline,.hover-underline{position:relative;text-decoration:none;transition:var(--transition-color)}.animated-underline:after,.hover-underline:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background-color:currentColor;transition:width var(--duration-normal) var(--ease-out)}.animated-underline:hover:after,.hover-underline:hover:after{width:100%}.animated-underline:hover,.hover-underline:hover{color:var(--accent-red)}.hover-fade{transition:var(--transition-opacity)}.hover-fade:hover{opacity:.7}.section-layout{padding:var(--space-section) var(--space-6);max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:160px 1fr;gap:var(--space-lg)}.section-title{font-family:var(--font-family-serif);font-size:var(--font-sm);font-weight:300;font-style:italic;color:var(--accent-red);letter-spacing:.02em;position:sticky;top:100px;align-self:start}@media(max-width:1024px){.section-layout{grid-template-columns:1fr;padding:var(--space-lg) var(--space-4)}.section-title{position:static;margin-bottom:var(--space-md)}}@media(max-width:768px){.section-layout{padding:var(--space-lg) var(--space-3)}.section-title{margin-bottom:var(--space-4)}}header{position:fixed;top:0;left:0;right:0;background-color:#fafcfd99;backdrop-filter:saturate(200%) blur(24px);-webkit-backdrop-filter:saturate(200%) blur(24px);z-index:100;border-bottom:1px solid rgba(26,26,26,.08);contain:layout style}nav{max-width:var(--max-width);margin:0 auto;padding:var(--space-3) var(--space-6);display:flex;justify-content:space-between;align-items:center}nav .logo{font-family:var(--font-family-base);font-size:var(--font-body);font-weight:600;color:var(--text-primary);text-decoration:none;letter-spacing:.01em;display:inline-block;transform-origin:left center}.nav-home-link{text-decoration:none}.nav-links{display:flex;gap:var(--space-5)}.nav-link{font-family:var(--font-family-base);color:var(--text-secondary);text-decoration:none;font-size:var(--font-sm);font-weight:400;display:inline-block;letter-spacing:.02em}nav .logo,.nav-home-link,.nav-link{transition:color var(--duration-fast) var(--ease-out),transform var(--duration-normal) var(--ease-out)}nav .logo:hover,.nav-home-link:hover,.nav-link:hover{color:var(--accent-red);transform:var(--hover-lift)}nav .logo:focus-visible,.nav-home-link:focus-visible,.nav-link:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}nav .logo:active,.nav-home-link:active,.nav-link:active{animation:spring .22s var(--ease-spring)}.nav-link.active,.nav-home-link.active{color:var(--accent-red)}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;padding:10px;background:transparent;border:none;cursor:pointer;z-index:101}.hamburger-line{display:block;width:20px;height:2px;background:var(--text-primary);border-radius:1px;transition:transform var(--duration-normal) var(--ease-out),opacity var(--duration-normal) var(--ease-out)}.mobile-menu-toggle.active .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.mobile-menu-toggle.active .hamburger-line:nth-child(2){opacity:0}.mobile-menu-toggle.active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-toggle:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px;border-radius:4px}body.mobile-menu-active{overflow:hidden}@keyframes spring{0%{transform:scale(1)}50%{transform:scale(.94) translateY(1px)}to{transform:scale(1)}}main{max-width:var(--max-width);margin:0 auto;padding:var(--space-15) var(--space-6) var(--space-10)}.site-footer{max-width:var(--max-width);margin:0 auto;padding:var(--space-10) var(--space-6) var(--space-8);display:flex;justify-content:center;border-top:1px solid rgba(26,26,26,.08);color:var(--text-secondary);font-size:var(--font-sm)}.footer-content{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%}.footer-built{font-size:var(--font-xs);color:var(--text-secondary);opacity:.6}.footer-meta{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap;letter-spacing:.02em}.site-footer a{color:var(--text-secondary);text-decoration:none;transition:var(--transition-color)}.site-footer a:hover{color:var(--accent-red)}.footer-separator{display:none}@media(max-width:768px){.footer-content{flex-direction:column;align-items:center;gap:var(--space-2)}}.hero-section{margin-bottom:var(--space-12);max-width:800px}.hero{position:relative}.hero h1,.hero .hero-title{font-family:var(--font-family-serif);font-size:clamp(40px,8vw,56px);line-height:1.15;letter-spacing:var(--tracking-tight);font-weight:300;text-transform:none}.timeline{display:flex;flex-direction:column;gap:var(--space-2)}.timeline-item{display:flex;flex-direction:column;gap:var(--space-1)}.year{font-family:var(--font-family-mono);font-size:var(--font-sm);color:var(--text-secondary)}.role{font-family:var(--font-family-base);font-size:28px;font-weight:300;letter-spacing:var(--tracking-normal);color:var(--text-primary)}.carousel-section{margin-bottom:var(--space-10);overflow-x:clip;padding:var(--space-5) 0;width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);contain:layout style}.carousel-section h2{font-size:var(--font-h1);margin-bottom:var(--space-5);letter-spacing:var(--tracking-wide);max-width:var(--max-width);margin-left:auto;margin-right:auto;padding:0 var(--space-3)}.carousel-section .view-all-link{max-width:var(--max-width);margin-left:auto;margin-right:auto;padding:0 var(--space-3)}.carousel-container{width:100%;overflow:hidden;position:relative;min-height:550px;padding:var(--space-2) 0}.carousel-container+.carousel-container{margin-top:var(--space-3)}.carousel-track{display:flex;gap:var(--space-2);--marquee-distance: 4200px ;--marquee-duration: 60s;animation:scroll var(--marquee-duration) linear infinite;will-change:transform;padding-left:0;transform:translateZ(0);backface-visibility:hidden}.carousel-item{flex-shrink:0;width:400px;height:500px;position:relative;cursor:pointer;transition:transform var(--duration-slow) var(--ease-spring);contain:layout style paint}.carousel-item:hover{transform:var(--hover-scale-emphasis);z-index:10}.carousel-item:active{animation:spring .3s var(--ease-spring)}.carousel-item:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.carousel-item .placeholder{width:100%;height:100%;background:linear-gradient(135deg,#e0e0e0,#d0d0d0);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:24px;font-family:var(--font-family-mono);border:2px solid #c0c0c0}.carousel-item .placeholder:before{content:"PROJECT "}.carousel-image{width:100%;height:100%;object-fit:cover;border-radius:8px;display:block;background:linear-gradient(135deg,#e0e0e0,#d0d0d0);mask-image:radial-gradient(ellipse 90% 90% at center,black 60%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 90% 90% at center,black 60%,transparent 100%);transition:transform var(--duration-slow) var(--ease-out);transform:translateZ(0);backface-visibility:hidden}.carousel-item:hover .carousel-image{transform:scale(1.05)}.carousel-image.lazy{opacity:0;transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.carousel-image:not(.lazy){opacity:1}.carousel-item-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:var(--space-2);background:linear-gradient(180deg,#0c0c0c00,#0c0c0c47 55%,#0c0c0c8c);opacity:0;transition:opacity var(--duration-normal) var(--ease-out);border-radius:8px;pointer-events:none}.carousel-item:hover .carousel-item-overlay{opacity:.8}.project-label{color:#fff;font-family:var(--font-family-mono);font-size:var(--font-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.bento-section{margin-bottom:var(--space-12);max-width:var(--max-width);margin-left:auto;margin-right:auto}.bento-section h2{font-size:var(--font-h2);margin-bottom:var(--space-6);letter-spacing:var(--tracking-tight)}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,200px);gap:var(--space-2);contain:layout style}.bento-item-1{grid-column:1;grid-row:1}.bento-item-2{grid-column:2;grid-row:1}.bento-item-3{grid-column:3 / 5;grid-row:1 / 3}.bento-item-4{grid-column:1;grid-row:2}.bento-item-5{grid-column:2;grid-row:2}.bento-item-6{grid-column:1 / 3;grid-row:3}.bento-item-7{grid-column:3;grid-row:3}.bento-item-8{grid-column:4;grid-row:3}.bento-item{position:relative;overflow:hidden;border-radius:8px;cursor:pointer;text-decoration:none;color:inherit;opacity:0;transform:translateY(20px);animation:bentoFadeIn .6s ease forwards;animation-delay:var(--delay, 0s)}@keyframes bentoFadeIn{to{opacity:1;transform:translateY(0)}}.bento-item:hover{z-index:10}.bento-image-stack{position:relative;width:100%;height:100%}.bento-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease-in-out,transform var(--duration-slow) var(--ease-out);transform:translateZ(0);backface-visibility:hidden}.bento-image.active{opacity:1}.bento-item:hover .bento-image.active{transform:var(--hover-scale-medium)}.bento-item-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:var(--space-2);background:linear-gradient(180deg,#0c0c0c00,#0c0c0c47 55%,#0c0c0c8c);opacity:0;transition:opacity var(--duration-normal) var(--ease-out);border-radius:8px;pointer-events:none}.bento-item:hover .bento-item-overlay{opacity:1}.bento-label{color:#fff;font-family:var(--font-family-mono);font-size:var(--font-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.bento-section .view-all-link{margin-top:var(--space-4)}@media(max-width:900px){.bento-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,180px)}.bento-item-1{grid-column:1;grid-row:1}.bento-item-2{grid-column:2;grid-row:1}.bento-item-3{grid-column:1 / 3;grid-row:2}.bento-item-4{grid-column:1;grid-row:3}.bento-item-5{grid-column:2;grid-row:3}.bento-item-6{grid-column:1 / 3;grid-row:4}.bento-item-7,.bento-item-8{display:none}}@media(max-width:600px){.bento-grid{grid-template-columns:1fr;grid-template-rows:repeat(6,220px)}.bento-item-1{grid-column:1;grid-row:1}.bento-item-2{grid-column:1;grid-row:2}.bento-item-3{grid-column:1;grid-row:3}.bento-item-4{grid-column:1;grid-row:4}.bento-item-5{grid-column:1;grid-row:5}.bento-item-6{grid-column:1;grid-row:6}.bento-item-7,.bento-item-8{display:none}}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(calc(-1 * var(--marquee-distance)))}}.projects-section{margin-bottom:var(--space-12)}.projects-section h2{font-size:var(--font-h2);margin-bottom:var(--space-6);letter-spacing:var(--tracking-tight)}.view-all-link{display:block;margin-top:var(--space-4);font-family:var(--font-family-mono);font-size:14px;color:var(--text-secondary);text-decoration:none;letter-spacing:.05em;text-align:right;transition:var(--transition-color),var(--transition-transform)}.view-all-link:hover{color:var(--accent-red);transform:var(--hover-shift)}.view-all-link:focus-visible,.back-link:focus-visible,.error-link:focus-visible,.scroll-to-top:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.project-card{background:var(--bg-color);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);contain:layout style paint;box-shadow:0 0 #1a1a1a00;text-decoration:none;color:inherit;transform-style:preserve-3d;perspective:1000px;position:relative}.project-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(255,255,255,.15) 0%,transparent 60%);opacity:0;transition:opacity var(--duration-fast) var(--ease-out);pointer-events:none;z-index:2;border-radius:inherit}.project-card:hover:before{opacity:1}.project-card:hover{box-shadow:var(--shadow-lg)}.project-card.tilting{transform:perspective(1000px) rotateX(var(--rotate-x, 0deg)) rotateY(var(--rotate-y, 0deg)) var(--hover-scale-subtle)}.project-card:active{animation:spring .3s var(--ease-spring)}.project-card:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.project-image-container{aspect-ratio:16/9;overflow:hidden}.project-image{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow) var(--ease-out);transform:translateZ(0);backface-visibility:hidden}.project-card:hover .project-image{transform:var(--hover-scale-emphasis)}.project-image-placeholder{aspect-ratio:16/9;background:linear-gradient(135deg,#e0e0e0,#d0d0d0);display:flex;align-items:center;justify-content:center;border-bottom:2px solid #c0c0c0}.project-number{font-family:var(--font-family-mono);font-size:72px;color:var(--text-secondary);opacity:.3}.project-info{padding:var(--space-4)}.project-info h3{font-size:var(--font-h3);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.project-category{font-size:var(--font-body);color:var(--text-secondary);text-transform:none;letter-spacing:var(--tracking-wide);font-family:var(--font-family-base);font-weight:300}.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease-out}.lightbox.active{opacity:1;pointer-events:all}.lightbox-close{position:fixed;top:100px;right:var(--space-5);font-size:28px;color:#fff;cursor:pointer;z-index:10002;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-normal) var(--ease-out),background-color var(--duration-fast) var(--ease-out);opacity:.7;font-weight:300;background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:50%;border:1px solid rgba(255,255,255,.2);padding:0;font-family:inherit}.lightbox-close:focus-visible{outline:2px solid white;outline-offset:2px;opacity:1}.lightbox-close:hover{opacity:1;background:#ffffff40;transform:var(--hover-scale-emphasis)}.lightbox-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);transform:translateY(10px);opacity:0;transition:transform .25s ease-out,opacity .25s ease-out}.lightbox.active .lightbox-content{transform:translateY(0);opacity:1}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 32px #0006}.lightbox-title{color:#fff;font-family:var(--font-family-mono);font-size:var(--font-xs);text-align:center;opacity:.7;max-width:600px;letter-spacing:.05em}.project-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#fafcfdfa;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s ease;backdrop-filter:blur(10px)}.project-modal.active{opacity:1;pointer-events:all}.modal-close{position:absolute;top:var(--space-5);right:var(--space-5);font-size:var(--font-h1);cursor:pointer;color:var(--text-primary);z-index:1001;transition:transform var(--duration-normal) var(--ease-out);width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;font-family:inherit}.modal-close:hover{transform:rotate(90deg)}.modal-close:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.modal-content{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--gap);max-width:1400px;width:90%;max-height:80vh;transform:scale(.9);transition:transform var(--duration-normal) var(--ease-spring)}.project-modal.active .modal-content{transform:scale(1)}.modal-image{border-radius:12px;overflow:hidden}.modal-placeholder{width:100%;height:600px;background:linear-gradient(135deg,#e0e0e0,#d0d0d0);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:24px;font-family:var(--font-family-mono);border:2px solid #c0c0c0}.modal-placeholder:before{content:"PROJECT IMAGE"}.modal-details{display:flex;flex-direction:column;gap:var(--space-4)}.modal-title{font-size:56px;line-height:var(--leading-tight)}.modal-description{font-size:var(--font-body-lg);line-height:var(--leading-normal);color:var(--text-secondary)}.modal-meta{display:flex;flex-direction:column;gap:var(--space-2);margin-top:auto}.meta-item{display:flex;justify-content:space-between;padding-bottom:var(--space-2);border-bottom:1px solid rgba(26,26,26,.1)}.meta-label{font-family:var(--font-family-mono);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--text-secondary)}.meta-value{font-family:var(--font-family-base);font-size:var(--font-body)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}.reveal.visible{opacity:1;transform:translateY(0)}.fade-in{opacity:0;transition:opacity var(--duration-slow) var(--ease-out)}.fade-in.loaded{opacity:1}.carousel-item.active{opacity:1!important;transform:translateY(0)!important}.work-list-section{margin-bottom:var(--space-12);margin-top:var(--space-4)}.work-list{display:flex;flex-direction:column;gap:var(--space-6);max-width:900px;margin:0 auto}.work-item{display:flex;flex-direction:column;gap:var(--space-3);text-decoration:none;color:inherit;padding:var(--space-3);margin:calc(var(--space-3) * -1);border-radius:12px;transition:background-color var(--duration-fast) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.work-item:hover{background:#1a1a1a08;transform:var(--hover-lift)}.work-item:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.work-item-image{aspect-ratio:16/10;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#f0f0f0,#e8e8e8)}.work-image{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow) var(--ease-out);transform:translateZ(0);backface-visibility:hidden}.work-item:hover .work-image{transform:var(--hover-scale-medium)}.work-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:48px;color:var(--text-secondary);opacity:.3}.work-item-content{display:flex;flex-direction:column;gap:var(--space-1)}.work-item-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;line-height:1.3;color:var(--text-primary)}.work-item-description{font-family:var(--font-serif);font-size:.9375rem;line-height:1.5;color:var(--text-secondary)}.work-item-meta{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.work-meta-item{font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);opacity:.7}.work-meta-item:not(:last-child):after{content:"·";margin-left:var(--space-1);opacity:.5}@media(max-width:1024px){.work-list{max-width:100%;gap:var(--space-5)}}@media(max-width:768px){.work-list{gap:var(--space-4)}.work-item-title{font-size:1.25rem}.work-item-description{font-size:.875rem}}.archive-grid-section{margin-bottom:var(--space-15)}.archive-filters{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid rgba(26,26,26,.08)}.filter-btn{padding:.5rem 1rem;border:1px solid rgba(26,26,26,.12);background:transparent;border-radius:100px;font-family:var(--font-sans);font-size:.8125rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.filter-btn:hover{border-color:var(--accent-red);color:var(--accent-red)}.filter-btn.active{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-color)}.filter-btn:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.sort-controls{display:flex;align-items:center;gap:.5rem;margin-left:auto}.sort-label{font-family:var(--font-sans);font-size:.8125rem;color:var(--text-secondary)}.sort-select{padding:.5rem 2rem .5rem .75rem;border:1px solid rgba(26,26,26,.12);border-radius:6px;background:transparent;font-family:var(--font-sans);font-size:.8125rem;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.sort-select:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}@media(max-width:768px){.archive-filters{gap:.5rem}.filter-btn{padding:.6rem .875rem;font-size:.75rem;min-height:44px}.sort-controls{width:100%;margin-left:0;margin-top:var(--space-1)}}.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-2);contain:layout style}.archive-item{position:relative;cursor:pointer;transition:transform var(--duration-slow) var(--ease-out),box-shadow var(--duration-slow) var(--ease-out);contain:layout style paint;aspect-ratio:3/4;overflow:hidden;border-radius:8px;transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;box-shadow:0 0 #1a1a1a00}.archive-item:hover{transform:var(--hover-scale-emphasis) translateZ(0) var(--hover-lift-large);z-index:10;box-shadow:var(--shadow-lg)}.archive-item:active{animation:spring .3s var(--ease-spring)}.archive-item:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.archive-image{width:100%;height:100%;object-fit:cover;display:block;background:linear-gradient(135deg,#e8e8e8,#f0f0f0);opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.archive-image.loaded,.archive-image[complete]{opacity:1}.archive-image.lazy{opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.archive-image:not(.lazy){opacity:1}.archive-item-info{position:absolute;bottom:0;left:0;right:0;padding:var(--space-2);background:linear-gradient(to top,rgba(26,26,26,.7) 0%,rgba(26,26,26,.3) 60%,transparent 100%);opacity:0;transform:translateY(10px);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out);display:flex;flex-direction:column;gap:var(--space-1)}.archive-item:hover .archive-item-info{opacity:1;transform:translateY(0)}.archive-item-brand{color:#fffffff2;font-family:var(--font-family-mono);font-size:var(--font-sm);font-weight:400;text-transform:uppercase;letter-spacing:.06em;text-shadow:0 1px 6px rgba(0,0,0,.6)}.archive-item-title{color:#fff;font-family:var(--font-family-mono);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.error-section{min-height:80vh;display:flex;align-items:center;justify-content:center}.error-content{text-align:center;display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.error-code{font-size:120px;letter-spacing:var(--tracking-wide);color:var(--text-secondary);opacity:.5;font-variant-numeric:tabular-nums}.error-message{font-family:var(--font-family-base);font-size:var(--font-h2);font-weight:400;color:var(--text-primary);position:relative}.error-link{margin-top:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--text-primary);color:var(--bg-color);text-decoration:none;font-family:var(--font-family-mono);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);transition:transform var(--duration-normal) var(--ease-spring);display:inline-block}.error-link:hover{transform:var(--hover-scale-emphasis);color:var(--bg-color)}.error-link:active{animation:spring .3s var(--ease-spring)}.fuzzy-text{position:relative;display:inline-block;--fuzzy-opacity: .2;text-shadow:0 0 10px rgba(0,0,0,.12);animation:fuzzy-base 3s ease-in-out infinite}.fuzzy-text:hover{--fuzzy-opacity: .5}.fuzzy-text:before,.fuzzy-text:after{content:attr(data-text);position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;filter:blur(1px);opacity:var(--fuzzy-opacity)}.fuzzy-text:before{color:#ff6b9b;animation:fuzzy-shift 1.8s steps(6) infinite}.fuzzy-text:after{color:#6bb3ff;animation:fuzzy-shift 1.6s steps(5) infinite reverse}@keyframes fuzzy-base{0%,to{transform:translateY(0)}50%{transform:translateY(1px)}}@keyframes fuzzy-shift{0%{transform:translate(0);opacity:var(--fuzzy-opacity)}25%{transform:translate(1px,-1px);opacity:calc(var(--fuzzy-opacity) + .1)}50%{transform:translate(-1px,1px);opacity:calc(var(--fuzzy-opacity) + .05)}75%{transform:translate(1px,1px);opacity:calc(var(--fuzzy-opacity) + .15)}to{transform:translate(0);opacity:var(--fuzzy-opacity)}}.glitch-text{display:inline-block;position:relative;color:var(--text-primary);text-shadow:0 0 12px rgba(0,0,0,.08);animation:glitch-skew 2.5s ease-in-out infinite}.glitch-text:before,.glitch-text:after{content:attr(data-text);position:absolute;inset:0;pointer-events:none;clip-path:inset(0 0 0 0);opacity:.75}.glitch-text:before{color:#ff4f7a;transform:translate(-1px);animation:glitch-slice 2s steps(8) infinite}.glitch-text:after{color:#4fc3ff;transform:translate(1px);animation:glitch-slice 1.8s steps(7) infinite reverse}@keyframes glitch-skew{0%,to{transform:skew(0)}50%{transform:skew(1deg)}}@keyframes glitch-slice{0%{clip-path:inset(0 0 85% 0)}20%{clip-path:inset(10% 0 60% 0)}40%{clip-path:inset(40% 0 20% 0)}60%{clip-path:inset(20% 0 45% 0)}80%{clip-path:inset(5% 0 70% 0)}to{clip-path:inset(0 0 85% 0)}}.about-section{min-height:80vh;display:block}.about-content{width:100%;max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4);align-items:start}.about-main{display:flex;flex-direction:column;gap:var(--space-5);padding-right:var(--space-5)}.about-side{display:flex;flex-direction:column;gap:var(--space-4);width:100%;align-self:start}.about-header-row{display:flex;align-items:flex-end;justify-content:space-between}.about-media-header{grid-column:1 / -1;font-size:var(--font-h2);letter-spacing:var(--tracking-wide);margin-top:var(--space-12);margin-bottom:0}.about-media-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-3);align-items:start;justify-content:start;width:100%;margin-top:var(--space-4);padding-top:var(--space-4);grid-column:1 / -1}.about-media-item{width:100%}.about-image-wrapper{display:flex;flex-direction:column}.about-video-wrapper{display:flex;flex-direction:column;position:relative}.about-photo{width:100%;aspect-ratio:1 / 1;height:auto;border-radius:8px;display:block;object-fit:cover}.image-caption{font-family:var(--font-family-mono);font-size:11px;color:var(--text-secondary);margin-top:var(--space-1);text-align:center;letter-spacing:.03em}.about-video{width:100%;aspect-ratio:1 / 1;height:auto;border-radius:8px;object-fit:cover;cursor:pointer;transition:transform var(--duration-normal) var(--ease-out),opacity var(--duration-fast) var(--ease-out)}.about-video-wrapper:after{content:"Click to unmute";position:absolute;bottom:8px;left:8px;padding:6px 10px;background:#000000a6;color:#fff;font-family:var(--font-family-mono);font-size:10px;letter-spacing:.03em;border-radius:6px;opacity:0;transform:translateY(4px);transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);pointer-events:none}.about-video-wrapper:hover:after{opacity:1;transform:translateY(0)}.about-video-wrapper.video-unmuted:after{content:"Click to mute"}.about-media-item{transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.about-media-item:hover{transform:var(--hover-lift)}.about-hero{max-width:700px}.about-statement{font-family:var(--font-family-serif);font-size:40px;font-weight:300;line-height:1.3;color:var(--text-primary);margin:0}.about-timeline{width:100%;align-self:end}.about-timeline h2{font-family:var(--font-family-mono);font-size:var(--font-body);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-3);color:var(--text-secondary)}.about-timeline .timeline{display:grid;grid-template-columns:max-content max-content 1fr;column-gap:var(--space-3);row-gap:var(--space-2);align-items:baseline}.about-title{font-size:var(--font-display);letter-spacing:var(--tracking-wide)}.timeline-item{display:contents}.year,.timeline-item .company{font-family:var(--font-family-mono);font-size:var(--font-sm);color:var(--text-secondary)}.timeline-item .role{font-family:var(--font-family-mono);font-size:var(--font-sm);font-weight:400;color:var(--text-primary)}.about-text{max-width:700px;display:flex;flex-direction:column;gap:var(--space-3);font-family:var(--font-family-mono);font-size:var(--font-sm);line-height:var(--leading-relaxed);font-weight:400;color:var(--text-secondary)}.about-text p:has(+.about-list){margin-bottom:calc(var(--space-2) * -1)}.about-list{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--font-h3);line-height:var(--leading-normal);font-weight:300}.about-list li{position:relative;padding-left:1.25rem}.about-list li:before{content:"•";position:absolute;left:0;color:var(--accent-red);font-size:.9em;line-height:inherit}.about-cta{font-weight:400;color:var(--text-primary);margin-top:var(--space-2)}.about-details{max-width:700px;display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid rgba(26,26,26,.1)}.detail-item{display:flex;flex-direction:column;gap:var(--space-1);align-items:flex-start}.detail-value{font-family:var(--font-family-mono);font-size:var(--font-sm);color:var(--text-secondary);font-weight:400}@media(max-width:1100px){.about-content{grid-template-columns:1fr}.about-side{order:2}.about-main{order:1}.about-media-row{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}}@media(max-width:720px){.about-media-row{grid-template-columns:repeat(2,1fr)}.about-title{font-size:var(--font-h1)}.about-text,.about-list{font-size:var(--font-body-lg);line-height:var(--leading-relaxed)}}@media(prefers-reduced-motion:reduce){.carousel-track{animation:none!important}}.project-detail-section{display:flex;flex-direction:column;width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.project-hero{display:flex;flex-direction:column;padding:var(--space-section) 0 var(--space-6);gap:var(--space-3)}.back-link{font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);text-decoration:none;transition:var(--transition-color)}.back-link:hover{color:var(--accent-red)}.project-detail-title{font-family:var(--font-family-serif);font-size:var(--font-display-lg);font-weight:300;letter-spacing:-.03em;line-height:1.1;margin:0}.project-detail-oneliner{font-family:var(--font-family-serif);font-size:var(--font-subhead);font-weight:300;line-height:1.4;color:var(--text-secondary);max-width:600px}.project-meta-inline{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-top:var(--space-2)}.project-meta-inline .meta-separator{color:#0003}.project-gallery{display:flex;flex-direction:column;gap:var(--space-3)}.gallery-main{width:100%;max-width:900px;aspect-ratio:16/9;overflow:hidden;border-radius:12px;background:var(--bg-grouped)}.gallery-main-image{width:100%;height:100%;object-fit:cover;transition:opacity .8s var(--ease-out),transform var(--duration-slow) var(--ease-out)}.gallery-main:hover .gallery-main-image{transform:var(--hover-scale-subtle)}.gallery-dots{display:flex;gap:var(--space-2);justify-content:center}.gallery-dot{width:8px;height:8px;border-radius:50%;background:#00000026;border:none;padding:0;cursor:pointer;transition:background-color var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.gallery-dot:hover{background:#0000004d}.gallery-dot.active{background:var(--text-primary);transform:scale(1.2)}.project-content-wrapper{padding:var(--space-6) 0 var(--space-section);display:flex;flex-direction:column;gap:var(--space-content)}.section-label{font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:var(--space-4)}.project-summary{font-family:var(--font-family-serif);font-size:22px;font-weight:300;line-height:1.6;color:var(--text-primary);max-width:700px}.project-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.tools-column{display:flex;flex-direction:column;gap:var(--space-3)}.tools-column h3{font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin:0}.tools-list{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;padding:0;margin:0}.tools-list li{font-family:var(--font-family-mono);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--text-primary);background:#0000000a;padding:6px 12px;border-radius:100px;border:1px solid rgba(0,0,0,.08)}.project-section-block h2{font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-weight:400;margin-bottom:var(--space-4)}.project-section-block p{font-family:var(--font-family-serif);font-size:22px;font-weight:300;line-height:1.6;color:var(--text-primary);white-space:pre-line;max-width:700px}.project-footer-nav{padding:var(--space-6) 0 var(--space-section);border-top:1px solid rgba(0,0,0,.06)}.footer-nav-label{font-family:var(--font-family-mono);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);display:block;margin-bottom:var(--space-2)}.footer-nav-link{font-family:var(--font-family-serif);font-size:var(--font-h2);font-weight:300;color:var(--text-primary);text-decoration:none;transition:var(--transition-color)}.footer-nav-link:hover{color:var(--accent-red)}.project-detail-header,.project-detail-meta,.meta-item,.meta-label,.meta-value,.project-detail-image,.detail-image,.gallery-thumbnails,.gallery-thumb,.project-detail-content,.project-detail-section-block,.project-skills,.skills-list,.skill-tag,.project-software,.software-list,.software-tag{display:none}@media(max-width:1500px){:root{--gap: var(--mobile-gap)}nav{padding:var(--space-2) var(--space-4)}main{padding:var(--space-12) var(--space-4) var(--gap)}.hero h1,.hero .hero-title{font-size:36px}.role{font-size:var(--font-h3)}.carousel-section h2{font-size:36px;padding:0 var(--space-2)}.carousel-item{width:300px;height:400px}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-1280px)}}.projects-grid{grid-template-columns:1fr;gap:var(--space-2)}.modal-content{grid-template-columns:1fr;gap:var(--space-5)}.modal-placeholder{height:400px}.work-item{grid-template-columns:1fr;gap:var(--space-4)}.work-item-title{font-size:36px}.work-header h1,.archive-header h1,.about-title{font-size:var(--font-h1)}.archive-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.project-detail-section{padding:0 var(--space-4)}.gallery-main{max-width:800px}.project-hero{padding:var(--space-10) 0 var(--space-5)}.project-detail-title{font-size:48px}.project-detail-oneliner{font-size:20px}.project-meta-inline{flex-wrap:wrap}.project-content-wrapper{padding:var(--space-5) 0 var(--space-10);gap:var(--space-8)}.project-tools-grid{gap:var(--space-6)}}@media(max-width:1024px){.about-content{grid-template-columns:1fr;gap:var(--space-6)}.about-main{padding-right:0}.about-media-row{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.about-timeline .timeline{grid-template-columns:max-content 1fr;column-gap:var(--space-3)}.about-timeline .timeline .company{grid-column:1 / -1;margin-bottom:var(--space-1)}.nav-links{gap:var(--space-3)}.modal-content{width:95%;max-height:85vh}}@media(max-width:768px){nav{display:flex;justify-content:space-between}nav .logo{font-size:var(--font-sm)}.mobile-menu-toggle{display:flex}.nav-links{position:fixed;top:0;right:0;width:100%;height:100vh;background:#fafcfdfa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;justify-content:center;align-items:center;gap:var(--space-4);transform:translate(100%);transition:transform var(--duration-normal) var(--ease-out);z-index:100}.nav-links.mobile-open{transform:translate(0)}.nav-links .nav-link{font-size:var(--font-h2);font-family:var(--font-family-serif);font-weight:300;color:var(--text-primary);opacity:0;transform:translateY(20px);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out),color var(--duration-fast) var(--ease-out)}.nav-links.mobile-open .nav-link{opacity:1;transform:translateY(0)}.nav-links.mobile-open .nav-link:nth-child(1){transition-delay:.1s}.nav-links.mobile-open .nav-link:nth-child(2){transition-delay:.15s}.nav-links.mobile-open .nav-link:nth-child(3){transition-delay:.2s}.nav-links .nav-link:hover{color:var(--accent-red);transform:scale(1.05)}.hero h1,.hero .hero-title{font-size:var(--font-h2);white-space:normal}.carousel-item{width:250px;height:350px}.modal-close{top:var(--space-2);right:var(--space-2);font-size:36px}.modal-title{font-size:36px}.project-detail-section{padding:0 var(--space-3)}.project-detail-title{font-size:36px}.project-detail-oneliner{font-size:var(--font-body-lg)}.project-meta-inline{flex-direction:column;gap:var(--space-1)}.project-meta-inline .meta-separator{display:none}.project-tools-grid{grid-template-columns:1fr;gap:var(--space-6)}.project-summary,.project-section-block p{font-size:var(--font-body-lg)}.project-footer-nav{padding:var(--space-6) 0}.footer-nav-link{font-size:var(--font-h3)}.scroll-to-top{bottom:var(--space-3);right:var(--space-3);width:40px;height:40px}}.scroll-to-top{position:fixed;bottom:var(--space-5);right:var(--space-5);width:48px;height:48px;background:var(--accent-red);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity var(--duration-normal) var(--ease-out),visibility var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);z-index:1000;box-shadow:var(--shadow-accent)}.scroll-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top:hover{transform:var(--hover-lift) var(--hover-scale-emphasis);box-shadow:0 6px 20px #4a0f1e59}.scroll-to-top:active{transform:translateY(0) scale(.95)}@keyframes fadeScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.work-item-image img{view-transition-name:project-image}::view-transition-old(project-image),::view-transition-new(project-image){animation-duration:.4s;animation-timing-function:cubic-bezier(.4,0,.2,1)}::view-transition-new(project-image){animation-name:fadeScale}@media(prefers-reduced-motion:no-preference){.work-header h1,.hero h1,.hero .hero-title{animation:slideUp .6s cubic-bezier(.16,1,.3,1)}.work-item{animation:slideUp .5s cubic-bezier(.16,1,.3,1);animation-fill-mode:both}.work-item:nth-child(1){animation-delay:.05s}.work-item:nth-child(2){animation-delay:.1s}.work-item:nth-child(3){animation-delay:.15s}.work-item:nth-child(4){animation-delay:.2s}.work-item:nth-child(5){animation-delay:.25s}.archive-item{opacity:0;transform:translateY(20px)}.archive-item.archive-animate{opacity:1;transform:translateY(0);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}}@media(prefers-reduced-motion:reduce){.work-item,.work-header h1,.hero h1,.hero .hero-title,.archive-item,.archive-header h1{animation:none!important}}img.lazy{opacity:0;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);transition:opacity var(--duration-normal) var(--ease-out);min-height:200px}img.lazy[src]{opacity:1;background:none}.archive-image.lazy{background:linear-gradient(135deg,#f5f5f5,#e8e8e8);animation:shimmer 1.5s infinite;background-size:400px 100%}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.archive-image.lazy[src]{animation:none;background:none}.chat-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:6px;background:transparent;border:none;border-radius:50%;cursor:none;transition:transform var(--duration-normal) var(--ease-out),background-color var(--duration-fast) var(--ease-out);margin-left:var(--space-3);will-change:transform;contain:none}.chat-trigger:hover{transform:scale(1.15);background:#4a0f1e1a}.chat-trigger:hover .chat-trigger-icon{transform:rotate(15deg)}.chat-trigger:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.chat-trigger-icon{width:24px;height:24px;object-fit:contain;transition:transform var(--duration-normal) var(--ease-out)}@keyframes chatPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.chat-trigger.has-update .chat-trigger-icon{animation:chatPulse 1s ease-in-out 3}.chat-trigger-mobile{display:none;position:fixed;bottom:16px;right:16px;width:44px;height:44px;padding:10px;background:var(--bg-color);border:1px solid rgba(26,26,26,.08);border-radius:50%;cursor:none;z-index:99;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;transition:transform var(--duration-normal) var(--ease-out),opacity var(--duration-normal) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.chat-trigger-mobile:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003,0 3px 6px #0000001f}.chat-trigger-mobile:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.chat-trigger-mobile .chat-trigger-icon{width:24px;height:24px}.chat-trigger-mobile.hidden{opacity:0;pointer-events:none;transform:translateY(20px)}.chat-backdrop{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity var(--duration-fast) var(--ease-out),visibility var(--duration-fast) var(--ease-out);z-index:10001}.chat-backdrop.active{opacity:1;visibility:visible}.chat-sidebar{position:fixed;top:0;right:0;width:400px;max-width:100vw;height:100vh;height:100dvh;background:#fafcfdf2;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-left:1px solid rgba(26,26,26,.08);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--duration-fast) var(--ease-out);z-index:10002;box-shadow:-4px 0 24px #00000014}.chat-sidebar.open{transform:translate(0)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3);border-bottom:1px solid rgba(26,26,26,.08);flex-shrink:0;gap:var(--space-2)}.chat-title{font-family:var(--font-family-serif);font-size:var(--font-body-lg);font-weight:300;color:var(--text-primary);margin:0;flex:1}.chat-header-actions{display:flex;align-items:center;gap:var(--space-1)}.chat-clear,.chat-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:none;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.chat-clear:hover,.chat-close:hover{background:#4a0f1e14;color:var(--accent-red)}.chat-clear:focus-visible,.chat-close:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.chat-clear svg,.chat-close svg{width:18px;height:18px}.chat-skip-link{position:absolute;top:-100px;left:50%;transform:translate(-50%);background:var(--accent-red);color:#fff;padding:var(--space-2) var(--space-3);border-radius:6px;font-size:var(--font-sm);z-index:10003;transition:top var(--duration-fast) var(--ease-out)}.chat-skip-link:focus{top:var(--space-2)}.chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);justify-content:flex-start;align-items:stretch}.chat-welcome{color:var(--text-secondary);font-size:var(--font-sm);line-height:var(--leading-relaxed);margin:0;padding:0;flex-shrink:0}.chat-welcome p{margin:0 0 var(--space-4);font-size:var(--font-body)}.chat-suggestions-label{font-family:var(--font-family-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-red);margin-bottom:var(--space-2)}.chat-suggestions{display:flex;flex-direction:column;gap:var(--space-1)}.chat-suggestion{font-family:var(--font-family-base);font-size:var(--font-sm);color:var(--text-secondary);padding:var(--space-2);background:#00000008;border:1px solid transparent;border-radius:8px;cursor:none;text-align:left;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.chat-suggestion:hover{background:#4a0f1e0f;border-color:#4a0f1e26;color:var(--accent-red)}.chat-suggestion:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.chat-message{max-width:85%;padding:var(--space-2) var(--space-3);border-radius:12px;font-family:var(--font-family-base);font-size:14px;line-height:var(--leading-relaxed);animation:messageSlideIn var(--duration-fast) var(--ease-out);position:relative}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message-user{align-self:flex-end;background:var(--accent-red);color:#fff;border-bottom-right-radius:4px}.chat-message-assistant{align-self:flex-start;background:#0000000a;color:var(--text-primary);border-bottom-left-radius:4px}.chat-message a{color:inherit;text-decoration:underline;text-underline-offset:2px}.chat-message-user a{color:#fff}.chat-message-assistant a{color:var(--accent-red)}.chat-message strong{font-weight:600}.chat-message ul,.chat-message ol{margin:var(--space-1) 0;padding-left:var(--space-3)}.chat-message li{margin-bottom:4px}.chat-message-wrapper{position:relative;display:flex;flex-direction:column;flex-shrink:0;padding-bottom:var(--space-2)}.chat-message-time{font-family:var(--font-family-mono);font-size:10px;color:var(--text-secondary);margin-top:4px;opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.chat-message-wrapper:has(.chat-message-user) .chat-message-time{align-self:flex-end}.chat-message-wrapper:has(.chat-message-assistant) .chat-message-time{align-self:flex-start}.chat-message-wrapper:hover .chat-message-time{opacity:.6}.chat-message-truncated{max-height:200px;overflow:hidden;position:relative}.chat-message-truncated:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,#0000000a);pointer-events:none}.chat-show-more{font-family:var(--font-family-mono);font-size:11px;color:var(--accent-red);background:none;border:none;padding:var(--space-1) 0;cursor:none;text-transform:uppercase;letter-spacing:.05em}.chat-show-more:hover{text-decoration:underline}.chat-loading{padding:var(--space-2) var(--space-3)}.typing-indicator{display:flex;gap:4px;align-items:center}.typing-indicator span{width:6px;height:6px;background:var(--text-secondary);border-radius:50%;animation:typingPulse 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-scroll-bottom{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:var(--bg-color);border:1px solid rgba(26,26,26,.12);border-radius:20px;padding:6px 12px;font-family:var(--font-family-mono);font-size:11px;color:var(--text-secondary);cursor:none;opacity:0;visibility:hidden;transition:opacity var(--duration-fast) var(--ease-out),visibility var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-sm);z-index:1}.chat-scroll-bottom.visible{opacity:1;visibility:visible}.chat-scroll-bottom:hover{background:var(--bg-secondary)}.chat-input-container{display:flex;gap:var(--space-2);padding:var(--space-3);border-top:1px solid rgba(26,26,26,.08);background:#fafcfdcc;flex-shrink:0}.chat-input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid rgba(26,26,26,.12);border-radius:8px;font-family:var(--font-family-base);font-size:14px;resize:none;background:#fff;color:var(--text-primary);min-height:40px;max-height:120px;transition:border-color var(--duration-fast) var(--ease-out);cursor:none}.chat-input:focus{outline:none;border-color:var(--accent-red)}.chat-input::placeholder{color:var(--text-secondary);opacity:.6}.chat-input:disabled{opacity:.6;cursor:not-allowed}.chat-send{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-red);color:#fff;border:none;border-radius:8px;cursor:none;flex-shrink:0;transition:transform var(--duration-fast) var(--ease-out),opacity var(--duration-fast) var(--ease-out)}.chat-send:hover:not(:disabled){transform:scale(1.05)}.chat-send:disabled{opacity:.5;cursor:not-allowed}.chat-send:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.chat-send svg{width:18px;height:18px}.chat-error{background:#dc35451a;border:1px solid rgba(220,53,69,.2);color:#dc3545;padding:var(--space-2) var(--space-3);border-radius:8px;font-size:var(--font-sm)}.chat-error code{font-family:var(--font-family-mono);font-size:11px;display:block;margin-top:var(--space-1);word-break:break-all}@media(max-width:768px){.chat-trigger{display:none}.chat-trigger-mobile{display:flex}.chat-sidebar{width:100vw;transform:translateY(100%);border-left:none;border-top:1px solid rgba(26,26,26,.08)}.chat-sidebar.open{transform:translateY(0)}.chat-input-container{padding-bottom:max(var(--space-3),env(safe-area-inset-bottom))}}@media(prefers-reduced-motion:reduce){.chat-sidebar,.chat-backdrop,.chat-message,.chat-trigger,.chat-trigger-mobile,.typing-indicator span{animation:none;transition:none}.chat-sidebar.open{transform:translate(0)}.chat-trigger.has-update .chat-trigger-icon{animation:none}@media(max-width:768px){.chat-sidebar.open{transform:translateY(0)}}}@font-face{font-family:Karla Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/_astro/karla-latin-ext-wght-normal.Dq0rrjgs.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Karla Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/_astro/karla-latin-wght-normal.C3-ma4ov.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-vietnamese-300-normal.CrayiRmU.woff2) format("woff2"),url(/_astro/crimson-pro-vietnamese-300-normal.Dnrjoigy.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-latin-ext-300-normal.DO8p3e_z.woff2) format("woff2"),url(/_astro/crimson-pro-latin-ext-300-normal.CQpSIbk0.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-latin-300-normal.BdPotd8_.woff2) format("woff2"),url(/_astro/crimson-pro-latin-300-normal.Ilu4iuVU.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-vietnamese-400-normal.C3m3Wqkz.woff2) format("woff2"),url(/_astro/crimson-pro-vietnamese-400-normal.CEHt5KbE.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-latin-ext-400-normal.B3ID4PT2.woff2) format("woff2"),url(/_astro/crimson-pro-latin-ext-400-normal.BWiDT69a.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-latin-400-normal.B4SlG4wx.woff2) format("woff2"),url(/_astro/crimson-pro-latin-400-normal.BzhyrSeK.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-vietnamese-300-italic.CgHv8RIy.woff2) format("woff2"),url(/_astro/crimson-pro-vietnamese-300-italic.CJ5-UQ-Y.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-latin-ext-300-italic.CRX3ebte.woff2) format("woff2"),url(/_astro/crimson-pro-latin-ext-300-italic.BzyJCYGt.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:300;src:url(/_astro/crimson-pro-latin-300-italic.BNT9kYf3.woff2) format("woff2"),url(/_astro/crimson-pro-latin-300-italic.D8v7NOB7.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-vietnamese-400-italic.NXtqStND.woff2) format("woff2"),url(/_astro/crimson-pro-vietnamese-400-italic.XRYdg6KH.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-latin-ext-400-italic.C6Jf9c7d.woff2) format("woff2"),url(/_astro/crimson-pro-latin-ext-400-italic.DuC2towc.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:italic;font-display:swap;font-weight:400;src:url(/_astro/crimson-pro-latin-400-italic.BJbyz_Tg.woff2) format("woff2"),url(/_astro/crimson-pro-latin-400-italic.iL-nM4zC.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--accent-red);color:#fff;padding:.75rem 1.5rem;border-radius:4px;z-index:9999;font-family:var(--font-sans);font-size:.875rem;text-decoration:none;transition:top .2s ease}.skip-link:focus{top:1rem;outline:2px solid var(--accent-red);outline-offset:2px}header{view-transition-name:main-header}::view-transition-old(main-header),::view-transition-new(main-header){animation-duration:.2s;animation-timing-function:cubic-bezier(.4,0,.2,1);mix-blend-mode:normal}.site-footer{view-transition-name:site-footer}::view-transition-old(site-footer),::view-transition-new(site-footer){animation-duration:.2s;animation-timing-function:cubic-bezier(.4,0,.2,1);mix-blend-mode:normal}main{view-transition-name:main-content}::view-transition-old(main-content){animation:.2s cubic-bezier(.4,0,1,1) both page-fade-out}::view-transition-new(main-content){animation:.3s cubic-bezier(.16,1,.3,1) 50ms both page-fade-in}@keyframes page-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes page-fade-in{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.page-title,.hero-tagline,.about-intro,.error-code{view-transition-name:page-title}::view-transition-old(page-title){animation:.2s ease-out both title-fade-out}::view-transition-new(page-title){animation:.35s cubic-bezier(.16,1,.3,1) 80ms both title-fade-in}@keyframes title-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes title-fade-in{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}[data-transition-name]{view-transition-name:var(--transition-name)}::view-transition-old(project-image),::view-transition-new(project-image){animation-duration:.35s;animation-timing-function:cubic-bezier(.16,1,.3,1);mix-blend-mode:normal}.scroll-to-top{view-transition-name:scroll-to-top}::view-transition-old(scroll-to-top),::view-transition-new(scroll-to-top){animation:none;mix-blend-mode:normal}.nav-link.active:after{view-transition-name:nav-indicator}@media(prefers-reduced-motion:reduce){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation-duration:.01ms!important;animation-delay:0ms!important}}::view-transition-old(root),::view-transition-new(root){animation-duration:.25s}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
