.article-shell{padding:144px 24px 80px}.article-container{width:min(860px,100%);margin:0 auto}.article-header{margin-bottom:40px}.article-kicker{color:var(--accent, #7dd3fc);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.article-title{margin:12px 0 16px;font-size:clamp(2.25rem,6vw,4.5rem);line-height:1.02}.article-description{color:#ffffffb8;font-size:1.15rem;line-height:1.8}.article-meta{color:#ffffff8c;display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;font-size:.9rem}.article-prose{color:#ffffffd1;font-size:1.05rem;line-height:1.9}.article-prose h2{color:#fff;font-size:2rem;line-height:1.2;margin:56px 0 16px}.article-prose h3{color:#fff;font-size:1.35rem;margin:36px 0 12px}.article-prose a{color:#7dd3fc}.article-prose table{border-collapse:collapse;display:block;margin:28px 0;overflow-x:auto;width:100%}.article-prose th,.article-prose td{border-bottom:1px solid rgba(255,255,255,.14);padding:14px 12px;text-align:left}.article-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;margin:40px 0;padding:24px}.article-cta{align-items:flex-start;display:flex;flex-direction:column;gap:10px}.cta-primary{background:#fff;border-radius:999px;color:#0b0b12;display:inline-flex;font-weight:700;padding:14px 22px;text-decoration:none}.cta-sub{color:#ffffffa3;margin:0}.related-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.related-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;display:block;padding:18px;text-decoration:none}.related-type{color:#ffffff8a;display:block;font-size:.78rem;margin-bottom:8px;text-transform:uppercase}.article-container--index{width:min(1080px,100%)}.article-index-grid{display:grid;gap:20px;grid-template-columns:1fr;margin-top:32px}@media(min-width:560px){.article-index-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:900px){.article-index-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.article-index-empty{grid-column:1 / -1;padding:64px 24px;text-align:center;color:#0000008c;font-size:15px;background:#00000005;border-radius:16px}.article-index-card{background:#ffffff0e;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;display:flex;flex-direction:column;min-height:100%;overflow:hidden;text-decoration:none;transition:border-color .18s ease,transform .18s ease}.article-index-card:hover{border-color:#a0d3d973;transform:translateY(-2px)}.article-index-thumb{aspect-ratio:16 / 9;background:#ffffff14;object-fit:cover;width:100%}.article-index-body{display:flex;flex:1;flex-direction:column;gap:8px;padding:16px 18px 18px}.article-index-type,.article-index-card time{color:#ffffff8f;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.article-index-card h2{display:-webkit-box;font-size:1rem;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-height:1.4;margin:0;overflow:hidden}.article-index-card p{color:#ffffffad;display:-webkit-box;flex:1;font-size:.85rem;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-height:1.6;margin:0;overflow:hidden}.article-index-card time{display:block;margin-top:auto;padding-top:8px}.article{padding:140px 24px 100px}.article-inner{max-width:760px;margin:0 auto}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--slate);margin-bottom:28px;flex-wrap:wrap}.breadcrumb a{color:var(--silver);transition:color var(--duration-fast) var(--ease)}.breadcrumb a:hover{color:var(--glacier)}.breadcrumb .sep{color:var(--slate);opacity:.6}.breadcrumb .current{color:var(--snow);opacity:.7}.article-header{margin-bottom:56px}.article-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--glacier);margin-bottom:20px}.article-eyebrow:before{content:"";display:inline-block;width:24px;height:1px;background:var(--glacier)}.article-title{font-size:clamp(32px,5vw,44px);font-weight:700;line-height:1.2;letter-spacing:-.02em;color:var(--snow);margin-bottom:24px}.article-deck{font-size:19px;line-height:1.75;font-weight:500;color:var(--snow);opacity:.92;margin-bottom:32px}.article-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--slate);flex-wrap:wrap;padding:18px 0;border-top:1px solid var(--graphite);border-bottom:1px solid var(--graphite)}.article-meta .meta-author{display:flex;align-items:center;gap:10px;color:var(--snow);font-weight:500}.article-meta .meta-author img{width:28px;height:28px;border-radius:50%;object-fit:cover}.article-meta .meta-dot{color:var(--slate);opacity:.5}.persona-badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--glacier);background:#a0d3d914;border:1px solid rgba(160,211,217,.25);border-radius:999px}.tldr{margin:0 0 48px;padding:28px 32px;background:linear-gradient(135deg,#a0d3d90f,#a0d3d905);border:1px solid rgba(160,211,217,.18);border-radius:14px}.tldr-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--glacier);margin-bottom:14px}.tldr p{font-size:17px;line-height:1.8;font-weight:500;color:var(--snow);margin:0 0 10px}.tldr p:last-child{margin-bottom:0}.tldr strong{color:var(--snow);font-weight:700}.prose{font-size:18px;line-height:1.9;font-weight:500;color:var(--snow);letter-spacing:.005em}.prose h2{font-size:clamp(25px,3.2vw,32px);font-weight:700;letter-spacing:-.01em;color:var(--snow);margin:64px 0 20px;padding-top:8px}.prose h2:first-child{margin-top:0}.prose h3{font-size:21px;font-weight:700;color:var(--snow);margin:40px 0 16px}.prose h4{font-size:18px;font-weight:700;color:var(--glacier);margin:28px 0 12px}.prose p{margin:0 0 22px}.prose p:last-child{margin-bottom:0}.prose strong{color:var(--snow);font-weight:800}.prose em{color:var(--snow);font-style:normal;font-weight:700}.prose a{color:var(--glacier);border-bottom:1px solid rgba(160,211,217,.35);transition:all var(--duration-fast) var(--ease)}.prose a:hover{color:var(--snow);border-bottom-color:var(--snow)}.prose ul,.prose ol{margin:0 0 24px;padding-left:0;list-style:none}.prose ul li,.prose ol li{position:relative;padding-left:28px;margin-bottom:10px}.prose ul li:before{content:"";position:absolute;left:8px;top:14px;width:5px;height:5px;border-radius:50%;background:var(--glacier)}.prose ol{counter-reset:ol-counter}.prose ol li{counter-increment:ol-counter}.prose ol li:before{content:counter(ol-counter);position:absolute;left:0;top:0;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--glacier);width:20px;text-align:right;line-height:32px}.prose blockquote{margin:32px 0;padding:4px 0 4px 24px;border-left:3px solid var(--glacier);font-size:18px;font-weight:500;line-height:1.7;color:var(--snow);opacity:.85;font-style:italic}.prose blockquote p{margin:0}.prose code{font-family:var(--mono);font-size:.9em;padding:2px 6px;background:#ffffff0f;border:1px solid var(--graphite);border-radius:4px;color:var(--glacier)}.prose pre{margin:24px 0;padding:20px 24px;background:var(--charcoal);border:1px solid var(--graphite);border-radius:12px;overflow-x:auto;font-family:var(--mono);font-size:14px;line-height:1.6;color:var(--silver)}.prose pre code{padding:0;background:none;border:none;color:inherit}.prose hr{margin:56px 0;border:0;height:1px;background:var(--graphite)}.prose figure{margin:32px 0}.prose img{width:100%;border-radius:12px;border:1px solid var(--graphite)}.prose figcaption{margin-top:12px;font-size:13px;color:var(--slate);text-align:center}.cmp-table-wrap{margin:32px 0 40px;border:1px solid var(--graphite);border-radius:14px;overflow:hidden;background:var(--charcoal)}.cmp-table-scroll{overflow-x:auto}.cmp-table{width:100%;border-collapse:collapse;font-size:15px;min-width:540px}.cmp-table th,.cmp-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--graphite);vertical-align:top}.cmp-table thead th{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);background:#0003;border-bottom:1px solid var(--graphite)}.cmp-table tbody th{font-weight:600;color:var(--snow);width:36%;background:#0000001f}.cmp-table td{color:var(--snow);opacity:.92}.cmp-table .col-karui{color:var(--glacier);font-weight:600;position:relative}.cmp-table thead .col-karui{color:var(--glacier);opacity:1}.cmp-table tbody tr:last-child th,.cmp-table tbody tr:last-child td{border-bottom:none}.cmp-table .num{font-family:var(--mono);font-variant-numeric:tabular-nums}.cmp-table .row-cost{background:linear-gradient(to right,#f294410f,#f2944105)}.cmp-table .row-cost td.col-karui{color:var(--sunset);font-weight:700}.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:32px 0}.pros-cons .card{padding:24px 28px;border-radius:14px;border:1px solid var(--graphite);background:var(--charcoal)}.pros-cons .card-title{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px}.pros-cons .pros .card-title{color:var(--success)}.pros-cons .cons .card-title{color:var(--sunset)}.pros-cons ul{margin:0;list-style:none;padding:0}.pros-cons ul li{position:relative;padding-left:22px;margin-bottom:10px;font-size:15px;line-height:1.6;color:var(--snow);opacity:.9}.pros-cons ul li:before{position:absolute;left:0;top:0;font-family:var(--mono);font-weight:700;font-size:14px}.pros-cons .pros ul li:before{content:"+";color:var(--success)}.pros-cons .cons ul li:before{content:"−";color:var(--sunset)}@media(max-width:640px){.pros-cons{grid-template-columns:1fr}}.callout{margin:32px 0;padding:22px 26px;border-radius:12px;border:1px solid var(--graphite);background:var(--charcoal);font-size:15px;line-height:1.7;color:var(--snow)}.callout-label{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;color:var(--silver)}.callout p{margin:0 0 8px}.callout p:last-child{margin-bottom:0}.callout.callout-info{border-color:#a0d3d94d;background:linear-gradient(135deg,#a0d3d90d,#a0d3d903)}.callout.callout-info .callout-label{color:var(--glacier)}.callout.callout-coupon{border-color:#f2944159;background:linear-gradient(135deg,#f2944114,#f2944105)}.callout.callout-coupon .callout-label{color:var(--sunset)}.callout.callout-coupon strong{color:var(--sunset);font-family:var(--mono);font-size:1.1em;letter-spacing:.04em}.callout.callout-method{border-color:var(--graphite)}.callout.callout-method dl{display:grid;grid-template-columns:max-content 1fr;gap:8px 20px;margin:0}.callout.callout-method dt{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--slate)}.callout.callout-method dd{margin:0;font-size:14px;color:var(--snow);opacity:.88;font-family:var(--mono)}.cta-card{margin:56px 0;padding:40px 36px;border-radius:16px;border:1px solid var(--graphite);background:linear-gradient(135deg,rgba(160,211,217,.06),rgba(242,148,65,.04) 60%,var(--charcoal));text-align:center}.cta-card .cta-eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--glacier);margin-bottom:14px}.cta-card .cta-headline{font-size:clamp(22px,3vw,28px);font-weight:700;line-height:1.3;letter-spacing:-.01em;color:var(--snow);margin-bottom:12px}.cta-card .cta-sub{font-size:15px;color:var(--snow);opacity:.75;margin-bottom:28px}.cta-card .cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.cta-card .cta-tag{display:block;margin-top:18px;font-size:12px;color:var(--slate);letter-spacing:.04em}.cta-inline{margin:40px 0;padding:20px 24px;border-radius:12px;border:1px solid var(--graphite);background:var(--charcoal);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.cta-inline .cta-inline-text{font-size:15px;font-weight:500;color:var(--snow);flex:1;min-width:220px}.cta-inline .cta-inline-text strong{color:var(--glacier);font-weight:600}.article-faq{margin:56px 0}.article-faq .faq-h{font-size:24px;font-weight:700;color:var(--snow);margin-bottom:24px}.article-faq details{padding:20px 4px;border-bottom:1px solid var(--graphite)}.article-faq details:last-child{border-bottom:none}.article-faq summary{list-style:none;cursor:pointer;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;font-size:16px;font-weight:600;color:var(--snow);line-height:1.5}.article-faq summary::-webkit-details-marker{display:none}.article-faq summary:after{content:"+";font-family:var(--mono);font-size:22px;font-weight:400;color:var(--glacier);line-height:1;flex-shrink:0;transition:transform var(--duration-fast) var(--ease)}.article-faq details[open] summary:after{content:"−"}.article-faq details>p,.article-faq details>div{margin-top:14px;font-size:16px;line-height:1.8;font-weight:500;color:var(--snow);opacity:.92}.author-box{margin:56px 0 0;padding:28px;border-radius:16px;background:var(--charcoal);border:1px solid var(--graphite);display:flex;gap:24px;align-items:flex-start}.author-box-photo{flex-shrink:0;width:72px;height:72px;border-radius:50%;overflow:hidden;border:1px solid var(--graphite)}.author-box-photo img{width:100%;height:100%;object-fit:cover;display:block}.author-box-body{flex:1;min-width:0}.author-box-name{font-size:16px;font-weight:700;color:var(--snow);margin-bottom:4px}.author-box-handle{font-size:13px;color:var(--slate);font-family:var(--mono);margin-bottom:12px}.author-box-handle a{color:var(--glacier)}.author-box-bio{font-size:14px;line-height:1.75;color:var(--snow);opacity:.82}.author-box-bio a{color:var(--glacier);border-bottom:1px solid rgba(160,211,217,.3)}@media(max-width:540px){.author-box{flex-direction:column;text-align:left;gap:16px}}.related{margin:80px 0 0;padding-top:56px;border-top:1px solid var(--graphite)}.related-h{font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:24px}.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.related-card{display:block;padding:24px;border-radius:14px;border:1px solid var(--graphite);background:var(--charcoal);transition:all var(--duration-fast) var(--ease);height:100%}.related-card:hover{border-color:var(--slate);transform:translateY(-2px);background:#28282fb3}.related-card .type-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--glacier);margin-bottom:12px}.related-card .related-title{font-size:15px;font-weight:600;line-height:1.5;color:var(--snow);margin:0}@media(max-width:768px){.related-grid{grid-template-columns:1fr}}.toc{margin:32px 0 40px;padding:20px 24px;border-radius:12px;background:var(--charcoal);border:1px solid var(--graphite)}.toc-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:12px}.toc ol{list-style:none;margin:0;padding:0;counter-reset:toc}.toc ol li{counter-increment:toc;padding:6px 0 6px 28px;position:relative;font-size:14px}.toc ol li:before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:6px;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--glacier);opacity:.7}.toc a{color:var(--snow);opacity:.78;transition:opacity var(--duration-fast) var(--ease)}.toc a:hover{opacity:1;color:var(--glacier)}.demo{margin:32px 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}.demo-card{position:relative;aspect-ratio:4 / 3;border-radius:12px;overflow:hidden;background:var(--charcoal);border:1px solid var(--graphite)}.demo-card img{width:100%;height:100%;object-fit:cover}.demo-card .demo-label{position:absolute;top:12px;left:12px;padding:6px 12px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:#0c0c0fd9;backdrop-filter:blur(8px);border-radius:6px;color:var(--snow)}.demo-card .demo-size{position:absolute;bottom:12px;left:12px;padding:6px 12px;font-size:13px;font-family:var(--mono);background:#0c0c0fd9;backdrop-filter:blur(8px);border-radius:6px;color:var(--glacier);font-weight:600}@media(max-width:640px){.demo{grid-template-columns:1fr}}@media(max-width:768px){.article{padding:120px 20px 80px}.cta-card{padding:32px 24px}.author-box{padding:24px}}@media(max-width:480px){.article-meta{gap:10px;font-size:12px}.tldr{padding:22px}}
