.blog-layout-wrapper{min-height:100vh;background:#ffffff}.blog-nav-header{background:white;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:100}.blog-nav-container{max-width:800px;margin:0 auto;padding:1rem 2rem}.blog-breadcrumb{display:flex;align-items:center;font-size:.875rem;flex-wrap:wrap}.breadcrumb-link{color:#666;text-decoration:none;transition:color .2s;padding:.25rem 0}.breadcrumb-link:hover{color:#000}.breadcrumb-current{color:#000;font-weight:500}.breadcrumb-separator{margin:0 .5rem;color:#ccc}.blog-list-wrapper{min-height:calc(100vh - 57px);background:#ffffff}.blog-list-container{max-width:700px;margin:0 auto;padding:4rem 2rem}.blog-list-header{margin-bottom:4rem}.blog-list-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;color:#000;letter-spacing:-.02em}.blog-list-subtitle{font-size:1.125rem;color:#666;font-weight:400}.posts-list{position:relative}.year-group{margin-bottom:3rem}.year-marker{font-size:.875rem;font-weight:600;color:#999;margin-bottom:1.5rem;padding-bottom:.5rem;letter-spacing:.05em}.post-item{margin-bottom:1px;position:relative;transition:all .2s ease}.post-item:not(:last-child){border-bottom:1px solid #f0f0f0}.post-item-link{display:grid;grid-template-columns:100px 1fr;gap:2rem;padding:1.5rem 0;text-decoration:none;color:inherit;transition:all .2s ease;position:relative}.post-item-link:before{content:"";position:absolute;left:-1rem;right:-1rem;top:0;bottom:0;background:transparent;transition:background .2s ease;z-index:-1}.post-item-link:hover:before{background:#fafafa}.post-item-link:hover .post-item-title{color:#000}.post-item-link:hover{padding-left:.1rem}.post-item-date{font-size:.875rem;color:#999;padding-top:.125rem;font-variant-numeric:tabular-nums}.post-item-content{min-width:0}.post-item-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:#222;line-height:1.3;transition:color .2s ease}.post-item-excerpt{color:#666;line-height:1.6;margin-bottom:.75rem;font-size:.9375rem}.post-item-meta{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#999}.post-item-reading-time{color:#999}.meta-separator{color:#ddd}.post-item-tags{display:flex;gap:.5rem}.post-item-tag{color:#666;transition:color .2s}.post-item-tag:before{content:"#";opacity:.5}.blog-post-wrapper{background:white}.blog-post-main-container{position:relative;padding:3rem 2rem}.blog-article-centered{max-width:700px;margin:0 auto;position:relative}.article-header{margin-bottom:2rem}.article-title{font-size:2.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem;color:#000;letter-spacing:-.02em}.article-meta{display:flex;align-items:center;gap:1rem;color:#64748b;margin-bottom:1rem;font-size:.875rem}.meta-avatar{flex-shrink:0}.avatar-image{border-radius:50%;-o-object-fit:cover;object-fit:cover}.meta-text{display:flex;flex-direction:column;gap:.25rem}.meta-author,.meta-date{color:#64748b;margin:0}.meta-author{font-weight:600;color:#374151}.toc-container{position:fixed;right:2rem;top:50%;transform:translateY(-50%);width:240px;height:-moz-fit-content;height:fit-content;max-height:70vh;overflow-y:auto;z-index:10}.toc-content{padding:1.5rem}.toc-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#666;margin-bottom:1rem}.toc-nav{padding-left:0}.toc-list{list-style:none;padding:0;margin:0}.toc-item{margin-bottom:.5rem}.toc-level-2{padding-left:1rem}.toc-level-3{padding-left:2rem}.toc-link{color:#666;text-decoration:none;font-size:.875rem;line-height:1.5;display:block;transition:all .2s;padding:.25rem 0}.toc-link:hover{color:#666;padding-left:.25rem}.toc-item.active .toc-link{color:#666;font-weight:600}@media (max-width:1250px){.toc-container{display:none}}@media (max-width:768px){.blog-list-container{padding:3rem 1.5rem}.blog-list-header h1{font-size:2rem}.post-item-link{grid-template-columns:1fr;gap:.5rem;padding:1.25rem 0}.post-item-date{color:#999;margin-bottom:.25rem}.post-item-title{font-size:1.125rem}.post-item-excerpt{font-size:.875rem}.post-item-link:hover{padding-left:0}}@media (max-width:480px){.blog-list-container{padding:2rem 1rem}.blog-list-header{margin-bottom:3rem}.blog-list-header h1{font-size:1.75rem}.blog-list-subtitle{font-size:1rem}}.latest-blog-post{max-width:700px;margin:4rem auto;padding:0 2rem}.latest-post-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid #f0f0f0}.latest-post-section-title{font-size:1rem;font-weight:600;color:#666;letter-spacing:.025em;text-transform:uppercase;margin:0}.view-all-link{font-size:.875rem;color:#999;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#000}.latest-post-card{display:block;text-decoration:none;color:inherit;background:#ffffff;border:1px solid #f0f0f0;border-radius:8px;padding:2rem;transition:all .2s ease;position:relative;overflow:hidden}.latest-post-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;transform:translateX(-100%);transition:transform .3s ease}.latest-post-content{position:relative}.latest-post-date{font-size:.8125rem;color:#999;margin-bottom:.75rem;font-variant-numeric:tabular-nums}.latest-post-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:#000;line-height:1.3;letter-spacing:-.01em}.latest-post-excerpt{font-size:1rem;line-height:1.6;color:#666;margin:0 0 1rem}.latest-post-read-more{font-size:.875rem;color:#999;font-weight:500;display:inline-block;transition:all .2s ease}.latest-post-card:hover .latest-post-read-more{color:#000}@media (max-width:768px){.latest-blog-post{margin:3rem auto;padding:0 1.5rem}.latest-post-card{padding:1.5rem}.latest-post-title{font-size:1.25rem}.latest-post-excerpt{font-size:.9375rem}}@media (max-width:480px){.latest-blog-post{margin:2rem auto;padding:0 1rem}.latest-post-header{flex-direction:column;gap:.5rem;align-items:flex-start}.latest-post-card{padding:1.25rem;border-radius:6px}.latest-post-title{font-size:1.125rem}}.latest-post-skeleton{padding:2rem;border:1px solid #f0f0f0;border-radius:8px}.skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px;margin-bottom:1rem}.skeleton-date{height:.875rem;width:120px}.skeleton-title{height:1.5rem;width:70%}.skeleton-excerpt{height:1rem;width:100%}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}