@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-zinc-300:#d4d4d8;--color-zinc-600:#52525c;--spacing:.25rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25/1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-zinc-300:lab(84.9837% .601262 -2.17986);--color-zinc-600:lab(35.1166% 1.78212 -6.1173)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.top-15{top:calc(var(--spacing)*15)}.col-3{grid-column:3}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.my-4{margin-block:calc(var(--spacing)*4)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-5{margin-top:calc(var(--spacing)*5)}.mt-6{margin-top:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.table{display:table}.max-w-none{max-width:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.flex-wrap{flex-wrap:wrap}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-zinc-300{border-color:var(--color-zinc-300)}.pl-4{padding-left:calc(var(--spacing)*4)}.pl-6{padding-left:calc(var(--spacing)*6)}.text-justify{text-align:justify}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-zinc-600{color:var(--color-zinc-600)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.hover\:text-zinc-600:hover{color:var(--color-zinc-600)}}}:root{--color-bg:#f5f5f5;--color-text:#141414;--color-muted:#7a7a7a;--color-border:#e0ddd4;--cream:var(--color-bg);--black:var(--color-text);--white:var(--color-bg);--gray:var(--color-muted);--gray-light:var(--color-border);--color-magenta:#f0f;--color-cyan:#0ff;--color-yellow:#ff0;--color-green:#0f0;--color-orange:#f60;--color-pink:#f06;--color-mint:#0f9;--color-red:#f30;--color-lime:#6f0;--color-coral:#f09;--category-strategy:var(--color-magenta);--category-design:var(--color-cyan);--category-interactive:var(--color-yellow);--category-content:var(--color-green);--font-display:"neue-haas-grotesk-display",sans-serif;--font-body:"neue-haas-grotesk-text",sans-serif;--text-xs:10px;--text-sm:12px;--text-base:14px;--text-lg:18px;--leading-tight:1;--leading-normal:1.5;--leading-loose:1.7;--tracking-tight:-.02em;--tracking-wide:.06em;--space-1:.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2rem;--space-6:3rem;--space-8:4rem;--gutter:1.25rem;--content-width:700px;--nav-height:52px;--btn-bg:var(--white);--btn-text:var(--color-text);--btn-border:var(--color-text);--btn-hover-bg:var(--color-text);--btn-hover-text:var(--color-bg);--btn-radius:999px;--btn-padding-x:2rem;--btn-padding-y:.875rem;--transition-fast:.15s ease;--transition-base:.3s ease;--z-sticky:20;--z-header:100;--z-modal:200}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-weight:300;font-size:var(--text-base);line-height:var(--leading-normal)}::selection{background:var(--selection-color,var(--color-magenta));color:var(--black)}a{color:inherit}.label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.container{max-width:1400px;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem}.container-narrow{max-width:900px;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem}.full-bleed{width:100%;max-width:none;margin:0;padding:0}.site-header{z-index:100;background:0 0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;transition:color .3s;display:flex;position:fixed;top:0;left:0;right:0}.site-header.header-dark{color:var(--color-text)}.site-header.header-dark .site-logo img{filter:invert()}.site-header.header-light{color:var(--white)}.site-main{background:var(--cream);flex-direction:column;min-height:100vh;display:flex;position:relative}.site-logo{font-family:var(--font-display);text-transform:uppercase;font-size:42px;font-weight:600;text-decoration:none}.site-logo img{transition:filter .3s}.site-logo:hover{text-decoration:underline}.site-nav{gap:1.5rem;display:flex}.site-nav a{font-family:var(--font-display);text-transform:uppercase;color:inherit;font-size:42px;font-weight:600;text-decoration:none}.site-nav a:hover{text-decoration:underline}.site-cta{border-top:1px solid var(--gray-light);text-align:center;padding:4rem 1.25rem}.site-cta h2{font-family:var(--font-display);text-transform:uppercase;margin-bottom:1rem;font-size:clamp(2rem,6vw,3.5rem);font-weight:600;line-height:1}.site-cta p{font-family:var(--font-body);max-width:400px;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;font-size:15px;line-height:1.6}.site-cta-email{font-family:var(--font-body);border-bottom:1px solid;padding-bottom:2px;font-size:1.125rem;text-decoration:none}.site-cta-email:hover{opacity:.7}.site-footer{background:var(--black);color:var(--cream);border-top:1px solid var(--gray);margin-top:auto;padding:3rem 1.25rem}.footer-columns{grid-template-columns:1fr;gap:2.5rem;display:grid}@media (min-width:768px){.footer-columns{grid-template-columns:auto auto 1fr;gap:4rem}}.footer-col{font-size:14px;line-height:1.6}.footer-col p{margin:0}.footer-col--left,.footer-col--center{max-width:200px}.footer-col--left p:first-child{margin-bottom:.75rem;font-weight:500}.footer-col--center p{margin-bottom:1rem}.footer-col--right{text-align:left;max-width:280px}@media (min-width:768px){.footer-col--right{margin-left:auto}}.footer-col--right p:first-child{margin-bottom:1.5rem}.footer-email{text-decoration:underline;transition:opacity .15s}.footer-email:hover{opacity:.7}.footer-copyright{color:var(--gray);margin-top:1rem;font-size:12px}.btn{font-family:var(--font-body);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;border-radius:var(--btn-radius);background:var(--btn-bg);color:var(--btn-text);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);border:1px solid #000;padding:.75rem 1.75rem;text-decoration:none;display:inline-block;box-shadow:0 4px #000}.btn:hover{background:var(--btn-hover-bg);color:var(--btn-hover-text)}.btn--neon:hover{color:var(--black);animation:.6s step-end infinite neonCycle}@keyframes neonCycle{0%{background:var(--color-magenta)}10%{background:var(--color-lime)}20%{background:var(--color-cyan)}30%{background:var(--color-coral)}40%{background:var(--color-yellow)}50%{background:var(--color-mint)}60%{background:var(--color-red)}70%{background:var(--color-green)}80%{background:var(--color-pink)}90%{background:var(--color-orange)}to{background:var(--color-magenta)}}.btn-solid{background:var(--btn-hover-bg);color:var(--btn-hover-text)}.btn-solid:hover{background:var(--btn-bg);color:var(--btn-text)}.section-divider{border-top:1px solid var(--black)}.hero{padding:0;overflow:hidden}.hero-title{font-family:var(--font-display);letter-spacing:-.04em;text-transform:uppercase;white-space:nowrap;margin:0;font-size:17.5vw;font-weight:600;line-height:.85}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);text-transform:uppercase;font-weight:600;line-height:1.2}h1{margin-bottom:2rem;font-size:clamp(3rem,8vw,5rem)}h2{margin-bottom:1.5rem;font-size:clamp(2.5rem,7vw,4rem)}h3{margin-bottom:1rem;font-size:clamp(1.5rem,4vw,2rem)}p{margin-bottom:1rem}.content-section{padding:8rem var(--gutter);max-width:var(--content-width);margin:0 auto}.content-section p{font-size:18px;line-height:1.7}.content-section .btn{margin-top:1rem}.work-grid{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2rem;padding:0 1.25rem;display:flex;overflow-x:auto}.work-grid::-webkit-scrollbar{display:none}.work-grid .project-card{scroll-snap-align:start;flex:0 0 80vw}@media (min-width:768px){.work-grid .project-card{flex:0 0 45vw}}@media (min-width:1024px){.work-grid .project-card{flex:0 0 35vw}}.project-card{text-decoration:none;display:block}.project-card-image{aspect-ratio:4/3;background:var(--gray-light);width:100%;margin-bottom:.75rem;position:relative;overflow:hidden}.project-card-image img{object-fit:cover;filter:grayscale()contrast(1.1);width:100%;height:100%;transition:filter .3s}.project-card:hover .project-card-image img{filter:grayscale(0%)contrast()}.project-card-label{align-items:baseline;gap:.75rem;display:flex}.project-card-title{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.project-card-client{font-family:var(--font-body);color:var(--gray);font-size:11px}.project-hero{aspect-ratio:16/9;background:var(--gray-light);width:100%;position:relative}.project-hero img{object-fit:cover;width:100%;height:100%}.project-header{border-bottom:1px solid var(--black);padding:2rem 1.25rem}.project-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.02em;font-size:clamp(3rem,9vw,5.25rem);font-weight:600;line-height:1}.project-client{font-family:var(--font-body);color:var(--gray);margin-top:.5rem;font-size:1.2rem;font-style:italic}.project-meta{flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;display:flex}.project-tag{text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--black);padding:.4rem .75rem;font-size:10px;text-decoration:none;transition:background .15s,color .15s}.project-tag:hover{background:var(--hover-color)}.project-tagline{font-family:var(--font-body);max-width:700px;margin:0;padding:3rem 1.25rem 0;font-size:1.1rem;font-weight:600}.project-content{max-width:700px;padding:1.5rem 1.25rem 3rem}.project-content p{font-family:var(--font-body);margin-bottom:1.5rem;font-size:15px;line-height:1.7}.project-credits{max-width:700px;margin-top:-1.5rem;margin-bottom:3rem;padding:0 1.25rem}.project-credits p{font-family:var(--font-body);color:var(--gray);margin:0;font-size:12px;line-height:1.8}.project-gallery{flex-wrap:wrap;gap:1rem;padding:0 1.25rem 3rem;display:flex}.project-gallery-item{background:var(--gray-light);cursor:zoom-in;aspect-ratio:var(--aspect-ratio,1.5);border:none;padding:0;position:relative;overflow:hidden}.project-gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.project-gallery-item--video{aspect-ratio:auto;background:0 0;line-height:0}.project-gallery-item--video video{width:100%;height:auto;display:block}.project-gallery-item:hover img{transform:scale(1.02)}.project-gallery-item--landscape{width:100%}.project-gallery-item--square{width:calc(50% - .5rem)}.project-gallery-item--portrait{width:100%}@media (min-width:768px){.project-gallery-item--portrait{width:calc(50% - .5rem)}}.project-gallery-rows{flex-direction:column;gap:1rem;padding:0 1.25rem 3rem;display:flex}.gallery-row{gap:1rem;width:100%;display:grid}.gallery-row--1-up{grid-template-columns:1fr}.gallery-row--2-up{grid-template-columns:repeat(2,1fr)}.gallery-row--3-up{grid-template-columns:repeat(3,1fr)}.gallery-row--4-up{grid-template-columns:repeat(4,1fr)}.gallery-row--5-up{grid-template-columns:repeat(5,1fr)}.gallery-row--6-up{grid-template-columns:repeat(6,1fr)}.gallery-row--7-up{grid-template-columns:repeat(7,1fr)}.gallery-row--8-up{grid-template-columns:repeat(8,1fr)}.gallery-row--9-up{grid-template-columns:repeat(9,1fr)}.gallery-row--10-up{grid-template-columns:repeat(10,1fr)}.gallery-row-item{background:var(--gray-light);cursor:zoom-in;aspect-ratio:var(--aspect-ratio,1.5);border:none;padding:0;position:relative;overflow:hidden}.gallery-row-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.gallery-row-item--video{aspect-ratio:auto;background:0 0;line-height:0}.gallery-row-item--video video{width:100%;height:auto;display:block}.gallery-row-item:hover img{transform:scale(1.02)}.gallery-row-item--pad-tight,.gallery-row-item--pad-normal{background:var(--color-bg)}.gallery-row-item--pad-tight img{object-fit:contain!important;width:calc(100% - 10rem)!important;height:calc(100% - 10rem)!important;inset:5rem!important}.gallery-row-item--pad-normal img{object-fit:contain!important;width:calc(100% - 14rem)!important;height:calc(100% - 14rem)!important;inset:7rem!important}.gallery-row-item--pad-tight:hover img,.gallery-row-item--pad-normal:hover img{transform:scale(1.02)}@media (max-width:767px){.gallery-row-item--pad-tight img{object-fit:contain!important;width:calc(100% - 2rem)!important;height:calc(100% - 2rem)!important;inset:1rem!important}.gallery-row-item--pad-normal img{object-fit:contain!important;width:calc(100% - 4rem)!important;height:calc(100% - 4rem)!important;inset:2rem!important}.gallery-row--2-up,.gallery-row--3-up,.gallery-row--4-up,.gallery-row--5-up,.gallery-row--6-up,.gallery-row--7-up,.gallery-row--8-up,.gallery-row--9-up,.gallery-row--10-up{grid-template-columns:1fr}.project-gallery-rows,.gallery-row{gap:.5rem}}.lightbox{z-index:100;background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-close{color:var(--white);cursor:pointer;z-index:101;background:0 0;border:none;font-size:2.5rem;line-height:1;position:absolute;top:1.5rem;right:1.5rem}.lightbox-nav{color:var(--white);cursor:pointer;z-index:101;background:0 0;border:none;padding:1rem;font-size:2rem;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav--prev{left:1rem}.lightbox-nav--next{right:1rem}.lightbox-image{width:100%;max-width:90vw;height:85vh;max-height:90vh;position:relative}.filters{border-bottom:1px solid var(--black);margin-bottom:2rem;padding:2rem 0}.filters-group{margin-bottom:1.5rem}.filters-group:last-child{margin-bottom:0}.filters-group .label{margin-bottom:.75rem;display:block}.filters-category{text-transform:uppercase;letter-spacing:.06em;color:var(--gray);margin-bottom:.5rem;font-size:10px}.filters-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.filter-btn{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--black);color:var(--black);cursor:pointer;background:0 0;padding:.4rem .75rem;font-size:11px;transition:background .15s,color .15s}.filter-btn:hover,.filter-btn.active{background:var(--black);color:var(--cream)}.filter-clear{color:var(--gray);cursor:pointer;background:0 0;border:none;margin-top:1rem;font-size:11px;text-decoration:underline}.filter-clear:hover{color:var(--black)}.studio-page{padding-top:calc(52px + 1.5rem)}.studio-intro{max-width:900px;padding:3rem 1.25rem 4rem}.studio-intro-text{font-family:var(--font-body);font-size:clamp(1rem,2.5vw,1.25rem);line-height:1.7}.studio-intro-text p{margin-bottom:1rem}.studio-grid{border-top:1px solid var(--gray-light);grid-template-columns:1fr;gap:3rem;padding:3rem 1.25rem;display:grid}@media (min-width:768px){.studio-grid{grid-template-columns:1fr 1fr;gap:4rem}}.studio-content h2,.studio-services h2{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.5rem;font-size:11px}.studio-section{margin-bottom:3rem}.studio-section:last-child{margin-bottom:0}.studio-section p{margin-bottom:1rem;font-size:15px;line-height:1.7}.studio-section p:last-child{margin-bottom:0}.studio-service-group{margin-bottom:1.5rem}.studio-service-group h3{text-transform:uppercase;letter-spacing:.08em;color:var(--gray);margin-bottom:.5rem;font-size:10px}.studio-services ul{margin:0;padding:0;list-style:none}.studio-services li{font-size:14px;line-height:1.8}.studio-contact{border-top:1px solid var(--gray-light);grid-template-columns:1fr;gap:3rem;padding:3rem 1.25rem;display:grid}@media (min-width:768px){.studio-contact{grid-template-columns:1fr 1fr;gap:4rem}}.studio-contact-cta h2{font-family:var(--font-display);text-transform:uppercase;margin-bottom:1rem;font-size:clamp(2rem,5vw,3rem);font-weight:600;line-height:1}.studio-contact-cta p{max-width:360px;margin-bottom:1.5rem;font-size:15px;line-height:1.6}.studio-email{font-family:var(--font-body);border-bottom:1px solid;padding-bottom:2px;font-size:1rem;text-decoration:none}.studio-email:hover{opacity:.7}.studio-contact-info-section{flex-wrap:wrap;gap:3rem;padding:2rem 1.25rem;display:flex}.studio-info-block{margin-bottom:1.5rem}.studio-info-block .label{color:var(--gray);margin-bottom:.25rem;display:block}.studio-info-block p{font-size:14px;line-height:1.5}.studio-social{gap:1rem;display:flex}.studio-social a{font-size:14px;text-decoration:none}.studio-social a:hover{text-decoration:underline}.studio-note{border-top:1px solid var(--gray-light);padding:3rem 1.25rem}.studio-note p{color:var(--gray);max-width:700px;font-size:12px;line-height:1.7}.page-header{border-bottom:1px solid var(--black);padding:3rem 1.25rem 2rem}.page-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.02em;font-size:clamp(3rem,12vw,6rem);font-weight:600;line-height:.9}.testimonial-section{border-top:1px solid var(--black);padding:3rem 1.25rem}.testimonial-quote{font-family:var(--font-body);max-width:700px;font-size:1.25rem;font-style:italic}.testimonial-attribution{color:var(--gray);margin-top:1rem;font-style:normal;display:block}.project-link-section{padding:2rem 1.25rem}.project-nav{border-top:1px solid var(--black);grid-template-columns:1fr auto 1fr;gap:1rem;padding:2rem 1.25rem;display:grid}.project-nav-item{flex-direction:column;display:flex}.project-nav-item a{flex-direction:column;gap:.25rem;text-decoration:none;transition:opacity .15s;display:flex}.project-nav-item a:hover{opacity:.6}.project-nav-prev{text-align:left;align-items:flex-start}.project-nav-all{justify-content:center;align-items:center}.project-nav-all a{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--black);border-radius:999px;padding:.5rem 1rem;font-size:12px;transition:background .15s,color .15s}.project-nav-all a:hover{background:var(--black);color:var(--cream);opacity:1}.project-nav-next{text-align:right;align-items:flex-end}.project-nav-label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em;color:var(--gray);font-size:10px}.project-nav-title{font-family:var(--font-display);text-transform:uppercase;font-size:1.75rem;font-weight:600}.project-nav-disabled{min-width:100px;display:block}@media (max-width:640px){.project-nav{grid-template-rows:auto auto;grid-template-columns:1fr 1fr}.project-nav-all{order:-1;grid-column:1/-1;margin-bottom:1rem}}.work-page{padding-top:140px}.work-page-header{padding:0 1.25rem .25rem}.work-page-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.02em;font-size:clamp(3rem,10vw,6rem);font-weight:600;line-height:1}.projects-section{padding:0 1.25rem 4rem}@media (max-width:768px){.site-nav{gap:1rem}.site-nav a{font-size:24px}}.hero-carousel{background:var(--black);width:100%;height:100vh;position:relative;overflow:hidden}.hero-carousel-slide{opacity:0;transition:opacity .8s,transform .5s;position:absolute;inset:0;transform:translate(0)}.hero-carousel-slide.active{opacity:1}.hero-carousel-slide.slide-left,.hero-carousel-slide.slide-right{transition:opacity 50ms,transform .5s}.hero-carousel-slide.slide-left.active{animation:.5s forwards slideInFromRight}.hero-carousel-slide.slide-left.exiting{animation:.5s forwards slideOutToLeft}.hero-carousel-slide.slide-right.active{animation:.5s forwards slideInFromLeft}.hero-carousel-slide.slide-right.exiting{animation:.5s forwards slideOutToRight}@keyframes slideInFromRight{0%{opacity:1;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutToLeft{0%{opacity:1;transform:translate(0)}to{opacity:1;transform:translate(-100%)}}@keyframes slideInFromLeft{0%{opacity:1;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutToRight{0%{opacity:1;transform:translate(0)}to{opacity:1;transform:translate(100%)}}.hero-carousel-slide img{object-fit:cover;width:100%;height:100%}.hero-carousel-nav{z-index:10;display:flex;position:absolute;inset:0}.hero-carousel-zone{cursor:pointer;flex:1}.hero-carousel-zone-prev{cursor:w-resize}.hero-carousel-zone-prev:hover{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M19 12H5M12 19l-7-7 7-7'/%3E%3C/svg%3E") 16 16,w-resize}.hero-carousel-zone-next{cursor:e-resize}.hero-carousel-zone-next:hover{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") 16 16,e-resize}.hero-carousel-info{z-index:20;color:var(--white);opacity:0;transition:opacity .3s,transform .3s;position:absolute;bottom:2rem;left:2rem;transform:translateY(10px)}.hero-carousel:hover .hero-carousel-info{opacity:1;transform:translateY(0)}.hero-carousel-client{font-family:var(--font-display);text-transform:uppercase;color:var(--white);mix-blend-mode:normal;margin-bottom:.15rem;font-size:clamp(1.5rem,5vw,42px);font-weight:600}.hero-carousel-tagline{font-family:var(--font-body);color:var(--white);mix-blend-mode:normal;font-size:18px}.hero-carousel-link{font-family:var(--font-body);color:var(--black);margin-top:.75rem;font-size:14px;text-decoration:underline;display:inline-block}.hero-carousel-indicators{z-index:20;mix-blend-mode:difference;gap:.5rem;display:flex;position:absolute;bottom:2rem;right:2rem}.hero-carousel-indicator{cursor:pointer;background:#fff6;border:none;border-radius:50%;width:8px;height:8px;transition:background .2s}.hero-carousel-indicator.active,.hero-carousel-indicator:hover{background:var(--white)}@media (max-width:768px){.hero-carousel{height:60vh}.hero-carousel-info{opacity:1;bottom:1.5rem;left:1rem;transform:none}.hero-carousel-indicators{bottom:1.5rem;right:1rem}}.grid-dense{grid-template-columns:1fr;gap:0;width:100%;min-height:60vh;display:grid}@media (min-width:768px){.grid-dense{grid-template-columns:repeat(2,1fr)}}.card-dense{aspect-ratio:3/2;background:var(--cream);position:relative;overflow:hidden}.card-dense-image{position:absolute;inset:0}.card-dense-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.card-dense:hover .card-dense-image img{transform:scale(1.05)}.card-dense-overlay{opacity:0;background:#1a1a1abf;flex-direction:column;justify-content:flex-end;padding:1.25rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.card-dense:hover .card-dense-overlay{opacity:1}.card-dense-client{font-family:var(--font-display);text-transform:uppercase;color:var(--cream);margin-bottom:.25rem;font-size:21px;font-weight:600}.card-dense-title{font-family:var(--font-body);color:var(--cream);margin-bottom:.75rem;font-size:1rem}.card-dense-tags{flex-wrap:wrap;gap:.35rem;display:flex}.tag-category{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.04em;color:var(--black);border-radius:2px;padding:.25rem .5rem;font-size:9px}.tag-category-strategy{background:var(--category-strategy)}.tag-category-design{background:var(--category-design)}.tag-category-interactive{background:var(--category-interactive)}.tag-category-content{background:var(--category-content)}@media (max-width:767px){.card-dense{aspect-ratio:auto}.card-dense-image{aspect-ratio:3/2;position:relative}.card-dense-overlay{opacity:1;background:var(--cream);padding:1rem;position:relative}.card-dense-client,.card-dense-title{color:var(--black)}.card-dense:hover .card-dense-image img{transform:none}}.work-filters{background:var(--cream);border-bottom:1px solid var(--gray-light);flex-wrap:wrap;gap:.5rem;padding:.75rem 1.25rem;display:flex}.filter-pill{font-family:var(--font-body);border:1px solid var(--black);color:var(--black);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:12px;transition:background .15s,color .15s;display:flex}.filter-pill:hover,.filter-pill.active{background:var(--hover-color)}.filter-pill-count{opacity:.7;font-size:10px}.filter-divider{background:var(--gray-light);align-self:center;width:1px;height:24px}.image-cycler{width:100%;height:100%;position:relative}.image-cycler-frame{opacity:0;transition:opacity .5s;position:absolute;inset:0}.image-cycler-frame.active{opacity:1}.image-cycler-frame img{object-fit:cover;width:100%;height:100%}.projects-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:e-resize;scroll-snap-type:x mandatory;width:100%;overflow:auto hidden}.projects-scroll::-webkit-scrollbar{display:none}.projects-scroll-track{width:max-content;display:flex}.projects-scroll-item{aspect-ratio:4/3;flex-shrink:0;width:33.333vw;position:relative;overflow:hidden}@media (max-width:1023px){.projects-scroll-item{width:50vw}}@media (max-width:767px){.projects-scroll-item{scroll-snap-align:center;width:100vw}}.projects-scroll-item img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.projects-scroll-item:hover img{transform:scale(1.03)}.projects-scroll-info{color:var(--white);opacity:0;padding:1.5rem;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.projects-scroll-item:hover .projects-scroll-info{opacity:1}.projects-scroll-client{font-family:var(--font-display);text-transform:uppercase;margin-bottom:.25rem;font-size:36px;font-weight:600}.projects-scroll-tagline{font-family:var(--font-body);font-size:16px}.projects-scroll-container{width:100%;position:relative}.projects-scroll-arrow{z-index:10;cursor:pointer;background:0 0;border:none;width:80px;position:absolute;top:0;bottom:0}.projects-scroll-arrow-prev{cursor:w-resize;left:0}.projects-scroll-arrow-prev:hover{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23141414' stroke-width='2'%3E%3Cpath d='M19 12H5M12 19l-7-7 7-7'/%3E%3C/svg%3E") 16 16,w-resize}.projects-scroll-arrow-next{cursor:e-resize;right:0}.projects-scroll-arrow-next:hover{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23141414' stroke-width='2'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") 16 16,e-resize}.styleguide{padding:calc(var(--nav-height) + var(--space-4))var(--gutter)var(--space-8);max-width:1200px;margin:0 auto}.styleguide-header{margin-bottom:var(--space-8);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-4)}.styleguide-header h1{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3rem,8vw,5rem);font-weight:600;line-height:var(--leading-tight);margin:0 0 var(--space-2)}.styleguide-header p{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-muted);margin:0}.styleguide-section{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}.styleguide-section:last-child{border-bottom:none}.styleguide-section h2{font-family:var(--font-body);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin:0 0 var(--space-4);font-weight:600}.styleguide-section h3{font-family:var(--font-body);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-muted);margin:var(--space-4)0 var(--space-2);font-weight:600}.styleguide-section code{font-family:var(--font-body);font-size:var(--text-sm);background:var(--color-border);border-radius:2px;margin:2px 0;padding:2px 6px;display:inline-block}.styleguide-swatches{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.styleguide-swatches-accent{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.styleguide-swatch{gap:var(--space-1);flex-direction:column;display:flex}.styleguide-swatch-color{height:80px;padding:var(--space-1);font-family:var(--font-body);font-size:var(--text-xs);border:1px solid var(--color-border);justify-content:flex-start;align-items:flex-end;display:flex}.styleguide-swatches-accent .styleguide-swatch-color{height:60px;color:var(--color-text)}.styleguide-type-specimen{margin-bottom:var(--space-4)}.styleguide-display-sample{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,6vw,4rem);font-weight:600;line-height:var(--leading-tight);margin:var(--space-2)0}.styleguide-body-sample{font-family:var(--font-body);font-size:var(--text-lg);line-height:var(--leading-loose);margin:var(--space-2)0}.styleguide-type-sizes{margin-top:var(--space-4)}.styleguide-type-size{margin:var(--space-1)0;font-family:var(--font-body)}.styleguide-spacing{gap:var(--space-4);flex-wrap:wrap;align-items:flex-end;display:flex}.styleguide-spacing-item{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.styleguide-spacing-box{background:var(--color-magenta);opacity:.7}.styleguide-spacing-label{text-align:center}.styleguide-spacing-label span{font-size:var(--text-xs);color:var(--color-muted);display:block}.styleguide-buttons{gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.styleguide-button-item{align-items:flex-start;gap:var(--space-1);flex-direction:column;display:flex}.styleguide-button-vars{background:var(--color-border);padding:var(--space-3);border-radius:4px}.styleguide-button-vars code{margin:var(--space-1)0;background:0 0;display:block}.styleguide-layout-vars,.styleguide-effects,.styleguide-zindex{gap:var(--space-1);flex-direction:column;display:flex}.carousel-tool-page{color:#f0f0f0;background:#1a1a1a;min-height:100vh}.carousel-tool{flex-direction:column;min-height:100vh;display:flex}.carousel-tool-header{z-index:50;background:#111;border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.carousel-tool-header h1{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:14px;font-weight:600}.carousel-tool-header-left{align-items:center;gap:1rem;display:flex}.carousel-tool-project-name{color:#888;font-size:12px}.carousel-tool-header-right{gap:.5rem;display:flex}.carousel-tool-btn{color:#f0f0f0;font-family:var(--font-body);cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;padding:.5rem 1rem;font-size:12px;transition:background .15s,border-color .15s}.carousel-tool-btn:hover:not(:disabled){background:#333;border-color:#666}.carousel-tool-btn:disabled{opacity:.4;cursor:not-allowed}.carousel-tool-btn-icon{justify-content:center;align-items:center;padding:.5rem;display:flex}.carousel-tool-main{flex:1;grid-template-columns:280px 1fr 320px;min-height:0;display:grid}@media (max-width:1200px){.carousel-tool-main{grid-template-columns:240px 1fr 280px}}@media (max-width:900px){.carousel-tool-main{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}}.carousel-tool-sidebar{background:#1a1a1a;border-right:1px solid #333;flex-direction:column;max-height:calc(100vh - 60px);display:flex;overflow-y:auto}.carousel-tool-sidebar-right{border-left:1px solid #333;border-right:none}.carousel-tool-section{border-bottom:1px solid #333;padding:1rem}.carousel-tool-section-grow{flex:1;overflow-y:auto}.carousel-tool-section-title{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;color:#888;margin:0 0 .75rem;font-size:10px;font-weight:600}.carousel-tool-center{flex-direction:column;height:calc(100vh - 60px);padding:1.5rem;display:flex;overflow:hidden}.carousel-tool-empty{text-align:center;color:#666;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:3rem;display:flex}.carousel-tool-empty-icon{opacity:.3;margin-bottom:1rem}.carousel-tool-empty h3{font-family:var(--font-body);color:#888;margin:0 0 .5rem;font-size:16px;font-weight:600}.carousel-tool-empty p{max-width:280px;font-size:13px;line-height:1.5}.carousel-tool-empty-small{padding:2rem 1rem}.carousel-tool-loading{color:#666;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;font-size:12px;display:flex}.carousel-tool-spinner{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.project-selector{position:relative}.project-selector-trigger{color:#f0f0f0;cursor:pointer;width:100%;font-family:var(--font-body);text-align:left;background:#222;border:1px solid #444;border-radius:4px;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;font-size:13px;display:flex}.project-selector-trigger:hover{border-color:#666}.project-selector-selected{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.project-selector-thumb{object-fit:cover;border-radius:2px;flex-shrink:0}.project-selector-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.project-selector-count{color:#888;flex-shrink:0;font-size:11px}.project-selector-placeholder{color:#666}.project-selector-chevron{flex-shrink:0;transition:transform .2s}.project-selector-chevron.open{transform:rotate(180deg)}.project-selector-dropdown{z-index:100;background:#222;border:1px solid #444;border-radius:4px;flex-direction:column;max-height:400px;margin-top:4px;display:flex;position:absolute;top:100%;left:0;right:0;overflow:hidden}.project-selector-search{border-bottom:1px solid #333;align-items:center;gap:.5rem;padding:.75rem;display:flex}.project-selector-search input{color:#f0f0f0;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;font-size:13px}.project-selector-search input::placeholder,.project-selector-search-icon{color:#666}.project-selector-list{flex:1;margin:0;padding:0;list-style:none;overflow-y:auto}.project-selector-item{color:#f0f0f0;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.75rem;transition:background .1s;display:flex}.project-selector-item:hover{background:#333}.project-selector-item.active{background:#2a2a2a}.project-selector-item-thumb{object-fit:cover;border-radius:2px;flex-shrink:0}.project-selector-item-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.project-selector-item-title{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.project-selector-item-count{color:#888;font-size:11px}.project-selector-empty{text-align:center;color:#666;padding:1.5rem;font-size:13px}.image-grid{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.image-grid-item{cursor:pointer;border-radius:2px;position:relative;overflow:hidden}.image-grid-item-inner{aspect-ratio:1;background:#2a2a2a;position:relative}.image-grid-thumb{object-fit:cover;width:100%;height:100%;transition:opacity .15s,transform .15s}.image-grid-item:hover .image-grid-thumb{transform:scale(1.05)}.image-grid-item.in-carousel{opacity:.5}.image-grid-item.in-carousel .image-grid-thumb{filter:grayscale(50%)}.image-grid-badge{background:var(--color-cyan);color:#000;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:4px;right:4px}.image-grid-panorama-btn{color:var(--color-cyan);cursor:pointer;opacity:0;background:#000000b3;border:none;border-radius:2px;padding:4px 6px;font-size:10px;transition:opacity .15s;position:absolute;top:4px;left:4px}.image-grid-item:hover .image-grid-panorama-btn{opacity:1}.image-grid-dimensions{opacity:0;background:#000000b3;border-radius:2px;padding:2px 4px;font-size:9px;transition:opacity .15s;position:absolute;bottom:4px;right:4px}.image-grid-item:hover .image-grid-dimensions{opacity:1}.crop-canvas-container{width:100%;height:100%;position:relative}.crop-canvas{touch-action:none}.crop-canvas.dragging{cursor:grabbing}.crop-canvas-loading{color:#666;flex-direction:column;align-items:center;gap:.75rem;font-size:13px;display:flex}.crop-canvas-spinner{animation:1s linear infinite spin}.crop-editor{flex-direction:column;flex:1;display:flex}.crop-editor-canvas-wrapper{flex:1;min-height:0;display:flex}.crop-editor-controls{border-top:1px solid #333;flex-wrap:wrap;gap:2rem;margin-top:1rem;padding:1rem 0;display:flex}.crop-editor-control-group{flex-direction:column;gap:.5rem;display:flex}.crop-editor-control-group label{text-transform:uppercase;letter-spacing:.08em;color:#888;font-size:10px}.crop-editor-zoom-controls{align-items:center;gap:.5rem;display:flex}.crop-editor-zoom-value{text-align:center;min-width:40px;font-size:12px}.crop-editor-btn{color:#f0f0f0;cursor:pointer;background:#333;border:1px solid #444;border-radius:4px;justify-content:center;align-items:center;padding:.4rem;display:flex}.crop-editor-btn:hover:not(:disabled){background:#444}.crop-editor-btn:disabled{opacity:.4;cursor:not-allowed}.crop-editor-nudge-controls{flex-direction:column;align-items:center;gap:2px;display:flex}.crop-editor-nudge-row{gap:2px;display:flex}.crop-editor-nudge-btn,.crop-editor-reset-btn{width:28px;height:28px}.crop-editor-center-row{gap:4px;margin-top:6px;display:flex}.crop-editor-center-btn{flex:1;height:24px;font-size:10px}.crop-editor-lock-row{gap:4px;margin-top:4px;display:flex}.crop-editor-lock-btn{flex:1;height:24px;font-size:10px}.crop-editor-lock-btn.active{color:#ffc800;background:#ffc80033;border-color:#ffc800}.crop-editor-split-group{border-top:1px solid #333;margin-top:.5rem;padding-top:.75rem}.crop-editor-split-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;font-size:12px;display:flex}.crop-editor-split-btn.active{border-color:var(--color-cyan);color:var(--color-cyan);background:#00c8ff26}.crop-editor-split-controls{background:#222;border-radius:4px;flex-direction:column;gap:.75rem;margin-top:.75rem;padding:.75rem;display:flex}.crop-editor-slice-slider{flex-direction:column;gap:.25rem;display:flex}.crop-editor-slice-label{color:#ccc;text-align:center;font-size:12px}.crop-editor-slider{appearance:none;cursor:pointer;background:#333;border-radius:2px;width:100%;height:4px}.crop-editor-slider::-webkit-slider-thumb{appearance:none;background:var(--color-cyan);cursor:pointer;border-radius:50%;width:14px;height:14px}.crop-editor-slider::-moz-range-thumb{background:var(--color-cyan);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.crop-editor-slider-labels{color:#666;justify-content:space-between;font-size:10px;display:flex}.crop-editor-apply-btn{background:var(--color-cyan);color:#000;border:none;padding:.5rem 1rem;font-size:12px;font-weight:500}.crop-editor-apply-btn:hover:not(:disabled){background:#5fd9ff}.crop-editor-apply-btn:disabled{color:#666;background:#333}.crop-editor-info{color:#888;flex-direction:column;gap:.25rem;margin-left:auto;font-size:11px;display:flex}.crop-editor-instructions{text-align:center;color:#666;padding:.75rem;font-size:11px}.crop-editor-empty,.crop-editor-error{color:#666;flex:1;justify-content:center;align-items:center;display:flex}.aspect-ratio-selector{flex-direction:column;gap:1rem;display:flex}.aspect-ratio-presets{flex-wrap:wrap;gap:.5rem;display:flex}.aspect-ratio-preset{cursor:pointer;color:#ccc;background:#222;border:1px solid #444;border-radius:4px;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .75rem;transition:background .15s,border-color .15s;display:flex}.aspect-ratio-preset:hover{background:#333;border-color:#666}.aspect-ratio-preset.active{border-color:var(--color-cyan);color:var(--white);background:#333}.aspect-ratio-preset-icon{opacity:.7}.aspect-ratio-preset.active .aspect-ratio-preset-icon{opacity:1}.aspect-ratio-preset-name{font-size:11px;font-weight:500}.aspect-ratio-preset-ratio{color:#888;font-size:10px}.aspect-ratio-custom{background:#222;border-radius:4px;padding:1rem}.aspect-ratio-custom-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.aspect-ratio-custom-field{flex-direction:column;gap:.25rem;display:flex}.aspect-ratio-custom-field label{color:#888;font-size:10px}.aspect-ratio-custom-field input{color:#f0f0f0;width:80px;font-family:var(--font-body);background:#333;border:1px solid #444;border-radius:4px;padding:.5rem;font-size:13px}.aspect-ratio-custom-field input:focus{border-color:var(--color-cyan);outline:none}.aspect-ratio-custom-or,.aspect-ratio-custom-x{color:#666;padding-bottom:.5rem;font-size:12px}.aspect-ratio-custom-apply{background:var(--color-cyan);color:#000;font-family:var(--font-body);cursor:pointer;border:none;border-radius:4px;padding:.5rem 1rem;font-size:12px;font-weight:600}.aspect-ratio-custom-apply:hover{opacity:.9}.aspect-ratio-current{color:#888;text-align:center;font-size:12px}.draggable-image-list{flex-direction:column;gap:.75rem;display:flex}.draggable-image-list-items{flex-direction:column;gap:4px;display:flex}.draggable-image-item{cursor:grab;background:#222;border:1px solid #333;border-radius:4px;align-items:center;gap:.5rem;padding:.5rem;transition:background .15s,border-color .15s;display:flex}.draggable-image-item:hover{background:#2a2a2a}.draggable-image-item.active{border-color:var(--color-cyan)}.draggable-image-item.dragging{opacity:.5}.draggable-image-item.drag-over{background:#333;border-color:#666}.draggable-image-item-number{color:#888;min-width:16px;font-size:11px}.draggable-image-item-thumb{border-radius:2px;width:40px;height:40px;position:relative;overflow:hidden}.draggable-image-item-thumb img{object-fit:cover;width:100%;height:100%}.draggable-image-item-pano-badge{background:var(--color-magenta);color:#000;border-radius:2px;padding:1px 3px;font-size:8px;position:absolute;bottom:2px;right:2px}.draggable-image-item-duplicate{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-left:auto;padding:4px;display:flex}.draggable-image-item-duplicate:hover{color:var(--color-cyan);background:#00ffff1a}.draggable-image-item-remove{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.draggable-image-item-remove:hover{color:#f66;background:#ff66661a}.draggable-image-item-drag-handle{color:#444;cursor:grab}.draggable-image-list-actions{justify-content:center;display:flex}.draggable-image-list-clear{color:#888;cursor:pointer;background:0 0;border:none;font-size:11px;text-decoration:underline}.draggable-image-list-clear:hover{color:#f66}.carousel-preview{flex-direction:column;align-items:center;gap:.75rem;display:flex}.carousel-preview-phone{background:#000;border-radius:24px;width:200px;padding:8px;box-shadow:0 10px 40px #0006}.carousel-preview-screen{cursor:pointer;background:#1a1a1a;border-radius:16px;position:relative;overflow:hidden}.carousel-preview-image{width:100%;display:block}.carousel-preview-placeholder{color:#666;background:#222;justify-content:center;align-items:center;font-size:11px;display:flex}.carousel-preview-nav{color:var(--white);cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-preview-screen:hover .carousel-preview-nav{opacity:1}.carousel-preview-nav:disabled{opacity:0!important}.carousel-preview-nav-prev{left:8px}.carousel-preview-nav-next{right:8px}.carousel-preview-dots{justify-content:center;gap:4px;padding:8px 0;display:flex}.carousel-preview-dot{cursor:pointer;background:#444;border:none;border-radius:50%;width:6px;height:6px}.carousel-preview-dot.active{background:var(--white)}.carousel-preview-footer{justify-content:center;align-items:center;gap:.75rem;display:flex}.carousel-preview-counter{color:#888;font-size:11px}.carousel-preview-refresh{cursor:pointer;color:#888;background:0 0;border:1px solid #444;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;transition:color .15s,border-color .15s;display:flex}.carousel-preview-refresh:hover:not(:disabled){color:#f0f0f0;border-color:#666}.carousel-preview-refresh:disabled{opacity:.5;cursor:not-allowed}.carousel-preview-instructions{color:#666;font-size:10px}.carousel-preview-spinner{animation:1s linear infinite spin}.panorama-splitter{flex-direction:column;gap:1.5rem;max-width:800px;margin:0 auto;display:flex}.panorama-splitter-header{justify-content:space-between;align-items:center;display:flex}.panorama-splitter-header h2{font-family:var(--font-body);margin:0;font-size:16px;font-weight:600}.panorama-splitter-close{color:#888;cursor:pointer;background:0 0;border:none;padding:4px}.panorama-splitter-close:hover{color:var(--white)}.panorama-splitter-preview{position:relative}.panorama-splitter-image-container{border-radius:4px;position:relative;overflow:hidden}.panorama-splitter-image{width:100%;height:auto;display:block}.panorama-splitter-overlay{display:flex;position:absolute;inset:0}.panorama-splitter-slice{border-left:2px dashed var(--color-cyan);border-right:2px dashed var(--color-cyan);background:#00ffff1a;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0}.panorama-splitter-slice:first-child{border-left:none}.panorama-splitter-slice:last-child{border-right:none}.panorama-splitter-slice-number{color:var(--color-cyan);text-shadow:0 2px 4px #00000080;font-size:24px;font-weight:600}.panorama-splitter-controls{flex-direction:column;gap:1rem;display:flex}.panorama-splitter-control{flex-direction:column;gap:.5rem;display:flex}.panorama-splitter-control label{color:#888;font-size:12px}.panorama-splitter-slider-row{align-items:center;gap:1rem;display:flex}.panorama-splitter-slider{appearance:none;cursor:pointer;background:#444;border-radius:2px;flex:1;height:4px}.panorama-splitter-slider::-webkit-slider-thumb{appearance:none;background:var(--color-cyan);cursor:grab;border-radius:50%;width:16px;height:16px}.panorama-splitter-slider-value{text-align:center;min-width:40px;font-size:24px;font-weight:600}.panorama-splitter-slider-labels{color:#666;justify-content:space-between;font-size:10px;display:flex}.panorama-splitter-error-message{color:#f66;background:#ff66661a;border-radius:4px;padding:.5rem;font-size:12px}.panorama-splitter-info{color:#888;flex-wrap:wrap;gap:1.5rem;font-size:11px;display:flex}.panorama-splitter-info-highlight{color:var(--color-cyan);font-weight:500}.panorama-splitter-label-hint{color:#666;margin-top:2px;font-size:10px;font-weight:400;display:block}.panorama-splitter-crop-band{pointer-events:none;z-index:1;background:#0009;position:absolute;left:0;right:0}.panorama-splitter-crop-top{border-bottom:2px solid var(--color-yellow);top:0}.panorama-splitter-crop-bottom{border-top:2px solid var(--color-yellow);bottom:0}.panorama-splitter-actions{justify-content:flex-end;gap:.75rem;display:flex}.panorama-splitter-btn{font-family:var(--font-body);cursor:pointer;border-radius:4px;padding:.75rem 1.5rem;font-size:13px;font-weight:600}.panorama-splitter-btn-secondary{color:#ccc;background:0 0;border:1px solid #444}.panorama-splitter-btn-secondary:hover{background:#333}.panorama-splitter-btn-primary{background:var(--color-cyan);color:#000;border:none}.panorama-splitter-btn-primary:hover{opacity:.9}.panorama-splitter-btn-primary:disabled{opacity:.4;cursor:not-allowed}.panorama-splitter-error{color:#888;flex-direction:column;align-items:center;gap:1rem;padding:3rem;display:flex}.export-panel{flex-direction:column;gap:1rem;display:flex}.export-panel-info{background:#222;border-radius:4px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.export-panel-info-row{justify-content:space-between;font-size:12px;display:flex}.export-panel-label{color:#888}.export-panel-value{font-weight:500}.export-panel-quality{flex-direction:column;gap:.5rem;display:flex}.export-panel-quality label{color:#888;font-size:11px}.export-panel-slider{appearance:none;cursor:pointer;background:#444;border-radius:2px;width:100%;height:4px}.export-panel-slider::-webkit-slider-thumb{appearance:none;background:var(--white);cursor:grab;border-radius:50%;width:14px;height:14px}.export-panel-quality-labels{color:#666;justify-content:space-between;font-size:9px;display:flex}.export-panel-filenames{flex-direction:column;gap:.5rem;display:flex}.export-panel-filenames label{text-transform:uppercase;letter-spacing:.08em;color:#888;font-size:10px}.export-panel-filename-list{flex-wrap:wrap;gap:.25rem;display:flex}.export-panel-filename{color:#aaa;background:#333;border-radius:2px;padding:2px 6px;font-size:10px}.export-panel-filename-more{color:#666}.export-panel-progress{background:#222;border-radius:4px;height:24px;position:relative;overflow:hidden}.export-panel-progress-bar{background:var(--color-cyan);transition:width .2s;position:absolute;top:0;bottom:0;left:0}.export-panel-progress-text{color:var(--white);mix-blend-mode:difference;justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;inset:0}.export-panel-actions{flex-direction:column;gap:.5rem;display:flex}.export-panel-btn{font-family:var(--font-body);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:12px;font-weight:600;display:flex}.export-panel-btn:disabled{opacity:.4;cursor:not-allowed}.export-panel-btn-secondary{color:#ccc;background:0 0;border:1px solid #444}.export-panel-btn-secondary:hover:not(:disabled){background:#333}.export-panel-btn-primary{background:var(--color-cyan);color:#000;border:none}.export-panel-btn-primary:hover:not(:disabled){opacity:.9}.export-panel-help{color:#666;font-size:10px;line-height:1.4}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
