*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #000;--ink: #f2efe8;--ink-soft: #9a948a;--ink-dim: #5a564f;--rule: #1f1d1a;--accent: #ff4713;--paper: #e8e2d2;--paper-edge: #c9c0a8;--ink-on-paper: #1a1814;--display: "Space Grotesk", system-ui, -apple-system, sans-serif;--serif: "Instrument Serif", Georgia, serif;--maxw: 1400px}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;overflow-x:hidden}body{background:var(--bg);color:var(--ink);font-family:var(--display);min-height:100vh;min-height:100dvh;font-weight:400;line-height:1.5;overflow-x:hidden}.js-fade #root{opacity:0;transition:opacity .8s ease-out}.js-fade #root.is-loaded{opacity:1}@media(prefers-reduced-motion:reduce){.js-fade #root,.js-fade #root.is-loaded{opacity:1;transition:none}}#root{width:100%;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}input,textarea{font:inherit;color:inherit}::selection{background:var(--accent);color:var(--bg)}.site-header{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:22px clamp(20px,4vw,48px);pointer-events:none;mix-blend-mode:difference}.site-header>*{pointer-events:auto}.site-header nav{display:flex;gap:clamp(20px,3vw,40px);align-items:baseline;margin-left:auto}.site-header .header-link{position:relative;padding-bottom:3px;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1rem,1.4vw,1.2rem);letter-spacing:0}.site-header .header-link:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.2,.8,.2,1)}.site-header .header-link:hover:after{transform:scaleX(1);transform-origin:left}.site-header-tagline{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.15rem,2.2vw,1.7rem);line-height:1;letter-spacing:-.01em;color:var(--ink-soft);white-space:nowrap;pointer-events:none}@media(max-width:720px){.site-header-tagline{display:none}}main{flex:1;display:flex;flex-direction:column}.hero{position:relative;min-height:100vh;min-height:100dvh;padding:clamp(120px,16vh,180px) clamp(20px,4vw,48px) clamp(60px,8vh,100px);display:flex;flex-direction:column;justify-content:center}.hero-bg{position:fixed;inset:0;width:100vw;height:100vh;height:100lvh;object-fit:cover;object-position:center center;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;animation:hero-bg-fade linear both;animation-timeline:scroll(root block)}@keyframes hero-bg-fade{to{opacity:.5;filter:blur(8px)}}@media(prefers-reduced-motion:reduce){.hero-bg{animation:none}}@media(max-width:800px){.hero-bg{object-position:30% center}}.hero-inner{position:relative;z-index:1;width:100%;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;column-gap:0}.hero-content{grid-column:2 / -1;text-align:left}@media(max-width:800px){.hero-inner{grid-template-columns:1fr}.hero-content{grid-column:1 / -1}}.hero-name{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(2.4rem,6vw,5.2rem);line-height:1;letter-spacing:-.02em;margin:0}@media(max-width:800px){.hero-name{font-size:clamp(4.4rem,12vw,5.2rem);line-height:.95}}.hero-line{display:flex;align-items:baseline;flex-wrap:nowrap;gap:.25em;margin-top:.1em;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(2.4rem,6vw,5.2rem);line-height:1;letter-spacing:-.02em}.hero-the{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--ink-soft);font-size:1em;letter-spacing:-.02em}.rolling{position:relative;display:inline-block;overflow:hidden;vertical-align:baseline;height:1em;line-height:1;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,#000 22%,#000 78%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,#000 22%,#000 78%,transparent 100%)}.rolling-track{display:flex;flex-direction:column;transition:transform .6s cubic-bezier(.7,0,.2,1)}.rolling-item{height:1em;line-height:1;white-space:nowrap;color:var(--ink-soft);font-family:inherit;font-style:inherit;font-weight:inherit}.site-footer{position:relative;z-index:1;background:var(--bg);padding:clamp(56px,8vh,88px) clamp(20px,4vw,48px) clamp(36px,5vh,56px);border-top:1px solid var(--rule)}.footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(32px,5vh,56px)}@media(min-width:800px){.footer-inner{grid-template-columns:1fr 1.2fr;grid-template-rows:auto auto;column-gap:clamp(40px,6vw,72px);row-gap:32px}.footer-info{grid-column:1;grid-row:1}.footer-form{grid-column:2;grid-row:1 / span 2}.footer-tempero{grid-column:1;grid-row:2;align-self:start}}.footer-info h2{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1;letter-spacing:-.02em;margin-bottom:22px}.footer-info .email,.footer-info .phone{font-size:clamp(.95rem,1.5vw,1.1rem);font-weight:500;display:block;width:fit-content;position:relative;padding-bottom:2px;margin-bottom:8px}.footer-info .phone{margin-bottom:18px}.footer-info .email:after,.footer-info .phone:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform:scaleX(1);transform-origin:left;transition:transform .5s cubic-bezier(.2,.8,.2,1)}.footer-info .email:hover:after,.footer-info .phone:hover:after{transform:scaleX(0);transform-origin:right}.footer-meta{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);display:flex;flex-wrap:wrap;gap:8px 22px}.footer-meta a:hover{color:var(--ink)}.footer-tempero{display:inline-flex;align-items:center;gap:12px;color:var(--ink-soft);text-decoration:none;font-family:var(--sans);width:max-content;transition:color .25s ease}.footer-tempero:hover{color:var(--ink)}.footer-tempero-logo{width:32px;height:32px;display:block;flex-shrink:0;border-radius:6px}.footer-tempero-text{display:flex;flex-direction:column;line-height:1.25}.footer-tempero-name{font-size:.95rem;font-weight:500;letter-spacing:-.005em}.footer-tempero-url{font-size:.78rem;letter-spacing:.04em;color:var(--ink-dim)}.contact-form{display:flex;flex-direction:column;gap:12px}.contact-form .row{display:grid;gap:12px;grid-template-columns:1fr}@media(min-width:600px){.contact-form .row{grid-template-columns:1fr 1fr}}.contact-form label{display:block;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin-bottom:4px}.contact-form label .optional{text-transform:none;letter-spacing:0;font-size:.85em;color:var(--ink-soft);margin-left:4px;font-style:italic;font-family:var(--serif)}.contact-form input,.contact-form textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--ink);padding:6px 0 8px;font-size:.95rem;font-family:var(--display);color:var(--ink);transition:border-color .2s ease;resize:none}.contact-form textarea{min-height:72px;font-family:var(--display)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-bottom-color:var(--ink)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--ink-dim)}.contact-form .submit-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:4px}.contact-form button[type=submit]{background:var(--ink);color:var(--bg);padding:10px 22px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;transition:background .2s ease,color .2s ease}.contact-form button[type=submit]:hover{background:var(--accent);color:var(--ink)}.contact-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.contact-form .status{font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}.contact-form .status.ok{color:#6ad28a}.contact-form .status.err{color:#ff5a4a}.route-fallback{min-height:60vh;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:1.1rem}.page-fade--in{animation:page-fade-in .32s ease forwards}.page-fade--out{animation:page-fade-out .22s ease forwards}@keyframes page-fade-in{0%{opacity:0}to{opacity:1}}@keyframes page-fade-out{0%{opacity:1}to{opacity:0}}.blog-index{padding:clamp(120px,16vh,180px) clamp(20px,4vw,48px) clamp(60px,8vh,100px);max-width:var(--maxw);margin:0 auto;width:100%}.blog-index-header{margin-bottom:clamp(40px,6vh,72px);text-align:center}.blog-index-header h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(2.4rem,6vw,5.2rem);line-height:1;letter-spacing:-.02em;margin:0}.blog-status{font-family:var(--serif);font-style:italic;color:var(--ink-soft);text-align:center;padding:clamp(40px,8vh,80px) 0;font-size:1.1rem}.blog-status.err{color:#ff5a4a}.blog-filters{display:flex;flex-direction:column;gap:22px;margin-bottom:clamp(32px,5vh,56px)}.blog-filters-row{display:flex;flex-wrap:wrap;align-items:center;gap:16px 32px}.blog-search{flex:1 1 280px;background:transparent;border:none;border-bottom:1px solid var(--rule);padding:10px 2px;font-family:var(--serif);font-style:italic;font-size:clamp(1rem,1.5vw,1.25rem);color:var(--ink);outline:none;transition:border-bottom-color .25s ease}.blog-search:focus{border-bottom-color:var(--ink)}.blog-search::placeholder{color:var(--ink-dim);font-style:italic}.blog-search::-webkit-search-cancel-button{appearance:none}.blog-feature-toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-family:var(--display);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);-webkit-user-select:none;user-select:none;transition:color .25s ease;flex-shrink:0}.blog-feature-toggle:hover{color:var(--ink)}.blog-feature-toggle input{appearance:none;-webkit-appearance:none;width:14px;height:14px;border:1px solid var(--ink-soft);background:transparent;cursor:pointer;transition:background .2s ease,border-color .2s ease;display:grid;place-items:center;position:relative}.blog-feature-toggle:hover input{border-color:var(--ink)}.blog-feature-toggle input:checked{background:var(--accent);border-color:var(--accent)}.blog-feature-toggle input:checked:after{content:"";position:absolute;left:3px;top:0;width:4px;height:8px;border:solid #fff;border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.blog-tag-chips{display:grid;grid-template-columns:repeat(6,max-content);justify-content:center;align-items:baseline;gap:6px 26px}@media(max-width:1100px){.blog-tag-chips{grid-template-columns:repeat(4,max-content)}}@media(max-width:700px){.blog-tag-chips{grid-template-columns:repeat(3,max-content)}}@media(max-width:480px){.blog-tag-chips{grid-template-columns:repeat(2,max-content)}}.blog-tag-chip{background:none;border:none;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(.95rem,1.2vw,1.15rem);line-height:1.4;color:var(--ink-soft);cursor:pointer;padding:4px 0;position:relative;transition:color .25s ease}.blog-tag-chip:hover{color:var(--ink)}.blog-tag-chip.is-active{color:var(--accent)}.blog-tag-chip.is-active:after{content:"";position:absolute;left:0;right:0;bottom:1px;height:1px;background:var(--accent)}.stamp-album{width:100%}.stamp-position{position:absolute;opacity:0;animation:stamp-appear .55s ease forwards;animation-delay:var(--stamp-delay, 0s)}@keyframes stamp-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stamp{--tilt: 0deg;display:block;position:relative;width:100%;background:transparent;border:1px dotted rgba(242,239,232,.45);container-type:inline-size;transform:rotate(var(--tilt));transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .3s ease}.stamp:hover{transform:rotate(0) translateY(-3px);border-color:#f2efe8e6;z-index:5}.stamp.tier-ultimate{padding:16px}.stamp.tier-super{padding:13px}.stamp.tier-noteworthy{padding:10px}.stamp.tier-standard,.stamp.tier-quiet{padding:8px}.stamp-image{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#1a1814}.stamp-image img,.stamp-image picture{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%);transition:filter .6s ease}.stamp:hover .stamp-image img,.stamp:hover .stamp-image picture{filter:grayscale(0%)}.stamp-image-fallback{position:absolute;inset:0;background:repeating-linear-gradient(135deg,#2a2620,#2a2620 8px,#1f1c17 8px 16px)}.stamp-title{position:absolute;left:0;right:0;bottom:0;padding:14cqi 4cqi 3cqi;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(.75rem,5cqi,2.2rem);line-height:1.1;color:#fff;background:linear-gradient(to top,#000000e0,#0000008c,#0000);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;pointer-events:none;opacity:0;transition:opacity .3s ease}.stamp:hover .stamp-title{opacity:1}.post-detail{padding:clamp(100px,14vh,160px) clamp(20px,4vw,48px) clamp(80px,10vh,120px);max-width:var(--maxw);margin:0 auto;width:100%}.post-hero{width:100%;max-width:920px;aspect-ratio:16 / 9;overflow:hidden;background:#0c0b0a;margin:0 auto clamp(32px,5vh,56px)}.post-hero img{width:100%;height:100%;object-fit:cover;display:block}.post-header{max-width:880px;margin:0 auto clamp(32px,5vh,56px)}.post-header h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(2.4rem,6.5vw,5rem);line-height:.98;letter-spacing:-.02em;margin:0 0 18px}.post-meta{font-family:var(--display);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin:0}.post-tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px 10px;margin:16px 0 0;padding:0}.post-tags li{font-family:var(--display);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--rule);padding:6px 10px}.post-gallery{max-width:1100px;margin:clamp(48px,7vh,80px) auto 0;display:flex;flex-direction:column;gap:clamp(24px,4vw,40px)}.post-gallery-item{margin:0;overflow:hidden;background:#0c0b0a}.post-gallery-item-btn{display:block;width:100%;background:none;border:none;padding:0;margin:0;cursor:zoom-in;transition:opacity .2s ease}.post-gallery-item-btn:hover{opacity:.92}.post-gallery-item img,.post-gallery-item-btn img{width:100%;height:auto;display:block}.post-gallery-item figcaption{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--ink-soft);padding:8px 4px 0}.post-gallery-item-video .md-video{width:100%;max-width:none;margin:0}.back-link{display:inline-block;margin:clamp(48px,6vh,72px) 0 0;font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:1rem;position:relative}.back-link:hover{color:var(--ink)}.back-link--top{margin:0 0 clamp(24px,4vh,40px)}.md-body{max-width:720px;margin:0 auto;font-family:var(--display);font-size:clamp(1rem,1.2vw,1.1rem);line-height:1.7;color:var(--ink)}.md-body p{margin:0 0 1.2em}.md-body h2{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.05;letter-spacing:-.02em;margin:1.8em 0 .6em}.md-body h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.1;margin:1.6em 0 .5em}.md-body a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--ink-dim);text-underline-offset:3px;transition:text-decoration-color .25s ease,color .25s ease}.md-body a:hover{color:var(--accent);text-decoration-color:var(--accent)}.md-body ul,.md-body ol{margin:0 0 1.2em 1.4em;padding:0}.md-body li{margin-bottom:.4em}.md-body img{display:block;max-width:100%;height:auto;margin:1.5em auto}.md-body hr{border:0;border-top:1px solid var(--rule);margin:2em 0}.md-video{position:relative;width:min(100%,1100px);margin:2em auto;aspect-ratio:16 / 9;background:#0c0b0a}.md-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.md-video-fallback{display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;color:var(--ink-soft)}.md-gallery{width:min(100%,1100px);margin:2em auto;display:grid;gap:10px;grid-template-columns:1fr;align-items:start}@media(min-width:600px){.md-gallery{grid-template-columns:repeat(2,1fr)}.md-gallery[data-count="1"]{grid-template-columns:1fr}}@media(min-width:900px){.md-gallery[data-count="3"],.md-gallery[data-count="6"],.md-gallery[data-count="9"]{grid-template-columns:repeat(3,1fr)}}.md-gallery-item{display:block;background:none;border:none;padding:0;margin:0;cursor:zoom-in;transition:opacity .2s ease}.md-gallery-item:hover{opacity:.92}.md-gallery-item img{width:100%;height:auto;display:block;margin:0}.md-quote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.4vw,1.8rem);line-height:1.35;letter-spacing:-.01em;color:var(--ink);border-left:2px solid var(--accent);padding:.2em 0 .2em 1em;margin:1.6em 0;max-width:60ch}.md-quote p{margin:0}.md-note{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;border:1px solid var(--rule);border-left:2px solid var(--accent);padding:16px 20px;margin:1.6em 0;background:#ff47130a}.md-note-label{font-family:var(--display);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);padding-top:.25em}.md-note-body p:last-child{margin-bottom:0}.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;animation:lightbox-fade .22s ease-out}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}.lightbox-backdrop{position:absolute;inset:0;background:#000000f2;border:0;cursor:zoom-out;padding:0}.lightbox-img{position:relative;max-width:92vw;max-height:88vh;object-fit:contain;display:block;z-index:1;box-shadow:0 12px 60px #0009}.lightbox-close,.lightbox-prev,.lightbox-next{position:absolute;background:none;border:none;color:#f2efe8a6;cursor:pointer;line-height:1;font-family:var(--display);z-index:2;padding:8px 14px;transition:color .2s ease,transform .2s ease}.lightbox-close:hover,.lightbox-prev:not(:disabled):hover,.lightbox-next:not(:disabled):hover{color:var(--ink)}.lightbox-prev:disabled,.lightbox-next:disabled{opacity:.25;cursor:default}.lightbox-close{top:clamp(12px,2vh,24px);right:clamp(12px,2vw,28px);font-size:2rem}.lightbox-prev,.lightbox-next{top:50%;transform:translateY(-50%);font-family:var(--serif);font-style:italic;font-size:clamp(2.2rem,4vw,3.4rem)}.lightbox-prev:not(:disabled):hover{transform:translateY(-50%) translate(-3px)}.lightbox-next:not(:disabled):hover{transform:translateY(-50%) translate(3px)}.lightbox-prev{left:clamp(8px,2vw,28px)}.lightbox-next{right:clamp(8px,2vw,28px)}.lightbox-counter{position:absolute;bottom:clamp(14px,2.5vh,28px);left:50%;transform:translate(-50%);font-family:var(--display);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);z-index:2}@media(max-width:600px){.lightbox-prev,.lightbox-next{font-size:2rem;padding:6px 10px}.lightbox-img{max-width:96vw;max-height:80vh}}.post-detail--project-link{max-width:none;padding:0;margin:0}.coded-zone{position:relative;isolation:isolate;overflow:hidden;padding:clamp(100px,14vh,160px) clamp(20px,4vw,48px) clamp(48px,7vh,80px)}.coded-zone-backdrop{position:absolute;inset:0;z-index:0;pointer-events:none;background-image:url(/blog/project-link/projectlinkbackground.jpg);background-size:cover;background-position:top center;background-repeat:no-repeat;opacity:.32}.coded-zone-fade-top,.coded-zone-fade-bottom{position:absolute;left:0;right:0;z-index:0;height:18rem;pointer-events:none}.coded-zone-fade-top{top:0;background:linear-gradient(to bottom,#000000eb,#0000)}.coded-zone-fade-bottom{bottom:0;background:linear-gradient(to top,#000,#000000f2 25%,#0000)}.coded-zone-content{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto}.coded-zone-content .back-link--top{margin:0 0 clamp(20px,3vh,32px)}.code-tag{font-family:ui-monospace,SF Mono,Cascadia Mono,Consolas,Liberation Mono,monospace;font-size:.72rem;letter-spacing:.04em;color:var(--accent);max-width:880px;margin:0 auto 16px;opacity:.85}.code-tag-slash{color:var(--ink-dim)}.code-tag--eof{text-align:center;color:var(--ink-dim);opacity:.55;margin:clamp(40px,6vh,64px) auto 0}.md-body-card{position:relative;max-width:760px;margin:0 auto;background:#0c0b0ad1;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:clamp(24px,4vw,44px) clamp(20px,4vw,56px);border:1px solid rgba(255,255,255,.04);box-shadow:0 30px 80px -30px #000000a6}.md-body-card .md-body{max-width:none}@media(min-width:900px){.md-body-card{max-width:800px}}.post-detail--project-link>.back-link{display:block;max-width:var(--maxw);margin:0 auto;padding:clamp(40px,5vh,56px) clamp(20px,4vw,48px) clamp(60px,8vh,96px)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.rolling-track{transition:none}.scroll-hint{animation:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
