:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}#footer div{display:flex}#footer a{padding:0 20px}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.tab-bar{border-bottom:2px solid var(--border);background:var(--bg);z-index:10;display:flex;position:sticky;top:0}.tab-btn{color:var(--text);cursor:pointer;font-size:18px;font-weight:600;font-family:var(--heading);background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:12px 24px;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text-h);border-bottom-color:var(--border)}.tab-btn--active{color:var(--accent);border-bottom-color:var(--accent)}.animal-game{flex-direction:column;align-items:center;min-height:400px;padding:20px;display:flex;position:relative}.animal-image{object-fit:contain;border-radius:12px;width:100%;max-width:350px;margin-bottom:20px;box-shadow:0 4px 20px #00000026}.animal-loading{background:var(--accent-bg);width:350px;height:260px;color:var(--accent);border-radius:12px;justify-content:center;align-items:center;margin-bottom:20px;font-size:48px;display:flex}.animal-image-error{background:var(--accent-bg);border-radius:12px;justify-content:center;align-items:center;width:350px;height:260px;margin-bottom:20px;font-size:80px;display:flex}.animal-prompt{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:20px;display:flex}.animal-letter{border-bottom:3px solid #0000;justify-content:center;align-items:center;width:36px;height:44px;font-size:28px;font-weight:700;transition:all .15s;display:inline-flex}.animal-letter--completed{color:var(--accent)}.animal-letter--current{color:var(--accent);background:var(--accent-bg);border-bottom-color:var(--accent);border-radius:4px 4px 0 0}.animal-letter--future{color:var(--text)}.animal-letter--wrong{color:red;border-bottom-color:red}.animal-score{color:var(--accent);margin-bottom:16px;font-size:18px;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.animal-spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}#footer{text-align:center;border-top:1px solid var(--border);justify-content:center;align-items:center;gap:16px;padding:32px 0;display:flex;position:absolute;bottom:0;left:0;right:0}.sg-pv{flex-direction:column;align-items:center;gap:4px;margin-top:10px;display:flex}.sg-pv-labels{justify-content:center;gap:12px;display:flex}.sg-pv-label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;text-align:center;width:100px;font-size:10px;font-weight:600}.sg-pv-label:first-child,.sg-pv-label:last-child{width:30px}.sg-pv-digits{justify-content:center;gap:12px;margin-bottom:2px;display:flex}.sg-pv-digit{color:var(--accent);text-align:center;width:100px;font-size:28px;font-weight:700;transition:transform .2s}.sg-pv-digit:first-child,.sg-pv-digit:last-child{width:30px}.sg-pv-cols{justify-content:center;align-items:flex-start;gap:12px;display:flex}.sg-pv-col-label{text-align:center;color:var(--text);opacity:.6;margin-bottom:3px;font-size:9px}.sg-pv-hundreds{flex-direction:column;align-items:center;width:240px;display:flex}.sg-pv-hundreds-row,.sg-pv-ones-row{gap:3px;display:flex}.sg-pv-hblock{border-radius:2px;justify-content:center;align-items:center;width:20px;height:18px;font-size:6px;font-weight:700;transition:background .2s,border-color .2s,transform .2s;display:flex}.sg-pv-hblock--empty{background:var(--bg);border:1.5px solid var(--border);color:#0000}.sg-pv-hblock--filled{background:var(--accent-bg);border:2px solid var(--accent);color:var(--accent)}.sg-pv-hblock--new{box-shadow:0 0 6px var(--accent-border);animation:.35s cubic-bezier(.34,1.56,.64,1) both pv-pop}.sg-pv-ones{flex-direction:column;align-items:center;width:122px;display:flex}.sg-pv-dot{border-radius:3px;width:7px;height:7px;margin:1.5px 0;transition:background .2s,border-color .2s,transform .2s}.sg-pv-dot--empty{background:var(--bg);border:1.5px solid var(--border)}.sg-pv-dot--filled{background:var(--accent-bg);border:2.5px solid var(--accent)}.sg-pv-dot--new{box-shadow:0 0 6px var(--accent-border);animation:.35s cubic-bezier(.34,1.56,.64,1) both pv-pop}.sg-pv-tens-wrap{flex-direction:column;align-items:center;width:100px;display:flex}.sg-pv-tens{grid-template-columns:repeat(10,1fr);gap:4px 0;width:fit-content;transition:box-shadow .3s;display:grid}.sg-pv-tens--just-carried{animation:.6s ease-out pv-grid-pulse}.sg-pv-tdot{border-radius:1px;width:7px;height:7px;transition:background .15s,border-color .15s}.sg-pv-tdot--empty{background:var(--bg);border:1px solid var(--border)}.sg-pv-tdot--filled{background:var(--accent-bg);border:1.5px solid var(--accent)}.sg-pv-tdot--new-row{animation:.5s cubic-bezier(.34,1.56,.64,1) both pv-row-pop}.sg-pv-ones--just-carried .sg-pv-dot--filled{animation:.4s ease-out pv-carry-flash}@keyframes pv-pop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes pv-row-pop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes pv-grid-pulse{0%{filter:brightness()}50%{filter:brightness(1.4)}to{filter:brightness()}}@keyframes pv-carry-flash{0%{background:var(--accent);border-color:var(--accent)}50%{background:var(--accent-bg);transform:scale(1.1)}to{background:var(--accent-bg);border-color:var(--accent)}}.game-container:focus{outline:1px solid var(--accent);outline-offset:-3px;border-radius:4px}.game-container:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){.sg-pv-dot--new,.sg-pv-tdot--new-row,.sg-pv-tens--just-carried,.sg-pv-ones--just-carried .sg-pv-dot--filled{animation:none}.sg-pv-dot,.sg-pv-tdot{transition:none}}#config{flex-direction:column;align-items:center;margin:12px 0;display:flex}.config-toggle{border:2px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:8px;padding:6px 16px;font-size:14px;font-weight:600;transition:border-color .2s,background .2s}.config-toggle:hover{border-color:var(--accent-border);background:var(--accent-bg)}.config-panel{border:1px solid var(--border);background:var(--accent-bg);border-radius:8px;gap:16px;margin-top:8px;padding:12px 20px;display:flex}.config-label{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:14px;display:flex}.config-label input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:16px;height:16px}
