.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;box-shadow:0 2px 10px #0066ff1a}.header.scrolled{background:#fffffffa;box-shadow:0 4px 20px #0066ff26}.header-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.logo{display:flex;align-items:center;cursor:pointer;font-family:Poppins,sans-serif;font-weight:700;font-size:1.5rem;transition:transform .3s ease}.logo:hover{transform:scale(1.05)}.logo-text{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.nav{display:flex;align-items:center;gap:2rem}.nav a{text-decoration:none;color:var(--gray-700);font-weight:500;font-size:.95rem;transition:color .3s ease;position:relative}.nav a:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--primary-blue);transition:width .3s ease}.nav a:hover{color:var(--primary-blue)}.nav a:hover:after{width:100%}.nav .cta-button{background:var(--primary-blue);color:var(--white)!important;padding:.6rem 1.5rem;border-radius:8px;font-weight:600;transition:all .3s ease;box-shadow:var(--shadow-sm)}.nav .cta-button:after{display:none}.nav .cta-button:hover{background:var(--primary-blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}.mobile-menu-toggle span{width:25px;height:3px;background:var(--gray-900);border-radius:3px;transition:all .3s ease}@media (max-width: 768px){.mobile-menu-toggle{display:flex}.nav{position:absolute;top:100%;left:0;right:0;background:var(--white);flex-direction:column;padding:2rem;gap:1.5rem;box-shadow:var(--shadow-lg);transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease}.nav.open{transform:translateY(0);opacity:1;visibility:visible}.nav a{width:100%;text-align:center;padding:.5rem}.nav .cta-button{width:100%}}@media (max-width: 480px){.logo{font-size:1.3rem}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px;background:linear-gradient(135deg,#f5f7fa,#fff)}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;z-index:0}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:float 20s ease-in-out infinite}.orb-1{width:400px;height:400px;background:linear-gradient(135deg,var(--primary-blue) 0%,var(--accent-blue) 100%);top:-200px;right:-200px;animation-delay:0s}.orb-2{width:300px;height:300px;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--primary-blue-light) 100%);bottom:-150px;left:-150px;animation-delay:5s}.orb-3{width:250px;height:250px;background:linear-gradient(135deg,var(--primary-blue-light) 0%,var(--primary-blue) 100%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1;padding:2rem 0}.hero-text{animation:fadeInUp .8s ease}.hero-title{font-family:Poppins,sans-serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.2;margin-bottom:1.5rem;color:var(--gray-900);letter-spacing:-1px}.hero-subtitle{font-size:1.2rem;color:var(--gray-600);line-height:1.8;margin-bottom:2.5rem;max-width:600px}.hero-buttons{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.btn-primary,.btn-secondary{padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:all .3s ease;border:none;font-family:Inter,sans-serif}.btn-primary{background:var(--primary-blue);color:var(--white);box-shadow:var(--shadow-md)}.btn-primary:hover{background:var(--primary-blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:transparent;color:var(--primary-blue);border:2px solid var(--primary-blue)}.btn-secondary:hover{background:var(--primary-blue);color:var(--white);transform:translateY(-2px)}.hero-stats{display:flex;gap:3rem;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column}.stat-number{font-family:Poppins,sans-serif;font-size:2.5rem;font-weight:700;color:var(--primary-blue);line-height:1}.stat-label{font-size:.9rem;color:var(--gray-600);margin-top:.5rem}.hero-visual{display:flex;justify-content:center;align-items:center;animation:fadeInRight .8s ease}.code-window{background:var(--white);border-radius:12px;box-shadow:var(--shadow-xl);overflow:hidden;width:100%;max-width:500px;border:1px solid var(--gray-200)}.code-window-header{background:var(--gray-100);padding:.75rem 1rem;display:flex;gap:.5rem;border-bottom:1px solid var(--gray-200)}.window-dot{width:12px;height:12px;border-radius:50%;background:var(--gray-300)}.window-dot:nth-child(1){background:#ff5f57}.window-dot:nth-child(2){background:#ffbd2e}.window-dot:nth-child(3){background:#28ca42}.code-content{padding:1.5rem;font-family:Courier New,monospace;font-size:.9rem;line-height:1.8;background:var(--gray-900);color:var(--white)}.code-line{margin-bottom:.5rem}.code-keyword{color:#c678dd}.code-variable{color:#61afef}.code-string{color:#98c379}.code-number{color:#d19a66}.code-function{color:#e06c75}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);z-index:1}.mouse{width:30px;height:50px;border:2px solid var(--primary-blue);border-radius:15px;position:relative}.wheel{width:4px;height:10px;background:var(--primary-blue);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%);animation:scroll 2s infinite}@keyframes scroll{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(20px)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 968px){.hero-content{grid-template-columns:1fr;text-align:center}.hero-subtitle{max-width:100%}.hero-buttons,.hero-stats{justify-content:center}.hero-visual{margin-top:3rem}.scroll-indicator{display:none}}@media (max-width: 480px){.hero{padding-top:100px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.btn-primary,.btn-secondary{padding:.8rem 1.5rem;font-size:.9rem}.hero-stats{gap:2rem}}.servicios{padding:6rem 0;background:var(--white);position:relative}.section-header{text-align:center;margin-bottom:4rem}.section-title{font-family:Poppins,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--gray-900);margin-bottom:1rem;letter-spacing:-.5px}.section-subtitle{font-size:1.1rem;color:var(--gray-600);max-width:600px;margin:0 auto}.servicios-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem}.servicio-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:2.5rem;transition:all .3s ease;position:relative;overflow:hidden}.servicio-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary-blue) 0%,var(--accent-blue) 100%);transform:scaleX(0);transition:transform .3s ease}.servicio-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--primary-blue)}.servicio-card:hover:before{transform:scaleX(1)}.servicio-icon{font-size:3.5rem;margin-bottom:1.5rem;display:block;transition:transform .3s ease}.servicio-card:hover .servicio-icon{transform:scale(1.1) rotate(5deg)}.servicio-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem}.servicio-description{color:var(--gray-600);line-height:1.7;margin-bottom:1.5rem}.servicio-features{list-style:none;display:flex;flex-wrap:wrap;gap:.75rem}.servicio-features li{background:var(--gray-50);color:var(--primary-blue);padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;border:1px solid var(--gray-200);transition:all .3s ease;white-space:nowrap;overflow:visible}.servicio-card:hover .servicio-features li{background:var(--primary-blue);color:var(--white);border-color:var(--primary-blue)}@media (max-width: 768px){.servicios{padding:4rem 0}.servicios-grid{grid-template-columns:1fr;gap:1.5rem}.servicio-card{padding:2rem}}.sobre-mi{padding:6rem 0;background:linear-gradient(180deg,var(--white) 0%,var(--gray-50) 100%)}.sobre-mi-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.sobre-mi-text{animation:fadeInLeft .8s ease}.section-title{font-family:Poppins,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--gray-900);margin-bottom:2rem;letter-spacing:-.5px}.gradient-text{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sobre-mi-description{margin-bottom:2.5rem}.sobre-mi-description p{font-size:1.05rem;line-height:1.8;color:var(--gray-700);margin-bottom:1.5rem}.sobre-mi-description strong{color:var(--primary-blue);font-weight:600}.sobre-mi-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.stat-box{background:var(--white);padding:1.5rem;border-radius:12px;text-align:center;border:1px solid var(--gray-200);transition:all .3s ease;box-shadow:var(--shadow-sm)}.stat-box:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--primary-blue)}.stat-value{font-family:Poppins,sans-serif;font-size:2rem;font-weight:700;color:var(--primary-blue);margin-bottom:.5rem}.stat-text{font-size:.9rem;color:var(--gray-600);font-weight:500}.sobre-mi-visual{animation:fadeInRight .8s ease}.experience-timeline{position:relative;padding-left:2rem}.experience-timeline:before{content:"";position:absolute;left:.5rem;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--primary-blue) 0%,var(--accent-blue) 100%)}.timeline-item{position:relative;margin-bottom:2.5rem;padding-left:2rem}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-1.75rem;top:.5rem;width:14px;height:14px;border-radius:50%;background:var(--primary-blue);border:3px solid var(--white);box-shadow:0 0 0 3px var(--primary-blue);z-index:1}.timeline-content{background:var(--white);padding:1.5rem;border-radius:12px;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);transition:all .3s ease}.timeline-content:hover{transform:translate(10px);box-shadow:var(--shadow-md);border-color:var(--primary-blue)}.timeline-content h4{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:600;color:var(--gray-900);margin-bottom:.5rem}.timeline-content p{color:var(--gray-600);line-height:1.6;font-size:.95rem}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@media (max-width: 968px){.sobre-mi-content{grid-template-columns:1fr}.sobre-mi-visual{margin-top:3rem}}@media (max-width: 480px){.sobre-mi{padding:4rem 0}.sobre-mi-stats{grid-template-columns:1fr}.experience-timeline,.timeline-item{padding-left:1.5rem}}.portfolio{padding:6rem 0;background:var(--white)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:4rem}.portfolio-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow-sm)}.portfolio-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--primary-blue)}.portfolio-card-header{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--accent-blue) 100%);padding:1.5rem;display:flex;justify-content:space-between;align-items:center}.portfolio-badge{background:#fff3;color:var(--white);padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.portfolio-links{display:flex;gap:.5rem}.portfolio-link{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:8px;text-decoration:none;font-size:1.2rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.portfolio-link:hover{background:#ffffff4d;transform:scale(1.1)}.portfolio-card-body{padding:2rem}.portfolio-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem}.portfolio-description{color:var(--gray-600);line-height:1.7;margin-bottom:1.5rem}.portfolio-tech{display:flex;flex-wrap:wrap;gap:.75rem}.tech-tag{background:var(--gray-50);color:var(--primary-blue);padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;border:1px solid var(--gray-200);white-space:nowrap;overflow:visible}.portfolio-cta{text-align:center;padding:3rem;background:var(--gray-50);border-radius:16px;border:2px dashed var(--gray-300)}.portfolio-cta p{font-size:1.2rem;color:var(--gray-700);margin-bottom:1.5rem;font-weight:500}.portfolio-cta .btn-primary{padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:all .3s ease;border:none;font-family:Inter,sans-serif;background:var(--primary-blue);color:var(--white);box-shadow:var(--shadow-md)}.portfolio-cta .btn-primary:hover{background:var(--primary-blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media (max-width: 768px){.portfolio{padding:4rem 0}.portfolio-grid{grid-template-columns:1fr;gap:1.5rem}.portfolio-card-body{padding:1.5rem}}.contacto{padding:6rem 0;background:var(--white)}.contacto-content{display:grid;grid-template-columns:1fr 2fr;gap:4rem;margin-top:3rem}.contacto-info{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease;box-shadow:var(--shadow-sm)}.info-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--primary-blue)}.info-icon{font-size:3rem;margin-bottom:1rem}.info-card h3{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:600;color:var(--gray-900);margin-bottom:.5rem}.info-card a{color:var(--primary-blue);text-decoration:none;font-weight:500;transition:color .3s ease}.info-card a:hover{color:var(--primary-blue-dark);text-decoration:underline}.info-card p{color:var(--gray-600);font-size:.95rem}.contacto-form{background:var(--gray-50);padding:2.5rem;border-radius:16px;border:1px solid var(--gray-200)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:var(--gray-900);margin-bottom:.5rem;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:1px solid var(--gray-300);border-radius:8px;font-size:1rem;font-family:Inter,sans-serif;color:var(--gray-900);background:var(--white);transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #0066ff1a}.form-group textarea{resize:vertical;min-height:120px}.btn-submit{width:100%;padding:1rem 2rem;background:var(--primary-blue);color:var(--white);border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;box-shadow:var(--shadow-md)}.btn-submit:hover:not(:disabled){background:var(--primary-blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.form-status{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.form-status.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.form-status.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 968px){.contacto-content{grid-template-columns:1fr}.contacto-info{flex-direction:row;flex-wrap:wrap}.info-card{flex:1;min-width:200px}}@media (max-width: 768px){.contacto{padding:4rem 0}.contacto-form{padding:1.5rem}.form-row{grid-template-columns:1fr;gap:0}.contacto-info{flex-direction:column}}.footer{background:linear-gradient(135deg,var(--gray-900) 0%,#1a1a2e 100%);color:var(--white);padding:4rem 0 2rem;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--primary-blue) 50%,transparent 100%)}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:3rem}.footer-section{animation:fadeInUp .6s ease}.footer-logo{display:flex;align-items:center;font-family:Poppins,sans-serif;font-weight:700;font-size:1.8rem;margin-bottom:1rem}.footer-logo .logo-text{color:var(--white);letter-spacing:-.5px}.footer-logo .logo-dot{color:var(--primary-blue);font-size:2rem;margin:0 2px}.footer-description{color:#ffffffb3;line-height:1.7;font-size:.95rem}.footer-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:600;margin-bottom:1.5rem;color:var(--white)}.footer-links,.footer-contact,.footer-services{list-style:none}.footer-links li,.footer-contact li,.footer-services li{margin-bottom:.75rem}.footer-links a{color:#ffffffb3;text-decoration:none;transition:color .3s ease;font-size:.95rem}.footer-links a:hover{color:var(--primary-blue)}.footer-contact li{display:flex;align-items:center;gap:.75rem;color:#ffffffb3;font-size:.95rem}.contact-icon{font-size:1.2rem}.footer-contact a{color:#ffffffb3;text-decoration:none;transition:color .3s ease}.footer-contact a:hover{color:var(--primary-blue)}.footer-services li{color:#ffffffb3;font-size:.95rem;position:relative;padding-left:1rem}.footer-services li:before{content:"→";position:absolute;left:0;color:var(--primary-blue)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;gap:1rem}.footer-bottom p{color:#fff9;font-size:.9rem}.scroll-top{width:45px;height:45px;background:var(--primary-blue);color:var(--white);border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}.scroll-top:hover{background:var(--primary-blue-dark);transform:translateY(-3px);box-shadow:var(--shadow-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.footer{padding:3rem 0 1.5rem}.footer-content{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}}.container{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 768px){.container{padding:0 1.5rem}}@media (max-width: 480px){.container{padding:0 1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-blue: #0066FF;--primary-blue-dark: #0052CC;--primary-blue-light: #3385FF;--accent-blue: #00A8FF;--white: #FFFFFF;--gray-50: #F8F9FA;--gray-100: #F1F3F5;--gray-200: #E9ECEF;--gray-300: #DEE2E6;--gray-600: #6C757D;--gray-700: #495057;--gray-800: #343A40;--gray-900: #212529;--shadow-sm: 0 2px 4px rgba(0, 102, 255, .1);--shadow-md: 0 4px 6px rgba(0, 102, 255, .15);--shadow-lg: 0 10px 25px rgba(0, 102, 255, .2);--shadow-xl: 0 20px 40px rgba(0, 102, 255, .25)}html{scroll-behavior:smooth}body{font-family:Inter,-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;color:var(--gray-900);background-color:var(--white);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--primary-blue);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-blue-dark)}
