@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0.qu-9752pffj.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.09zddjkbdep5a.woff2?dpl=dpl_3B89JeocZ6YFgTNs6eRVaNQ7hz7D)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
:root{--bg:#eaf8ff;--surface:#fff;--surface-strong:#fff5cc;--ink:#213047;--muted:#63728a;--line:#cde0ee;--green:#3fbd62;--green-dark:#168041;--blue:#3274d9;--sky:#69cfff;--pink:#ff6e96;--gold:#ffc83d;--orange:#ff9d32;--shadow:0 18px 0 #20375314, 0 24px 50px #20375324;--radius:8px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;min-height:100%}body{min-height:100%;color:var(--ink);background:radial-gradient(circle at 12% 8%, #ffc83d47, transparent 26%), radial-gradient(circle at 92% 4%, #69cfff75, transparent 24%), linear-gradient(180deg, #dff6ff 0, #f7fff0 520px, #fffaf0 100%), var(--bg);font-family:var(--font-geist-sans), Arial, Helvetica, sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}.site-header{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe6;border-bottom:3px solid #3274d929;justify-content:space-between;align-items:center;gap:16px;padding:14px clamp(16px,4vw,44px);display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;min-width:0;display:inline-flex}.brand-mark{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg, var(--green-dark), var(--green), var(--gold));border:2px solid #fff;place-items:center;width:40px;height:40px;font-weight:800;display:grid;box-shadow:0 4px #16804138}.brand strong,.brand small{white-space:nowrap;display:block}.brand small{color:var(--muted);font-size:12px}.top-nav{align-items:center;gap:6px;display:flex;overflow-x:auto}.top-nav a{border-radius:var(--radius);color:#324038;white-space:nowrap;min-height:36px;padding:9px 11px;font-size:14px;font-weight:700}.top-nav a:hover,.top-nav .play-link{color:#fff;background:var(--blue);box-shadow:0 3px #1e4f9b}.hero,.page-hero,.content-shell,.site-footer{width:min(1120px,100% - 32px);margin-inline:auto}.hero{grid-template-columns:minmax(0,1fr) minmax(320px,.85fr);align-items:stretch;gap:28px;padding:46px 0 18px;display:grid}.hero-copy{background:linear-gradient(135deg, #fffffffa, #fff5cceb), var(--surface);box-shadow:var(--shadow);border:3px solid #21304714;border-radius:24px;padding:clamp(28px,5vw,48px)}.hero h1,.page-hero h1{letter-spacing:0;text-wrap:balance;max-width:760px;margin-top:10px;font-size:clamp(42px,7vw,76px);line-height:.98}.hero p,.page-hero p,.article-card p,.mini-card p,.code-card p,.table-card p{color:var(--muted);line-height:1.65}.hero-copy>p:not(.eyebrow),.page-hero p{max-width:680px;margin-top:18px;font-size:18px}.eyebrow{color:#8a5200;letter-spacing:.08em;text-transform:uppercase;background:#fff5cc;border:2px solid #ffc83d8c;border-radius:999px;width:fit-content;padding:7px 10px;font-size:12px;font-weight:800;display:inline-flex}.hero-actions,.cta-strip{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.button,.code-actions button{cursor:pointer;border:0;border-radius:14px;justify-content:center;align-items:center;min-height:44px;padding:12px 16px;font-weight:800;transition:transform .16s,box-shadow .16s;display:inline-flex}.button:hover,.code-actions button:hover{transform:translateY(-1px)}.button.primary,.code-actions button{color:#fff;background:linear-gradient(180deg, #39c766, var(--green-dark));box-shadow:0 5px #0f5e2f}.button.secondary{color:#854d00;background:linear-gradient(180deg, #ffe178, var(--gold));box-shadow:0 5px #d58a12}.hero-panel,.mini-card,.article-card,.table-card,.info-band{background:var(--surface);border:3px solid #21304714;border-radius:18px;box-shadow:0 12px 32px #22362614}.hero-art-card{min-height:520px;box-shadow:var(--shadow);background:#dff6ff;border:4px solid #fff;border-radius:28px;position:relative;overflow:hidden}.hero-art-card img{object-fit:cover;width:100%;height:100%;min-height:520px}.hero-panel{background:linear-gradient(180deg, #fffffff5, #fff5ccf0), var(--surface);border:3px solid #fff;border-radius:18px;flex-direction:column;justify-content:end;width:min(82%,320px);min-height:0;padding:18px;display:flex;position:absolute;bottom:18px;right:18px;box-shadow:0 12px 34px #21304733}.hero-panel span{color:var(--muted);font-weight:700}.hero-panel strong{margin:8px 0 12px;font-size:34px}.content-shell{padding:28px 0 54px}.highlight-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;padding-bottom:10px;display:grid}.highlight-card,.comment-card{background:linear-gradient(#fff,#f1fbff);border:3px solid #fff;border-radius:20px;box-shadow:0 10px #3274d914,0 18px 38px #2130471c}.highlight-card{padding:18px}.highlight-card span{color:#fff;background:linear-gradient(135deg, var(--pink), var(--orange));border-radius:12px;place-items:center;width:38px;height:38px;margin-bottom:10px;display:grid;box-shadow:0 4px #ff6e9647}.highlight-card h2{font-size:22px}.highlight-card p{color:var(--muted);margin-top:8px;line-height:1.55}.two-col{grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:24px;display:grid}.main-column,.side-column,.code-list{gap:18px;display:grid}.side-column{position:sticky;top:88px}.section-heading{gap:8px;display:grid}h2{letter-spacing:0;font-size:clamp(26px,4vw,38px)}h3{letter-spacing:0;font-size:20px}.code-card{border:3px solid #fff;border-left:8px solid var(--green);background:linear-gradient(90deg, #3fbd621f, #fffffff5 35%), var(--surface);border-radius:18px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;padding:18px;display:grid;box-shadow:0 8px #3fbd621f,0 16px 28px #21304714}.code-card h3{font-family:var(--font-geist-mono), Consolas, monospace;margin:4px 0;font-size:28px}.code-actions{justify-items:end;gap:8px;display:grid}.code-actions small,.code-note{color:var(--muted);font-size:12px}.code-note{border-top:1px solid var(--line);grid-column:1/-1;padding-top:10px}.ad-slot{color:#72859a;text-transform:uppercase;background:#ffffffb8;border:2px dashed #b6c7d9;border-radius:16px;place-items:center;width:100%;min-height:96px;font-size:12px;font-weight:700;display:grid}.ad-slot-rectangle{min-height:250px}.ad-slot-sidebar{min-height:300px}.tip-grid,.guide-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.tip-grid p,.guide-grid section{background:#fbfcf8;border:2px solid #fff;border-radius:16px;padding:16px;box-shadow:0 8px 22px #2130470f}.info-band,.table-card,.article-card,.mini-card{padding:22px}.mini-card{gap:12px;display:grid}.mini-card a{color:var(--blue);font-weight:800}.comments-section{gap:16px;display:grid}.comment-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.comment-card{grid-template-columns:auto 1fr;gap:12px;padding:16px;display:grid}.avatar{color:#fff;background:linear-gradient(135deg, var(--blue), var(--sky));border-radius:14px;place-items:center;width:44px;height:44px;font-weight:900;display:grid;box-shadow:0 4px #3274d92e}.comment-card span{color:var(--green-dark);font-size:12px;font-weight:800}.comment-card p{color:var(--muted);margin-top:8px;line-height:1.55}.article-list{gap:16px;display:grid}.article-preview{background:linear-gradient(#fff,#f7fcff);border:3px solid #fff;border-radius:20px;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:18px;padding:20px;display:grid;box-shadow:0 10px #3274d912,0 18px 36px #2130471a}.article-preview span,.article-meta,.hero-meta{color:var(--green-dark);font-size:13px;font-weight:800}.article-preview h2{margin-top:8px;font-size:clamp(22px,3vw,31px)}.article-preview h2 a:hover{color:var(--blue)}.article-preview p{color:var(--muted);margin-top:10px;line-height:1.65}.article-meta{white-space:nowrap;justify-items:end;gap:8px;display:grid}.hero-meta{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.article-title-block{grid-template-columns:1fr}.long-article{box-shadow:var(--shadow);background:#fffffff5;border:3px solid #fff;border-radius:22px;gap:24px;padding:clamp(20px,4vw,34px);display:grid}.long-article section{gap:12px;display:grid}.long-article .lead{color:#3b4d64;background:linear-gradient(90deg,#fff5cc,#e9fbff);border-radius:18px;padding:18px;font-size:18px;line-height:1.7}.long-article p,.long-article li{color:var(--muted);line-height:1.75}.long-article h2{margin-top:6px}.long-article ul{gap:8px;padding-left:22px;display:grid}.faq-item{background:#f7fcff;border:2px solid #fff;border-radius:16px;padding:16px}.faq-item p{margin-top:8px}.responsive-table{margin-top:16px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:560px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:14px}th{color:#854d00;background:var(--surface-strong)}.article-page{min-height:70vh}.page-hero{grid-template-columns:minmax(0,1fr) 320px;align-items:center;gap:24px;padding:48px 0 22px;display:grid}.page-hero.compact h1{font-size:clamp(38px,6vw,64px)}.page-hero-image{object-fit:cover;width:100%;height:260px;box-shadow:var(--shadow);border:4px solid #fff;border-radius:24px}.article-card{gap:18px;display:grid}.article-card h2{margin-top:8px}.steps{color:var(--muted);gap:12px;padding-left:22px;line-height:1.6;display:grid}.expired-list{flex-wrap:wrap;gap:10px;display:flex}.expired-list span{color:#6c5540;font-family:var(--font-geist-mono), Consolas, monospace;background:#fff8ea;border:2px solid #fff;border-radius:14px;padding:10px 12px;font-weight:800}.cta-strip{background:linear-gradient(90deg,#fff5cc,#e9fbff);border-radius:18px;justify-content:space-between;align-items:center;padding:18px}.site-footer{border-top:1px solid var(--line);justify-content:space-between;gap:20px;padding:34px 0 44px;display:flex}.site-footer p{max-width:560px;color:var(--muted);margin-top:8px;line-height:1.6}.site-footer nav{color:var(--blue);flex-wrap:wrap;gap:12px;font-weight:800;display:flex}@media (max-width:860px){.site-header{flex-direction:column;align-items:flex-start}.top-nav{width:100%;padding-bottom:2px}.hero,.page-hero,.two-col,.highlight-row,.comment-grid,.article-preview{grid-template-columns:1fr}.hero{padding-top:28px}.side-column{position:static}.tip-grid,.guide-grid,.code-card{grid-template-columns:1fr}.code-actions{justify-items:stretch}.site-footer{flex-direction:column}.page-hero-image{height:220px}.article-meta{justify-items:start}}@media (max-width:520px){.hero,.page-hero,.content-shell,.site-footer{width:min(100% - 24px,1120px)}.brand strong{font-size:15px}.hero-copy,.hero-panel,.article-card,.mini-card,.info-band,.table-card{padding:18px}.hero-art-card,.hero-art-card img{min-height:360px}.hero-panel{width:calc(100% - 24px);bottom:12px;right:12px}.hero h1,.page-hero.compact h1{font-size:38px}.hero-copy>p:not(.eyebrow),.page-hero p{font-size:16px}}
