/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:0}.z-50{z-index:50}.z-\[9999\]{z-index:9999}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-full{height:100%}.max-h-\[90vh\]{max-height:90vh}.w-full{width:100%}.max-w-\[90vw\]{max-width:90vw}.max-w-full{max-width:100%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-zoom-in{cursor:zoom-in}.cursor-zoom-out{cursor:zoom-out}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-10{gap:2.5rem}.gap-5{gap:1.25rem}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity))}.bg-opacity-90{--tw-bg-opacity:0.9}.object-contain{-o-object-fit:contain;object-fit:contain}.p-5{padding:1.25rem}.underline{text-decoration-line:underline}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-\[800ms\]{transition-duration:.8s}*{margin:0;padding:0;box-sizing:border-box}body,html{width:100%;height:100%}body{margin:0;padding:0}.mobile-container{width:100%;height:100dvh;overflow:hidden;position:relative}.mobile-wrapper{display:block}.desktop-wrapper{display:none}@media (min-width:768px){.mobile-wrapper{display:none}.desktop-wrapper{display:flex;width:100%;height:100dvh;background:#fff;align-items:center;justify-content:center;padding:2rem;overflow:hidden}.iphone-mockup{width:375px;height:812px;background:#000;border-radius:3rem;padding:.5rem;box-shadow:0 20px 60px rgba(0,0,0,.15);position:relative}.iphone-screen{width:100%;height:100%;background:#fff;border-radius:2.5rem;overflow:hidden;position:relative}.iphone-screen:after{content:"";position:absolute;bottom:.5rem;left:50%;transform:translateX(-50%);width:134px;height:5px;background:hsla(0,0%,100%,.3);border-radius:9999px}.mobile-container{width:100%;height:100%}}.screen-content{width:100%;height:100%}.screen-content,.top-section{display:flex;flex-direction:column;overflow:hidden}.top-section{height:50%}.logo-container{width:100%;color:#000;flex-shrink:0}.logo-container .logo-svg{width:100%;height:auto}.projects-grid{margin:30px 20px;flex-grow:1;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:1fr 1fr 1fr;gap:18px;min-height:0;overflow:hidden}.grid-header{grid-column:1/-1;background:#000;font-size:2.25rem;font-weight:700;color:#fff;padding:16px}.grid-cell,.grid-header{display:flex;align-items:center;justify-content:center;min-height:0;height:100%}.grid-cell{background:#f0f0f0;overflow:hidden;width:100%;text-decoration:none;color:inherit}.grid-cell.grid-cell-active{background:#000;cursor:pointer}.grid-cell.grid-cell-active:hover{opacity:.9}.grid-cell-active{background:#000}.grid-cell-active .grid-cell-content,.grid-cell-active .project-logo-wrapper{color:#fff}.grid-cell-content{font-size:3rem;font-weight:700;color:#000}.project-logo-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px}.project-logo-wrapper svg{width:100%;height:auto;max-height:100%;color:inherit}.bottom-section{height:50%;display:flex;flex-direction:column;margin-top:0;overflow:hidden}.image-container{width:100%;flex-grow:1;position:relative;overflow:hidden;flex-shrink:1;min-height:0;background:#f0f0f0}.project-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.contact-button{width:calc(100% - 40px);background:#000;color:#fff;border:none;padding:18px 24px;font-size:2.25rem;font-weight:700;cursor:pointer;margin:30px auto auto;flex-shrink:0;transition:opacity .2s}.contact-button:hover{opacity:.8}.logo-container-bottom{width:100%;color:#000;margin-top:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.logo-container-bottom .logo-svg{width:100%;height:auto}@media (max-width:375px){.screen-content{padding:20px}.grid-header{font-size:1.75rem;padding:12px}.grid-cell-content{font-size:2.5rem}.projects-grid{gap:16px}.contact-button{font-size:1.125rem;padding:16px 20px}}@media (min-width:768px){.screen-content{padding:22px}.grid-header{font-size:1.75rem;padding:14px}.grid-cell-content{font-size:2.25rem}.projects-grid{gap:16px}.contact-button{font-size:1.125rem;padding:16px 20px}}.project-detail-top{flex-shrink:0;padding-bottom:20px}.project-logo-container{width:100%;color:#000;display:flex;align-items:center;justify-content:center}.project-logo-container svg{width:100%;height:auto;max-height:80px}.project-detail-middle{flex-grow:1;min-height:0;overflow:hidden}.project-detail-bottom{flex-shrink:0;padding-top:20px;text-align:center;margin-bottom:20px}.page-transition{opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.page-transition-enter{opacity:1;transform:translateY(0)}.image-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(4,1fr);gap:18px;overflow:hidden}.image-grid-cell{position:relative;background:#f0f0f0;overflow:hidden;cursor:pointer;min-height:0}.image-grid-thumbnail{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.image-grid-cell:hover{opacity:.8}.back-button{width:calc(100% - 40px);background:#000;color:#fff;border:none;padding:18px 24px;font-size:2.25rem;font-weight:700;cursor:pointer;margin:auto;transition:opacity .2s}.back-button:hover{opacity:.8}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.lightbox-image-container{position:relative;width:90%;height:90%;max-width:90vw;max-height:90vh;cursor:pointer}.lightbox-image{-o-object-fit:contain;object-fit:contain;width:100%;height:100%}.contact-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.25);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer;opacity:0;transition:opacity .3s ease,-webkit-backdrop-filter .3s ease;transition:opacity .3s ease,backdrop-filter .3s ease;transition:opacity .3s ease,backdrop-filter .3s ease,-webkit-backdrop-filter .3s ease;pointer-events:none}.contact-overlay.open{opacity:1;pointer-events:auto}.contact-overlay-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;width:calc(100% - 40px);max-width:500px;position:relative;cursor:default;opacity:0;transform:scale(.95) translateY(20px);transition:opacity .3s ease .1s,transform .3s ease .1s}.contact-overlay.open .contact-overlay-content{opacity:1;transform:scale(1) translateY(0)}.contact-close-button{position:absolute;top:-50px;right:0;background:transparent;border:none;color:#fff;font-size:3rem;font-weight:700;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;line-height:1;transition:opacity .2s}.contact-close-button:hover{opacity:.7}.contact-action-button{width:100%;background:#000;color:#fff;border:none;padding:18px 24px;font-size:2.25rem;font-weight:700;cursor:pointer;transition:opacity .2s}.contact-action-button:hover{opacity:.8}@media (max-width:375px){.contact-action-button{font-size:1.5rem;padding:16px 20px}.contact-close-button{font-size:2.5rem;top:-40px}}@media (min-width:768px){.contact-action-button{font-size:1.75rem;padding:16px 20px}}@media (max-width:375px){.image-grid{gap:16px}.back-button{font-size:1.125rem;padding:16px 20px}}@media (min-width:768px){.image-grid{gap:16px}.back-button{font-size:1.125rem;padding:16px 20px}}@keyframes flicker{0%,10%,to{opacity:1}5%{opacity:0}}.flicker-dot{animation:flicker 10s infinite}@media (min-width:768px){.md\:fixed{position:fixed}.md\:bottom-5{bottom:1.25rem}.md\:right-5{right:1.25rem}.md\:block{display:block}.md\:hidden{display:none}.md\:w-1\/2{width:50%}.md\:w-\[500px\]{width:500px}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}