*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}img,svg{display:block;max-width:100%}a{color:inherit}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}ul{list-style:none}:focus-visible{outline:2px solid currentColor;outline-offset:3px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}:root{--ease-out: cubic-bezier(.16, 1, .3, 1);--bg: oklch(12% .002 250);--bg-2: oklch(17% .003 250);--paper: oklch(94% .003 250);--paper-dim: oklch(73% .004 250);--muted: oklch(50% .004 250);--rule: oklch(24% .004 250);--rule-soft: oklch(20% .004 250);--warm: oklch(64% .18 28);--warm-dim: oklch(52% .14 28);--cool: oklch(72% .11 220);--cool-dim: oklch(58% .09 220);--emphasis: var(--warm);--emphasis-dim: var(--warm-dim);--link: var(--cool);--link-dim: var(--cool-dim);--display: "Martian Mono", ui-monospace, "SF Mono", monospace;--body: "Hanken Grotesk", system-ui, sans-serif;--label: "Martian Mono", ui-monospace, "SF Mono", monospace}html,body{background:var(--bg);color:var(--paper)}body{font-family:var(--body);font-size:clamp(17px,1.1vw,19px);line-height:1.65;font-weight:400}.page{max-width:720px;margin:0 auto;padding:0 clamp(1.5rem,4vw,2.5rem)}.topbar{display:flex;justify-content:space-between;align-items:baseline;padding:1.5rem 0;font-size:.92rem}.topbar .name{font-family:var(--display);font-weight:500;font-size:1.02rem;letter-spacing:-.03em;color:var(--paper);text-decoration:none}.topbar .name b{font-family:var(--display);font-weight:600;color:var(--emphasis);margin-right:.35rem}.topbar nav{display:flex;gap:1.4rem}.topbar nav a{color:var(--paper-dim);text-decoration:none;font-weight:500;transition:color .4s var(--ease-out);padding:.5rem 0}.topbar nav a:hover{color:var(--link)}.pivot{margin:2.5rem 0 1.6rem;display:flex;align-items:center;gap:1.25rem;color:var(--muted)}.pivot:before,.pivot:after{content:"";flex:1;border-top:1px solid var(--rule)}.pivot span{font-family:var(--label);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--link);white-space:nowrap}.hello{padding:clamp(3rem,8vh,6rem) 0 clamp(2rem,4vh,3rem)}.hello h1{font-family:var(--display);font-weight:500;font-size:clamp(2.25rem,6vw,3.4rem);line-height:1.12;letter-spacing:-.04em;color:var(--paper);text-wrap:balance;margin-bottom:1.75rem}.hello h1 em{font-style:normal;color:var(--emphasis)}.hello .lede{font-family:var(--body);font-size:clamp(1.25rem,1.8vw,1.55rem);line-height:1.55;color:var(--paper);font-weight:400;max-width:34rem;text-wrap:pretty}.hello .lede b{font-family:var(--body);font-weight:600;color:var(--emphasis)}.prose{padding:clamp(1rem,2vh,2rem) 0 clamp(3rem,6vh,5rem)}.prose p{font-size:clamp(1.05rem,1.2vw,1.15rem);line-height:1.7;color:var(--paper);margin-bottom:1.4rem;max-width:38rem;text-wrap:pretty}.prose p a{color:var(--link);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:text-decoration-thickness .4s var(--ease-out)}.prose p a:hover{text-decoration-thickness:2px}.prose>p b{font-weight:600;color:var(--paper);background:linear-gradient(transparent 60%,color-mix(in oklch,var(--emphasis) 33%,transparent) 60%);padding:0 .1em}.prose p em{font-style:italic;color:var(--paper)}.plates{margin:2rem 0 2.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.plate{border:1px solid var(--rule);padding:1rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .4s var(--ease-out)}.plate:hover{border-color:var(--link-dim)}.plate-frame{position:relative;aspect-ratio:4 / 5;background:var(--bg-2);border:1px solid var(--rule);overflow:hidden}.plate-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.92) contrast(1.02)}.plate-frame:not(:has(img)):before,.plate-frame:not(:has(img)):after{content:"";position:absolute;top:50%;left:50%;background:var(--rule);transform:translate(-50%,-50%)}.plate-frame:not(:has(img)):before{width:1px;height:20px}.plate-frame:not(:has(img)):after{width:20px;height:1px}.plate-frame .idx{position:absolute;bottom:.55rem;left:.6rem;font-family:var(--label);font-weight:500;font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.plate-frame:has(img) .idx{display:none}.plate-caption{font-family:var(--body);font-size:.9rem;line-height:1.45;color:var(--paper-dim);text-wrap:balance}.plate-caption b{font-family:var(--label);font-weight:600;color:var(--paper);display:block;margin-bottom:.3rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.work{padding:clamp(2.5rem,5vh,4rem) 0;border-top:1px solid var(--rule)}.work h2{font-family:var(--display);font-weight:500;font-size:clamp(1.6rem,3.2vw,2.1rem);line-height:1.12;letter-spacing:-.04em;margin-bottom:.5rem}.work h2 em{font-style:normal;color:var(--emphasis)}.work .caption{font-family:var(--body);color:var(--paper-dim);font-size:1rem;margin-bottom:2rem;max-width:36rem}.entries{display:flex;flex-direction:column}.entry{padding:1.75rem 0;border-top:1px solid var(--rule-soft);text-decoration:none;color:inherit;display:block}.entry:last-child{border-bottom:1px solid var(--rule-soft)}.entry-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.5rem}.entry-title{font-family:var(--display);font-weight:500;font-size:clamp(1.1rem,1.8vw,1.35rem);line-height:1.25;letter-spacing:-.035em;text-wrap:balance;color:var(--paper);transition:color .4s var(--ease-out)}.entry-title em{font-style:normal;color:var(--emphasis)}.entry:hover .entry-title{color:var(--link)}.entry-year{font-family:var(--label);font-size:.78rem;color:var(--muted);font-weight:500;font-variant-numeric:tabular-nums;white-space:nowrap;padding-top:.4rem}.entry-summary{font-size:1rem;line-height:1.6;color:var(--paper-dim);max-width:38rem;margin-bottom:.6rem}.entry-read{font-family:var(--label);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--link-dim);display:inline-flex;align-items:baseline;gap:.45rem;transition:color .4s var(--ease-out)}.entry:hover .entry-read{color:var(--link)}.entry-read:after{content:"→";transition:transform .4s var(--ease-out)}.entry:hover .entry-read:after{transform:translate(4px)}.sayhey{padding:clamp(3rem,6vh,5rem) 0;border-top:1px solid var(--rule)}.sayhey h2{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,4vw,2.6rem);line-height:1.12;letter-spacing:-.04em;margin-bottom:1.25rem}.sayhey h2 em{font-style:normal;color:var(--emphasis)}.sayhey>p{font-family:var(--body);font-size:clamp(1.15rem,1.4vw,1.3rem);line-height:1.55;color:var(--paper);max-width:34rem;margin-bottom:1.75rem}.sayhey>p b{font-family:var(--body);font-weight:600;color:var(--emphasis)}.contact-form{display:flex;flex-direction:column;gap:1.1rem;max-width:34rem}.contact-form .field{display:flex;flex-direction:column;gap:.45rem}.contact-form label{font-family:var(--label);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--paper-dim)}.contact-form input,.contact-form textarea{font-family:var(--body);font-size:1rem;color:var(--paper);background:var(--bg-2);border:1px solid var(--rule);border-radius:0;padding:.7rem .85rem;transition:border-color .3s var(--ease-out)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--link-dim)}.contact-form textarea{resize:vertical;min-height:7rem;line-height:1.6}.contact-form .hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.contact-form .submit{align-self:flex-start;display:inline-flex;align-items:baseline;gap:.6rem;padding:.7rem 1.1rem;border:1px solid var(--emphasis);color:var(--emphasis);font-family:var(--label);font-weight:500;font-size:.9rem;letter-spacing:-.01em;transition:background .4s var(--ease-out),color .4s var(--ease-out),opacity .3s var(--ease-out)}.contact-form .submit:after{content:"→";transition:transform .4s var(--ease-out)}.contact-form .submit:hover{background:var(--emphasis);color:var(--bg)}.contact-form .submit:hover:after{transform:translate(3px)}.contact-form .submit[disabled]{opacity:.55;cursor:default}.contact-form .submit[disabled]:hover{background:none;color:var(--emphasis)}.form-status{font-family:var(--label);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;min-height:1rem}.form-status.is-success{color:var(--link);text-transform:none;letter-spacing:0;font-family:var(--body);font-size:.95rem}.form-status.is-error{color:var(--emphasis);text-transform:none;letter-spacing:0;font-family:var(--body);font-size:.95rem}.form-status.is-error a{color:var(--emphasis)}.sayhey .alt{margin-top:1.5rem;font-size:.9rem;color:var(--paper-dim)}.sayhey .alt a{color:var(--paper);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;margin-left:.4rem}.sayhey .alt a+a{margin-left:1rem}footer{padding:2rem 0 3rem;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:baseline;font-family:var(--label);font-size:.72rem;letter-spacing:.04em;color:var(--muted);flex-wrap:wrap;gap:.5rem}.case-hero{padding:clamp(3rem,8vh,6rem) 0 clamp(1rem,2vh,2rem)}.case-kicker{display:block;font-family:var(--label);font-weight:500;font-size:.72rem;text-transform:uppercase;color:var(--paper-dim);letter-spacing:.08em;margin-bottom:1.5rem}.case-title{font-family:var(--display);font-weight:500;font-size:clamp(2rem,5.5vw,3rem);line-height:1.12;letter-spacing:-.04em;color:var(--paper);text-wrap:balance;margin-bottom:1.75rem}.case-title em{font-style:normal;color:var(--emphasis)}.case-summary{font-family:var(--body);font-size:clamp(1.25rem,1.8vw,1.55rem);line-height:1.55;color:var(--paper);font-weight:400;max-width:34rem;text-wrap:pretty;margin-bottom:2.5rem}.case-meta{display:grid;grid-template-columns:6rem 1fr;gap:.55rem 1.5rem;max-width:38rem;padding:1rem 0 0;border-top:1px solid var(--rule-soft)}.case-meta dt{font-family:var(--label);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--emphasis);align-self:center}.case-meta dd{font-size:.98rem;color:var(--paper);line-height:1.55}.case-body{padding:clamp(2.5rem,5vh,4rem) 0;border-top:1px solid var(--rule)}.body-prose p{font-size:clamp(1.05rem,1.2vw,1.15rem);line-height:1.7;color:var(--paper);margin-bottom:1.4rem;max-width:38rem}.body-prose p:last-child{margin-bottom:0}.body-prose p b{font-weight:600;color:var(--paper);background:linear-gradient(transparent 60%,color-mix(in oklch,var(--emphasis) 33%,transparent) 60%);padding:0 .1em}.body-prose p em{font-style:italic;color:var(--paper)}.stack{font-size:.98rem;line-height:1.7;color:var(--paper-dim);max-width:38rem}.stack b{color:var(--paper);font-weight:600}.case-foot{padding:clamp(2.5rem,5vh,4rem) 0 clamp(3rem,6vh,5rem);border-top:1px solid var(--rule)}.case-foot .lbl{display:block;font-family:var(--label);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--paper-dim);margin-bottom:.6rem}.case-foot a{font-family:var(--display);font-weight:500;font-size:clamp(1.25rem,2.2vw,1.55rem);line-height:1.25;letter-spacing:-.035em;color:var(--paper);text-decoration:none;display:inline-flex;align-items:baseline;gap:.5rem;text-wrap:balance;transition:color .4s var(--ease-out)}.case-foot a em{font-style:normal;color:var(--emphasis)}.case-foot a:after{content:"→";transition:transform .4s var(--ease-out)}.case-foot a:hover,.case-foot a:hover em{color:var(--link)}.case-foot a:hover:after{transform:translate(4px)}@media(max-width:640px){.topbar{flex-direction:column;gap:1rem}.topbar nav{width:100%;justify-content:space-between}.plates{grid-template-columns:1fr}.entry-head{flex-direction:column;gap:.4rem}.case-meta{grid-template-columns:1fr;gap:.2rem}.case-meta dd{margin-bottom:.8rem}footer{flex-direction:column;gap:1.5rem;padding-top:2.5rem}}
