:root{--bg: #fcfcfd;--surface: #f5f6f9;--surface-2: #ecedf2;--text: #1b1c22;--muted: #636a7a;--border: #eaebf0;--accent: #5b5bd6;--accent-ink: #ffffff;--accent-soft: #eef0fc;--accent-2: #0ea5a5;--accent-warm: #f5a524;--warn-soft: #fff6e6;--code-bg: #14152a;--code-text: #e8e8f4;--radius: 16px;--radius-sm: 10px;--maxw: 1320px;--measure: 66ch;--toc-w: 240px;--note-w: 300px;--header-h: 66px;--shadow: 0 1px 2px rgba(20,22,40,.03), 0 10px 30px rgba(20,22,40,.05);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-head: ui-rounded, "SF Pro Rounded", "Segoe UI", system-ui, var(--font);--font-read: Georgia, "Iowan Old Style", serif;color-scheme:light}[data-theme=dark]{--bg: #0f1115;--surface: #161922;--surface-2: #1d212c;--text: #e8eaed;--muted: #9aa1ac;--border: #262a33;--accent: #8b8bf0;--accent-ink: #0f1115;--accent-soft: #1c1f3a;--accent-2: #2dd4bf;--warn-soft: #2a2412;--shadow: 0 1px 2px rgba(0,0,0,.3), 0 8px 24px rgba(0,0,0,.4);color-scheme:dark}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 16px)}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,.brand,.hero h1,.article-head h1,.page-hero h1{font-family:var(--font-head);letter-spacing:-.02em}.sec-body p,.content p,.sec-body li,.content li{line-height:1.78}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--accent);color:var(--accent-ink);padding:10px 16px;border-radius:0 0 8px}.skip-link:focus{left:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.progress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:60;transition:width .1s linear}.site-header{position:sticky;top:0;z-index:50;height:var(--header-h);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--border)}.nav{max-width:var(--maxw);margin:0 auto;height:100%;display:flex;align-items:center;gap:20px;padding:0 20px}.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:17px;color:var(--text);letter-spacing:-.02em;white-space:nowrap;flex-shrink:0}.brand:hover{text-decoration:none}.brand .mark{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:16px}.brand .ai{color:var(--accent)}.nav-links{display:flex;gap:4px;margin-left:8px}.nav-links a{color:var(--text);padding:8px 12px;border-radius:8px;font-size:15px;font-weight:500}.nav-links a:hover{background:var(--surface-2);text-decoration:none}.nav-spacer{flex:1}.nav-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:38px;height:38px;border:1px solid var(--border);background:var(--surface);border-radius:9px;display:grid;place-items:center;cursor:pointer;color:var(--text);font-size:16px}.icon-btn:hover{background:var(--surface-2)}.btn{display:inline-flex;align-items:center;gap:6px;cursor:pointer;background:var(--accent);color:var(--accent-ink);border:0;padding:10px 18px;border-radius:11px;font-weight:650;font-size:14px}.btn:hover{filter:brightness(1.05);text-decoration:none}.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn.block{width:100%;justify-content:center}.nav-toggle{display:none}.breadcrumbs{max-width:var(--maxw);margin:0 auto;padding:14px 20px 0;font-size:13px;color:var(--muted);white-space:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.breadcrumbs::-webkit-scrollbar{display:none}.breadcrumbs a{color:var(--muted)}.breadcrumbs span{margin:0 6px;opacity:.6}.layout{max-width:var(--maxw);margin:0 auto;padding:20px;display:grid;grid-template-columns:var(--toc-w) minmax(0,1fr);gap:44px;align-items:start}.toc{position:sticky;top:calc(var(--header-h) + 20px);max-height:calc(100vh - var(--header-h) - 40px);overflow:auto;font-size:14px;padding-right:6px}.toc h2{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 10px}.toc ul{list-style:none;margin:0;padding:0;border-left:2px solid var(--border)}.toc li a{display:block;padding:6px 0 6px 14px;margin-left:-2px;color:var(--muted);border-left:2px solid transparent;font-weight:500;line-height:1.35}.toc li a:hover{color:var(--text);text-decoration:none}.toc li a.active{color:var(--accent);border-left-color:var(--accent);font-weight:600}.toc .sub a{padding-left:26px;font-size:13px;font-weight:400}.article-wrap{min-width:0}.sec{display:grid;grid-template-columns:minmax(0,1fr) var(--note-w);gap:44px;align-items:start}.sec-body{min-width:0;max-width:var(--measure)}.sec-notes{position:sticky;top:calc(var(--header-h) + 20px)}.article-head{margin-bottom:8px}.eyebrow{color:var(--accent);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.07em}.article-head h1{font-size:clamp(28px,4vw,40px);line-height:1.15;letter-spacing:-.02em;margin:8px 0 14px}.byline{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:14px;flex-wrap:wrap}.byline .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#fff;font-weight:700}.byline .dot:before{content:"•";margin:0 8px;opacity:.5}.share{display:flex;gap:8px;margin-left:auto}.share a{width:32px;height:32px;border:1px solid var(--border);border-radius:8px;display:grid;place-items:center;color:var(--muted);font-size:14px}.share a:hover{color:var(--accent);border-color:var(--accent);text-decoration:none}.sec-body :is(h2,h3){line-height:1.25;letter-spacing:-.01em;scroll-margin-top:calc(var(--header-h) + 16px)}.sec-body h2{font-size:26px;margin:0 0 14px}.sec-body h3{font-size:19px;margin:26px 0 8px}.sec-body p,.sec-body li{font-size:18px;line-height:1.72}.sec-body p{margin:0 0 18px}.sec-body ul,.sec-body ol{margin:0 0 18px;padding-left:22px}.sec-body li{margin:6px 0}.lead{font-size:20px!important;line-height:1.6!important}.lead strong{font-weight:700}.callout{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:18px 20px;margin:0 0 22px}.callout.key{border-left:4px solid var(--accent);background:var(--accent-soft)}.callout .label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:8px}.callout ul{margin:0}.table-wrap{overflow-x:auto;margin:0 0 22px;border:1px solid var(--border);border-radius:var(--radius)}table{border-collapse:collapse;width:100%;font-size:15px}th,td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--border)}thead th{background:var(--surface);font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--surface)}.fn{font-size:.7em;vertical-align:super;color:var(--accent);font-weight:700;padding:0 2px}.fn:hover{text-decoration:none}.note{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:14px 15px;margin-bottom:14px;font-size:13.5px;box-shadow:var(--shadow);transition:border-color .2s,transform .2s}.note .note-label{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.note .note-label .ic{width:18px;height:18px;border-radius:5px;display:grid;place-items:center;font-size:11px;background:var(--accent-soft);color:var(--accent)}.note p{margin:0 0 8px;line-height:1.5;color:var(--text)}.note p:last-child{margin:0}.note.ref .ic{background:color-mix(in srgb,var(--accent-2) 18%,transparent);color:var(--accent-2)}.note.cta{background:linear-gradient(160deg,var(--accent-soft),var(--bg));border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.note.related .ic{background:var(--warn-soft);color:#c08400}.note ul{margin:0;padding-left:16px}.note ul li{margin:4px 0}.sec.is-active .sec-notes .note{border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.sec:not(.is-active) .sec-notes{opacity:.72}.faq details{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;background:var(--surface)}.faq summary{cursor:pointer;padding:14px 16px;font-weight:600;font-size:16px;list-style:none;display:flex;justify-content:space-between;gap:12px}.faq summary::-webkit-details-marker{display:none}.faq summary:after{content:"+";color:var(--accent);font-weight:700}.faq details[open] summary:after{content:"–"}.faq details p{padding:0 16px 16px;margin:0;color:var(--muted);font-size:16px}.end-cta{margin-top:14px;border-radius:var(--radius);padding:26px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.end-cta h3{margin:0 0 6px;font-size:22px;color:#fff}.end-cta p{margin:0 0 16px;opacity:.92}.end-cta .btn{background:#fff;color:var(--accent)}.references{margin-top:36px;padding-top:20px;border-top:1px solid var(--border);font-size:14px;color:var(--muted)}.references ol{padding-left:20px}.site-footer{border-top:1px solid var(--border);background:var(--surface);margin-top:60px}.footer-grid{max-width:var(--maxw);margin:0 auto;padding:48px 20px 24px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}.footer-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 14px}.footer-grid ul{list-style:none;margin:0;padding:0}.footer-grid li{margin:8px 0}.footer-grid a{color:var(--text);font-size:14px}.footer-grid a:hover{color:var(--accent)}.foot-brand p{color:var(--muted);font-size:14px;max-width:34ch}.newsletter{display:flex;gap:8px;margin-top:14px;max-width:320px}.newsletter input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:9px;background:var(--bg);color:var(--text);font-size:14px}.footer-bottom{max-width:var(--maxw);margin:0 auto;padding:18px 20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:13px}.footer-bottom .socials{display:flex;gap:14px}.footer-bottom a{color:var(--muted)}@media(max-width:1180px){.sec{grid-template-columns:minmax(0,1fr)}.sec-notes{position:static;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:4px 0 26px;opacity:1!important}.sec:not(.is-active) .sec-notes{opacity:1}}@media(max-width:900px){.layout{grid-template-columns:1fr}.toc{position:static;max-height:none;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px}.toc.collapsible h2,.toc.collapsible ul{display:none}.toc.collapsible.open ul{display:block}.toc .toc-toggle{display:flex}}@media(max-width:760px){.nav-links{display:none}.nav-toggle{display:grid}.sec-notes{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.share{width:100%;margin:8px 0 0}}@media(max-width:460px){.footer-grid{grid-template-columns:1fr}.nav-actions .btn{display:none}.nav{padding-left:14px;padding-right:14px}}.mobile-menu{display:none}.mobile-menu.open{display:block;position:fixed;inset:var(--header-h) 0 0;background:var(--bg);z-index:40;padding:16px 20px}.mobile-menu a{display:block;padding:14px 0;border-bottom:1px solid var(--border);color:var(--text);font-size:17px;font-weight:500}.toc-toggle{display:none;width:100%;justify-content:space-between;background:none;border:0;color:var(--text);font-weight:600;cursor:pointer;align-items:center;font-size:14px;padding:0}.content{min-width:0;max-width:760px}.content :is(h2,h3){scroll-margin-top:calc(var(--header-h) + 16px);line-height:1.25}.content h2{font-size:26px;margin:38px 0 14px}.content h3{font-size:19px;margin:24px 0 8px}.content p,.content li{font-size:18px;line-height:1.72}.content table{display:block;max-width:100%;overflow-x:auto}.content pre{max-width:100%;overflow-x:auto}.content img,.content svg,.content figure{max-width:100%}.content{overflow-wrap:break-word}.content p{margin:0 0 18px}.page-hero{max-width:var(--maxw);margin:0 auto;padding:26px 20px 8px}.page-hero .eyebrow{color:var(--accent);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.07em}.page-hero h1{font-size:clamp(28px,4vw,40px);line-height:1.12;letter-spacing:-.02em;margin:8px 0 12px;max-width:20ch}.page-hero .byline{display:flex;gap:12px;color:var(--muted);font-size:14px;flex-wrap:wrap;align-items:center}.verdict{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--radius);background:var(--accent-soft);padding:18px 20px;margin:0 0 24px}.verdict .score{text-align:center}.verdict .score b{font-size:34px;line-height:1;color:var(--accent)}.verdict .score small{display:block;color:var(--muted);font-size:12px}.verdict .label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:4px}.stars{color:var(--accent);letter-spacing:2px}.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 0 24px}.proscons>div{border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;background:var(--surface)}.proscons h4{margin:0 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.05em}.proscons .pros h4{color:#16a34a}.proscons .cons h4{color:#dc2626}.proscons ul{margin:0;padding-left:20px}.proscons li{margin:6px 0;font-size:15px}@media(max-width:600px){.proscons{grid-template-columns:1fr}}.item{border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin:0 0 18px;background:var(--bg);scroll-margin-top:calc(var(--header-h) + 16px)}.item-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.rank{width:34px;height:34px;border-radius:9px;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;font-weight:800;flex:none}.item-head h3{margin:0;font-size:20px}.item-head .tag{margin-left:auto;font-size:12px;color:var(--muted);border:1px solid var(--border);padding:3px 9px;border-radius:999px}.item .meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin:8px 0}.item .meta b{color:var(--text)}.item-shot{margin:14px 0 0}.item-shot img{display:block;width:100%;height:auto;border-radius:10px;border:1px solid var(--border)}.chips{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 24px}.chips a{font-size:13px;border:1px solid var(--border);border-radius:999px;padding:6px 13px;color:var(--text);background:var(--surface)}.chips a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.compare{width:100%;border-collapse:collapse;margin:0 0 24px;font-size:15px}.compare th,.compare td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.compare thead th{background:var(--surface)}.compare thead th:not(:first-child){text-align:center}.compare td:not(:first-child){text-align:center}.compare .row-label{font-weight:600;color:var(--muted)}.compare .win{background:var(--accent-soft);font-weight:600}.compare-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:0 0 26px}.stat{border:1px solid var(--border);border-radius:var(--radius);padding:18px;background:var(--surface)}.stat .num{font-size:30px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.stat .desc{font-size:14px;color:var(--text);margin:4px 0}.stat .src{font-size:12px;color:var(--muted)}.stat .src a{color:var(--muted)}@media(max-width:760px){.stat-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}}.chart{border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);height:220px;display:grid;place-items:center;color:var(--muted);font-size:14px;margin:0 0 24px}.cite{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:16px 18px;margin:24px 0}.cite code{display:block;background:var(--code-bg);color:var(--code-text);padding:12px;border-radius:8px;font-size:13px;overflow-x:auto;margin:8px 0}.cite .btn{font-size:13px;padding:7px 13px}.summary-box{border:1px solid var(--border);border-left:4px solid var(--accent-2);border-radius:var(--radius);background:var(--surface);padding:20px 22px;margin:0 0 26px}.summary-box h2{margin-top:0}.prompt{border:1px solid var(--border);border-radius:var(--radius);margin:0 0 14px;overflow:hidden;background:var(--bg)}.prompt .ptitle{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);font-weight:600;font-size:15px}.prompt .ptitle .copy{margin-left:auto;font-size:12px;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:7px;padding:6px 11px;cursor:pointer}.prompt .ptitle .copy[data-copied]{color:#16a34a;border-color:#16a34a}.prompt pre{margin:0;padding:14px;background:var(--code-bg);color:var(--code-text);font-size:13.5px;line-height:1.55;overflow-x:auto;white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.prompt .pdesc{padding:10px 14px;font-size:13px;color:var(--muted)}.tool-embed{border:2px dashed var(--accent);border-radius:var(--radius);background:var(--accent-soft);padding:28px;text-align:center;margin:0 0 26px}.tool-embed .fields{display:grid;gap:10px;max-width:520px;margin:14px auto;text-align:left}.tool-embed input,.tool-embed select,.tool-embed textarea{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:9px;background:var(--bg);color:var(--text);font:inherit}.tool-embed .out{background:var(--code-bg);color:var(--code-text);border-radius:9px;padding:14px;text-align:left;font-family:ui-monospace,monospace;font-size:13.5px;min-height:70px}.tool-embed .pg-modes{display:inline-flex;gap:6px;margin:12px 0 0;background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:4px}.tool-embed .pg-mode{border:0;background:transparent;color:var(--muted);font:inherit;font-size:13px;padding:6px 14px;border-radius:999px;cursor:pointer}.tool-embed .pg-mode.is-on{background:var(--accent);color:#fff}.tool-embed .pg-out{white-space:pre-wrap;word-break:break-word;margin:0 0 10px;max-height:420px;overflow:auto}.tool-embed .pg-copy{width:100%}.steps{counter-reset:s;list-style:none;padding:0;margin:0 0 24px}.steps li{counter-increment:s;position:relative;padding:0 0 0 46px;margin:0 0 16px;min-height:34px}.steps li:before{content:counter(s);position:absolute;left:0;top:-2px;width:32px;height:32px;border-radius:9px;background:var(--accent-soft);color:var(--accent);font-weight:800;display:grid;place-items:center}.video-embed{aspect-ratio:16/9;background:var(--code-bg);border-radius:var(--radius);display:grid;place-items:center;color:#cfd2e6;margin:0 0 18px}.video-embed .play{width:70px;height:70px;border-radius:50%;background:#ffffff24;display:grid;place-items:center;font-size:26px}.chapters{list-style:none;padding:0;margin:0 0 24px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.chapters li{display:flex;gap:14px;padding:11px 16px;border-bottom:1px solid var(--border);font-size:15px}.chapters li:last-child{border-bottom:0}.chapters .t{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600;min-width:46px}.transcript{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.transcript summary{cursor:pointer;font-weight:600}.ic{width:1.15em;height:1.15em;display:inline-block;vertical-align:middle}.icon-btn .ic{width:19px;height:19px}.brand .mark{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.brand .mark .ic{width:17px;height:17px;color:#fff}.share a .ic,.socials a .ic{width:17px;height:17px}.search-modal[aria-hidden=true]{display:none}.search-modal{position:fixed;inset:0;z-index:80;display:grid;place-items:start center;padding-top:12vh}.search-backdrop{position:absolute;inset:0;background:#080a108c;backdrop-filter:blur(2px)}.search-box{position:relative;width:min(620px,92vw);background:var(--bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 64px #0000004d;overflow:hidden}.search-in{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.search-in .ic{width:18px;height:18px;color:var(--muted)}.search-in input{flex:1;border:0;background:none;font-size:17px;color:var(--text);outline:none}.search-in kbd{font-size:11px;border:1px solid var(--border);border-radius:6px;padding:2px 6px;color:var(--muted)}.search-results{list-style:none;margin:0;padding:6px;max-height:50vh;overflow:auto}.search-results a{display:flex;justify-content:space-between;gap:12px;padding:11px 12px;border-radius:9px;color:var(--text)}.search-results a:hover{background:var(--surface-2);text-decoration:none}.search-results .r-kicker{color:var(--muted);font-size:12px;white-space:nowrap}.search-results .r-empty{padding:16px 12px;color:var(--muted)}.search-foot{padding:10px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}.search-foot .muted{opacity:.7}.back-top{position:fixed;right:22px;bottom:22px;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--text);box-shadow:var(--shadow);cursor:pointer;display:grid;place-items:center;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .2s,transform .2s;z-index:45}.back-top.show{opacity:1;transform:none;pointer-events:auto}.back-top .ic{width:20px;height:20px}.foot-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.lang-switch{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:5px 8px;font-size:13px}.footer-bottom .socials a{display:inline-grid;place-items:center}.hero-img{margin:14px 0 22px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface)}.hero-img img{display:block;width:100%;aspect-ratio:1200 / 630;object-fit:cover}.hero-img figcaption{font-size:12.5px;color:var(--muted);padding:8px 14px}.hero-img.ph{aspect-ratio:1200 / 630;display:grid;place-items:center;color:var(--muted);font-size:14px}.content figure.fig{margin:22px 0}.content figure.fig img{display:block;width:100%;height:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}.content figure.fig figcaption{font-size:12.5px;color:var(--muted);margin-top:8px;text-align:center}@media(max-width:760px){.hero-img img,.hero-img.ph{aspect-ratio:16 / 9}}.author-box{display:flex;gap:16px;align-items:flex-start;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:18px 20px;margin:34px 0 0}.author-box .avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#fff;font-weight:700;font-size:18px;flex:none}.author-box h4{margin:0 0 4px;font-size:16px}.author-box p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}.author-box .a-links{margin-top:8px;display:flex;gap:12px;font-size:13px}.related{margin:40px 0 0}.related h2{font-size:20px;margin:0 0 14px}.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.related-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);transition:border-color .2s,transform .2s;overflow:hidden}.related-card:hover{border-color:var(--accent);transform:translateY(-2px)}.related-card .body{padding:14px 16px 16px}.related-card .k{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);font-weight:700}.related-card h3{font-size:15px;margin:6px 0 0;line-height:1.35}.card-thumb{display:block;width:100%;aspect-ratio:1200 / 630;object-fit:cover;background:var(--surface);border-bottom:1px solid var(--border)}.card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.card-date{font-size:12px;color:var(--muted)}.related-card a{color:var(--text)}.related-card a:hover{text-decoration:none}@media(max-width:760px){.related-grid{grid-template-columns:1fr}}.compare td.win:after{content:" ✔";color:var(--accent);font-weight:700}@media(max-width:600px){.compare th:first-child,.compare td:first-child{position:sticky;left:0;background:var(--bg);z-index:1}}@supports not ((-webkit-background-clip: text) or (background-clip: text)){.stat .num,.hero h1 .grad{background:none!important;color:var(--accent)!important;-webkit-text-fill-color:currentColor}}.note{box-shadow:0 1px 2px #10121d0a}[data-theme=dark] .note{box-shadow:none}.icon-btn{border-radius:11px}.nav-links a{border-radius:10px}.note.cta .note-label .ic{background:color-mix(in srgb,var(--accent-warm) 20%,transparent);color:var(--accent-warm)}.end-cta{border-radius:20px}.sec-body h2,.content h2{margin-top:2px}.callout{border-radius:var(--radius)}.lead.callout.key{border-left-width:4px}.hub{max-width:var(--maxw);margin:0 auto;padding:24px 20px 0}.hub-head{max-width:720px;margin:8px 0 28px}.hub-head h1{font-size:clamp(30px,5vw,46px);line-height:1.08;margin:8px 0 12px}.hub-head p{font-size:19px;color:var(--muted);margin:0}.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.hub-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .2s,transform .2s;color:var(--text);overflow:hidden}.hub-card:hover{border-color:var(--accent);transform:translateY(-2px);text-decoration:none}.hub-card .body{padding:16px 20px 20px}.hub-card .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:700}.hub-card h3{margin:8px 0 6px;font-size:18px;line-height:1.3}.hub-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}.hub-empty{color:var(--muted);font-size:17px;padding:20px 0}.hub-cta{margin:48px 0 0;padding:32px;border-radius:20px;background:linear-gradient(135deg,var(--accent-soft),var(--bg));border:1px solid color-mix(in srgb,var(--accent) 25%,var(--border));text-align:center}.hub-cta h2{margin:0 0 6px;font-size:24px}.hub-cta p{margin:0 0 16px;color:var(--muted)}.hub-cta .newsletter{max-width:380px;margin:0 auto}@media(max-width:900px){.hub-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.hub-grid{grid-template-columns:1fr}}.content pre,.sec-body pre{position:relative}.code-copy{position:absolute;top:8px;right:8px;font-size:12px;padding:5px 10px;border-radius:7px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#e8e8f4;cursor:pointer}.code-copy:hover{background:#ffffff29}.nl-ok{margin:0;padding:12px 14px;background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:var(--radius-sm);color:var(--text);font-size:15px}.nl-err{margin:8px 0 0;font-size:13px;color:#c0392b}.draft-flag{margin:0 0 14px;padding:8px 12px;border-radius:var(--radius-sm);background:color-mix(in srgb,#f5a524 18%,var(--bg));border:1px solid color-mix(in srgb,#f5a524 45%,var(--border));font-size:13px;font-weight:600}.post-share{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:30px 0 6px;padding-top:18px;border-top:1px solid var(--border)}.post-share-label{font-size:13px;font-weight:700;color:var(--muted);margin-right:2px}.post-share-btn{font:inherit;font-size:13px;font-weight:600;padding:6px 14px;border-radius:999px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;text-decoration:none;transition:border-color .2s,color .2s}.post-share-btn:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}#pagefind{--pagefind-ui-primary: var(--accent);--pagefind-ui-text: var(--text);--pagefind-ui-background: var(--bg);--pagefind-ui-border: var(--border);--pagefind-ui-tag: var(--surface);--pagefind-ui-border-radius: 10px;--pagefind-ui-font: var(--font)}.lead-magnet{display:flex;gap:16px;align-items:flex-start;margin:28px 0 0;padding:20px 22px;border-radius:var(--radius);background:linear-gradient(160deg,var(--accent-soft),var(--bg));border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border))}.lead-magnet .lm-icon{width:40px;height:40px;flex:none;border-radius:10px;display:grid;place-items:center;font-size:18px;background:color-mix(in srgb,var(--accent-warm) 22%,transparent);color:var(--accent-warm)}.lead-magnet h3{margin:0 0 4px;font-size:18px}.lead-magnet p{margin:0 0 12px;color:var(--muted);font-size:14px}.lead-magnet .newsletter{max-width:420px}.page{max-width:720px;margin:0 auto;padding:32px 20px 8px}.page h1{font-size:clamp(28px,4vw,40px);line-height:1.14;margin:8px 0 16px}.page h2{font-size:22px;margin:28px 0 10px}.page p,.page li{font-size:18px;line-height:1.7}.page ul{padding-left:22px}.page li{margin:6px 0}
