:root{--color-washed-black: #1a1a1a;--color-pure-white: #ffffff;--color-pearl: #f7f7f3;--color-beige: #f0f0ec;--color-ink-black: #000000;--color-concrete: #d4d4d0;--color-dim-grey: #6d6868;--color-silver-mist: #b3b3b3;--color-royal-blue: #1009f6;--color-energy-gold: #ffba09;--color-sky-blue: #add3e5;--color-deep-moss: #304801;--color-thistle-bloom: #e3c7de;--font-sans: "Inter", "Noto Sans JP", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-serif: "EB Garamond", "Noto Serif JP", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--text-caption: 11px;--text-body: 14px;--text-body-lg: 16px;--text-heading-sm: 25px;--text-heading: 28px;--text-heading-lg: 32px;--text-display: 48px;--radius-md: 4.375px;--radius-cards: 24px;--radius-images: 40px;--radius-buttons: 999px;--max-w: 1280px;--rail-w: 184px;--header-h: 64px;--bg: var(--color-pearl);--surface: var(--color-pure-white);--surface-2: var(--color-beige);--text: var(--color-washed-black);--muted: var(--color-dim-grey);--border: var(--color-concrete);--hairline: rgba(26,26,26,.14);--accent: var(--color-deep-moss);--on-accent: var(--color-pure-white)}body[data-palette=moss]{--bg: var(--color-pearl);--surface: var(--color-pure-white);--surface-2: var(--color-beige);--text: var(--color-washed-black);--muted: var(--color-dim-grey);--border: var(--color-concrete);--hairline: rgba(26,26,26,.14);--accent: var(--color-deep-moss);--on-accent: var(--color-pure-white)}body[data-palette=ink]{--bg: var(--color-pure-white);--surface: var(--color-pearl);--surface-2: var(--color-beige);--text: var(--color-ink-black);--muted: var(--color-dim-grey);--border: var(--color-concrete);--hairline: rgba(0,0,0,.12);--accent: var(--color-ink-black);--on-accent: var(--color-pure-white)}body[data-palette=royal]{--bg: var(--color-pearl);--surface: var(--color-pure-white);--surface-2: var(--color-beige);--text: var(--color-washed-black);--muted: var(--color-dim-grey);--border: var(--color-concrete);--hairline: rgba(26,26,26,.14);--accent: var(--color-royal-blue);--on-accent: var(--color-pure-white)}body[data-palette=amber]{--bg: #f4eee1;--surface: #faf6ec;--surface-2: #ebe2cc;--text: #1f1a10;--muted: #6d6864;--border: #d6cdb6;--hairline: rgba(31,26,16,.16);--accent: #8a6312;--on-accent: #faf6ec}*,*:before,*:after{box-sizing:border-box}html{scrollbar-gutter:stable}html,body{margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-body-lg);line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:"palt";text-wrap:pretty}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}.eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:500}.serif-italic{font-family:var(--font-serif);font-style:italic;font-weight:400}.hairline{height:1px;background:var(--hairline);border:0}.site-header{position:sticky;top:0;z-index:30;background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--hairline)}.site-header__inner{max-width:var(--max-w);margin:0 auto;padding:0 28px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--font-sans);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:14px}.brand:before{content:"";display:inline-block;width:7px;height:7px;background:var(--accent);border-radius:999px;transform:translateY(-1px)}.brand__tag{font-family:var(--font-serif);font-style:italic;font-weight:400;text-transform:none;letter-spacing:0;font-size:14px;color:var(--muted)}.nav{display:flex;gap:22px;align-items:center}.nav a{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .15s ease}.nav a:hover,.nav a.is-active{color:var(--text)}.nav__cat-btn{display:none;align-items:center;gap:5px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .15s ease;padding:0}.nav__cat-btn:after{content:"▾";font-size:9px;letter-spacing:0;transform:translateY(-1px);color:var(--accent)}.nav__cat-btn:hover,.nav__cat-btn.is-open{color:var(--text)}.nav__cat-btn .nav__cat-chip{font-family:var(--font-serif);font-style:italic;font-weight:400;text-transform:none;letter-spacing:0;font-size:13px;color:var(--accent);margin-left:4px;max-width:8ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catsheet-backdrop{position:fixed;inset:0;background:#1a1a1a6b;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .18s ease}.catsheet-backdrop[hidden]{display:none}.catsheet{width:100%;max-width:560px;max-height:78vh;background:var(--bg);border-radius:24px 24px 0 0;border:1px solid var(--hairline);border-bottom:0;display:flex;flex-direction:column;animation:slideUp .28s cubic-bezier(.2,.7,.2,1);overflow:hidden}.catsheet__head{display:flex;align-items:center;justify-content:space-between;padding:16px 22px 14px;border-bottom:1px solid var(--hairline)}.catsheet__head .eyebrow{font-size:10px}.catsheet__head-grab{position:absolute;left:50%;top:8px;transform:translate(-50%);width:38px;height:4px;border-radius:999px;background:var(--hairline)}.catsheet__body{padding:6px 10px 28px;overflow:auto;-webkit-overflow-scrolling:touch}.catsheet__item{display:flex;align-items:baseline;justify-content:space-between;gap:12px;width:100%;padding:16px 12px;text-align:left;font-size:16px;color:var(--text);border-bottom:1px solid var(--hairline);cursor:pointer;transition:color .12s ease,background .12s ease;border-radius:8px}.catsheet__item:last-child{border-bottom:0}.catsheet__item:active{background:var(--surface-2)}.catsheet__item.is-active{color:var(--accent);font-weight:500}.catsheet__item .count{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.catsheet__item.is-active .count{color:var(--accent)}.catsheet__item .check{width:14px;display:inline-block;text-align:right;color:var(--accent);font-size:13px}.hero{max-width:var(--max-w);margin:0 auto;padding:72px 28px 56px;display:grid;grid-template-columns:auto 1fr;align-items:end;gap:28px;border-bottom:1px solid var(--hairline)}.hero__index{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg);padding-bottom:4px}.hero__title{margin:0;font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:clamp(56px,9vw,124px);line-height:.92;letter-spacing:-.02em;color:var(--text)}.hero__meta{margin-top:18px;display:flex;gap:16px;flex-wrap:wrap;align-items:baseline}.hero__lede{font-size:14px;color:var(--muted);max-width:56ch;line-height:1.6}.shell{max-width:var(--max-w);margin:0 auto;padding:40px 28px 120px;display:grid;grid-template-columns:var(--rail-w) minmax(0,1fr) var(--rail-w);gap:40px}body[data-rail=off] .shell{grid-template-columns:1fr}body[data-rail=off] .rail{display:none}.rail{position:sticky;top:calc(var(--header-h) + 24px);align-self:start;max-height:calc(100vh - var(--header-h) - 48px);overflow:auto;padding-right:4px}.rail__group{margin-bottom:36px}.rail__label{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:10px}.rail__label:after{content:"";flex:1;height:1px;background:var(--hairline)}.rail__item{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:8px 0;font-size:14px;color:var(--text);letter-spacing:.02em;border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease;text-align:left;width:100%}.rail__item:hover{color:var(--accent)}.rail__item.is-active{color:var(--accent);border-bottom-color:var(--accent)}.rail__item .count{font-family:var(--font-mono);font-size:11px;color:var(--muted)}.rail__about{font-family:var(--font-serif);font-style:italic;font-size:15px;line-height:1.55;color:var(--text)}.rail__about p{margin:0 0 10px}.rail__about p:last-child{margin-bottom:0;font-size:13px;color:var(--muted);font-style:normal;font-family:var(--font-sans);letter-spacing:.04em}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-bottom:22px;margin-bottom:28px;border-bottom:1px solid var(--hairline)}.toolbar__title{font-family:var(--font-serif);font-style:italic;font-size:22px;letter-spacing:-.005em;font-weight:400}.toolbar__count{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.feed{display:flex;flex-direction:column;gap:0}body[data-layout=list] .feed{gap:0}body[data-layout=grid] .feed{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px}body[data-layout=magazine] .feed{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(10px,auto);gap:24px}.post{display:grid;grid-template-columns:96px 1fr;gap:28px;padding:28px 0 32px;border-bottom:1px solid var(--hairline)}body[data-layout=list] .post:first-child{padding-top:0}.post__meta{display:flex;flex-direction:column;gap:6px;padding-top:4px}.post__index{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--muted)}.post__date{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--text)}.post__cat{margin-top:6px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}.post__type{margin-top:auto;font-family:var(--font-mono);font-style:normal;font-size:11px;letter-spacing:.08em;color:var(--muted);background:none;border:0;padding:4px 0;text-align:left;cursor:pointer;transition:color .14s ease;align-self:flex-start}.post__type:hover,.post__type:focus-visible{color:var(--accent)}.post__type .hash{color:var(--accent);margin-right:1px}.toolbar__tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--accent);background:none;border:0;padding:0;cursor:pointer}.toolbar__tag .clear{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:999px;border:1px solid var(--accent);color:var(--accent);font-size:10px;line-height:1}.toolbar__tag:hover .clear{background:var(--accent);color:var(--bg)}.post__body{min-width:0}.post__title{margin:0 0 12px;font-family:var(--font-serif);font-weight:500;font-size:32px;line-height:1.18;letter-spacing:-.005em;color:var(--text)}.post__title em{font-style:italic;font-weight:400}.post__lede{margin:0 0 18px;font-size:16px;line-height:1.7;color:var(--text)}.post__lede--muted{color:var(--muted)}.read-more{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid var(--text);color:var(--text);border-radius:999px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;transition:background .18s ease,color .18s ease}.read-more:hover{background:var(--text);color:var(--bg)}.read-more:after{content:"→";font-family:var(--font-sans);letter-spacing:0}.note{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:28px;line-height:1.35;letter-spacing:-.005em;color:var(--text);margin:4px 0 10px;font-feature-settings:"palt"}.note__attr{font-family:var(--font-sans);font-style:normal;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:12px;display:inline-block}.media{position:relative;border-radius:var(--radius-cards);overflow:hidden;background:var(--surface-2);isolation:isolate}.media__inner{position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,transparent 0 18px,rgba(0,0,0,.04) 18px 19px)}.media__label{position:absolute;left:16px;bottom:14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;background:var(--surface);padding:4px 9px;border-radius:999px;border:1px solid var(--hairline)}.media--16x9{aspect-ratio:16 / 9}.media--4x3{aspect-ratio:4 / 3}.media--1x1{aspect-ratio:1 / 1}.media--3x4{aspect-ratio:3 / 4}.media__caption{margin-top:14px;font-family:var(--font-serif);font-style:italic;font-size:14px;line-height:1.5;color:var(--muted)}.media__caption strong{font-style:normal;font-family:var(--font-sans);font-weight:500;color:var(--text);margin-right:8px}.carousel{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:1fr;gap:6px;height:360px}.carousel .media{border-radius:var(--radius-md)}.carousel .media:first-child{grid-row:1 / span 2;border-radius:var(--radius-cards)}.carousel .media:nth-child(2){grid-column:2 / span 2}.video{position:relative;border-radius:var(--radius-cards);overflow:hidden;aspect-ratio:16 / 9;background:linear-gradient(140deg,#1a1a1a,#2b2b2b);isolation:isolate}.video__noise{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 30% 40%,rgba(255,255,255,.4) 0%,transparent 40%),radial-gradient(circle at 70% 60%,rgba(255,255,255,.3) 0%,transparent 40%),repeating-linear-gradient(0deg,transparent 0 3px,rgba(255,255,255,.05) 3px 4px)}.video__play{position:absolute;inset:0;display:grid;place-items:center}.video__play-btn{width:84px;height:84px;border-radius:999px;background:var(--surface);display:grid;place-items:center;color:var(--text);transition:transform .2s ease}.video__play-btn:hover{transform:scale(1.05)}.video__play-btn:before{content:"";width:0;height:0;border-left:18px solid currentColor;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:4px}.video__chip{position:absolute;top:14px;left:14px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:#0000008c;border:1px solid rgba(255,255,255,.2);padding:4px 9px;border-radius:999px}.video__time{position:absolute;bottom:14px;right:14px;font-family:var(--font-mono);font-size:12px;color:#fff;background:#000000b3;padding:3px 8px;border-radius:4px}.code{background:#161613;color:#e8e6df;border-radius:var(--radius-cards);font-family:var(--font-mono);font-size:13px;line-height:1.65;overflow:hidden;border:1px solid #2a2a25}.code__bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid #2a2a25;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#a8a39a}.code__lang{display:inline-flex;align-items:center;gap:8px}.code__lang:before{content:"";width:6px;height:6px;background:#b6c25b;border-radius:999px}.code pre{margin:0;padding:18px 22px;overflow-x:auto;white-space:pre}.code .kw{color:#c6a45b}.code .fn{color:#b6c25b}.code .str{color:#d4a08a}.code .com{color:#6d6864;font-style:italic}.code .num{color:#9ec1c9}.app{background:var(--color-royal-blue);color:#fff;border-radius:var(--radius-cards);padding:36px;display:grid;grid-template-columns:1fr 240px;gap:28px;align-items:end}.app__eyebrow{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#ffffffb8;margin-bottom:18px}.app__name{font-family:var(--font-serif);font-weight:500;font-size:36px;line-height:1.1;margin:0 0 12px;letter-spacing:-.01em}.app__desc{font-size:14px;line-height:1.6;color:#ffffffdb;margin:0 0 18px;max-width:42ch}.app__btn{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;border:1px solid rgba(255,255,255,.7);border-radius:999px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#fff}.app__btn:hover{background:#fff;color:var(--color-royal-blue);border-color:#fff}.app__icon{aspect-ratio:1 / 1;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:20px;display:grid;place-items:center;font-family:var(--font-serif);font-style:italic;font-size:76px;color:#ffffffe6}.app--gold{background:var(--color-energy-gold);color:#000}.app--gold .app__eyebrow{color:#0009}.app--gold .app__desc{color:#000000bd}.app--gold .app__btn{border-color:#0009;color:#000}.app--gold .app__btn:hover{background:#000;color:var(--color-energy-gold);border-color:#000}.app--gold .app__icon{background:#0000000f;border-color:#0000001f;color:#000000e6}.linkshare{display:grid;grid-template-columns:1fr 200px;gap:20px;align-items:stretch;background:var(--surface-2);border-radius:var(--radius-cards);padding:22px 24px;border:1px solid var(--hairline);text-decoration:none;color:inherit;transition:background .15s ease}.linkshare:hover{background:var(--surface)}.linkshare__copy{display:flex;flex-direction:column;gap:8px;padding:4px 0}.linkshare__site{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.linkshare__title{font-family:var(--font-serif);font-weight:500;font-size:22px;line-height:1.25;margin:0}.linkshare__desc{font-size:13px;color:var(--muted);line-height:1.5;margin:0}.linkshare__url{margin-top:auto;font-family:var(--font-mono);font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:8px}.linkshare__url:before{content:"↗";color:var(--accent)}.linkshare__thumb{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--hairline);min-height:120px;background-image:repeating-linear-gradient(135deg,transparent 0 14px,rgba(0,0,0,.04) 14px 15px);display:grid;place-items:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}body[data-layout=magazine] .post{grid-column:span 6}body[data-layout=magazine] .post[data-type=note]{grid-column:span 3;border-bottom:1px solid var(--hairline)}body[data-layout=magazine] .post[data-type=code]{grid-column:span 4}body[data-layout=magazine] .post[data-type=photo]{grid-column:span 3}body[data-layout=magazine] .post[data-type=video]{grid-column:span 4}body[data-layout=magazine] .post[data-type=software]{grid-column:span 6}body[data-layout=magazine] .post[data-type=link]{grid-column:span 3}body[data-layout=magazine] .post[data-type=article],body[data-layout=magazine] .post[data-type=carousel]{grid-column:span 6}body[data-layout=grid] .post{grid-template-columns:1fr;border-bottom:0;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-cards);padding:24px}body[data-layout=grid] .post[data-type=software],body[data-layout=grid] .post[data-type=article]{grid-column:span 2}body[data-layout=grid] .post__meta{flex-direction:row;align-items:baseline;gap:14px;padding-top:0;margin-bottom:14px;flex-wrap:wrap}body[data-layout=grid] .post__cat{margin-top:0}body[data-layout=grid] .post__type{margin-top:0;margin-left:auto}body[data-layout=grid] .post__title{font-size:26px}@media(max-width:920px){.shell{grid-template-columns:1fr;gap:32px;padding:24px 18px 100px}.rail{position:static;max-height:none;overflow:visible;border-bottom:1px solid var(--hairline);padding-bottom:18px}body[data-layout=grid] .feed,body[data-layout=magazine] .feed{display:flex;flex-direction:column;gap:0}body[data-layout=grid] .post,body[data-layout=magazine] .post{grid-column:auto}body[data-layout=grid] .post{background:transparent;border:0;border-bottom:1px solid var(--hairline);border-radius:0;padding:28px 0 32px}.post{grid-template-columns:1fr;gap:16px}.post__meta{flex-direction:row;align-items:baseline;gap:14px;flex-wrap:wrap;padding-top:0}.post__cat{margin-top:0}.post__type{margin-top:0;margin-left:auto}.post__title{font-size:26px}.hero{padding:44px 18px 36px;grid-template-columns:1fr;gap:18px}.hero__index{writing-mode:horizontal-tb;transform:none}.app{grid-template-columns:1fr;padding:24px}.app__icon{display:none}.linkshare{grid-template-columns:1fr}.linkshare__thumb{min-height:100px}.carousel{height:260px}.site-header__inner{padding:0 16px;gap:12px}.nav{gap:14px}.nav a{font-size:11px}.nav__cat-btn{display:inline-flex;font-size:11px}.nav__cat-btn .nav__cat-chip{font-size:12px;max-width:6ch}.nav__link--works,.nav__link--about,.nav__link--contact,.rail__group--mobile-hide{display:none}}.catsheet__head .catsheet__back{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:4px 6px;margin-left:-6px;border-radius:6px;transition:background .12s ease,color .12s ease}.catsheet__head .catsheet__back:hover{color:var(--text);background:var(--surface-2)}.catsheet__head .catsheet__back:before{content:"←";color:var(--accent);font-size:13px}.catsheet__section{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;padding:18px 12px;text-align:left;border-bottom:1px solid var(--hairline);cursor:pointer;border-radius:8px;transition:background .12s ease;background:transparent}.catsheet__section:last-child{border-bottom:0}.catsheet__section:active{background:var(--surface-2)}.catsheet__section-label{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:24px;line-height:1.15;color:var(--text);margin-bottom:4px;letter-spacing:-.005em}.catsheet__section.is-active .catsheet__section-label{color:var(--accent)}.catsheet__section-desc{font-size:12px;color:var(--muted);letter-spacing:.04em}.catsheet__section-cat-hint{display:inline-block;margin-left:8px;padding:2px 8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent);border-radius:999px;text-transform:uppercase;vertical-align:middle}.catsheet__section-arrow{font-family:var(--font-sans);font-size:22px;color:var(--accent);flex-shrink:0;font-weight:300;line-height:1}.sentinel{display:flex;align-items:center;justify-content:center;gap:14px;padding:64px 0 24px;color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase}.sentinel__bar{width:18px;height:1px;background:var(--muted)}.sentinel__dot{width:6px;height:6px;border-radius:999px;background:var(--accent);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}}.site-footer{border-top:1px solid var(--hairline);padding:28px;text-align:center;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.page{max-width:980px;margin:0 auto;padding:64px 28px 120px}.page__eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;display:flex;align-items:center;gap:14px}.page__eyebrow:after{content:"";flex:1;height:1px;background:var(--hairline)}.page__title{margin:0 0 14px;font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:clamp(48px,6vw,88px);line-height:.96;letter-spacing:-.02em;color:var(--text)}.page__lede{font-family:var(--font-serif);font-style:italic;font-size:clamp(18px,2.2vw,22px);line-height:1.55;color:var(--text);max-width:60ch;margin:0 0 56px}.works{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.work{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-cards);padding:22px 22px 24px;display:flex;flex-direction:column;gap:14px;text-align:left;transition:transform .18s ease,border-color .18s ease,background .18s ease;cursor:pointer;position:relative;overflow:hidden;min-height:320px}.work:hover{transform:translateY(-2px);border-color:var(--text)}.work__thumb{aspect-ratio:4 / 3;border-radius:14px;display:grid;place-items:center;font-family:var(--font-serif);font-style:italic;font-size:96px;line-height:1;color:var(--on-accent);background:var(--accent);background-image:repeating-linear-gradient(135deg,transparent 0 20px,rgba(255,255,255,.06) 20px 21px);overflow:hidden}.work__thumb[data-accent=moss]{background-color:var(--color-deep-moss);color:#fff}.work__thumb[data-accent=royal]{background-color:var(--color-royal-blue);color:#fff}.work__thumb[data-accent=ink]{background-color:var(--color-washed-black);color:var(--color-pearl)}.work__thumb[data-accent=gold]{background-color:var(--color-energy-gold);color:#000}.work__head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.work__title{margin:0;font-family:var(--font-serif);font-weight:500;font-size:24px;letter-spacing:-.005em;line-height:1.18;color:var(--text)}.work__type{font-size:13px;color:var(--muted);margin-top:-4px}.work__cta{margin-top:auto;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:8px}.work__cta:after{content:"→"}.workmodal{width:min(960px,100%);background:var(--bg);margin-top:48px;border-radius:28px 28px 0 0;overflow:auto;animation:slideUp .32s cubic-bezier(.2,.7,.2,1);border:1px solid var(--hairline)}.workmodal__hero{aspect-ratio:16 / 9;display:grid;place-items:center;font-family:var(--font-serif);font-style:italic;font-size:200px;line-height:1;color:var(--on-accent);background:var(--accent);background-image:repeating-linear-gradient(135deg,transparent 0 28px,rgba(255,255,255,.06) 28px 29px)}.workmodal__hero[data-accent=moss]{background-color:var(--color-deep-moss);color:#fff}.workmodal__hero[data-accent=royal]{background-color:var(--color-royal-blue);color:#fff}.workmodal__hero[data-accent=ink]{background-color:var(--color-washed-black);color:var(--color-pearl)}.workmodal__hero[data-accent=gold]{background-color:var(--color-energy-gold);color:#000}.workmodal__body{padding:48px 64px 80px}.workmodal__meta{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;margin:32px 0 36px;padding:22px 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.workmodal__meta div{display:flex;flex-direction:column;gap:6px}.workmodal__meta dt{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:0}.workmodal__meta dd{margin:0;font-size:15px;line-height:1.4;color:var(--text)}.workmodal__desc{font-size:17px;line-height:1.85;margin:0 0 20px;max-width:64ch}.workmodal__related{display:inline-flex;align-items:center;gap:12px;padding:14px 22px;border:1px solid var(--text);border-radius:999px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text);cursor:pointer;transition:background .18s ease,color .18s ease}.workmodal__related:hover{background:var(--text);color:var(--bg)}.workmodal__related:after{content:"→"}.workmodal__related[hidden]{display:none}.workmodal__body>.workmodal__related{margin-top:8px}.work__thumb-img,.workmodal__hero-img{width:100%;height:100%;object-fit:cover;display:block}.work-tags{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 28px}.work-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--muted);padding:5px 11px;border:1px solid var(--hairline);border-radius:999px;background:var(--surface)}.work-section{margin-top:28px;padding-top:24px;border-top:1px solid var(--hairline);max-width:64ch}.work-section__head{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}.work-section__p{font-size:15px;line-height:1.8;margin:0 0 10px}.work-list{margin:0;padding-left:1.1em;font-size:15px;line-height:1.7}.work-list li{margin:0 0 8px}.work-links{display:flex;flex-wrap:wrap;gap:12px;margin:4px 0 8px}.about{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start}.about__photo{aspect-ratio:3 / 4;border-radius:var(--radius-cards);background:var(--surface-2);background-image:repeating-linear-gradient(135deg,transparent 0 18px,rgba(0,0,0,.04) 18px 19px);position:relative;overflow:hidden}.about__photo-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.about__photo--filled{background-image:none}.about__photo.about__photo--filled:after{content:none}.about__photo:after{content:"Portrait — drop your photo here";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);text-align:center;white-space:nowrap}.about__name{font-family:var(--font-sans);font-weight:700;font-size:clamp(28px,3vw,36px);margin:0 0 6px;line-height:1.1;letter-spacing:-.01em}.about__role{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}.about__intro{font-family:var(--font-serif);font-style:italic;font-size:22px;line-height:1.55;color:var(--text);margin:0 0 28px;padding-left:18px;border-left:1px solid var(--accent)}.about p{font-size:16px;line-height:1.85;margin:0 0 18px}.about__sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin:40px 0 14px;display:flex;align-items:center;gap:14px}.about__sub:after{content:"";flex:1;height:1px;background:var(--hairline)}.about__cv{display:grid;grid-template-columns:auto 1fr;gap:8px 22px;font-size:15px;line-height:1.55}.about__cv dt{font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:.06em}.about__cv dd{margin:0}.about__tools{display:flex;flex-wrap:wrap;gap:8px}.tool-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--text);padding:6px 12px;border:1px solid var(--hairline);border-radius:999px;background:var(--surface)}.cvgroup{display:flex;flex-direction:column;gap:8px;font-size:15px;line-height:1.55}.cvrow{display:grid;grid-template-columns:96px 1fr;gap:22px;align-items:baseline}.cvrow__key{font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:.04em}.cvrow__val{color:var(--text)}.cvgroup--awards .cvrow{grid-template-columns:56px 1fr}.cvgroup--career .cvrow{grid-template-columns:132px 1fr}.cvgroup--media .cvrow{grid-template-columns:124px 1fr}.cv-extra{margin-top:8px}.cv-extra__rows{display:none;margin-bottom:14px}.cv-extra.is-open .cv-extra__rows{display:flex}.cv-more__btn{cursor:pointer;display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:8px 14px;border:1px solid var(--hairline);border-radius:999px;background:var(--surface);transition:color .18s ease,border-color .18s ease}.cv-more__btn:hover{color:var(--accent);border-color:var(--accent)}.cv-more__close,.cv-extra.is-open .cv-more__open{display:none}.cv-extra.is-open .cv-more__close{display:inline}.contact{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}.contact__email-card{background:var(--accent);color:var(--on-accent);border-radius:var(--radius-cards);padding:36px;display:flex;flex-direction:column;gap:22px}.contact__email-card .eyebrow,body[data-palette=amber] .contact__email-card .eyebrow,body[data-palette=ink] .contact__email-card .eyebrow{color:#ffffffb3}.contact__email-value{font-family:var(--font-serif);font-style:italic;font-size:clamp(28px,4vw,40px);line-height:1.1;word-break:break-word}.contact__msg{font-size:14px;line-height:1.6;color:#ffffffdb;margin:0}.contact__copy-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid rgba(255,255,255,.55);border-radius:999px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:inherit;background:transparent;cursor:pointer;transition:background .18s ease,color .18s ease}.contact__copy-btn:hover{background:var(--on-accent);color:var(--accent)}.contact__links{display:flex;flex-direction:column;gap:0}.contact__link{display:grid;grid-template-columns:1fr auto auto;align-items:baseline;gap:16px;padding:18px 0;border-bottom:1px solid var(--hairline);text-align:left;cursor:pointer;text-decoration:none;color:var(--text);transition:color .15s ease}.contact__link:first-child{border-top:1px solid var(--hairline)}.contact__link:hover{color:var(--accent)}.contact__link-label{font-family:var(--font-serif);font-style:italic;font-size:22px;letter-spacing:-.005em}.contact__link-handle{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.contact__link-arrow{font-family:var(--font-mono);font-size:14px;color:var(--accent)}.contact__rep{grid-column:1 / -1;margin-top:36px;padding-top:28px;border-top:1px solid var(--hairline);font-family:var(--font-serif);font-style:italic;font-size:15px;color:var(--muted);text-align:center;max-width:56ch;margin-left:auto;margin-right:auto}@media(max-width:920px){.page{padding:36px 18px 100px}.works{grid-template-columns:1fr;gap:18px}.work{min-height:auto}.workmodal__body{padding:32px 22px 64px}.workmodal__hero{font-size:100px}.workmodal__meta{grid-template-columns:1fr;gap:14px}.about{grid-template-columns:1fr;gap:32px}.about__photo{max-width:320px}.contact{grid-template-columns:1fr;gap:32px}.cvrow,.cvgroup--awards .cvrow,.cvgroup--career .cvrow,.cvgroup--media .cvrow{grid-template-columns:1fr;gap:2px;padding-bottom:4px}}.modal-backdrop{position:fixed;inset:0;background:#1a1a1a6b;backdrop-filter:blur(4px);z-index:100;display:flex;align-items:stretch;justify-content:center;animation:fadeIn .2s ease}.modal-backdrop[hidden]{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:min(880px,100%);background:var(--bg);margin-top:48px;border-radius:28px 28px 0 0;overflow:auto;animation:slideUp .32s cubic-bezier(.2,.7,.2,1);border:1px solid var(--hairline)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal__head{position:sticky;top:0;background:color-mix(in oklab,var(--bg) 92%,transparent);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid var(--hairline);font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);z-index:1}.modal__close{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;border:1px solid var(--hairline);transition:background .15s ease}.modal__close:hover{background:var(--surface-2)}.modal__close:before{content:"";width:12px;height:12px;background:linear-gradient(45deg,transparent 45%,currentColor 45% 55%,transparent 55%),linear-gradient(-45deg,transparent 45%,currentColor 45% 55%,transparent 55%)}.modal__body{padding:56px 64px 96px}.modal__cat{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}.modal__title{font-family:var(--font-serif);font-weight:500;font-size:clamp(34px,4.6vw,52px);line-height:1.12;margin:0 0 20px;letter-spacing:-.012em}.modal__meta{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:40px;display:flex;gap:18px;flex-wrap:wrap}.modal__meta span:not(:last-child):after{content:"·";margin-left:18px;color:var(--hairline)}.modal__lede{font-family:var(--font-serif);font-style:italic;font-size:22px;line-height:1.5;color:var(--text);margin:0 0 36px;padding-left:18px;border-left:1px solid var(--accent)}.modal__body p{font-size:17px;line-height:1.85;margin:0 0 22px;color:var(--text);font-feature-settings:"palt"}.modal__body h3{font-family:var(--font-serif);font-weight:500;font-size:24px;margin:44px 0 16px;letter-spacing:-.005em}.modal__sep{display:flex;align-items:center;justify-content:center;margin:44px 0;color:var(--muted);letter-spacing:.6em}@media(max-width:720px){.modal{margin-top:24px;border-radius:24px 24px 0 0}.modal__body{padding:36px 22px 80px}}.serif-display{font-family:var(--font-serif);font-style:italic;font-weight:400}.media__img,.media video,video.video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}video.video{background:#000}.carousel .media .media__img{border-radius:inherit}.post-detail{max-width:820px}.detail-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:28px;transition:color .15s ease}.detail-back:before{content:"←";color:var(--accent)}.detail-back:hover{color:var(--text)}.detail-prose{padding:0!important}.detail-card .post{grid-template-columns:1fr;padding:0;border-bottom:0}.detail-card .post__meta{display:none}.detail-extra{margin-top:28px;padding:0!important}
