@font-face{font-family:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/blog/_astro/bricolage-grotesque-vietnamese-wght-normal.BUzh504Q.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:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/blog/_astro/bricolage-grotesque-latin-ext-wght-normal.CcLUaPy7.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:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/blog/_astro/bricolage-grotesque-latin-wght-normal.DLoelf7F.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}@font-face{font-family:Instrument Sans Variable;font-style:normal;font-display:swap;font-weight:400 700;src:url(/blog/_astro/instrument-sans-latin-ext-wght-normal.B5bTHO_g.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:Instrument Sans Variable;font-style:normal;font-display:swap;font-weight:400 700;src:url(/blog/_astro/instrument-sans-latin-wght-normal.BbzFLZTg.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}:root{--bg: #0c0714;--bg-elevated: #140d22;--surface: rgba(255, 255, 255, .04);--surface-hover: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--text: #efeaf9;--text-muted: #a89ec6;--text-faint: #6f6590;--violet: #a78bfa;--pink: #f472b6;--grad-accent: linear-gradient(100deg, #a78bfa 0%, #f472b6 55%, #fb7185 100%);--font-display: "Bricolage Grotesque Variable", "Bricolage Grotesque", sans-serif;--font-body: "Instrument Sans Variable", "Instrument Sans", sans-serif;--radius: 18px;--radius-sm: 10px;--max-width: 76rem;--measure: 42rem;color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background-color:var(--bg);color:var(--text);font-family:var(--font-body);font-size:1.0625rem;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}.scene-glow{position:fixed;inset:0;z-index:-2;pointer-events:none;background:radial-gradient(42rem 30rem at 12% -8%,rgba(109,66,210,.28),transparent 65%),radial-gradient(36rem 26rem at 95% 8%,rgba(244,114,182,.13),transparent 60%),radial-gradient(50rem 36rem at 50% 115%,rgba(76,41,145,.22),transparent 65%),linear-gradient(to bottom,#150c28,var(--bg) 42rem)}.scene-grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.12;letter-spacing:-.02em;text-wrap:balance;margin:0}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}::selection{background:#a78bfa59}.container{width:min(100% - 2.5rem,var(--max-width));margin-inline:auto}.grad-text{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}.chip{display:inline-flex;align-items:center;gap:.45em;font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.32em .9em;border-radius:999px;border:1px solid color-mix(in srgb,var(--chip-color, var(--violet)) 45%,transparent);color:var(--chip-color, var(--violet));background:color-mix(in srgb,var(--chip-color, var(--violet)) 10%,transparent);transition:background .2s ease,border-color .2s ease}a.chip:hover{background:color-mix(in srgb,var(--chip-color, var(--violet)) 20%,transparent);border-color:color-mix(in srgb,var(--chip-color, var(--violet)) 70%,transparent)}.chip:before{content:"";width:.5em;height:.5em;border-radius:50%;background:var(--chip-color, var(--violet));box-shadow:0 0 8px var(--chip-color, var(--violet))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:.7em 1.5em;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.btn-primary{background:var(--grad-accent);color:#16091f;box-shadow:0 4px 24px #be64dc59}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #be64dc80}.btn-ghost{border-color:var(--border-strong);color:var(--text);background:var(--surface)}.btn-ghost:hover{background:var(--surface-hover);border-color:#ffffff4d}.store-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.05);border-radius:.5rem;padding:0 1rem;height:2.5rem;min-width:130px;color:#fff;font-size:.875rem;font-weight:600;transition:background-color .15s ease}.store-btn:hover{background:#fff3}.prose{max-width:var(--measure);margin-inline:auto;font-size:1.0938rem;color:#ddd5ef}.prose>*+*{margin-top:1.2em}.prose h2{font-size:1.65rem;margin-top:2.2em;padding-top:.6em}.prose h2:before{content:"";display:block;width:2.4rem;height:3px;border-radius:3px;background:var(--grad-accent);margin-bottom:.9rem}.prose h3{font-size:1.25rem;margin-top:1.8em}.prose a{color:var(--violet);text-decoration:underline;text-decoration-color:#a78bfa66;text-underline-offset:3px;transition:text-decoration-color .15s ease,color .15s ease}.prose a:hover{color:var(--pink);text-decoration-color:currentColor}.prose strong{color:var(--text)}.prose ul,.prose ol{padding-left:1.4em}.prose li+li{margin-top:.45em}.prose li::marker{color:var(--pink)}.prose blockquote{margin:1.6em 0;padding:.2em 0 .2em 1.3em;border-left:3px solid var(--pink);color:var(--text-muted);font-style:italic}.prose code{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.15em .4em;font-size:.9em}.prose hr{border:none;height:1px;background:var(--border);margin:2.5em 0}:focus-visible{outline:2px solid var(--violet);outline-offset:3px;border-radius:4px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.site-header[data-astro-cid-3ef6ksr2]{position:sticky;top:0;z-index:50;background:#0c0714bf;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.header-inner[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:1.5rem;padding-block:.85rem}.wordmark[data-astro-cid-3ef6ksr2]{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:-.03em;white-space:nowrap}.wordmark-logo[data-astro-cid-3ef6ksr2]{display:block;border-radius:8px}.wordmark-suffix[data-astro-cid-3ef6ksr2]{color:var(--text-faint);font-weight:500;margin-left:.15em}.header-nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:1.35rem;margin-left:auto;font-family:var(--font-display);font-size:.92rem;font-weight:500}.header-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{color:var(--text-muted);transition:color .15s ease}.header-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover{color:var(--text)}.nav-app[data-astro-cid-3ef6ksr2]{color:var(--text-faint)!important}.nav-app[data-astro-cid-3ef6ksr2]:hover{color:var(--violet)!important}.header-cta[data-astro-cid-3ef6ksr2]{font-size:.85rem;padding:.55em 1.3em}@media(max-width:860px){.header-nav[data-astro-cid-3ef6ksr2]{display:none}.header-cta[data-astro-cid-3ef6ksr2]{margin-left:auto}}.site-footer[data-astro-cid-sz7xmlte]{margin-top:6rem;border-top:1px solid var(--border);background:linear-gradient(to bottom,transparent,rgba(109,66,210,.08));padding:3.5rem 0 2rem}.footer-grid[data-astro-cid-sz7xmlte]{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}.wordmark[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:800;font-size:1.4rem;letter-spacing:-.03em}.wordmark-logo[data-astro-cid-sz7xmlte]{display:block;border-radius:9px}.footer-brand[data-astro-cid-sz7xmlte] p[data-astro-cid-sz7xmlte]{color:var(--text-muted);font-size:.95rem;max-width:30ch;margin:.9rem 0 0}nav[data-astro-cid-sz7xmlte] h4[data-astro-cid-sz7xmlte]{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);margin-bottom:1rem}nav[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{display:block;color:var(--text-muted);font-size:.95rem;padding-block:.28rem;transition:color .15s ease}nav[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--text)}.footer-bottom[data-astro-cid-sz7xmlte]{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.05)}.footer-credits[data-astro-cid-sz7xmlte]{display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center}.footer-credits[data-astro-cid-sz7xmlte] p[data-astro-cid-sz7xmlte]{color:#ffffff4d;font-size:.625rem;line-height:1.4;margin:0}.dev-credit[data-astro-cid-sz7xmlte]{color:#fff6;font-size:.625rem;transition:color .15s ease}.footer-socials[data-astro-cid-sz7xmlte]{display:flex;align-items:center;gap:1.4rem;color:#fff9}.footer-socials[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;color:inherit;transition:color .15s ease,transform .15s ease}.footer-socials[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:#fff;transform:translateY(-2px)}.dev-credit[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;gap:.85rem;color:#fff6;font-size:.625rem;transition:color .15s ease}.dev-credit[data-astro-cid-sz7xmlte]:hover{color:var(--pink)}.dev-credit-logo[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;justify-content:center;width:1.2rem;height:1.2rem;border-radius:.35rem;background:#ffffff14}.dev-logo-svg[data-astro-cid-sz7xmlte]{width:.85rem;height:.85rem;fill:#ffffff4d;transition:fill .15s ease}.dev-credit[data-astro-cid-sz7xmlte]:hover .dev-logo-svg[data-astro-cid-sz7xmlte],.dev-credit[data-astro-cid-sz7xmlte]:focus-visible .dev-logo-svg[data-astro-cid-sz7xmlte]{fill:var(--pink)}.dev-credit-text[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;gap:.25rem}.dev-credit-text[data-astro-cid-sz7xmlte] strong[data-astro-cid-sz7xmlte]{color:#ffffffb3}.kwai[data-astro-cid-sz7xmlte]{font-weight:900;font-size:.8rem;letter-spacing:-.05em}@media(max-width:860px){.footer-bottom[data-astro-cid-sz7xmlte]{flex-direction:column;justify-content:center}}@media(max-width:760px){.footer-grid[data-astro-cid-sz7xmlte]{grid-template-columns:1fr 1fr}.footer-brand[data-astro-cid-sz7xmlte]{grid-column:1 / -1}}
