.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,.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.typewriter-cursor{display:inline;color:var(--accent-red);animation:typewriter-blink 2s step-end infinite;margin-left:.05em;font-weight:300}@keyframes typewriter-blink{0%,49%{opacity:1}50%,to{opacity:0}}@media(prefers-reduced-motion:reduce){.typewriter-cursor{display:none}}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-color) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.img-loading{opacity:0;transition:opacity .3s ease}.img-loaded{opacity:1}@media(prefers-reduced-motion:reduce){.skeleton{animation:none;background:var(--bg-secondary)}.img-loading{opacity:1;transition:none}}:root{--bg-color: #fafcfd;--bg-secondary: #f5f5f5;--text-primary: #2f2f2f;--text-secondary: #5a5a5a;--accent-red: #4a0f1e;--link-color: #5f5f5f;--font-family-base: "Karla Variable", "Helvetica Neue", Arial, sans-serif;--font-family-serif: "Crimson Pro Variable", 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: 72px;--font-display: 80px;--font-h1: 56px;--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);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--border-light: rgba(26, 26, 26, .08);--border-medium: rgba(26, 26, 26, .12);--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)}html{scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}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:auto}@media(hover:hover){html.custom-cursor-enabled,html.custom-cursor-enabled body{cursor:none}html.custom-cursor-enabled *,html.custom-cursor-enabled *:before,html.custom-cursor-enabled *:after{cursor:none!important}}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;will-change:transform;contain:layout style;transition:opacity .2s var(--ease-out)}.cursor-trail{position:fixed;inset:0;pointer-events:none;z-index:99998}.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-trail,.cursor-text{display:none!important}}@media(hover:none){a:active,button:active,[role=button]:active{opacity:.7;transition:opacity .1s ease}.work-card:active,.fashion-card:active,.archive-item:active{transform:scale(.98);transition:transform .1s ease}}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)}a,button,[role=button],.clickable{cursor:pointer}input,textarea,select{cursor:text}.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-layout .section-title{font-family:var(--font-family-serif);font-size:26px;font-weight:300;color:var(--accent-red);position:sticky;top:100px;align-self:start;text-transform:uppercase;letter-spacing:.05em}@media(max-width:1024px){.section-layout{grid-template-columns:1fr;padding:var(--space-lg) var(--space-4)}.section-layout .section-title{position:static;margin-bottom:var(--space-md)}}@media(max-width:768px){.section-layout{padding:var(--space-lg) var(--space-3)}.section-layout .section-title{margin-bottom:var(--space-4)}}.section-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.section-title{font-family:var(--font-family-serif);font-size:26px;font-weight:300;color:var(--accent-red);margin:0;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em}.section-line{flex:1;height:1px;background:linear-gradient(90deg,var(--accent-red) 0%,transparent 100%);opacity:.3}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 var(--border-light);contain:layout style}nav{max-width:var(--max-width);margin:0 auto;padding:16px 64px;display:flex;justify-content:space-between;align-items:center}nav .logo{position:relative;font-family:var(--font-family-serif);font-size:22px;font-weight:400;color:var(--text-primary);text-decoration:none;letter-spacing:.01em;display:inline-block;padding-bottom:2px}nav .logo:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:1.5px;background-color:var(--accent-red);transform:scaleX(0);transform-origin:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.nav-home-link{text-decoration:none}.nav-links{display:flex;gap:var(--space-5);position:absolute;left:50%;transform:translate(-50%)}.nav-link{position:relative;font-family:var(--font-family-mono);color:var(--text-secondary);text-decoration:none;font-size:12px;font-weight:400;display:inline-block;letter-spacing:.08em;text-transform:uppercase;padding:.5rem 0}.nav-link:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:1.5px;background-color:var(--accent-red);transform:scaleX(0);transform-origin:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}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{color:var(--accent-red)}nav .logo:hover:before{transform:scaleX(1)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:before{transform:scaleX(1)}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 .3s var(--ease-spring)}.nav-link.active{color:var(--text-primary)}.nav-link.active:before,.nav-link[aria-current=page]:before{transform:scaleX(1)}.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:var(--radius-sm)}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:120px 0 80px}.site-footer{max-width:var(--max-width);margin:0 auto;padding:var(--space-10) var(--space-6) max(var(--space-8),env(safe-area-inset-bottom));display:flex;justify-content:center;border-top:1px solid var(--border-light);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;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1)}.footer-built-line{white-space:nowrap}.footer-controls{display:flex;align-items:center;gap:var(--space-1)}.footer-toggle{border:1px solid var(--border-medium);background:transparent;color:var(--text-secondary);border-radius:var(--radius-full);font-family:var(--font-family-mono);font-size:10px;line-height:1.2;padding:12px 14px;text-transform:uppercase;letter-spacing:.05em;transition:border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out)}.footer-toggle:hover{border-color:#4a0f1e73;color:var(--accent-red);background:#4a0f1e0a}.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)}.footer-built{align-items:center;text-align:center}.footer-controls{justify-content:center}}.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}.back-link:focus-visible,.error-link:focus-visible{outline:2px solid var(--accent-red);outline-offset:4px}.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:var(--radius-sm);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}.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}.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:var(--radius-lg);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:var(--radius-md);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 var(--border-light)}.filter-btn{padding:.5rem 1rem;border:1px solid var(--border-medium);background:transparent;border-radius:var(--radius-full);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 var(--border-medium);border-radius:var(--radius-sm);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:var(--radius-md);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-hero{max-width:700px}.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:var(--radius-lg);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;position:relative;transition:background-color var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.gallery-dot:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px}.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:var(--radius-full);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)}.meta-item,.meta-label,.meta-value,.skill-tag{display:none}@media(max-width:1500px){:root{--gap: var(--mobile-gap)}nav{padding:16px 32px}main{padding:96px 0 48px}.hero h1,.hero .hero-title{font-size:36px}.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){.nav-links{gap:var(--space-3)}}@media(max-width:768px){header{backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px)}nav{display:flex;justify-content:space-between;padding:12px 16px}nav .logo{font-size:20px}.mobile-menu-toggle{display:flex}.nav-links{position:fixed;top:0;left:auto;right:0;width:100%;height:100vh;height:100dvh;background:#fafcfdfa;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);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}.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)}}@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)}}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes slideFromLeft{to{opacity:1;transform:translate(0)}}@keyframes expandLine{to{opacity:1;transform:scaleX(1)}}.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:pointer;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 var(--border-light);border-radius:50%;cursor:pointer;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 var(--border-light);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 var(--border-light);flex-shrink:0;gap:var(--space-2);background:var(--bg-color);position:relative;z-index:1}.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-text{height:32px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;background:#4a0f1e0a;border:1px solid rgba(74,15,30,.16);border-radius:var(--radius-full);color:var(--accent-red);font-family:var(--font-family-mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;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)}.chat-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.chat-clear-text:hover,.chat-close:hover{background:#4a0f1e14;color:var(--accent-red)}.chat-clear-text:focus-visible,.chat-close:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}.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:var(--radius-sm);font-size:var(--font-sm);z-index:10003;transition:top var(--duration-fast) var(--ease-out),visibility var(--duration-fast);visibility:hidden}.chat-sidebar.open .chat-skip-link:focus{top:var(--space-2);visibility:visible}.chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--space-4);padding-top:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);justify-content:flex-start;align-items:stretch;scroll-padding-top:var(--space-3);scroll-padding-bottom:var(--space-3)}.chat-welcome{color:var(--text-secondary);font-size:var(--font-sm);line-height:var(--leading-relaxed);margin:0;margin-top:var(--space-2);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:var(--radius-md);cursor:pointer;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:var(--radius-lg);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-streaming:after{content:"";display:inline-block;width:2px;height:1.1em;background:var(--text-primary);margin-left:2px;vertical-align:text-bottom;animation:cursor-blink 1s step-end infinite}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@media(prefers-reduced-motion:reduce){.chat-message-streaming:after{animation:none;opacity:1}}.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:pointer;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 var(--border-medium);border-radius:var(--radius-lg);padding:6px 12px;font-family:var(--font-family-mono);font-size:11px;color:var(--text-secondary);cursor:pointer;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;flex-direction:column;gap:var(--space-2);padding:var(--space-3);border-top:1px solid var(--border-light);background:#fafcfdcc;flex-shrink:0}.chat-draft-notice{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);font-size:11px;color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#00000005;padding:6px 8px}.chat-draft-dismiss{border:none;background:transparent;color:var(--accent-red);font-family:var(--font-family-mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.chat-turnstile{display:flex;justify-content:center;width:100%}.chat-privacy-note{margin:0;font-size:11px;color:var(--text-secondary);opacity:.8;line-height:1.4}.chat-input-row{display:flex;gap:var(--space-2);width:100%}.chat-input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--border-medium);border-radius:var(--radius-md);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:text}.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:var(--radius-md);cursor:pointer;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:var(--radius-md);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}.chat-retry{margin-top:var(--space-1);border:1px solid rgba(220,53,69,.35);background:#dc354514;color:#9f1c2f;border-radius:var(--radius-sm);padding:6px 10px;font-family:var(--font-family-mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.chat-retry:hover:not(:disabled){background:#dc354529}.chat-trigger-nav{display:none}@media(max-width:768px){.chat-trigger,.chat-trigger-mobile{display:none}.chat-trigger-nav{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;background:transparent;border:none;font-family:var(--font-family-serif);font-size:var(--font-h2);font-weight:300;text-transform:none;letter-spacing:normal;color:var(--text-primary);cursor:pointer;margin-top:var(--space-3);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 .chat-trigger-nav{opacity:1;transform:translateY(0);transition-delay:.25s}.chat-trigger-nav .chat-trigger-icon{width:24px;height:24px}.chat-trigger-nav:hover{color:var(--accent-red);transform:scale(1.05)}.chat-sidebar{width:100vw;transform:translateY(100%);border-left:none;border-top:1px solid var(--border-light)}.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)}}}:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}html[data-motion=reduce]{scroll-behavior:auto!important}html[data-motion=reduce] *,html[data-motion=reduce] *:before,html[data-motion=reduce] *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.defer-render{content-visibility:auto;contain-intrinsic-size:auto 900px}@font-face{font-family:Crimson Pro Variable;font-style:italic;font-display:swap;font-weight:200 900;src:url(/_astro/crimson-pro-vietnamese-wght-italic.Dpzp2Zc3.woff2) format("woff2-variations");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 Variable;font-style:italic;font-display:swap;font-weight:200 900;src:url(/_astro/crimson-pro-latin-ext-wght-italic.BwehhlXF.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:Crimson Pro Variable;font-style:italic;font-display:swap;font-weight:200 900;src:url(/_astro/crimson-pro-latin-wght-italic.CkPs-Rv6.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}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--accent-red);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-sm);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}.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}}
