:root{--bg:#fff7ef;--bg-accent:#ffe9d6;--text:#1d1510;--muted:#7a5a46;--accent:#e06a1a;--border:#f2d7c4;--font-sans:"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo","Noto Sans JP","Helvetica Neue",Arial,sans-serif;--font-serif:"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo","Noto Sans JP","Helvetica Neue",Arial,sans-serif;--code-bg:#f8f3ee;--code-border:#ead9ca;--code-text:#3a2a1f}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text);background:#fff;min-height:100vh;font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.page{flex-direction:row;gap:64px;max-width:980px;margin:0 auto;padding:64px 32px 72px;display:flex}.site-header{flex-direction:column;align-items:flex-start;gap:12px;min-width:140px;display:flex}.brand-icon{justify-content:center;align-items:center;display:inline-flex}.brand-mark{object-fit:cover;border-radius:14px;width:48px;height:48px}.site-title{font-family:var(--font-serif);margin:0;font-size:22px;font-weight:700}.site-title-mobile{display:none}.site-subtitle{color:var(--muted);margin:0;font-size:14px}.site-nav{flex-direction:column;gap:12px;font-size:14px;display:flex}.content,.main-column{flex-direction:column;flex:1;gap:48px;display:flex}.intro{max-width:620px;margin-top:8px;font-size:16px}.intro h1{font-family:var(--font-serif);margin:0 0 6px;font-size:22px}.intro code{color:var(--accent);font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.95em;font-weight:700}.intro code:before,.intro code:after{content:"`"}.section{flex-direction:column;gap:20px;padding-top:8px;display:flex}.section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.section h2{font-family:var(--font-serif);margin:0;font-size:18px}.section h1{font-family:var(--font-serif);margin:0 0 6px;font-size:22px}.section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:12px}.list{flex-direction:column;gap:16px;margin:0;padding:0;list-style:none;display:flex}.list-item{border-bottom:1px solid #1d151014;justify-content:space-between;align-items:flex-start;gap:16px;padding:10px 0;display:flex}.list-title{margin:0;font-size:15px;font-weight:600;display:inline-block}.list-meta{color:var(--muted);white-space:nowrap;font-size:12px}.list-plain .list-item{background:0 0;border-radius:0}.post{max-width:100%}.post-header h1{font-family:var(--font-serif);margin:0 0 8px;font-size:28px}.post-date{color:var(--muted);margin:0;font-size:13px}.post-toc{text-align:left;border-radius:12px;margin:24px 0 28px;padding:16px 18px 16px 0}.post-toc-title{letter-spacing:.12em;color:var(--muted);cursor:pointer;align-items:center;gap:8px;margin:0;padding-left:0;font-size:12px;list-style:none;display:flex}.post-toc-title::marker{content:""}.post-toc-title::-webkit-details-marker{display:none}.post-toc-title:before{content:"▸";font-size:12px;transition:transform .2s}.post-toc[open] .post-toc-title:before{transform:rotate(90deg)}.post-toc nav{margin-top:12px}.post-toc ul{flex-direction:column;gap:6px;margin:0;padding-left:0;font-size:14px;list-style:none;display:flex}.post-toc-item.depth-2{padding-left:12px}.post-toc-item.depth-3{padding-left:22px;font-size:13px}.post-toc-item.depth-4{padding-left:32px;font-size:12.5px}.post-content{margin-top:24px;font-size:16px}.post-content code{color:var(--accent);background:0 0;border-radius:0;padding:0;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.92em;font-weight:700}.post-content pre,.post-content .shiki{box-shadow:none;border:none;border-radius:12px;margin:20px 0;padding:18px 20px;overflow-x:auto;background:#f5f6f8!important}.post-content pre code,.post-content .shiki code{background:0 0;padding:0;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.95em}.post-content :not(pre)>code:before,.post-content :not(pre)>code:after{color:var(--accent);opacity:.9}.post-content :not(pre)>code:before{content:"`";margin-right:.04em}.post-content :not(pre)>code:after{content:"`";margin-left:.04em}.post-content h2{font-family:var(--font-serif);margin:28px 0 12px;font-size:20px}.post-content .heading-anchor{color:inherit;text-decoration:none}.post-content .heading-anchor:hover:after{content:" #";color:var(--muted);font-weight:400}.post-content hr{border:0;border-top:1px solid #1d15101f;margin:28px 0}.post-content blockquote{border-left:3px solid var(--accent);color:var(--muted);margin:20px 0;padding:4px 0 4px 16px}.post-content blockquote>:first-child{margin-top:0}.post-content blockquote>:last-child{margin-bottom:0}.post-content .footnotes{color:var(--muted);margin-top:32px}.post-content .footnotes h2{font-family:var(--font-serif);border-bottom:1px solid var(--border);letter-spacing:.08em;margin:0 0 12px;padding-bottom:4px;font-size:14px;font-weight:600;display:inline-block}.post-content .footnotes ol{margin:0;padding-left:20px;font-size:13px}.post-content .footnotes li+li{margin-top:8px}.post-content ul{padding-left:18px}.post-content li+li{margin-top:6px}.misc{gap:12px}.misc-coming{color:var(--muted);margin:0}.misc-links{flex-direction:column;gap:20px;font-size:15px;display:flex}.misc-item{flex-direction:column;gap:6px;display:flex}.misc-title{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0;font-size:12px;font-weight:700}.misc-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.misc-list li{flex-direction:column;gap:4px;display:flex}.misc-meta{color:var(--muted);font-size:12px}.site-footer{color:var(--muted);flex-wrap:wrap;justify-content:space-between;gap:12px;padding-top:18px;font-size:12px;display:flex}.footer-links{gap:10px;font-size:12px;display:flex}.icon-link{width:24px;height:24px;color:var(--muted);place-items:center;display:grid}.icon-link svg{fill:currentColor;width:20px;height:20px}.icon-link:hover{color:var(--accent)}@media (max-width:680px){.page{flex-direction:column;padding:40px 20px 56px}.site-header{flex-direction:column;align-items:flex-start;gap:10px}.site-title-mobile{display:block}.page-title{display:none}.site-nav{flex-direction:row;gap:16px}.list-item,.section-header,.misc-links{flex-direction:column;align-items:flex-start}}
