*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f0f0f0;--header-bg: #1a1a1a;--card-bg: #ffffff;--text: #333333;--text-muted: #888888;--border: #e0e0e0;--accent: #1a1a1a;--max-width: 1100px}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,Yu Gothic,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;font-size:16px}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}.site-header{background:var(--header-bg);color:#fff;padding:0 1rem;position:sticky;top:0;z-index:100}.header-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px}.site-title{font-size:1.2rem;font-weight:700;letter-spacing:.05em;color:#fff}.site-nav{display:flex;gap:1.5rem;list-style:none}.site-nav a{color:#bbb;font-size:.875rem;transition:color .15s}.site-nav a:hover{color:#fff}.page-wrapper{max-width:var(--max-width);margin:2rem auto;padding:0 1rem;display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.post-card{background:var(--card-bg);border-radius:4px;overflow:hidden;box-shadow:0 1px 3px #00000014;transition:box-shadow .2s}.post-card:hover{box-shadow:0 4px 12px #0000001f}.post-card-thumb{aspect-ratio:16 / 9;overflow:hidden}.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.post-card:hover .post-card-thumb img{transform:scale(1.03)}.post-card-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#d8d8d8,#ebebeb);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#999;letter-spacing:.05em}.post-card-body{padding:.875rem 1rem 1rem}.post-card-category{display:inline-block;font-size:.7rem;background:var(--accent);color:#fff;padding:2px 8px;border-radius:2px;margin-bottom:.5rem;letter-spacing:.05em}.post-card-title{font-size:.9rem;font-weight:700;line-height:1.55;margin-bottom:.4rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card-title a:hover{text-decoration:underline}.post-card-meta{font-size:.75rem;color:var(--text-muted)}.sidebar{display:flex;flex-direction:column;gap:1.25rem}.sidebar-widget{background:var(--card-bg);border-radius:4px;overflow:hidden;box-shadow:0 1px 3px #00000014}.sidebar-widget-title{background:var(--accent);color:#fff;padding:.55rem 1rem;font-size:.8rem;font-weight:700;letter-spacing:.05em}.sidebar-widget-body{padding:1rem}.profile-text{font-size:.85rem;line-height:1.7;color:var(--text)}.category-list{list-style:none;display:flex;flex-direction:column}.category-list li a{display:flex;justify-content:space-between;font-size:.875rem;padding:.45rem 0;border-bottom:1px solid var(--border);transition:color .15s}.category-list li:last-child a{border-bottom:none}.category-list li a:hover{color:#555}.category-count{color:var(--text-muted);font-size:.8rem}.recent-posts-list{list-style:none;display:flex;flex-direction:column;gap:.875rem}.recent-post-item a{font-size:.85rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-post-item a:hover{text-decoration:underline}.recent-post-date{font-size:.75rem;color:var(--text-muted);margin-top:3px}.affiliate-banner{background:#f8f8f8;border:1px dashed #ccc;border-radius:4px;padding:1.25rem 1rem;text-align:center;font-size:.8rem;color:#aaa;min-height:100px;display:flex;align-items:center;justify-content:center}.page-title-bar{max-width:var(--max-width);margin:1.5rem auto 0;padding:0 1rem}.page-title{font-size:1.2rem;font-weight:700;padding-bottom:.6rem;border-bottom:3px solid var(--accent);display:inline-block}.article-wrapper{max-width:var(--max-width);margin:2rem auto;padding:0 1rem;display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}.article-main{background:var(--card-bg);border-radius:4px;box-shadow:0 1px 3px #00000014;padding:2rem 2.25rem}.article-category{display:inline-block;font-size:.7rem;background:var(--accent);color:#fff;padding:2px 10px;border-radius:2px;margin-bottom:.75rem;letter-spacing:.05em}.article-title{font-size:1.65rem;font-weight:700;line-height:1.45;margin-bottom:.75rem}.article-meta{font-size:.8rem;color:var(--text-muted);padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.75rem}.article-body{line-height:1.9}.article-body h2{font-size:1.3rem;font-weight:700;margin:2.25rem 0 1rem;padding:.5rem 0 .5rem .875rem;border-left:4px solid var(--accent);background:#f8f8f8}.article-body h3{font-size:1.1rem;font-weight:700;margin:1.75rem 0 .75rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.article-body p{margin-bottom:1.25rem}.article-body ul,.article-body ol{margin:.75rem 0 1.25rem 1.5rem}.article-body li{margin-bottom:.4rem}.article-body a{color:#1a1a1a;text-decoration:underline;text-underline-offset:2px}.article-body a:hover{opacity:.7}.article-body img{margin:1.5rem auto;border-radius:4px;box-shadow:0 2px 8px #0000001a}.article-body blockquote{border-left:4px solid #ddd;padding:.75rem 1rem;margin:1.25rem 0;color:#666;background:#f9f9f9;border-radius:0 4px 4px 0}.article-body code{background:#f0f0f0;padding:.15em .45em;border-radius:3px;font-size:.875em;font-family:SFMono-Regular,Consolas,Menlo,monospace}.article-body pre{background:#1a1a1a;color:#eee;padding:1.25rem;border-radius:4px;overflow-x:auto;margin:1.25rem 0}.article-body pre code{background:none;padding:0;color:inherit;font-size:.875rem}.article-tags{margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;gap:.5rem;flex-wrap:wrap}.tag{font-size:.8rem;background:#f0f0f0;border:1px solid #ddd;padding:3px 12px;border-radius:20px;color:var(--text-muted)}.site-footer{background:var(--header-bg);color:#777;text-align:center;padding:1.5rem 1rem;margin-top:3rem;font-size:.8rem}@media(max-width:768px){.page-wrapper,.article-wrapper{grid-template-columns:1fr;margin:1.25rem auto}.posts-grid{grid-template-columns:1fr}.site-nav{display:none}.article-title{font-size:1.3rem}.article-main{padding:1.25rem 1rem}}
