@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400;1,500&family=DM+Sans:opsz,wght@9..40,400;9..40,500&display=swap";*{box-sizing:border-box;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin:0;padding:0}html,body,#root{min-height:100%}body{min-width:320px}img,svg{max-width:100%;display:block}button,input,textarea,select{font:inherit}:root{--canvas:#f3efe9;--ink:#363a35;--ink-soft:#8a8e89;--ink-faint:#363a351a;--font-serif:"Cormorant Garamond", serif;--font-sans:"DM Sans", sans-serif;--space-xs:.5rem;--space-sm:1.5rem;--space-md:4rem;--space-lg:8rem;--space-xl:12rem}html{scroll-behavior:smooth}body{color:var(--ink);font-family:var(--font-sans);background-color:#4a4340;background-image:radial-gradient(circle at 20% 30%,#615854 0%,#0000 40%),radial-gradient(circle at 80% 80%,#3b3532 0%,#0000 50%);background-attachment:fixed;min-height:100vh;padding:0}a{color:inherit;text-decoration:none}h1,h2,h3{font-family:var(--font-serif);font-weight:400}em{font-style:italic}.page-shell{justify-content:center;width:100%;min-height:100vh;display:flex}.studio-canvas{background-color:var(--canvas);flex-direction:column;width:100%;min-height:100vh;display:flex;position:relative;overflow:hidden}.eyebrow{color:var(--ink-soft);font-family:var(--font-sans);letter-spacing:.2em;text-transform:uppercase;font-size:.65rem;font-weight:500}.site-header,.site-footer{padding:var(--space-md);justify-content:space-between;align-items:center;display:flex}.site-header{padding-bottom:0}.logo{font-family:var(--font-serif);letter-spacing:.02em;font-size:1.5rem;font-style:italic}.meta-nav{gap:var(--space-sm);display:flex}.meta-nav a,.meta-nav span{align-items:center;gap:6px;transition:color .2s;display:flex;position:relative}.meta-nav a:before,.meta-nav span:before{background:var(--ink-faint);content:"";border-radius:50%;width:4px;height:4px;display:block}.meta-nav a:hover{color:var(--ink)}.hero{padding:var(--space-xl) var(--space-md) 9rem;text-align:center;flex-direction:column;align-items:center;display:flex}.bookmark-icon{fill:none;height:24px;margin-bottom:var(--space-sm);stroke:var(--ink);stroke-linejoin:round;stroke-width:1.5px;width:16px}.hero h1{color:var(--ink);margin-bottom:var(--space-md);max-width:11ch;font-size:clamp(2.8rem,5vw,5.4rem);line-height:.98}.hero h1 em{padding:0 .08em;display:inline-block}.squiggle{fill:none;height:60px;margin-bottom:var(--space-md);stroke:var(--ink);stroke-linecap:round;stroke-width:1.5px;width:24px}.hero-copy{color:var(--ink);letter-spacing:.1em;text-transform:none;max-width:42ch;font-size:.9rem;line-height:1.7}.section-block{padding:0 var(--space-md) var(--space-xl)}.section-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);justify-content:center;display:flex}.section-header:before,.section-header:after{background-color:var(--ink-faint);content:"";width:40px;height:1px}.work-grid{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);max-width:1000px;margin:0 auto;display:grid}.work-item{cursor:pointer;gap:var(--space-sm);flex-direction:column;display:flex}.work-link{gap:var(--space-sm);flex-direction:column;display:flex}.work-item-offset{margin-top:4rem}.device-shell{aspect-ratio:3/4;border:1px solid var(--ink-faint);background-color:#ffffff4d;justify-content:center;align-items:center;transition:all .4s;display:flex;position:relative}.device-shell:before,.device-shell:after{content:"";pointer-events:none;width:100%;height:100%;position:absolute}.device-shell:before{border-bottom:1px solid var(--ink-soft);border-top:1px solid var(--ink-soft);opacity:0;transition:opacity .4s,transform .6s cubic-bezier(.16,1,.3,1);transform:scaleX(.05)}.device-shell:after{border-left:1px solid var(--ink-soft);border-right:1px solid var(--ink-soft);opacity:0;transition:opacity .4s,transform .6s cubic-bezier(.16,1,.3,1);transform:scaleY(.05)}.work-item:hover .device-shell{background-color:#fff9;border-color:#363a3533}.work-item:hover .device-shell:before{opacity:.3;transform:scaleX(.1)}.work-item:hover .device-shell:after{opacity:.3;transform:scaleY(.1)}.shell-label{color:var(--ink-soft);font-family:var(--font-serif);font-size:1.1rem;font-style:italic}.app-artwork{border-radius:22%;max-width:52%;height:auto;transition:transform .4s,box-shadow .4s;box-shadow:0 18px 32px #363a3529}.work-meta{padding-top:var(--space-xs);border-top:1px solid #0000;justify-content:space-between;align-items:baseline;transition:border-color .4s;display:flex}.work-item:hover .work-meta{border-top-color:var(--ink-faint)}.work-item:hover .app-artwork{transform:translateY(-4px);box-shadow:0 22px 42px #363a3538}.work-title{font-size:1.25rem}.work-type{color:var(--ink-soft)}.narrative-stack{justify-items:center;gap:2rem;width:100%;max-width:1000px;margin:0 auto;display:grid}.narrative-heading{font-family:var(--font-serif);text-align:center;max-width:16ch;font-size:clamp(2.3rem,3.4vw,3.3rem);line-height:1.08}.narrative-copy{align-content:start;gap:var(--space-sm);text-align:center;justify-items:center;display:grid}.narrative-copy p,.contact-lead{max-width:42ch;font-size:.98rem;line-height:1.8}.contact-panel{border-top:1px solid var(--ink-faint);align-items:end;gap:var(--space-md);max-width:1000px;padding-top:var(--space-sm);justify-content:space-between;margin:0 auto;display:flex}.contact-link{border-bottom:1px solid var(--ink);font-family:var(--font-serif);padding-bottom:.15rem;font-size:clamp(1.6rem,2.4vw,2.2rem);line-height:1.1;transition:color .2s,border-color .2s}.contact-link:hover{border-color:var(--ink-soft);color:var(--ink-soft)}.site-footer{border-top:1px solid var(--ink-faint);margin-top:auto}@media (width<=900px){.hero{padding:var(--space-lg) var(--space-sm)}.hero h1{max-width:12ch}.site-header,.site-footer,.contact-panel,.narrative-stack{grid-template-columns:1fr;align-items:start}.site-header,.site-footer{gap:var(--space-sm)}.site-header,.site-footer,.section-block{padding-left:var(--space-sm);padding-right:var(--space-sm)}.work-grid{gap:var(--space-md);grid-template-columns:1fr}.work-item-offset{margin-top:0}.work-meta,.contact-panel{flex-direction:column}.meta-nav{flex-wrap:wrap;justify-content:center}}
