:root{--slate: #626d71;--ceramic: #cdcdc0;--latte: #ddbc95;--coffee: #b38867;--bg: #f4f2ec;--surface: #ffffff;--surface-2: #efece3;--border: #dcd9cf;--border-strong: #cdcdc0;--text: #33383b;--text-muted: #626d71;--text-faint: #9b968b;--brand: #b38867;--brand-ink: #95684a;--accent: #ddbc95;--header-bg: #626d71;--header-fg: #f7f6f1;--max-width: 1560px;--read-width: 860px;--gap: 2.25rem;--radius: 6px;--radius-sm: 4px;--shadow-sm: 0 1px 2px rgba(60, 55, 45, .06);--shadow: 0 2px 4px rgba(60, 55, 45, .06), 0 10px 24px rgba(60, 55, 45, .08);--font-sans: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Yu Gothic", Meiryo, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "SFMono-Regular", "Consolas", "Liberation Mono", Menlo, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--brand-ink);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}.site-header{border-bottom:3px solid var(--coffee)}.masthead{background:var(--header-bg);color:var(--header-fg)}.masthead__inner{max-width:var(--max-width);margin:0 auto;padding:.85rem 1.25rem;display:flex;align-items:center;gap:1rem}.brand{display:flex;align-items:center;gap:.6rem;color:var(--header-fg);font-weight:800}.brand:hover{text-decoration:none}.brand__mark{width:34px;height:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:4px;border-radius:6px;background:linear-gradient(135deg,var(--coffee),var(--latte))}.brand__mark span{border-radius:1.5px;background:#ffffffe6}.brand__mark span:nth-child(2n){background:#ffffff8c}.brand__title{font-size:1.4rem;letter-spacing:.02em}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.25rem}.narrow{max-width:var(--read-width);margin:0 auto}.post-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem 1.1rem}@media(min-width:540px){.post-list{grid-template-columns:repeat(3,1fr)}}@media(min-width:820px){.post-list{grid-template-columns:repeat(4,1fr)}}@media(min-width:1100px){.post-list{grid-template-columns:repeat(5,1fr)}}.tile{display:flex;flex-direction:column;color:var(--text)}.tile:hover{text-decoration:none}.tile__thumb{position:relative;aspect-ratio:16 / 9;border-radius:var(--radius);overflow:hidden;background:var(--surface-2);border:1px solid var(--border)}.tile__thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.tile:hover .tile__thumb img{transform:scale(1.045)}.tile__emoji{width:100%;height:100%;display:grid;place-items:center;font-size:3.4rem;color:#fff}.tile__title{margin:.55rem 0 .3rem;font-size:.95rem;line-height:1.45;font-weight:700;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tile:hover .tile__title{color:var(--brand-ink)}.tile__meta{font-size:.74rem;color:var(--text-faint)}.author-badge{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.78rem}.author-badge:hover{text-decoration:none}.author-badge__avatar{display:grid;place-items:center;width:1.45em;height:1.45em;border-radius:50%;font-size:.8em;color:#fff;flex:none}.author-badge__name{font-weight:700;color:var(--text-muted)}.author-badge:hover .author-badge__name{color:var(--coffee)}.author-badge--lg{font-size:.95rem}.author-badge--lg .author-badge__avatar{width:1.9em;height:1.9em}.tag-row{display:flex;flex-wrap:wrap;gap:.4rem}.tag{display:inline-flex;align-items:center;gap:.25rem;padding:.16rem .6rem;font-size:.78rem;font-weight:600;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.tag:hover{background:color-mix(in srgb,var(--latte) 45%,var(--surface));color:var(--brand-ink);border-color:var(--latte);text-decoration:none}.tag--active{background:var(--coffee);color:#fff;border-color:var(--coffee)}.tag--active:hover{background:var(--brand-ink);color:#fff}.tag__count{font-size:.7rem;opacity:.7}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.05rem 1.15rem;margin-bottom:1.25rem}.panel__title{margin:0 0 .85rem;padding-bottom:.5rem;border-bottom:2px solid var(--coffee);font-size:.92rem;font-weight:800;color:var(--slate)}.mini-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.mini-list li{border-bottom:1px dashed var(--border)}.mini-list li:last-child{border-bottom:none}.mini-item{display:flex;gap:.6rem;padding:.6rem 0;align-items:flex-start}.mini-item:hover{text-decoration:none}.mini-item__emoji{flex:none;width:34px;height:34px;display:grid;place-items:center;font-size:1.1rem;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.mini-item__title{font-size:.85rem;font-weight:600;color:var(--text);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mini-item:hover .mini-item__title{color:var(--coffee)}.mini-item__date{font-size:.72rem;color:var(--text-faint)}.cat-list{list-style:none;margin:0;padding:0}.cat-list a{display:flex;justify-content:space-between;padding:.5rem .2rem;border-bottom:1px dashed var(--border);color:var(--text);font-weight:600;font-size:.9rem}.cat-list a:hover{color:var(--coffee);text-decoration:none}.cat-list a:last-child{border-bottom:none}.cat-list .count{color:var(--text-faint);font-weight:500}.tagcloud{background:var(--surface-2);border-top:1px solid var(--border)}.tagcloud__inner{max-width:var(--max-width);margin:0 auto;padding:2.25rem 1.25rem}.tagcloud__title{margin:0 0 1rem;padding-left:.7rem;border-left:5px solid var(--coffee);font-size:1.15rem}.tagcloud .tag{background:var(--surface)}.page-title{font-size:1.5rem;margin:.4rem 0 .25rem}.page-lead{color:var(--text-muted);margin:0 0 1.5rem;font-size:.92rem}.breadcrumb{font-size:.8rem;color:var(--text-faint);margin-bottom:.5rem}.breadcrumb a{color:var(--text-muted)}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:2rem 0 1rem;padding-left:.7rem;border-left:5px solid var(--coffee)}.section-head h2{margin:0;font-size:1.15rem}.category-pill{display:inline-flex;align-items:center;padding:.1rem .55rem;border-radius:var(--radius-sm);font-size:.74rem;font-weight:700;color:#fff;background:var(--slate)}.category-pill[data-category=personal]{background:var(--coffee)}.article{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem clamp(1.25rem,3vw,2.5rem)}.article__header{border-bottom:1px solid var(--border);padding-bottom:1.1rem;margin-bottom:1.4rem}.article__title{font-size:clamp(1.45rem,3.5vw,1.95rem);line-height:1.4;margin:.6rem 0 .8rem}.article__meta{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;color:var(--text-faint);font-size:.83rem}.prose{font-size:1.02rem}.prose h2{margin-top:2rem;padding:.3rem 0 .3rem .7rem;border-left:5px solid var(--latte);background:var(--surface-2);font-size:1.3rem}.prose h3{margin-top:1.6rem;font-size:1.1rem}.prose p,.prose ul,.prose ol{margin:1rem 0}.prose ul,.prose ol{padding-left:1.4rem}.prose li{margin:.3rem 0}.prose blockquote{margin:1.2rem 0;padding:.6rem 1rem;border-left:4px solid var(--coffee);background:var(--surface-2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-muted)}.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--surface-2);padding:.12em .4em;border-radius:4px}.prose pre{padding:1rem 1.1rem;border-radius:var(--radius-sm);overflow-x:auto;border:1px solid var(--border)}.prose pre code{background:none;padding:0}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.prose a{text-decoration:underline;text-underline-offset:2px}.byline-box{display:flex;gap:1rem;align-items:flex-start;margin-top:1.5rem;padding:1.1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--member-color, var(--coffee));border-radius:var(--radius)}.byline-box__avatar{flex:none;width:2.6em;height:2.6em;border-radius:50%;display:grid;place-items:center;font-size:1.3em;color:#fff}.member-header{display:flex;gap:1.2rem;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;border-left:4px solid var(--member-color, var(--coffee));margin-bottom:1.4rem}.member-header__avatar{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;font-size:2.3rem;color:#fff;flex:none}.member-header h1{margin:0 0 .2rem;font-size:1.4rem}.member-header__role{color:var(--member-color, var(--brand-ink));font-weight:700;margin:0 0 .4rem}.member-header__bio{margin:0;color:var(--text-muted);font-size:.92rem}.chip-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.55rem}.chip{font-size:.76rem;padding:.15rem .55rem;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.muted{color:var(--text-muted)}.empty{text-align:center;color:var(--text-faint);padding:3rem 1rem;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface)}.list-reset{list-style:none;margin:0;padding:0}.timeline{margin-top:2.5rem;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--member-color, var(--coffee));border-radius:var(--radius);padding:1rem 1.4rem}.timeline>summary{cursor:pointer;font-weight:700;color:var(--slate);list-style:none;padding:.3rem 0}.timeline>summary::-webkit-details-marker{display:none}.timeline>summary:before{content:"▸ ";color:var(--member-color, var(--coffee))}.timeline[open]>summary:before{content:"▾ "}.timeline .prose h2{font-size:1.05rem;margin-top:1.4rem;border-left-color:var(--member-color, var(--latte))}.site-footer{background:var(--slate);color:#f7f6f1d9;font-size:.85rem}.site-footer__inner{max-width:var(--max-width);margin:0 auto;padding:2rem 1.25rem;display:flex;flex-wrap:wrap;gap:1rem 2rem;justify-content:space-between;align-items:center}.site-footer a{color:#f7f6f1eb}.site-footer nav{display:flex;gap:1rem;flex-wrap:wrap}
