#theme-toggle{position:relative;width:50px;height:50px;border:3px solid var(--c-border);border-radius:50%;background:var(--c-bg-elevated);color:var(--c-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.4,0,.2,1)}#theme-toggle .auto-badge{position:absolute;top:-6px;right:-6px;padding:2px 6px;font-size:.6rem;font-weight:700;letter-spacing:.02em;color:var(--color-bg);background:var(--color-text);border-radius:999px;opacity:0;transform:scale(.9);transition:opacity .2s ease,transform .2s ease;pointer-events:none}#theme-toggle[data-theme=system] .auto-badge{opacity:1;transform:scale(1)}#theme-toggle:hover{background:var(--gradient-primary);color:#fff;transform:rotate(180deg) scale(1.15);border-color:var(--c-border-strong)}#theme-toggle:focus-visible{outline:4px solid var(--c-accent-1);outline-offset:4px}#theme-toggle:active{transform:scale(.9)}#theme-toggle .sun-icon{display:block}#theme-toggle .moon-icon{display:none}:root.dark #theme-toggle .sun-icon{display:none}:root.dark #theme-toggle .moon-icon{display:block}#theme-toggle svg{transition:transform .4s ease}@media(max-width:640px){#theme-toggle{width:44px;height:44px}#theme-toggle svg{width:20px;height:20px}}@media(prefers-reduced-motion:reduce){#theme-toggle,#theme-toggle svg{transition:none!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", Helvetica, Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;--color-bg: #edf2f7;--color-bg-secondary: #ffffff;--color-text: #1a1a1a;--color-text-secondary: #65717b;--color-text-tertiary: #9ca3af;--color-accent: #3ea8ff;--color-accent-hover: #0f83fd;--color-accent-light: rgba(62, 168, 255, .1);--color-border: #d6e3ed;--shadow: 0 2px 4px rgb(0 0 0 / .06);--shadow-card: 0 2px 4px rgb(0 0 0 / .08), 0 0 0 1px rgb(0 0 0 / .02)}:root.dark{--color-bg: #0f172a;--color-bg-secondary: #1e293b;--color-text: #e2e8f0;--color-text-secondary: #94a3b8;--color-text-tertiary: #64748b;--color-accent: #3ea8ff;--color-accent-hover: #60b8ff;--color-accent-light: rgba(62, 168, 255, .15);--color-border: #334155;--shadow: 0 2px 4px rgb(0 0 0 / .2);--shadow-card: 0 2px 4px rgb(0 0 0 / .3), 0 0 0 1px rgb(0 0 0 / .1)}html{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{transition:background-color .3s,color .3s}.site-wrapper{min-height:100vh;display:flex;flex-direction:column}.site-header{position:sticky;top:0;z-index:50;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000000a}.header-content{max-width:1280px;margin:0 auto;padding:0 1.5rem;height:56px;display:flex;justify-content:space-between;align-items:center}.site-logo{display:flex;align-items:center;gap:.625rem;text-decoration:none;color:var(--color-text)}.site-title{font-size:1.25rem;font-weight:800;letter-spacing:-.01em}.header-logo{height:36px;width:36px;display:block;border-radius:8px}.site-nav{display:flex;align-items:center;gap:1.25rem}.nav-link{color:var(--color-text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;padding:.375rem .75rem;border-radius:8px;transition:color .2s,background-color .2s}.nav-link:hover{color:var(--color-text);background:var(--color-bg)}.nav-search-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--color-text-secondary);transition:color .2s,background-color .2s;text-decoration:none}.nav-search-btn:hover{color:var(--color-text);background:var(--color-bg)}.site-main{max-width:1280px;margin:0 auto;padding:2rem 1.5rem;display:grid;grid-template-columns:1fr 300px;gap:3rem;flex:1}.site-main.is-article{display:block;max-width:100%;padding:0}@media(max-width:1024px){.site-main{grid-template-columns:1fr;gap:3rem}}.main-content{min-width:0}.article-layout{display:flex;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;gap:0}@media(max-width:1100px){.article-layout{max-width:860px}.article-sidebar{display:none}}@media(max-width:860px){.article-layout{padding:0}.article-actions{display:none}}.article-actions{width:50px;flex-shrink:0;margin-right:30px}.actions-sticky{position:sticky;top:80px;display:flex;flex-direction:column;align-items:center;gap:.375rem;padding-top:1rem}.action-divider{width:24px;height:1px;background:var(--color-border);margin:.25rem 0}.action-btn{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-tertiary);cursor:pointer;transition:all .2s ease}.action-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-light)}.action-btn.copied{color:#10b981;border-color:#10b981;background:#10b9811a}.article-center{flex:1;min-width:0;max-width:790px}.article-sidebar{width:300px;flex-shrink:0;margin-left:30px}.sidebar-author-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:1.25rem}.sidebar-author-inner{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.sidebar-author-avatar{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.sidebar-author-info{flex:1;min-width:0}.sidebar-author-name{display:block;font-size:.9375rem;font-weight:700;color:var(--color-text);margin-bottom:.375rem}.sidebar-author-social{display:flex;gap:.5rem;align-items:center}.sidebar-social-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);transition:color .2s}.sidebar-social-icon:hover{color:var(--color-accent)}.sidebar-author-bio{font-size:.8125rem;line-height:1.5;color:var(--color-text-secondary);margin:0}.sidebar-author-details{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.375rem}.sidebar-author-detail{font-size:.8125rem;line-height:1.5;color:var(--color-text-secondary);margin:0}.sidebar-author-detail strong{color:var(--color-text)}.article-sidebar-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-top:1.25rem}.article-sidebar-section .sidebar-heading{font-size:.875rem}.article-sidebar-section .sidebar-posts{margin-top:.75rem}.toc-sticky{position:sticky;top:80px}.toc{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.toc-title{font-size:.875rem;font-weight:700;color:var(--color-text);margin-bottom:.75rem}.toc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.toc-item{border-left:2px solid var(--color-border)}.toc-item-h3{padding-left:.75rem}.toc-link{display:block;padding:.3rem 0 .3rem .875rem;font-size:.8125rem;line-height:1.4;color:var(--color-text-secondary);text-decoration:none;transition:color .15s,border-color .15s}.toc-link:hover,.toc-link.is-active{color:var(--color-accent)}.toc-item:has(.toc-link.is-active){border-left-color:var(--color-accent)}.article{background:var(--color-bg-secondary);border-radius:12px;box-shadow:var(--shadow-card);padding:3rem 3.5rem;overflow:hidden}@media(max-width:860px){.article{padding:2rem 1.25rem;border-radius:0;box-shadow:none}}.article-header{margin-bottom:2.5rem}.article-date{display:inline-block;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.75rem}.article-title{font-size:1.875rem;font-weight:800;line-height:1.3;color:var(--color-text);margin-bottom:1.25rem}.article-hero-image{width:100%;margin-bottom:1.5rem;border-radius:8px;overflow:hidden;aspect-ratio:16 / 9;max-height:400px}.article-hero-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.article-body{font-size:1rem;line-height:1.8;color:var(--color-text)}.article-body h2{font-size:1.625rem;font-weight:700;margin-top:2.5rem;margin-bottom:1rem;line-height:1.4;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.article-body h3{font-size:1.375rem;font-weight:700;margin-top:2rem;margin-bottom:.75rem;line-height:1.4}.article-body p{margin-bottom:1.25rem}.article-body a{color:var(--color-accent);text-decoration:underline;transition:color .2s}.article-body a:hover{color:var(--color-accent-hover)}.article-body ul,.article-body ol{margin-bottom:1.25rem;padding-left:1.75rem;list-style-position:outside}.article-body ul{list-style-type:disc}.article-body ol{list-style-type:decimal}.article-body li{margin-bottom:.5rem}.article-body li::marker{color:var(--color-accent)}.article-body blockquote{position:relative;margin:2.25rem 0;padding:.25rem 0 .25rem 1.75rem;border-left:4px solid var(--color-text);background:transparent;border-radius:0;color:var(--color-text)}.article-body blockquote:before{content:"QUOTE";display:block;font-size:.75rem;font-weight:600;letter-spacing:.18em;color:var(--color-text-tertiary);margin-bottom:.85rem}.article-body blockquote>p{font-size:1.0625rem;line-height:1.9;margin:0 0 .5rem;color:var(--color-text)}.article-body blockquote>:last-child{margin-bottom:0}.article-body blockquote footer,.article-body blockquote cite{display:block;margin-top:.9rem;font-size:.875rem;color:var(--color-text-tertiary);font-style:normal}.article-body blockquote footer:before,.article-body blockquote cite:before{content:"— "}.article-body code{background:var(--color-bg);padding:.2em .4em;border-radius:4px;font-size:.875em;font-family:var(--font-mono);border:1px solid var(--color-border)}.article-body pre{background:#1e293b;color:#e2e8f0;padding:1.25rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0}:root.dark .article-body pre{background:#0f172a}.article-body pre code{background:transparent;padding:0;border:none;color:inherit}.article-body img{max-width:100%;height:auto;border-radius:.5rem;margin:1.5rem 0}.article-body table{width:100%;border-collapse:collapse;margin:1.5rem 0}.article-body th,.article-body td{padding:.75rem;border:1px solid var(--color-border);text-align:left}.article-body th{background:var(--color-bg-secondary);font-weight:600}.site-sidebar{display:flex;flex-direction:column;gap:2.5rem}.sidebar-section{display:flex;flex-direction:column;gap:1rem}.sidebar-heading{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.sidebar-posts{list-style:none;display:flex;flex-direction:column}.sidebar-posts li{border-bottom:1px solid var(--color-border)}.sidebar-posts li:last-child{border-bottom:none}.sidebar-post-link{display:flex;align-items:center;gap:1rem;padding:.75rem 0;text-decoration:none;color:var(--color-text);transition:color .2s}.sidebar-post-link:hover{color:var(--color-accent)}.sidebar-post-link:hover .sidebar-post-image img{transform:scale(1.05)}.sidebar-post-image{width:64px;height:64px;flex-shrink:0;border-radius:8px;overflow:hidden;background:var(--color-bg)}.sidebar-post-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.sidebar-post-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.25rem}.sidebar-post-title{font-size:.875rem;font-weight:500;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.sidebar-post-date{font-size:.75rem;color:var(--color-text-tertiary);font-family:var(--font-mono);white-space:nowrap}.sidebar-categories{list-style:none;display:flex;flex-direction:column;gap:.5rem}.category-link{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.875rem;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:8px;text-decoration:none;transition:all .2s ease}.category-link:hover{color:var(--color-accent);background:var(--color-accent-light)}.category-link .category-name{font-weight:500}.category-link .count{font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);background:var(--color-bg);border-radius:9999px;min-width:1.5rem;height:1.375rem;display:inline-flex;align-items:center;justify-content:center;padding:0 .4rem;transition:all .2s ease}.category-link:hover .count{color:var(--color-accent);background:var(--color-accent-light)}.sidebar-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}.tag-link{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.8125rem;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:6px;text-decoration:none;transition:all .2s ease}.tag-link:hover{color:var(--color-accent);background:var(--color-accent-light)}.tag-link .tag-count{font-size:.75rem;opacity:.8}.sidebar-heading-row{display:flex;align-items:center;justify-content:space-between}.sidebar-more-link{font-size:.75rem;color:var(--color-accent);text-decoration:none;white-space:nowrap}.sidebar-more-link:hover{text-decoration:underline}.sidebar-post-no-image{display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--color-bg)}.sidebar-tags-more{margin-top:.5rem;text-align:right}.tags-more-link{font-size:.875rem;color:var(--color-accent);text-decoration:none}.tags-more-link:hover{text-decoration:underline}.site-footer{margin-top:4rem;padding:3rem 1.5rem 2rem;border-top:1px solid var(--color-border);background:var(--color-bg-secondary);box-shadow:0 -1px 3px #00000005}.footer-content{max-width:1280px;margin:0 auto}.footer-grid{display:grid;grid-template-columns:minmax(220px,280px) 1fr;gap:2.5rem;align-items:start}.footer-section{display:flex;flex-direction:column;gap:.875rem}.footer-heading{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.footer-contact-link{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:.6rem .95rem;border:1px solid var(--color-border);border-radius:.5rem;background:var(--color-bg);color:var(--color-text);text-decoration:none;font-size:.9rem;font-weight:500;transition:border-color .2s,color .2s}.footer-contact-link:hover{color:var(--color-accent);border-color:var(--color-accent)}.footer-links{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.6rem 1.2rem}.footer-link{display:inline-block;color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s}.footer-link:hover{color:var(--color-accent)}.footer-meta{margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--color-border);text-align:center}.footer-meta p{font-size:.875rem;color:var(--color-text-tertiary);margin-bottom:.5rem}.footer-note{font-size:.8125rem}.footer-legal{margin-top:.5rem}.footer-legal-link{font-size:.8125rem;color:var(--c-text-sub);text-decoration:underline;opacity:.75}.footer-legal-link:hover{opacity:1}@media(max-width:768px){.site-footer{padding:2.5rem 1.25rem 1.75rem}.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-links{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.popular-toc{margin-bottom:1.25rem}.popular-posts-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.popular-post-item{border-left:2px solid var(--color-border)}.popular-post-link{display:flex;align-items:flex-start;gap:.625rem;padding:.375rem 0 .375rem .875rem;font-size:.8125rem;line-height:1.4;color:var(--color-text-secondary);text-decoration:none;transition:color .15s}.popular-post-link:hover{color:var(--color-accent)}.popular-post-rank{flex-shrink:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;color:var(--color-accent);background:var(--color-accent-light);border-radius:50%;margin-top:.1rem}.popular-post-title-text{flex:1;min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.popular-post-rank-inline{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:1.25rem;height:1.25rem;font-size:.6875rem;font-weight:700;color:var(--color-accent);background:var(--color-accent-light);border-radius:50%;margin-right:.375rem}.popular-posts-loading{font-size:.8125rem;color:var(--color-text-tertiary)}.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:700px){.featured-grid{grid-template-columns:1fr}}.featured-card{border-radius:10px;overflow:hidden;background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:box-shadow .2s,transform .2s}.featured-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.featured-card-link{display:block;text-decoration:none;color:inherit}.featured-card-image{aspect-ratio:16 / 9;overflow:hidden;background:var(--color-bg)}.featured-card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.featured-card:hover .featured-card-image img{transform:scale(1.04)}.featured-card-placeholder{width:100%;height:100%;background:var(--color-bg)}.featured-card-body{padding:.75rem}.featured-card-title{font-size:.875rem;font-weight:700;line-height:1.4;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.featured-card:hover .featured-card-title{color:var(--color-accent)}
