@font-face{font-family:DM Sans;font-style:normal;font-weight:400 500;font-display:swap;src:url(/fonts/dm-sans.woff2) format("woff2");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:DM Sans;font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/dm-sans-italic.woff2) format("woff2");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:Space Grotesk;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/space-grotesk.woff2) format("woff2");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:JetBrains Mono;font-style:normal;font-weight:400 500;font-display:swap;src:url(/fonts/jetbrains-mono.woff2) format("woff2");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}:root{--color-bg: #F8F7F4;--color-bg-secondary: #EFEDE8;--color-bg-elevated: #FFFFFF;--color-text: #1A1918;--color-text-secondary: #6B6966;--color-text-tertiary: #706C69;--color-accent: #2C2A28;--color-border: #D4D2CD;--color-border-light: #E8E6E1;--color-highlight: #C4A77D;--color-highlight-dark: #A8895F;--color-highlight-rgb: 196, 167, 125;--color-glow: rgba(196, 167, 125, .15);--color-glow-strong: rgba(196, 167, 125, .3);--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .8rem + .35vw, 1rem);--text-base: clamp(1rem, .9rem + .5vw, 1.125rem);--text-lg: clamp(1.125rem, 1rem + .6vw, 1.375rem);--text-xl: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem);--text-2xl: clamp(2rem, 1.5rem + 2.5vw, 3.5rem);--text-3xl: clamp(2.5rem, 1.8rem + 3.5vw, 5rem);--text-hero: clamp(3rem, 2rem + 5vw, 8rem);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--space-5xl: 8rem;--container-max: 1400px;--container-padding: clamp(1rem, 3vw, 3rem);--grid-gap: clamp(1rem, 2vw, 1.5rem);--section-padding: clamp(4rem, 10vw, 8rem);--border-radius: 2px;--border-radius-lg: 8px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--shadow-sm: 0 1px 2px rgba(26, 25, 24, .04);--shadow-md: 0 4px 6px -1px rgba(26, 25, 24, .05), 0 2px 4px -1px rgba(26, 25, 24, .03);--shadow-lg: 0 10px 15px -3px rgba(26, 25, 24, .08), 0 4px 6px -2px rgba(26, 25, 24, .04);--shadow-xl: 0 20px 25px -5px rgba(26, 25, 24, .1), 0 10px 10px -5px rgba(26, 25, 24, .04);--shadow-glow: 0 0 40px rgba(196, 167, 125, .15);--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-in-out-quart: cubic-bezier(.76, 0, .24, 1);--card-transition-duration: .6s;--card-stagger-delay: .08s}html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:hidden}.lenis.lenis-smooth iframe{pointer-events:none}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);overflow-x:hidden;position:relative}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")}@media(hover:none)and (pointer:coarse){body:before{display:none}}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:1.1;letter-spacing:-.02em}.text-mono{font-family:var(--font-mono);font-size:.85em;letter-spacing:.02em}.text-label{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary)}.split-char{display:inline-block;will-change:transform,opacity}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding);padding-left:max(var(--container-padding),var(--safe-area-left));padding-right:max(var(--container-padding),var(--safe-area-right))}.section{padding:var(--section-padding) 0}.section--bordered{border-top:1px solid var(--color-border)}.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;background:transparent;z-index:1001;pointer-events:none}.scroll-progress__bar{height:100%;background:linear-gradient(90deg,var(--color-highlight),var(--color-accent));transform-origin:left;transform:scaleX(0);will-change:transform}.cursor{display:none}@media(hover:hover)and (pointer:fine){.cursor{display:block;position:fixed;top:0;left:0;pointer-events:none;z-index:10000;mix-blend-mode:difference}.cursor__dot{width:8px;height:8px;background:#fff;border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:transform .15s ease,width .2s ease,height .2s ease}.cursor__ring{width:40px;height:40px;border:1px solid rgba(255,255,255,.5);border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:transform .08s ease,width .3s ease,height .3s ease,border-color .2s ease}.cursor--hover .cursor__dot{transform:translate(-50%,-50%) scale(2)}.cursor--hover .cursor__ring{width:60px;height:60px;border-color:var(--color-highlight)}.cursor--click .cursor__dot{transform:translate(-50%,-50%) scale(.5)}body:has(.cursor) *{cursor:none!important}}.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:var(--space-lg) 0;padding-top:calc(var(--space-lg) + var(--safe-area-top));background:transparent;transition:background var(--transition-base),box-shadow var(--transition-base)}@media(max-width:767px){.header{padding:var(--space-md) 0;padding-top:calc(var(--space-md) + var(--safe-area-top))}}.header--scrolled{background:#f8f7f4eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-sm)}.header__inner{display:flex;justify-content:space-between;align-items:center}.header__logo{font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;letter-spacing:.15em;text-transform:uppercase;position:relative;padding:var(--space-sm) 0;transition:color var(--transition-fast)}.header__logo:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--color-highlight);transform:scaleX(0);transform-origin:right;transition:transform var(--transition-base) cubic-bezier(.65,0,.35,1)}.header__logo:hover:after{transform:scaleX(1);transform-origin:left}.header__nav{display:none}@media(min-width:768px){.header__nav{display:flex;gap:var(--space-2xl)}}.header__nav-link{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);transition:color var(--transition-fast);position:relative;padding:var(--space-sm) 0}.header__nav-link:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--color-text);transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.65,0,.35,1)}.header__nav-link:hover{color:var(--color-text)}.header__nav-link:hover:before{transform:scaleX(1);transform-origin:left}.header__nav-link:focus-visible,.header__logo:focus-visible{outline:2px solid var(--color-highlight);outline-offset:4px;border-radius:2px}.header__menu-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;width:48px;height:48px;padding:0;position:relative;z-index:1001;border-radius:50%;transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent}.header__menu-btn:active{background:var(--color-bg-secondary)}@media(min-width:768px){.header__menu-btn{display:none}}.header__menu-btn span{display:block;width:22px;height:2px;background:var(--color-text);position:absolute;transform-origin:center;transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .2s ease,background .2s ease}.header__menu-btn span:first-child{transform:translateY(-6px) rotate(0)}.header__menu-btn span:last-child{transform:translateY(6px) rotate(0)}.header__menu-btn.is-active span:first-child{transform:translateY(0) rotate(45deg);transition:transform .4s cubic-bezier(.23,1,.32,1) .1s}.header__menu-btn.is-active span:last-child{transform:translateY(0) rotate(-45deg);transition:transform .4s cubic-bezier(.23,1,.32,1) .1s}@media(hover:hover){.header__menu-btn:hover span{background:var(--color-highlight)}}.mobile-menu{position:fixed;inset:0;z-index:999;display:flex;flex-direction:column;justify-content:center;align-items:center;pointer-events:none;padding-bottom:var(--safe-area-bottom)}.mobile-menu__backdrop{position:absolute;inset:0;background:#f8f7f4fa;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);opacity:0;transition:opacity .4s cubic-bezier(.23,1,.32,1)}.mobile-menu.is-open{pointer-events:auto}.mobile-menu.is-open .mobile-menu__backdrop{opacity:1}.mobile-menu__nav{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);position:relative;z-index:1}.mobile-menu__link{font-family:var(--font-display);font-size:clamp(2.5rem,10vw,4rem);font-weight:500;letter-spacing:-.02em;color:var(--color-text);opacity:0;transform:translate(60px);transition:opacity .5s cubic-bezier(.23,1,.32,1),transform .5s cubic-bezier(.23,1,.32,1),color var(--transition-fast);position:relative;-webkit-tap-highlight-color:transparent}.mobile-menu__link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-highlight);transition:width .3s cubic-bezier(.23,1,.32,1)}.mobile-menu.is-open .mobile-menu__link{opacity:1;transform:translate(0)}.mobile-menu__link:nth-child(1){transition-delay:.1s}.mobile-menu__link:nth-child(2){transition-delay:.18s}.mobile-menu__link:nth-child(3){transition-delay:.26s}.mobile-menu__link:active{color:var(--color-highlight)}.mobile-menu__link:active:after{width:100%}.mobile-menu__footer{position:absolute;bottom:calc(var(--space-3xl) + var(--safe-area-bottom));left:0;right:0;display:flex;justify-content:center;gap:var(--space-xl);opacity:0;transform:translateY(30px);transition:opacity .5s cubic-bezier(.23,1,.32,1) .3s,transform .5s cubic-bezier(.23,1,.32,1) .3s;z-index:1}.mobile-menu.is-open .mobile-menu__footer{opacity:1;transform:translateY(0)}.mobile-menu__social{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);padding:var(--space-md);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-menu__social:active{color:var(--color-text)}body.menu-open{overflow:hidden}.hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;position:relative;padding-top:calc(100px + var(--safe-area-top));overflow:hidden}@media(max-width:767px){.hero{min-height:85vh;min-height:85dvh;padding-top:calc(70px + var(--safe-area-top));padding-bottom:var(--space-2xl);justify-content:center}}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 20% 40%,rgba(196,167,125,.06) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 60%,rgba(196,167,125,.04) 0%,transparent 50%);pointer-events:none}.hero__content{position:relative;padding-bottom:calc(var(--space-5xl) + 80px);z-index:1}@media(max-width:767px){.hero__content{padding-bottom:0}}.hero__label{display:inline-flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);position:relative}@media(max-width:767px){.hero__label{margin-bottom:var(--space-lg)}}.hero__label:before{content:"";width:24px;height:1px;background:var(--color-highlight)}.hero__title{font-size:var(--text-hero);font-weight:500;letter-spacing:-.04em;line-height:.92;margin-bottom:var(--space-xl);overflow:hidden;position:relative}@media(max-width:767px){.hero__title{margin-bottom:var(--space-lg)}}.hero__title:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(196,167,125,.08),transparent);animation:titleShimmer 8s ease-in-out infinite;pointer-events:none}@keyframes titleShimmer{0%,to{left:-100%}50%{left:150%}}.hero__title span{display:block;overflow:hidden}.hero__title .char{display:inline-block;will-change:transform,opacity}.hero__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:520px;line-height:1.6;letter-spacing:.01em}.hero__meta{display:flex;flex-wrap:wrap;gap:var(--space-xl);margin-top:var(--space-3xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}@media(max-width:639px){.hero__meta{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:var(--space-sm);margin-left:calc(var(--container-padding) * -1);margin-right:calc(var(--container-padding) * -1);padding-left:var(--container-padding);padding-right:var(--container-padding)}.hero__meta::-webkit-scrollbar{display:none}.hero__meta-item{flex-shrink:0;min-width:max-content}.hero__meta-item:last-child{padding-right:var(--space-md)}}@media(min-width:640px){.hero__meta{gap:var(--space-3xl);margin-top:var(--space-4xl)}}.hero__meta-item{display:flex;flex-direction:column;gap:var(--space-xs);position:relative;padding-left:var(--space-md)}.hero__meta-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--color-highlight),transparent);opacity:.5;border-radius:1px}.hero__meta-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;letter-spacing:-.01em}.hero__scroll-arrow{position:absolute;bottom:var(--space-3xl);left:50%;transform:translate(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:50%;background:transparent;cursor:pointer;transition:all var(--transition-base);animation:arrowBounce 2s ease-in-out infinite}.hero__scroll-arrow svg{width:20px;height:20px;transition:transform var(--transition-fast)}.hero__scroll-arrow:hover{color:var(--color-highlight);border-color:var(--color-highlight);background:#c4a77d14}.hero__scroll-arrow:hover svg{transform:translateY(2px)}.hero__scroll-arrow:focus-visible{outline:2px solid var(--color-highlight);outline-offset:4px}@keyframes arrowBounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}@media(max-width:767px){.hero__scroll-arrow{display:none}}.hero__scroll-hint{display:none}@media(max-width:767px){.hero__scroll-hint{display:flex;flex-direction:column;align-items:center;gap:4px;position:absolute;bottom:var(--space-2xl);left:50%;transform:translate(-50%);animation:scrollHint 2s ease-in-out infinite}.hero__scroll-hint span{width:4px;height:4px;border-radius:50%;background:var(--color-text-tertiary)}.hero__scroll-hint span:nth-child(1){opacity:.4}.hero__scroll-hint span:nth-child(2){opacity:.6}.hero__scroll-hint span:nth-child(3){opacity:.9}@keyframes scrollHint{0%,to{transform:translate(-50%) translateY(0);opacity:1}50%{transform:translate(-50%) translateY(8px);opacity:.5}}}.work{background:var(--color-bg)}.work__header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-3xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}.work__title{font-size:var(--text-2xl);position:relative}.work__title:after{content:"";position:absolute;bottom:-4px;left:0;width:48px;height:3px;background:var(--color-highlight);border-radius:2px}.work__count{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-tertiary);letter-spacing:.05em}.bento-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--grid-gap)}.bento-card{position:relative;background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);overflow:visible;cursor:pointer;transform-style:preserve-3d;perspective:1200px;isolation:isolate}.bento-card .atropos-inner{border-radius:var(--border-radius-lg);overflow:hidden}.bento-card .atropos-shadow{filter:blur(50px);opacity:0;transition:opacity var(--card-transition-duration) var(--ease-out-expo)}.bento-card:hover .atropos-shadow{opacity:.2}.bento-card__number{position:absolute;top:var(--space-lg);left:var(--space-lg);font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.05em;color:#fff9;z-index:10;padding:.35em .7em;background:#1a191866;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:100px;border:1px solid rgba(255,255,255,.08);opacity:0;transform:translateY(-4px);transition:opacity .4s var(--ease-out-expo),transform .4s var(--ease-out-expo),background .3s ease,color .3s ease;will-change:opacity,transform}.bento-card:hover .bento-card__number{opacity:1;transform:translateY(0);background:#1a191899;color:#ffffffe6}@media(hover:none)and (pointer:coarse){.bento-card__number{opacity:1;transform:translateY(0)}}.bento-card__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1);transform-origin:center center;will-change:transform}.bento-card__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-xl);border-radius:var(--border-radius-lg);z-index:5;background:radial-gradient(ellipse 120% 100% at 50% 100%,rgba(26,25,24,.95) 0%,rgba(26,25,24,.7) 25%,rgba(26,25,24,.3) 50%,transparent 70%),linear-gradient(to bottom,rgba(26,25,24,.15) 0%,transparent 30%),radial-gradient(ellipse 80% 60% at 0% 0%,rgba(26,25,24,.2) 0%,transparent 50%),radial-gradient(ellipse 80% 60% at 100% 0%,rgba(26,25,24,.2) 0%,transparent 50%);opacity:0;transition:opacity .5s var(--ease-out-quart);will-change:opacity}.bento-card__overlay:before{content:"";position:absolute;inset:0;border-radius:inherit;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");mix-blend-mode:overlay}.bento-card__overlay:after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px #fff0;transition:box-shadow .5s var(--ease-out-quart);pointer-events:none}.bento-card:hover .bento-card__overlay{opacity:1}.bento-card:hover .bento-card__overlay:after{box-shadow:inset 0 0 0 1px #ffffff14}@media(hover:none)and (pointer:coarse){.bento-card__overlay{opacity:1;background:radial-gradient(ellipse 120% 100% at 50% 100%,rgba(26,25,24,.9) 0%,rgba(26,25,24,.5) 30%,transparent 60%)}}.bento-card__content{position:relative;z-index:2}.bento-card__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:#fff;margin-bottom:var(--space-xs);opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease-out-expo),transform .5s var(--ease-out-expo);will-change:opacity,transform}.bento-card:hover .bento-card__title{opacity:1;transform:translateY(0)}.bento-card__category{font-family:var(--font-mono);font-size:var(--text-xs);color:#ffffffa6;text-transform:uppercase;letter-spacing:.1em;display:inline-flex;align-items:center;gap:var(--space-sm);opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease-out-expo) var(--card-stagger-delay),transform .5s var(--ease-out-expo) var(--card-stagger-delay),color .3s ease;will-change:opacity,transform}.bento-card:hover .bento-card__category{opacity:1;transform:translateY(0)}.bento-card:hover .bento-card__category:hover{color:#ffffffe6}.bento-card__category:before{content:"";width:0;height:1px;background:var(--color-highlight);transition:width .4s var(--ease-out-expo) .15s}.bento-card:hover .bento-card__category:before{width:16px}@media(hover:none)and (pointer:coarse){.bento-card__title,.bento-card__category{opacity:1;transform:translateY(0)}.bento-card__category:before{width:12px}}.bento-card{grid-column:span 12;aspect-ratio:4/3}@media(min-width:640px){.bento-card{grid-column:span 6}.bento-card--large{grid-column:span 12;aspect-ratio:16/9}}@media(min-width:1024px){.bento-card--large{grid-column:span 8;aspect-ratio:16/10}.bento-card--tall{grid-column:span 4;grid-row:span 2;aspect-ratio:auto}.bento-card--wide{grid-column:span 6;aspect-ratio:16/10}.bento-card--square{grid-column:span 4;aspect-ratio:1}}.bento-card--has-frame{background:var(--color-bg-tertiary);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.bento-card--has-frame .atropos-inner,.bento-card--has-frame .bento-card__overlay{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.device-frame--bento,.device-frame--desktop.device-frame--bento{position:absolute;inset:0;display:flex;flex-direction:column;border-radius:0;box-shadow:none}.device-frame--bento .device-frame__chrome{display:flex;align-items:center;gap:5px;padding:8px 12px;background:#2a2928;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.device-frame--bento .device-frame__chrome span{width:8px;height:8px;border-radius:50%}.device-frame--bento .device-frame__chrome span:nth-child(1){background:#ff5f57}.device-frame--bento .device-frame__chrome span:nth-child(2){background:#ffbd2e}.device-frame--bento .device-frame__chrome span:nth-child(3){background:#28c840}.device-frame--bento .device-frame__screen{position:relative;flex:1;overflow:hidden;border-radius:0}.device-frame--bento .bento-card__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:0}.bento-grid.bento-grid--services{display:grid;grid-template-columns:1fr;gap:var(--grid-gap)}@media(min-width:640px){.bento-grid.bento-grid--services{grid-template-columns:repeat(2,1fr);gap:calc(var(--grid-gap) * 1.25)}}@media(min-width:1024px){.bento-grid.bento-grid--services{grid-template-columns:repeat(2,1fr)}}.bento-grid--services .bento-card--service{grid-column:span 1;aspect-ratio:4/3;border:1px solid var(--color-border-light);transition:border-color .4s var(--ease-out-expo),box-shadow .4s var(--ease-out-expo)}.bento-grid--services .bento-card--service:hover{border-color:var(--color-highlight);box-shadow:0 8px 32px #c4a77d1f}@media(min-width:640px){.bento-grid--services .bento-card--service{aspect-ratio:1}}@media(min-width:1024px){.bento-grid--services .bento-card--service{aspect-ratio:16/10}}.services__pricing{margin-top:var(--space-4xl);padding:var(--space-xl) var(--space-2xl);background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-secondary);text-align:center;max-width:640px;margin-left:auto;margin-right:auto;line-height:1.7;position:relative}.services__pricing:before,.services__pricing:after{content:"";position:absolute;width:24px;height:2px;background:var(--color-highlight);top:50%;transform:translateY(-50%)}.services__pricing:before{left:var(--space-lg)}.services__pricing:after{right:var(--space-lg)}@media(max-width:639px){.services__pricing:before,.services__pricing:after{display:none}}.about{background:var(--color-bg-secondary);position:relative;overflow:hidden}.about:before{content:"";position:absolute;top:-20%;right:-10%;width:50%;height:80%;background:radial-gradient(ellipse at center,rgba(196,167,125,.06) 0%,transparent 70%);pointer-events:none}.about__grid{display:grid;grid-template-columns:1fr;gap:var(--space-3xl);align-items:center}@media(min-width:768px){.about__grid{grid-template-columns:1fr 1.1fr;gap:var(--space-5xl)}}.about__image-wrapper{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--border-radius-lg)}.about__image-wrapper:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,var(--color-highlight),var(--color-border-light),var(--color-highlight));border-radius:calc(var(--border-radius-lg) + 3px);z-index:-1;opacity:.8}.about__image-wrapper:after{content:"";position:absolute;inset:0;background:var(--color-bg);border-radius:var(--border-radius-lg);z-index:-1}.about__image-wrapper .about__image{position:relative}@media(min-width:768px){.about__image-wrapper{margin-left:var(--space-xl)}}.about__image{width:100%;height:100%;object-fit:cover;border-radius:var(--border-radius-lg)}.about__content{max-width:500px}@media(min-width:768px){.about__content{max-width:none}}.about__label{margin-bottom:var(--space-lg);display:inline-flex;align-items:center;gap:var(--space-sm)}.about__label:before{content:"";width:16px;height:1px;background:var(--color-highlight)}.about__title{font-size:var(--text-2xl);margin-bottom:var(--space-xl);position:relative}.about__title:after{content:"";position:absolute;bottom:-8px;left:0;width:40px;height:3px;background:var(--color-highlight);border-radius:2px}.about__text{color:var(--color-text-secondary);margin-bottom:var(--space-lg);line-height:1.7}.about__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-3xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.about__stat{display:flex;flex-direction:column;gap:var(--space-xs);position:relative}@media(hover:hover){.about__stat{padding:var(--space-md);margin:calc(var(--space-md) * -1);border-radius:var(--border-radius-lg);transition:background .3s ease}.about__stat:hover{background:#c4a77d14}.about__stat:hover .about__stat-value{color:var(--color-highlight-dark)}}.about__stat-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;transition:color .3s ease}.about__stat-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.contact{background:var(--color-bg);position:relative}.contact:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,var(--color-border) 1px,transparent 0);background-size:40px 40px;opacity:.3;pointer-events:none}.contact__grid{display:grid;grid-template-columns:1fr;gap:var(--space-3xl);position:relative}@media(min-width:768px){.contact__grid{grid-template-columns:1fr 1fr;gap:var(--space-4xl)}}.contact__info{max-width:500px}.contact__label{margin-bottom:var(--space-lg);display:inline-flex;align-items:center;gap:var(--space-sm)}.contact__label:before{content:"";width:16px;height:1px;background:var(--color-highlight)}.contact__title{font-size:var(--text-2xl);margin-bottom:var(--space-xl);position:relative}.contact__title:after{content:"";display:inline-block;width:8px;height:8px;background:var(--color-highlight);border-radius:50%;margin-left:.1em;vertical-align:middle;animation:pulseDot 2s ease-in-out infinite}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.contact__text{color:var(--color-text-secondary);line-height:1.7}.contact__details{display:flex;flex-direction:column;gap:var(--space-xl)}.contact__detail{display:flex;flex-direction:column;gap:var(--space-sm)}.contact__detail-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em}.contact__detail-value{font-family:var(--font-display);font-size:var(--text-lg);transition:color var(--transition-fast),transform var(--transition-fast);display:inline-flex;align-items:center;gap:var(--space-sm)}@media(max-width:767px){a.contact__detail-value{padding:var(--space-md) 0;margin:calc(var(--space-md) * -1) 0}}a.contact__detail-value:after{content:"";width:0;height:1px;background:var(--color-highlight);transition:width var(--transition-base);position:absolute;bottom:0;left:0}a.contact__detail-value{position:relative}a.contact__detail-value:hover{color:var(--color-highlight)}a.contact__detail-value:hover:after{width:100%}.contact__detail-icon{width:20px;height:20px;opacity:0;transform:translate(-10px);transition:opacity var(--transition-fast),transform var(--transition-fast)}a.contact__detail-value:hover .contact__detail-icon{opacity:1;transform:translate(0)}.contact__social{display:flex;flex-wrap:wrap;gap:var(--space-lg);margin-top:var(--space-3xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.contact__social-link{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid transparent;border-radius:var(--border-radius);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.contact__social-link:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.5;transition:opacity var(--transition-fast),transform var(--transition-fast)}.contact__social-link:hover{color:var(--color-text);border-color:var(--color-border);background:var(--color-bg-secondary)}.contact__social-link:hover:before{opacity:1;transform:scale(1.5)}.contact__social-link:active{transform:scale(.97)}.footer{padding:var(--space-2xl) 0;padding-bottom:calc(var(--space-2xl) + var(--safe-area-bottom));border-top:1px solid var(--color-border);background:var(--color-bg)}.footer__inner{display:flex;flex-direction:column;gap:var(--space-md);align-items:center;text-align:center}@media(min-width:768px){.footer__inner{flex-direction:row;justify-content:space-between}}.footer__copyright{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);display:inline-flex;align-items:center;gap:var(--space-sm)}.footer__copyright:before{content:"";width:6px;height:6px;background:var(--color-highlight);border-radius:50%;opacity:.6}.footer__credits{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);letter-spacing:.02em}.scroll-top{position:fixed;bottom:calc(var(--space-xl) + var(--safe-area-bottom));right:var(--space-lg);width:48px;height:48px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-base);z-index:100;-webkit-tap-highlight-color:transparent}.scroll-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-top:active{transform:scale(.9);background:var(--color-bg-secondary)}.scroll-top svg{width:20px;height:20px;transition:transform var(--transition-fast)}.scroll-top:hover svg{transform:translateY(-2px)}@media(min-width:768px){.scroll-top{display:none}}.floating-cta{position:fixed;bottom:calc(var(--space-xl) + var(--safe-area-bottom));left:var(--space-lg);right:calc(var(--space-lg) + 60px);z-index:100;opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-base)}.floating-cta.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.floating-cta__btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--color-highlight);color:var(--color-bg);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:500;border-radius:var(--border-radius-lg);box-shadow:0 8px 32px #c4a77d59;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.floating-cta__btn:active{transform:scale(.97);background:var(--color-highlight-dark)}.floating-cta__btn svg{width:16px;height:16px}@media(min-width:768px){.floating-cta{display:none}}.project-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);pointer-events:none;opacity:0}@media(max-width:767px){.project-modal{padding:0}}.project-modal.is-active{pointer-events:auto;opacity:1}.project-modal__backdrop{position:absolute;inset:0;background:#f8f7f4eb;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px)}.project-modal__content{position:relative;width:100%;max-width:1100px;max-height:90vh;background:var(--color-bg);border-radius:var(--border-radius-lg);overflow-y:auto;overflow-x:hidden;display:grid;grid-template-columns:1fr;box-shadow:var(--shadow-xl);-webkit-overflow-scrolling:touch}@media(max-width:767px){.project-modal__content{max-width:100%;max-height:100%;height:100%;border-radius:0;padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom)}}@media(min-width:768px){.project-modal__content{grid-template-columns:1.2fr 1fr;overflow:hidden}}.project-modal__image{aspect-ratio:16/9;background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}@media(min-width:768px){.project-modal__image{aspect-ratio:auto;min-height:500px}}.project-modal__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.project-modal__image-placeholder{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.1em}.project-modal__swipe-hint{position:absolute;top:var(--space-lg);left:50%;transform:translate(-50%);width:40px;height:4px;background:var(--color-border);border-radius:2px;opacity:.5}@media(min-width:768px){.project-modal__swipe-hint{display:none}}.project-modal__nav{display:flex;justify-content:center;gap:var(--space-md);padding:var(--space-lg) 0}.project-modal__nav-dot{width:10px;height:10px;border-radius:50%;background:var(--color-border);border:none;padding:0;cursor:pointer;transition:all .3s var(--ease-out-expo);-webkit-tap-highlight-color:transparent}.project-modal__nav-dot:hover{background:var(--color-text-secondary);transform:scale(1.2)}.project-modal__nav-dot.is-active{background:var(--color-highlight);transform:scale(1.3)}.project-modal__arrow{display:none;position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);z-index:20;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.project-modal__arrow svg{width:18px;height:18px}.project-modal__arrow--prev{left:var(--space-lg)}.project-modal__arrow--next{right:var(--space-lg)}.project-modal__arrow:hover{border-color:var(--color-text);color:var(--color-text);background:var(--color-bg-secondary)}.project-modal__arrow:active{transform:translateY(-50%) scale(.9)}.project-modal__arrow.is-hidden{opacity:0;pointer-events:none}@media(min-width:768px){.project-modal__arrow{display:flex}}.project-modal__details{padding:var(--space-2xl);display:flex;flex-direction:column;gap:var(--space-xl);overflow-y:auto}@media(min-width:768px){.project-modal__details{padding:var(--space-3xl)}}.project-modal__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-lg)}.project-modal__category{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm);display:inline-flex;align-items:center;gap:var(--space-sm)}.project-modal__category:before{content:"";width:8px;height:1px;background:var(--color-highlight)}.project-modal__title{font-size:var(--text-xl);line-height:1.2}.project-modal__close{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-secondary);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.project-modal__close:hover{border-color:var(--color-text);color:var(--color-text);background:var(--color-bg-secondary)}.project-modal__close:active{transform:scale(.9)}.project-modal__close svg{width:20px;height:20px}.project-modal__description{color:var(--color-text-secondary);line-height:1.7}.project-modal__meta{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.project-modal__meta-item{display:flex;flex-direction:column;gap:var(--space-xs)}.project-modal__meta-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.project-modal__meta-value{font-family:var(--font-display);font-size:var(--text-base)}.project-modal__cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-md) var(--space-xl);background:var(--color-highlight);color:var(--color-bg);border:2px solid var(--color-highlight);border-radius:var(--border-radius-lg);transition:all .3s var(--ease-out-expo);align-self:flex-start;margin-top:auto;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.project-modal__cta:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.project-modal__cta:hover:before{left:100%}@media(max-width:767px){.project-modal__cta{width:100%;padding:var(--space-lg) var(--space-xl)}}.project-modal__cta:hover{background:var(--color-highlight-dark);border-color:var(--color-highlight-dark);box-shadow:0 4px 20px #c4a77d4d}.project-modal__cta:active{transform:scale(.97)}.project-modal__cta svg{transition:transform var(--transition-fast)}.project-modal__cta:hover svg{transform:translate(4px)}body.modal-open{overflow:hidden}.header--simple{position:relative;background:var(--color-bg)}.header__back{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.header__back:hover{color:var(--color-text)}.header__back svg{width:16px;height:16px}.work-hero{padding-top:var(--space-4xl);padding-bottom:var(--space-3xl)}.work-hero__label{display:block;margin-bottom:var(--space-lg)}.work-hero__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:500;color:var(--color-text);margin-bottom:var(--space-md)}.work-hero__subtitle{font-family:var(--font-body);font-size:var(--text-lg);color:var(--color-text-secondary);max-width:480px}.work-grid-section{padding-top:0;padding-bottom:var(--section-padding)}.project-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media(min-width:640px){.project-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2xl)}}@media(min-width:1024px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card{position:relative;display:block;aspect-ratio:4/3;background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);overflow:hidden;text-decoration:none;border:1px solid var(--color-border-light);transition:border-color .4s var(--ease-out-expo),box-shadow .4s var(--ease-out-expo),transform .4s var(--ease-out-expo)}.project-card:hover{border-color:var(--color-highlight);box-shadow:0 12px 40px #c4a77d26;transform:translateY(-4px)}.project-card__number{position:absolute;top:var(--space-lg);left:var(--space-lg);font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.05em;color:#ffffffb3;z-index:10;padding:.35em .7em;background:#1a191880;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:100px;border:1px solid rgba(255,255,255,.1)}.project-card__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s var(--ease-out-expo)}.project-card:hover .project-card__image{transform:scale(1.03)}.project-card__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-xl);background:linear-gradient(to top,rgba(26,25,24,.95) 0%,rgba(26,25,24,.7) 40%,rgba(26,25,24,.2) 70%,transparent 100%);opacity:1}@media(hover:hover){.project-card__overlay{opacity:0;transition:opacity .4s var(--ease-out-expo)}.project-card:hover .project-card__overlay{opacity:1}}.project-card__content{transform:translateY(8px);transition:transform .4s var(--ease-out-expo)}.project-card:hover .project-card__content{transform:translateY(0)}@media(hover:none){.project-card__content{transform:translateY(0)}}.project-card__category{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-highlight);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-xs)}.project-card__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:#fff;margin-bottom:var(--space-sm)}.project-card__description{font-family:var(--font-body);font-size:var(--text-sm);color:#ffffffb3;line-height:1.5;margin-bottom:var(--space-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card__meta{display:flex;align-items:center;gap:var(--space-md);font-family:var(--font-mono);font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.project-card__status{padding:.25em .5em;background:#ffffff1a;border-radius:4px}.project-hero{position:relative;width:100%;padding-top:var(--space-2xl);overflow:hidden}.project-hero__image{width:100%;height:100%;object-fit:cover;object-position:top center}.device-frame--hero{margin:0 auto}.device-frame--hero .device-frame__screen{aspect-ratio:unset;height:360px}@media(min-width:640px){.device-frame--hero .device-frame__screen{height:440px}}@media(min-width:1024px){.device-frame--hero .device-frame__screen{height:500px}}.project-info{position:relative;z-index:10;margin-top:var(--space-xl);padding:var(--space-2xl) 0;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.project-info__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:500;color:var(--color-text);margin-bottom:var(--space-xl)}@media(min-width:768px){.project-info__title{font-size:var(--text-3xl)}}.project-info__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl)}@media(min-width:640px){.project-info__grid{grid-template-columns:repeat(4,1fr)}}.project-info__item{display:flex;flex-direction:column;gap:var(--space-xs)}.project-info__label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.1em}.project-info__value{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text)}.project-info__services{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.project-info__service{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.25em .6em;border-radius:4px}.project-info__link{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);text-decoration:none;transition:color .2s ease}.project-info__link:hover{color:var(--color-highlight)}.project-content{padding:var(--space-4xl) 0}.project-content__grid{display:grid;gap:var(--space-4xl)}@media(min-width:768px){.project-content__grid{grid-template-columns:1fr 1fr;gap:var(--space-3xl)}}.project-section{max-width:560px}.project-section--intro{grid-column:1 / -1;max-width:720px}.project-section__label{display:block;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-md)}.project-section__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;color:var(--color-text);margin-bottom:var(--space-lg)}.project-section__text{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7}.project-section__text--large{font-size:var(--text-lg);color:var(--color-text)}.project-gallery{padding:var(--space-3xl) 0 var(--space-4xl);border-top:1px solid var(--color-border)}.project-gallery__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:var(--color-text);margin-bottom:var(--space-2xl)}.project-gallery__grid{display:grid;gap:var(--space-lg)}@media(min-width:640px){.project-gallery__grid{grid-template-columns:repeat(2,1fr)}}.project-gallery__item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);border:1px solid var(--color-border-light)}.project-gallery__item--desktop,.project-gallery__item--mobile{grid-column:span 1}@media(min-width:640px){.project-gallery__item--desktop{grid-column:span 2}}.project-gallery__image{width:100%;height:100%;object-fit:cover;object-position:top center}.project-gallery__caption{margin-top:var(--space-md);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-align:center}.device-frame{position:relative;display:flex;flex-direction:column;width:100%;background:#1a1918;overflow:hidden}.device-frame--desktop{border-radius:8px;box-shadow:0 4px 6px #0000001a,0 10px 40px #00000026}.device-frame--desktop .device-frame__chrome{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#2a2928;border-bottom:1px solid rgba(255,255,255,.05)}.device-frame--desktop .device-frame__chrome span{width:10px;height:10px;border-radius:50%}.device-frame--desktop .device-frame__chrome span:nth-child(1){background:#ff5f57}.device-frame--desktop .device-frame__chrome span:nth-child(2){background:#ffbd2e}.device-frame--desktop .device-frame__chrome span:nth-child(3){background:#28c840}.device-frame--desktop .device-frame__screen{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden}.device-frame--desktop .device-frame__screen .project-gallery__image{position:absolute;inset:0}.device-frame--mobile{width:240px;border-radius:32px;padding:12px;box-shadow:0 4px 6px #0000001a,0 10px 40px #0003,inset 0 0 0 2px #ffffff1a}@media(min-width:640px){.device-frame--mobile{width:280px}}.device-frame--mobile .device-frame__chrome{display:flex;justify-content:center;padding:8px 0 6px}.device-frame--mobile .device-frame__chrome span{display:none}.device-frame--mobile .device-frame__chrome span:first-child{display:block;width:80px;height:24px;background:#000;border-radius:20px}.device-frame--mobile .device-frame__screen{position:relative;width:100%;aspect-ratio:9/19.5;border-radius:20px;overflow:hidden;background:#fff}.device-frame--mobile .device-frame__screen .project-gallery__image{position:absolute;inset:0}.project-nav{padding:var(--space-3xl) 0;border-top:1px solid var(--color-border)}.project-nav__link{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl);background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);text-decoration:none;border:1px solid var(--color-border-light);transition:border-color .3s var(--ease-out-expo),background .3s var(--ease-out-expo)}.project-nav__link:hover{border-color:var(--color-highlight);background:var(--color-bg-elevated)}.project-nav__label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-xs)}.project-nav__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:var(--color-text)}.project-nav__arrow{width:24px;height:24px;color:var(--color-text-tertiary);transition:color .3s ease,transform .3s var(--ease-out-expo)}.project-nav__link:hover .project-nav__arrow{color:var(--color-highlight);transform:translate(4px)}.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.lightbox.is-open{opacity:1;visibility:visible}.lightbox__backdrop{position:absolute;inset:0;background:var(--color-bg);cursor:pointer}.lightbox__content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.lightbox__image-wrapper{position:relative;max-width:90vw;max-height:80vh;transform:scale(.95);transition:transform .3s var(--ease-out-expo)}.lightbox.is-open .lightbox__image-wrapper{transform:scale(1)}.lightbox__image{display:block;max-width:100%;max-height:80vh;width:auto;height:auto;border-radius:var(--border-radius-lg);box-shadow:0 8px 32px #0000001f;user-select:none;-webkit-user-drag:none}.lightbox.is-zoomed .lightbox__content{align-items:flex-start;overflow-y:auto;-webkit-overflow-scrolling:touch}.lightbox.is-zoomed .lightbox__image-wrapper{max-width:100%;max-height:none;width:100%;padding:var(--space-xl)}@media(max-width:768px){.lightbox.is-zoomed .lightbox__image-wrapper{padding:0}.lightbox.is-zoomed .lightbox__image{border-radius:0}}.lightbox.is-zoomed .lightbox__image{max-height:none;width:100%;height:auto;border-radius:var(--border-radius-lg)}.lightbox__zoom{position:absolute;top:var(--space-lg);left:var(--space-lg);height:44px;display:flex;align-items:center;gap:var(--space-sm);padding:0 var(--space-md);background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:22px;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;z-index:10;opacity:0;visibility:hidden}.lightbox__zoom.is-visible{opacity:1;visibility:visible}.lightbox__zoom:hover{background:var(--color-bg-elevated);border-color:var(--color-border);color:var(--color-text)}.lightbox__zoom svg{width:16px;height:16px}.lightbox.is-zoomed .lightbox__nav{opacity:0;visibility:hidden}.lightbox__scroll-hint{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);opacity:0;visibility:hidden;transition:opacity .3s ease;z-index:10}.lightbox.is-zoomed .lightbox__scroll-hint{opacity:1;visibility:visible}.lightbox.is-zoomed .lightbox__counter,.lightbox.is-zoomed .lightbox__swipe-hint{opacity:0;visibility:hidden}.lightbox__close{position:absolute;top:var(--space-lg);right:var(--space-lg);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:50%;color:var(--color-text-secondary);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;z-index:10}.lightbox__close:hover{background:var(--color-bg-elevated);border-color:var(--color-border);color:var(--color-text)}.lightbox__close svg{width:20px;height:20px}.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:50%;color:var(--color-text-secondary);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease,opacity .2s ease;z-index:10}.lightbox__nav:hover{background:var(--color-bg-elevated);border-color:var(--color-border);color:var(--color-text)}.lightbox__nav:disabled{opacity:.3;cursor:not-allowed}.lightbox__close:focus-visible,.lightbox__nav:focus-visible,.lightbox__zoom:focus-visible{outline:2px solid var(--color-highlight);outline-offset:2px}.lightbox__nav svg{width:24px;height:24px}.lightbox__nav--prev{left:var(--space-lg)}.lightbox__nav--next{right:var(--space-lg)}@media(max-width:768px){.lightbox__nav{display:none}}.lightbox__counter{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-tertiary);z-index:10}.lightbox__swipe-hint{position:absolute;bottom:calc(var(--space-lg) + 28px);left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);opacity:1;transition:opacity .3s ease}@media(min-width:769px){.lightbox__swipe-hint{display:none}}.lightbox.has-swiped .lightbox__swipe-hint{opacity:0}.project-gallery__item{cursor:pointer}.project-gallery__item:hover .device-frame{transform:translateY(-2px);transition:transform .3s var(--ease-out-expo)}.device-frame--hero{cursor:pointer}.device-frame--hero:hover{transform:translateY(-2px);transition:transform .3s var(--ease-out-expo)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--color-highlight);outline-offset:2px}button:focus-visible,a:focus-visible{outline:2px solid var(--color-highlight);outline-offset:4px;border-radius:var(--border-radius)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}::selection{background:var(--color-highlight);color:var(--color-text)}::-moz-selection{background:var(--color-highlight);color:var(--color-text)}
