.error-page{padding-top:var(--space-8)}.error-hero{text-align:center;padding:60px 20px 20px}.error-inner{max-width:1000px;margin:auto}.error-image{display:block;margin:auto;width:100%;max-width:900px;height:auto}.error-hero h1{font-size:44px;margin-top:20px;font-weight:600}.error-hero p{font-size:18px;color:var(--text-muted);margin-top:10px}.error-actions{margin-top:22px}.btn-primary{display:inline-block;padding:12px 24px;background:var(--accent-blue);color:var(--color-white);border-radius:var(--radius-sm);text-decoration:none;font-weight:500}.btn-primary:hover{background:#1d4ed8}@media(max-width:992px){.error-image{max-width:700px}.error-hero h1{font-size:36px}}@media(max-width:768px){.error-page{padding-top:20px}.error-hero{padding:40px 20px}.error-image{max-width:520px}.error-hero h1{font-size:30px}.error-hero p{font-size:16px}}@media(max-width:576px){.error-image{max-width:420px}.error-hero h1{font-size:26px}}.about-page{display:flex;flex-direction:column;gap:var(--space-8);padding-block:var(--space-7)}.full-bleed{margin-inline:calc(50% - 50vw);width:auto}.full-bleed-inner{max-width:1800px;margin-inline:auto;padding-inline:clamp(1rem,6vw,5rem)}.about-page .about-split{display:grid;grid-template-columns:minmax(280px,520px)1fr;align-items:center;gap:clamp(2rem,5vw,5rem);max-width:1440px;margin-inline:auto;padding-inline:clamp(1rem,6vw,5rem)}.about-page .about-visual{display:flex;justify-content:center}.about-page .about-visual img{width:100%;max-width:520px;height:auto;display:block}.about-page .about-content{max-width:760px}.about-page .about-content h1{font-size:clamp(1.9rem,3vw,2.5rem);font-weight:800;color:var(--text-strong);margin-bottom:1rem}.about-page .about-content p{margin-top:1rem;font-size:1rem;line-height:1.7;color:var(--text)}.about-page .about-content a{color:var(--accent-blue);font-weight:600;text-decoration:none}.about-page .about-content a:hover{text-decoration:underline}.about-page .about-features{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem 2rem;margin-top:1.25rem;padding-left:0;list-style:none}.about-page .about-features li{position:relative;padding-left:1.3rem;font-weight:600;color:#1e0a52}.about-page .about-features li::before{content:"›";position:absolute;left:0;top:0;color:#4f46e5;font-size:1.25rem;line-height:1}.about-page .about-contact{margin-top:1.4rem;font-weight:600}.about-page .stats-row{background:#f2f3f8}.about-page .stats-row .full-bleed-inner{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));align-items:center;gap:2rem;padding-block:clamp(2rem,6vw,3.5rem)}.about-page .stat{position:relative;text-align:center;padding-inline:clamp(.75rem,2vw,1.5rem)}@media(min-width:993px){.about-page .stat:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:64px;background:#111;opacity:.28}}.about-page .stat-number{font-size:clamp(2rem,3.6vw,3.1rem);font-weight:800;letter-spacing:.2px;color:var(--text-strong);line-height:1.1;white-space:nowrap}.about-page .stat-label{margin-top:.55rem;font-size:clamp(.95rem,1.2vw,1.05rem);font-weight:600;color:var(--text)}.about-page .authors-section{text-align:center}.about-page .authors-title{font-size:clamp(1.5rem,2.6vw,2.2rem);font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:#1e0a52;margin-bottom:2.5rem;padding-inline:clamp(1rem,6vw,5rem)}.about-page .authors-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2.25rem;align-items:start}.about-page .author-card{text-align:left}.about-page .author-card img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--space-2);background:var(--gray-100);display:block}.about-page .author-card h3{margin-top:.9rem;font-size:1rem;font-weight:700;color:#1f3bd1}.about-page .author-card p{margin-top:.35rem;font-size:.85rem;font-weight:600;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:.65rem}html[data-theme=dark] .about-page .stats-row{background:var(--surface-1)}html[data-theme=dark] .about-page .stat:not(:last-child)::after{background:var(--border)}html[data-theme=dark] .about-page .authors-title{color:#a78bfa}html[data-theme=dark] .about-page .about-features li{color:#c4b5fd}html[data-theme=dark] .about-page .about-features li::before{color:#a78bfa}@media(max-width:992px){.about-page .about-split{grid-template-columns:1fr;gap:2.5rem}.about-page .about-visual img{max-width:420px}.about-page .about-content{max-width:100%}.about-page .stats-row .full-bleed-inner{grid-template-columns:repeat(2,minmax(0,1fr));gap:2.25rem 1.5rem}.about-page .stat::after{display:none}.about-page .authors-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:768px){.about-page .authors-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem}}@media(max-width:576px){.about-page .about-visual img{max-width:300px}.about-page .about-features{grid-template-columns:1fr}.about-page .stats-row .full-bleed-inner{grid-template-columns:1fr;gap:1.75rem;padding-block:2rem}.about-page .stat-number{font-size:2.2rem}.about-page .authors-grid{grid-template-columns:1fr}.about-page .authors-title{margin-bottom:2rem}}.archive-header{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px 28px;margin-bottom:28px}.archive-header .taxonomy-label{display:inline-block;font-size:12px;font-weight:600;color:var(--accent-blue);background:rgba(37,99,235,8%);padding:4px 10px;border-radius:var(--radius-pill);margin-bottom:10px;text-transform:none;letter-spacing:normal}.archive-header h1{font-size:28px;margin-bottom:10px}.archive-header .small{color:var(--gray-500);font-size:15px;margin-bottom:16px}.archive-header .taxonomy-content{margin-bottom:18px}.archive-header .taxonomy-content p{margin-bottom:12px;line-height:1.6}.archive-header .taxonomy-content ul{margin:10px 0 16px 18px}.archive-header .taxonomy-content h2{font-size:20px}.archive-header .taxonomy-count{font-size:13px;color:var(--gray-400)}.archive-header .hr{margin-top:12px;opacity:.4}.article .post-feed{max-width:100%;overflow-x:hidden}.article .post-feed .list-item,.article .post-feed .list-title,.article .post-feed .list-excerpt{max-width:100%;word-wrap:break-word;overflow-wrap:break-word}.post-feed .list-item{padding:1.2rem 0}.post-feed .meta-date{display:block;font-size:.78rem;color:var(--slate-500);margin-bottom:.35rem;letter-spacing:.02em}.post-feed .list-title{margin:0;font-size:1.35rem;line-height:1.35;font-weight:700}.post-feed .list-title a{color:var(--text-strong);text-decoration:none}.post-feed .list-title a:hover{color:var(--link-article);text-decoration:underline}.post-feed .list-excerpt{margin:.45rem 0 .65rem;font-size:.95rem;line-height:1.6;color:var(--text-soft);max-width:68ch}.post-feed .list-meta{font-size:.82rem;color:var(--slate-500)}.post-feed .list-meta span:not(:first-child)::before{content:" · ";padding:0 .15rem}.pagination{margin:30px 0;width:100%}.pagination-list{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;width:100%;padding:10px 16px;border-radius:var(--radius-md);gap:12px}.pagination-left{display:flex;justify-content:flex-start;gap:10px;min-width:0}.pagination-center{text-align:center;color:var(--gray-500);font-size:14px;font-weight:600}.pagination-right{display:flex;justify-content:flex-end;gap:10px;min-width:0}.pagination-item a{display:inline-block;padding:8px 14px;font-size:14px;font-weight:600;color:var(--text);text-decoration:none;background:var(--bg-article);border:1px solid var(--border);border-radius:var(--space-2);box-shadow:var(--shadow-sm);transition:all .2s ease}.pagination-item a:hover{color:var(--link-article);border-color:var(--link-article);background:var(--surface-1);transform:translateY(-1px)}.pagination-item.first a,.pagination-item.last a{font-weight:700}@media(max-width:768px){.archive-header h1{font-size:25px}.archive-header .taxonomy-content h2{font-size:17px}.author-profile-top{grid-template-columns:1fr;text-align:center;justify-items:center}.author-socials{justify-content:center}.list-item h2{font-size:1.25rem}}@media(max-width:576px){.pagination-list{grid-template-columns:1fr}.pagination-left,.pagination-right{justify-content:center;flex-wrap:wrap}.pagination-center{order:-1}}html[data-theme=dark] .archive-header .taxonomy-label{color:#93c5fd;background:rgba(147,197,253,.12)}html[data-theme=dark] .pagination-item a:hover{background:rgba(147,197,253,.1)}.author-box{margin-top:3rem;padding:1.75rem;border:1px solid #e5e7eb;border-left:4px solid #10b981;border-radius:12px;background:#fff}.author-box-inner{display:flex;gap:1rem;align-items:flex-start}.author-avatar{width:72px;height:72px;flex-shrink:0;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb;background:#f9fafb}.author-content{flex:1}.author-name{margin:0;font-size:1rem;font-weight:700;color:#0f172a}.author-title{margin:.2rem 0 0;font-size:.85rem;font-weight:500;color:#64748b}.author-bio{margin-top:.6rem;font-size:.92rem;line-height:1.6;color:#334155}.author-links{margin-top:.6rem;font-size:.85rem;color:#64748b}.author-links a{font-size:.85rem;font-weight:600;color:#2563eb;text-decoration:none}.author-links a:hover{text-decoration:underline}.author-box-socials{display:inline;margin-left:.1rem;color:#94a3b8}.author-box-socials a{color:#2563eb;font-weight:600;text-decoration:none}.author-box-socials a:hover{text-decoration:underline}.author-box-credentials{list-style:none;padding:0;margin:.55rem 0 0;display:flex;flex-wrap:wrap;gap:.35rem}.author-box-credentials li{font-size:.72rem;font-weight:600;letter-spacing:.02em;color:#0c4a6e;background:#e0f2fe;border:1px solid #bae6fd;padding:.2rem .55rem;border-radius:4px}.author-box-topics{list-style:none;padding:0;margin:.45rem 0 0;display:flex;flex-wrap:wrap;gap:.3rem}.author-box-topics li{font-size:.72rem;font-weight:500;color:#047857;background:#ecfdf5;border:1px solid #a7f3d0;padding:.18rem .5rem;border-radius:999px}p.author-links{margin:0}.author-profile-top{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem}.author-lg-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #f1f5f9;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);background-color:#fff}.author-profile-info h1{margin:0;font-size:2rem;color:#0f172a;line-height:1.2}.author-job-title{font-weight:700;font-size:1rem;margin:.4rem 0;letter-spacing:.02em}.author-socials{display:flex;gap:.75rem;margin-top:.75rem}.author-socials a{text-decoration:none;font-size:.85rem;font-weight:600;padding:.4rem .8rem;background:#f8fafc;color:#64748b;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s ease}.author-socials a:hover{background:#10b981;color:#fff;border-color:#10b981;transform:translateY(-2px)}.author-bio-content{font-size:1.05rem;line-height:1.7;color:#475569;margin-top:1.5rem}.author-works-for{margin:.4rem 0 0;font-size:.95rem;color:#475569}.author-works-for a{color:#10b981;text-decoration:none;font-weight:600}.author-works-for a:hover{text-decoration:underline}.author-post-count{color:#64748b;font-weight:500}.author-expertise{margin-top:2rem}.author-expertise h2,.author-credentials h2{font-size:1.15rem;font-weight:700;color:#0f172a;margin:0 0 .75rem}.expertise-chips{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.expertise-chips li{margin:0}.expertise-chip{display:inline-block;padding:.35rem .75rem;background:#ecfdf5;color:#047857;border:1px solid #a7f3d0;border-radius:999px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s ease}a.expertise-chip:hover{background:#10b981;color:#fff;border-color:#10b981}.author-credentials{margin-top:1.75rem}.credential-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.6rem}.credential-item{padding:.7rem .9rem;background:#f8fafc;border:1px solid #e2e8f0;border-left:3px solid #0ea5e9;border-radius:6px;font-size:.9rem;line-height:1.4}.credential-name{display:block;font-weight:600;color:#0f172a}.credential-id{display:inline-block;margin-top:.25rem;font-size:.78rem;color:#64748b;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.author-directory{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.author-directory li a{display:block;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;text-decoration:none;color:#1e293b;font-weight:600;text-align:center;transition:all .2s}.author-directory li a:hover{border-color:#10b981;background:#fff;color:#10b981}@media(max-width:640px){.author-box-inner{align-items:center}.author-socials{justify-content:center}.author-profile-top{flex-direction:column;text-align:center;gap:1rem}.author-avatar{width:64px;height:64px}.author-name{font-size:.95rem}}.archive-lead{margin:.5rem 0 0;font-size:1.05rem;color:#4b5563;max-width:60ch}.archive-intro{margin-top:.75rem;color:#374151;max-width:65ch}.author-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1.5rem}.author-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.author-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(15,23,42,8%);border-color:#10b981}.author-card-link{display:flex;gap:1rem;padding:1rem 1.1rem;text-decoration:none;color:inherit;align-items:flex-start}.author-card-link:hover,.author-card-link:focus{text-decoration:none}.author-card-media{flex-shrink:0}.author-card-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb;background:#f9fafb;display:block}.author-card-avatar-placeholder{display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.75rem;color:#047857;background:#ecfdf5;border-color:#a7f3d0}.author-card-body{flex:1;min-width:0}.author-card-name{margin:0 0 .15rem;font-size:1.05rem;line-height:1.3;color:#0f172a}.author-card-link:hover .author-card-name{color:#047857}.author-card-job{margin:0 0 .4rem;font-size:.85rem;color:#6b7280;font-weight:500}.author-card-bio{margin:0 0 .4rem;font-size:.85rem;color:#4b5563;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.author-card-meta{margin:0;font-size:.78rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.02em}@media(max-width:600px){.author-grid{grid-template-columns:1fr}.author-card-avatar,.author-card-avatar-placeholder{width:60px;height:60px;font-size:1.4rem}}cmd,code,pre{font-family:Consolas,andale mono,Monaco,Courier,courier new,Verdana,sans-serif;font-size:15px}pre{white-space:pre !important;overflow-x:auto;overflow-y:auto;position:relative;white-space:pre-wrap;line-height:1.5em;padding:10px !important;border-bottom-left-radius:4px;border-bottom-right-radius:4px;border:1px solid #585656;max-height:550px;margin-bottom:2em;margin-top:0;display:block;-moz-tab-size:4;-o-tab-size:4;tab-size:4;background:#252a37;color:#f7f8f9}cmd{white-space:pre-wrap;line-height:1.5em;overflow-x:auto;padding:10px !important;border-bottom-left-radius:4px;border-bottom-right-radius:4px;border:1px solid #585656;max-height:550px;margin-bottom:2em;margin-top:0;display:block;background:#f5f2f0;color:var(--color-black);font-size:14px !important;border-radius:0 0 6px 6px}code{padding:2px 4px;display:inline-block;border-radius:4px;font-size:95%;font-weight:inherit;line-height:22px;overflow-wrap:anywhere;word-break:break-word}pre::-webkit-scrollbar{width:8px;height:8px}pre::-webkit-scrollbar-thumb{background-color:transparent;transition:background-color .3s;border-radius:4px}pre:hover::-webkit-scrollbar-thumb{background-color:#73859f}pre::-webkit-scrollbar-track{background-color:#1d2327}.code-header{display:flex;justify-content:space-between;align-items:center;background:var(--slate-800);margin-top:1rem;color:var(--gray-200);font-size:.75rem;padding:.35rem .6rem;border-radius:6px 6px 0 0}.code-copy{background:0 0;border:0;color:inherit;cursor:pointer;font-size:.75rem}.contact-hero{background:var(--surface-1);padding-block:clamp(3rem,8vw,6rem)}.contact-inner{max-width:1800px;margin-inline:auto;padding-inline:clamp(1rem,6vw,5rem);display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:clamp(2.5rem,6vw,6rem)}.contact-content h1{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;color:var(--text-strong);margin-bottom:1.25rem}.contact-content p{margin-top:1rem;font-size:1rem;line-height:1.75;color:var(--text);max-width:640px}.contact-content a{color:#dc2626;font-weight:600;text-decoration:none}.contact-content a:hover{text-decoration:underline}.contact-social{margin-top:2rem}.contact-social span{display:block;font-weight:700;margin-bottom:.75rem;color:var(--text-strong)}.social-icons{display:flex;gap:1.25rem;align-items:center}.social-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;transition:transform .2s ease,opacity .2s ease}.social-icon svg{width:36px;height:36px;fill:currentColor}.social-icon.youtube{color:red}.social-icon.facebook{color:#1877f2}.social-icon.linkedin{color:#0a66c2}.social-icon:hover{transform:translateY(-2px);opacity:.85}.social-icon:focus-visible{outline:2px solid currentColor;outline-offset:4px}.contact-visual{display:flex;justify-content:center}.contact-visual img{width:100%;max-width:520px;height:auto}@media(max-width:992px){.contact-inner{grid-template-columns:1fr;text-align:left}.contact-visual img{max-width:420px}}@media(max-width:576px){.contact-visual img{max-width:300px}}.content-area{width:100%}.article{max-width:var(--content-max);margin-inline:auto;padding-inline:var(--gap);background:var(--bg-article);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(1.1rem,2vw,1.5rem);box-shadow:var(--shadow-sm),0 10px 28px rgba(0,0,0,8%)}.layout-full .article{max-width:none;width:100%;margin:0;padding-inline:clamp(1rem,5vw,4rem)}h1,h2,h3{line-height:1.25;margin:1.2em 0 .5em}h1{font-size:2rem;margin-top:.2em}h2{font-size:1.5rem}h3{font-size:1.2rem}p{margin:.9em 0}ul,ol{padding-left:1.2em}li{margin:.35em 0}img{max-width:100%;height:auto}blockquote{margin:1em 0;padding:.8em 1em;border-left:4px solid var(--border);background:var(--surface-1)}.article-header{margin-bottom:var(--space-6)}.article-body{font-size:.95rem;line-height:1.75;color:var(--text)}.article-body h2{margin-top:2.5rem;margin-bottom:1rem;color:var(--text-strong)}.article-body h3{margin-top:3.5rem;margin-bottom:1rem;color:#1e40af}.article-body h4{margin-top:3.5rem;margin-bottom:1rem;color:var(--text-soft)}.article-body h2+h3{margin-top:.75rem}.article-body h3+h4{margin-top:.5rem}.article-body>h2:first-child{margin-top:0}.article-body p:has(img){margin:0}.article-body p img{display:block}.article-body ul,.article-body ol{margin:.75rem 0 1.25rem 2.25rem;padding:0;line-height:1.6}.article-body p:has(+ul),.article-body p:has(+ol){margin-bottom:0}.article-body li{margin:0;line-height:1.7rem}.article-body a{color:var(--link-article);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}.article-body a:hover{border-bottom-color:var(--link-article);text-decoration:none}.article-meta{display:flex;flex-direction:column;gap:.3rem;padding:1rem 1.2rem;background:var(--surface-1);border-left:4px solid var(--accent-green);border-radius:var(--space-2);margin:var(--space-5)0;font-family:inherit}.meta-item{display:flex;flex-wrap:wrap;align-items:center;font-size:.9rem;line-height:1.4;color:var(--text-muted)}.meta-label{margin-right:.3rem}.article-meta a{color:var(--text-strong);font-weight:600;text-decoration:none;transition:color .2s}.article-meta a:hover{color:var(--accent-green);text-decoration:underline}.date-block{font-size:.85rem;color:var(--slate-400)}.taxonomy-block{margin-top:.2rem;padding-top:.4rem;border-top:1px solid var(--slate-200);font-size:.82rem;display:flex;flex-wrap:nowrap;align-items:center;gap:.4rem;overflow:hidden}.meta-cat{flex:none;color:var(--text-muted)}.meta-cat a{color:var(--accent-green-dark);font-weight:600}.meta-tag-list{flex:auto;min-width:0;display:block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted)}.meta-tag-list a{font-weight:400;color:var(--text-muted);text-decoration:none}.meta-tag-list a:hover{text-decoration:underline}.faq-section{margin-top:2.5rem}.faq-section h3{margin:var(--space-5)0 .5rem;color:#1e40af;line-height:1.4}.faq-section p{margin-bottom:1rem;color:var(--text-soft);line-height:1.6}.faq-section h3:not(:first-of-type){padding-top:var(--space-5);border-top:1px dashed var(--slate-300)}.alert{margin:var(--space-6)0;border-radius:var(--radius-sm);padding:1.25rem;border-left:4px solid}.alert-title{font-weight:700;margin-bottom:.5rem}.alert-note{background:rgba(99,169,241,.12);border-color:#0660bb}.alert-note .alert-title{color:#0660bb}.alert-warning{background:rgba(243,204,204,.15);border-color:var(--accent-red)}.alert-warning .alert-title{color:var(--accent-red)}.alert-important{background:rgba(232,207,194,.15);border-color:#cc4129}.alert-important .alert-title{color:#cc4129}.alert-hint{background:#ffffed;border-color:#5f5c17}.alert-hint .alert-title{color:#5f5c17}.hero-image{border-radius:var(--radius-lg);overflow:hidden}.hero-image img{display:block;width:100%;height:auto}.article-hero{margin:var(--space-5)0 var(--space-6)}.article-hero img{width:100%;height:auto;border-radius:14px;display:block;max-height:480px}figure.article-image{margin:0}.callout{border:1px solid var(--border);background:#fbfbfb;padding:12px 14px;border-radius:12px}.article-body table{width:100%;max-width:100%;border-collapse:collapse;table-layout:auto;display:block;overflow-x:auto;font-size:.95rem;line-height:1.5;margin:var(--space-5)0}.article-body thead th{position:sticky;top:0;z-index:2;background:linear-gradient(to bottom,var(--surface-1),var(--surface-2));color:var(--text-strong);font-weight:600;font-size:.9rem;padding:.65rem .75rem;border:1px solid var(--border);border-bottom:2px solid var(--border-strong);text-align:left;vertical-align:top;overflow-x:auto;overflow-y:hidden;white-space:normal;word-break:break-word}.article-body tbody td{padding:.6rem .75rem;border:1px solid var(--border);color:var(--text-soft);text-align:left;vertical-align:top;overflow-x:auto;overflow-y:hidden;white-space:normal;word-break:break-word}.article-body tbody tr:nth-child(even){background:var(--surface-1)}@media(hover:hover){.article-body tbody tr:hover{background:var(--surface-2)}}.article-body td::-webkit-scrollbar,.article-body th::-webkit-scrollbar{height:6px}.article-body td::-webkit-scrollbar-thumb,.article-body th::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:3px}.post-feed{margin-top:var(--space-7)}.list-item{padding:var(--space-5)0}.meta-date{font-size:.85rem;color:var(--slate-400);display:block;margin-bottom:.4rem;font-variant-numeric:tabular-nums}.list-item h2{margin:0 0 .6rem;font-size:1.5rem;line-height:1.3}.list-item h2 a{color:var(--text-strong);text-decoration:none;transition:color .2s}.list-item h2 a:hover{color:var(--accent-green)}.list-item p.small{margin:0;color:var(--text-muted);font-size:.95rem;line-height:1.6}hr{border:none;height:2px;margin:2.5rem 0;background:linear-gradient( to right,transparent,var(--border),transparent )}.hr{height:1px;margin:var(--space-5)0;background:linear-gradient( to right,transparent,var(--border),transparent )}.hr.light{margin:1.25rem 0;border-top:1px solid var(--border)}.taxonomy-label{font-size:.75rem;font-weight:800;color:var(--slate-400);letter-spacing:.1em;display:block;margin-bottom:.5rem;text-transform:uppercase}.article .section-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--slate-400);margin-bottom:var(--space-5);border-bottom:1px solid var(--slate-100);padding-bottom:.5rem}@media(max-width:992px){.article{padding:clamp(1rem,3vw,1.4rem);border-radius:var(--radius-lg)}h1{font-size:1.85rem}h2{font-size:1.4rem}h3{font-size:1.2rem}.article-body h2,.article-body h3,.article-body h4,.faq-section h2,.faq-section h3{margin-top:2.75rem}.article-meta{padding:.9rem 1rem}.article-hero img{max-height:360px}}@media(max-width:768px){.article{padding:var(--space-4);border-radius:14px}.article-body{font-size:.93rem;line-height:1.65}.article-hero img{max-height:280px}h1{font-size:1.6rem}h2,.faq-section h2{font-size:1.3rem}h3,.article-body h3{font-size:1.1rem}.article-body h2,.article-body h3,.article-body h4,.faq-section h2,.faq-section h3{margin-top:2.25rem;margin-bottom:.75rem}.article-body h2+h3,.faq-section h2+h3{margin-top:.5rem}.article-body ul,.article-body ol{margin-left:1.25rem}.article-body table{font-size:.9rem;max-height:55vh;overflow-y:auto;border:1px solid var(--border)}.meta-item{row-gap:.25rem}.hero-image{border-radius:var(--radius-md)}.article-meta{padding:.8rem}.meta-tag-list{margin-left:0;margin-top:.2rem;display:block}}@media(max-width:576px){.list-item h2{font-size:1.25rem}.article-body table{font-size:.9rem;max-height:50vh}.article-hero img{max-height:220px;border-radius:var(--radius-md)}}html[data-theme=dark] .article-body a{color:var(--link-article)}html[data-theme=dark] .article-body a:hover{border-bottom-color:var(--link-article)}html[data-theme=dark] .article-body h3,html[data-theme=dark] .faq-section h3{color:#93c5fd}html[data-theme=dark] blockquote{background:var(--surface-1);border-left-color:var(--border-strong);color:var(--text-soft)}html[data-theme=dark] .faq-section h3:not(:first-of-type){border-top-color:var(--border)}html[data-theme=dark] .alert-note{background:rgba(99,169,241,.1);border-color:#60a5fa}html[data-theme=dark] .alert-note .alert-title{color:#93c5fd}html[data-theme=dark] .alert-warning{background:rgba(248,113,113,.1);border-color:#f87171}html[data-theme=dark] .alert-warning .alert-title{color:#fca5a5}html[data-theme=dark] .alert-important{background:rgba(251,146,60,.1);border-color:#fb923c}html[data-theme=dark] .alert-important .alert-title{color:#fdba74}html[data-theme=dark] .alert-hint{background:rgba(250,204,21,6%);border-color:#facc15}html[data-theme=dark] .alert-hint .alert-title{color:#fde047}html[data-theme=dark] .article-meta{background:var(--surface-1);border-left-color:var(--accent-green)}html[data-theme=dark] .article-meta a:hover{color:#34d399}html[data-theme=dark] .meta-cat a{color:#34d399}html[data-theme=dark] .callout{background:var(--surface-1);border-color:var(--border)}html[data-theme=dark] hr{background:linear-gradient(to right,transparent,var(--border),transparent)}html[data-theme=dark] .list-item h2 a:hover{color:#34d399}.site-footer{background:radial-gradient(circle at top right,#2d0b6f,#1b0440 70%);color:var(--gray-200);padding-top:var(--space-8);position:relative}.footer-inner{margin:0 auto;padding:0 7rem var(--space-7);display:grid;grid-template-columns:2fr 2fr 2fr 1.5fr;gap:var(--space-7);align-items:stretch}.footer-col{display:flex;flex-direction:column}.footer-logo{width:217px;margin-bottom:var(--space-4)}.footer-col h4{font-size:1.05rem;font-weight:800;margin-bottom:var(--space-4);text-decoration:underline}.footer-col p{font-size:.95rem;line-height:1.6;color:var(--gray-300)}.footer-list{list-style:none;padding:0;margin:0;flex-grow:1}.footer-list li{margin-bottom:.7rem;font-size:.9rem}.footer-list li a{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.footer-list a{color:var(--gray-200);text-decoration:none}.footer-list a:hover{text-decoration:underline}.footer-social{display:flex;gap:.75rem;margin-top:1.2rem}.footer-social a{width:38px;height:38px;background:var(--color-white);border-radius:50%;display:grid;place-items:center;color:var(--brand-900);transition:all .2s ease}.footer-social a:hover{background:var(--accent-violet);color:var(--color-white)}.footer-social svg{width:18px;height:18px;fill:currentColor}.footer-bottom{text-align:center;padding:1.2rem;font-size:.85rem;border-top:1px solid rgba(255,255,255,.1);color:#cbd5f5}.footer-bottom a{color:#e5e168;font-weight:600;text-decoration:none}.footer-bottom a:hover{text-decoration:underline}@media(max-width:1200px){.footer-inner{padding:0 var(--space-7)var(--space-7);grid-template-columns:repeat(2,1fr);gap:2.5rem}}@media(max-width:992px){.footer-inner{padding:0 var(--space-6)2.5rem;gap:var(--space-6)}.footer-col h4{font-size:1rem}.footer-col p,.footer-list li{font-size:.9rem}}@media(max-width:576px){.footer-inner{grid-template-columns:1fr;padding:0 1.25rem 2.5rem;gap:var(--space-6)}.footer-col{align-items:flex-start}.footer-logo{width:190px}.footer-col:first-child{align-items:center;text-align:center}.footer-col:first-child p{max-width:28rem}.footer-social{justify-content:center}.footer-list li a{-webkit-line-clamp:3;line-clamp:3}}@media(max-width:400px){.footer-social a{width:34px;height:34px}.footer-social svg{width:16px;height:16px}.footer-bottom{font-size:.8rem;padding:1rem}}.site-header{background:#2a045c;color:var(--color-white)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);padding:0 var(--space-4)}.site-brand img{width:160px;display:block}.header-menu{display:flex;align-items:center;gap:var(--space-5)}.header-menu-toggle,.sidebar-menu-toggle{display:none}.header-menu a{color:var(--color-white);text-decoration:none;font-size:.9rem}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,8%);border:1px solid rgba(255,255,255,.12);color:var(--color-white);cursor:pointer;flex-shrink:0;padding:0;transition:background .2s ease,transform .15s ease,border-color .2s ease}.theme-toggle:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25);transform:rotate(20deg)}.theme-toggle:focus-visible{outline:2px solid #c7d2fe;outline-offset:2px}.theme-toggle .theme-icon{width:18px;height:18px;display:block}.theme-toggle .theme-icon-sun{display:none}.theme-toggle .theme-icon-moon{display:block}html[data-theme=dark] .theme-toggle .theme-icon-sun{display:block}html[data-theme=dark] .theme-toggle .theme-icon-moon{display:none}.theme-toggle--mobile{display:none}.header-menu .theme-toggle--desktop{margin-right:.25rem;order:-1}.header-menu-search{position:relative}.header-menu-search input{width:280px;padding:.55rem .8rem;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-md);font-size:.9rem;transition:all .2s ease}.header-menu-search input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.2)}#search-results{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--color-white);border:1px solid #ddd;border-radius:var(--space-2);box-shadow:0 10px 25px rgba(0,0,0,.15);z-index:1000;max-height:400px;overflow-y:auto;display:none}#search-results.has-results{display:block}.search-item{display:block;padding:12px 16px;text-decoration:none;background-color:var(--color-white);border-bottom:1px solid var(--slate-100)}.search-item:last-child{border-bottom:none}.search-item:hover{background:var(--slate-50);color:#7c3aed}.search-title{color:var(--slate-800) !important;font-weight:600;font-size:.9rem;line-height:1.3}mark{background:#fff3cd;color:var(--color-black);padding:0 2px}.search-empty{padding:1rem;color:var(--slate-400);font-size:.9rem;text-align:center}.search-excerpt{font-size:.9rem;color:var(--slate-700);line-height:1.5;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.search-excerpt mark{background:#fef08a;color:var(--color-black);font-weight:600;padding:0 2px;border-radius:2px}.search-item:hover .search-excerpt{color:#7c3aed}body.has-mobile-panel-open{overflow:hidden;touch-action:none}@media(max-width:768px){.header-menu-toggle,.sidebar-menu-toggle{display:block;background:0 0;border:none;color:var(--color-white);font-size:1.3rem;cursor:pointer}.header-inner{position:relative;justify-content:center}.site-brand{position:absolute;left:50%;transform:translateX(-50%)}.sidebar-menu-toggle{position:absolute;left:var(--space-4)}.header-menu-toggle{position:absolute;right:var(--space-4)}.theme-toggle--desktop{display:none}.theme-toggle--mobile{display:inline-flex;position:absolute;right:calc(var(--space-4) + 38px + .25rem);top:50%;transform:translateY(-50%)}.theme-toggle--mobile:hover{transform:translateY(-50%)rotate(20deg)}.header-menu{position:fixed;top:var(--header-h);right:0;width:280px;max-width:85%;height:calc(100vh - var(--header-h));background:linear-gradient(180deg,var(--sidebar-bg) 0%,color-mix(in srgb,var(--sidebar-bg) 88%,black) 100%);display:flex;flex-direction:column;align-items:stretch;gap:0;transform:translateX(100%);transition:transform .3s ease;z-index:2000;padding:0;border-left:1px solid rgba(255,255,255,5%);overflow-y:auto;font-size:.95rem}@supports not (background:color-mix(in srgb,red 50%,blue)){.header-menu{background:var(--sidebar-bg)}}.header-menu.open{transform:translateX(0)}.header-menu>a{position:relative;display:flex;align-items:center;width:100%;min-height:var(--drop-item-h);padding:.65rem 1rem .65rem calc(var(--space-4) + 4px);background:0 0;color:var(--gray-200);font-size:.95rem;font-weight:400;text-decoration:none;border:none;border-bottom:1px solid rgba(255,255,255,6%);transition:background .18s ease,color .18s ease,padding-left .2s ease}.header-menu>a::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:0 0;transition:background .2s ease,box-shadow .2s ease}.header-menu>a:hover{background:linear-gradient( 90deg,rgba(167,139,250,.1) 0%,transparent 60% );color:var(--color-white);text-decoration:none;padding-left:calc(var(--space-4) + 8px)}.header-menu>a:hover::before{background:rgba(167,139,250,.45)}.header-menu-search{width:auto;margin:0;padding:1rem var(--space-4).85rem;order:-1;border-bottom:1px solid rgba(255,255,255,6%)}.header-menu-search input{width:100%;background:rgba(255,255,255,6%);border:1px solid rgba(255,255,255,.1);color:var(--color-white);padding:.65rem .8rem;font-size:16px;border-radius:var(--radius-md)}#search-results{position:static;margin-top:.5rem;box-shadow:none;background:rgba(255,255,255,4%);border-color:rgba(255,255,255,.1)}.search-item{color:var(--color-white);border-bottom-color:rgba(255,255,255,5%)}@media(max-width:400px){.theme-toggle--mobile{width:34px;height:34px;right:calc(var(--space-4) + 34px + .2rem)}.theme-toggle--mobile .theme-icon{width:16px;height:16px}}}html[data-theme=dark] .header-menu-search input{background:rgba(255,255,255,8%);border-color:rgba(255,255,255,.18);color:var(--color-white)}html[data-theme=dark] .header-menu-search input::placeholder{color:rgba(255,255,255,.55)}html[data-theme=dark] .header-menu-search input:focus{border-color:#a78bfa;box-shadow:0 0 0 3px rgba(167,139,250,.22)}html[data-theme=dark] #search-results{background:var(--surface-1);border-color:var(--border);box-shadow:0 10px 25px rgba(0,0,0,.6)}html[data-theme=dark] .search-item{background-color:var(--surface-1);border-bottom-color:var(--border-subtle)}html[data-theme=dark] .search-item:hover{background:var(--surface-2);color:#a78bfa}html[data-theme=dark] .search-title{color:var(--text-strong) !important}html[data-theme=dark] .search-excerpt{color:var(--text-soft)}html[data-theme=dark] .search-excerpt mark{background:#fbbf24;color:var(--slate-900)}.container{max-width:100%;margin-inline:auto;padding-inline:clamp(1rem,6vw,6rem);box-sizing:border-box}.hero{background:linear-gradient(111deg,var(--brand-100) 0%,#f7f7fb 55%,var(--color-white) 100%);padding:clamp(3rem,6vw,5rem)0}.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,4vw,3rem);align-items:center}.hero-left h1{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;margin-bottom:1rem;line-height:1.2}.hero-left h1 span{text-decoration:underline}.hero-desc{max-width:520px;color:var(--slate-600);margin-bottom:2.2rem;line-height:1.6;font-size:1rem}.hero-features{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.6rem 2.2rem;margin-bottom:2.5rem}.feature{display:flex;gap:.75rem;align-items:flex-start}.feature-icon svg{width:22px;height:22px;fill:var(--brand-800);margin-top:2px;flex-shrink:0}.feature h5{font-size:1rem;font-weight:700;margin:0}.feature p{margin-top:.25rem;font-size:.9rem;color:var(--text-muted)}.hero-cta{display:inline-block;padding:.75rem 1.8rem;border-radius:var(--radius-pill);background:var(--brand-800);color:var(--color-white);font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease}.hero-cta:hover{background:#3a2aa3;transform:translateY(-1px)}.hero-right img{max-width:100%;height:auto;display:block}.hero-search{background:#2b0a6b;padding:clamp(2rem,5vw,3rem)0}.hero-search-inner{max-width:1400px;margin-inline:auto;padding-inline:clamp(1rem,6vw,6rem);display:grid;grid-template-columns:1fr 1.4fr;align-items:center;gap:clamp(1.5rem,4vw,3rem);box-sizing:border-box}.hero-search-box{background:#dbeafe;padding:1rem;border-radius:var(--space-2);position:relative}.hero-search-box input{width:100%;padding:.8rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--accent-blue-light);font-size:1rem;outline:none;background:var(--color-white)}.hero-search-box input::placeholder{color:var(--text-muted)}.hero-search-box input:disabled{cursor:not-allowed;opacity:.9}.hero-search-text{color:var(--color-white)}#hero-search-results{position:absolute;top:calc(100% + 8px);left:0;width:100%;background:var(--color-white);border-radius:var(--radius-md);box-shadow:0 12px 30px rgba(0,0,0,.15);max-height:420px;overflow-y:auto;z-index:1000;display:none}#hero-search-results.has-results{display:block}.featured-articles{padding:clamp(3rem,6vw,5rem)0;background:var(--color-white)}.featured-articles .section-title,.tutorials .section-title{font-size:clamp(1.4rem,3vw,1.6rem);font-weight:800;margin-bottom:2.5rem;display:flex;align-items:center;gap:.5rem;color:var(--slate-900)}.featured-articles .section-title span,.tutorials .section-title span{color:var(--accent-violet);font-weight:900}.featured-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem}.featured-card{background:var(--color-white);border-radius:var(--space-2);overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,6%);transition:transform .25s ease,box-shadow .25s ease}.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.featured-image{position:relative;aspect-ratio:16/9;display:block}.featured-image img{width:100%;height:270px;object-fit:cover;display:block}.featured-tags{position:absolute;bottom:10px;left:10px;display:flex;flex-wrap:wrap;gap:6px}.featured-tags span{background:var(--color-white);color:#1e1b4b;font-size:.7rem;font-weight:700;padding:4px 8px;border-radius:4px;text-transform:uppercase}.featured-content{padding:1rem 1rem 1.4rem}.featured-content h3{font-size:1rem;line-height:1.4;margin:0 0 .5rem}.featured-content h3 a{color:var(--slate-900);text-decoration:none;transition:color .2s ease}.featured-content h3 a:hover{color:var(--accent-violet)}.featured-content time{font-size:.8rem;color:var(--text-muted)}.testimonials{background:linear-gradient(135deg,#2b0a6b,#2e1065);padding:4.5rem 1.5rem;position:relative;overflow:hidden}.testimonials::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,4%) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,4%) 1px,transparent 1px);background-size:80px 80px;opacity:.3}.testimonials-title{text-align:center;color:var(--color-white);font-size:1.9rem;font-weight:800;margin-bottom:var(--space-7)}.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:var(--space-7)}.testimonial-card{background:var(--color-white);border-radius:var(--radius-md);padding:1.8rem 2rem 2.2rem;position:relative;box-shadow:0 20px 40px rgba(0,0,0,.15)}.testimonial-text{margin:0;color:var(--gray-800);font-size:1rem;line-height:1.6}.testimonial-author{display:block;margin-top:1.2rem;font-weight:700;color:#1e1b4b}.quote-mark{position:absolute;bottom:16px;right:20px;font-size:4rem;line-height:1;color:var(--border);font-weight:900}.testimonials-cta{text-align:center;margin-bottom:30px}.tutorials{padding:clamp(3rem,6vw,5rem)0;background:var(--color-white)}.tutorials-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2rem}.tutorial-card{background:linear-gradient( 180deg,var(--color-white) 0%,var(--color-white) 40%,#eef4ff 100% );border-radius:var(--radius-lg);border:1px solid var(--border);padding:2.2rem 1.6rem 2rem;text-align:center;position:relative;box-shadow:0 12px 28px rgba(0,0,0,6%);transition:transform .25s ease,box-shadow .25s ease}.tutorial-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.1)}.tutorial-image{height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem}.tutorial-image img{max-height:120px;max-width:240px;width:auto;height:auto;object-fit:contain}.tutorial-card h3{margin:.6rem 0 .5rem;font-size:1.05rem;font-weight:800;line-height:1.3;color:var(--slate-900)}.tutorial-card p{font-size:.9rem;color:var(--slate-600);line-height:1.5;margin-bottom:1.6rem}.tutorial-btn{display:inline-block;background:var(--brand-900);color:var(--color-white);padding:.75rem 2rem;border-radius:var(--radius-pill);font-weight:700;text-decoration:none;transition:background .2s ease,transform .2s ease}.tutorial-btn:hover{background:#3a1a8a;transform:translateY(-1px)}@media(max-width:1200px){.tutorials-grid{grid-template-columns:repeat(3,1fr)}#hero-search-results{width:100%;max-height:400px}}@media(min-width:1200px){#hero-search-results{left:50%;transform:translateX(-50%);width:720px;max-width:90vw}}@media(max-width:992px){.hero-inner{grid-template-columns:1fr;text-align:center}.hero-desc{margin-inline:auto}.hero-features{justify-items:start;max-width:520px;margin-inline:auto}.hero-cta{margin-inline:auto}.hero-right{order:-1;margin-bottom:2rem;display:flex;justify-content:center}.hero-right img{margin-inline:auto}.hero-search-inner{grid-template-columns:1fr;text-align:center}.hero-search-text,.hero-search-box{max-width:520px;margin-inline:auto}.featured-grid{grid-template-columns:repeat(2,1fr)}.featured-image img{height:220px}.tutorials-grid{grid-template-columns:repeat(2,1fr)}.testimonials-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:576px){.hero{padding:3rem 0}.hero-left h1{font-size:1.9rem}.hero-features{grid-template-columns:1fr;gap:1.4rem;justify-items:center;text-align:center}.feature{flex-direction:column;align-items:center;text-align:center}.feature h5{font-size:.95rem}.feature p{font-size:.85rem}.feature-icon svg{margin-top:0}.hero-right{justify-content:center}.hero-right img{max-width:90%}.hero-search{padding:2rem 0}.hero-search-box{padding:.75rem}.hero-search-box input{font-size:.95rem}.featured-grid{grid-template-columns:1fr}.featured-image img{height:200px}.featured-articles .section-title,.tutorials .section-title{margin-bottom:2rem}.tutorials-grid{grid-template-columns:1fr}.tutorial-image{height:100px}.tutorial-image img{max-height:100px}.testimonials-grid{grid-template-columns:1fr}}html[data-theme=dark] .hero{background:linear-gradient(111deg,#1a0a3a 0%,var(--slate-900) 55%,var(--slate-800) 100%)}html[data-theme=dark] .hero-desc{color:var(--text-soft)}html[data-theme=dark] .feature p{color:var(--text-muted)}html[data-theme=dark] .feature-icon svg{fill:#a78bfa}html[data-theme=dark] .featured-articles{background:0 0}html[data-theme=dark] .featured-card{background:var(--surface-1);box-shadow:0 8px 24px rgba(0,0,0,.4)}html[data-theme=dark] .featured-card:hover{box-shadow:0 14px 30px rgba(0,0,0,.55)}html[data-theme=dark] .featured-content h3 a{color:var(--text-strong)}html[data-theme=dark] .featured-content h3 a:hover{color:#a78bfa}html[data-theme=dark] .featured-content time{color:var(--text-muted)}html[data-theme=dark] .featured-tags span{background:rgba(255,255,255,.1);color:var(--gray-100)}html[data-theme=dark] .featured-articles .section-title,html[data-theme=dark] .tutorials .section-title{color:var(--text-strong)}html[data-theme=dark] .featured-articles .section-title span,html[data-theme=dark] .tutorials .section-title span{color:#a78bfa}html[data-theme=dark] .tutorials{background:0 0}html[data-theme=dark] .tutorial-card{background:linear-gradient(180deg,var(--surface-1) 0%,var(--surface-1) 40%,var(--slate-700) 100%);border-color:var(--border);box-shadow:0 12px 28px rgba(0,0,0,.4)}html[data-theme=dark] .tutorial-card:hover{box-shadow:0 18px 40px rgba(0,0,0,.55)}html[data-theme=dark] .tutorial-card h3{color:var(--text-strong)}html[data-theme=dark] .tutorial-card p{color:var(--text-soft)}:root{--bp-sm:576px;--bp-md:768px;--bp-lg:992px;--bp-xl:1200px;--header-h:56px;--drop-item-h:44px;--shell-max:140rem;--content-max:56rem;--left-w:320px;--right-w:320px;--gap:clamp(1rem, 1.8vw, 2rem);--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-7:3rem;--space-8:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow-md:0 4px 12px rgba(0,0,0,.08);--shadow-lg:0 14px 30px rgba(0,0,0,.10);--shadow-xl:0 20px 40px rgba(0,0,0,.15);--color-white:#ffffff;--color-black:#000000;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--brand-50:#eef2ff;--brand-100:#dcdcf7;--brand-700:#4c1d95;--brand-800:#2b1d6f;--brand-900:#1e044d;--accent-green:#10b981;--accent-green-dark:#047857;--accent-blue:#2563eb;--accent-blue-light:#3b82f6;--accent-violet:#6d28d9;--accent-red:#c82231;--bg-main:#f5f7fb;--bg-article:var(--color-white);--surface-1:var(--slate-50);--surface-2:var(--slate-100);--text:var(--gray-900);--text-strong:var(--slate-900);--text-muted:var(--slate-500);--text-soft:var(--slate-600);--text-invert:var(--gray-200);--border:var(--gray-200);--border-subtle:var(--slate-100);--border-strong:var(--slate-300);--link:#0b57d0;--link-hover:var(--accent-blue);--link-article:var(--accent-blue);--header-bg:var(--brand-900);--header-text:var(--gray-200);--header-link:#c7d2fe;--nav-bg:var(--color-white);--nav-border:var(--gray-200);--nav-link:var(--brand-900);--nav-link-hover:var(--accent-violet);--nav-active-bg:var(--brand-50);--sidebar-bg:var(--slate-800);--sidebar-border:var(--slate-700);--sidebar-hover:#273445;--tip-bg:var(--slate-900);--tip-fg:var(--color-white);--muted:var(--text-muted)}@font-face{font-family:inter;src:url(/fonts/inter-subset.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:inter;src:url(/fonts/inter-italic-subset.woff2)format("woff2");font-weight:100 900;font-style:italic;font-display:swap}*,*::before,*::after{box-sizing:border-box}html{font-size:100%;-webkit-text-size-adjust:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Arial,sans-serif;line-height:1.6;background:var(--bg-main);color:var(--text)}a{color:var(--link);text-decoration:none;word-break:break-word}a:hover{text-decoration:underline}.shell{width:100%}.shell-full{max-width:none;padding:0}.page-grid{display:grid;grid-template-columns:minmax(220px,var(--left-w))minmax(0,1fr)minmax(220px,var(--right-w));align-items:start;margin-top:clamp(1rem,2vw,2rem)}.page-grid>*{min-width:0}.right-sidebar{padding-left:var(--gap);position:sticky;top:0}.video-ad-slot{max-width:100%;margin:var(--space-5)0;overflow:hidden}.video-ad-slot>div{width:100% !important;max-width:100% !important;height:auto !important;max-height:none !important}.video-ad-slot iframe,.video-ad-slot video{width:100% !important;height:auto !important}@media(max-width:1200px){.right-sidebar{display:none}.page-grid{grid-template-columns:var(--left-w)minmax(0,1fr)}}@media(max-width:992px){.page-grid{grid-template-columns:minmax(220px,320px)minmax(0,1fr)}}@media(max-width:768px){.page-grid{grid-template-columns:1fr;margin-top:.4rem}.shell{padding-inline:var(--space-4)}.video-ad-slot{display:none !important}}@media(min-width:1200px){.layout-full .article{padding-inline:var(--space-8)}}.site-navigation{background:var(--nav-bg);border-bottom:1px solid var(--nav-border)}.site-navigation .nav-wrapper{position:relative;display:flex;align-items:center;padding:.5rem 1.5rem}.site-navigation .nav-inner{display:flex;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;white-space:nowrap;flex:1;scrollbar-width:none;position:relative;z-index:1}.site-navigation .nav-inner::-webkit-scrollbar{display:none}.site-navigation .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:50;width:34px;height:34px;border:0;border-radius:var(--radius-pill);cursor:pointer;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.15);border:1px solid rgba(0,0,0,8%);background:var(--nav-bg);color:var(--brand-700);pointer-events:auto;transition:background .2s ease,box-shadow .2s ease,transform .15s ease}.site-navigation .nav-arrow:hover{background:var(--brand-700);color:var(--color-white);box-shadow:0 6px 16px rgba(76,29,149,.35);transform:translateY(-50%)scale(1.05)}.site-navigation .nav-left{left:6px}.site-navigation .nav-right{right:6px}.site-navigation .nav-link{position:relative;padding:5px 15px;font-weight:600;color:var(--nav-link);text-decoration:none;transition:all .25s ease}.site-navigation .nav-link:not(:last-child)::after{content:"";position:absolute;right:0;top:30%;height:40%;width:1px;background:rgba(0,0,0,.1)}.site-navigation .nav-link:hover{color:var(--nav-link-hover);background:var(--nav-active-bg);border-radius:var(--radius-sm)}.site-navigation .nav-link::before{content:"";position:absolute;bottom:6px;left:50%;width:0;height:2px;background:var(--nav-link-hover);transition:all .25s ease;transform:translateX(-50%)}html[data-theme=dark] .site-navigation .nav-arrow{background:var(--surface-2);border-color:rgba(255,255,255,8%);color:#a78bfa}html[data-theme=dark] .site-navigation .nav-arrow:hover{background:var(--accent-violet);color:var(--color-white)}html[data-theme=dark] .site-navigation .nav-link:not(:last-child)::after{background:rgba(255,255,255,8%)}.site-navigation .nav-link:hover::before{width:50%}.nav-fade-right{opacity:0;transition:opacity .2s ease}.nav-fade-right.is-visible{opacity:1}.page-container{max-width:1800px;margin:2.5rem auto;padding:2.5rem 2rem;background:var(--bg-article);border-radius:var(--space-2);line-height:1.75}.related-posts{margin-top:var(--space-7);margin-bottom:var(--space-6);overflow:hidden}.related-posts h2{margin:0 0 1.25rem;font-size:1.2rem;font-weight:800;color:var(--text-strong)}.related-scroll{display:flex;gap:16px;overflow-x:auto;overflow-y:hidden;padding-bottom:10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.related-scroll::-webkit-scrollbar{height:6px}.related-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.related-card{flex:0 0 240px;width:240px;text-decoration:none;color:inherit;scroll-snap-align:start}.related-card-image{width:100%;height:150px;overflow:hidden;border-radius:var(--radius-md)}.related-card-image img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}.related-card:hover img{transform:scale(1.08)}.related-card h3{font-size:.95rem;font-weight:600;margin-top:8px;line-height:1.4;color:var(--text-strong);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.related-card:hover h3{color:var(--accent-green)}@media(max-width:992px){.related-card{flex:0 0 220px}.related-card-image{height:130px}}@media(max-width:576px){.related-posts{padding:1.25rem}.related-posts h2{font-size:1.1rem}.related-scroll{gap:14px}.related-card{flex:0 0 190px}.related-card-image{height:120px}.related-card h3{font-size:.9rem}}.glc-search-modal-body .gsc-control-cse,.glc-search-modal-body .gsc-control-wrapper-cse,.glc-search-modal-body .gsc-resultsbox-visible,.glc-search-modal-body .gsc-wrapper{width:100% !important;max-width:none !important}.glc-search-modal-body .gsc-above-wrapper-area{max-width:none !important;width:100% !important}.glc-search-overlay[hidden]{display:none !important}.glc-search-overlay{position:fixed;inset:0;z-index:9999}.glc-search-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}.glc-search-modal{position:relative;width:min(1100px,calc(100vw - 32px));max-height:calc(100vh - 60px);margin:30px auto;background:var(--bg-article);border-radius:14px;box-shadow:0 24px 80px rgba(0,0,0,.22);overflow:hidden;display:flex;flex-direction:column}.glc-search-modal-header{padding:20px 24px 12px;border-bottom:1px solid var(--border)}.glc-search-modal-header h2{margin:0 0 6px;font-size:1.25rem;color:var(--text-strong)}.glc-search-query-text{margin:0;font-size:.95rem;color:var(--text-soft)}.glc-search-modal-body{padding:16px 24px 24px;overflow:auto;max-height:70vh}.glc-search-close{position:absolute;top:12px;right:12px;z-index:2;width:42px;height:42px;border:0;border-radius:var(--radius-pill);background:var(--surface-2);color:var(--text);cursor:pointer;font-size:1.5rem;line-height:1}.search-overlay-open{overflow:hidden}.glc-search-field{display:flex;gap:10px;align-items:center}.glc-search-input{width:100%}.glc-search-button{flex:none;white-space:nowrap}@media(max-width:768px){.glc-search-modal{width:calc(100vw - 16px);max-height:calc(100vh - 16px);margin:8px auto;border-radius:var(--radius-md)}.glc-search-modal-header,.glc-search-modal-body{padding-left:16px;padding-right:16px}.glc-search-field{flex-direction:column;align-items:stretch}.glc-search-button{width:100%}}.left-sidebar{position:sticky;top:0;padding-right:var(--gap)}.right-sidebar{contain:layout paint}.right-sidebar *{max-width:100%;box-sizing:border-box}.right-sidebar img,.right-sidebar video,.right-sidebar iframe,.right-sidebar pre,.right-sidebar code{max-width:100%;overflow-wrap:break-word}.sidebar-menu{height:100vh;overflow-y:hidden;overflow-x:hidden;background:linear-gradient(180deg,var(--sidebar-bg) 0%,color-mix(in srgb,var(--sidebar-bg) 88%,black) 100%);font-size:.95rem;font-weight:400;scrollbar-width:none;position:relative}@supports not (background:color-mix(in srgb,red 50%,blue)){.sidebar-menu{background:var(--sidebar-bg)}}.sidebar-menu:hover{overflow-y:auto}.sidebar-menu ul{list-style:none;margin:0;padding:0}.sidebar-menu ul li{margin:0}.sidebar-link{position:relative;box-sizing:border-box;font-family:inherit;display:flex;align-items:center;width:100%;min-width:0;min-height:var(--drop-item-h);padding:.65rem 1rem .65rem calc(var(--space-4) + 4px);background:0 0;color:var(--gray-200);font-size:.95rem;font-weight:400;text-decoration:none;cursor:pointer;border:none;border-bottom:1px solid rgba(255,255,255,6%);transition:background .18s ease,color .18s ease,padding-left .2s ease}.sidebar-link::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:0 0;transition:background .2s ease,box-shadow .2s ease}.sidebar-link:hover{background:linear-gradient( 90deg,rgba(167,139,250,.1) 0%,transparent 60% );color:var(--color-white);text-decoration:none;padding-left:calc(var(--space-4) + 8px)}.sidebar-link:hover::before{background:rgba(167,139,250,.45)}.sidebar-link.is-active{color:var(--color-white);text-decoration:none;border-bottom-color:transparent;background:linear-gradient( 90deg,rgba(167,139,250,.18) 0%,rgba(167,139,250,4%) 60%,transparent 100% );font-weight:500}.sidebar-link.is-active::before{background:linear-gradient(180deg,#a78bfa 0%,var(--accent-violet) 100%);box-shadow:0 0 14px rgba(167,139,250,.45)}.sidebar-menu ul li{margin:0}.sidebar-link .menu-text{flex:auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.sidebar-group-toggle .menu-text{margin-right:1.8rem}.sidebar-submenu .menu-text{max-width:calc(100% - .5rem)}.sidebar-group-toggle{position:relative;display:flex;align-items:center;font-family:inherit}.sidebar-group-toggle::after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%);border-left:5px solid var(--gray-200);border-top:5px solid transparent;border-bottom:5px solid transparent;transition:transform .25s ease,border-left-color .25s ease}.sidebar-group.open>.sidebar-group-toggle::after{transform:translateY(-50%)rotate(90deg);border-left-color:#a78bfa}.sidebar-submenu-wrapper{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows .35s ease;border-left:2px solid transparent;margin-left:12px}.sidebar-group.open .sidebar-submenu-wrapper{grid-template-rows:1fr;border-left-color:var(--accent-violet)}.sidebar-submenu{min-height:0;background:rgba(0,0,0,.18);min-width:0}.sidebar-submenu .sidebar-link{min-height:40px;padding:.6rem 1.5rem .6rem calc(1.5rem + 4px);font-size:.9rem;font-weight:400;color:var(--gray-100);background:0 0;border-bottom:1px solid rgba(255,255,255,4%)}.sidebar-submenu .sidebar-link:hover{background:rgba(167,139,250,8%);color:var(--color-white);padding-left:calc(1.5rem + 8px)}.sidebar-submenu .sidebar-link.is-active{background:linear-gradient( 90deg,rgba(16,185,129,.18) 0%,rgba(16,185,129,4%) 60%,transparent 100% );color:var(--color-white)}.sidebar-submenu .sidebar-link.is-active::before{background:linear-gradient(180deg,#34d399 0%,var(--accent-green) 100%);box-shadow:0 0 12px rgba(16,185,129,.4)}.sidebar-menu::-webkit-scrollbar{width:0}@media(max-width:768px){.left-sidebar{position:fixed;top:var(--header-h);left:0;width:280px;height:calc(100vh - var(--header-h));background:var(--sidebar-bg);transform:translateX(-100%);transition:transform .3s ease;z-index:900;overflow-y:auto;padding-right:0}.left-sidebar.open{transform:translateX(0)}}html[data-theme=dark] .sidebar-link{border-bottom-color:rgba(255,255,255,4%)}html[data-theme=dark] .sidebar-submenu{background:rgba(255,255,255,2%)}html[data-theme=dark] .sidebar-submenu .sidebar-link{border-bottom-color:rgba(255,255,255,3%)}.bg{color:#f8f8f2;background-color:#282a36}.chroma{color:#f8f8f2;background-color:#282a36}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#3d3f4a}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}.chroma .line{display:flex}.chroma .k{color:#ff79c6}.chroma .kc{color:#ff79c6}.chroma .kd{color:#8be9fd}.chroma .kn{color:#ff79c6}.chroma .kp{color:#ff79c6}.chroma .kr{color:#ff79c6}.chroma .kt{color:#8be9fd}.chroma .na{color:#50fa7b}.chroma .nc{color:#50fa7b}.chroma .nl{color:#8be9fd}.chroma .nt{color:#ff79c6}.chroma .nb{color:#8be9fd}.chroma .bp{font-style:italic}.chroma .nv{color:#8be9fd}.chroma .vc{color:#8be9fd}.chroma .vg{color:#8be9fd}.chroma .vi{color:#8be9fd}.chroma .vm{color:#8be9fd}.chroma .nf{color:#50fa7b}.chroma .fm{color:#50fa7b}.chroma .s{color:#f1fa8c}.chroma .sa{color:#f1fa8c}.chroma .sb{color:#f1fa8c}.chroma .sc{color:#f1fa8c}.chroma .dl{color:#f1fa8c}.chroma .sd{color:#f1fa8c}.chroma .s2{color:#f1fa8c}.chroma .se{color:#f1fa8c}.chroma .sh{color:#f1fa8c}.chroma .si{color:#f1fa8c}.chroma .sx{color:#f1fa8c}.chroma .sr{color:#f1fa8c}.chroma .s1{color:#f1fa8c}.chroma .ss{color:#f1fa8c}.chroma .m{color:#bd93f9}.chroma .mb{color:#bd93f9}.chroma .mf{color:#bd93f9}.chroma .mh{color:#bd93f9}.chroma .mi{color:#bd93f9}.chroma .il{color:#bd93f9}.chroma .mo{color:#bd93f9}.chroma .o{color:#ff79c6}.chroma .ow{color:#ff79c6}.chroma .c{color:#6272a4}.chroma .ch{color:#6272a4}.chroma .cm{color:#6272a4}.chroma .c1{color:#6272a4}.chroma .cs{color:#6272a4}.chroma .cp{color:#ff79c6}.chroma .cpf{color:#ff79c6}.chroma .gd{color:#f55}.chroma .ge{text-decoration:underline}.chroma .gh{font-weight:700}.chroma .gi{color:#50fa7b;font-weight:700}.chroma .go{color:#44475a}.chroma .gu{font-weight:700}.chroma .gl{text-decoration:underline}.article-toc{background:var(--bg-article);border:1px solid var(--border);border-left:4px solid var(--accent-green);border-radius:12px;padding:1.25rem;padding-right:.25rem;margin:var(--space-6)0;box-shadow:var(--shadow-sm);max-height:500px;overflow-y:auto}.article-toc h2{font-size:1.1rem;font-weight:700;color:var(--text-strong);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.article-toc h2::before{content:"";display:inline-block;width:18px;height:18px;background-color:var(--accent-green);mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='12' x2='21' y2='12'%3E%3C/line%3E%3Cline x1='8' y1='18' x2='21' y2='18'%3E%3C/line%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'%3E%3C/line%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'%3E%3C/line%3E%3C/svg%3E")no-repeat center;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='12' x2='21' y2='12'%3E%3C/line%3E%3Cline x1='8' y1='18' x2='21' y2='18'%3E%3C/line%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'%3E%3C/line%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'%3E%3C/line%3E%3C/svg%3E")no-repeat center}.article-toc ul{list-style:none;padding-left:0;margin:0}.article-toc ul ul{padding-left:1.25rem;margin-top:.25rem;border-left:1px solid var(--border-subtle)}.article-toc li{margin-bottom:.5rem}.article-toc a{text-decoration:none;color:var(--text-soft);font-size:.95rem;font-weight:400;transition:all .2s ease;display:inline-block}.article-toc a:hover{color:var(--accent-green);transform:translateX(4px)}.article-toc strong,.article-toc b{font-weight:400 !important}.article-toc::-webkit-scrollbar{width:6px}.article-toc::-webkit-scrollbar-track{background:0 0}.article-toc::-webkit-scrollbar-thumb{background-color:var(--border-strong);border-radius:var(--radius-pill)}.article-toc::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}@media(max-width:576px){.article-toc{padding:var(--space-4);border-radius:var(--space-2);max-height:240px}}.hidden{display:none !important}.m0{margin:0 !important}.mt8{margin-top:8px !important}.ad-300x600{width:300px;height:600px;background:var(--surface-1);border:2px dashed var(--slate-300);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--slate-600)}.ad-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;color:var(--text-muted)}.ad-size{font-size:1.2rem;font-weight:700}.video-wrapper{position:relative;width:100%;padding-bottom:56.25%;margin:1.5rem 0}.video-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0}@media(min-width:768px){.video-wrapper{padding-bottom:50%}}@media(min-width:992px){.video-wrapper{max-width:800px;padding-bottom:45%;margin-left:auto;margin-right:auto}}