:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background-image:url(/assets/background-FSS7cwLc.png);background-size:contain;background-size:cover}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.card{background-color:#1a1a1a;border-radius:10px}.blog-list{text-align:left}.posts{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.post-preview{padding:1.5rem;border:1px solid #333;border-radius:8px;transition:border-color .3s}.post-preview:hover{border-color:#646cff}.post-preview h3{margin:0 0 .5rem}.post-preview h3 a{text-decoration:none;color:inherit}.post-preview h3 a:hover{color:#646cff}.post-date{color:#888;font-size:.9rem;display:block;margin-bottom:1rem}.tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.tag{background:#333;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;color:#646cff}.blog-post{text-align:left}.back-link{display:inline-block;margin-bottom:2rem;color:#888;text-decoration:none}.back-link:hover{color:#646cff}.post-header{border-bottom:1px solid #333;padding-bottom:1rem;margin-bottom:2rem}.post-header h1{margin:0 0 .5rem;font-size:2.5rem}.post-meta{display:flex;gap:1rem;align-items:center;margin-bottom:.5rem}.post-author{color:#8b93ff;font-weight:600}.post-author:after{content:"•";margin-left:1rem;color:#888}.markdown-content{line-height:1.7}.markdown-content h1{font-size:2rem;margin:2rem 0 1rem}.markdown-content h2{font-size:1.5rem;margin:1.5rem 0 1rem}.markdown-content h3{font-size:1.25rem;margin:1.25rem 0 .75rem}.markdown-content p{margin:1rem 0}.markdown-content ul,.markdown-content ol{margin:1rem 0;padding-left:2rem}.markdown-content li{margin:.5rem 0}.markdown-content code{background:#1a1a1a;padding:.2rem .4rem;border-radius:3px;font-size:.9em;font-family:Courier New,Courier,monospace}.markdown-content pre{background:#1a1a1a;padding:1rem;border-radius:8px;overflow-x:auto;margin:1rem 0}.markdown-content pre code{background:none;padding:0}.markdown-content blockquote{border-left:4px solid #646cff;padding-left:1rem;margin:1rem 0;color:#888}.markdown-content a{color:#646cff;text-decoration:underline}.markdown-content a:hover{color:#535bf2}.markdown-content img{max-width:100%;height:auto;border-radius:8px;margin:1rem 0}.home{text-align:left}.home h2{margin-top:0}.home p{font-size:1.1rem;line-height:1.7}.home a{color:#646cff;text-decoration:underline}.downloads{text-align:left}.downloads h2{margin-top:0}.downloads-intro{font-size:1.1rem;color:#fffc;margin-bottom:2rem}.download-items{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.download-item{padding:1.5rem;background:#646cff0d;border:1px solid rgba(100,108,255,.2);border-radius:8px;transition:all .3s}.download-item:hover{border-color:#646cff66;box-shadow:0 0 20px #646cff33}.download-item h3{margin-top:0;color:#8b93ff}.download-item p{margin-bottom:1rem}.download-button{display:inline-block;padding:.75rem 1.5rem;background:#646cff33;border:1px solid rgba(100,108,255,.4);border-radius:6px;color:#fff;text-decoration:none;font-weight:600;transition:all .3s}.download-button:hover{background:#646cff4d;box-shadow:0 0 15px #646cff66;transform:translateY(-2px)}.downloads-note{margin-top:2rem;padding:1rem;background:#646cff0d;border-left:3px solid #646cff;border-radius:4px}.downloads-note p{margin:0}.downloads-note a{color:#8b93ff;text-decoration:underline}#root{max-width:1280px;margin:0 auto;text-align:center;min-height:100vh;display:flex;flex-direction:column}.app{flex:1;display:flex;flex-direction:column;padding-top:110px}.nav{position:fixed;top:0;left:0;right:0;padding:1.25rem 2rem;display:flex;justify-content:space-between;align-items:center;max-width:1200px;width:90%;margin:0 auto;background:#0f172acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(100,108,255,.2);border-radius:0 0 12px 12px;z-index:1000}.nav h1{margin:0;font-size:1.8rem;font-weight:700;text-shadow:0 2px 8px rgba(100,108,255,.5);letter-spacing:.5px}.nav h1 a{text-decoration:none;color:#fff;transition:color .3s}.nav h1 a:hover{color:#8b93ff}.nav-links{display:flex;gap:1rem}.nav-links a{text-decoration:none;color:#ffffffe6;font-weight:600;padding:.6rem 1.2rem;border-radius:6px;background:#646cff1a;border:1px solid rgba(100,108,255,.3);transition:all .3s;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.nav-links a:hover{background:#646cff40;border-color:#646cff99;box-shadow:0 0 15px #646cff66;transform:translateY(-1px)}.github-link{display:flex;align-items:center;justify-content:center;padding:.6rem!important}.github-link svg{transition:transform .3s}.github-link:hover svg{transform:scale(1.1)}.main{flex:1;padding:1rem 0;max-width:1200px;width:90%;margin:0 auto 2rem}.main>*{background:linear-gradient(135deg,#0f172af2,#1e293be6);padding:2.5rem;border-radius:16px;border:1px solid rgba(100,108,255,.2);box-shadow:0 8px 32px #0006,0 0 0 1px #646cff1a}.footer{padding:1.25rem 0;border-top:1px solid rgba(100,108,255,.2);background:#0a0f1ef2;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;max-width:1200px;width:90%;margin:0 auto}.footer-copyright{color:#ffffff80;font-size:.85rem}.footer-links{display:flex;gap:1.5rem;align-items:center}.footer-links a{color:#ffffffb3;transition:color .3s;text-decoration:none;font-size:.85rem}.footer-links a:hover{color:#8b93ff}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
