:root{--c-ink-900: #101214;--c-ink-800: #15181b;--c-ink-700: #1a1d1f;--c-line: #272a2b;--c-paper: #d6d3cb;--c-mute: #82837e;--c-faint: #3a3c3b;--c-lime: #a6e22e;--c-lime-2: #8ac04a;--c-orange: #fd971f;--c-cyan: #66d9ef;--bg: var(--c-ink-900);--surface: var(--c-ink-800);--chrome: var(--c-ink-700);--border: var(--c-line);--text: var(--c-paper);--text-muted: var(--c-mute);--decoration: var(--c-faint);--link: var(--c-lime);--post: var(--c-lime);--log: var(--c-orange);--info: var(--c-cyan);--accent-soft: var(--c-lime-2);--pane: var(--surface);--fg: var(--text);--dim: var(--text-muted);--faint: var(--decoration);--rule: var(--border);--accent: var(--link);--accent2: var(--accent-soft);--warm: var(--log);--blue: var(--info);--status: var(--chrome);--mono: var(--font-mono, "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace);--sans: var(--font-sans, "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-7: 32px;--sp-8: 48px;--page-pad: var(--sp-2);--grid-gap: var(--sp-2);--pane-pad-y: var(--sp-5);--pane-pad-x: var(--sp-6);--pane-head-pad-y: 6px;--pane-head-pad-x: var(--sp-3);--bar-pad-x: var(--sp-4);--row-pad-y: 6px;--list-gap: var(--sp-2);--section-gap: var(--sp-6);--entry-pad-y: var(--sp-3)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--mono);font-size:13px;line-height:1.7}body{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}ul{margin:0;padding:0;list-style:none}p{margin:0}.top-bar{display:flex;align-items:center;background:var(--status);padding:6px var(--bar-pad-x);border-bottom:1px solid var(--rule);font-size:11.5px;gap:10px;flex-shrink:0}.top-bar .site-tag{color:var(--bg);background:var(--accent);padding:1px 8px;font-weight:600}.top-bar .win-active{color:var(--fg);background:var(--rule);padding:1px 8px}.top-bar .dim{color:var(--dim)}.top-bar .spacer{flex:1}.main{flex:1;min-height:0;display:grid;grid-template-columns:1.35fr 1fr;grid-template-rows:auto 1fr;gap:var(--grid-gap);padding:var(--page-pad);width:100%;max-width:1600px;margin:0 auto}.left-col{grid-column:1;grid-row:1 / 3;display:flex;flex-direction:column;gap:var(--grid-gap);min-height:0;min-width:0}.activity-pane{grid-column:2;grid-row:1;min-height:0;min-width:0}.tags-pane{grid-column:2;grid-row:2;min-height:0;min-width:0}.hero-pane{flex-shrink:0}.articles-pane{flex:1;min-height:0;min-width:0}.main-home{grid-template-rows:1fr}.main-home .left-col{grid-row:1}.main-home .right-col{grid-column:2;grid-row:1;display:flex;flex-direction:column;gap:var(--grid-gap);min-width:0;min-height:0}.main-home .articles-pane{flex:0 1 auto}.main-home .log-pane{flex-shrink:0}.main-home .tags-pane{flex:0 1 auto}.pane-header .pane-more{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.pane-header .pane-more:hover{color:var(--accent);border-bottom-color:var(--accent)}.pane-header .marker-log{color:var(--warm)}.log-teaser-list{display:flex;flex-direction:column}.log-teaser{display:grid;grid-template-columns:58px auto 1fr auto;align-items:baseline;gap:12px;padding:var(--row-pad-y) 0}.log-teaser-date{color:var(--dim);font-size:11.5px}.log-teaser-bar{color:var(--warm)}.log-teaser-body{font-family:var(--sans);font-size:13.5px;line-height:1.45;color:var(--fg);justify-self:start;max-width:100%;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.log-teaser-body:hover{color:var(--warm);border-bottom-color:var(--warm)}.log-teaser-tags{display:inline-flex;gap:8px;white-space:nowrap;font-size:11.5px}.log-teaser-tag{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.log-teaser-tag:hover{color:var(--accent);border-bottom-color:var(--accent)}.log-teaser-tag:hover .hash{color:var(--accent)}.log-teaser-tag .hash{color:var(--faint)}.tag-label{color:var(--dim)}.tag-label .hash{color:var(--faint)}a.tag-label{border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}a.tag-label:hover{color:var(--accent);border-bottom-color:var(--accent)}a.tag-label:hover .hash{color:var(--accent)}.pane{background:var(--pane);border:1px solid var(--rule);display:flex;flex-direction:column;min-height:0;min-width:0}.pane-header{display:flex;align-items:center;padding:var(--pane-head-pad-y) var(--pane-head-pad-x);background:var(--status);border-bottom:1px solid var(--rule);font-size:11px;color:var(--dim);gap:10px;flex-shrink:0}.pane-header .marker{color:var(--accent)}.pane-header .title{color:var(--fg)}.pane-header .sep{color:var(--faint)}.pane-header .spacer{flex:1}.pane-header .controls{color:var(--faint)}.pane-body{flex:1;min-height:0;min-width:0;padding:var(--pane-pad-y) var(--pane-pad-x);overflow:hidden}.pane-body.scroll{overflow:auto}.hero-title{font-size:26px;color:var(--fg);font-weight:500;letter-spacing:-.01em}.hero-title .cursor{color:var(--accent)}.hero-fullpath{margin-top:4px;color:var(--dim);font-size:12px}.hero-fullpath .comment{color:var(--faint)}.hero-tagline{margin-top:8px;font-family:var(--sans);color:var(--fg);font-size:14px;max-width:72ch;line-height:1.7}.hero-about{margin-top:6px;color:var(--fg);font-size:12px;max-width:72ch}.hero-about .comment{color:var(--faint)}.hero-about a{color:var(--accent);border-bottom:1px solid var(--faint);transition:border-color .15s}.hero-about a:hover{border-bottom-color:var(--accent)}.month-group{margin-bottom:var(--section-gap)}.month-label{color:var(--accent2);font-size:11.5px;margin-bottom:6px;display:flex;align-items:baseline;gap:8px}.month-label .month-name{color:var(--faint)}.month-label .fill-dots{flex:1;color:var(--faint);overflow:hidden;white-space:nowrap}.article-row{display:grid;grid-template-columns:58px 1fr auto;align-items:baseline;gap:12px;padding:var(--row-pad-y) 0}.article-date{color:var(--dim);font-size:11.5px}.article-link{color:var(--fg);font-family:var(--sans);font-size:13.5px;line-height:1.45;justify-self:start;border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.draft-badge{color:#ff5f87;font-weight:700;letter-spacing:.05em;margin-right:6px;font-size:11px}.draft-banner{display:inline-block;margin:6px 0 12px;padding:4px 10px;border:1px dashed #ff5f87;color:#ff5f87;font-weight:700;letter-spacing:.08em;font-size:11px}.article-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.article-tags{color:var(--dim);font-size:11.5px;text-align:right;white-space:nowrap;display:inline-flex;gap:6px;justify-content:flex-end}.article-tags .hash{color:var(--faint)}.article-tag{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.article-tag:hover{color:var(--accent);border-bottom-color:var(--accent)}.article-tag:hover .hash{color:var(--accent)}.articles-pane .article-row{grid-template-columns:58px auto 1fr auto}.article-bar{color:var(--accent)}.articles-pane .article-link{justify-self:start;max-width:100%;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.article-tags-row{display:flex;flex-wrap:wrap;gap:8px 12px;margin:-16px 0 28px;font-family:var(--mono);font-size:12px}.article-tags-row .article-tag{color:var(--dim)}.article-tags-row .hash{color:var(--faint)}.articles-empty{color:var(--dim);font-family:var(--sans);font-size:13px;padding:4px 0}.articles-empty .comment{color:var(--faint)}.tags-list{display:flex;flex-direction:column;gap:var(--list-gap)}.tag-row{display:grid;grid-template-columns:24px 13ch 1fr auto;align-items:baseline;gap:8px;padding:3px 0;color:var(--fg);font-size:12.5px}.tag-num{color:var(--faint);font-size:10.5px}.tag-label{color:var(--accent)}.tag-blurb{color:var(--dim);font-size:11px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.tag-count{color:var(--dim);font-size:11px}.pane-rss{color:var(--dim);font-size:10.5px;letter-spacing:.05em;border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.pane-rss:hover{color:var(--warm);border-bottom-color:var(--warm)}.entry-list{list-style:none;margin:0;padding:0}.entry-card{display:grid;grid-template-columns:48px 1fr;gap:14px;padding:var(--entry-pad-y) 0}.entry-card+.entry-card{border-top:1px solid var(--rule)}.entry-date{color:var(--dim);font-size:11.5px;padding-top:2px}.entry-main{min-width:0;border-left:2px solid var(--entry-accent, transparent);padding-left:14px}.entry-list--post{--entry-accent: var(--post)}.entry-list--log{--entry-accent: var(--log)}.entry-card--post{--entry-accent: var(--post)}.entry-card--log{--entry-accent: var(--log)}.entry-title{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;font-family:var(--sans);font-size:14px;font-weight:600;color:var(--fg);line-height:1.45;text-decoration:underline;text-decoration-color:transparent;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .1s,text-decoration-color .1s}.entry-title:hover{color:var(--entry-accent, var(--accent));text-decoration-color:var(--entry-accent, var(--accent))}.entry-summary{margin:4px 0 0;color:var(--dim);font-family:var(--sans);font-size:12.5px;line-height:1.6;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden}.entry-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px 12px;font-size:11.5px}.entry-tags .hash{color:var(--faint)}.entry-tag{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}a.entry-tag:hover{color:var(--accent);border-bottom-color:var(--accent)}a.entry-tag:hover .hash{color:var(--accent)}.pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:var(--section-gap);padding-top:16px;border-top:1px solid var(--rule);font-size:12px}.page-nav{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.page-nav:hover{color:var(--accent);border-bottom-color:var(--accent)}.page-nav.is-disabled{color:var(--faint);pointer-events:none}.page-nums{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}.page-num{display:inline-block;min-width:22px;padding:2px 6px;text-align:center;color:var(--dim);border:1px solid transparent;border-radius:3px;transition:color .1s,border-color .1s}.page-num:hover{color:var(--accent);border-color:var(--rule)}.page-num.is-current{color:var(--fg);border-color:var(--dim);font-weight:600}.log-meta-tags{display:inline-flex;gap:10px}.log-meta-tags .hash{color:var(--faint)}.log-nav{max-width:92ch;margin:40px auto 0;display:flex;justify-content:space-between;gap:16px;padding-top:18px;border-top:1px dashed var(--rule);font-family:var(--mono);font-size:12.5px}.log-nav a{display:flex;flex-direction:column;gap:3px;color:var(--fg);border-bottom:0;transition:color .15s}.log-nav-next{text-align:right}.log-nav a:hover{color:var(--accent)}.log-nav-label{color:var(--dim);font-size:11px;font-family:var(--sans)}.log-nav a:hover .log-nav-label{color:var(--accent)}.cal{font-family:var(--mono)}.cal-head{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:8px;max-width:280px}.cal-title{flex:1;text-align:center;color:var(--accent);letter-spacing:.02em}.cal-nav{font-family:var(--mono);font-size:11px;color:var(--dim);background:none;border:none;cursor:pointer;padding:2px 6px;line-height:1;transition:color .1s}.cal-nav:hover:not(:disabled){color:var(--accent)}.cal-nav:disabled{color:var(--faint);opacity:.4;cursor:default}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px 2px;max-width:280px}.cal-wd{color:var(--faint);font-size:10px;text-align:center;padding-bottom:2px}.cal-day{text-align:center;font-size:11.5px;color:var(--dim);padding:3px 0;border-radius:2px;border-bottom:2px solid transparent}.cal-blank{visibility:hidden}.cal-day.has-post{color:var(--post)}.cal-day.has-log{color:var(--log)}.cal-day.has-both{color:var(--post);border-bottom-color:var(--log)}.cal-day.is-future{color:var(--faint)}.cal-day.is-today{background:var(--rule);color:var(--accent)}.cal-day.is-today.has-post{color:var(--post)}.cal-day.is-today.has-log{color:var(--log)}.cal-day.is-today.has-both{color:var(--post)}.activity-footer{margin-top:var(--sp-3);font-size:11px;color:var(--dim)}.activity-footer .faint{color:var(--faint)}.activity-footer .post{color:var(--post)}.activity-footer .log{color:var(--log)}.bottom-bar{background:var(--status);border-top:1px solid var(--rule);padding:5px var(--bar-pad-x);display:flex;align-items:center;font-size:11px;color:var(--dim);gap:10px;flex-shrink:0}.bottom-bar .sep-pipe{color:var(--faint);padding:0 2px}.bottom-bar .spacer{flex:1}.article-main{flex:1;display:flex;padding:var(--page-pad);min-height:0;width:100%;max-width:1100px;margin:0 auto}.article-pane{flex:1}.article-pane .pane-header .rule{flex:1;color:var(--faint);white-space:nowrap;overflow:hidden}.article-pane .pane-header .controls{letter-spacing:.2em}.article-pane .pane-body{padding:36px 56px 48px;overflow-y:auto}.article{max-width:92ch;margin:0 auto}.article-meta{font-family:var(--mono);font-size:11.5px;color:var(--dim);display:flex;align-items:baseline;gap:10px;margin-bottom:18px}.article-meta .sep{color:var(--faint)}.article-meta .updated{color:var(--dim)}.breadcrumb{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-bottom:16px;display:flex;align-items:baseline;flex-wrap:wrap;gap:8px}.breadcrumb a{color:var(--dim);border-bottom:1px solid transparent;transition:color .1s,border-bottom-color .1s}.breadcrumb a:hover{color:var(--accent);border-bottom-color:var(--accent)}.breadcrumb .sep{color:var(--faint)}.breadcrumb .current{color:var(--fg)}.breadcrumb a.current{color:var(--accent)}.breadcrumb .count{color:var(--dim)}.article-meta .rule{flex:1;color:var(--faint);overflow:hidden;white-space:nowrap}.article-title{font-family:var(--sans);font-weight:600;font-size:28px;line-height:1.4;color:var(--fg);margin:0 0 28px;letter-spacing:-.005em}.article-body{font-family:var(--sans);font-size:15.5px;line-height:1.85;color:var(--fg)}.article-body>*+*{margin-top:1.4em}.article-body h2{font-family:var(--sans);font-weight:600;font-size:19px;line-height:1.5;color:var(--fg);margin:2.4em 0 .8em;padding-bottom:6px;border-bottom:1px solid var(--rule)}.article-body h2:before{content:"## ";color:var(--faint);font-family:var(--mono);font-weight:400}.article-body h3{font-family:var(--sans);font-weight:600;font-size:16.5px;color:var(--fg);margin:2em 0 .6em}.article-body h3:before{content:"### ";color:var(--faint);font-family:var(--mono);font-weight:400}.article-body a{color:var(--accent);border-bottom:1px solid var(--faint);transition:border-color .15s}.article-body a:hover{border-bottom-color:var(--accent)}.article-body strong{color:var(--fg);font-weight:600}.article-body em{color:var(--accent2);font-style:normal;border-bottom:1px dotted var(--faint)}.article-body code{font-family:var(--mono);font-size:.88em;background:var(--bg);color:var(--blue);padding:1px 6px;border:1px solid var(--rule);border-radius:2px}.article-body pre{margin:1.6em 0;background:var(--bg);border:1px solid var(--rule);border-left:2px solid var(--accent);padding:14px 18px;overflow-x:auto;font-family:var(--mono);font-size:13px;line-height:1.65;color:var(--fg);position:relative}.article-body pre code{background:transparent;border:0;padding:0;color:inherit;font-size:inherit}.article-body pre:before{content:attr(data-lang);position:absolute;top:6px;right:12px;font-size:10.5px;color:var(--dim);letter-spacing:.05em;text-transform:uppercase}.code-copy{position:absolute;top:6px;right:8px;background:var(--status);border:1px solid var(--rule);color:var(--dim);font-family:var(--mono);font-size:10.5px;padding:2px 8px;cursor:pointer;letter-spacing:.05em;text-transform:uppercase;opacity:0;transition:opacity .15s,color .15s,border-color .15s,background .15s}.article-body pre:hover .code-copy,.article-body pre:focus-within .code-copy,.code-copy:focus-visible{opacity:1}.code-copy:hover{color:var(--accent);border-color:var(--accent)}.code-copy.copied{color:var(--bg);background:var(--accent);border-color:var(--accent);opacity:1}@media(hover:none){.code-copy{opacity:1}}.article-body blockquote{margin:1.6em 0;padding:4px 0 4px 20px;border-left:2px solid var(--faint);color:var(--dim);font-style:normal}.article-body blockquote p{margin:0}.article-body blockquote p+p{margin-top:1em}.article-body ul,.article-body ol{padding-left:0;list-style:none}.article-body ul li,.article-body ol li{position:relative;padding-left:1.6em}.article-body ul li+li,.article-body ol li+li{margin-top:.4em}.article-body ul li:before{content:"·";position:absolute;left:.6em;color:var(--accent);font-family:var(--mono)}.article-body ol{counter-reset:ol}.article-body ol li{counter-increment:ol;padding-left:2.4em}.article-body ol li:before{content:counter(ol,decimal-leading-zero);position:absolute;left:0;font-family:var(--mono);font-size:.85em;color:var(--accent)}.article-body table{border-collapse:collapse;margin:1.6em 0;font-family:var(--mono);font-size:13px;width:100%}.article-body th,.article-body td{text-align:left;padding:7px 12px;border-bottom:1px solid var(--rule)}.article-body th{color:var(--accent);font-weight:600;border-bottom:1px solid var(--faint)}.article-body td{color:var(--fg)}.article-body img{display:block;max-width:100%;height:auto;margin:1.8em auto;border:1px solid var(--rule)}.article-body figure{margin:1.8em 0}.article-body figcaption{font-family:var(--mono);font-size:11.5px;color:var(--dim);text-align:center;margin-top:8px}.article-body hr{border:0;border-top:1px solid var(--rule);margin:2.4em 0}.article-footer{max-width:92ch;margin:56px auto 0;padding-top:20px;border-top:1px dashed var(--rule);font-family:var(--mono);font-size:12.5px;display:flex;gap:14px;align-items:baseline;color:var(--dim)}.article-footer a{color:var(--fg);border-bottom:1px solid transparent;transition:color .15s,border-color .15s}.article-footer a:hover{color:var(--accent);border-bottom-color:var(--accent)}.article-footer .key{color:var(--accent);background:var(--bg);border:1px solid var(--rule);padding:1px 7px;font-size:11px}.article-layout.has-toc{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:40px;align-items:start}.article-col{min-width:0}.toc-rail{position:sticky;top:8px;align-self:start;max-height:calc(100vh - 80px);overflow-y:auto;font-family:var(--mono);font-size:12px;padding-top:2px}.toc-head{color:var(--faint);letter-spacing:.08em;margin-bottom:10px}.toc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}.toc-item.toc-d3{padding-left:14px}.toc-link{color:var(--dim);border-bottom:1px solid transparent;line-height:1.5;transition:color .1s,border-bottom-color .1s}.toc-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.toc-details{display:none;font-family:var(--mono);font-size:12.5px;border:1px solid var(--rule);border-radius:2px;margin-bottom:24px;padding:0 12px}.toc-details summary{cursor:pointer;padding:8px 0;color:var(--dim);list-style:none}.toc-details summary::-webkit-details-marker{display:none}.toc-details summary:before{content:"▸ ";color:var(--faint)}.toc-details[open] summary:before{content:"▾ "}.toc-details summary:hover{color:var(--accent)}.toc-details .toc-list{padding:2px 0 12px}@media(max-width:899px){html,body{font-size:12px}.top-bar{padding:5px 10px;font-size:10.5px}.top-bar .win-tags,.top-bar .win-log,.top-bar .win-search{display:none}.main{display:flex;flex-direction:column;padding:6px;gap:6px}.left-col,.main-home .right-col{display:contents}.hero-pane{order:1}.activity-pane{order:2}.articles-pane{order:3;flex:none}.log-pane{order:4}.tags-pane{order:5}.main-home .tags-pane{flex:none}.pane-header{padding:4px 10px;font-size:10.5px}.pane-body{padding:10px 12px}.hero-title{font-size:18px}.hero-tagline{font-size:13px}.hero-about{font-size:11px}.article-row{grid-template-columns:44px 1fr;gap:8px;padding:5px 0}.article-date{font-size:11px}.article-link{font-size:13px}.article-tags{grid-column:2 / 3;font-size:11px;margin-top:2px}.articles-pane .article-row{grid-template-columns:44px auto 1fr}.articles-pane .article-tags{grid-column:3 / 4}.log-teaser{grid-template-columns:44px auto 1fr;gap:8px;padding:5px 0}.log-teaser-date{font-size:11px}.log-teaser-body{font-size:13px}.log-teaser-tags{grid-column:3 / 4;font-size:11px;margin-top:2px}.activity-chart{font-size:11px}.bottom-bar{padding:4px 10px;font-size:10.5px}.article-main{padding:4px}.article-pane .pane-body{padding:22px 18px 32px}.article-title{font-size:22px;margin-bottom:22px}.article-body{font-size:14.5px;line-height:1.8}.article-body h2{font-size:17px}.article-body h3{font-size:15.5px}.article-body pre{font-size:12px;padding:12px 14px}.article-meta{flex-wrap:wrap}.article-meta .rule{display:none}.article-footer{margin-top:36px;flex-wrap:wrap}.entry-card{grid-template-columns:38px 1fr;gap:10px}.log-nav{flex-direction:column;gap:14px}.log-nav-next{text-align:left}.article-layout.has-toc{display:block}.toc-rail{display:none}.toc-details{display:block}}
