.expandable-spider-web{display:block;background:#0a0a0a;overflow:hidden}.web-container{transition:transform .8s cubic-bezier(.4,0,.2,1)}.center-node{transition:all .5s ease}.center-node:hover circle{r:40;filter:brightness(1.2) drop-shadow(0 0 20px rgba(102,126,234,.8))}.center-node:hover text{font-size:20px}.center-node circle.pulse{animation:pulse 3s ease-in-out infinite;transition:all .3s ease}.center-node text{transition:all .3s ease;pointer-events:none}@keyframes pulse{0%,to{r:35;opacity:.9}50%{r:38;opacity:1}}.project-node{transition:all .5s ease}.project-node:hover .project-circle{transform-origin:center;r:25;filter:brightness(1.2)}.project-node.expanded .project-circle{animation:expandPulse .5s ease}@keyframes expandPulse{0%{r:20}50%{r:35}to{r:30}}.project-circle{transition:all .3s ease}.project-label{transition:all .3s ease;pointer-events:none;-webkit-user-select:none;user-select:none}.sub-nodes{animation:fadeIn .5s ease}.sub-node-circle{transition:all .3s ease}.sub-node:hover .sub-node-circle{r:15;filter:brightness(1.3)}.sub-node-text{transition:all .3s ease;pointer-events:none}.sub-node:hover .sub-node-text{fill:#fff!important;font-weight:700}.details-button{animation:slideIn .5s ease;transition:all .3s ease}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.details-button:hover rect{opacity:1;filter:brightness(1.2)}.details-button text{pointer-events:none}.center-node.shrinking{transition:all .8s ease}.project-node.receiving-energy{transition:transform .3s ease}.project-node.receiving-energy .project-circle{animation:energyReceive .3s ease}@keyframes energyReceive{0%{filter:brightness(1)}50%{filter:brightness(1.5) drop-shadow(0 0 20px currentColor)}to{filter:brightness(1)}}.project-node:not(.receiving-energy){animation:float 6s ease-in-out infinite}.project-node:nth-child(odd){animation-delay:0s}.project-node:nth-child(2n){animation-delay:3s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.centered-node-bg{animation:fadeIn .8s ease}.centered-node-bg circle{animation:gentlePulse 4s ease-in-out infinite}@keyframes gentlePulse{0%,to{opacity:.3}50%{opacity:.15}}.project-details-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.project-details{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;padding:2.5rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;border:1px solid rgba(255,255,255,.1);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-button:hover{background-color:#ffffff1a;transform:rotate(90deg)}.project-details h2{font-size:2rem;margin-bottom:1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.project-description{font-size:1.1rem;color:#ccc;margin-bottom:2rem}.project-content{display:flex;flex-direction:column;gap:2rem}.technologies h3,.project-info h3{font-size:1.2rem;margin-bottom:1rem;color:#fff}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background-color:#667eea33;color:#667eea;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;border:1px solid rgba(102,126,234,.3);transition:all .3s ease}.tech-tag:hover{background-color:#667eea4d;transform:translateY(-2px)}.project-info p{color:#bbb;line-height:1.6}.project-actions{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.project-link{display:inline-block;color:#fff;padding:.75rem 2rem;border-radius:30px;text-decoration:none;font-weight:500;transition:all .3s ease;min-width:150px;text-align:center}.project-link.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.project-link.secondary{background:linear-gradient(135deg,#374151,#1f2937);border:1px solid rgba(255,255,255,.1)}.project-link:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000004d}.project-link.primary:hover{box-shadow:0 10px 20px #667eea4d}@media (max-width: 768px){.project-details{padding:2rem;width:95%}.project-details h2{font-size:1.5rem}}.app{width:100%;height:100vh;display:flex;flex-direction:column;position:relative}.app-header{position:absolute;top:2rem;right:2rem;z-index:10}.header-content{text-align:right}.app-header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.subtitle{font-size:.9rem;color:#888;font-weight:300}.app-main{flex:1;position:relative;width:100%;height:100%}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0a0a0a;color:#fff;overflow:hidden}#root{width:100vw;height:100vh}
