.prose .tbl-wrap{margin:2em 0}.prose .tbl-bench{width:100%;display:grid;grid-template-columns:1.2fr 1.6fr auto;font-size:1rem}.prose .tbl-bench>div{padding:1.5rem 1.125rem 1.5rem 0;border-bottom:1px solid rgba(11,18,32,.06);align-self:center}.prose .tbl-bench>div.tbl-bench-h{padding:.875rem 1.125rem .875rem 0;font:600 .6875rem/1 JetBrains Mono,ui-monospace,monospace;color:var(--spoko-color-text-muted);letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid rgba(11,18,32,.1)}.prose .tbl-bench>div:nth-child(3n){padding-right:0;text-align:right}.prose .tbl-bench .tbl-metric{display:flex;align-items:baseline;gap:.875rem;flex-wrap:wrap}.prose .tbl-bench .tbl-metric .abbr{font-weight:700;font-size:1.05em;letter-spacing:-.01em;color:var(--spoko-color-text-default)}.prose .tbl-bench .tbl-metric .name{color:var(--spoko-color-text-muted);font-size:.9em}.prose .tbl-bench .tbl-pill{display:inline-flex;align-items:center;gap:.25rem;background:color-mix(in oklab,var(--spoko-color-accent) 8%,transparent);color:var(--spoko-color-accent);padding:.5rem .875rem;border-radius:62.5rem;font:600 .9em/1 JetBrains Mono,ui-monospace,monospace}.prose .tbl-bench .tbl-pill .lt{opacity:.6}.prose .tbl-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem}@media (max-width:45rem){.prose .tbl-stat-grid{grid-template-columns:1fr}}.prose .tbl-stat-card{position:relative;padding:1.5rem 1.375rem 1.375rem;border:1px solid rgba(11,18,32,.06);border-radius:.875rem;background:var(--spoko-color-bg-page);transition:border-color .25s,transform .25s}.prose .tbl-stat-card:hover{border-color:var(--spoko-color-accent);transform:translateY(-.125rem)}.prose .tbl-stat-card:before{content:"";position:absolute;left:1.375rem;right:1.375rem;top:0;height:2px;background:var(--spoko-color-accent);border-radius:0 0 2px 2px}.prose .tbl-stat-card .tag{font:600 .6875rem/1 JetBrains Mono,monospace;color:var(--spoko-color-accent);letter-spacing:.14em}.prose .tbl-stat-card .abbr{margin:1.125rem 0 .25rem;font-size:1.875rem;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--spoko-color-text-default)}.prose .tbl-stat-card .name{color:var(--spoko-color-text-muted);font-size:.875rem;line-height:1.4;margin:0}.prose .tbl-stat-card .desc{margin:1.125rem 0 1.375rem;color:var(--spoko-color-text-default);font-size:.90625rem;line-height:1.55;padding-top:1.125rem;border-top:1px dashed rgba(11,18,32,.06)}.prose .tbl-stat-card .threshold{display:flex;align-items:baseline;gap:.375rem;font-family:JetBrains Mono,monospace}.prose .tbl-stat-card .threshold .lbl{font-size:.625rem;color:var(--spoko-color-text-muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600}.prose .tbl-stat-card .threshold .val{margin-left:auto;font-size:1.375rem;font-weight:600;color:var(--spoko-color-text-default);letter-spacing:-.01em}.prose .tbl-stat-card .threshold .lt{color:var(--spoko-color-accent);margin-right:.125rem}.prose .tbl-rail{border-top:1px solid rgba(11,18,32,.06)}.prose .tbl-rail-head,.prose .tbl-rail-row{display:grid;grid-template-columns:13.75rem 1fr 8.125rem;gap:1.75rem}.prose .tbl-rail-head{padding:.875rem 1.375rem .875rem 1.5rem;font:600 .6875rem/1 JetBrains Mono,monospace;color:var(--spoko-color-text-muted);letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid rgba(11,18,32,.1)}.prose .tbl-rail-head>span:last-child{text-align:right}.prose .tbl-rail-row{position:relative;padding:1.375rem 1.375rem 1.375rem 1.5rem;border-bottom:1px solid rgba(11,18,32,.06);align-items:center;transition:background .2s ease}.prose .tbl-rail-row:hover{background:var(--list-hover-bg)}.prose .tbl-rail-row:before{content:"";position:absolute;left:0;top:1rem;bottom:1rem;width:2px;background:var(--spoko-color-accent);border-radius:2px;opacity:0;transition:opacity .25s}.prose .tbl-rail-row:hover:before{opacity:1}.prose .tbl-rail-row .abbr{font-weight:700;font-size:1.0625rem;letter-spacing:-.01em;color:var(--spoko-color-text-default)}.prose .tbl-rail-row .name{display:block;color:var(--spoko-color-text-muted);font-size:.875rem;margin-top:.0625rem}.prose .tbl-rail-row .measures{color:var(--spoko-color-text-default);font-size:.96875rem;line-height:1.55}.prose .tbl-rail-row .threshold{text-align:right;font:600 1.0625rem/1 JetBrains Mono,monospace;color:var(--spoko-color-text-default)}.prose .tbl-rail-row .threshold .lt{color:var(--spoko-color-accent);margin-right:.125rem}@media (max-width:45rem){.prose .tbl-rail-head{display:none}.prose .tbl-rail-row{grid-template-columns:1fr;gap:.375rem;padding:1.125rem}.prose .tbl-rail-row .threshold{text-align:left;margin-top:.25rem}}.prose .tbl-vs{display:grid;grid-template-columns:1fr 1fr;border:1px solid rgba(11,18,32,.06);border-radius:1rem;overflow:hidden;position:relative}.prose .tbl-vs:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:#0b12200f;transform:translate(-.5px)}.prose .tbl-vs-head{padding:1.125rem 1.375rem;font-weight:600;font-size:.875rem;display:flex;align-items:center;gap:.625rem;border-bottom:1px solid rgba(11,18,32,.06)}.prose .tbl-vs-head.good{background:#0f9d5814;color:#0f9d58}.prose .tbl-vs-head.bad{background:#d83a3a12;color:#d83a3a}.prose .tbl-vs-head .pip{width:1.375rem;height:1.375rem;border-radius:62.5rem;background:currentColor;display:grid;place-items:center}.prose .tbl-vs-head .pip svg{color:#fff}.prose .tbl-vs-list{display:flex;flex-direction:column}.prose .tbl-vs-item{display:flex;align-items:baseline;padding:1rem 1.375rem;color:var(--spoko-color-text-default);font-size:.9375rem;line-height:1.5;border-bottom:1px solid rgba(11,18,32,.06);transition:background .2s}.prose .tbl-vs-item:last-child{border-bottom:none}.prose .tbl-vs-item.good:hover{background:#0f9d5814}.prose .tbl-vs-item.bad:hover{background:#d83a3a12}.prose .tbl-vs-num{flex-shrink:0;font:.625rem/1 JetBrains Mono,monospace;color:var(--spoko-color-text-muted);letter-spacing:.14em;margin-right:.625rem;opacity:.7}@media (max-width:45rem){.prose .tbl-vs{grid-template-columns:1fr}.prose .tbl-vs:before{display:none}.prose .tbl-vs-head{border-top:1px solid rgba(11,18,32,.06)}.prose .tbl-vs-head:first-child{border-top:none}}.prose .tbl-tradeoff{display:flex;flex-direction:column;gap:.75rem}.prose .tbl-tradeoff-row{display:grid;grid-template-columns:1fr 2.75rem 1fr;border-radius:.875rem;overflow:hidden;border:1px solid rgba(11,18,32,.06);background:var(--spoko-color-bg-page)}.prose .tbl-tradeoff-cell{padding:1.125rem 1.375rem;font-size:.9375rem;line-height:1.5;color:var(--spoko-color-text-default);display:flex;align-items:center}.prose .tbl-tradeoff-cell.good{background:linear-gradient(90deg,rgba(15,157,88,.08),transparent 80%);border-right:1px solid rgba(11,18,32,.06)}.prose .tbl-tradeoff-cell.bad{background:linear-gradient(270deg,rgba(216,58,58,.07),transparent 80%)}.prose .tbl-tradeoff-arrow{display:grid;place-items:center;color:var(--spoko-color-text-muted);font:600 .6875rem/1 JetBrains Mono,monospace;letter-spacing:.14em;border-left:1px solid rgba(11,18,32,.06);border-right:1px solid rgba(11,18,32,.06)}@media (max-width:45rem){.prose .tbl-tradeoff-row{grid-template-columns:1fr}.prose .tbl-tradeoff-cell.good{border-right:none;border-bottom:1px solid rgba(11,18,32,.06)}.prose .tbl-tradeoff-arrow{transform:rotate(90deg);padding:.375rem;border-left:none;border-right:none;border-top:1px solid rgba(11,18,32,.06);border-bottom:1px solid rgba(11,18,32,.06)}}.prose .tbl-ledger{display:grid;grid-template-columns:1fr 1fr;gap:0 4rem}.prose .tbl-ledger-col h4{margin:0 0 .875rem;padding-bottom:.875rem;font:600 .8125rem/1.2 inherit;letter-spacing:.12em;text-transform:uppercase;color:var(--spoko-color-text-muted);border-bottom:1px solid rgba(11,18,32,.1);display:flex;align-items:center;gap:.625rem}.prose .tbl-ledger-col h4 .dot{width:.5rem;height:.5rem;border-radius:62.5rem}.prose .tbl-ledger-col.good h4 .dot{background:#0f9d58}.prose .tbl-ledger-col.bad h4 .dot{background:#d83a3a}.prose .tbl-ledger-col h4 .label-strong{color:var(--spoko-color-text-default);font-size:1.0625rem;font-weight:700;text-transform:none;letter-spacing:-.01em;margin-right:auto}.prose .tbl-ledger ul{list-style:none;margin:0;padding:0}.prose .tbl-ledger li{position:relative;padding:.875rem 0 .875rem 1.375rem;border-bottom:1px dashed rgba(11,18,32,.06);color:var(--spoko-color-text-default);font-size:.96875rem;line-height:1.5}.prose .tbl-ledger li:before{content:"";position:absolute;left:0;top:1.375rem;width:.625rem;height:1px}.prose .tbl-ledger-col.good li:before{background:#0f9d58}.prose .tbl-ledger-col.bad li:before{background:#d83a3a}.prose .tbl-ledger li:last-child{border-bottom:none}@media (max-width:45rem){.prose .tbl-ledger{grid-template-columns:1fr;gap:2rem}}html{scrollbar-gutter:stable;--list-pad-left:24px;--list-pad-right:22px;--list-pad-y:20px;--list-hover-bg:linear-gradient(90deg, color-mix(in oklab, var(--spoko-color-accent) 8%, transparent), transparent 60%)}main{overflow-x:clip}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-accent,.text-primary,[text-accent=""],[text-primary=""]{color:var(--spoko-color-accent)}.bg-page,.bg-dark,.bg-light{background-color:var(--spoko-color-bg-page)}.text-default{color:var(--spoko-color-text-default)}.text-page{color:var(--spoko-color-text-page)}.text-muted{color:var(--spoko-color-text-muted)}.post-figure{margin:1.5rem 0}.prose{counter-reset:h2-counter h3-counter}.prose h2,.prose h3:not(.insp-category-title):not(.itemgrid-title),.post-section-h2,.blog-card-title{clip-path:inset(-2em 0-2em 0)}.prose h2{margin-top:3rem;margin-bottom:1.5rem;counter-increment:h2-counter;counter-reset:h3-counter}.prose h2:before{content:"SECTION "counter(h2-counter,decimal-leading-zero);display:block;font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--spoko-color-accent);margin-bottom:.4rem;padding-left:1.75rem;background:linear-gradient(var(--spoko-color-accent),var(--spoko-color-accent)) no-repeat left center/1.25rem 1px}html[lang=pl] .prose h2:before{content:"SEKCJA "counter(h2-counter,decimal-leading-zero)}.prose h2:after{content:"";display:inline-block;vertical-align:middle;height:1px;width:9999px;margin-left:1.25rem;margin-right:calc(-9999px - 1.25rem);background:linear-gradient(90deg,var(--spoko-color-accent),transparent);transform-origin:left;transform:scaleX(1)}@supports (animation-timeline:view()){.prose h2:after{transform:scaleX(0);animation:h2-sweep-line linear both;animation-timeline:view();animation-range:entry 0%entry 40%}}@media (prefers-reduced-motion:reduce){.prose h2:after{animation:none;transform:scaleX(1)}}@keyframes h2-sweep-line{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.post-section-h2:after{content:"";display:inline-block;vertical-align:middle;height:1px;width:9999px;margin-left:1.25rem;margin-right:calc(-9999px - 1.25rem);background:linear-gradient(90deg,var(--spoko-color-accent),transparent)}.cosmic-bg{position:relative;background:var(--spoko-color-bg-page);isolation:isolate;overflow:hidden}.cosmic-bg:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 90% 60%at 50% 0%,color-mix(in oklab,var(--spoko-color-accent) 18%,transparent),transparent 65%),radial-gradient(ellipse 50% 80%at 0% 40%,color-mix(in oklab,var(--spoko-color-accent) 10%,transparent),transparent 60%),radial-gradient(ellipse 50% 80%at 100% 40%,color-mix(in oklab,var(--spoko-color-accent) 10%,transparent),transparent 60%)}.cosmic-bg:after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 80% 20%,rgba(255,255,255,.45),transparent),radial-gradient(1px 1px at 35% 70%,rgba(255,255,255,.5),transparent),radial-gradient(1.2px 1.2px at 65% 55%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 15% 85%,rgba(255,255,255,.35),transparent),radial-gradient(1px 1px at 90% 75%,rgba(255,255,255,.45),transparent);opacity:0}html.dark .cosmic-bg:after{opacity:.7}.cosmic-bg--soft:before{opacity:.55}html.dark .cosmic-bg--soft:after{opacity:.35}.cosmic-bg>*{position:relative;z-index:1}.post-kicker{font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--spoko-color-accent);padding-left:1.75rem;background:linear-gradient(var(--spoko-color-accent),var(--spoko-color-accent)) no-repeat left center/1.25rem 1px}.prose hr{display:none}.prose h3:not(.insp-category-title):not(.itemgrid-title){margin-top:2rem;margin-bottom:1rem;color:var(--spoko-color-text-default);counter-increment:h3-counter}.prose h3:not(.insp-category-title):not(.itemgrid-title):before{content:counter(h2-counter,decimal-leading-zero)"."counter(h3-counter);display:block;font-size:.625rem;font-weight:700;letter-spacing:.2em;color:var(--spoko-color-accent);opacity:.7}.prose h3:not(.insp-category-title):not(.itemgrid-title):after,.blog-card-title:after{content:"";display:inline-block;vertical-align:middle;height:1px;width:9999px;margin-left:.875rem;margin-right:calc(-9999px - .875rem);background:linear-gradient(90deg,currentColor,transparent);opacity:.15}.prose h2+h3:not(.insp-category-title):not(.itemgrid-title){margin-top:1.5rem}.prose>*+h2{margin-top:4rem}.prose>*+h3:not(.insp-category-title):not(.itemgrid-title){margin-top:2.5rem}.prose pre{margin-top:1.5rem;margin-bottom:1.5rem}.not-prose h1,.not-prose h2,.not-prose h3,.not-prose h4,.not-prose h5,.not-prose h6{margin-top:0;margin-bottom:0;scroll-margin-top:0}.prose ul,.prose ol{margin-top:1rem;margin-bottom:1.5rem}.list-disc>li::marker,.list-decimal>li::marker,.list-square>li::marker{color:currentColor}.btn{display:inline-flex;cursor:pointer;align-items:center;justify-content:center;border-width:1px;--un-border-opacity:1;border-color:rgb(156 163 175/var(--un-border-opacity));border-radius:9999px;background-color:transparent;padding:.875rem 1.5rem;text-align:center;font-size:1rem;line-height:1.5rem;font-weight:500;line-height:1.375;color:var(--spoko-color-text-page);transition:all .3s cubic-bezier(.4,0,.2,1);outline:2px solid transparent;outline-offset:2px}@media (min-width:768px){.btn{padding-left:2rem;padding-right:2rem}}.btn-primary.btn-primary{position:relative;display:inline-flex;cursor:pointer;align-items:center;justify-content:center;overflow:hidden;border-radius:9999px;border-style:none;padding:.625rem 1.25rem;text-align:center;font-size:.875rem;line-height:1.25rem;--un-text-opacity:1;color:rgb(255 255 255/var(--un-text-opacity));font-weight:500;font-weight:600;line-height:1.375;min-height:2.75rem;background:linear-gradient(135deg,var(--spoko-color-primary) 0%,var(--spoko-color-secondary) 100%);box-shadow:0 4px 15px #0161ef40,0 2px 8px #0161ef26;outline:2px solid transparent;outline-offset:2px}.dark .btn-primary.btn-primary{--un-text-opacity:1;color:rgb(255 255 255/var(--un-text-opacity))}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover{box-shadow:0 8px 25px #0161ef59,0 4px 12px #0161ef40}.btn-primary:hover:before{left:100%}.btn-primary:active{opacity:.9}.dark .btn-primary{box-shadow:0 4px 20px #0161ef66,0 2px 10px #0161ef33}.dark .btn-primary:hover{box-shadow:0 8px 30px #0161ef80,0 4px 15px #0161ef4d}.btn-secondary.btn-secondary{position:relative;display:inline-flex;cursor:pointer;align-items:center;justify-content:center;border-radius:9999px;padding:.625rem 1.25rem;text-align:center;font-size:.875rem;line-height:1.25rem;font-weight:500;line-height:1.375;min-height:2.75rem;border-color:#0a6ca4;color:#0a6ca4;border-width:2px;border-style:solid;background-color:transparent;transition:all .3s cubic-bezier(.4,0,.2,1);outline:2px solid transparent;outline-offset:2px}.btn-secondary.btn-secondary.btn-secondary:hover{background-color:#0a6ca4!important;border-color:#0a6ca4!important;color:#fff!important;box-shadow:0 6px 20px #0a6ca44d}.btn-secondary:active{opacity:.9}.dark .btn-secondary{border-color:#60a5fa;color:#93c5fd}.dark .btn-secondary:hover{background-color:#60a5fa;border-color:#60a5fa;color:#fff;box-shadow:0 6px 25px #60a5fa66}.btn-tertiary{cursor:pointer;border-style:none;--un-shadow:0 0 var(--un-shadow-color, rgb(0 0 0 / 0));box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow);color:var(--spoko-color-text-muted);transition:all .2s ease;outline:2px solid transparent;outline-offset:2px}.btn-tertiary:hover{color:var(--spoko-color-accent)}.dark .btn-tertiary{color:#9ca3af}.dark .btn-tertiary:hover{color:var(--spoko-color-accent)}.btn-link{display:inline-flex;cursor:pointer;align-items:center;color:var(--spoko-color-accent);transition:transform .2s ease,color .2s ease;outline:2px solid transparent;outline-offset:2px}.btn-link:hover{color:var(--spoko-color-primary);transform:translate(4px)}.dark .btn-link{color:#60a5fa}.dark .btn-link:hover{color:#93c5fd}.btn-link:focus-visible{outline-color:var(--spoko-color-accent)}.btn:focus-visible,.btn-primary:focus-visible{outline-color:#0003}.dark .btn-primary:focus-visible{outline-color:#fff3}.btn-secondary:focus-visible,.btn-tertiary:focus-visible{outline-color:var(--spoko-color-accent)}@media (prefers-reduced-motion:reduce){.btn,.btn-primary,.btn-secondary,.btn-tertiary{transition:none;transform:none!important}.btn-primary:before{display:none}}.icon-rotating-border{position:relative;border:2px dashed transparent}.icon-rotating-border:before{content:"";position:absolute;inset:-4px;border-radius:9999px;border:2px dashed var(--spoko-color-primary);opacity:.4;transition:opacity .4s ease,border-color .4s ease}.group:hover .icon-rotating-border:before{opacity:.7;border-color:var(--spoko-color-secondary);animation:icon-border-spin 14s linear infinite}@keyframes icon-border-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.icon-rotating-border:before{animation:none}}.grid-item-border:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:linear-gradient(90deg,var(--spoko-color-primary),var(--spoko-color-secondary));transition:width .4s ease,left .4s ease}.grid-item-border:hover:after,.group:hover .grid-item-border:after{width:100%;left:0}.grid-item-border-left:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--spoko-color-primary),var(--spoko-color-secondary));transition:width .4s ease}.grid-item-border-left:hover:after,.group:hover .grid-item-border-left:after{width:100%}.dark .icon-rotating-border [data-icon="logos:astro-icon"]{filter:brightness(0) invert(1) brightness(.85)}.cta-card{background:#ffffff80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 20px #0000000f,0 1px 4px #00000008;border:1px solid rgba(13,135,205,.15);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.cta-card:hover{box-shadow:0 8px 32px #0d87cd1f,0 2px 8px #0d87cd14;border-color:#0d87cd40}.dark .cta-card{background:#03062066;border:1px solid rgba(71,85,105,.4);box-shadow:0 4px 20px #0006,0 1px 4px #0003}.dark .cta-card:hover{box-shadow:0 8px 32px #0d87cd33,0 2px 8px #0d87cd1f;border-color:#0d87cd4d}@media (prefers-reduced-motion:reduce){.cta-card,.cta-card:before{transition:none;transform:none!important}}.locale-link.locale-link:hover,.theme-toggle.theme-toggle:hover{color:var(--spoko-color-accent)}.locale-link.locale-link:hover svg,.theme-toggle.theme-toggle:hover svg{color:var(--spoko-color-accent)}.site-header{position:sticky;top:0;z-index:40;width:100%;min-height:104px;transition:min-height .35s ease}.site-header.scroll{min-height:60px}.site-header-utility{position:relative;z-index:9;overflow:hidden;max-height:44px;opacity:1;border-bottom:1px solid rgba(16,16,16,.08);color:var(--spoko-color-text-muted);transition:max-height .35s ease,opacity .2s ease,border-color .3s ease}.dark .site-header-utility{border-bottom-color:#ffffff14}.site-header.scroll .site-header-utility{max-height:0;opacity:0;border-bottom-color:transparent}.site-header-utility-inner{max-width:80rem;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:12px;font-weight:500;line-height:1;height:44px}@media (max-width:1024px){.site-header-utility-inner{padding:0 1rem}}.site-header-utility-left,.site-header-utility-right{display:flex;align-items:center;gap:10px;min-width:0;height:100%}.site-header-utility-item{display:inline-flex;align-items:center;gap:6px;color:inherit;text-decoration:none;transition:color .2s ease;white-space:nowrap}.site-header-utility-item:hover{color:var(--spoko-color-accent)}.site-header-utility-icon{padding:2px}.site-header-utility-sep{opacity:.35;user-select:none}.site-header-utility .theme-toggle{padding:4px}.site-header-utility .theme-toggle svg{width:14px;height:14px}@media (max-width:767px){.site-header-utility{display:none}.site-header{min-height:70px}}.site-header-brand{position:absolute;top:58px;left:max(1.5rem,calc((100vw - 80rem)/2 + 1.5rem));z-index:10;color:var(--spoko-color-text-default);text-decoration:none;display:inline-flex;align-items:center;padding:10px 18px;background:0 0;border:1px solid transparent;border-radius:999px;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;transform-origin:left center;transition:top .35s ease,left .35s ease,padding .35s ease,transform .35s ease,background .3s ease,border-color .3s ease,box-shadow .3s ease,backdrop-filter .3s ease,-webkit-backdrop-filter .3s ease}.site-header-brand>span,.menu-drawer-brand>span{margin-left:0}.site-header.scroll .site-header-brand{top:10px;left:max(1.25rem,calc((100vw - 80rem)/2 + 1.25rem));transform:scale(.88);background:#ffffffad;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-color:#0a162814;box-shadow:0 12px 40px #0000002e,0 2px 8px #00000014}.dark .site-header.scroll .site-header-brand{background:#030620ad;border-color:#ffffff1a;box-shadow:0 12px 40px #0006,0 2px 8px #0003}@media (max-width:1024px){.site-header-brand,.site-header.scroll .site-header-brand{left:max(1rem,calc((100vw - 80rem)/2 + 1rem))}}@media (max-width:767px){.site-header-brand,.site-header-pill{height:44px;box-sizing:border-box}.site-header-brand{display:flex;top:10px;left:1rem;padding:0;line-height:1}.site-header-brand>span{width:12.5rem;height:100%;flex-shrink:0;transition:width .35s ease}.site-header-brand svg{display:block;width:100%;height:auto;max-height:36px;transition:max-height .35s ease}.site-header.scroll .site-header-brand>span{width:8rem}.site-header.scroll .site-header-brand svg{max-height:24px}.site-header.scroll .site-header-brand{transform:none;left:.75rem;padding:0 12px}.site-header-pill-menu-label{display:none}.site-header-pill-menu{padding:6px}}.site-header-pill{position:absolute;top:52px;right:max(1.5rem,calc((100vw - 80rem)/2 + 1.5rem));z-index:70;display:flex;align-items:center;gap:6px;padding:6px;background:#ffffffad;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid rgba(10,22,40,.08);border-radius:999px;box-shadow:0 8px 30px #0003;transition:top .35s ease,right .35s ease,box-shadow .3s ease;color:var(--spoko-color-text-default)}.dark .site-header-pill{background:#030620ad;border-color:#ffffff1a;box-shadow:0 8px 30px #0006}.site-header.scroll .site-header-pill{top:10px;right:max(1.25rem,calc((100vw - 80rem)/2 + 1.25rem));box-shadow:0 12px 40px #00000047,0 2px 8px #00000026}.dark .site-header.scroll .site-header-pill{box-shadow:0 12px 40px #00000080,0 2px 8px #0003}@media (max-width:1024px){.site-header-pill,.site-header.scroll .site-header-pill{right:max(1rem,calc((100vw - 80rem)/2 + 1rem))}}@media (max-width:767px){.site-header-pill{top:10px;right:.75rem;padding:4px}.site-header.scroll .site-header-pill{right:.75rem}.site-header-pill .site-header-pill-cta.site-header-pill-cta{padding:6px 14px}}.site-header-pill .site-header-pill-cta.site-header-pill-cta{padding:9px 18px;min-height:0;font-size:13px;border-radius:999px;color:#fff}.site-header-pill .site-header-pill-cta.site-header-pill-cta:hover{box-shadow:0 4px 15px #0161ef40,0 2px 8px #0161ef26}.site-header-pill .site-header-pill-cta.site-header-pill-cta:hover:before{left:-100%}.site-header-pill-menu{background:0 0;color:inherit;border:0;cursor:pointer;padding:8px 14px 8px 12px;border-radius:999px;font-size:13px;font-weight:500;font-family:inherit;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:8px;transition:background-color .2s ease}.site-header-pill-menu:hover{background:#0a16280f}.dark .site-header-pill-menu:hover{background:#ffffff14}.site-header-pill-menu-icon{position:relative;display:block;width:16px;height:12px;flex-shrink:0}.site-header-pill-menu-icon>span{position:absolute;left:0;display:block;height:1.8px;background:currentColor;border-radius:2px;transform-origin:center;transition:width .3s cubic-bezier(.4,0,.2,1),top .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1)}.site-header-pill-menu-icon>span:first-child{top:3px;width:14px}.site-header-pill-menu-icon>span:last-child{top:9px;width:10px}body.drawer-open .site-header-pill-menu-icon>span{top:calc(50% - 1px);width:16px}body.drawer-open .site-header-pill-menu-icon>span:first-child{transform:rotate(45deg)}body.drawer-open .site-header-pill-menu-icon>span:last-child{transform:rotate(-45deg)}.menu-drawer{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:0;transition:opacity .3s ease}.menu-drawer.open{pointer-events:auto;opacity:1}.menu-drawer-backdrop{position:absolute;inset:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.menu-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:560px;max-width:90vw;background:#fbfcfe;border-left:1px solid rgba(10,22,40,.1);padding:24px 32px 28px;display:flex;flex-direction:column;color:var(--spoko-color-text-default);overflow-y:auto;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);outline:0}.menu-drawer.open .menu-drawer-panel{transform:translate(0)}.dark .menu-drawer-panel{background:#08121f;border-left-color:#ffffff1a}.menu-drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.menu-drawer-brand{font-size:22px;font-weight:700;letter-spacing:-.02em;color:inherit;text-decoration:none;display:inline-flex;align-items:baseline}.menu-drawer-brand-dot{color:var(--spoko-color-accent)}.menu-drawer-close{background:0 0;border:1px solid rgba(10,22,40,.1);color:inherit;cursor:pointer;width:36px;height:36px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .3s cubic-bezier(.4,0,.2,1)}.menu-drawer-close:hover{background:#0a16280d;transform:rotate(90deg)}.menu-drawer-close:active{transform:rotate(180deg)}.dark .menu-drawer-close{border-color:#ffffff1a}.dark .menu-drawer-close:hover{background:#ffffff0f}.menu-drawer-close-icon{position:relative;display:block;width:14px;height:14px}.menu-drawer-close-icon>span{position:absolute;top:calc(50% - 1px);left:0;display:block;width:14px;height:1.8px;background:currentColor;border-radius:2px;transform-origin:center}.menu-drawer-close-icon>span:first-child{transform:rotate(45deg)}.menu-drawer-close-icon>span:last-child{transform:rotate(-45deg)}.menu-drawer-primary{display:flex;flex-direction:column;margin-bottom:28px}.menu-drawer-primary-link{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;border-bottom:1px solid rgba(10,22,40,.08);color:inherit;text-decoration:none;transition:color .2s ease}.dark .menu-drawer-primary-link{border-bottom-color:#ffffff14}.menu-drawer-primary-link:hover{color:var(--spoko-color-accent)}.menu-drawer-primary-text{min-width:0}.menu-drawer-primary-title{display:block;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;line-height:1.1}@media (max-width:767px){.menu-drawer-primary-title{font-size:1.25rem}}.menu-drawer-primary-sub{display:block;font-size:12px;color:var(--spoko-color-text-muted);margin-top:2px}.menu-drawer-primary-arrow{flex-shrink:0;width:18px;height:18px;opacity:.4;transition:transform .2s ease,opacity .2s ease}.menu-drawer-primary-link:hover .menu-drawer-primary-arrow{opacity:1;transform:translate(4px)}.menu-drawer-section{margin-bottom:24px}.menu-drawer-section-title{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--spoko-color-text-muted);margin:0 0 10px}.menu-drawer-chips{display:flex;flex-wrap:wrap;gap:6px}.menu-drawer-chip{padding:8px 14px;border-radius:999px;border:1px solid rgba(10,22,40,.1);color:inherit;text-decoration:none;font-size:13px;font-weight:500;transition:border-color .2s ease,color .2s ease,background .2s ease}.menu-drawer-chip:hover{border-color:var(--spoko-color-accent);color:var(--spoko-color-accent)}.dark .menu-drawer-chip{border-color:#ffffff1f}.menu-drawer-spacer{flex:1;min-height:16px}.menu-drawer-help-card{padding:18px;border-radius:14px;background:#0d87cd0f;border:1px solid rgba(13,135,205,.15);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.dark .menu-drawer-help-card{background:#0d87cd1a;border-color:#0d87cd33}.menu-drawer-help-text{min-width:0}.menu-drawer-help-title{font-size:15px;font-weight:600;margin:0 0 2px}.menu-drawer-help-sub{font-size:12px;color:var(--spoko-color-text-muted);margin:0}.menu-drawer-help-cta.menu-drawer-help-cta{padding:11px 18px;min-height:0;font-size:13px;white-space:nowrap;display:inline-flex;align-items:center}.menu-drawer-help-cta svg{transition:transform .2s cubic-bezier(.4,0,.2,1)}.menu-drawer-help-cta:hover svg{transform:translate(4px)}.menu-drawer-primary-link .menu-drawer-primary-arrow{transition:transform .2s cubic-bezier(.4,0,.2,1)}.menu-drawer-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid rgba(10,22,40,.08)}.dark .menu-drawer-footer{border-top-color:#ffffff14}.menu-drawer-footer-utility,.menu-drawer-footer-socials{display:flex;align-items:center;gap:6px}.menu-drawer-footer-social{color:inherit;opacity:.7;padding:6px;transition:opacity .2s ease,color .2s ease}.menu-drawer-footer-social:hover{opacity:1;color:var(--spoko-color-accent)}.lang-segmented{display:inline-flex;border:1px solid rgba(10,22,40,.12);border-radius:999px;padding:2px;gap:0}.dark .lang-segmented{border-color:#ffffff26}.lang-segmented-btn{background:0 0;color:inherit;border:0;cursor:pointer;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;font-family:inherit;line-height:1;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.lang-segmented-btn:hover:not(.is-active){color:var(--spoko-color-accent)}.lang-segmented-btn.is-active{background:#0a1628;color:#fff}.dark .lang-segmented-btn.is-active{background:#ffffffeb;color:#0a1628}.site-header-utility .lang-segmented-btn{padding:4px 10px;font-size:11px}.menu-drawer-theme-chip.menu-drawer-theme-chip{background:0 0;color:inherit;border:1px solid rgba(10,22,40,.12);cursor:pointer;width:32px;height:32px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s ease,color .2s ease,background .2s ease}.menu-drawer-theme-chip.menu-drawer-theme-chip:hover{border-color:var(--spoko-color-accent);color:var(--spoko-color-accent)}.dark .menu-drawer-theme-chip.menu-drawer-theme-chip{border-color:#ffffff26}body.drawer-open{overflow:hidden}[astro-icon].icon-light>*{stroke-width:1.2}[astro-icon].icon-bold>*{stroke-width:2.4}.dark svg[data-icon="logos:wordpress-icon"],.dark svg[data-icon="logos:pwa"]{filter:brightness(2.5)}[data-aw-toggle-menu] path{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}[data-aw-toggle-menu].expanded g>path:first-child{--un-translate-y:15px;--un-translate-x:-3px;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-rotate:-45deg;transform:translate(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skew(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}[data-aw-toggle-menu].expanded g>path:last-child{--un-translate-y:-8px;--un-translate-x:14px;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-rotate:45deg;transform:translate(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skew(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}.dd :first-child{margin-top:0}.prose table{width:100%;border-collapse:collapse;table-layout:fixed}.prose table thead{--un-bg-opacity:1;background-color:rgb(243 244 246/var(--un-bg-opacity))}.dark .prose table thead{--un-bg-opacity:1;background-color:rgb(31 41 55/var(--un-bg-opacity))}.prose table th,.prose table td{border-width:1px;--un-border-opacity:1;border-color:rgb(209 213 219/var(--un-border-opacity));padding:.75rem 1rem;text-align:left;word-break:break-word;overflow-wrap:break-word;hyphens:auto}.dark .prose table th,.dark .prose table td{--un-border-opacity:1;border-color:rgb(75 85 99/var(--un-border-opacity))}.prose table th{--un-bg-opacity:1;background-color:rgb(243 244 246/var(--un-bg-opacity));font-weight:600}.dark .prose table th{--un-bg-opacity:1;background-color:rgb(31 41 55/var(--un-bg-opacity));--un-text-opacity:1;color:rgb(243 244 246/var(--un-text-opacity))}.prose table tbody tr:hover{--un-bg-opacity:1;background-color:rgb(249 250 251/var(--un-bg-opacity))}.dark .prose table tbody tr:hover{background-color:#37415180}:root{--demo-bg:#f0f2f7;--demo-border:rgba(0, 0, 0, .08);--demo-label:rgba(0, 0, 0, .35);--demo-text:rgba(0, 0, 0, .85);--demo-text-muted:rgba(0, 0, 0, .45);--demo-surface:rgba(0, 0, 0, .04);--demo-surface-2:rgba(0, 0, 0, .07);--demo-line:rgba(0, 0, 0, .12);--demo-divider:rgba(0, 0, 0, .06)}html.dark{--demo-bg:#0d0d14;--demo-border:rgba(255, 255, 255, .08);--demo-label:rgba(255, 255, 255, .35);--demo-text:rgba(255, 255, 255, .85);--demo-text-muted:rgba(255, 255, 255, .45);--demo-surface:rgba(255, 255, 255, .05);--demo-surface-2:rgba(255, 255, 255, .09);--demo-line:rgba(255, 255, 255, .15);--demo-divider:rgba(255, 255, 255, .06)}.blog-demo{background:var(--demo-bg);border:1px solid var(--demo-border);border-radius:16px;margin:2rem 0}.blog-demo-label{color:var(--demo-label);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;font-family:ui-monospace,monospace;pointer-events:none;text-align:center;margin-bottom:1.5rem}.blog-demo-codepen{display:flex;justify-content:flex-end;padding:.6rem 1rem .75rem;border-top:1px solid var(--demo-divider);margin-top:.5rem}.blog-demo-codepen a{font-size:.7rem;color:var(--demo-text-muted);font-family:ui-monospace,monospace;text-decoration:none;display:flex;align-items:center;gap:.35rem;transition:color .2s}.blog-demo-codepen a:hover{color:var(--demo-text)}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-cyrillic-ext-wght-normal.BOeWTOD4.woff2)format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-cyrillic-wght-normal.DqGufNeO.woff2)format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-greek-ext-wght-normal.DlzME5K_.woff2)format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-greek-wght-normal.CkhJZR-_.woff2)format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-vietnamese-wght-normal.CBcvBZtf.woff2)format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-latin-ext-wght-normal.DO1Apj_S.woff2)format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_spoko/inter-latin-wght-normal.Dx4kXJAl.woff2)format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.highlight{font-weight:600}@media screen and (prefers-reduced-motion:no-preference){@supports (animation-timeline:view()){html:not(.no-scroll-animations) .header-special{grid-column:1/-1;inset:0;width:100%;height:100%;opacity:1;translate:0 0;animation:header-special-animation linear forwards;animation-timeline:view();animation-range:exit 0;will-change:translate,opacity}html:not(.no-scroll-animations) .header-special:hover{opacity:1}@keyframes header-special-animation{30%{opacity:1}85%,to{opacity:0;translate:0 200px}}html:not(.no-scroll-animations) main section:not(.header-special) img:not(.blog-demo *){opacity:0;animation:fade-in linear forwards;animation-timeline:view();animation-range:entry 0%cover 20%}html:not(.no-scroll-animations) main section:not(.header-special)>div:first-child{opacity:0;animation:fade-in linear forwards;animation-timeline:view();animation-range:entry 0%cover 25%}@keyframes fade-in{to{opacity:1}}}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}img{content-visibility:auto}