#mesh-bg[data-v-a433399e]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}canvas#mesh-canvas[data-v-a433399e]{pointer-events:auto}.portfolio-foreground[data-v-a433399e]{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:2rem;font-family:Inter,Arial,sans-serif;color:#f3f3f3;background:#23272fcc;border-radius:18px;box-shadow:0 4px 32px #0000002e}.portfolio-header[data-v-a433399e]{text-align:center;margin-bottom:2rem}.portfolio-title[data-v-a433399e]{font-size:2.5rem;margin:.5rem 0 .2rem}.portfolio-tagline[data-v-a433399e]{font-size:1.2rem;color:#aaa;margin-bottom:1rem}.portfolio-nav[data-v-a433399e]{margin-bottom:2rem}.portfolio-nav a[data-v-a433399e]{margin:0 1rem;text-decoration:none;color:#42b883;font-weight:500;transition:color .2s}.portfolio-nav a[data-v-a433399e]:hover{color:#646cff}.portfolio-section[data-v-a433399e]{margin-bottom:2.5rem}.portfolio-section h2[data-v-a433399e]{color:#42b883;margin-bottom:.5rem}.portfolio-grid[data-v-a433399e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:2rem 1.5rem;margin:2rem 0 0;justify-items:center;align-items:end}.portfolio-grid-item[data-v-a433399e]{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;background:#646cff1a;border-radius:12px;padding:1rem .5rem .5rem;min-width:120px;min-height:120px;width:120px;height:120px;box-shadow:0 2px 8px #0000000a;transition:box-shadow .2s,transform .2s}.portfolio-grid-item[data-v-a433399e]:hover{box-shadow:0 6px 24px #646cff2e;transform:translateY(-4px) scale(1.04)}.portfolio-grid-item img[data-v-a433399e]{width:56px;height:56px;margin-bottom:.7rem;object-fit:contain}.portfolio-grid-item span[data-v-a433399e]{font-size:1.08rem;color:#fff;margin-top:.2rem;font-weight:500;letter-spacing:.5px;text-align:center}.animations-list[data-v-a433399e]{list-style:disc inside;padding-left:1rem}@media (max-width: 600px){.portfolio-foreground[data-v-a433399e]{padding:1rem}.portfolio-title[data-v-a433399e]{font-size:2rem}}.portfolio-section[data-v-7f5c4670]{margin-bottom:2.5rem}.portfolio-section h2[data-v-7f5c4670]{color:#42b883;margin-bottom:.5rem}.portfolio-grid[data-v-7f5c4670]{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:2rem 1.5rem;margin:2rem 0 0;justify-items:center;align-items:end}.portfolio-grid-item[data-v-7f5c4670]{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;background:#646cff1a;border-radius:12px;padding:1rem .5rem .5rem;min-width:120px;min-height:120px;width:120px;height:120px;box-shadow:0 2px 8px #0000000a;transition:box-shadow .2s,transform .2s}.portfolio-grid-item[data-v-7f5c4670]:hover{box-shadow:0 6px 24px #646cff2e;transform:translateY(-4px) scale(1.04)}.portfolio-grid-item img[data-v-7f5c4670]{width:56px;height:56px;margin-bottom:.7rem;object-fit:contain}.portfolio-grid-item span[data-v-7f5c4670]{font-size:1.08rem;color:#fff;margin-top:.2rem;font-weight:500;letter-spacing:.5px;text-align:center}.animations-list[data-v-7f5c4670]{list-style:disc inside;padding-left:1rem}.new-page[data-v-03dcc1dc]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#333}.new-page h1[data-v-03dcc1dc]{color:#42b883;margin-bottom:.5rem}.graph-canvas[data-v-03dcc1dc]{border:2px solid #42b883;margin:1.5rem 0;background:#181c23;display:block;width:900px;height:700px}.controls[data-v-03dcc1dc]{margin-bottom:1rem;color:#fff}.controls label[data-v-03dcc1dc]{margin-right:.5rem}.controls select[data-v-03dcc1dc]{padding:.25rem;border:1px solid #42b883;border-radius:4px;background:#2c2f33;color:#fff}.description[data-v-03dcc1dc]{color:#fff;text-align:center;max-width:600px}.description p[data-v-03dcc1dc]{margin:.5rem 0}.description ol[data-v-03dcc1dc]{text-align:left;margin:.5rem 0;padding-left:1.5rem}.portfolio-section[data-v-a08cdd96]{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;max-width:900px;margin:0 auto}.canvas-container[data-v-a08cdd96]{display:flex;justify-content:center;align-items:center;margin-top:2rem}.canvas-controls[data-v-a08cdd96]{display:flex;justify-content:flex-end;margin-bottom:.5rem;width:100%}.graph-canvas[data-v-a08cdd96]{background:#181c24!important;border-radius:12px;box-shadow:0 2px 12px #0000001f;outline:none;touch-action:none;border:none;width:800px;height:600px}.description[data-v-a08cdd96]{color:#bfc9d1;font-size:1.1rem;margin-bottom:.5rem;margin-top:.5rem;text-align:left;max-width:700px}.instructions[data-v-a08cdd96]{color:#bfc9d1;font-size:1rem;margin-bottom:1.2rem;margin-top:0;padding-left:1.2rem;list-style:disc inside}.canvas-container[data-v-76f381fc]{display:flex;justify-content:center;align-items:center;margin-top:2rem}canvas[data-v-76f381fc]{background:#181c24!important;border-radius:12px;box-shadow:0 2px 12px #0000001f;outline:none;touch-action:none}.description[data-v-76f381fc]{color:#bfc9d1;font-size:1.1rem;margin-bottom:.5rem;margin-top:.5rem}.instructions[data-v-76f381fc]{color:#bfc9d1;font-size:1rem;margin-bottom:1.2rem;margin-top:0;padding-left:1.2rem;list-style:disc inside}.animationsLink[data-v-76f381fc]{color:#4fd1c5;text-decoration:none;font-weight:500}.animationsLink[data-v-76f381fc]:hover{text-decoration:underline}.algorithm-description[data-v-76f381fc]{color:#bfc9d1;font-size:1rem;margin-top:2rem;padding:0 1rem}.algorithm-description h3[data-v-76f381fc]{color:#4fd1c5;font-size:1.5rem;margin-bottom:.5rem}.boids-formulas[data-v-76f381fc]{background:#222;color:#bfc9d1;padding:1rem;border-radius:8px;overflow-x:auto}.portfolio-section[data-v-97f7c495]{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;max-width:900px;margin:0 auto}.canvas-container[data-v-97f7c495]{display:flex;justify-content:center;align-items:center;margin-top:2rem}.canvas-controls[data-v-97f7c495]{display:flex;justify-content:flex-end;margin-bottom:.5rem;width:100%}.canvas-controls label[data-v-97f7c495]{color:#bfc9d1;font-size:1rem;margin-right:1rem}.canvas-controls input[data-v-97f7c495]{margin-left:.5rem;margin-right:.5rem}.graph-canvas[data-v-97f7c495]{background:#181c24!important;border-radius:12px;box-shadow:0 2px 12px #0000001f;outline:none;touch-action:none;border:none;width:800px;height:600px}.description[data-v-97f7c495]{color:#bfc9d1;font-size:1.1rem;margin-bottom:.5rem;margin-top:.5rem;text-align:left;max-width:700px}.instructions[data-v-97f7c495]{color:#bfc9d1;font-size:1rem;margin-bottom:1.2rem;margin-top:0;padding-left:1.2rem;list-style:disc inside}.animationsLink[data-v-97f7c495]{color:#4fd1c5;text-decoration:none;font-weight:500}.animationsLink[data-v-97f7c495]:hover{text-decoration:underline}body{background:#23272f;margin:0;min-width:320px;min-height:100vh}#app{width:100vw;height:100vh;margin:0;padding:0;text-align:initial}.link{color:#23e112b6;text-decoration:none;cursor:pointer;transition:color .2s}.link:hover,.link:focus{color:#5cff4a;text-decoration:underline;outline:none}.animationsLink{color:#1e90ff;text-decoration:underline;cursor:pointer;transition:color .2s}.animationsLink:hover,.animationsLink:focus{color:#63b3ed;outline:none}
