*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--surface: #141414;--surface-2: #1a1a1a;--border: #222;--text: #f5f5f5;--text-muted: #888;--accent: #4da6ff;--accent-hover: #6bb8ff;--radius: 12px;--ease-out: cubic-bezier(.23, 1, .32, 1)}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.landing{min-height:100vh}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:4rem 2rem}.hero__inner{max-width:720px;text-align:center}.hero__title{font-size:clamp(3.5rem,8vw,6rem);font-weight:900;letter-spacing:-.03em;line-height:1;margin-bottom:1.5rem}.hero__subtitle{font-size:1.25rem;color:var(--text);max-width:520px;margin:0 auto 3rem;line-height:1.7;text-wrap:balance}.hero__ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border-radius:999px;text-decoration:none;cursor:pointer;border:none;transition:transform .2s var(--ease-out),background .2s var(--ease-out)}.cta:active{transform:scale(.97)}.cta--primary{background:var(--accent);color:#000}.cta--primary:hover{background:var(--accent-hover)}.cta--secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.cta--secondary:hover{background:var(--border)}.copy-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem;font-family:SF Mono,Fira Code,monospace;cursor:pointer;transition:border-color .15s var(--ease-out),background .15s var(--ease-out),transform .1s var(--ease-out)}.copy-btn:hover{border-color:var(--accent);background:var(--border)}.copy-btn:active{transform:scale(.97)}.copy-btn__icon{width:16px;height:16px;color:var(--text-muted);transition:color .2s var(--ease-out)}.copy-btn__icon--check{color:#1dd1a1}.features{padding:6rem 2rem;max-width:1000px;margin:0 auto}.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:border-color .2s var(--ease-out)}.feature-card:hover{border-color:var(--accent)}.feature-card__icon{font-size:2rem;display:block;margin-bottom:1rem}.feature-card h3{font-size:1.125rem;font-weight:700;margin-bottom:.5rem}.feature-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6}.code-section{padding:4rem 2rem 6rem;max-width:720px;margin:0 auto}.code-section__title{font-size:2rem;font-weight:800;margin-bottom:1.5rem;letter-spacing:-.02em}.code-section__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.code-section__header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface-2);border-bottom:1px solid var(--border)}.code-section__dots{display:flex;gap:6px}.code-section__dot{width:10px;height:10px;border-radius:50%}.code-section__dot--red{background:#ff5f57}.code-section__dot--yellow{background:#febc2e}.code-section__dot--green{background:#28c840}.code-section__title{font-size:.8rem;font-weight:600;color:var(--text-muted)}.code-section__body{padding:1.25rem;overflow-x:auto;font-size:.875rem;line-height:1.7;font-family:SF Mono,Fira Code,monospace}.code-section__body code{color:var(--text)}.demos{padding:4rem 2rem;max-width:1100px;margin:0 auto}.demos__title{font-size:2rem;font-weight:800;margin-bottom:3rem;letter-spacing:-.02em;text-align:center}.demo-section{padding:2rem;max-width:1100px;margin:0 auto 4rem}.demo-section:last-child{margin-bottom:0}.section-title{margin-bottom:1.5rem}.section-title__number{display:inline-block;font-size:.75rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.section-title__heading{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.25rem}.section-title__subtitle{font-size:.9rem;color:var(--text-muted)}.interactive-canvas{position:relative;width:100%;height:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}.interactive-canvas--large{height:550px}.interactive-label{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:.75rem;color:var(--text-muted);pointer-events:none;opacity:.6}.caterpillar-segment{will-change:transform}.caterpillar-eye{position:absolute;width:6px;height:6px;background:#fff;border-radius:50%;top:30%}.caterpillar-eye--left{left:25%}.caterpillar-eye--right{right:25%}.caterpillar-antenna{position:absolute;width:2px;height:16px;background:#888;top:-14px;border-radius:1px}.caterpillar-antenna--left{left:30%;transform:rotate(-15deg)}.caterpillar-antenna--right{right:30%;transform:rotate(15deg)}.caterpillar-foot{position:absolute;width:8px;height:3px;background:#666;border-radius:2px;bottom:-2px}.caterpillar-foot--left{left:10%}.caterpillar-foot--right{right:10%}.sun{box-shadow:0 0 40px #feca574d}.planet{box-shadow:inset -2px -2px 4px #0000004d}.yoyo-body{cursor:pointer;transition:border-color .15s var(--ease-out)}.yoyo-body--grabbed{border-color:var(--accent)!important}.spring-legend{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px}.spring-legend__item{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-muted)}.spring-legend__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.spring-legend__params{font-family:SF Mono,Fira Code,monospace;font-size:.7rem;opacity:.6}.scattered-canvas{position:relative;width:100%;height:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}.magnet-letter{font-size:3rem;font-weight:900;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .15s var(--ease-out)}.click-demo{display:flex;gap:2rem;justify-content:center;align-items:center;padding:3rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem}.click-target{width:120px;height:120px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:2px solid var(--border);border-radius:var(--radius);font-weight:700;font-size:.9rem;letter-spacing:.05em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .2s var(--ease-out)}.click-target:hover{border-color:var(--accent)}.click-target--star{font-size:3rem;width:100px;height:100px;color:#feca57}.hook-demo{display:flex;justify-content:center;padding:3rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem}.hook-badge{padding:.75rem 1.5rem;font-size:.85rem;font-weight:700;letter-spacing:.1em;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:background .2s var(--ease-out),border-color .2s var(--ease-out),color .2s var(--ease-out)}.hook-badge--active{background:var(--accent);border-color:var(--accent);color:#000}.section-code__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.section-code__header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface-2);border-bottom:1px solid var(--border)}.section-code__dots{display:flex;gap:6px}.section-code__dot{width:10px;height:10px;border-radius:50%}.section-code__dot--red{background:#ff5f57}.section-code__dot--yellow{background:#febc2e}.section-code__dot--green{background:#28c840}.section-code__title{font-size:.8rem;font-weight:600;color:var(--text-muted)}.section-code__body{padding:1.25rem;overflow-x:auto;font-size:.8rem;line-height:1.7;font-family:SF Mono,Fira Code,monospace}.section-code__body code{color:var(--text)}.floating-slider{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#141414cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:999px;font-size:.75rem}.floating-slider__label{color:var(--text-muted);font-weight:500}.floating-slider input[type=range]{width:80px;accent-color:var(--accent)}.floating-slider__value{font-family:SF Mono,Fira Code,monospace;color:var(--accent);min-width:2ch;text-align:right}.docs{padding:4rem 2rem;max-width:1100px;margin:0 auto}.docs__title{font-size:2rem;font-weight:800;margin-bottom:3rem;letter-spacing:-.02em;text-align:center}.docs__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}@media(max-width:768px){.docs__grid{grid-template-columns:1fr}}.docs__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}.docs__card--wide{grid-column:1 / -1}.docs__card-title{font-size:1.125rem;font-weight:700;margin-bottom:.5rem;font-family:SF Mono,Fira Code,monospace;color:var(--accent)}.docs__card-desc{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.docs__table{width:100%;border-collapse:collapse;font-size:.85rem}.docs__table thead th{text-align:left;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.docs__table tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--border);vertical-align:top}.docs__table tbody tr:last-child td{border-bottom:none}.docs__table code{font-family:SF Mono,Fira Code,monospace;font-size:.8rem;background:var(--surface-2);padding:.15rem .4rem;border-radius:4px;color:var(--text)}.footer{padding:4rem 2rem 3rem;border-top:1px solid var(--border);margin-top:4rem}.footer__inner{max-width:720px;margin:0 auto;text-align:center}.footer__links{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2rem}.footer__links a{color:var(--text-muted);text-decoration:none;font-weight:500;transition:color .2s var(--ease-out)}.footer__links a:hover{color:var(--text)}.footer__bottom{font-size:.85rem;color:var(--text-muted)}.footer__bottom a{color:var(--text-muted);text-decoration:none;transition:color .2s var(--ease-out)}.footer__bottom a:hover{color:var(--text)}@media(max-width:768px){.hero__title{font-size:3rem}.hero__subtitle{font-size:1rem}.features__grid{grid-template-columns:1fr}.interactive-canvas{height:300px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}
