.blog-page{min-height:70vh;padding:60px 0 120px}.blog-page-header{margin-bottom:64px}.blog-page-header picture{display:block}.blog-page-title-image{width:100%;height:auto;margin:0 0 16px;display:block}.blog-page-subtitle{color:#fff6ddb3;text-align:center;margin:40px 0 0;font-family:Manrope,system-ui,sans-serif;font-size:20px}.blog-page-empty{text-align:center;color:#fff6dd80;padding:80px 0;font-size:18px}.blog-filter-bar{align-items:center;gap:16px;margin-bottom:40px;display:flex}.blog-filter-dropdown{position:relative}.blog-filter-toggle{color:#fff6dd;background:#ffffff0a;border:1px solid #ffffff26;border-radius:9999px;align-items:center;gap:10px;padding:10px 20px;font-family:Manrope,system-ui,sans-serif;font-size:15px;line-height:20px;transition:border-color .2s,background .2s;display:inline-flex}.blog-filter-toggle:hover{background:#ffffff0f;border-color:#f59a0666}.blog-filter-chevron{transition:transform .2s}.blog-filter-chevron--open{transform:rotate(180deg)}.blog-filter-menu{z-index:50;background:#1a1a1a;border:1px solid #ffffff1f;border-radius:12px;min-width:220px;max-height:320px;margin:0;padding:8px 0;list-style:none;position:absolute;top:calc(100% + 8px);left:0;overflow-y:auto;box-shadow:0 12px 40px #00000080}.blog-filter-option{color:#fff6ddb3;text-align:left;background:0 0;border:none;width:100%;padding:10px 20px;font-family:Manrope,system-ui,sans-serif;font-size:14px;transition:background .15s,color .15s;display:block}.blog-filter-option:hover{color:#fff6dd;background:#ffffff0f}.blog-filter-option--active{color:#f59a06}.blog-filter-clear{color:#fff6dd99;background:0 0;border:1px solid #f59a064d;border-radius:9999px;padding:8px 16px;font-family:Manrope,system-ui,sans-serif;font-size:13px;transition:color .2s,border-color .2s}.blog-filter-clear:hover{color:#fff6dd;border-color:#f59a0699}.blog-page-grid{grid-template-columns:repeat(2,1fr);gap:32px;display:grid}.blog-page-card{color:inherit;flex-direction:column;padding:0;text-decoration:none;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;overflow:hidden}.blog-page-card:hover{border-color:#f59a064d;transform:translateY(-4px);box-shadow:0 12px 32px #0006}.blog-page-card-cover{aspect-ratio:16/7;flex-shrink:0;width:100%;overflow:hidden}.blog-page-card-cover img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.blog-page-card:hover .blog-page-card-cover img{transform:scale(1.05)}.blog-page-card-body{flex-direction:column;flex:1;padding:28px 32px 32px;display:flex}.blog-page-card-meta{color:#fff6dd80;align-items:center;gap:8px;margin-bottom:14px;font-family:Manrope,system-ui,sans-serif;font-size:14px;display:flex}.blog-page-card-dot{color:#fff6dd4d}.blog-page-card-title{color:#fff6dd;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0 0 12px;font-family:Anta,system-ui,sans-serif;font-size:24px;font-weight:400;line-height:1.3;display:-webkit-box;overflow:hidden}.blog-page-card-desc{color:#fff6ddb3;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;margin:0 0 16px;font-family:Manrope,system-ui,sans-serif;font-size:15px;line-height:1.6;display:-webkit-box;overflow:hidden}.blog-page-card-tags{scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;gap:8px;margin-top:auto;display:flex;overflow:auto hidden}.blog-page-card-tags::-webkit-scrollbar{display:none}.blog-page-tag{color:#fff6dd99;white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:9999px;flex-shrink:0;padding:4px 12px;font-family:Manrope,system-ui,sans-serif;font-size:13px;line-height:1.4;display:inline-block}@media (max-width:768px){.blog-page{padding:40px 0 80px}.blog-page-title-image{width:100%}.blog-filter-bar{margin-bottom:28px}.blog-filter-menu{min-width:200px}.blog-page-grid{grid-template-columns:1fr;gap:24px}.blog-page-card-body{padding:20px 24px 24px}.blog-page-tag{padding:3px 9px;font-size:11px}}@media (max-width:480px){.blog-page-tag{padding:3px 7px;font-size:10px}}.article-page{min-height:70vh;padding:40px 0 120px}.article-layout{grid-template-columns:1fr 260px;align-items:start;gap:48px;display:grid}.article-main{min-width:0;max-width:780px}.article-header{margin-bottom:48px}.article-sidebar{flex-direction:column;gap:24px;display:flex;position:sticky;top:140px}.article-toc{background:0 0;border:1px solid #0000;border-radius:16px;padding:24px;position:relative}.article-toc:before{content:"";background:var(--brand-gradient);-webkit-mask-composite:xor;pointer-events:none;border-radius:16px;padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.article-toc-title{color:#fff6dd;margin:0 0 16px;font-family:Anta,system-ui,sans-serif;font-size:18px;font-weight:400}.article-toc-list{margin:0;padding:0;list-style:none}.article-toc-item{margin-bottom:10px}.article-toc-item:last-child{margin-bottom:0}.article-toc-item--sub{padding-left:16px}.article-toc-link{color:#fff6dd8c;font-family:Manrope,system-ui,sans-serif;font-size:13px;line-height:1.5;text-decoration:none;transition:color .2s;display:block}.article-toc-link:hover{color:#fff6dd}.article-toc-item--active .article-toc-link{color:#fff6dd;background:var(--brand-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.article-social{align-items:center;gap:10px;padding:0 4px;display:flex}.article-social-link{width:40px;height:40px;cursor:inherit;background:0 0;border:none;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:transform .2s;display:inline-flex;position:relative}.article-social-link:hover{transform:scale(1.1)}.article-social-icon{background-color:#fff6dd;width:40px;height:40px;transition:background .3s;display:block;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.article-social-link:hover .article-social-icon{background:var(--brand-gradient)}.article-copy-btn.is-copied .article-social-icon{opacity:.5}.article-copy-toast{color:#fff6dd;white-space:nowrap;pointer-events:none;background:#f59a06e6;border-radius:6px;padding:3px 10px;font-family:Manrope,system-ui,sans-serif;font-size:12px;animation:2s forwards toast-fade;position:absolute;top:-28px;left:50%;transform:translate(-50%)}@keyframes toast-fade{0%,70%{opacity:1}to{opacity:0}}.article-breadcrumbs{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:32px;font-family:Anta,system-ui,sans-serif;font-size:15px;display:flex}.article-breadcrumb-link{color:#fff6dd99;white-space:nowrap;text-decoration:none;transition:color .2s}.article-breadcrumb-link:hover{color:#fff6dd}.article-breadcrumb-sep{color:#fff6dd4d;-webkit-user-select:none;user-select:none}.article-breadcrumb-current{color:#fff6dd66;text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}.article-meta{color:#fff6dd80;align-items:center;gap:8px;margin-bottom:20px;font-family:Manrope,system-ui,sans-serif;font-size:14px;display:flex}.article-meta-dot{color:#fff6dd4d}.article-title{color:#fff6dd;margin:0 0 16px;font-family:Anta,system-ui,sans-serif;font-size:48px;font-weight:400;line-height:1.15}.article-description{color:#fff6ddb3;margin:0 0 20px;font-family:Manrope,system-ui,sans-serif;font-size:20px;line-height:1.6}.article-tags{flex-wrap:wrap;gap:8px;display:flex}.article-cover{aspect-ratio:16/7;border-radius:16px;width:100%;margin-bottom:48px;overflow:hidden}.article-cover img{object-fit:cover;width:100%;height:100%;display:block}.article-body{color:#fff6dde0;font-family:Manrope,system-ui,sans-serif;font-size:18px;line-height:1.8}.article-body h2{color:#fff6dd;margin:56px 0 20px;scroll-margin-top:120px;font-family:Anta,system-ui,sans-serif;font-size:32px;font-weight:400;line-height:1.2}.article-body h3{color:#fff6dd;margin:40px 0 16px;scroll-margin-top:120px;font-family:Anta,system-ui,sans-serif;font-size:24px;font-weight:400;line-height:1.3}.article-body p{margin:0 0 24px}.article-body strong{color:#fff6dd;font-weight:700}.article-body a{color:#f59a06;text-underline-offset:3px;-webkit-text-decoration:underline #f59a064d;text-decoration:underline #f59a064d;transition:text-decoration-color .2s}.article-body a:hover{text-decoration-color:#f59a06}.article-body ul,.article-body ol{margin:0 0 24px;padding-left:24px}.article-body li{margin-bottom:10px}.article-body li::marker{color:#f59a06}.article-body blockquote{border-left:3px solid;border-image:var(--brand-gradient)1;background:#ffffff08;border-radius:0 12px 12px 0;margin:32px 0;padding:16px 24px}.article-body blockquote p{color:#fff6ddcc;margin:0;font-style:italic}.article-body code{background:#ffffff14;border-radius:6px;padding:2px 8px;font-size:.9em}.article-body pre{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin:0 0 24px;padding:20px 24px;overflow-x:auto}.article-body pre code{background:0 0;border-radius:0;padding:0;font-size:14px;line-height:1.6}.article-body hr{background:#ffffff1a;border:none;height:1px;margin:48px 0}.article-body img{border-radius:12px;max-width:100%;height:auto;margin:24px 0}.banner-screenshot{margin:40px 0;padding:0}.banner-screenshot-grid{gap:16px;display:grid}.banner-screenshot-grid--multi{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.banner-screenshot-frame{border-radius:12px;overflow:hidden}.banner-screenshot-frame img{border-radius:0;width:100%;height:auto;margin:0;display:block}.banner-screenshot-caption{color:#fff6dd73;text-align:center;margin-top:14px;font-family:Manrope,system-ui,sans-serif;font-size:15px;font-style:italic}@media (max-width:1024px){.article-layout{grid-template-columns:1fr}.article-sidebar{order:-1;position:static}.article-toc{display:none}.article-social{justify-content:flex-start}}@media (max-width:768px){.article-page{padding:24px 0 80px}.article-title{font-size:32px}.article-body{font-size:16px}.article-body h2{margin-top:40px;font-size:26px}.article-body h3{margin-top:32px;font-size:20px}}
