:root{--bg-base:#0a0f1d;--bg-alt:#0e1628;--bg-card:#141e3799;--bg-nav:#0a0f1dd9;--border-color:#6366f126;--border-hover:#6366f166;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#6366f1;--accent-secondary:#06b6d4;--accent-glow:#6366f14d;--card-shadow:0 10px 30px -15px #020617b3;--nav-shadow:0 4px 20px -2px #02061780;--transition-fast:.2s ease;--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.6s cubic-bezier(.4, 0, .2, 1);--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif}[data-theme=light]{--bg-base:#f8fafc;--bg-alt:#f1f5f9;--bg-card:#fffc;--bg-nav:#f8fafcd9;--border-color:#6366f11a;--border-hover:#6366f14d;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent-primary:#4f46e5;--accent-secondary:#0891b2;--accent-glow:#4f46e526;--card-shadow:0 10px 30px -15px #94a3b84d;--nav-shadow:0 4px 20px -2px #94a3b826}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.6;overflow-x:hidden}#hero-canvas{z-index:-1;pointer-events:none;opacity:.8;width:100vw;height:100vh;position:fixed;top:0;left:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.section-padding{padding:4.5rem 0}.section-alt-bg{background-color:var(--bg-alt);transition:background-color var(--transition-normal)}.gradient-text{background:linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:inline-block}.flex-center{justify-content:center;align-items:center;display:flex}.link-hover{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none;position:relative}.link-hover:after{content:"";background-color:var(--accent-secondary);transform-origin:100% 100%;width:100%;height:2px;transition:transform var(--transition-fast) ease-out;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.link-hover:hover{color:var(--accent-secondary)}.link-hover:hover:after{transform-origin:0 100%;transform:scaleX(1)}.section-title-wrapper{text-align:center;margin-bottom:2.25rem}.subtitle-badge{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.15em;color:var(--accent-primary);background-color:var(--border-color);border-radius:9999px;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.875rem;font-weight:600;display:inline-block}.section-title{font-family:var(--font-heading);letter-spacing:-.02em;font-size:2.25rem;font-weight:700;position:relative}.section-title:after{content:"";background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));border-radius:2px;width:60px;height:4px;margin:.75rem auto 0;display:block}.header{z-index:100;background-color:var(--bg-nav);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);width:100%;box-shadow:var(--nav-shadow);transition:background-color var(--transition-normal), border-color var(--transition-normal);position:fixed;top:0;left:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;height:4.5rem;margin:0 auto;padding:0 1.5rem;display:flex}.logo{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.03em;transition:color var(--transition-fast);font-size:1.5rem;font-weight:800;text-decoration:none}.logo-accent{color:var(--accent-primary);font-weight:600}.logo-dot{color:var(--accent-secondary);text-shadow:0 0 10px var(--accent-glow)}.nav-menu ul{gap:2rem;list-style:none;display:flex}.nav-link{font-family:var(--font-heading);color:var(--text-secondary);transition:color var(--transition-fast);cursor:pointer;background:0 0;border:none;padding:.5rem 0;font-size:.95rem;font-weight:500;text-decoration:none;position:relative}.nav-link:hover,.nav-link.active{color:var(--accent-primary)}.nav-link.active:after{content:"";background-color:var(--accent-primary);border-radius:1px;width:100%;height:2px;position:absolute;bottom:0;left:0}.theme-toggle-btn{border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);transition:all var(--transition-fast);background:0 0;border-radius:8px;padding:.5rem}.theme-toggle-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background-color:var(--border-color)}.sun-icon{display:block}.moon-icon,[data-theme=light] .sun-icon{display:none}[data-theme=light] .moon-icon{display:block}.menu-toggle{cursor:pointer;z-index:10;background:0 0;border:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;padding:0;display:none}.hamburger,.hamburger:before,.hamburger:after{background-color:var(--text-primary);width:2rem;height:.2rem;transition:all var(--transition-normal);border-radius:10px;position:relative}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0}.hamburger:before{top:-.6rem}.hamburger:after{bottom:-.6rem}.menu-toggle.open .hamburger{background-color:#0000}.menu-toggle.open .hamburger:before{top:0;transform:rotate(45deg)}.menu-toggle.open .hamburger:after{bottom:0;transform:rotate(-45deg)}.btn{font-family:var(--font-heading);cursor:pointer;transition:all var(--transition-normal);border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 1.6rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);color:#fff;box-shadow:0 4px 15px -3px var(--accent-glow);border:none;position:relative;overflow:hidden}.btn-primary:after{content:"";background:linear-gradient(90deg,#fff0 0%,#ffffff59 50%,#fff0 100%);width:50%;height:100%;transition:none;position:absolute;top:0;left:-150%;transform:skew(-25deg)}.btn-primary:hover:after{transition:left .85s ease-in-out;left:150%}.btn-primary:hover{box-shadow:0 8px 20px -3px var(--accent-glow);filter:brightness(1.05);transform:translateY(-2px)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background-color:#0000}.btn-secondary:hover{border-color:var(--accent-primary);background-color:var(--border-color);transform:translateY(-2px)}.btn-icon{transition:transform var(--transition-fast)}.btn-secondary:hover .btn-icon{transform:translateY(2px)}.hero{justify-content:center;align-items:center;min-height:100vh;padding-top:5rem;display:flex;position:relative;overflow:hidden}.hero-content{grid-template-columns:1.2fr .8fr;align-items:center;gap:4rem;width:100%;display:grid}.hero-badge{background-color:var(--border-color);color:var(--accent-secondary);border:1px solid #6366f11a;border-radius:9999px;width:fit-content;margin-bottom:1.5rem;padding:.35rem .9rem;font-size:.85rem;font-weight:500;display:inline-block}.hero-title{font-family:var(--font-heading);letter-spacing:-.03em;margin-bottom:1rem;font-size:3.5rem;font-weight:800;line-height:1.15}.hero-subtitle{color:var(--text-secondary);max-width:600px;margin-bottom:1.5rem;font-size:1.5rem;font-weight:600;line-height:1.35}.hero-description{color:var(--text-secondary);max-width:600px;margin-bottom:1.75rem;font-size:1.1rem}.hero-cta{flex-wrap:wrap;gap:1rem;display:flex}.profile-card{background:linear-gradient(135deg, var(--border-color), #06b6d426);box-shadow:var(--card-shadow);transition:transform var(--transition-normal), box-shadow var(--transition-normal), background var(--transition-normal);border-radius:16px;padding:1px;position:relative;overflow:hidden}.profile-card:hover{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));transform:translateY(-6px)scale(1.02);box-shadow:0 20px 40px -15px #6366f159}.avatar-glow{background:radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);z-index:0;width:200px;height:200px;position:absolute;top:-50px;right:-50px}.profile-box{z-index:1;background:var(--bg-card);-webkit-backdrop-filter:blur(16px);border-radius:15px;width:100%;padding:2rem;position:relative}.profile-header{align-items:center;gap:1.25rem;display:flex}.avatar-container{flex-shrink:0}.avatar-wrapper{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:76px;height:76px;box-shadow:0 4px 15px var(--accent-glow);border-radius:50%;padding:2px;position:relative}.avatar-img{object-fit:cover;border:2px solid var(--bg-card);border-radius:50%;width:100%;height:100%;display:block}.status-indicator{background-color:#0a0f1d;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:flex;position:absolute;bottom:2px;right:2px}[data-theme=light] .status-indicator{background-color:#f8fafc}.status-dot{background-color:#10b981;border-radius:50%;width:8px;height:8px;display:block}.status-pulse{opacity:.75;z-index:-1;background-color:#10b981;border-radius:50%;width:100%;height:100%;animation:2s ease-in-out infinite status-pulse;position:absolute}@keyframes status-pulse{0%{opacity:.75;transform:scale(1)}70%{opacity:0;transform:scale(2.2)}to{opacity:0;transform:scale(2.2)}}.profile-info-text{flex-direction:column;gap:.25rem;display:flex}.profile-name{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.01em;font-size:1.25rem;font-weight:700}.profile-role-badge{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.75rem;font-weight:700;display:inline-block}.profile-availability{color:var(--text-muted);font-size:.75rem;font-weight:500}.profile-stats{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);text-align:center;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.5rem 0;padding:1.25rem 0;display:grid}.p-stat-item{flex-direction:column;gap:.15rem;display:flex}.p-stat-num{font-family:var(--font-heading);color:var(--text-primary);font-size:1.15rem;font-weight:800}.p-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.profile-tech-section{flex-direction:column;display:flex}.tech-title{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.75rem;font-weight:700}.tech-tag-grid{flex-wrap:wrap;gap:.5rem;display:flex}.tech-tag-badge{background-color:var(--bg-alt);border:1px solid var(--border-color);font-family:var(--font-heading);color:var(--text-secondary);transition:all var(--transition-fast);border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.8rem;font-weight:600;display:flex}.tech-tag-badge:hover{border-color:var(--accent-primary);color:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.tech-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.tech-dot.react{background-color:#61dafb}.tech-dot.next{background-color:#fff}[data-theme=light] .tech-dot.next{background-color:#0f172a}.tech-dot.ts{background-color:#3178c6}.tech-dot.ws{background-color:#ff5a00}.scroll-down-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;animation:2s infinite bounce;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.scroll-down-btn:hover{color:var(--accent-primary)}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%)}40%{transform:translate(-50%,-10px)}60%{transform:translate(-50%,-5px)}}.about-grid{grid-template-columns:1.2fr .8fr;align-items:start;gap:4rem;display:grid}.about-text-content h3{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:600;line-height:1.35}.about-text-content p{color:var(--text-secondary);margin-bottom:1.25rem}.about-details-grid{border-top:1px dashed var(--border-color);border-bottom:1px dashed var(--border-color);grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:1.5rem;margin-bottom:1.5rem;padding:1.25rem 0;display:grid}.about-detail-item{flex-direction:column;gap:.15rem;display:flex}.about-detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.about-detail-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.about-detail-value a{color:var(--text-primary);transition:color var(--transition-fast)}.about-detail-value a:hover{color:var(--accent-primary)}@media (width<=600px){.about-details-grid{grid-template-columns:1fr;gap:1rem}}.metrics-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.5rem;display:grid}.metric-card{background-color:var(--bg-alt);border:1px solid var(--border-color);text-align:center;transition:all var(--transition-normal);border-radius:12px;padding:1.25rem}.metric-card:hover{border-color:var(--accent-primary);transform:translateY(-5px)}.metric-num{font-family:var(--font-heading);color:var(--accent-primary);margin-bottom:.25rem;font-size:2rem;font-weight:800;display:block}.metric-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.about-photo-wrapper{width:100%;max-width:280px;margin-bottom:2rem;margin-left:auto;margin-right:auto;position:relative}.about-photo-frame{aspect-ratio:3/4;box-shadow:var(--card-shadow);background:linear-gradient(135deg, var(--border-color), #06b6d426);z-index:1;transition:transform var(--transition-normal);border-radius:20px;padding:1px;position:relative;overflow:hidden}.about-photo{object-fit:cover;width:100%;height:100%;transition:filter var(--transition-normal), transform var(--transition-normal);filter:grayscale(10%)contrast(102%);border-radius:19px}.about-photo-frame:after{content:"";border:2px solid var(--accent-primary);z-index:-1;transition:transform var(--transition-normal), border-color var(--transition-normal);border-radius:20px;position:absolute;inset:12px -12px -12px 12px}.about-photo-wrapper:hover .about-photo-frame{transform:translate(-6px,-6px)}.about-photo-wrapper:hover .about-photo-frame:after{border-color:var(--accent-secondary);transform:translate(10px,10px)}.about-photo-wrapper:hover .about-photo{filter:grayscale(0%)contrast();transform:scale(1.04)}.info-card{background:var(--bg-card);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(8px);box-shadow:var(--card-shadow);border-radius:16px;padding:2rem}.info-card h4{font-family:var(--font-heading);border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.2rem;font-weight:700}.info-list{list-style:none}.info-list li{border-bottom:1px dashed var(--border-color);justify-content:space-between;padding:.75rem 0;font-size:.9rem;display:flex}.info-list li:last-child{border-bottom:none}.info-label{color:var(--text-muted);font-weight:600}.info-value{color:var(--text-primary);text-align:right}.skills-filter-container{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:2rem;display:flex}.filter-btn{background-color:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-family:var(--font-heading);transition:all var(--transition-normal);border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600}.filter-btn:hover,.filter-btn.active{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:translateY(-2px)}.skills-grid-wrapper{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem;display:grid}.skill-item{background:var(--bg-card);border:1px solid var(--border-color);transition:all var(--transition-normal);border-radius:12px;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;display:flex;position:relative;overflow:hidden}.skill-item.hidden{opacity:0;pointer-events:none;transform:translateY(10px)}.skill-item:hover{border-color:var(--accent-secondary);box-shadow:0 4px 15px -3px var(--accent-glow);transform:translateY(-3px)}.skill-card-body{align-items:center;gap:.6rem;width:100%;display:flex}.skill-category-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.skill-dot-frontend{background-color:var(--accent-primary);box-shadow:0 0 8px var(--accent-glow)}.skill-dot-backend{background-color:#10b981;box-shadow:0 0 8px #10b98180}.skill-dot-state{background-color:#8b5cf6;box-shadow:0 0 8px #8b5cf680}.skill-dot-database{background-color:#f59e0b;box-shadow:0 0 8px #f59e0b80}.skill-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.95rem;font-weight:600}.skill-category-name{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem;font-weight:700}.timeline{max-width:1000px;margin:0 auto;padding:2rem 0;position:relative}.timeline:after{content:"";background-color:var(--border-color);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{width:50%;padding:1rem 0;position:relative}.timeline-item:nth-child(odd){padding-right:3rem;left:0}.timeline-item:nth-child(2n){padding-left:3rem;left:50%}.timeline-badge{background-color:var(--bg-base);border:3px solid var(--accent-primary);z-index:2;width:16px;height:16px;transition:background-color var(--transition-normal);border-radius:50%;position:absolute;top:2rem}.timeline-item:nth-child(odd) .timeline-badge{right:-8px}.timeline-item:nth-child(2n) .timeline-badge{left:-8px}.timeline-card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:all var(--transition-normal);border-radius:16px;padding:2rem;position:relative}.timeline-card:hover{border-color:var(--accent-primary);transform:translateY(-5px)}.timeline-card:hover+.timeline-badge{background-color:var(--accent-primary)}.timeline-date{font-family:var(--font-heading);color:var(--accent-primary);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:inline-block}.timeline-role{font-family:var(--font-heading);margin-bottom:.25rem;font-size:1.4rem;font-weight:700}.timeline-company{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.95rem;font-weight:500}.timeline-company .location{color:var(--text-muted);font-size:.85rem}.timeline-project-info{color:var(--accent-secondary);background-color:var(--border-color);border-radius:6px;width:fit-content;margin-bottom:.75rem;padding:.35rem .75rem;font-size:.85rem;font-weight:600}.timeline-body ul{list-style:none}.timeline-body li{color:var(--text-secondary);margin-bottom:.75rem;padding-left:1.25rem;font-size:.9rem;position:relative}.timeline-body li:before{content:"▹";color:var(--accent-primary);font-weight:700;position:absolute;left:0}.timeline-body li:last-child{margin-bottom:0}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:all var(--transition-normal);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.project-card:hover{border-color:var(--accent-primary);box-shadow:0 20px 40px -20px var(--accent-glow);transform:translateY(-8px)}.project-content{flex-direction:column;height:100%;padding:2.25rem;display:flex}.project-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.project-tags .tag{font-family:var(--font-heading);color:var(--accent-secondary);background-color:var(--border-color);border-radius:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.project-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.project-description{color:var(--text-secondary);flex-grow:1;margin-bottom:1.5rem;font-size:.9rem}.project-bullets{border-top:1px solid var(--border-color);padding-top:1.25rem;list-style:none}.project-bullets li{color:var(--text-muted);margin-bottom:.5rem;padding-left:1.25rem;font-size:.85rem;position:relative}.project-bullets li:before{content:"✓";color:var(--accent-secondary);font-weight:700;position:absolute;left:0}.project-bullets li:last-child{margin-bottom:0}.contact-grid{grid-template-columns:.9fr 1.1fr;align-items:start;gap:4rem;display:grid}.contact-info h3{font-family:var(--font-heading);margin-bottom:1.25rem;font-size:1.75rem;font-weight:700}.contact-info p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.05rem}.contact-details-list{flex-direction:column;gap:1.25rem;display:flex}.contact-detail-item{align-items:center;gap:1.25rem;display:flex}.icon-box{background-color:var(--bg-alt);border:1px solid var(--border-color);width:3rem;height:3rem;color:var(--accent-primary);transition:all var(--transition-normal);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-detail-item:hover .icon-box{border-color:var(--accent-primary);color:var(--bg-base);background-color:var(--accent-primary);box-shadow:0 4px 12px var(--accent-glow)}.detail-text{flex-direction:column;display:flex}.detail-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.detail-value{font-family:var(--font-heading);color:var(--text-primary);font-size:1.05rem;font-weight:600;text-decoration:none}.contact-form-wrapper{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:20px;padding:2rem}.contact-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{position:relative}.form-group input,.form-group textarea{background-color:var(--bg-alt);border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-normal);border-radius:8px;outline:none;padding:.85rem 1rem;font-size:.95rem}.form-group textarea{resize:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-primary);background-color:var(--bg-base);box-shadow:0 0 0 3px var(--accent-glow)}.form-group label{color:var(--text-muted);pointer-events:none;transition:all var(--transition-fast);font-size:.95rem;position:absolute;top:.85rem;left:1rem}.form-group input:focus~label,.form-group input:not(:placeholder-shown)~label,.form-group textarea:focus~label,.form-group textarea:not(:placeholder-shown)~label{color:var(--accent-primary);background-color:var(--bg-base);border-radius:4px;padding:0 .4rem;font-size:.75rem;font-weight:600;top:-.6rem;left:.75rem}[data-theme=light] .form-group input:focus~label,[data-theme=light] .form-group input:not(:placeholder-shown)~label,[data-theme=light] .form-group textarea:focus~label,[data-theme=light] .form-group textarea:not(:placeholder-shown)~label{background-color:#fff}.btn-submit{width:100%;padding:.9rem 1.8rem}.form-feedback{text-align:center;margin-top:.5rem;font-size:.9rem;font-weight:500}.form-feedback.success{color:#10b981}.form-feedback.error{color:#ef4444}.footer{border-top:1px solid var(--border-color);background-color:var(--bg-alt);transition:background-color var(--transition-normal);padding:4rem 0 2rem}.footer-container{grid-template-columns:1.5fr 1fr;gap:3rem;display:grid}.footer-brand .logo{margin-bottom:1rem;display:inline-block}.footer-brand p{color:var(--text-muted);max-width:320px;font-size:.9rem}.footer-links ul{grid-template-columns:repeat(2,1fr);gap:1rem;list-style:none;display:grid}.footer-links a{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.9rem;text-decoration:none}.footer-links a:hover{color:var(--accent-primary)}.footer-bottom{border-top:1px solid var(--border-color);flex-wrap:wrap;grid-column:1/-1;justify-content:space-between;align-items:center;gap:1.5rem;padding-top:2rem;display:flex}.footer-bottom p{color:var(--text-muted);font-size:.85rem}.footer-socials{gap:1.25rem;display:flex}.footer-socials a{color:var(--text-muted);transition:all var(--transition-fast)}.footer-socials a:hover{color:var(--accent-primary);transform:translateY(-2px)}.scroll-top-btn{z-index:99;background-color:var(--accent-primary);color:#fff;cursor:pointer;opacity:0;visibility:hidden;width:2.5rem;height:2.5rem;transition:all var(--transition-normal);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 10px #0003}.scroll-top-btn.show{opacity:1;visibility:visible}.scroll-top-btn:hover{background-color:var(--accent-secondary);transform:translateY(-3px)}.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity var(--transition-slow), transform var(--transition-slow)}.reveal{transform:translateY(30px)}.reveal-left{transform:translate(-40px)}.reveal-right{transform:translate(40px)}.reveal.active,.reveal-left.active,.reveal-right.active{opacity:1;transform:translate(0)}@media (width<=1024px){.hero-title{font-size:3rem}.hero-content{grid-template-columns:1fr;gap:3rem}.hero-graphics-block{width:100%;max-width:500px;margin:0 auto}.about-grid{grid-template-columns:1fr;gap:3rem}.about-info-panel{width:100%;max-width:500px;margin:0 auto}.contact-grid{grid-template-columns:1fr;gap:3rem}.contact-info{text-align:center}.contact-details-list{align-items:center;max-width:500px;margin:0 auto}.contact-form-wrapper{width:100%;max-width:600px;margin:0 auto}}@media (width<=768px){.section-padding{padding:3rem 0}.section-title-wrapper{margin-bottom:1.75rem}.menu-toggle{display:flex}.nav-menu{background-color:var(--bg-alt);-webkit-backdrop-filter:blur(12px);z-index:99;width:100%;height:calc(100vh - 4.5rem);transition:left var(--transition-normal);border-top:1px solid var(--border-color);justify-content:center;align-items:center;display:flex;position:fixed;top:4.5rem;left:-100%}.nav-menu.open{left:0}.nav-menu ul{flex-direction:column;align-items:center;gap:2.5rem}.nav-link{font-size:1.25rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.metrics-grid{grid-template-columns:1fr;gap:1rem}.timeline:after{left:1.5rem}.timeline-item{width:100%;padding-left:3rem!important;padding-right:0!important;left:0!important}.timeline-badge{left:.8rem!important;right:auto!important}.footer-container{text-align:center;grid-template-columns:1fr;gap:2rem}.footer-brand p{margin:0 auto 1.5rem}.footer-links ul{justify-content:center}.footer-bottom{text-align:center;flex-direction:column}}@media (width<=480px){.hero-title{font-size:2rem}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn{width:100%}.contact-form-wrapper{padding:1.5rem}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);border:3px solid var(--bg-base);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg, var(--accent-secondary) 0%, var(--accent-primary) 100%)}.project-footer{align-items:center;margin-top:auto;padding-top:1.5rem;display:flex}.project-link{color:var(--accent-primary);transition:color var(--transition-fast);cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.project-link-icon{transition:transform var(--transition-fast)}.project-card:hover .project-link{color:var(--accent-secondary)}.project-card:hover .project-link-icon{transform:translate(4px)}.skill-item[data-category=frontend]:hover{border-color:var(--accent-primary);box-shadow:0 6px 20px -5px var(--accent-glow)}.skill-item[data-category=backend]:hover{border-color:#10b981;box-shadow:0 6px 20px -5px #10b9814d}.skill-item[data-category=state]:hover{border-color:#8b5cf6;box-shadow:0 6px 20px -5px #8b5cf64d}.skill-item[data-category=database]:hover{border-color:#f59e0b;box-shadow:0 6px 20px -5px #f59e0b4d}.scroll-progress-bar{background:linear-gradient(90deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);height:3px;box-shadow:0 0 10px var(--accent-glow);z-index:101;transition:width .1s ease-out;position:absolute;bottom:-1px;left:0}.specialty-text{transition:opacity .3s,transform .3s;display:inline-block}.specialty-text.fade-in{opacity:1;transform:translateY(0)}.specialty-text.fade-out{opacity:0;transform:translateY(-8px)}.contact-interactive-panel{flex-direction:column;gap:1.5rem;display:flex}.connect-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=576px){.connect-grid{grid-template-columns:1fr 1fr}}.connect-card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal);border-radius:16px;flex-direction:column;justify-content:space-between;padding:1.5rem;display:flex;position:relative;overflow:hidden}.connect-card:hover{border-color:var(--border-hover);box-shadow:0 10px 30px -10px var(--accent-glow);transform:translateY(-4px)}.connect-card h4{font-family:var(--font-heading);color:var(--text-primary);margin:.5rem 0 1rem;font-size:1.2rem;font-weight:700}.card-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--accent-secondary);background:var(--border-color);border-radius:9999px;padding:.15rem .5rem;font-size:.7rem;font-weight:700;position:absolute;top:1rem;right:1rem}.card-email-text{font-family:var(--font-heading);color:var(--text-secondary);word-break:break-all;margin-bottom:1.25rem;font-size:.925rem}.card-actions{gap:.5rem;margin-top:auto;display:flex}.btn-sm{border-radius:8px;padding:.5rem 1rem;font-size:.85rem}.text-success{color:#10b981!important}.availability-status{color:#10b981;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;display:flex}.status-dot-pulse{background-color:#10b981;border-radius:50%;width:8px;height:8px;position:relative}.status-dot-pulse:after{content:"";background-color:#10b981;border-radius:50%;width:100%;height:100%;animation:1.5s ease-in-out infinite status-pulse-anim;position:absolute;top:0;left:0}@keyframes status-pulse-anim{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}.schedule-slots{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.slot-row{border-bottom:1px dashed var(--border-color);justify-content:space-between;padding-bottom:.25rem;font-size:.85rem;display:flex}.slot-day{color:var(--text-muted);font-weight:500}.slot-hours{color:var(--text-secondary);font-weight:600}.btn-whatsapp{color:#10b981;background-color:#0000;border:1px solid #10b9814d}.btn-whatsapp:hover{background-color:#10b9811a;border-color:#10b981}.faq-section{margin-top:.5rem}.faq-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem;font-weight:700}.faq-accordion{flex-direction:column;gap:.75rem;display:flex}.faq-item{background:var(--bg-card);border:1px solid var(--border-color);transition:all var(--transition-normal);border-radius:12px;overflow:hidden}.faq-item:hover,.faq-item.open{border-color:var(--border-hover)}.faq-question-btn{cursor:pointer;width:100%;font-family:var(--font-heading);color:var(--text-primary);text-align:left;transition:color var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:.95rem;font-weight:600;display:flex}.faq-question-btn:hover{color:var(--accent-primary)}.faq-chevron{transition:transform var(--transition-normal);color:var(--text-muted)}.faq-item.open .faq-chevron{color:var(--accent-primary);transform:rotate(180deg)}.faq-answer-wrapper{max-height:0;transition:max-height var(--transition-normal) ease-out;overflow:hidden}.faq-item.open .faq-answer-wrapper{max-height:120px}.faq-answer{color:var(--text-secondary);padding:0 1.25rem 1rem;font-size:.875rem;line-height:1.5}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background-color:#020617bf;justify-content:center;align-items:center;width:100vw;height:100vh;padding:1.5rem;animation:.3s ease-out forwards modal-fade-in;display:flex;position:fixed;top:0;left:0}.modal-container{background:var(--bg-alt);border:1px solid var(--border-color);border-radius:24px;flex-direction:column;width:100%;max-width:620px;max-height:85vh;padding:2rem;animation:.35s cubic-bezier(.34,1.56,.64,1) forwards modal-slide-up;display:flex;position:relative;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080}[data-theme=light] .modal-container{background:#fff}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-close-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);border-radius:50%;position:absolute;top:1.25rem;right:1.25rem}.modal-close-btn:hover{color:var(--text-primary);border-color:var(--accent-primary);transform:rotate(90deg)}.modal-header{margin-bottom:1.25rem;padding-right:2rem}.modal-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-primary);margin-bottom:.4rem;font-size:.72rem;font-weight:700;display:inline-block}.modal-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:.5rem;font-size:1.6rem;font-weight:800}.modal-tags{flex-wrap:wrap;gap:.5rem;display:flex}.modal-body{flex-direction:column;gap:1.25rem;display:flex}.modal-section h4{font-family:var(--font-heading);color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:1rem;font-weight:700;display:flex}.modal-section p{color:var(--text-secondary);font-size:.9rem;line-height:1.55}.section-icon{font-size:1.05rem}.modal-details-grid{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;grid-template-columns:1fr 1fr;gap:.75rem;padding:.85rem;display:grid}.modal-detail-item{flex-direction:column;gap:.15rem;display:flex}.modal-detail-item .detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.modal-detail-item .detail-value{color:var(--text-secondary);font-size:.875rem;font-weight:600}.challenge-section,.solution-section,.outcome-section{border-left:4px solid;border-radius:12px;padding:.85rem 1rem}.challenge-section{background:#ef44440f;border-left-color:#ef4444}.solution-section{border-left-color:var(--accent-primary);background:#6366f10f}.outcome-section{background:#10b9810f;border-left-color:#10b981}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1rem;display:flex}
