:root{--main-width:1200px;--nav-width:1200px}body{font-size:16px}.post-content{line-height:1.85}.post-content p{margin-bottom:1.5em}.post-content pre code{font-size:.9rem;line-height:1.6}.post-content code:not(pre code){padding:.2em .5em;border-radius:4px;font-size:.9em;background-color:var(--code-bg)}.post-content table{display:block;overflow-x:auto;max-width:100%;margin:1.5rem 0;border-collapse:collapse}.post-content th,.post-content td{padding:.75rem 1rem;border:1px solid var(--border);white-space:nowrap}.post-content th{background-color:var(--code-bg);font-weight:600}.post-content ul,.post-content ol{margin-bottom:1.5em;padding-left:1.5em}.post-content li{margin-bottom:.5em;line-height:1.8}.post-content li>ul,.post-content li>ol{margin-top:.5em;margin-bottom:0}.post-content img{margin:1.5rem 0;border-radius:8px}.post-content figure{margin:2rem 0}.post-content strong{font-weight:600}.post-tags a,.post-categories a{position:relative;z-index:2;pointer-events:auto}.post-categories a{display:inline-block;padding:1px 8px;font-size:.8rem;color:#fff;border-radius:4px;text-decoration:none}.post-tags a{display:inline-block;padding:1px 8px;font-size:.8rem;border-radius:4px;text-decoration:none;line-height:1.5}.post-tags a::before{content:"#";color:#6b7280;margin-right:4px}.post-categories-tags{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:10px;flex:1}.entry-footer{display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;margin-top:16px}.post-single .post-meta{margin-top:16px;display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between}article.post-entry,article.tag-entry{display:flex;flex-direction:row !important;align-items:center;gap:32px}article.post-entry figure,article.tag-entry figure{flex:none;width:200px;height:150px;margin:0;padding:16px;border-radius:8px;overflow:hidden;position:relative}article.post-entry figure img,article.tag-entry figure img{width:100%;height:100%;object-fit:cover}article.post-entry .entry-content-wrapper{flex:auto}.post-content li pre code{margin-left:3rem}.post-content li p{margin-bottom:1rem}.category-frontend{background-color:#42a5f5}.category-backend{background-color:#7e57c2}.category-infra{background-color:#00897b}.category-db{background-color:#8bc34a}.category-genai{background-color:#ef5350}.category-column{background-color:#ffb74d}.category-web{background-color:#2980b9}.category-default{background-color:#777}.layout-2col{display:flex;gap:1rem;align-items:flex-start}.post-main{flex:1 1 100%;max-width:calc(100% - 250px);border-right:1px solid #aaa4;padding-right:3rem}.post-toc{width:250px;flex:0 0 250px;position:sticky;top:1rem;font-size:.85rem;line-height:1.6;max-height:calc(100vh - 2rem);overflow-y:auto}.post-toc::-webkit-scrollbar{width:4px}.post-toc::-webkit-scrollbar-track{background:0 0}.post-toc::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:100px;opacity:.5}.post-toc::-webkit-scrollbar-thumb:hover{opacity:.8}.post-toc .toc .inner{margin:0}.post-toc div.toc{padding-left:0;background:0 0;border:none}.post-toc summary{display:none}.post-toc .toc ul{list-style:none;padding-left:0;margin-left:0}.post-toc .toc li{margin:.3rem 0}.post-toc .toc a{text-decoration:none;opacity:.5}.post-toc .toc a.active{font-weight:currentColor;opacity:1}.post-toc .toc a:hover{box-shadow:none;opacity:.75}.post-toc .toc ul ul{margin-left:1rem}.highlight{margin:24px 0 !important}@media(max-width:768px){.post-toc{display:none}.post-main{border-right:none;padding-right:0;max-width:100%}.post-content{line-height:1.9}.post-single h2{font-size:1.4rem;margin-top:2.5rem}.post-single h3{font-size:1.2rem}.post-content pre code{font-size:.85rem}.post-content th,.post-content td{padding:.5rem .75rem;font-size:.9rem}}.post-single h1{font-size:2rem;margin-bottom:24px}.post-single h2{font-size:1.5rem;margin-top:3rem;margin-bottom:1rem;border-bottom:1px solid #aaa4;padding-bottom:.5rem}.post-single h3{font-size:1.3rem;margin-top:2rem;margin-bottom:.75rem}.post-single h4{font-size:1.1rem;margin-top:1.5rem;margin-bottom:.5rem;font-weight:600}.post-content ul li{margin-top:.5rem}.post-single figure{height:300px}.post-single figure img{width:100%;height:100%;object-fit:cover}.post-content blockquote{background:#0001;padding:1rem 1.5rem;margin:1.5rem 0;border-left:4px solid var(--primary);border-radius:0 4px 4px 0}.dark .post-content blockquote{background:#fff1}.post-content blockquote p{margin:0}.post-content ol li{margin:.5rem 0}:root{--header-height:50px}.nav{position:fixed;top:0;left:0;right:0;width:100%;background:var(--theme);z-index:100;border-bottom:1px solid var(--border);max-width:none;line-height:var(--header-height);display:flex;justify-content:space-between;align-items:center}.logo a{font-size:20px}.logo a img,.logo a svg{height:30px;width:30px}#menu a{font-size:14px}.logo-switches{display:flex;align-items:center;margin:auto 12px;flex-shrink:0}button#theme-toggle{font-size:20px}body{padding-top:var(--header-height)}.post-toc{top:calc(var(--header-height) + 1rem);max-height:calc(100vh - var(--header-height) - 2rem)}.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}.post-card{display:flex;flex-direction:column;background:var(--entry);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,8%);transition:transform .2s ease,box-shadow .2s ease;position:relative}.post-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12)}.dark .post-card{box-shadow:0 2px 8px rgba(0,0,0,.3)}.dark .post-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.4)}.post-card-cover{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--code-bg)}.post-card-cover figure{margin:0;padding:0;width:100%;height:100%;border-radius:0}.post-card-cover figure img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.post-card:hover .post-card-cover figure img{transform:scale(1.05)}.post-card-content{display:flex;flex-direction:column;flex:1;padding:16px;position:relative}.post-card-header{margin-bottom:8px}.post-card-title{font-size:1rem;font-weight:600;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;color:var(--primary)}.post-card-summary{flex:1;margin-bottom:12px}.post-card-summary p{font-size:.85rem;line-height:1.6;color:var(--secondary);margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.post-card-footer{margin-top:auto}.post-card-date{font-size:.75rem;color:var(--secondary);opacity:.8}.post-card-link{position:absolute;inset:0;z-index:1}.terms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;list-style:none;padding:0;margin-top:24px}.term-card{background:var(--entry);border-radius:8px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.term-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.term-card a{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;text-decoration:none;color:var(--primary)}.term-name{font-weight:500;font-size:.95rem}.term-count{background:var(--tertiary);color:var(--content);font-size:.8rem;padding:2px 10px;border-radius:12px;font-weight:500}@media(max-width:1024px){.posts-grid{grid-template-columns:repeat(2,1fr);gap:20px}.terms-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.posts-grid{grid-template-columns:1fr;gap:16px}.terms-grid{grid-template-columns:1fr}.post-card-title{font-size:.95rem}.post-card-summary p{font-size:.8rem}.post-card-meta{flex-direction:column;align-items:flex-start;gap:4px}}.post-card-footer{display:flex;flex-direction:row;justify-content:space-between;align-items:flex-end;gap:8px;flex-wrap:wrap}.post-card-meta{display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:wrap}.post-card-categories{display:flex;flex-wrap:wrap;gap:4px}.post-card-category{display:inline-block;padding:2px 8px;font-size:.7rem;color:#fff !important;border-radius:4px;text-decoration:none;position:relative;z-index:2;pointer-events:auto;line-height:1.4}.post-card-category:hover{opacity:.8}.post-card-tags{display:flex;flex-wrap:wrap;gap:4px}.post-card-tag{display:inline-block;padding:2px 6px;font-size:.7rem;color:var(--secondary);background-color:var(--code-bg);border-radius:4px;text-decoration:none;position:relative;z-index:2;pointer-events:auto;line-height:1.4}.post-card-tag:hover{color:var(--primary);background-color:var(--tertiary)}.page-footer nav.pagination{display:flex !important;justify-content:center !important;align-items:center !important;gap:4px !important;flex-wrap:wrap !important;margin-top:2rem !important;padding:1rem 0 !important}.page-footer nav.pagination .pagination-numbers{display:flex !important;align-items:center !important;gap:8px !important}.page-footer nav.pagination .pagination-item{display:inline-flex !important;justify-content:center !important;align-items:center !important;min-width:36px !important;height:36px !important;padding:0 10px !important;border-radius:6px !important;font-size:.9rem !important;font-weight:500 !important;text-decoration:none !important;color:var(--primary) !important;background-color:transparent !important;border:1px solid var(--primary) !important;transition:all .2s ease !important;line-height:1 !important}.page-footer nav.pagination a.pagination-item:hover:not(.pagination-disabled):not(.pagination-current){color:#fff !important;background-color:var(--primary) !important;border-color:var(--primary) !important}.page-footer nav.pagination .pagination-item.pagination-current,.page-footer nav.pagination span.pagination-item.pagination-current{color:#fff !important;background-color:#2576b8 !important;border-color:#185a91 !important;cursor:default !important}.page-footer nav.pagination .pagination-item.pagination-disabled,.page-footer nav.pagination span.pagination-item.pagination-disabled{color:#9ca3af !important;background-color:#e5e7eb !important;border:2px solid #e5e7eb !important;cursor:not-allowed !important}.page-footer nav.pagination .pagination-ellipsis{display:inline-flex !important;justify-content:center !important;align-items:center !important;min-width:36px !important;height:36px !important;color:var(--secondary) !important;font-size:.9rem !important;border:none !important;background:0 0 !important}.page-footer nav.pagination .pagination-first,.page-footer nav.pagination .pagination-last{font-size:.85rem !important}@media(max-width:600px){.page-footer nav.pagination{gap:2px !important}.page-footer nav.pagination .pagination-numbers{gap:2px !important}.page-footer nav.pagination .pagination-item{min-width:32px !important;height:32px !important;padding:0 6px !important;font-size:.8rem !important}.page-footer nav.pagination .pagination-ellipsis{min-width:24px !important;height:32px !important}.page-footer nav.pagination .pagination-first,.page-footer nav.pagination .pagination-prev,.page-footer nav.pagination .pagination-next,.page-footer nav.pagination .pagination-last{padding:0 8px !important}}