@import url("https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap");:root{--color-bg:#fafaf7;--color-ink:#0a0a0a;--color-muted:#666666;--color-accent:#002ced;--color-orange:#ff5a1f;--color-faint:#dcdcd6;--color-paper:#ffffff;--font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,SFMono-Regular,monospace;--font-display:"Inter Tight","Inter",system-ui,sans-serif}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--color-bg);color:var(--color-ink);font-family:var(--font-mono);font-size:13px;line-height:1.6;font-feature-settings:"palt"}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.site-header{background:var(--color-ink);color:var(--color-bg);padding:14px 36px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px 12px;font-family:var(--font-mono);font-size:13px}.site-header__brand{font-weight:700;letter-spacing:.02em;color:var(--color-bg)}.site-header__nav{display:flex;gap:6px}.site-header__search-toggle{display:none;background:transparent;border:1px solid rgba(250,250,247,.28);color:var(--color-bg);font-family:var(--font-mono);font-size:12px;padding:5px 10px;height:28px;align-items:center;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.site-header__search-toggle:hover{background:rgba(255,255,255,.08);border-color:var(--color-orange)}.site-header__search-toggle.is-open{background:var(--color-orange);border-color:var(--color-orange);color:#ffffff}.site-header__link{padding:4px 10px;color:var(--color-bg);opacity:.85;transition:opacity .12s ease}.site-header__link:hover{opacity:1}.site-header__link.is-active{background:var(--color-orange);color:#ffffff;opacity:1;font-weight:700}.nextra-search{position:relative;display:inline-flex;align-items:center;margin-left:8px}.nextra-search input[type=search]{font:inherit;font-family:var(--font-mono);font-size:12px;padding:5px 10px;background:rgba(255,255,255,.05);border:1px solid rgba(250,250,247,.28);border-radius:0;color:var(--color-bg);outline:none;width:180px;transition:border-color .12s ease,background .12s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.nextra-search input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none;appearance:none}.nextra-search input[type=search]::placeholder{color:rgba(250,250,247,.55)}.nextra-search input[type=search]:focus{border-color:var(--color-orange);background:rgba(255,255,255,.08)}.nextra-search kbd{display:none}.nextra-search-results{width:min(560px,calc(100vw - 32px));max-height:min(70vh,480px);overflow-y:auto;background:var(--color-paper);color:var(--color-ink);border:1px solid var(--color-ink);font-family:var(--font-mono);font-size:12px;padding:6px 0;box-shadow:0 10px 28px rgba(10,10,10,.18);z-index:100;list-style:none}.nextra-search-results:empty{display:none}.nextra-search-results>div:not([role=option]){font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted);padding:10px 14px 4px;margin-top:6px;border-top:1px solid var(--color-faint)}.nextra-search-results>div:not([role=option]):first-child{margin-top:0;border-top:none}.nextra-search-results [role=option]{display:block;padding:10px 14px;color:var(--color-ink);text-decoration:none;border-bottom:1px solid var(--color-faint);cursor:pointer}.nextra-search-results [role=option]:last-child{border-bottom:none}.nextra-search-results [role=option]:hover,.nextra-search-results [role=option][data-focus]{background:#f6f8ff}.nextra-search-results [role=option]>div:first-child{font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px;color:var(--color-ink);line-height:1.3}.nextra-search-results [role=option]>div:nth-child(2){font-size:11px;color:var(--color-muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.nextra-search-results mark{background:rgba(255,90,31,.18);color:var(--color-accent);font-weight:700;padding:0 2px}.site-header__search-empty{display:block;padding:14px;color:var(--color-muted)}.site-footer{background:var(--color-accent);color:#ffffff;padding:28px 36px;display:grid;grid-template-columns:repeat(4,1fr);grid-gap:24px;gap:24px;font-family:var(--font-mono);font-size:11px}.site-footer__head{font-weight:700;margin-bottom:6px}.site-footer__body{opacity:.85;line-height:1.7}.site-footer__col-right{text-align:right}.page{background:var(--color-bg);color:var(--color-ink);font-family:var(--font-mono);min-height:50vh}.divider-strong{border-bottom:1px solid var(--color-ink)}.divider-faint{border-bottom:1px solid var(--color-faint)}.hero{padding:48px 36px 36px;border-bottom:1px solid var(--color-ink)}.hero__grid{display:grid;grid-template-columns:1fr 320px;grid-gap:48px;gap:48px;align-items:end}.hero__caption{font-size:12px;color:var(--color-muted);margin-bottom:12px}.hero__title{font-family:var(--font-display);font-size:clamp(80px,14vw,200px);line-height:.82;font-weight:900;letter-spacing:-.06em;margin:0}.hero__title-slash{color:var(--color-accent)}.hero__meta-num{font-family:var(--font-display);font-size:56px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:6px}.hero__meta-num-small{color:var(--color-muted);font-size:32px}.hero__meta-sub{font-size:12px;color:var(--color-muted);margin-bottom:16px}.hero__meta-text{font-family:var(--font-display);font-size:16px;line-height:1.55;margin:0}.whoami{padding:36px;border-bottom:1px solid var(--color-ink);background:var(--color-paper);display:flex;flex-direction:column;gap:28px}.whoami__head{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:11px;color:var(--color-muted)}.whoami__label{letter-spacing:.1em;text-transform:uppercase}.whoami__grid{display:block}.whoami__profile{font-family:var(--font-mono);font-size:13px;line-height:1.7;gap:18px}.whoami__id,.whoami__profile{display:flex;flex-direction:column}.whoami__id{margin:0;gap:8px}.whoami__id-row{display:grid;grid-template-columns:56px 1fr;grid-gap:12px;gap:12px;align-items:baseline}.whoami__id dt{font-family:var(--font-mono);font-size:11px;color:var(--color-accent);letter-spacing:.08em;font-weight:700}.whoami__id dd{margin:0;font-size:18px;font-weight:600;letter-spacing:-.01em;line-height:1.4}.whoami__bio,.whoami__id dd{font-family:var(--font-display)}.whoami__bio{display:flex;flex-direction:column;gap:4px;font-size:14px;line-height:1.7;color:var(--color-ink)}.whoami__bio-line{margin:0}.whoami__bio-more{align-self:flex-start;margin-top:4px;font-family:var(--font-mono);font-size:11px;color:var(--color-accent);font-weight:700;letter-spacing:.04em}.whoami__links{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:4px}.whoami__link{display:inline-flex;align-items:center;padding:4px 8px;border:1px solid var(--color-faint);background:var(--color-paper);color:var(--color-ink);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.02em;transition:background .12s ease,color .12s ease,border-color .12s ease}.whoami__link:hover{background:var(--color-accent);color:#ffffff;border-color:var(--color-accent)}.whoami__link-name{display:inline-block}.whoami__works{display:flex;flex-direction:column;gap:14px}.whoami__works-head{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);letter-spacing:.1em;text-transform:uppercase}.whoami__works-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:18px;gap:18px}.whoami__work{display:flex;flex-direction:column;gap:8px;color:var(--color-ink)}.whoami__work-thumb{display:block;aspect-ratio:16/10;background:var(--color-bg);overflow:hidden;border:1px solid var(--color-faint)}.whoami__work-thumb img{width:100%;height:100%;object-fit:cover;display:block}.whoami__work:hover .whoami__work-thumb{border-color:var(--color-accent)}.whoami__work-meta{display:flex;flex-direction:column;gap:2px}.whoami__work-date{font-family:var(--font-mono);font-size:10px;color:var(--color-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.whoami__work-title{font-family:var(--font-display);font-size:14px;font-weight:700;line-height:1.3;letter-spacing:-.01em}@media (max-width:880px){.whoami{padding:24px 20px}.whoami__works-grid{grid-template-columns:repeat(2,1fr);gap:12px}.whoami__work-thumb{aspect-ratio:1/1}.whoami__work-title{font-size:12px}}@media (max-width:480px){.whoami__works-grid{grid-template-columns:1fr;gap:14px}.whoami__work-thumb{aspect-ratio:16/10}.whoami__work-title{font-size:13px}}.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);border-bottom:1px solid var(--color-ink)}.cat-grid__cell{padding:20px 16px;border-right:1px solid var(--color-ink);color:var(--color-ink);display:flex;flex-direction:column;gap:6px}.cat-grid__cell:last-child{border-right:none}.cat-grid__cell.is-feature{background:var(--color-orange);color:#ffffff}.cat-grid__cell-no{font-size:10px;letter-spacing:.08em;opacity:.7}.cat-grid__cell-name{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1}.cat-grid__cell-count{font-size:11px;margin-top:2px;opacity:.85}.index-row,.index-table__head{display:grid;grid-template-columns:60px 110px 1fr;align-items:baseline}.index-table__head{padding:12px 36px;font-size:10px;letter-spacing:.1em;color:var(--color-muted);border-bottom:1px solid var(--color-ink)}.index-row{padding:20px 36px;border-bottom:1px solid var(--color-faint);color:var(--color-ink)}.index-row.is-first{background:#f6f8ff}.index-row__no{font-size:11px;color:var(--color-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.index-row.is-first .index-row__no{color:var(--color-accent);font-weight:700}.index-row__date{font-size:11px;color:var(--color-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.index-row__title{font-family:var(--font-display);font-size:19px;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.index-row.is-first .index-row__title{font-size:28px}.index-row__tags{font-size:10px;color:var(--color-muted);line-height:1.6}.index-row__read{font-size:11px;color:var(--color-muted);text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.works-grid{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--color-ink)}.works-card{display:flex;flex-direction:column;border-right:1px solid var(--color-faint);border-bottom:1px solid var(--color-faint);background:var(--color-paper);color:var(--color-ink);transition:background .12s ease}.works-card:nth-child(3n){border-right:none}.works-card:hover{background:#f6f8ff}.works-card__thumb{aspect-ratio:16/10;background:var(--color-bg);border-bottom:1px solid var(--color-faint);overflow:hidden;display:block;position:relative}.works-card__thumb img{width:100%;height:100%;object-fit:cover;display:block}.works-card__thumb--placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-faint);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em}.works-card__body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1 1}.works-card__meta{font-family:var(--font-mono);font-size:10px;color:var(--color-muted);letter-spacing:.06em;display:flex;justify-content:space-between;align-items:baseline}.works-card__no{color:var(--color-accent);font-weight:700}.works-card__title{font-family:var(--font-display);font-size:20px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0}.works-card__tags{margin-top:auto;font-family:var(--font-mono);font-size:10px;color:var(--color-muted);line-height:1.6}@media (max-width:880px){.works-grid{grid-template-columns:1fr}.works-card,.works-card:nth-child(3n){border-right:none}}.tag-cloud{display:flex;flex-wrap:wrap;gap:0;border-bottom:1px solid var(--color-ink)}.tag-cloud__item{display:inline-flex;align-items:baseline;gap:8px;padding:14px 18px;border-right:1px solid var(--color-faint);border-bottom:1px solid var(--color-faint);background:var(--color-paper);color:var(--color-ink);font-family:var(--font-mono);font-size:13px}.tag-cloud__item:hover{background:#f6f8ff;color:var(--color-accent)}.tag-cloud__item.is-all{background:var(--color-accent);color:#ffffff;border-right-color:var(--color-accent);border-bottom-color:var(--color-accent)}.tag-cloud__item.is-all:hover{background:var(--color-orange);color:#ffffff}.tag-cloud__item.is-all .tag-cloud__count{color:#ffffff;opacity:.85}.tag-cloud__tag{font-weight:700}.tag-cloud__count{font-size:11px;color:var(--color-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pagination{padding:20px 36px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--color-ink);font-size:11px}.pagination__meta{color:var(--color-muted)}.pagination__pages{display:flex;gap:6px}.pagination__page{font-family:var(--font-mono);font-size:11px;padding:6px 12px;border:1px solid var(--color-ink);background:var(--color-paper);color:var(--color-ink)}.pagination__page.is-active{background:var(--color-orange);color:#ffffff;font-weight:700}.pagination__page.is-disabled{opacity:.4;pointer-events:none;cursor:default}.pagination__page:hover:not(.is-active):not(.is-disabled){background:var(--color-bg)}.post-hero{padding:48px 36px 36px;border-bottom:1px solid var(--color-ink)}.post-hero__caption{font-size:12px;color:var(--color-muted);margin-bottom:12px}.post-hero__caption-cat{color:var(--color-accent)}.post-hero__title{font-family:var(--font-display);font-size:clamp(40px,7vw,84px);line-height:.95;font-weight:900;letter-spacing:-.045em;margin:0 0 20px;text-wrap:balance}.post-hero__meta{display:flex;gap:32px;font-size:12px;padding-top:16px;border-top:1px solid var(--color-faint);flex-wrap:wrap}.post-hero__meta-key{color:var(--color-muted)}.post-hero__meta-tag,.post-hero__meta-val--accent{color:var(--color-accent)}.post-hero__meta-tag{margin-right:8px}.post-hero__meta-tag:hover{text-decoration:underline}.post-layout{display:grid;grid-template-columns:260px 1fr;max-width:1100px;margin:0 auto;padding:40px 36px}.post-toc{padding-right:32px;border-right:1px solid var(--color-faint);position:-webkit-sticky;position:sticky;top:20px;height:-moz-fit-content;height:fit-content;font-size:12px}.post-toc__head{color:var(--color-accent);font-weight:700;margin-bottom:12px}.post-toc__list{list-style:none;padding:0;margin:0}.post-toc__item{margin-bottom:8px;line-height:1.4}.post-toc__item.is-sub{padding-left:14px}.post-toc__no{color:var(--color-muted);margin-right:8px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.post-toc__link{color:var(--color-ink)}.post-body{padding-left:40px;max-width:680px;font-size:16px;line-height:1.85}.post-body,.post-body h2{font-family:var(--font-display)}.post-body h2{font-size:30px;font-weight:800;letter-spacing:-.025em;margin:40px 0 16px}.post-body h3{font-family:var(--font-display);font-size:20px;font-weight:700;margin:28px 0 10px}.post-body p{margin:0 0 18px}.post-body blockquote{margin:28px 0;padding:20px 24px;background:var(--color-paper);border:1px solid var(--color-ink);border-left:6px solid var(--color-accent);font-family:var(--font-display);font-size:18px;line-height:1.55}.post-body a{color:var(--color-accent);border-bottom:1px solid var(--color-faint)}.post-body img{max-width:100%;height:auto}.post-body iframe{max-width:100%;display:block}.post-body iframe[src*="player.vimeo.com"],.post-body iframe[src*="speakerdeck.com"],.post-body iframe[src*="youtube.com/embed"]{width:100%;aspect-ratio:16/9}.post-body pre{padding:14px 16px;overflow-x:auto;font-size:13px;line-height:1.55}.post-body code,.post-body pre{background:var(--color-paper);border:1px solid var(--color-faint);font-family:var(--font-mono)}.post-body code{font-size:.92em;padding:1px 5px;border-radius:2px}.post-body pre code{background:transparent;border:none;padding:0}.post-body ol,.post-body ul{padding-left:1.4em;margin:0 0 18px}.post-end{margin-top:36px;padding:14px 0;border-top:1px dashed var(--color-ink);font-family:var(--font-mono);font-size:12px;color:var(--color-muted);display:flex;justify-content:space-between}.post-end__accent{color:var(--color-accent)}.about-page{padding:48px 36px 64px;max-width:720px;margin:0 auto;line-height:1.85}.about-page,.about-page h1{font-family:var(--font-display)}.about-page h1{font-size:clamp(56px,10vw,120px);line-height:.85;font-weight:900;letter-spacing:-.05em;margin:0 0 32px}.about-page h1 .slash{color:var(--color-accent)}.about-page h2{font-family:var(--font-display);font-size:22px;font-weight:700;margin:32px 0 8px}.about-page a{color:var(--color-accent);border-bottom:1px solid var(--color-faint)}@media (max-width:880px){.site-header{align-items:center;gap:8px 12px;padding:14px 20px}.site-header__brand{flex:1 1}.site-header__search-toggle{display:inline-flex}.site-header__search-slot{order:1;flex-basis:100%;display:none}.site-header__search-slot.is-open{display:block}.site-header__nav{order:2;flex-basis:100%;flex-wrap:wrap}.nextra-search{margin-left:0;width:100%}.nextra-search input[type=search]{width:100%;font-size:16px;padding:8px 12px}.nextra-search-results{position:fixed!important;inset:auto 0 0 0!important;width:100%!important;max-width:none!important;max-height:70vh!important;transform:none!important;border:none;border-top:1px solid var(--color-ink);box-shadow:0 -10px 28px rgba(10,10,10,.18)}.site-footer{grid-template-columns:repeat(2,1fr);padding:20px}.hero{padding:32px 20px 24px}.hero__grid{grid-template-columns:1fr;gap:24px}.cat-grid{grid-template-columns:repeat(3,1fr)}.cat-grid__cell:nth-child(3n){border-right:none}.index-row,.index-table__head{grid-template-columns:80px 1fr;padding-left:20px;padding-right:20px}.index-row__no,.index-table__head>:first-child{display:none}.post-hero{padding:32px 20px 24px}.post-layout{grid-template-columns:1fr;padding:24px 20px}.post-toc{border-right:none;border-bottom:1px solid var(--color-faint);padding:0 0 20px;margin-bottom:24px;position:static}.post-body{padding-left:0}.pagination{flex-direction:column;gap:12px;align-items:flex-start;padding:20px}}