body{margin:0}.tool-page{font-family:Inter,sans-serif;background:var(--tp-bg);color:var(--tp-text);line-height:1.7;min-height:100vh}.tool-page-container{max-width:1200px;margin:0 auto;padding:48px 40px 0;position:relative;z-index:1}.tp-breadcrumb{padding:20px 0;font-family:var(--font-mono);font-size:12px;color:var(--tp-text-muted)}.tp-breadcrumb a{color:var(--tp-text-muted);text-decoration:none}.tp-breadcrumb a:hover{color:var(--primary-text)}.tp-breadcrumb span{margin:0 10px;color:var(--tp-text-muted)}.blog-frozen-bar{position:fixed;top:var(--nav-height, 64px);left:0;right:0;z-index:var(--z-frozen-bar, 90);background:#121e37eb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(40,60,100,.4);height:44px}[data-theme=light] .blog-frozen-bar{background:#192d50eb;border-bottom-color:#283c644d}.blog-frozen-bar__inner{display:flex;align-items:center;gap:1rem;max-width:var(--max-width, 1200px);margin:0 auto;padding:0 40px;height:100%}.blog-frozen-bar__label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.blog-frozen-bar__tool{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);transition:color var(--transition-fast);white-space:nowrap}.blog-frozen-bar__tool:hover{color:var(--primary)}.blog-frozen-bar__logo{width:20px;height:20px;object-fit:contain;flex-shrink:0}.blog-frozen-bar__name{font-family:var(--font-body);font-weight:600;font-size:.85rem}[data-theme=light] .blog-frozen-bar__label,[data-theme=light] .blog-frozen-bar__name{color:#fff}[data-theme=light] .blog-frozen-bar__tool:hover .blog-frozen-bar__name{color:#c5d5ff}[data-theme=light] .blog-frozen-bar__divider{background:#ffffff4d}.blog-frozen-bar__divider{width:1px;height:20px;background:var(--nav-border);flex-shrink:0}.blog-post .tool-page-container{padding-top:44px}@media(max-width:767px){.blog-frozen-bar__inner{padding:0 20px;gap:.75rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.blog-frozen-bar__inner::-webkit-scrollbar{display:none}.blog-frozen-bar__label{display:none}.blog-frozen-bar__label+.blog-frozen-bar__divider{display:none}}@media(max-width:480px){.blog-frozen-bar__inner{padding:0 12px;gap:.5rem}.blog-frozen-bar__name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.blog-header{padding:80px 0 40px;text-align:center;max-width:800px;margin:0 auto}.blog-category-badge{display:inline-block;padding:6px 16px;background:var(--accent-10);border:1px solid var(--accent-30);border-radius:4px;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--tp-magenta);text-transform:uppercase;letter-spacing:.1em;margin-bottom:20px}.blog-title{font-family:var(--font-display);font-size:clamp(26px,5vw + 6px,42px);font-weight:700;line-height:1.2;margin:0 0 24px;color:var(--tp-text)}.blog-meta{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-bottom:20px}.blog-meta-item{display:flex;flex-direction:column;align-items:center;gap:4px}.blog-meta-label{font-family:var(--font-mono);font-size:10px;color:var(--tp-text-muted);text-transform:uppercase;letter-spacing:.1em}.blog-meta-value{font-family:var(--font-mono);font-size:13px;color:var(--tp-cyan);font-weight:500}.blog-meta-item.updated .blog-meta-value{color:var(--tp-green)}.blog-tags{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.blog-tag{font-family:var(--font-mono);font-size:12px;color:var(--tp-text-muted);text-decoration:none;padding:4px 10px;background:var(--tp-card);border:1px solid var(--tp-border);border-radius:4px;transition:all .2s}.blog-tag:hover{color:var(--tp-cyan);border-color:var(--tp-cyan)}.blog-disclosure{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:var(--warning-10);border:1px solid var(--warning-20);border-left:3px solid var(--tp-yellow);border-radius:6px;margin-bottom:30px;max-width:800px;margin-left:auto;margin-right:auto}.blog-disclosure-icon{width:20px;height:20px;background:var(--tp-yellow);color:var(--tp-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:12px;font-weight:700;flex-shrink:0}.blog-disclosure p{font-family:var(--font-mono);font-size:12px;color:var(--tp-text-muted);margin:0;line-height:1.6}.blog-featured-image{max-width:900px;margin:0 auto 40px;border-radius:12px;overflow:hidden;border:1px solid var(--tp-border)}.blog-featured-image img{width:100%;height:auto;display:block;aspect-ratio:16 / 9}.blog-layout{display:grid;grid-template-columns:1fr 280px;gap:60px;align-items:start;padding-bottom:60px}.blog-content{max-width:100%;min-width:0;font-size:17px;line-height:1.9;color:var(--tp-text-muted);overflow:visible}.blog-content h2{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--tp-text);text-transform:uppercase;letter-spacing:.03em;margin:50px 0 20px;padding-bottom:12px;border-bottom:1px solid var(--tp-border)}.blog-content h2:before{content:"// ";color:var(--tp-cyan)}.blog-content h3{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--tp-text);margin:35px 0 15px}.blog-content h4{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--tp-cyan);text-transform:uppercase;letter-spacing:.05em;margin:30px 0 12px}.blog-content p{margin-bottom:20px}.blog-content strong{color:var(--tp-text);font-weight:600}.blog-content em{color:var(--tp-text);font-style:italic}.blog-content a{color:var(--primary-text);text-decoration:none;border-bottom:1px solid var(--primary-30);transition:all .2s}.blog-content a:hover{color:var(--tp-text);border-color:var(--tp-cyan)}.blog-content ul,.blog-content ol{margin:0 0 24px;padding-left:0}.blog-content ul{list-style:none}.blog-content ul li{position:relative;padding-left:24px;margin-bottom:12px}.blog-content ul li:before{content:"+";position:absolute;left:0;color:var(--tp-cyan);font-family:var(--font-mono);font-weight:700}.blog-content ol{list-style:none;counter-reset:step-counter}.blog-content ol li{position:relative;padding-left:36px;margin-bottom:16px;counter-increment:step-counter}.blog-content ol li:before{content:counter(step-counter,decimal-leading-zero);position:absolute;left:0;font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--tp-cyan)}.blog-content blockquote{margin:30px 0;padding:20px 24px;background:var(--tp-card);border:1px solid var(--tp-border);border-left:4px solid var(--tp-magenta);border-radius:8px;font-style:normal}.blog-content blockquote p{margin:0;color:var(--tp-text)}.blog-content code{font-family:var(--font-mono);font-size:14px;background:var(--tp-card);padding:3px 8px;border-radius:4px;border:1px solid var(--tp-border);color:var(--primary-text)}.blog-content pre{margin:24px 0;padding:20px 24px;background:var(--tp-card);border:1px solid var(--tp-border);border-radius:8px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.blog-content .table-scroll-wrapper{overflow-x:auto}.blog-content pre code{padding:0;background:none;border:none;color:var(--tp-text-muted);white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.blog-content pre.astro-code span[style*="#6A737D" i]{color:#b7c0cc!important}.blog-content table{width:100%;margin:30px 0;border-collapse:collapse;background:var(--tp-card);border:1px solid var(--tp-border);border-radius:8px;overflow:hidden}.blog-content thead{background:var(--primary-5)}.blog-content th{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--tp-cyan);text-transform:uppercase;letter-spacing:.05em;padding:14px 16px;text-align:left;border-bottom:1px solid var(--tp-border)}.blog-content td{font-size:14px;padding:14px 16px;border-bottom:1px solid var(--tp-border)}.blog-content tr:last-child td{border-bottom:none}.blog-content img{max-width:100%;height:auto;border-radius:8px;border:1px solid var(--tp-border);margin:24px 0}.blog-content figure,.blog-content .blog-image{margin:30px 0;max-width:100%;overflow:hidden}.blog-content figure img,.blog-content .blog-image img{width:100%;max-width:100%;height:auto;display:block}.blog-content figure img,.blog-content .blog-image img{margin:0;border-radius:8px 8px 0 0}.blog-content figcaption{font-family:var(--font-mono);font-size:12px;color:var(--tp-text-muted);text-align:center;margin-top:0;padding:12px 16px;background:var(--tp-card);border:1px solid var(--tp-border);border-top:none;border-radius:0 0 8px 8px}.blog-content hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--tp-border),transparent);margin:40px 0}.blog-content .tip-box,.blog-content .warning-box,.blog-content .info-box{padding:20px 24px;margin:24px 0;border-radius:8px;border:1px solid}.blog-content .tip-box{background:var(--success-10);border-color:var(--success-20);border-left:4px solid var(--tp-green)}.blog-content .warning-box{background:var(--warning-10);border-color:var(--warning-20);border-left:4px solid var(--tp-yellow)}.blog-content .info-box{background:var(--primary-5);border-color:var(--primary-20);border-left:4px solid var(--tp-cyan)}.blog-content .blog-key-facts{background:var(--primary-5);border:1px solid var(--primary-20);border-left:4px solid var(--tp-green);border-radius:8px;padding:20px 24px;margin:24px 0}.blog-content .blog-key-facts-header{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--tp-green);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.blog-content .blog-key-facts-list{list-style:none;padding:0;margin:0}.blog-content .blog-key-facts-list li{position:relative;padding:6px 0 6px 20px;margin-bottom:0;font-size:15px;line-height:1.6;color:var(--tp-text)}.blog-content .blog-key-facts-list li:before{content:"→";position:absolute;left:0;color:var(--tp-green);font-family:inherit;font-weight:400}.blog-sidebar{position:sticky;top:100px;align-self:start;transition:top .1s ease-out}.blog-sidebar.sticky-bottom{top:auto!important;bottom:20px}.blog-sidebar.sticky-top{top:100px!important;bottom:auto}.blog-sidebar-card{background:var(--tp-card);border:1px solid var(--tp-border);border-radius:10px;padding:20px;margin-bottom:20px}.blog-sidebar-title{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--primary-text);text-transform:uppercase;letter-spacing:.08em;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--tp-border)}.blog-related-tools{list-style:none;margin:0;padding:0}.blog-related-tools li{margin-bottom:10px}.blog-related-tools a{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--tp-card-alt);border:1px solid var(--tp-border);border-radius:6px;font-family:var(--font-mono);font-size:13px;color:var(--tp-text-muted);text-decoration:none;transition:all .2s}.blog-related-tools a:before{content:">";color:var(--tp-cyan);font-weight:700}.blog-related-tools a:hover{border-color:var(--tp-cyan);color:var(--tp-text)}.blog-toc{padding:0}.blog-toc-summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0;padding:20px;border-bottom:none;user-select:none;-webkit-user-select:none;transition:color .2s}.blog-toc-summary::-webkit-details-marker{display:none}.blog-toc-summary::marker{display:none}.blog-toc-summary:hover,.blog-toc-summary:focus-visible{color:var(--tp-cyan)}.blog-toc-summary:focus-visible{outline:2px solid var(--tp-cyan);outline-offset:-2px}.blog-toc-chevron{flex-shrink:0;color:var(--tp-text-muted);transition:transform .2s ease,color .2s ease}.blog-toc-summary:hover .blog-toc-chevron{color:var(--tp-cyan)}.blog-toc[open] .blog-toc-summary{border-bottom:1px solid var(--tp-border);margin-bottom:0;padding-bottom:12px}.blog-toc[open] .blog-toc-chevron{transform:rotate(180deg);color:var(--tp-cyan)}.blog-toc-nav{padding:16px 20px 20px}.blog-toc-list{list-style:none;margin:0;padding:0}.blog-toc-list li{margin-bottom:8px}.blog-toc-list a{font-family:var(--font-mono);font-size:12px;color:var(--tp-text-muted);text-decoration:none;display:block;border-left:2px solid transparent;padding:6px 0 6px 12px;transition:all .2s}.blog-toc-list a:hover{color:var(--tp-cyan);border-left-color:var(--tp-cyan)}.blog-toc-list .toc-h3 a{padding-left:24px;font-size:11px}@media(max-width:1024px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:20px}}@media(min-width:640px)and (max-width:768px){.tool-page-container{padding-left:24px;padding-right:24px}.blog-content h2{font-size:22px}}@media(max-width:639px){.tool-page-container{padding-left:20px;padding-right:20px}.blog-meta{gap:20px}.blog-sidebar{grid-template-columns:1fr}.blog-content h2{font-size:20px}.blog-content{font-size:16px}}.blog-content figure img,.blog-content .blog-image img{cursor:zoom-in;transition:transform .2s ease,box-shadow .2s ease}.blog-content figure img:hover,.blog-content .blog-image img:hover{transform:scale(1.01);box-shadow:0 0 20px var(--primary-20)}.blog-lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#0c1222f2;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-lightbox, 600);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.blog-lightbox.active{opacity:1;visibility:visible}.blog-lightbox-content{position:relative;max-width:90vw;max-height:90vh}.blog-lightbox-image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;border:1px solid var(--tp-border);box-shadow:0 0 60px var(--primary-15)}.blog-lightbox-close{position:absolute;top:-40px;right:0;width:36px;height:36px;background:var(--tp-card);border:1px solid var(--tp-border);border-radius:50%;color:var(--tp-text-muted);font-family:var(--font-mono);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.blog-lightbox-close:hover{background:var(--tp-cyan);color:var(--tp-bg);border-color:var(--tp-cyan)}.blog-lightbox-caption{font-family:var(--font-mono);font-size:13px;color:var(--tp-text-muted);text-align:center;margin-top:16px;padding:12px 20px;background:var(--tp-card);border:1px solid var(--tp-border);border-radius:6px}.blog-content figure:after,.blog-content .blog-image:after{content:"Click to enlarge";display:block;font-family:var(--font-mono);font-size:10px;color:var(--tp-cyan);text-transform:uppercase;letter-spacing:.1em;text-align:center;margin-top:-8px;padding-bottom:8px;opacity:.6}.guide-info-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;margin-bottom:.75rem}.guide-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.02em;border:1px solid var(--border)}.guide-badge--beginner{background:#10b9811a;color:#10b981;border-color:#10b9814d}.guide-badge--intermediate{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b4d}.guide-badge--advanced{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.guide-badge--type{background:#6366f11a;color:#6366f1;border-color:#6366f14d}
