:root{--bg:#fff;--fg:#1a1a1a;--secondary:#717171;--muted:#a3a3a3;--border:#e5e5e5}@media (prefers-color-scheme:dark){:root{--bg:#0a0a0a;--fg:#e5e5e5;--secondary:#a3a3a3;--muted:#525252;--border:#262626}}*{box-sizing:border-box;margin:0;padding:0}body,html,#root{background-color:var(--bg);width:100%;height:100%;color:var(--fg);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}#root{overflow-y:auto}a{color:inherit;text-decoration:none}ul{list-style:none}.gallery-main{width:100%;max-width:480px;margin:0 auto;padding:60px 24px}.gallery-header{margin-bottom:60px}.gallery-header h1{letter-spacing:-.02em;margin:0;font-size:1.75rem;font-weight:600;line-height:1.2}#gallery-container{flex-direction:column;gap:64px;padding-bottom:80px;display:flex}.discipline-section{width:100%}.discipline-header{margin-bottom:32px}.discipline-header h2{letter-spacing:-.02em;color:var(--fg);margin-bottom:8px;font-size:1.5rem;font-weight:500;line-height:1.2}.discipline-desc{color:var(--secondary);max-width:340px;font-size:.85rem;line-height:1.6}.group-container{margin-top:40px}.group-title{text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin-bottom:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.65rem;font-weight:600}.shape-list{flex-direction:column;gap:0;display:flex}.shape-list li{border-bottom:1px solid var(--border)}.shape-list li:first-child{border-top:1px solid var(--border)}.shape-link-btn{letter-spacing:-.01em;color:var(--fg);text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:16px 0;font-size:1.05rem;font-weight:400;transition:opacity .2s;display:block}.shape-link-btn:hover{opacity:.6}.viewer-container{z-index:0;background-color:var(--bg);width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.canvas-wrapper{width:100%;height:100%;position:absolute;top:0;left:0}canvas{cursor:grab;width:100%;height:100%;display:block}canvas:active{cursor:grabbing}#ui-layer{z-index:10;pointer-events:none;flex-direction:column;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.top-nav{z-index:20;pointer-events:auto;position:absolute;top:1.25rem;left:1.25rem}.gallery-main .top-nav{margin-bottom:2rem;position:relative;top:0;left:0}.back-link-btn{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:.75rem;font-weight:500;transition:color .2s}.back-link-btn:hover{color:var(--fg)}.title-nav-container{z-index:20;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex;position:absolute;top:2.5rem}#shape-title{letter-spacing:-.01em;pointer-events:none;text-align:center;color:var(--fg);margin:0;font-size:1.75rem;font-weight:500;line-height:1.2}.nav-controls{pointer-events:none;gap:2rem;display:flex}.nav-btn{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);pointer-events:auto;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-btn:hover{color:var(--fg)}#info-toggle{border:1px solid var(--fg);background:var(--bg);width:2.75rem;height:2.75rem;color:var(--fg);cursor:pointer;pointer-events:auto;z-index:100;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:1.25rem;right:1.25rem}#info-toggle:hover{background:var(--fg);color:var(--bg)}#info-toggle .icon{font-family:serif;font-size:1.2rem;font-style:italic;font-weight:700}#content-section{pointer-events:auto;z-index:50;color:#f0f0f0;background:#0f0f0fcc;width:100%;max-width:28.125rem;height:100vh;padding:5rem 2.5rem;transition:transform .4s cubic-bezier(.16,1,.3,1);position:fixed;top:0;right:0;overflow-y:auto;box-shadow:-.625rem 0 2.5rem #0000004d}#content-section.hidden{transform:translate(100%)}.info-block{width:100%;margin-bottom:3.75rem}.info-block h3{text-transform:uppercase;letter-spacing:.25em;color:#ffffff80;text-align:left;margin-bottom:1.5625rem;font-size:.65rem;display:block}#shape-desc{text-align:left;width:100%}#shape-desc p{color:#ffffffe6;margin-bottom:1.25rem;font-size:1rem;font-weight:300;line-height:1.8}#formula-list{flex-direction:column;align-items:flex-start;gap:2.5rem;width:100%;display:flex}.formula-item{text-align:left;border-bottom:1px solid #ffffff1a;width:100%;padding-bottom:1.25rem}.formula-label{color:#fff6;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.7rem;font-weight:600;display:block}.formula-render{color:#fff;padding:.625rem 0;font-size:1.25rem;overflow-x:auto}@media (width<=37.5rem){.title-nav-container{gap:1rem;top:3.75rem}#shape-title{font-size:1.5rem}#content-section{max-width:100%;padding:3.75rem 1.5625rem}}.vfx-wrapper{width:100vw;height:100vh;transition:background .6s cubic-bezier(.16,1,.3,1),color .6s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.vfx-wrapper.dark-theme{color:#fff;background:#000}.vfx-wrapper.white-theme{color:#000;background:#fff}.vfx-container{scroll-snap-type:y mandatory;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none;background:0 0;width:100%;height:100%;overflow-y:scroll}.vfx-container::-webkit-scrollbar{display:none}.vfx-slide{scroll-snap-align:start;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.vfx-canvas-container{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.vfx-label{z-index:100;pointer-events:none;transition:color .4s;position:fixed;bottom:60px;left:60px}.vfx-label h2{letter-spacing:.3em;text-transform:uppercase;opacity:.8;margin:0;font-size:1.4rem;font-weight:500}.vfx-label .vfx-line{opacity:.4;width:40px;height:1px;margin-bottom:12px;transition:background .4s}.vfx-exit-btn{z-index:100;color:inherit;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#8080801a;border:1px solid #80808033;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:all .3s;display:flex;position:fixed;top:30px;right:30px}.vfx-exit-btn:hover{background:#8080804d}.vfx-nav{z-index:100;flex-direction:column;gap:20px;display:flex;position:fixed;top:50%;right:40px;transform:translateY(-50%)}.vfx-nav a{border-radius:50%;width:8px;height:8px;transition:all .4s cubic-bezier(.16,1,.3,1)}.vfx-nav a.active{transform:scale(2);box-shadow:0 0 15px #8080804d}.vfx-museum-main{color:#000;background:#fff;flex-direction:column;align-items:center;width:100vw;height:100vh;padding:80px 40px;display:flex;overflow-y:auto}.vfx-top-nav{position:absolute;top:30px;left:40px}.vfx-back-btn{color:#000;cursor:pointer;background:0 0;border:1px solid #00000026;border-radius:20px;padding:8px 16px;transition:all .3s}.vfx-back-btn:hover{color:#fff;background:#000}.vfx-museum-header{text-align:center;margin-bottom:60px}.vfx-museum-header h1{letter-spacing:.1em;margin-bottom:10px;font-size:4rem}.vfx-museum-header p{opacity:.6;font-size:1.2rem}.vfx-museum-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px;width:100%;max-width:1200px;padding-bottom:80px;display:grid}.vfx-card{text-align:left;cursor:pointer;color:#000;background:#00000005;border:1px solid #0000000d;border-radius:12px;padding:40px;transition:all .4s cubic-bezier(.16,1,.3,1)}.vfx-card:hover{background:#0000000d;border-color:#00000026;transform:translateY(-5px)}.vfx-card h3{margin-bottom:10px;font-size:1.5rem}.vfx-card p{opacity:.5;font-size:.9rem}.hidden{display:none}@keyframes vfx-float{0%{transform:translate(0)}33%{transform:translate(30px,-50px)}66%{transform:translate(-20px,20px)}to{transform:translate(0)}}:root{--accent-rgb:16, 185, 129;--accent:rgb(var(--accent-rgb));--accent-hover:rgba(var(--accent-rgb), .04)}@media (prefers-color-scheme:dark){:root{--accent-rgb:52, 211, 153}}.lab-container{flex-direction:column;max-width:640px;min-height:100vh;margin:0 auto;padding:80px 24px;display:flex}.lab-header{margin-bottom:48px}.lab-title-row{justify-content:space-between;align-items:flex-end;margin-bottom:20px;display:flex}.lab-title-group{flex-direction:column;gap:6px;display:flex}.lab-header h1{letter-spacing:-.02em;color:var(--fg);margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1.75rem;font-weight:700;line-height:1}.lab-subtitle{color:var(--secondary);margin:0;font-size:.85rem}.lab-status{letter-spacing:.1em;color:var(--secondary);border:1px solid var(--border);background:rgba(var(--accent-rgb), .02);border-radius:4px;align-items:center;gap:8px;padding:4px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.65rem;display:flex}.status-dot{background-color:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent);border-radius:50%;animation:2s infinite pulse}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.lab-line{background:var(--border);width:100%;height:1px}.lab-main{flex-direction:column;flex-grow:1;justify-content:center;display:flex}.project-grid{flex-direction:column;gap:20px;display:flex}.project-card{border:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:8px;flex-direction:column;align-items:flex-start;width:100%;padding:24px;transition:all .25s cubic-bezier(.16,1,.3,1);display:flex}.project-card:hover{border-color:var(--accent);background-color:var(--accent-hover);box-shadow:0 4px 20px rgba(var(--accent-rgb), .02)}.project-card-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:12px;display:flex}.project-id{letter-spacing:.05em;color:var(--secondary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;font-weight:500;transition:color .2s}.project-card:hover .project-id{color:var(--accent)}.project-arrow{color:var(--muted);font-size:1.1rem;transition:all .25s cubic-bezier(.16,1,.3,1)}.project-card:hover .project-arrow{color:var(--accent);transform:translate(4px)}.project-title{letter-spacing:-.01em;color:var(--fg);margin:0 0 8px;font-size:1.35rem;font-weight:600;line-height:1.2}.project-desc{color:var(--secondary);margin:0;font-size:.85rem;line-height:1.5}.lab-footer{flex-direction:column;gap:16px;margin-top:48px;display:flex}.footer-content{letter-spacing:.05em;color:var(--muted);justify-content:space-between;align-items:center;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.7rem;display:flex}@media (width<=520px){.lab-container{padding:48px 16px}.lab-title-row{flex-direction:column;align-items:flex-start;gap:16px}.lab-status{align-self:flex-start}.project-card{padding:20px}.project-title{font-size:1.2rem}}
