:root{color-scheme:light;--bg: #f3f5f8;--bg-accent: #eef4fb;--surface: #ffffff;--surface-soft: #f7f9fc;--border: #d7dde7;--text: #1f2937;--text-soft: #526072;--heading: #162033;--accent: #0f5cc0;--accent-soft: #dce9fb;--code-bg: #0f172a;--code-border: #22314d;--code-text: #e8eef8;background:var(--bg);color:var(--text);font-family:Hiragino Sans,Yu Gothic,Meiryo,Segoe UI,sans-serif;line-height:1.8}*{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{margin:0;background:linear-gradient(180deg,var(--bg-accent) 0%,var(--bg) 18rem,var(--bg) 100%);color:var(--text);overflow-x:clip}body,h1,h2,h3,h4,p,ul,ol,pre,blockquote{margin:0}img,svg,video,canvas{display:block;max-width:100%}img{height:auto}a{color:var(--accent);text-decoration-thickness:.08em;text-underline-offset:.16em}a:hover{text-decoration-thickness:.14em}code,pre{font-family:JetBrains Mono,Cascadia Code,Consolas,monospace}.site-shell{min-height:100vh;overflow-x:clip}.site-header{position:sticky;top:0;z-index:10;backdrop-filter:blur(12px);background:#f3f5f8e0;border-bottom:1px solid rgb(215 221 231 / .9)}.site-header__inner{max-width:72rem;margin:0 auto;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem 1.5rem;flex-wrap:wrap}.site-brand{display:inline-flex;flex-direction:column;gap:.2rem;color:inherit;text-decoration:none;min-width:0}.site-brand__title{font-size:1.05rem;font-weight:800;letter-spacing:.01em;color:var(--heading)}.site-brand__tagline{font-size:.86rem;line-height:1.5;color:var(--text-soft)}.site-nav{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}.site-nav__link{display:inline-flex;align-items:center;justify-content:center;min-height:2.4rem;padding:.5rem .9rem;border-radius:.75rem;color:var(--text-soft);text-decoration:none;font-weight:700}.site-nav__link:hover,.site-nav__link.is-active{background:var(--surface);color:var(--heading);box-shadow:0 8px 24px #0f172a0f}.site-main{max-width:72rem;margin:0 auto;padding:2.25rem 1.25rem 4rem;min-width:0;overflow-x:clip}.site-main>*+*{margin-top:1.5rem}.site-main>.breadcrumbs:first-child+*{margin-top:0}ul{padding-left:1.25rem}.page-hero{max-width:56rem;margin:0 auto;padding:.5rem 0 .75rem}.section-heading{max-width:56rem;margin:0 auto}.section-heading__row{display:flex;align-items:end;justify-content:space-between;gap:1rem 1.5rem;flex-wrap:wrap}.section-heading__title,.section-heading h2{margin-top:.6rem;font-size:clamp(1.55rem,3vw,2.1rem);line-height:1.2;color:var(--heading)}.site-footer{max-width:72rem;margin:0 auto;padding:2rem 1.25rem;text-align:center;font-size:.85rem;color:var(--text-soft);border-top:1px solid var(--border)}.back-nav{max-width:56rem;margin:0 auto}.breadcrumbs{max-width:56rem;margin:0 auto 1rem}.breadcrumbs__list{display:flex;flex-wrap:wrap;gap:.45rem .7rem;align-items:center;list-style:none;padding:0;font-size:.9rem;color:var(--text-soft)}.breadcrumbs__item{display:inline-flex;align-items:center;gap:.7rem;min-width:0}.breadcrumbs__item:not(:last-child):after{content:">";color:#7a8798}.breadcrumbs__link{color:var(--text-soft);text-decoration:none}.breadcrumbs__link:hover{color:var(--accent)}.breadcrumbs__current{color:var(--heading);font-weight:700}.back-nav a{color:var(--text-soft);text-decoration:none;font-size:.92rem}.back-nav a:hover{color:var(--accent)}.section-heading p{margin-top:.7rem;color:var(--text-soft)}.eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.page-hero h1{margin-top:.9rem;font-size:clamp(2rem,4vw,3.4rem);line-height:1.15;letter-spacing:-.02em;color:var(--heading)}.page-hero .lead{max-width:40rem;text-wrap:pretty}.lead{margin-top:1rem;font-size:clamp(1.02rem,2vw,1.18rem);color:var(--text-soft)}.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.5rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:2.8rem;padding:.75rem 1.1rem;border-radius:999px;background:var(--heading);color:#fff;text-decoration:none;font-weight:700;box-shadow:0 12px 30px #16203324}.button--secondary{background:var(--surface);color:var(--heading);border:1px solid var(--border);box-shadow:none}.panel,article,.card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;box-shadow:0 18px 42px #0f172a0d}.panel{max-width:56rem;margin:0 auto;padding:1.35rem 1.45rem}article{max-width:56rem;margin:0 auto;padding:1.65rem;overflow:hidden;min-width:0}.post-header{padding-bottom:1.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.post-header h1{font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.18;letter-spacing:-.02em;color:var(--heading);text-wrap:balance}.post-header .lead{max-width:44rem;text-wrap:pretty}.list{display:grid;gap:1rem;list-style:none;padding:0;max-width:56rem;margin:0 auto}.card{display:flex;flex-direction:column;padding:0;overflow:hidden}.card__link{display:block;flex:1 1 auto;padding:1.2rem 1.25rem;color:inherit;text-decoration:none}.card__link:hover{background:var(--surface-soft)}.card__link:focus-visible{outline:3px solid rgb(15 92 192 / .2);outline-offset:-3px}.card h2{margin-top:.5rem;font-size:1.25rem;line-height:1.35}.card__link p+p{margin-top:.75rem}.card__link:hover h2{color:var(--accent)}.card__desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card__footer{padding:0 1.25rem 1.15rem}.card__link+.card__footer{margin-top:0}.meta{color:var(--text-soft);font-size:.92rem}.meta--pill{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;border-radius:999px;background:var(--surface-soft);border:1px solid var(--border)}.tag-list,.tag-directory{display:flex;flex-wrap:wrap;gap:.55rem;list-style:none;padding:0}.tag-list{margin-top:1rem}.tag-list--compact{margin-top:0}.tag-chip{display:inline-flex;align-items:center;justify-content:center;min-height:1.95rem;padding:.28rem .7rem;border-radius:999px;background:#eef4fb;border:1px solid #d7e4f6;color:#275287;font-size:.82rem;font-weight:700;line-height:1.2;text-decoration:none}.tag-chip:hover{background:#deecff;color:#0f5cc0}.tag-directory{display:grid;gap:1rem;max-width:56rem;margin:0 auto}.post-header__meta{display:flex;gap:.65rem;flex-wrap:wrap}article :where(h2,h3,h4){color:var(--heading);line-height:1.35;letter-spacing:-.01em}article h2{margin-top:2.4rem;margin-bottom:.95rem;font-size:1.55rem}article h3{margin-top:1.85rem;margin-bottom:.75rem;font-size:1.22rem}article p,article ul,article ol,article pre,article blockquote,article table{margin-top:1rem}article>*{max-width:100%;min-width:0}article p,article li,.panel p{overflow-wrap:anywhere}article ul,article ol{padding-left:1.45rem}article :where(ul,ol):not(.tag-list):not(.post-toc__list):not(.series-panel__list)>li+li{margin-top:.35rem}.tag-list>li,.tag-list>li+li{margin-top:0}article hr{border:0;border-top:1px solid var(--border);margin:2rem 0}article blockquote{padding:1rem 1.1rem;border-left:4px solid var(--accent);background:var(--surface-soft);color:var(--text-soft);border-radius:0 .85rem .85rem 0}article img{width:auto;max-width:100%;height:auto;border-radius:.9rem;border:1px solid var(--border);box-shadow:0 18px 36px #0f172a14}article p>img:only-child,article p>a:only-child>img:only-child{display:inline-block;margin-left:0;margin-right:0;max-width:100%}article p>a:only-child{display:inline-block;max-width:100%}article p:has(>img:only-child),article p:has(>a:only-child>img:only-child){text-align:left;overflow:hidden}article pre,article .astro-code{max-width:100%;overflow-x:auto;overflow-y:hidden}.code-block{position:relative;margin-top:1rem}.code-block>pre{margin-top:0;padding-top:3rem}.code-copy-badge{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;gap:.5rem;min-height:2rem;padding:.35rem .7rem;border:1px solid rgb(255 255 255 / .12);border-radius:999px;background:#0f172ab8;color:#e8eef8eb;font:inherit;font-size:.78rem;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.code-copy-badge:hover{background:#0f5cc0e6;border-color:#dce9fb66;color:#fff}.code-copy-badge:focus-visible{outline:3px solid rgb(220 233 251 / .35);outline-offset:2px}.code-copy-badge.is-copied{background:#057a55eb;border-color:#a7f3d073;color:#f0fdf4}.code-copy-badge__icon{position:relative;width:.9rem;height:.9rem;flex:none}.code-copy-badge__icon:before,.code-copy-badge__icon:after{content:"";position:absolute;border:1.5px solid currentColor;border-radius:.18rem;background:transparent}.code-copy-badge__icon:before{width:.62rem;height:.62rem;top:.18rem;left:.22rem;opacity:.85}.code-copy-badge__icon:after{width:.62rem;height:.62rem;top:0;left:0}article pre{padding:1rem 1.05rem;border-radius:.95rem;background:var(--code-bg);border:1px solid var(--code-border);color:var(--code-text);line-height:1.7;box-shadow:inset 0 1px #ffffff08}article pre code{display:block;background:transparent;color:inherit;padding:0;border:0;border-radius:0;font-size:.94rem;overflow-wrap:normal;white-space:pre}article :not(pre)>code,.panel code{padding:.18rem .4rem;border-radius:.45rem;background:#eef3fb;border:1px solid #d8e2f1;color:#1d3557;font-size:.92em}article table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;background:linear-gradient(to right,var(--surface) 30%,transparent),linear-gradient(to left,var(--surface) 30%,transparent),linear-gradient(to right,rgb(0 0 0 / .08),transparent 1.5rem),linear-gradient(to left,rgb(0 0 0 / .08),transparent 1.5rem);background-attachment:local,local,scroll,scroll;background-size:100% 100%;background-repeat:no-repeat;background-position:left,right,left,right}article table th,article table td{padding:.75rem .85rem;border:1px solid var(--border);text-align:left;vertical-align:top}article table th{background:var(--surface-soft)}.list--nested{max-width:none;margin-top:1.2rem}.related-posts{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.related-posts h2{margin-top:0;margin-bottom:0}.related-posts__lead{margin-top:.7rem;color:var(--text-soft)}@media(max-width:720px){.site-header__inner{padding:.9rem 1rem}.site-brand,.site-nav{width:100%}.site-main{padding:1.4rem .95rem 3rem}.breadcrumbs{margin-bottom:.85rem}.page-hero h1,.post-header h1{line-height:1.22}.section-heading__row{align-items:start}.panel,article,.card{border-radius:.9rem}.panel,article{padding:1.2rem}.card{padding:0}.card__link{padding:1rem 1.05rem}.card__footer{padding:0 1.05rem 1rem}.code-copy-badge{top:.65rem;right:.65rem}}@media(max-width:480px){html{font-size:15px}.site-nav__link{padding-inline:.75rem}}
