*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #eae4db;--surface: #ffffff;--border: #e0d9d1;--text: #333333;--muted: #888888;--light-muted: #bbbbbb;--accent: #5b9ec9;--accent-hover: #4a8db8;--tag-bg: #7ab0c8;--tag-text: #ffffff;--img-bg: #d6d1cb;--toc-bg: #aecde0;--font-sans: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans JP", sans-serif;--font-serif: "Hiragino Mincho ProN", "Hiragino Mincho Pro", "Yu Mincho", YuMincho, "ＭＳ 明朝", serif;--radius: 4px;--shadow: 0 2px 8px rgba(0,0,0,.07)}html{font-size:16px}body{font-family:var(--font-sans);background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg width='24' height='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 4v16M4 12h16' stroke='%23ccc5ba' stroke-width='0.8'/%3E%3C/svg%3E");background-size:24px 24px;color:var(--text);line-height:1.75;min-height:100dvh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}.site-header{background:var(--surface);text-align:center;padding-top:1.25rem;border-bottom:1px solid var(--border)}.site-header .tagline{font-size:.75rem;color:var(--muted);letter-spacing:.06em;margin-bottom:.75rem}.site-header .site-title{display:block;font-family:var(--font-serif);font-size:2rem;font-weight:400;letter-spacing:.08em;color:var(--text);line-height:1.3;margin-bottom:.5rem}.title-dots{color:var(--light-muted);letter-spacing:.35em;font-size:.9rem;margin-bottom:1rem}.site-header nav{display:flex;justify-content:center;gap:2.5rem;padding:.75rem 1rem;font-size:.9rem}.site-header nav a{color:var(--text);transition:color .15s}.site-header nav a:hover{color:var(--accent)}.site-body{flex:1;padding-block:2rem}.container{max-width:1100px;margin-inline:auto;padding-inline:1.25rem}.two-col{display:grid;grid-template-columns:1fr 280px;gap:1.5rem;align-items:start}.post-cards{display:flex;flex-direction:column;gap:0}.post-card{background:var(--surface);box-shadow:var(--shadow);margin-bottom:1.25rem;display:grid;grid-template-columns:240px 1fr;min-height:160px;border-radius:var(--radius);overflow:hidden}.card-thumb{position:relative;background:var(--img-bg);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.75rem;letter-spacing:.08em;flex-shrink:0}.card-tag-badge{position:absolute;top:.5rem;left:.5rem;background:var(--tag-bg);color:var(--tag-text);font-size:.7rem;padding:.2em .6em;border-radius:2px;font-weight:500;line-height:1.5;white-space:nowrap}.card-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.card-title{font-size:1.0625rem;font-weight:700;line-height:1.45}.card-title a:hover{color:var(--accent)}.card-excerpt{font-size:.85rem;color:var(--muted);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.card-footer{display:flex;justify-content:flex-end;align-items:center;font-size:.78rem;color:var(--muted);gap:.4rem}.card-date:before{content:"○ "}.tag-list{display:flex;flex-wrap:wrap;gap:.375rem}.tag{display:inline-block;background:var(--tag-bg);color:var(--tag-text);font-size:.72rem;font-weight:500;padding:.2em .65em;border-radius:2px;line-height:1.6;transition:opacity .15s}.tag:hover{opacity:.8}.page-heading{font-size:1rem;font-weight:700;padding-bottom:.5rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.author-banner{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.5rem;display:flex;gap:1.25rem;align-items:flex-start;margin-bottom:2rem;position:relative;overflow:hidden}.author-banner:after{content:"";position:absolute;right:-40px;bottom:-40px;width:160px;height:160px;background:#d8e8f0;border-radius:50%;opacity:.5}.author-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--border);flex-shrink:0}.author-avatar-placeholder{width:72px;height:72px;border-radius:50%;background:var(--img-bg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;border:3px solid var(--border)}.author-info{flex:1}.author-name{font-weight:700;margin-bottom:.35rem}.author-bio{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:.75rem}.author-icons{display:flex;gap:.5rem}.author-icon{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.75rem;transition:border-color .15s,color .15s}.author-icon:hover{border-color:var(--accent);color:var(--accent)}.article-header{border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1.25rem}.article-title{font-size:1.375rem;font-weight:700;line-height:1.45;letter-spacing:-.01em}.article-meta{display:flex;justify-content:flex-end;font-size:.8rem;color:var(--muted);margin-top:.75rem}.article-meta time:before{content:"○ "}.toc{background:var(--surface);border-radius:var(--radius);overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow)}.toc-header{background:var(--toc-bg);color:var(--surface);padding:.6rem 1rem;font-size:.875rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.toc-list{list-style:none;padding:.5rem 0}.toc-list li{border-bottom:1px dashed var(--border)}.toc-list li:last-child{border-bottom:none}.toc-list a{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.875rem;transition:background .15s}.toc-list a:hover{background:#f0f8ff;color:var(--accent)}.toc-num{min-width:22px;height:22px;border-radius:50%;background:var(--toc-bg);color:var(--surface);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.article-body{font-size:.9375rem;line-height:1.85}.article-body>*+*{margin-top:1.25em}.article-body h2{font-size:1.25rem;font-weight:700;padding:.5em 0;border-bottom:2px solid var(--border);margin-top:2.5em}.article-body h3{font-size:1.0625rem;font-weight:700;padding-left:.75em;border-left:3px solid var(--accent);margin-top:2em}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.article-body a:hover{opacity:.8}.article-body ul,.article-body ol{padding-left:1.75rem}.article-body li+li{margin-top:.3em}.article-body blockquote{border-left:3px solid var(--toc-bg);padding:.5em 1em;background:#f4f9fc;color:var(--muted);border-radius:0 var(--radius) var(--radius) 0}.article-body img{max-width:100%;height:auto;border-radius:var(--radius);display:block}.article-body code{font-size:.875em;background:#f0f0f0;padding:.15em .4em;border-radius:3px;font-family:SFMono-Regular,Consolas,monospace}.article-body pre{background:#f5f5f5;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;overflow-x:auto;font-size:.875rem;line-height:1.6}.article-body pre code{background:none;padding:0}.article-body table{width:100%;border-collapse:collapse;font-size:.9rem}.article-body th,.article-body td{border:1px solid var(--border);padding:.5rem .75rem}.article-body th{background:#f7f7f7;font-weight:600}.article-footer{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.back-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--muted);font-size:.85rem;margin-bottom:1.5rem;transition:color .15s}.back-link:hover{color:var(--accent)}.sidebar{display:flex;flex-direction:column;gap:1.25rem}.sidebar-widget{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.widget-dots{height:10px;background-image:radial-gradient(circle,#c0b8ae 1.5px,transparent 1.5px);background-size:10px 10px;background-repeat:repeat-x;background-position:0 50%}.widget-body{padding:1rem}.search-box{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.search-box input{flex:1;border:none;padding:.5rem .75rem;font-size:.85rem;outline:none;background:var(--surface);color:var(--text)}.search-box button{background:var(--accent);border:none;padding:0 .75rem;cursor:pointer;color:#fff;display:flex;align-items:center;transition:background .15s}.search-box button:hover{background:var(--accent-hover)}.profile-widget{text-align:center;padding:1.25rem 1rem}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:.75rem;border:3px solid var(--border)}.profile-avatar-placeholder{width:80px;height:80px;border-radius:50%;background:var(--img-bg);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto .75rem;border:3px solid var(--border)}.profile-name{font-weight:700;margin-bottom:.5rem}.profile-bio{font-size:.8rem;color:var(--muted);line-height:1.65;margin-bottom:.875rem;text-align:left}.profile-icons{display:flex;justify-content:center;gap:.5rem}.profile-icon{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.7rem;transition:border-color .15s,color .15s}.profile-icon:hover{border-color:var(--accent);color:var(--accent)}.widget-title{font-size:.9375rem;font-weight:700;text-align:center;padding:.75rem;border-bottom:1px solid var(--border)}.recent-list{list-style:none}.recent-item{display:grid;grid-template-columns:60px 1fr;gap:.625rem;padding:.75rem .875rem;border-bottom:1px solid var(--border)}.recent-item:last-child{border-bottom:none}.recent-thumb{background:var(--img-bg);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--muted);letter-spacing:0;aspect-ratio:16/10;border-radius:2px;line-height:1.2;text-align:center}.recent-title{font-size:.8rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-title a:hover{color:var(--accent)}.site-footer{background:var(--surface);border-top:1px solid var(--border);text-align:center;padding:1.25rem;font-size:.8rem;color:var(--muted)}.empty{color:var(--muted);font-size:.9rem;padding-block:2rem}@media(max-width:768px){.two-col{grid-template-columns:1fr}.site-header .site-title{font-size:1.5rem}.post-card{grid-template-columns:1fr}.card-thumb{aspect-ratio:16/7}}
