:root{color-scheme:light;--bg: #f7f6f2;--surface: #ffffff;--surface-alt: #edf2e9;--surface-warm: #fff7ef;--surface-blue: #eef4ff;--ink: #20241e;--ink-soft: #2f372f;--muted: #647064;--line: #dde2d7;--accent: #3f7b5b;--accent-strong: #2f5e45;--accent-warm: #b5663f;--blue: #4669a6;--radius: 8px;--shadow: 0 18px 50px rgba(29, 36, 48, .1);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;color:var(--ink);background:linear-gradient(180deg,rgba(237,242,233,.78),transparent 360px),var(--bg)}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}code{padding:.12rem .34rem;border:1px solid var(--line);border-radius:6px;background:#f2f5ef;font-size:.92em}.page-shell{width:min(1120px,calc(100% - 32px));margin:0 auto}.site-header{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:88px}.brand{display:inline-flex;align-items:center;gap:12px}.brand-mark{display:grid;width:44px;height:44px;place-items:center;border-radius:var(--radius);color:#fff;background:var(--ink);font-size:.85rem;font-weight:800}.brand strong,.brand small{display:block}.brand small{margin-top:2px;color:var(--muted);font-size:.78rem}nav{display:flex;align-items:center;gap:6px}nav a{display:inline-flex;align-items:center;gap:7px;padding:10px 12px;border-radius:var(--radius);color:var(--muted);font-size:.95rem}nav a:hover,nav a.is-active{color:var(--ink);background:#ffffffb8}.nav-icon,.meta-icon,.link-icon,.section-icon{flex:0 0 auto;stroke-width:2.15}main{min-height:64vh}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);align-items:stretch;gap:28px;padding:56px 0 42px}.hero-copy{display:flex;min-height:420px;flex-direction:column;justify-content:center;padding:48px 0}.eyebrow{display:inline-flex;width:fit-content;align-items:center;gap:6px;color:var(--accent);font-size:.78rem;font-weight:800;text-transform:uppercase}.hero h1,.section-heading h1,.section-heading h2,.narrow-page h1{margin:10px 0 0;line-height:1.05}.hero h1{max-width:720px;font-size:4rem}.hero p{max-width:650px;color:var(--muted);font-size:1.13rem;line-height:1.75}.hero-actions{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:18px}.button-link{display:inline-flex;min-height:44px;align-items:center;justify-content:center;border-radius:var(--radius);padding:0 18px;color:#fff;background:var(--accent-strong);font-weight:800}.button-link:hover{background:var(--ink)}.text-link{display:inline-flex;width:fit-content;align-items:center;gap:6px;color:var(--blue);font-weight:800}.text-link:hover{text-decoration:underline;text-underline-offset:4px}.hero-feature{position:relative;overflow:hidden;min-height:420px;border-radius:var(--radius);background:var(--ink);box-shadow:var(--shadow)}.hero-feature img{width:100%;height:100%;min-height:420px;object-fit:cover;opacity:.82}.hero-feature div{position:absolute;right:20px;bottom:20px;left:20px;padding:18px;border-radius:var(--radius);color:#fff;background:#1d2430d1;backdrop-filter:blur(8px)}.hero-feature span,.hero-feature strong{display:block}.hero-feature span{margin-bottom:6px;color:#b7f0e8;font-size:.78rem;font-weight:800;text-transform:uppercase}.hero-feature strong{font-size:1.35rem;line-height:1.25}.section{padding:34px 0 56px}.section-heading{margin-bottom:24px}.section-heading h1,.section-heading h2{font-size:2.25rem}.blog-masthead{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:28px;align-items:end;padding:34px 0 28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.blog-masthead h1{max-width:780px;margin:10px 0 0;font-size:2.65rem;line-height:1.12}.blog-masthead p{max-width:700px;margin:14px 0 0;color:var(--muted);font-size:1.05rem;line-height:1.75}.blog-masthead-meta{display:grid;gap:10px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.blog-masthead-meta span{display:flex;align-items:baseline;justify-content:flex-start;gap:12px;color:var(--muted);font-size:.95rem}.blog-masthead-meta strong{color:var(--ink);font-size:1.25rem}.blog-home-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:28px;align-items:start;padding:28px 0 64px}.lead-post{position:relative;display:block;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,rgba(237,242,233,.55),transparent 48%),var(--surface)}.lead-post:before{display:block;height:6px;background:linear-gradient(90deg,var(--accent),var(--blue),var(--accent-warm));content:""}.lead-post.has-cover{display:grid;grid-template-columns:minmax(240px,.45fr) minmax(0,1fr)}.lead-post.has-cover:before{grid-column:1 / -1}.lead-post-image{min-height:300px;background:var(--surface-alt)}.lead-post-image img{width:100%;height:100%;object-fit:cover}.lead-post-body{display:flex;flex-direction:column;padding:clamp(28px,4vw,46px)}.lead-post.has-cover .lead-post-body{padding:30px}.lead-post h2{max-width:760px;margin:16px 0 0;font-size:clamp(2rem,4vw,3.45rem);line-height:1.1;letter-spacing:0;word-break:keep-all;overflow-wrap:break-word}.lead-post.has-cover h2{font-size:clamp(1.8rem,2.5vw,2.35rem)}.lead-post h2 a:hover{color:var(--accent-strong)}.lead-post p{max-width:680px;margin:14px 0 20px;color:var(--muted);font-size:1.08rem;line-height:1.82;word-break:keep-all}.lead-post .text-link{margin-top:auto}.blog-section{padding:28px 0 0}.compact-heading{margin-bottom:16px}.compact-heading h2{font-size:1.65rem}.home-post-list{display:grid;gap:16px}.home-post-list .post-card.has-cover{grid-template-columns:170px minmax(0,1fr)}.home-post-list .post-card-image,.home-post-list .post-card-body{min-height:170px}.home-post-list .post-card-body{padding:18px}.home-post-list .post-card.no-cover .post-card-body{min-height:150px}.home-post-list .post-card h2{margin-top:10px;font-size:1.1rem}.home-post-list .post-card p{margin:10px 0 14px;font-size:.95rem;line-height:1.55}.blog-sidebar{position:sticky;top:18px;display:grid;gap:16px}.sidebar-block{padding:20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.sidebar-block h2{display:flex;align-items:center;gap:8px;margin:0 0 14px;font-size:1.08rem;line-height:1.25}.sidebar-block p{margin:0 0 14px;color:var(--muted);line-height:1.65}.category-list{display:grid;gap:8px}.category-list a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);color:var(--muted);font-weight:700}.category-list a:last-child{border-bottom:0}.category-list a:hover{color:var(--accent-strong)}.category-list strong{min-width:30px;padding:3px 8px;border-radius:999px;color:var(--ink);background:var(--surface-alt);text-align:center;font-size:.82rem}.starter-list{display:grid;gap:12px;margin:0;padding-left:20px}.starter-list a{color:var(--ink);font-weight:750;line-height:1.45}.starter-list a:hover{color:var(--accent-strong)}.post-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:16px}.post-card{display:block;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.post-card.has-cover{display:grid;grid-template-columns:minmax(220px,300px) minmax(0,1fr)}.post-card-image{min-height:210px;background:var(--surface-alt)}.post-card-image img{width:100%;height:100%;object-fit:cover}.post-card-body{display:flex;min-height:210px;flex-direction:column;padding:24px 26px}.post-card.no-cover .post-card-body{min-height:auto}.eyebrow-row{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-start;gap:8px 16px;color:var(--muted);font-size:.82rem}.eyebrow-row .eyebrow,.eyebrow-row time{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.post-card h2{margin:14px 0 0;font-size:1.25rem;line-height:1.25}.post-card h2 a:hover{color:var(--accent-strong)}.post-card p{margin:12px 0 18px;color:var(--muted);line-height:1.65}.post-card .text-link{margin-top:auto}.split-band{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:28px;margin:22px 0 64px;padding:34px;border-radius:var(--radius);color:#fff;background:var(--ink)}.split-band h2{margin:8px 0 0;font-size:1.9rem;line-height:1.18}.split-band p{margin:0;color:#dbe3ea;line-height:1.75}.narrow-page{width:min(760px,100%);margin:0 auto;padding:42px 0 72px}.article-shell{width:min(820px,100%);margin:0 auto;padding:42px 0 72px}.narrow-page h1,.article-header h1{margin:12px 0 0;font-size:3rem;line-height:1.08}.narrow-page p,.narrow-page li{color:var(--muted);font-size:1.06rem;line-height:1.8}.narrow-page h2{margin-top:34px}.article-header p{color:var(--muted);font-size:1.12rem;line-height:1.75}.article-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.92rem}.article-meta time,.article-meta span{display:inline-flex;align-items:center;gap:6px}.article-cover{width:100%;aspect-ratio:16 / 9;margin-top:28px;border-radius:var(--radius);object-fit:cover}.article-content{margin-top:34px;color:var(--ink-soft);font-size:1.08rem;line-height:1.88;word-break:keep-all;overflow-wrap:break-word}.article-content h2{margin:46px 0 20px;padding:.82rem 1rem .88rem 1.1rem;border-left:5px solid var(--accent);border-radius:var(--radius);color:var(--ink);background:linear-gradient(90deg,#edf2e9f2,#fff0);font-size:clamp(1.72rem,3vw,2.25rem);line-height:1.22;letter-spacing:0;word-break:keep-all}.article-content h3{margin:38px 0 14px;color:var(--accent-strong);font-size:1.42rem;line-height:1.32;letter-spacing:0}.article-content h4{margin:30px 0 12px;color:#365b87;font-size:1.17rem;line-height:1.35;letter-spacing:0}.article-content p,.article-content li{color:var(--ink-soft)}.article-content p{margin:1.12rem 0}.article-content ul,.article-content ol{padding-left:1.35rem}.article-content li+li{margin-top:.38rem}.article-content li::marker{color:var(--accent);font-weight:800}.article-content blockquote{margin:24px 0;padding:16px 18px;border-left:5px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;color:#263226;background:#eef4ea}.article-content blockquote.safety-note{border-left-color:var(--accent-warm);color:#4d3124;background:var(--surface-warm)}.article-content blockquote p{margin:0;color:inherit;font-size:.98rem;line-height:1.72}.article-content p.article-kicker{width:fit-content;margin:.72rem 0;padding:.36rem .68rem;border:1px solid rgba(63,123,91,.22);border-radius:var(--radius);color:var(--accent-strong);background:#edf2e9db;font-weight:850;line-height:1.45}.article-content p.article-label,.article-content p.article-step,.article-content p.article-structured,.article-content p.article-question,.article-content p.article-caution{margin:1.4rem 0;padding:.88rem 1rem;border-radius:var(--radius);font-weight:760;line-height:1.72}.article-content p.article-label{border-left:4px solid var(--accent);color:#244632;background:#edf2e9e6}.article-content p.article-question{border-left:4px solid var(--blue);color:#293f65;background:var(--surface-blue)}.article-content p.article-step,.article-content p.article-structured{border:1px solid rgba(70,105,166,.2);border-left:4px solid var(--blue);color:#2d436a;background:#eef4ffb8;font-weight:700}.article-content p.article-caution{border-left:4px solid var(--accent-warm);color:#583222;background:var(--surface-warm)}.article-content strong:not(.term){color:var(--ink);font-weight:850}.article-content .term{padding:.03em .22em .06em;border-radius:5px;font-weight:850;box-decoration-break:clone;-webkit-box-decoration-break:clone}.article-content .term-core{color:#23583f;background:#3f7b5b21}.article-content .term-flow{color:#315b91;background:#4669a624}.article-content .term-relation{color:#6c4b12;background:#b5882e29}.article-content .term-warn{color:#924422;background:#b5663f26}.article-content table{display:block;overflow-x:auto;width:100%;margin:24px 0 30px;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.article-content th,.article-content td{padding:10px 12px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:left;vertical-align:top}.article-content th{color:var(--ink);background:#edf2e9;font-weight:850}.article-content td{color:var(--ink-soft)}.article-content img{margin:26px auto 10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.article-content em{color:#5d685d}.article-content pre{overflow-x:auto;margin:20px 0 28px;padding:18px 20px;border:1px solid #c8d4e0;border-left:4px solid var(--accent);border-radius:var(--radius);color:var(--ink)!important;background:#f8fafc!important;box-shadow:inset 0 0 0 1px #ffffffb8;font-size:.98rem;line-height:1.75}.article-content pre code{display:block;padding:0;border:0;border-radius:0;color:inherit!important;background:transparent;white-space:pre-wrap}.article-content pre .line{display:block}.article-content a{color:var(--blue);font-weight:700;text-decoration:underline;text-underline-offset:4px}.article-content a[href^=http]:after{display:inline-block;width:.8em;height:.8em;margin-left:.22em;background:currentColor;content:"";vertical-align:-.08em;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h6v6'/%3E%3Cpath d='M10 14 21 3'/%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3C/svg%3E") center / contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h6v6'/%3E%3Cpath d='M10 14 21 3'/%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3C/svg%3E") center / contain no-repeat}.tag-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px;padding-top:24px;border-top:1px solid var(--line)}.tag-list a{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px;color:var(--muted);background:var(--surface);font-size:.9rem;font-weight:700}.tag-list a:hover{color:var(--ink);border-color:var(--accent)}.site-footer{display:flex;justify-content:space-between;gap:24px;padding:34px 0 42px;border-top:1px solid var(--line);color:var(--muted)}.site-footer p{max-width:540px;margin:8px 0 0;line-height:1.6}.footer-meta{text-align:right}@media(max-width:880px){.site-header,.site-footer{align-items:flex-start;flex-direction:column}.hero,.blog-masthead,.blog-home-layout,.lead-post{grid-template-columns:1fr}.blog-sidebar{position:static}.hero-copy{min-height:auto;padding:28px 0 0}.hero h1{font-size:3rem}.post-grid,.split-band,.post-card.has-cover{grid-template-columns:1fr}.eyebrow-row{align-items:flex-start;flex-direction:column;gap:8px}.home-post-list .post-card.has-cover{grid-template-columns:1fr}.post-card-image,.post-card-body{min-height:auto}.post-card-image{aspect-ratio:16 / 9}.home-post-list .post-card-image,.lead-post-image{min-height:auto;aspect-ratio:16 / 9}.footer-meta{text-align:left}}@media(max-width:560px){.page-shell{width:min(100% - 22px,1120px)}nav{width:100%;overflow-x:auto;padding-bottom:4px}.hero h1,.blog-masthead h1,.narrow-page h1,.article-header h1{font-size:2.3rem}.blog-masthead{padding:26px 0 22px}.blog-home-layout{padding-top:20px}.lead-post-body,.sidebar-block{padding:18px}.lead-post h2{font-size:2rem}.hero-feature,.hero-feature img{min-height:320px}.split-band{padding:24px}}
