: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;padding:0;min-width:320px;min-height:100vh;overflow-x:hidden}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}}.navigation{background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);position:sticky;height:4rem;top:0;z-index:1000}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none;transition:color .3s}.nav-logo:hover{color:#646cff}.nav-menu{display:flex;gap:2rem;list-style:none;margin:0;padding:0}.nav-menu a{color:#fffc;text-decoration:none;transition:color .3s;font-size:1rem}.nav-menu a:hover{color:#646cff}#root{width:100%;min-height:100vh;margin:0;padding:0}.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}.pattern-selector{background:#000c;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;height:15rem}.pattern-selector h3{margin:0 0 1rem;font-size:1.2rem;color:#646cff}.pattern-grid{display:flex;flex-direction:column;gap:.5rem;height:80%;overflow-y:scroll}.pattern-grid::-webkit-scrollbar{width:6px}.pattern-grid::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.pattern-grid::-webkit-scrollbar-thumb{background:#646cff80;border-radius:3px}.pattern-grid::-webkit-scrollbar-thumb:hover{background:#646cffb3}.pattern-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.75rem 1rem;color:#fff;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;flex-direction:column;gap:.25rem}.pattern-button:hover{background:#646cff33;border-color:#646cff;transform:translate(-3px)}.pattern-button:active{transform:translate(-3px) scale(.98)}.pattern-name{font-weight:600;font-size:1rem;color:#fff}.pattern-description{font-size:.85rem;color:#fff9;line-height:1.3}.play-pause-button{bottom:2rem;right:2rem;width:64px;height:64px;background:#646cffe6;border:2px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:100;box-shadow:0 4px 20px #646cff4d}.play-pause-button:hover{background:#646cff;transform:scale(1.1);box-shadow:0 6px 30px #646cff80}.play-pause-button:active{transform:scale(1.05)}.play-pause-button svg{width:32px;height:32px;color:#fff}.transform-controls{width:fit-content;height:fit-content;display:flex;gap:.5rem;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.75rem;z-index:100}.transform-button{padding:0;width:48px;height:48px;background:#646cff33;border:1px solid rgba(100,108,255,.4);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:#fff}.transform-button:hover{background:#646cff66;border-color:#646cff;transform:scale(1.1)}.transform-button:active{transform:scale(1.05)}.transform-button svg{width:36px;height:36px}.clear-button{aspect-ratio:1 / 1;background:#f44c;border:.1em solid rgba(255,255,255,.2);border-radius:.5em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 20px #ff44444d}.clear-button:hover{background:#f44;transform:scale(1.1);box-shadow:0 6px 30px #ff444480}.clear-button:active{transform:scale(1.05)}.clear-button svg{width:28px;height:28px;color:#fff}.pattern-preview{bottom:20px;left:20px;background:#141414f2;border:1px solid #333;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100}.pattern-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pattern-name{font-size:14px;font-weight:600;color:#0f8}.pattern-preview-svg{display:block}.project-page{width:100%;height:calc(100vh - 4.1rem);display:flex;flex-direction:column}.project-page.game-of-life-page .canvas-container{flex:1;display:flex;align-items:center;justify-content:center}.project-page.game-of-life-page .canvas-container .controls{color:#0ff;width:30%;display:flex;flex-direction:column}.project-page.game-of-life-page .canvas-container .controls .buttons{bottom:1.5rem;right:1.5rem;display:flex;flex-direction:row;gap:.5rem}.project-page.rubiks-cube-page .controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;z-index:10}.project-page.rubiks-cube-page .controls .move-category{display:flex;gap:.3rem;flex-direction:column}.project-page.rubiks-cube-page .controls .move-category button{width:2.5rem;height:2rem;display:flex;align-items:center;justify-content:center;font-size:1rem;border:none;border-radius:.3rem;background-color:#646cffcc;color:#fff;cursor:pointer;transition:background-color .3s}.project-page.rubiks-cube-page .controls .move-category button:hover{background-color:#646cff}.project-page.rubiks-cube-page .canvas-container{width:100%;display:flex;align-items:center;justify-content:center}.project-page.rubiks-cube-page .canvas-container canvas{border-radius:50%;aspect-ratio:1 / 1}.project-header{text-align:center;padding-bottom:1rem;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-header h1{font-size:2.5rem;margin-bottom:.5rem}.project-header p{color:#ffffffb3;font-size:1.1rem}.canvas-container{flex:1;width:100%;position:relative}.canvas-container canvas{display:block}.placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;background:#646cff1a;border:2px dashed rgba(100,108,255,.3)}.placeholder h2{font-size:2rem;margin-bottom:1rem;color:#fff9}.placeholder p{color:#fff6;font-size:1.2rem}.home{max-width:1200px;margin:0 auto;padding:4rem 2rem;text-align:center}.home h1{font-size:3rem;margin-bottom:1rem}.subtitle{font-size:1.25rem;color:#ffffffb3;margin-bottom:4rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:3rem}.project-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;text-decoration:none;color:#fff;transition:all .3s ease;cursor:pointer}.project-card:hover{background:#ffffff1a;border-color:#646cff;transform:translateY(-5px)}.project-card h2{font-size:1.5rem;margin-bottom:.5rem;color:#646cff}.project-card p{color:#ffffffb3;font-size:1rem}.page-transition{transition:opacity .1s ease-in-out}.page-transition.fade-in{opacity:1}.page-transition.fade-out{opacity:0}
