@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--paper: #FFFFFF;--paper-warm: #F6F6F8;--paper-sunk: #EFEFF2;--data-white: #FFFFFF;--canvas: #FFFFFF;--ink: #0B0B12;--ink-80: #26262F;--ink-55: #54545F;--ink-35: #9A9AA4;--blue: #2E2EFF;--blue-ink: #1C1CCC;--blue-tint: #E4E4FF;--teal: #18A6F6;--teal-ink: #0C82C9;--teal-tint: #DCF1FE;--orange: #FFD400;--orange-ink: #C99E00;--orange-tint: #FFF3BF;--minium: #FF2D2D;--minium-ink: #D81E1E;--minium-tint: #FFE0DE;--green: #2E2EFF;--green-ink: #1C1CCC;--green-tint: #E4E4FF;--hairline: #E6E6EA;--hairline-strong: #CFCFD6;--rule-ink: #0B0B12;--grid-line: rgba(11, 11, 18, .06);--grad-brand: linear-gradient(135deg, #2E2EFF 0%, #18A6F6 100%);--grad-cool: linear-gradient(135deg, #1C1CCC 0%, #2E2EFF 100%);--grad-sunset: linear-gradient(135deg, #FFD400 0%, #FFA800 100%);--grad-aqua: linear-gradient(135deg, #18A6F6 0%, #2E2EFF 100%);--grad-iris: linear-gradient(120deg, #2E2EFF 0%, #18A6F6 50%, #FFD400 100%);--glass-bg: #FFFFFF;--glass-bg-strong: #FFFFFF;--glass-border: #0B0B12;--glass-blur: 0px;--glass-highlight: none;--surface-page: var(--canvas);--surface-card: var(--data-white);--surface-data: var(--data-white);--surface-field: var(--data-white);--surface-sunk: var(--paper-sunk);--surface-notebook: var(--paper-warm);--surface-glass: var(--glass-bg);--text-strong: var(--ink);--text-body: var(--ink-80);--text-muted: var(--ink-55);--text-faint: var(--ink-35);--text-link: var(--blue-ink);--text-brand: var(--blue);--border-default: var(--hairline);--border-strong: var(--hairline-strong);--border-ink: var(--rule-ink);--accent: var(--orange);--verdict-pos: var(--green);--verdict-neg: var(--minium);--shadow-none: none;--shadow-soft: 5px 5px 0 var(--ink);--shadow-raise: 4px 4px 0 var(--ink);--shadow-glow: 6px 6px 0 var(--blue);--shadow-glow-teal: 6px 6px 0 var(--teal);--shadow-disc: 4px 4px 0 var(--ink);--shadow-pop: 5px 5px 0 var(--ink);--shadow-pop-violet: 5px 5px 0 var(--blue);--shadow-pop-teal: 5px 5px 0 var(--teal)}:root{--font-grotesk: "Bricolage Grotesque", system-ui, -apple-system, "Segoe UI", sans-serif;--font-sans: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--font-display: var(--font-grotesk);--font-body: var(--font-sans);--font-ui: var(--font-sans);--font-data: var(--font-mono);--font-serif: var(--font-body);--text-7xl: 4.25rem;--text-6xl: 3.5rem;--text-5xl: 2.75rem;--text-4xl: 2.125rem;--text-3xl: 1.75rem;--text-2xl: 1.375rem;--text-xl: 1.1875rem;--text-lg: 1.0625rem;--text-base: 1rem;--text-sm: .875rem;--text-xs: .8125rem;--text-2xs: .6875rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--leading-tight: 1.04;--leading-snug: 1.2;--leading-normal: 1.5;--leading-relaxed: 1.65;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-kicker: .16em;--num-tabular: "tnum" 1, "lnum" 1}:root{--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-0: 0;--radius-sm: 0px;--radius-md: 0px;--radius-lg: 0px;--radius-xl: 0px;--radius-2xl: 0px;--radius-full: 999px;--radius-blob: 0;--rule-hair: 1px;--rule-medium: 2px;--rule-strong: 3px;--rule-pop: 2.5px;--cut-corner: polygon(0 0, 100% 0, 100% calc(100% - 18px) , calc(100% - 18px) 100%, 0 100%);--cut-both: polygon(16px 0, 100% 0, 100% calc(100% - 16px) , calc(100% - 16px) 100%, 0 100%, 0 16px);--cut-tri-up: polygon(50% 0, 100% 100%, 0 100%);--cut-tri-down: polygon(0 0, 100% 0, 50% 100%);--cut-arrow: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%);--cut-chevron: polygon(0 0, 100% 0, 100% 100%, 18px 100%, 0 50%);--measure-text: 68ch;--measure-narrow: 52ch;--content-max: 1200px;--content-wide: 1340px;--margin-note: 16rem;--tap-min: 44px}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{margin:0;background:var(--canvas);color:var(--text-body);font-family:var(--font-ui);font-size:var(--text-base);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.lumiere{position:relative;background:var(--canvas);isolation:isolate}.lumiere:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:conic-gradient(from 200deg at 100% 0,var(--orange) 0 38deg,transparent 38deg),conic-gradient(from 20deg at 0 100%,var(--blue) 0 34deg,transparent 34deg),repeating-linear-gradient(135deg,transparent 0 26px,rgba(255,212,0,.5) 26px 30px) bottom right / 220px 220px no-repeat,repeating-linear-gradient(135deg,transparent 0 26px,rgba(46,46,255,.45) 26px 30px) top left / 200px 200px no-repeat,var(--canvas);opacity:.16}.tri{width:0;height:0;border-left:.5em solid transparent;border-right:.5em solid transparent;border-bottom:.86em solid var(--blue)}.cut-corner{clip-path:var(--cut-corner)}.cut-both{clip-path:var(--cut-both)}.cut-arrow{clip-path:var(--cut-arrow)}.cut-chevron{clip-path:var(--cut-chevron)}.num,.data,[data-num]{font-family:var(--font-data);font-feature-settings:var(--num-tabular);font-variant-numeric:tabular-nums lining-nums}.kicker{font-family:var(--font-data);font-size:var(--text-2xs);letter-spacing:var(--tracking-kicker);text-transform:uppercase;color:var(--text-muted)}.headline{font-family:var(--font-display);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--text-strong);text-wrap:balance}.text-gradient{background:var(--grad-iris);-webkit-background-clip:text;background-clip:text;color:transparent}.prose{font-family:var(--font-body);font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--text-body);max-width:var(--measure-text);text-wrap:pretty}a,.link{color:var(--text-link);text-decoration-color:var(--hairline-strong);text-underline-offset:.15em}.underline-minium,.mark-grad{background-image:var(--grad-sunset);background-repeat:no-repeat;background-position:0 90%;background-size:100% .34em;padding:0 .06em;border-radius:0}.dropcap:first-letter{font-family:var(--font-display);font-weight:var(--weight-bold);font-size:3.1em;line-height:.8;float:left;padding:.14em .18em 0 0;background:var(--grad-iris);-webkit-background-clip:text;background-clip:text;color:transparent}.glass{position:relative;background:var(--glass-bg);border:2px solid var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.glass-strong{position:relative;background:var(--glass-bg-strong);border:2.5px solid var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop)}.sticker{border:var(--rule-pop) solid var(--ink);border-radius:var(--radius-full);box-shadow:var(--shadow-pop)}.rule-strong{border-bottom:var(--rule-strong) solid var(--rule-ink)}.rule-hair{border-bottom:var(--rule-hair) solid var(--border-default)}.blob{width:4rem;height:4rem;background:var(--grad-brand);clip-path:var(--cut-tri-up)}.container{max-width:var(--content-max);margin:0 auto;padding:0 20px}.container-wide{max-width:var(--content-wide);margin:0 auto;padding:0 20px}:where(a,button,input,summary,[tabindex]):focus-visible{outline:3px solid var(--blue);outline-offset:2px}.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;font-family:var(--font-ui);font-weight:700}.skip-link:focus{left:8px;top:8px}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:700;line-height:1;letter-spacing:.02em;text-transform:uppercase;border-radius:0;cursor:pointer;text-decoration:none;gap:8px;transition:transform .12s ease,box-shadow .12s ease}.btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)!important}.btn[disabled],.btn[aria-disabled=true]{opacity:.45;cursor:not-allowed}.btn[disabled]:hover,.btn[aria-disabled=true]:hover{transform:none}.btn--sm{padding:8px 16px;font-size:13px;min-height:38px;gap:6px}.btn--md{padding:11px 22px;font-size:15px;min-height:46px;gap:8px}.btn--lg{padding:15px 30px;font-size:17px;min-height:56px;gap:10px}.btn--full{width:100%}.btn--primary{background:var(--grad-brand);color:#fff;border:2px solid var(--ink);box-shadow:var(--shadow-pop)}.btn--secondary{background:#fff;color:var(--ink);border:2px solid var(--ink);box-shadow:var(--shadow-pop)}.btn--ghost{background:transparent;color:var(--blue);border:2px solid transparent}.btn--ghost:hover{box-shadow:none!important;transform:none;color:var(--blue-ink)}.btn--teal{background:var(--grad-aqua);color:#fff;border:2px solid var(--ink);box-shadow:var(--shadow-pop)}.btn--minium{background:var(--grad-sunset);color:var(--ink);border:2px solid var(--ink);box-shadow:var(--shadow-pop)}.btn--minium-outline{background:#fff;color:var(--minium-ink);border:2px solid var(--minium)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:0;font-family:var(--font-ui);font-size:12px;font-weight:700;letter-spacing:.01em;line-height:1.3;white-space:nowrap}.badge--mono{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.04em}.badge--neutral{--b-fg: var(--ink);--b-line: var(--ink);--b-soft: var(--paper-sunk);--b-grad: var(--grad-cool)}.badge--blue{--b-fg: var(--blue-ink);--b-line: var(--blue);--b-soft: var(--blue-tint);--b-grad: var(--grad-brand)}.badge--teal{--b-fg: var(--teal-ink);--b-line: var(--teal);--b-soft: var(--teal-tint);--b-grad: var(--grad-aqua)}.badge--orange{--b-fg: var(--orange-ink);--b-line: var(--orange);--b-soft: var(--orange-tint);--b-grad: var(--grad-sunset)}.badge--positive{--b-fg: var(--green-ink);--b-line: var(--green);--b-soft: var(--green-tint);--b-grad: var(--grad-brand)}.badge--negative{--b-fg: var(--minium-ink);--b-line: var(--minium);--b-soft: var(--minium-tint);--b-grad: var(--grad-sunset)}.badge[data-variant=soft]{background:var(--b-soft);color:var(--b-fg);border:none}.badge[data-variant=outline]{background:#fff;color:var(--b-fg);border:1px solid var(--b-line)}.badge[data-variant=solid]{background:var(--b-line);color:#fff;border:none}.badge[data-variant=gradient]{background:var(--b-grad);color:#fff;border:none}.badge[data-variant=pop]{background:#fff;color:var(--b-fg);border:2px solid var(--b-line);box-shadow:3px 3px 0 var(--b-line);padding:4px 12px}.badge__dot{width:7px;height:7px;border-radius:999px;background:var(--b-line);flex:none}.badge[data-variant=solid] .badge__dot,.badge[data-variant=gradient] .badge__dot{background:#fff}.callout{position:relative;border-radius:var(--radius-xl);padding:24px 28px 22px 88px;margin:0;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}.callout--astuce{--c-grad: var(--grad-aqua);--c-label: var(--teal-ink);--c-glow: rgba(24,166,246,.42)}.callout--retenir{--c-grad: var(--grad-brand);--c-label: var(--blue-ink);--c-glow: rgba(46,46,255,.4)}.callout--attention{--c-grad: var(--grad-sunset);--c-label: var(--minium-ink);--c-glow: rgba(255,168,0,.45)}.callout__disc{position:absolute;left:24px;top:24px;width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--c-grad);box-shadow:0 12px 22px -8px var(--c-glow),inset 0 1px #ffffff80}.callout__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-label);font-weight:600}.callout__body{font-family:var(--font-sans);font-size:15.5px;line-height:1.6;color:var(--ink);margin-top:5px;max-width:60ch}.callout__body :first-child{margin-top:0}.callout__body :last-child{margin-bottom:0}.pullquote{position:relative;margin:0;padding:30px 30px 26px 84px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#2e2eff14,#ffd40012),var(--glass-bg-strong);border:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}.pullquote__mark{position:absolute;left:22px;top:6px;font-family:var(--font-display);font-weight:700;font-size:96px;line-height:1;background:var(--grad-iris);-webkit-background-clip:text;background-clip:text;color:transparent}.pullquote blockquote{margin:0;font-family:var(--font-display);font-weight:500;font-size:clamp(20px,3vw,27px);line-height:1.3;letter-spacing:-.01em;color:var(--ink)}.pullquote__cap{display:flex;align-items:center;gap:12px;margin-top:16px}.pullquote__avatar{width:40px;height:40px;border-radius:999px;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:15px;flex:none}.pullquote__author{font-family:var(--font-sans);font-size:14px;color:var(--ink);display:block}.pullquote__role{font-family:var(--font-mono);font-size:11px;color:var(--ink-55)}.proscons{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch}.proscons__col{display:flex;flex-direction:column;height:100%;border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:22px 24px}.proscons__col--pros{background:linear-gradient(160deg,#2e2eff1a,#fff9)}.proscons__col--cons{background:linear-gradient(160deg,#ff2d2d1a,#fff9)}.proscons__col h3{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em;margin:0 0 14px}.proscons__col--pros h3{color:var(--green-ink)}.proscons__col--cons h3{color:var(--minium-ink)}.proscons__col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}.proscons__col li{display:flex;gap:11px;font-family:var(--font-sans);font-size:14.5px;line-height:1.5;color:var(--ink-80)}.proscons__mark{font-weight:800;flex:none;font-family:var(--font-mono);line-height:1.4}.proscons__col--pros .proscons__mark{color:var(--green-ink)}.proscons__col--cons .proscons__mark{color:var(--minium-ink)}@media(max-width:760px){.proscons{grid-template-columns:1fr}}.panel{position:relative;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft)}.panel--strong{background:var(--glass-bg-strong)}.panel--p-none{padding:0}.panel--p-sm{padding:16px 18px}.panel--p-md{padding:20px 22px}.panel--p-lg{padding:24px 28px}.panel--p-xl{padding:32px 34px}.columns{display:grid;gap:24px;align-items:start}.columns--image-text{grid-template-columns:1.7fr 1fr}.columns--text-image{grid-template-columns:1fr 1.7fr}.columns--two{grid-template-columns:1fr 1fr}.columns--aside-body{grid-template-columns:1fr 2fr}.columns--body-aside{grid-template-columns:2fr 1fr}.columns--three{grid-template-columns:repeat(3,1fr)}.columns--center{align-items:center}.columns--stretch{align-items:stretch}@media(max-width:760px){.columns{grid-template-columns:1fr!important}}.visual{position:relative;border-radius:var(--radius-lg);min-height:196px;overflow:hidden;background:linear-gradient(140deg,#2e2eff,#18a6f6 58%,#ffd400);box-shadow:var(--shadow-raise)}.visual:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 80% 0%,rgba(255,255,255,.32),transparent 52%)}.visual img{display:block;width:100%;height:100%;object-fit:cover}.visual__label{position:absolute;left:14px;bottom:14px;z-index:1;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:#0000004d;padding:6px 12px;border-radius:999px}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}.features--2{grid-template-columns:repeat(2,1fr)}.features--4{grid-template-columns:repeat(4,1fr)}.features__item{display:flex;flex-direction:column;height:100%;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:24px 24px 22px;overflow:hidden}.features__orb{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;color:#fff;margin-bottom:18px;box-shadow:var(--shadow-disc),inset 0 1px #ffffff80}.features__orb--0{background:var(--grad-brand)}.features__orb--1{background:var(--grad-aqua)}.features__orb--2{background:var(--grad-sunset);color:var(--ink)}.features__orb--3{background:var(--grad-cool)}.features__img{position:relative;border-radius:var(--radius-md);height:128px;margin-bottom:18px;overflow:hidden;box-shadow:var(--shadow-raise)}.features__img img{display:block;width:100%;height:100%;object-fit:cover}.features__eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:6px}.features__item h3{font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink);margin:0 0 8px}.features__item p{font-family:var(--font-sans);font-size:14.5px;line-height:1.55;color:var(--ink-80);margin:0}.features__action{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-ui);font-weight:700;font-size:14px;color:#fff;background:var(--grad-brand);padding:11px 20px;border-radius:var(--radius-full);text-decoration:none;box-shadow:0 14px 28px -12px #2e2eff8c}@media(max-width:820px){.features,.features--2,.features--4{grid-template-columns:1fr}}.dtable{overflow:hidden;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--glass-bg-strong);box-shadow:var(--shadow-soft)}.dtable__scroll{overflow-x:auto}.dtable table{width:100%;border-collapse:collapse;font-family:var(--font-ui)}.dtable caption{caption-side:top;text-align:left;padding:14px 16px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-55);border-bottom:1px solid var(--hairline)}.dtable th{position:sticky;top:0;z-index:2;text-align:left;padding:14px 18px;background:var(--grad-brand);font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;white-space:nowrap}.dtable td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--hairline);font-family:var(--font-ui);font-size:14px;color:var(--ink-80);white-space:nowrap}.dtable tr:last-child td{border-bottom:none}.dtable .num{text-align:right;font-family:var(--font-mono);font-weight:500;font-variant-numeric:tabular-nums lining-nums}.dtable th.num{text-align:right}.dtable .col-sticky{position:sticky;left:0;font-weight:700;color:var(--ink);background:var(--glass-bg-strong)}.dtable tr[data-best]{background:linear-gradient(90deg,rgba(46,46,255,.12),transparent)}.dt-pos{color:var(--green-ink)}.dt-neg{color:var(--minium-ink)}.dt-muted{color:var(--ink-55)}.dt-strong{color:var(--ink)}.statdiscs{position:relative;height:188px}.statdiscs__disc{position:absolute;border-radius:24px;display:grid;place-items:center;text-align:center;border:1px solid rgba(255,255,255,.55);box-shadow:var(--shadow-disc),inset 0 1px #ffffffb3}.statdiscs__disc:nth-child(1){width:124px;height:124px;left:6px;top:20px;z-index:4;transform:rotate(-6deg);background:linear-gradient(150deg,#2e2eff,#18a6f6)}.statdiscs__disc:nth-child(2){width:100px;height:100px;right:16px;top:0;z-index:3;transform:rotate(5deg);background:linear-gradient(150deg,#18a6f6,#2e2eff)}.statdiscs__disc:nth-child(3){width:92px;height:92px;right:42px;bottom:0;z-index:2;transform:rotate(-3deg);background:linear-gradient(150deg,#ffd400,#ffa800)}.statdiscs__disc:nth-child(4){width:84px;height:84px;left:30px;bottom:6px;z-index:1;transform:rotate(4deg);background:linear-gradient(150deg,#1c1ccc,#2e2eff)}.statdiscs__val{font-family:var(--font-mono);font-weight:700;font-size:28px;color:#fff;line-height:1;font-variant-numeric:tabular-nums}.statdiscs__disc:nth-child(3) .statdiscs__val{color:var(--ink)}.statdiscs__val small{font-size:14px;opacity:.85}.statdiscs__label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#ffffffeb;margin-top:4px}.statdiscs__disc:nth-child(3) .statdiscs__label{color:#0b0b12cc}.faders{display:grid;gap:2px}.faders__row{display:grid;grid-template-columns:140px 1fr 48px;align-items:center;gap:14px;padding:9px 0}.faders__label{font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--ink-80)}.faders__track{position:relative;height:22px}.faders__ticks{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:10px;background-image:repeating-linear-gradient(90deg,var(--hairline-strong) 0 1px,transparent 1px 10%);opacity:.6}.faders__rail{position:absolute;left:0;right:0;top:50%;height:4px;transform:translateY(-50%);background:var(--paper-sunk);border-radius:999px}.faders__fill{position:absolute;left:0;top:0;bottom:0;border-radius:999px}.faders__knob{position:absolute;top:50%;width:16px;height:24px;transform:translate(-50%,-50%);border-radius:7px;background:#fff;border:2px solid var(--blue);box-shadow:0 4px 10px -2px #2e2eff80}.faders__knob:after{content:"";position:absolute;left:50%;top:4px;bottom:4px;width:1.5px;background:var(--blue);transform:translate(-50%)}.faders__value{font-family:var(--font-mono);font-weight:700;font-size:16px;text-align:right;color:var(--ink);font-variant-numeric:tabular-nums}.chart{margin:0;border-radius:var(--radius-xl);padding:22px 24px;background:var(--glass-bg-strong);border:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}.chart__cap{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.chart__title{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em;color:var(--ink)}.chart__sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-55)}.chart__plot{position:relative;border-radius:var(--radius-md);background-image:linear-gradient(rgba(11,11,18,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(11,11,18,.06) 1px,transparent 1px);background-size:100% 34px,9% 100%}.chart__dot{position:absolute;width:11px;height:11px;border-radius:999px;background:var(--blue);border:2.5px solid #fff;transform:translate(-50%,-50%);box-shadow:0 2px 8px #2e2eff80}.product{position:relative;display:block;text-decoration:none;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:24px 26px 22px;overflow:visible}.product__score{position:absolute;top:-16px;right:20px;width:70px;height:70px;border-radius:20px;transform:rotate(-6deg);display:grid;place-items:center;text-align:center;box-shadow:var(--shadow-disc),inset 0 1px #fff9}.product--positive .product__score,.product--positive .product__verdict{background:var(--grad-aqua);color:#fff}.product--neutral .product__score,.product--neutral .product__verdict{background:var(--grad-cool);color:#fff}.product--negative .product__score,.product--negative .product__verdict{background:var(--grad-sunset);color:var(--ink)}.product__score-val{font-family:var(--font-mono);font-weight:700;font-size:24px;line-height:1;font-variant-numeric:tabular-nums}.product__score-max{display:block;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.1em;opacity:.9}.product__cat{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-55)}.product h3{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.02em;color:var(--ink);margin:4px 0 14px;max-width:70%}.product__verdict{display:inline-flex;padding:5px 13px;border-radius:999px;font-family:var(--font-ui);font-weight:700;font-size:12px}.product__specs{display:flex;flex-wrap:wrap;gap:18px;margin-top:16px;padding-top:14px;border-top:1px solid var(--hairline)}.product__spec-l{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-55)}.product__spec-v{font-family:var(--font-mono);font-weight:600;font-size:16px;color:var(--ink);margin-top:2px;font-variant-numeric:tabular-nums}.field{display:block;font-family:var(--font-ui)}.field__label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}.field__wrap{display:flex;align-items:center;background:var(--glass-bg-strong);border:2px solid var(--hairline-strong);border-radius:var(--radius-full);padding:0 18px;min-height:50px;transition:border-color .15s ease,box-shadow .15s ease}.field__wrap:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-tint)}.field--error .field__wrap{border-color:var(--minium)}.field__wrap input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-ui);font-size:15px;color:var(--ink);min-width:0}.field--mono .field__wrap input{font-family:var(--font-mono);font-variant-numeric:tabular-nums lining-nums}.field__prefix{color:var(--ink-55);margin-right:8px;font-size:14px}.field__suffix{color:var(--ink-55);margin-left:8px;font-size:14px;font-family:var(--font-mono)}.field__hint{display:block;margin-top:6px;font-size:12px;color:var(--ink-55)}.field--error .field__hint{color:var(--minium-ink)}.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:2px solid var(--ink)}.site-header__bar{max-width:var(--content-wide);margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:20px;height:64px}.site-nav{display:flex;gap:4px;margin-left:8px}.site-nav__link{border:none;background:transparent;cursor:pointer;font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--ink-80);padding:8px 14px;text-decoration:none;text-transform:uppercase;letter-spacing:.03em}.site-nav__link:hover,.site-nav__link[aria-current=page]{background:var(--blue-tint);color:var(--blue-ink)}.site-header__meta{margin-left:auto;display:flex;align-items:center;gap:12px}.site-header__count{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-55)}.burger{display:none;border:2px solid var(--ink);background:#fff;width:44px;height:44px;cursor:pointer;place-items:center;color:var(--ink);box-shadow:var(--shadow-raise)}.mobile-nav{display:none;border-top:2px solid var(--ink);background:#fff;padding:6px 12px}.mobile-nav a{display:block;padding:12px 8px;font-family:var(--font-ui);font-weight:700;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--hairline);text-transform:uppercase;letter-spacing:.03em}.mobile-nav a:last-child{border-bottom:none}@media(max-width:860px){.site-nav,.site-header__count{display:none}.burger{display:grid}.mobile-nav:not([hidden]){display:block}}.wordmark{font-family:var(--font-grotesk);font-weight:800;letter-spacing:-.02em;color:var(--ink);display:inline-flex;align-items:baseline;line-height:1;text-decoration:none}.wordmark__tld{color:#fff;background:var(--blue);padding:2px 7px;margin-left:4px;clip-path:var(--cut-corner)}.wordmark--inverse{color:#fff}.wordmark--inverse .wordmark__tld{background:var(--orange);color:var(--ink)}.site-footer{background:var(--ink);color:#fff;margin-top:72px;position:relative;overflow:hidden}.site-footer__deco{position:absolute;inset:0;pointer-events:none;background:conic-gradient(from 200deg at 100% 0,rgba(255,212,0,.5) 0 34deg,transparent 34deg),conic-gradient(from 20deg at 0 100%,rgba(46,46,255,.7) 0 30deg,transparent 30deg);opacity:.5}.site-footer__grid{position:relative;max-width:var(--content-wide);margin:0 auto;padding:44px 20px;display:grid;gap:28px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.site-footer__about{font-family:var(--font-sans);font-size:14px;line-height:1.6;color:#ffffffc7;margin-top:12px;max-width:32ch}.site-footer h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff9;margin:0 0 12px}.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}.site-footer ul a{font-family:var(--font-ui);font-size:14px;color:#ffffffe0;text-decoration:none}.site-footer ul a:hover{color:var(--orange)}.site-footer__legal{position:relative;border-top:1px solid rgba(255,255,255,.14);padding:14px 20px}.site-footer__legal-in{max-width:var(--content-wide);margin:0 auto;font-family:var(--font-mono);font-size:11px;color:#ffffff8c;letter-spacing:.06em}.article-layout{max-width:var(--content-wide);margin:24px auto;padding:28px clamp(16px,3vw,44px) 40px;background:#fff;box-shadow:0 1px 0 var(--hairline),0 24px 60px -34px #0b0b1247}@media(max-width:720px){.article-layout{margin:0 auto}}.article-body{display:grid;grid-template-columns:248px minmax(0,1fr);gap:48px;align-items:start;padding-bottom:40px}.article-content{max-width:820px;min-width:0}@media(max-width:1000px){.article-body{grid-template-columns:1fr;gap:0}}.hero{padding:36px 0 30px}.hero__top{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}@media(max-width:900px){.hero__grid{grid-template-columns:1fr;gap:28px}}.hero h1{font-family:var(--font-grotesk);font-weight:800;font-size:clamp(34px,6vw,58px);line-height:.98;letter-spacing:-.03em;color:var(--ink);margin:0}.hero__excerpt{font-family:var(--font-sans);font-size:clamp(17px,2.2vw,21px);line-height:1.5;color:var(--ink-80);max-width:54ch;margin:18px 0 0}.hero__meta{display:flex;flex-wrap:wrap;align-items:center;gap:18px 22px;margin-top:24px}.hero__author{display:flex;align-items:center;gap:10px}.hero__avatar{width:40px;height:40px;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-family:var(--font-grotesk);font-weight:700;font-size:14px;clip-path:var(--cut-corner)}.hero__avatar--photo{background:none;object-fit:cover;border-radius:50%;clip-path:none;border:2px solid var(--ink)}.hero__author-name{font-family:var(--font-ui);font-weight:700;font-size:14px;color:var(--ink);line-height:1.2}.hero__author-role{font-family:var(--font-mono);font-size:11px;color:var(--ink-55)}.hero__metaitem{display:flex;flex-direction:column;gap:2px}.hero__metaitem .k{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-55)}.hero__metaitem .v{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}.hero__media{position:relative}.hero__media:before{content:"";position:absolute;left:-14px;top:-14px;width:64px;height:64px;background:var(--orange);clip-path:var(--cut-tri-up);z-index:0}.hero__media:after{content:"";position:absolute;right:-12px;bottom:-12px;width:54px;height:54px;background:var(--blue);z-index:0}.hero__media img,.hero__media .ph{position:relative;z-index:1;display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;border:2.5px solid var(--ink);box-shadow:var(--shadow-pop);background:linear-gradient(140deg,#2e2eff,#18a6f6 58%,#ffd400)}.hero__media .ph{display:grid;place-items:end start;padding:16px}.hero__media .ph span{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:#0000004d;padding:6px 12px}.takeaways{position:relative;background:#fff;border:2.5px solid var(--ink);box-shadow:var(--shadow-pop);padding:26px 28px 24px;margin:6px 0 30px}.takeaways__head{display:flex;align-items:center;gap:13px;margin-bottom:18px}.takeaways__icon{width:44px;height:44px;background:var(--grad-brand);color:#fff;display:grid;place-items:center;clip-path:var(--cut-corner);flex:none}.takeaways__title{font-family:var(--font-grotesk);font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink);margin:0}.takeaways__sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-55);margin-top:2px}.takeaways__list{list-style:none;margin:0;padding:0;display:grid;gap:13px}.takeaways__list li{position:relative;padding-left:30px;font-family:var(--font-sans);font-size:15.5px;line-height:1.55;color:var(--ink-80)}.takeaways__list li:before{content:"";position:absolute;left:2px;top:.4em;width:13px;height:13px;background:var(--blue);clip-path:var(--cut-tri-up)}.takeaways__list li:nth-child(2n):before{background:var(--orange)}.takeaways__list li strong{color:var(--ink);font-weight:700}.article-toc-desktop{position:sticky;top:84px;align-self:start;max-height:calc(100vh - 110px);overflow-y:auto}@media(max-width:1000px){.article-toc-desktop{display:none}}.toc__title{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-55);margin:0 0 12px;padding-bottom:10px;border-bottom:2px solid var(--ink)}.toc__list{list-style:none;margin:0;padding:0;display:grid;gap:2px}.toc__link{display:block;padding:7px 12px;font-family:var(--font-ui);font-size:13.5px;color:var(--ink-55);text-decoration:none;border-left:2px solid var(--hairline);transition:color .12s ease,background .12s ease,border-color .12s ease}.toc__item--h3 .toc__link{padding-left:24px;font-size:12.5px}.toc__link:hover{color:var(--ink);background:var(--paper-warm)}.toc__link.is-active{color:var(--blue-ink);font-weight:700;border-left-color:var(--blue);background:var(--blue-tint)}.toc-mobile{display:none;margin:0 0 26px;border:2px solid var(--ink);box-shadow:var(--shadow-raise);background:#fff}@media(max-width:1000px){.toc-mobile{display:block}}.toc-mobile>summary{cursor:pointer;list-style:none;padding:14px 18px;font-family:var(--font-ui);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:10px}.toc-mobile>summary::-webkit-details-marker{display:none}.toc-mobile>summary .chev{transition:transform .16s ease}.toc-mobile[open]>summary{border-bottom:2px solid var(--ink)}.toc-mobile[open]>summary .chev{transform:rotate(180deg)}.toc-mobile .toc{padding:10px 12px}.article-content>*{margin-top:0}.article-content h2{font-family:var(--font-grotesk);font-weight:800;font-size:clamp(24px,4vw,32px);letter-spacing:-.02em;color:var(--ink);margin:44px 0 14px;scroll-margin-top:90px;position:relative;padding-left:18px}.article-content h2:before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:6px;background:var(--grad-brand)}.article-content h3{font-family:var(--font-grotesk);font-weight:700;font-size:21px;letter-spacing:-.01em;color:var(--ink);margin:30px 0 10px;scroll-margin-top:90px}.article-content p{font-family:var(--font-body);font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--ink-80);margin:0 0 18px}.article-content>p{max-width:var(--measure-text)}.article-content a{color:var(--blue-ink);text-decoration:underline;text-decoration-color:var(--blue);text-underline-offset:2px;font-weight:600}.article-content strong{color:var(--ink);font-weight:700}.article-content ul,.article-content ol{margin:0 0 18px;font-family:var(--font-body);font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--ink-80);max-width:var(--measure-text)}.article-content ol{padding-left:24px}.article-content ul{list-style:none;padding-left:0}.article-content ul>li{position:relative;padding-left:26px;margin-bottom:9px}.article-content ul>li:before{content:"";position:absolute;left:2px;top:.55em;width:10px;height:10px;background:var(--blue);clip-path:var(--cut-tri-up)}.article-content ol>li{margin-bottom:9px}.article-content hr{border:none;border-top:2px solid var(--ink);margin:34px 0}.article-content img{max-width:100%;height:auto;border:2px solid var(--ink);box-shadow:var(--shadow-raise)}.article-content>:where(.callout,.pullquote,.proscons,.columns,.chart,.dtable,.features,.panel,figure){margin:28px 0}.article-content table{width:100%;border-collapse:collapse;margin:28px 0;border:1px solid var(--ink);box-shadow:var(--shadow-soft);font-family:var(--font-ui);font-size:14px}.article-content thead th{background:var(--grad-brand);color:#fff;text-align:left;padding:12px 16px;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase}.article-content tbody td{padding:11px 16px;border-top:1px solid var(--hairline);color:var(--ink-80)}.showcase{border-top:4px solid var(--ink);margin-top:64px;padding-top:36px}.showcase__intro{max-width:720px;margin-bottom:36px}.showcase__intro h2{font-family:var(--font-grotesk);font-weight:800;font-size:clamp(28px,5vw,40px);letter-spacing:-.02em;color:var(--ink);margin:10px 0 12px}.showcase__intro p{font-family:var(--font-sans);font-size:17px;line-height:1.6;color:var(--ink-80);margin:0}.lib{display:grid;gap:14px;margin-bottom:44px}.lib__head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;border-bottom:2px solid var(--ink);padding-bottom:8px}.lib__name{font-family:var(--font-grotesk);font-weight:700;font-size:22px;color:var(--ink)}.lib__tag{font-family:var(--font-mono);font-size:12px;color:#fff;background:var(--ink);padding:3px 9px}.lib__desc{font-family:var(--font-sans);font-size:14.5px;color:var(--ink-55);margin:0}.lib__demo{background:var(--paper-warm);border:1px solid var(--hairline);padding:28px;display:grid;gap:16px}.lib__row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.lib__code{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-80);background:var(--ink);color:#fff;padding:12px 16px;overflow-x:auto;white-space:pre}.lib__code .tok{color:var(--orange)}.brand[data-astro-cid-hhuuaa7r]{display:inline-flex;align-items:center;text-decoration:none;line-height:0}.brand[data-astro-cid-hhuuaa7r] img[data-astro-cid-hhuuaa7r]{display:block}.brand--inverse[data-astro-cid-hhuuaa7r] img[data-astro-cid-hhuuaa7r]{filter:brightness(0) invert(1)}.nav-mega[data-astro-cid-ctg3m53h]{position:static;display:inline-flex}.nav-mega__btn[data-astro-cid-ctg3m53h]{display:inline-flex;align-items:center;gap:5px;border:none;background:transparent;cursor:pointer}.nav-mega__btn[data-astro-cid-ctg3m53h] svg[data-astro-cid-ctg3m53h]{transition:transform .18s ease}.mega[data-astro-cid-ctg3m53h]{position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--hairline);border-bottom:2px solid var(--ink);box-shadow:0 24px 40px -24px #0b0b1259;padding:26px 20px 22px;z-index:60;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .16s ease,transform .16s ease,visibility .16s}.nav-mega[data-astro-cid-ctg3m53h]:hover .mega[data-astro-cid-ctg3m53h],.nav-mega[data-astro-cid-ctg3m53h]:focus-within .mega[data-astro-cid-ctg3m53h],.nav-mega__btn[data-astro-cid-ctg3m53h][aria-expanded=true]+.mega[data-astro-cid-ctg3m53h]{opacity:1;visibility:visible;transform:translateY(0)}.nav-mega[data-astro-cid-ctg3m53h]:hover .nav-mega__btn[data-astro-cid-ctg3m53h] svg[data-astro-cid-ctg3m53h],.nav-mega[data-astro-cid-ctg3m53h]:focus-within .nav-mega__btn[data-astro-cid-ctg3m53h] svg[data-astro-cid-ctg3m53h]{transform:rotate(180deg)}.mega__grid[data-astro-cid-ctg3m53h]{max-width:var(--content-wide);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:22px 30px}.mega__col-title[data-astro-cid-ctg3m53h]{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:10px}.mega__col[data-astro-cid-ctg3m53h] ul[data-astro-cid-ctg3m53h]{list-style:none;margin:0;padding:0;display:grid;gap:7px}.mega__col[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]{font-family:var(--font-ui);font-size:14px;color:var(--ink-80);text-decoration:none}.mega__col[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]:hover{color:var(--blue-ink);text-decoration:underline;text-underline-offset:2px}.mega__all[data-astro-cid-ctg3m53h]{display:inline-block;max-width:var(--content-wide);margin:18px auto 0;font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--blue-ink);text-decoration:none}.mega__all[data-astro-cid-ctg3m53h]:hover{text-decoration:underline}.mobile-nav__group[data-astro-cid-ctg3m53h]{border-bottom:1px solid var(--hairline)}.mobile-nav__group[data-astro-cid-ctg3m53h] summary[data-astro-cid-ctg3m53h]{cursor:pointer;padding:12px 8px;font-family:var(--font-ui);font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.03em;font-size:13px;list-style:none}.mobile-nav__group[data-astro-cid-ctg3m53h] summary[data-astro-cid-ctg3m53h]::-webkit-details-marker{display:none}.mobile-nav__group[data-astro-cid-ctg3m53h] summary[data-astro-cid-ctg3m53h]:after{content:"+";float:right;color:var(--ink-55)}.mobile-nav__group[data-astro-cid-ctg3m53h][open] summary[data-astro-cid-ctg3m53h]:after{content:"–"}.mobile-nav__group[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]{display:block;padding:9px 8px 9px 20px;font-size:14px;color:var(--ink-80);text-decoration:none;border:none;text-transform:none;letter-spacing:0;font-weight:500}.mobile-nav__direct[data-astro-cid-ctg3m53h]{display:block;padding:12px 8px;font-family:var(--font-ui);font-weight:700;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--hairline);text-transform:uppercase;letter-spacing:.03em;font-size:13px}@media(max-width:860px){.nav-mega[data-astro-cid-ctg3m53h]{display:none}}
