:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f5f7fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{color:inherit;text-decoration:none}ul{margin:0;padding:0;list-style:none}.lp-app{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top left,#e0f2fe,#f5f7fb 40%,#fff 80%);color:#0f172a}.lp-header{position:sticky;top:0;z-index:10;background:linear-gradient(90deg,#0033a0,#0055d4);color:#fff;box-shadow:0 1px 3px #0f172a40}.lp-header-inner{max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem}.lp-brand{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;letter-spacing:.03em}.lp-brand-mark{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:#ff6b00;color:#0f172a;font-weight:700}.lp-brand-text{font-size:.95rem}.lp-nav a{font-size:.9rem;opacity:.9}.lp-nav a:hover{opacity:1;text-decoration:underline}.lp-main{flex:1;max-width:1120px;margin:0 auto;padding:1.5rem}.lp-footer{padding:.75rem 1.5rem;text-align:center;font-size:.8rem;color:#64748b;border-top:1px solid rgba(148,163,184,.3);background-color:#f8fafc}.lp-hero{margin-bottom:1.5rem}.lp-hero h1{font-size:2.1rem;margin:0 0 .5rem}.lp-hero p{margin:0;max-width:44rem;color:#475569}.lp-hero-actions{margin-top:1rem;display:flex;gap:.75rem;flex-wrap:wrap}.lp-search{min-width:260px;max-width:380px;padding:.55rem .75rem;border-radius:999px;border:1px solid rgba(148,163,184,.7);font-size:.9rem;outline:none}.lp-search:focus{border-color:#0055d4;box-shadow:0 0 0 1px #0055d4}.lp-topics{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.lp-topic-pill{padding:.18rem .6rem;border-radius:999px;font-size:.75rem;background:#94a3b81f;color:#1f2933}.lp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:2rem}.lp-card{background:#fff;border-radius:.75rem;padding:1rem;box-shadow:0 1px 3px #0f172a14;display:flex;flex-direction:column;gap:.5rem;border:1px solid rgba(148,163,184,.25)}.lp-card-topic{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.lp-card-title{font-size:1.05rem;margin:0}.lp-card-title a:hover{color:#0055d4}.lp-card-excerpt{margin:0;font-size:.9rem;color:#4b5563}.lp-card-footer{margin-top:.5rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.lp-link{font-size:.85rem;color:#0055d4;font-weight:500}.lp-link-secondary{font-size:.8rem;color:#64748b}.lp-link-secondary:hover{color:#0f172a}.lp-empty{grid-column:1 / -1;padding:1rem;text-align:center;color:#64748b;font-size:.9rem}.lp-article{max-width:760px;margin:0 auto 2rem}.lp-article-loading{text-align:center;padding:2rem 0;color:#64748b}.lp-back{border:none;background:none;padding:0;margin-bottom:1rem;font-size:.85rem;color:#0055d4;cursor:pointer}.lp-back:hover{text-decoration:underline}.lp-article-meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.lp-article-body h1{margin-top:0;margin-bottom:.75rem;font-size:1.7rem}.lp-article-body h2{margin-top:1.5rem;margin-bottom:.5rem;font-size:1.2rem}.lp-article-body p{margin-top:.5rem;margin-bottom:.5rem;color:#374151}.lp-article-body a{color:#0055d4;text-decoration:underline}.lp-related{margin-top:2rem;padding-top:1rem;border-top:1px solid rgba(148,163,184,.4)}.lp-related h2{margin-top:0;font-size:1rem}.lp-related ul{margin-top:.5rem}.lp-related li+li{margin-top:.25rem}.lp-related a{color:#0055d4}.lp-related a:hover{text-decoration:underline}@media(max-width:640px){.lp-header-inner,.lp-main{padding-inline:1rem}.lp-card-footer{flex-direction:column;align-items:flex-start}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.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}
