*{margin:0;padding:0;box-sizing:border-box}.skip-link{position:absolute;top:-40px;left:6px;background:var(--accent);color:var(--text-primary);padding:8px 12px;text-decoration:none;border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);font-weight:500;z-index:9999;transition:top var(--transition-smooth)}.skip-link:focus{top:6px}:root{--bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--bg-tertiary:#2d2d2d;--text-primary:#ffffff;--text-secondary:#a0a0a0;--accent:#007aff;--border:rgba(255, 255, 255, 0.1);--shadow:rgba(0, 0, 0, 0.3);--font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px;--transition-fast:0.2s cubic-bezier(0.4, 0, 0.2, 1);--transition-smooth:0.3s cubic-bezier(0.4, 0, 0.2, 1);--hero-animations-play-state:running;--projects-animations-play-state:running}html{scroll-behavior:smooth}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}img{max-width:100%;height:auto;display:block}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);width:100%}.navbar{position:fixed;top:0;width:100%;background:rgba(15,15,15,.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;padding:var(--spacing-md) 0}.nav-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);display:flex;justify-content:space-between;align-items:center}.nav-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo{width:32px;height:32px;border-radius:var(--border-radius-sm);flex-shrink:0}.logo-text{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.nav-menu{display:flex;list-style:none;gap:var(--spacing-xl)}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color var(--transition-fast);position:relative}.nav-link:hover{color:var(--text-primary)}.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width var(--transition-fast)}.nav-link:hover::after{width:100%}.hamburger{display:none;flex-direction:column;cursor:pointer;gap:4px;background:0 0;border:none;padding:var(--spacing-xs)}.bar{width:24px;height:2px;background:var(--text-primary);transition:var(--transition-fast);display:block}.hero{min-height:100vh;display:flex;align-items:center;padding:var(--spacing-3xl) 0;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);position:relative;overflow:hidden}.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);background-size:40px 40px;background-position:0 0,20px 20px;animation:60s linear infinite dot-pattern-drift;animation-play-state:var(--hero-animations-play-state);z-index:1}@keyframes dot-pattern-drift{0%{transform:translate(0,0)}100%{transform:translate(-40px,-40px)}}.hero::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;background-position:0 0,30px 30px;opacity:.3;animation:8s ease-in-out infinite alternate grid-pattern-fade;animation-play-state:var(--hero-animations-play-state);z-index:1}@keyframes grid-pattern-fade{0%{opacity:.1;transform:scale(1)}100%{opacity:.3;transform:scale(1.01)}}.hero-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);position:relative;z-index:2}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:center}.hero-title{font-size:var(--font-size-5xl);font-weight:700;line-height:1.1;margin-bottom:var(--spacing-md)}.highlight{background:linear-gradient(135deg,var(--accent) 0,#00d4ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:var(--font-size-xl);color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-weight:500}.hero-description{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-xl)}.hero-buttons{display:flex;gap:var(--spacing-lg)}.hero-logo{max-width:100%;height:auto}.hero img{border-radius:20px}.btn{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-md);text-decoration:none;font-weight:500;transition:all var(--transition-fast);border:none;cursor:pointer;font-size:var(--font-size-base);position:relative;overflow:hidden;display:inline-block;transform:translate3d(0,0,0);z-index:1}.btn>*{position:relative;z-index:2}.btn::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s}.btn:hover::before{transform:translateX(100%)}.btn-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.4);transform:scale(0);animation:.6s linear ripple;pointer-events:none;z-index:0}@keyframes ripple{0%{transform:scale(0);opacity:1}100%{transform:scale(4);opacity:0}}.btn-primary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);background:linear-gradient(var(--bg-primary),var(--bg-primary)) padding-box,linear-gradient(90deg,var(--border),var(--border),var(--accent),var(--border),var(--border)) border-box;background-size:100% 100%,200% 100%;animation:8s linear infinite shine-border}@keyframes shine-border{0%{background-position:0 0,-200% 0}100%{background-position:0 0,200% 0}}.btn-primary:hover{transform:translateY(-2px);animation-duration:5s;background:linear-gradient(var(--bg-secondary),var(--bg-secondary)) padding-box,linear-gradient(90deg,var(--border),var(--border),var(--accent),var(--border),var(--border)) border-box}.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(102,126,234,.1),transparent);transition:left .5s;z-index:1}.btn-primary:hover::before{left:100%}.btn-primary::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(102,126,234,.05);opacity:0;transition:opacity .3s;z-index:1}.btn-primary:hover::after{opacity:1}.btn-secondary{background:0 0;color:var(--text-primary);border:1px solid var(--border);position:relative;overflow:hidden;transition:.3s}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--text-secondary);transform:translateY(-2px)}.btn-secondary::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.05);opacity:0;transition:opacity .3s;z-index:1}.btn-secondary:hover::after{opacity:1}.section-header{text-align:center;margin-bottom:var(--spacing-3xl)}.section-title{font-size:var(--font-size-4xl);font-weight:700;margin-bottom:var(--spacing-md)}.section-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary)}.projects{min-height:100vh;padding:var(--spacing-3xl) 0;background:var(--bg-secondary);position:relative;overflow:hidden}.projects::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle at center,rgba(0,122,255,.03) 0,rgba(0,122,255,.01) 30%,transparent 70%);border-radius:50%;z-index:1;pointer-events:none;animation:8s ease-in-out infinite alternate gentle-pulse;animation-play-state:var(--projects-animations-play-state)}@keyframes gentle-pulse{0%{opacity:.6;transform:translate(-50%,-50%) scale(.95)}100%{opacity:.9;transform:translate(-50%,-50%) scale(1.05)}}.projects-spotlight{position:absolute;top:50%;left:50%;width:400px;height:400px;transform:translate(-50%,-50%);background:radial-gradient(circle at center,rgba(255,255,255,.02) 0,rgba(255,255,255,.008) 40%,transparent 70%);border-radius:50%;z-index:1;pointer-events:none;animation:12s ease-in-out infinite spotlight-drift;animation-play-state:var(--projects-animations-play-state);opacity:.7}@keyframes spotlight-drift{0%,100%{transform:translate(-50%,-50%) rotate(0) scale(1);opacity:.5}25%{transform:translate(-48%,-52%) rotate(1deg) scale(1.1);opacity:.8}50%{transform:translate(-52%,-48%) rotate(-1deg) scale(.9);opacity:.6}75%{transform:translate(-50%,-50%) rotate(.5deg) scale(1.05);opacity:.7}}.projects .container{position:relative;z-index:2}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg);justify-items:center}.projects-grid:has(.project-card:first-child:last-child){grid-template-columns:1fr;max-width:400px}.projects-grid:has(.project-card:nth-child(2):last-child){grid-template-columns:repeat(2,1fr);max-width:800px}.projects-grid:has(.project-card:nth-child(3)){grid-template-columns:repeat(auto-fit,minmax(350px,1fr));max-width:1200px}.project-card{position:relative;z-index:3;background:var(--bg-primary);border:1px solid rgba(255,255,255,.05);background:var(--bg-primary);border-radius:var(--border-radius-xl);overflow:hidden;border:1px solid var(--border);transition:.4s cubic-bezier(.4, 0, .2, 1);transform-style:preserve-3d;will-change:transform;display:flex;flex-direction:column;height:100%;width:100%;max-width:400px;margin:0 auto;backface-visibility:hidden;-webkit-backface-visibility:hidden}.project-card:hover{box-shadow:0 20px 40px var(--shadow)}.project-image{height:160px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.project-placeholder{font-size:var(--font-size-3xl);color:var(--text-secondary)}.project-content{padding:var(--spacing-lg);display:flex;flex-direction:column;flex-grow:1}.project-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm)}.project-description{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);flex-grow:1}.project-tech{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.tech-tag{background:var(--bg-tertiary);color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);font-weight:500}.tech-tag a{text-decoration:none}.project-links{display:flex;gap:var(--spacing-sm);margin-top:auto}.project-link{cursor:pointer;font-family:var(--font-family);display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:0 0;color:var(--text-primary);text-decoration:none;font-weight:500;border:1px solid var(--border);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);transition:.3s;position:relative;overflow:hidden;min-height:36px}.project-link:hover{background:var(--bg-secondary);border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.project-link::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.05);opacity:0;transition:opacity .3s;z-index:1}.project-link:hover::after{opacity:1}.project-link i,.project-link span{position:relative;z-index:2}.skills{min-height:100vh;padding:var(--spacing-3xl) 0}.skills-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);gap:var(--spacing-lg);flex-wrap:wrap}.skills-actions{display:flex;gap:var(--spacing-md)}.skills-filters{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.btn-control,.btn-filter{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-control:hover,.btn-filter:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent);transform:translateY(-2px)}.btn-filter.active{background:var(--accent);color:var(--text-primary);border-color:var(--accent)}.btn-filter.active::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.1);z-index:1}.btn-filter.active i,.btn-filter.active span{position:relative;z-index:2}.skills-accordion{display:flex;flex-direction:column;gap:var(--spacing-lg)}.skill-accordion-item{background:var(--bg-secondary);border-radius:var(--border-radius-xl);border:1px solid var(--border);overflow:hidden;transition:all var(--transition-smooth);opacity:1;transform:translateY(0)}.skill-accordion-item.hidden{display:none!important;opacity:0!important;transform:translateY(-20px)!important;pointer-events:none!important;transition:.3s cubic-bezier(.4, 0, .2, 1)!important}.skill-accordion-item:not(.hidden){display:block!important;opacity:1!important;transform:translateY(0)!important;pointer-events:auto!important}.skill-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);cursor:pointer;background:var(--bg-secondary);transition:all var(--transition-fast);position:relative}.skill-accordion-header:hover{background:var(--bg-tertiary)}.skill-accordion-header.active{background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.skill-accordion-header::before{content:'';position:absolute;top:0;left:0;width:0;height:100%;background:linear-gradient(90deg,transparent,rgba(0,122,255,.05),transparent);transition:width .3s;z-index:1}.skill-accordion-header:hover::before{width:100%}.skill-accordion-header>*{position:relative;z-index:2}.skill-accordion-title{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.skill-accordion-title .skill-icon{font-size:var(--font-size-xl);color:var(--accent);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(0,122,255,.1);border-radius:var(--border-radius-sm)}.skill-accordion-title h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.skill-count{font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-weight:500}.skill-accordion-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-primary);border-radius:var(--border-radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.skill-accordion-toggle i{font-size:var(--font-size-lg);transition:transform var(--transition-fast)}.skill-accordion-header.active .skill-accordion-toggle{background:var(--accent);color:var(--text-primary)}.skill-accordion-header.active .skill-accordion-toggle i{transform:rotate(180deg)}.skill-accordion-content{max-height:0;overflow:hidden;transition:max-height var(--transition-smooth);background:var(--bg-primary)}.skill-accordion-content.active{max-height:1000px}.skill-accordion-content .skill-items{padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-lg)}.skill-accordion-content .skill-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--border);transition:all var(--transition-smooth);position:relative;overflow:hidden}.skill-accordion-content .skill-item:hover{background:var(--bg-tertiary);border:1px solid transparent;background:linear-gradient(var(--bg-tertiary),var(--bg-tertiary)) padding-box,linear-gradient(90deg,var(--border),var(--border),var(--accent),var(--border),var(--border)) border-box;background-size:100% 100%,200% 100%;animation:6s linear infinite shine-border-subtle}@keyframes shine-border-subtle{0%{background-position:0 0,-200% 0}100%{background-position:0 0,200% 0}}.skill-icon-wrapper{width:48px;height:48px;background:var(--bg-tertiary);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.skill-icon-wrapper i{font-size:var(--font-size-xl);color:var(--accent)}.skill-item:hover .skill-icon-wrapper{background:rgba(0,122,255,.15)}.skill-item:hover .skill-icon-wrapper i{color:var(--accent)}.skill-info{flex:1;min-width:0}.skill-info h4{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-xs) 0;color:var(--text-primary)}.skill-info p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;line-height:1.5}.skill-level{position:absolute;top:50%;right:var(--spacing-md);transform:translateY(-50%);z-index:10}.skill-level-text{display:inline-flex;align-items:center;font-size:var(--font-size-xs);font-weight:700;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);text-transform:uppercase;letter-spacing:.8px;line-height:1;border:1px solid;transition:all var(--transition-fast);box-shadow:0 2px 4px rgba(0,0,0,.1);backdrop-filter:blur(8px)}.skill-level-text.avanzado{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.3)}.skill-level-text.intermedio{background:rgba(251,191,36,.1);color:#fbbf24;border-color:rgba(251,191,36,.3)}.skill-level-text.basico{background:rgba(239,68,68,.1);color:#ef4444;border-color:rgba(239,68,68,.3)}.skill-bar,.skill-progress{display:none}@keyframes skillBarLoad{0%{width:0%;opacity:0}100%,50%{opacity:1}}.skill-progress{animation:1s ease-out forwards skillBarLoad}.btn-control,.btn-filter{position:relative;overflow:hidden}.btn-control::after,.btn-filter::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.2);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s}.btn-control:active::after,.btn-filter:active::after{width:200px;height:200px}.skill-accordion-item:hover{box-shadow:0 8px 32px rgba(0,0,0,.2)}.skill-accordion-header.active{box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}.btn-control:focus,.btn-filter:focus{outline:2px solid var(--accent);outline-offset:2px}.skill-accordion-header:focus{outline:2px solid var(--accent);outline-offset:-2px}@media (max-width:480px){.skill-accordion-content .skill-item{padding:var(--spacing-md)}.skill-info h4{font-size:var(--font-size-base)}.skill-info p{font-size:var(--font-size-xs)}.skill-level{gap:var(--spacing-xs)}.skill-bar{width:60px;height:3px}}@media (max-width:1199px){.skills-controls{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.skills-actions,.skills-filters{justify-content:center}}@media (max-width:767px){.skills-controls{margin-bottom:var(--spacing-lg)}.skills-filters{gap:var(--spacing-xs)}.btn-control,.btn-filter{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.skill-accordion-header{padding:var(--spacing-md) var(--spacing-lg)}.skill-accordion-title{gap:var(--spacing-sm)}.skill-accordion-title h3{font-size:var(--font-size-base)}.skill-accordion-content .skill-items{padding:var(--spacing-lg);gap:var(--spacing-md)}.skill-accordion-content .skill-item{flex-direction:column;text-align:center;gap:var(--spacing-md)}.skill-level{align-items:center;min-width:auto}.skill-bar{width:80px}}.contact{padding:var(--spacing-3xl) 0;background:var(--bg-secondary)}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:start}.contact-item{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.contact-icon{width:48px;height:48px;background:var(--accent);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:var(--font-size-lg)}.contact-details h4{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-xs)}.contact-details p{color:var(--text-secondary)}.contact-form{background:var(--bg-primary);padding:var(--spacing-xl);border-radius:var(--border-radius-xl);border:1px solid var(--border)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--border-radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:0;border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:120px}.footer{background:var(--bg-primary);padding:var(--spacing-xl) 0;border-top:1px solid var(--border)}.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.footer-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.footer-social{display:flex;gap:var(--spacing-md)}.social-link{width:40px;height:40px;background:var(--bg-secondary);border-radius:var(--border-radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}.social-link:hover{background:var(--accent);color:var(--text-primary);transform:translateY(-2px)}.footer-bottom{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--border);color:var(--text-secondary)}[data-tilt]{transform-origin:center center;transition:transform .3s cubic-bezier(.23, 1, .32, 1)}.hero::after,.hero::before{will-change:transform,opacity;backface-visibility:hidden}.hero .hero-mesh{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(0,122,255,.03) 0,transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,122,255,.02) 0,transparent 50%),radial-gradient(circle at 40% 80%,rgba(0,122,255,.02) 0,transparent 50%);z-index:1;pointer-events:none;animation:30s ease-in-out infinite mesh-drift;animation-play-state:var(--hero-animations-play-state)}@keyframes mesh-drift{0%,100%{transform:translate(0,0) rotate(0);opacity:.6}25%{transform:translate(-10px,-5px) rotate(1deg);opacity:.8}50%{transform:translate(5px,-10px) rotate(-1deg);opacity:.4}75%{transform:translate(-5px,5px) rotate(.5deg);opacity:.7}}@media (max-width:768px){.hero::before{background-size:30px 30px;animation-duration:40s}.hero::after{background-size:45px 45px;opacity:.2}.hero .hero-mesh{opacity:.3;animation-duration:20s}.projects::before{width:400px;height:400px;background:radial-gradient(circle at center,rgba(0,122,255,.02) 0,rgba(0,122,255,.008) 30%,transparent 70%);animation-duration:6s}.projects-spotlight{width:300px;height:300px;background:radial-gradient(circle at center,rgba(255,255,255,.015) 0,rgba(255,255,255,.005) 40%,transparent 70%);border-radius:50%;animation-duration:8s}}@media (max-width:480px){.projects::before{width:300px;height:300px;opacity:.5;border-radius:50%}.projects-spotlight{width:250px;height:250px;opacity:.4;border-radius:50%}}@media (min-width:768px) and (max-width:1199px){.hero-content{grid-template-columns:1fr;text-align:center;gap:var(--spacing-2xl)}.hero-title{font-size:clamp(2.5rem, 4vw, 3.5rem)}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);max-width:900px;padding:10px}.projects-grid:has(.project-card:first-child:last-child){grid-template-columns:1fr;max-width:350px}.projects-grid:has(.project-card:nth-child(2):last-child){grid-template-columns:repeat(2,1fr);max-width:700px}.skills-grid{grid-template-columns:repeat(2,1fr)}.contact-content{grid-template-columns:1fr;gap:var(--spacing-2xl)}}@media (max-width:900px){.navbar{height:68px}.nav-menu{top:68px;height:calc(100vh - 68px);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:var(--spacing-2xl)}.nav-menu li{margin:var(--spacing-lg) 0;width:100%;max-width:300px}}@media (max-width:767px){.container,.hero-container,.nav-container{padding:0 var(--spacing-md)}.navbar{padding:var(--spacing-sm) 0}.nav-menu{position:fixed;left:0;top:68px;flex-direction:column;background-color:rgba(15,15,15,.98);backdrop-filter:blur(20px);width:100%;text-align:center;transform:translateY(-100%);opacity:0;visibility:hidden;transition:.4s cubic-bezier(.4, 0, .2, 1);box-shadow:0 10px 27px rgba(0,0,0,.3);border-bottom:1px solid var(--border);padding:var(--spacing-lg) 0;z-index:999;min-height:calc(100vh - 68px)}.nav-menu.active{transform:translateY(0);opacity:1;visibility:visible}.nav-menu li{margin:var(--spacing-md) 0;opacity:0;transform:translateY(-20px);transition:.3s cubic-bezier(.4, 0, .2, 1)}.nav-menu.active li{opacity:1;transform:translateY(0)}.nav-menu.active li:first-child{transition-delay:0.1s}.nav-menu.active li:nth-child(2){transition-delay:0.2s}.nav-menu.active li:nth-child(3){transition-delay:0.3s}.nav-menu.active li:nth-child(4){transition-delay:0.4s}.nav-link{font-size:var(--font-size-lg);padding:var(--spacing-sm) var(--spacing-md);display:block;width:100%}.hamburger{display:flex!important;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-xs);min-width:44px;min-height:44px;cursor:pointer;background:0 0;border:none;z-index:1001}.bar{width:24px;height:2px;background:var(--text-primary);transition:.3s;margin:2px 0}.hamburger.active .bar:first-child{transform:translateY(6px) rotate(45deg)}.hamburger.active .bar:nth-child(2){opacity:0}.hamburger.active .bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.hero{min-height:90vh;padding:var(--spacing-2xl) 0}.hero-content{grid-template-columns:1fr;text-align:center;gap:var(--spacing-xl)}.hero-title{font-size:clamp(2rem, 6vw, 2.5rem)}.hero-buttons{flex-direction:column;align-items:center;gap:var(--spacing-sm)}.btn{width:100%;max-width:280px;text-align:center}.projects-grid{grid-template-columns:1fr;gap:var(--spacing-lg);max-width:320px;justify-items:center}.projects-grid:has(.project-card:first-child:last-child),.projects-grid:has(.project-card:nth-child(2):last-child),.projects-grid:has(.project-card:nth-child(3)){grid-template-columns:1fr;max-width:320px}.project-links{flex-wrap:wrap;gap:var(--spacing-xs)}.project-link{flex:1;min-width:100px;font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}.skills-grid{grid-template-columns:1fr}.skill-items{grid-template-columns:repeat(2,1fr)}.contact-content{grid-template-columns:1fr;gap:var(--spacing-xl)}.contact-form{padding:var(--spacing-lg)}.footer-content{flex-direction:column;gap:var(--spacing-lg);text-align:center}.section-title{font-size:clamp(1.75rem, 5vw, 2.25rem)}.nav-link,.project-link,.social-link{min-height:44px;display:flex;align-items:center;justify-content:center}}@media (max-width:480px){.container,.hero-container,.nav-container{padding:0 var(--spacing-sm)}.logo{width:28px;height:28px}.hero-title{font-size:clamp(1.75rem, 8vw, 2.25rem)}.btn{max-width:250px;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.btn-contact-form{max-width:100%}.projects-grid{max-width:320px;margin:0 auto}.project-content{padding:var(--spacing-md)}.skill-category{padding:var(--spacing-lg)}.contact-form{padding:var(--spacing-md)}.section-title{font-size:clamp(1.5rem, 6vw, 2rem)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:9999;opacity:0;visibility:hidden;transition:.3s cubic-bezier(.25, .8, .25, 1)}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{border-radius:var(--border-radius-xl);max-width:90%;width:600px;max-height:90%;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.5);border:1px solid var(--border);transform:scale(.8) translateY(50px);transition:.3s cubic-bezier(.25, .8, .25, 1);position:relative}.modal-overlay.active .modal-content{transform:scale(1) translateY(0)}.modal-header{position:relative;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border)}.modal-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);width:32px;height:32px;background:var(--bg-tertiary);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary);transform:scale(1.1)}.modal-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.modal-subtitle{color:var(--text-secondary);font-size:var(--font-size-base)}.modal-body{padding:var(--spacing-xl)}.modal-image{width:100%;height:200px;background:var(--bg-tertiary);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);border:1px solid var(--border)}.modal-image i{font-size:3rem;color:var(--text-secondary)}.modal-description{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-lg);font-size:var(--font-size-base)}.modal-tech{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.modal-tech .tech-tag{background:var(--bg-secondary);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);font-weight:500;border:1px solid var(--border)}.modal-links{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.modal-link{flex:1;min-width:150px;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);color:var(--text-primary);text-decoration:none;border-radius:var(--border-radius-md);border:1px solid var(--border);transition:all var(--transition-fast);font-weight:500}.modal-link:hover{background:var(--bg-tertiary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.modal-link.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-link.primary:hover{background:#0056b3;border-color:#0056b3}@media (max-width:767px){.modal-content{max-width:95%;margin:var(--spacing-md)}.modal-body,.modal-header{padding:var(--spacing-lg)}.modal-links{flex-direction:column}.modal-link{min-width:auto}}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.modal-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.btn:focus,.form-group input:focus,.form-group textarea:focus,.social-link:focus{outline:2px solid var(--accent);outline-offset:2px}.nav-link:focus{outline:0;border-radius:4px}@media (min-width:901px){.hamburger{display:none!important}.nav-menu{position:static!important;flex-direction:row!important;background:0 0!important;width:auto!important;box-shadow:none!important;padding:0!important;left:auto!important}}.no-scroll{overflow:hidden;position:fixed;width:100%;height:100%}.hero.paused .hero-mesh,.hero.paused::after,.hero.paused::before{animation-play-state:var(--hero-animations-play-state)}.hero.paused{--hero-animations-play-state:paused}.hero.active{--hero-animations-play-state:running}.btn-contact-form{width:100%;font-family:var(--font-family)}.projects-dock{display:flex;justify-content:center;align-items:center;gap:var(--spacing-lg);margin:var(--spacing-2xl) auto;padding:var(--spacing-lg);background:rgba(15,15,15,.95);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:50px;position:relative;z-index:10;max-width:500px;box-shadow:0 8px 32px rgba(0,0,0,.3),0 2px 8px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.1);transition:transform .3s}.dock-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm);background:0 0;border:none;border-radius:50%;cursor:pointer;transition:.4s cubic-bezier(.175, .885, .32, 1.275);position:relative;width:60px;height:60px;color:var(--text-secondary);overflow:visible;transform-origin:center bottom;will-change:transform}.dock-item::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(0,122,255,.3) 0,rgba(0,122,255,.1) 50%,transparent 100%);border-radius:50%;opacity:0;transition:.4s cubic-bezier(.175, .885, .32, 1.275);transform:translate(-50%,-50%);z-index:-1}.dock-item::after{content:'';position:absolute;bottom:-10px;left:50%;width:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);transform:translateX(-50%);transition:width .4s cubic-bezier(.4, 0, .2, 1);border-radius:2px}.dock-item:hover::before{width:80px;height:80px;opacity:1}.dock-item.active::after,.dock-item:hover::after{width:40px}.dock-item.active::after{background:var(--accent)}.dock-item:hover{transform:translateY(-12px) scale(1.2);color:var(--text-primary);background:rgba(0,122,255,.1);box-shadow:0 15px 40px rgba(0,122,255,.25),0 5px 15px rgba(0,122,255,.15)}.dock-item.active{background:rgba(0,122,255,.2);color:var(--accent);transform:translateY(-8px) scale(1.1);box-shadow:0 12px 30px rgba(0,122,255,.3),0 4px 12px rgba(0,122,255,.2)}.dock-item.active::before{width:70px;height:70px;opacity:1;background:radial-gradient(circle,rgba(0,122,255,.4) 0,rgba(0,122,255,.2) 50%,transparent 100%)}.dock-icon{font-size:1.25rem;transition:.3s;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.dock-item:hover .dock-icon{transform:scale(1.1);filter:drop-shadow(0 0 8px rgba(0, 122, 255, .5))}.dock-item.active .dock-icon{color:var(--accent);filter:drop-shadow(0 0 10px rgba(0, 122, 255, .7))}.dock-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;font-weight:600;text-align:center;line-height:1;opacity:0;pointer-events:none;transition:.3s;background:rgba(0,0,0,.9);color:var(--text-primary);padding:6px 10px;border-radius:16px;white-space:nowrap;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 12px rgba(0,0,0,.4);z-index:100}.dock-item:hover .dock-label{opacity:1}.dock-item.active .dock-label{opacity:1;background:rgba(0,122,255,.3);border-color:rgba(0,122,255,.4);color:var(--text-primary)}.projects-container{padding:15px!important;position:relative;width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-xl) 0;min-height:600px;overflow:hidden}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg);max-width:1200px;margin:0 auto;justify-items:center;opacity:0;visibility:hidden;transform:translateY(30px) scale(.95);transition:.6s cubic-bezier(.4, 0, .2, 1);position:absolute;top:0;left:0;right:0}.projects-grid.active{opacity:1;visibility:visible;transform:translateY(0) scale(1);position:relative}.projects-grid.fade-out{opacity:0;transform:translateY(-20px) scale(.95);transition:.3s cubic-bezier(.4, 0, .2, 1)}.future-project{border:1px solid rgba(255,255,255,.05);background:linear-gradient(135deg,var(--bg-primary) 0,rgba(0,122,255,.02) 100%)}.project-status{display:flex;justify-content:flex-end;margin-top:var(--spacing-md)}.status-badge{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);white-space:nowrap}.status-badge.planning{background:rgba(255,193,7,.2);color:#ffc107;border:1px solid rgba(255,193,7,.3)}@media (max-width:767px){.hero-container{padding-top:50px}.projects-dock{gap:var(--spacing-sm);padding:var(--spacing-md);margin:var(--spacing-lg) auto;max-width:350px}.dock-item{width:50px;height:50px;padding:var(--spacing-xs)}.dock-icon{font-size:1rem}.dock-label{font-size:.6rem;padding:4px 8px}.dock-item:hover{transform:translateY(-6px) scale(1.15)}.dock-item.active{transform:translateY(-4px) scale(1.05)}.projects-container{min-height:500px;padding:var(--spacing-lg) 0}.projects-grid{transform:translateY(20px) scale(.98)}.projects-grid.active{transform:translateY(0) scale(1)}}@media (max-width:480px){.projects-dock{gap:var(--spacing-xs);padding:var(--spacing-sm);max-width:280px}.dock-item{width:45px;height:45px}.dock-icon{font-size:.9rem}.dock-label{font-size:.55rem;padding:3px 6px}}