:root{--bg-primary: #f6f7f9;--bg-secondary: #eef0f4;--bg-card: #ffffff;--bg-card-hover: #fefefe;--text-primary: #1a1d24;--text-secondary: #4a5160;--text-muted: #6b7280;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: rgba(37, 99, 235, .1);--accent-glow: rgba(37, 99, 235, .2);--border: #e5e7ec;--border-soft: #ebeef2;--shadow: rgba(26, 29, 36, .06);--shadow-mid: rgba(26, 29, 36, .08);--shadow-strong: rgba(26, 29, 36, .12);--shadow-card: 0 1px 3px var(--shadow), 0 4px 12px var(--shadow-mid);--shadow-card-hover: 0 4px 12px var(--shadow-mid), 0 12px 28px var(--shadow-strong);--navbar-bg: rgba(255, 255, 255, .72);--navbar-border: rgba(255, 255, 255, .5);--navbar-glass-edge: rgba(255, 255, 255, .4);--footer-bg: #eef0f4;--success: #059669;--error: #dc2626;--whatsapp: #25d366;--pattern-opacity: .5;--dot-color: rgba(26, 29, 36, .055)}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--accent: #38bdf8;--accent-hover: #7dd3fc;--accent-soft: rgba(56, 189, 248, .15);--accent-glow: rgba(56, 189, 248, .2);--border: #334155;--border-soft: #475569;--shadow: rgba(0, 0, 0, .2);--shadow-mid: rgba(0, 0, 0, .25);--shadow-strong: rgba(0, 0, 0, .35);--shadow-card: 0 1px 3px var(--shadow), 0 4px 12px var(--shadow);--shadow-card-hover: 0 8px 24px var(--shadow-mid), 0 16px 40px var(--shadow-strong);--navbar-bg: rgba(15, 23, 42, .75);--navbar-border: rgba(255, 255, 255, .06);--navbar-glass-edge: rgba(255, 255, 255, .08);--footer-bg: #1e293b;--bg-card-hover: #253047;--pattern-opacity: 0;--dot-color: transparent}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skip-link{position:absolute;left:-9999px;top:0;z-index:9999;padding:.75rem 1.25rem;background:var(--accent);color:#fff;font-weight:600;text-decoration:none;border-radius:0 0 8px;transition:left .2s ease}.skip-link:focus{left:0;outline:none;box-shadow:0 4px 12px var(--accent-glow)}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);padding:.875rem 1.5rem;border-radius:12px;font-weight:500;font-size:.95rem;box-shadow:0 8px 24px var(--shadow-strong);z-index:9998;animation:toastIn .3s ease}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--error);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.app-loading{min-height:100vh;background:var(--bg-primary)}html{scroll-behavior:smooth}body{font-family:Figtree,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.65;transition:background-color .3s ease,color .3s ease;overflow-x:hidden;background-image:radial-gradient(circle at 1px 1px,var(--dot-color, var(--border-soft)) 1px,transparent 0);background-size:32px 32px;background-position:0 0;background-attachment:fixed}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.7) 0%,transparent 35%,transparent 65%,rgba(246,247,249,.6) 100%);pointer-events:none;z-index:0;opacity:calc(var(--pattern-opacity) * .85)}[data-theme=dark] body{background-image:none}[data-theme=dark] body:before{background:linear-gradient(180deg,rgba(15,23,42,.3) 0%,transparent 50%,rgba(30,41,59,.2) 100%);opacity:.15}.container{width:100%;max-width:1320px;margin:0 auto;padding:0 1.5rem}main{position:relative;z-index:1}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--navbar-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--navbar-border);box-shadow:0 1px 0 var(--navbar-glass-edge),inset 0 1px 0 var(--navbar-glass-edge),0 4px 30px var(--shadow);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.navbar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,var(--navbar-glass-edge) 0%,transparent 50%,rgba(0,0,0,.02) 100%);pointer-events:none;border-radius:inherit}.navbar-container{max-width:1320px;margin:0 auto;padding:.75rem 1.5rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;column-gap:3rem}.navbar-logo{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.35rem;color:var(--accent);text-decoration:none;letter-spacing:.02em;display:inline-flex;align-items:center;gap:.4rem;position:relative;transition:transform .25s ease,color .25s ease,text-shadow .25s ease;text-shadow:0 0 6px var(--accent-soft);animation:navBrandPulse 4.6s ease-in-out infinite}@keyframes navBrandPulse{0%,to{text-shadow:0 0 8px var(--accent-soft)}50%{text-shadow:0 0 16px color-mix(in srgb,var(--accent) 40%,transparent)}}.navbar-logo:after{content:"";position:absolute;left:-15%;right:-15%;bottom:-.15rem;height:2px;border-radius:999px;background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);opacity:.4;transform:translateY(0);transition:opacity .35s ease,transform .35s ease}.navbar-logo:hover{transform:scale(1.03);color:var(--accent-hover);text-shadow:0 0 18px var(--accent-soft)}.navbar-logo:hover:after{opacity:1}.logo-icon{display:flex;opacity:.9}.logo-icon svg{transition:transform .35s ease}.navbar-logo:hover .logo-icon svg{transform:rotate(-12deg)}.nav-link{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .6rem;margin:0 -.35rem;border-radius:10px;transition:background .3s ease,color .2s ease}.nav-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:10px;background:var(--accent-soft);opacity:0;transform:scale(.9);transition:opacity .3s ease,transform .3s ease;z-index:-1}.nav-link:hover:before,.nav-link.active:before{opacity:1;transform:scale(1)}.nav-icon{flex-shrink:0;opacity:.85;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .25s ease}.nav-link:hover .nav-icon{opacity:1;animation:navIconBounce .5s ease}.nav-link.active .nav-icon{opacity:1;animation:navIconPulse 2s ease-in-out infinite}@keyframes navIconBounce{0%{transform:translateY(0) scale(1)}40%{transform:translateY(-5px) scale(1.15)}70%{transform:translateY(2px) scale(1.05)}to{transform:translateY(-1px) scale(1)}}@keyframes navIconPulse{0%,to{opacity:1;filter:drop-shadow(0 0 0 transparent)}50%{opacity:.95;filter:drop-shadow(0 0 6px var(--accent-soft))}}.navbar-menu{display:flex;gap:2.75rem;align-items:center;justify-content:center}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s ease}.nav-link{position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:1px;transition:width .3s ease;z-index:0}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-link:hover,.nav-link.active{color:var(--accent)}.navbar-actions{display:flex;align-items:center;gap:1.5rem;justify-self:flex-end}.nav-mobile-controls{display:none}.btn-icon{background:transparent;border:1px solid var(--border);color:var(--text-primary);padding:.4rem .65rem;border-radius:8px;cursor:pointer;font-size:.85rem;transition:background .2s ease,border-color .2s ease}.btn-theme{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center}.btn-theme .icon-moon{display:none}.btn-theme .icon-sun svg,.btn-theme .icon-moon svg{transition:transform .4s ease}.btn-theme:hover .icon-sun svg{transform:rotate(90deg)}.btn-theme:hover .icon-moon svg{transform:rotate(-15deg)}[data-theme=dark] .btn-theme .icon-sun{display:none}[data-theme=dark] .btn-theme .icon-moon{display:flex;align-items:center;justify-content:center}.btn-mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}.btn-mobile-toggle span{width:22px;height:2px;background:var(--text-primary);border-radius:1px;transition:transform .3s ease,opacity .3s ease}.navbar.open .btn-mobile-toggle span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.navbar.open .btn-mobile-toggle span:nth-child(2){opacity:0}.navbar.open .btn-mobile-toggle span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.section{padding:4rem 0;min-height:50vh;position:relative;animation:sectionFadeIn .6s ease both}.section:before{content:"";position:absolute;left:50%;top:0;transform:translate(-50%);width:80%;max-width:200px;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);opacity:.8}.section:first-of-type:before,.section.cta:before{display:none}@keyframes sectionFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.section-title{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2.1rem,4.5vw,2.65rem);font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.section-title-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:var(--accent-soft);color:var(--accent);transition:transform .35s ease,box-shadow .35s ease,background .35s ease;animation:iconReveal .6s cubic-bezier(.22,1,.36,1) backwards}.section-title:hover .section-title-icon{transform:scale(1.08);box-shadow:0 8px 24px var(--accent-glow, var(--accent-soft));background:var(--accent-soft)}.section-title:after{content:"";display:block;width:60px;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));margin:0;border-radius:2px;animation:lineGrow .8s cubic-bezier(.22,1,.36,1) .15s backwards}.section-tagline{max-width:36rem;margin:-.25rem auto 2rem;text-align:center;font-size:clamp(1.06rem,2.15vw,1.2rem);line-height:1.6;color:var(--text-secondary);font-weight:500;letter-spacing:.01em}.about-header .section-title{margin-bottom:.65rem}@keyframes iconReveal{0%{opacity:0;transform:scale(.8) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes lineGrow{0%{width:0;opacity:0}to{width:60px;opacity:1}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal.visible .skill-group,.reveal.visible .project-card{animation:cardReveal .6s cubic-bezier(.22,1,.36,1) backwards}.reveal.visible .skill-group:nth-child(1),.reveal.visible .project-card:nth-child(1){animation-delay:.05s}.reveal.visible .skill-group:nth-child(2),.reveal.visible .project-card:nth-child(2){animation-delay:.15s}.reveal.visible .skill-group:nth-child(3),.reveal.visible .project-card:nth-child(3){animation-delay:.25s}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero{padding-top:6rem;padding-bottom:5rem;min-height:90vh;display:flex;align-items:center;position:relative;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 70% 40%,var(--accent-soft) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 20% 80%,var(--accent-soft) 0%,transparent 50%);pointer-events:none;opacity:.9}.hero-content{position:relative;z-index:1}.hero-anim{opacity:0;transform:translateY(20px);animation:heroFadeUp .7s cubic-bezier(.22,1,.36,1) forwards}.hero-anim-2{animation-delay:.08s}.hero-anim-3{animation-delay:.16s}.hero-anim-4{animation-delay:.24s}.hero-anim-5{animation-delay:.32s}.hero-anim-6{animation-delay:.4s}.hero-anim-7{animation-delay:.48s}@keyframes heroFadeUp{to{opacity:1;transform:translateY(0)}}.hero-content{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}.hero-greeting{color:var(--accent);font-weight:600;font-size:1rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.hero-name{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2.35rem,5.5vw,3.45rem);font-weight:700;color:#1d4ed8;text-shadow:0 6px 22px rgba(29,78,216,.28);line-height:1.2;margin-bottom:.5rem}[data-theme=dark] .hero-name{color:#7dd3fc;text-shadow:0 8px 26px rgba(56,189,248,.32)}.hero-title{font-size:1.42rem;color:var(--text-secondary);margin-bottom:1rem}.hero-intro{color:var(--text-secondary);max-width:520px;margin-bottom:1.75rem;font-size:1.13rem;line-height:1.75}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}.hero-quick-links{margin-top:1.05rem;display:flex;flex-wrap:wrap;gap:.75rem}.hero-quick-link{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border-radius:12px;text-decoration:none;background:color-mix(in srgb,var(--accent-soft) 72%,transparent);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);color:var(--accent);transition:transform .25s ease,border-color .25s ease,color .25s ease,background .25s ease}.hero-quick-link:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 52%,transparent);color:#fff;background:color-mix(in srgb,var(--accent-soft) 88%,transparent);background:var(--accent)}.hero-visual{display:flex;justify-content:center}.hero-avatar{width:360px;height:360px;border-radius:999px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 20px 40px var(--shadow-strong);position:relative;animation:avatarFloat 4s ease-in-out infinite}.avatar-glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:999px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);filter:blur(20px);opacity:.35;z-index:-1;animation:glowPulse 3s ease-in-out infinite}@keyframes avatarFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glowPulse{0%,to{opacity:.25;transform:scale(1)}50%{opacity:.4;transform:scale(1.05)}}.avatar-initials{font-family:Plus Jakarta Sans,sans-serif;font-size:3rem;font-weight:700;color:#fff;letter-spacing:.02em;position:relative;z-index:1;text-shadow:0 2px 12px rgba(0,0,0,.15)}.hero-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;position:relative;z-index:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:10px;text-decoration:none;cursor:pointer;border:none;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s ease,background .25s ease;font-family:inherit}.btn .btn-arrow,.btn svg{flex-shrink:0;transition:transform .25s ease}.btn:hover{transform:translateY(-3px)}.btn:hover .btn-arrow,.btn-primary:hover svg,.cta-btn:hover svg{transform:translate(4px)}.btn-secondary:hover svg{transform:translate(2px)}.btn-primary{background:var(--accent);color:#fff;position:relative;overflow:hidden}.btn-primary:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover:after{left:100%}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 8px 24px var(--accent-glow, var(--accent-soft))}.btn-secondary{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-secondary:hover{background:var(--accent-soft)}.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-outline:hover{background:var(--accent-soft)}.btn-small{padding:.5rem 1rem;font-size:.9rem}.btn-whatsapp{background:var(--whatsapp);color:#fff}.btn-whatsapp:hover{filter:brightness(1.1);box-shadow:0 6px 16px #25d36659}.about-header{max-width:1000px;margin:0 auto 1.25rem;display:flex;justify-content:center}.about-header-title{margin:0;display:inline-flex;align-items:center;gap:.75rem;justify-content:center}.about-header-title-right{justify-self:end}.about-content{max-width:100%;margin:0 auto;display:flex;flex-direction:column;gap:2.5rem}.about-main{max-width:100%;margin:0;text-align:left;display:flex;flex-direction:column;gap:1.25rem}.about-text{color:var(--text-secondary);margin-bottom:1rem;font-size:1.14rem;line-height:1.85}.btn-cv{margin-top:1.25rem;padding:.55rem 1.25rem;font-size:.95rem}.btn-cv .btn-icon-svg{flex-shrink:0}.about-education{margin-top:.5rem}.about-education-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:600;margin-bottom:.35rem;text-align:left}.about-education-subtitle{color:var(--text-secondary);margin-bottom:1.25rem}.about-education-grid{display:grid;grid-template-columns:1fr;gap:.95rem}.about-education-card{background:var(--bg-card);border-radius:16px;padding:1.2rem;border:1px solid var(--border);box-shadow:var(--shadow-card),0 0 0 1px #ffffff05;position:relative;overflow:hidden;transition:box-shadow .35s ease,transform .35s cubic-bezier(.22,1,.36,1),border-color .3s ease,background .3s ease}.about-education-card:before{content:"";position:absolute;top:0;left:-110%;width:60%;height:100%;background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);transition:left .6s ease}.about-education-card:hover{border-color:var(--accent);box-shadow:var(--shadow-card-hover),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 40px -10px var(--accent-soft);transform:translateY(-4px);background:var(--bg-card-hover, var(--bg-card))}.about-education-card:hover:before{left:120%}.about-education-card h4{margin:0 0 .35rem;font-weight:600;color:var(--text-primary);font-size:1.08rem}.about-education-card ul{margin:.5rem 0 0;padding-left:1.1rem;color:var(--text-secondary);font-size:1.02rem;line-height:1.65}.about-education-card li+li{margin-top:.25rem}.about-education-main{font-weight:600;color:var(--text-primary)}.about-education-secondary{color:var(--text-secondary)}.about-education-period{margin-top:.35rem;font-size:.98rem;color:var(--text-muted)}.about-education-icon{width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);margin-bottom:.5rem}.about-location-card{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem}.about-location-card .about-education-icon{margin-bottom:.25rem}@media (min-width: 900px){.about-content{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:start}.about-main{max-width:none}.about-education{margin-top:0}.about-education-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.about-education-grid .about-education-card:nth-child(1){grid-column:1 / -1}}@media (max-width: 899px){.about-header{grid-template-columns:1fr;gap:.5rem}.about-header-title-right{justify-self:start}.about-header-title{font-size:1.8rem}.about-main{text-align:center;margin:0 auto}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;max-width:100%;margin:0}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-card),0 0 0 1px #ffffff08,inset 0 1px #ffffff0a;transition:box-shadow .35s ease,transform .35s cubic-bezier(.22,1,.36,1),border-color .3s ease,background .3s ease;animation:skillCardDrift 6s ease-in-out infinite}[data-theme=dark] .skill-group{box-shadow:var(--shadow-card),0 0 0 1px #ffffff0a,0 0 20px -5px var(--accent-soft)}.skill-group:hover{border-color:var(--accent);box-shadow:var(--shadow-card-hover),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f;transform:translateY(-4px);background:var(--bg-card-hover, var(--bg-card))}[data-theme=dark] .skill-group:hover{box-shadow:var(--shadow-card-hover),0 0 0 1px var(--accent),0 0 28px -4px var(--accent),0 0 56px -8px var(--accent-soft)}.skill-group-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-soft);display:inline-flex;align-items:center;gap:.5rem}.skill-group-icon{flex-shrink:0;color:var(--accent);opacity:.9;transition:transform .25s ease}.skill-group:hover .skill-group-icon{transform:scale(1.1)}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.58rem 1rem;background:var(--accent-soft);color:var(--accent);border-radius:8px;font-size:.98rem;font-weight:600;transition:transform .25s ease,background .25s ease,color .25s ease}.skill-tag-icon{flex-shrink:0;opacity:.95;transition:transform .25s ease}.skill-group .skill-tag:hover{transform:scale(1.06);background:var(--accent);color:#fff}.skill-tag{border:1px solid rgba(255,255,255,.06)}.skill-tag-icon{padding:.2rem;border-radius:6px;background:color-mix(in srgb,var(--accent-soft) 70%,transparent)}@keyframes skillCardDrift{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.skill-group .skill-tag:hover .skill-tag-icon{transform:scale(1.1)}.projects{background:var(--bg-primary)}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:1.75rem}.project-card.no-image .project-card-inner{display:flex;flex-direction:column}.project-top-icon{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;margin-bottom:.9rem;background:color-mix(in srgb,var(--accent-soft) 85%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent-soft) 100%,var(--border))}.project-card.has-image{grid-column:auto}.project-card.no-image{grid-column:1 / -1;max-width:760px;width:100%;justify-self:center}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.75rem;position:relative;overflow:hidden;box-shadow:var(--shadow-card),0 0 0 1px #ffffff08,inset 0 1px #ffffff0a;transition:box-shadow .4s ease,transform .4s cubic-bezier(.22,1,.36,1),border-color .3s ease,background .3s ease}[data-theme=dark] .project-card{box-shadow:var(--shadow-card),0 0 0 1px #ffffff0a,0 0 20px -5px var(--accent-soft)}.project-card:before{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);transition:left .6s ease}.project-card:hover{border-color:var(--accent);box-shadow:var(--shadow-card-hover),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f;transform:translateY(-6px);background:var(--bg-card-hover, var(--bg-card))}[data-theme=dark] .project-card:hover{box-shadow:var(--shadow-card-hover),0 0 0 1px var(--accent),0 0 28px -4px var(--accent),0 0 56px -8px var(--accent-soft)}.project-card:hover:before{left:100%}.project-card-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;background:var(--accent-soft);color:var(--accent);margin-bottom:1rem;transition:transform .35s ease,box-shadow .35s ease,background .35s ease}.project-card:hover .project-card-icon{transform:scale(1.08);box-shadow:0 8px 20px var(--accent-glow, var(--accent-soft));background:var(--accent-soft)}.project-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.project-desc,.project-problem{color:var(--text-secondary);font-size:.95rem;margin-bottom:.5rem}.project-problem{font-size:.85rem;color:var(--text-muted);font-style:italic}.project-tools{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.project-tool{display:inline-flex;align-items:center;gap:.35rem;padding:.32rem .65rem;background:var(--accent-soft);color:var(--accent);border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 24%,transparent);font-size:.8rem;font-weight:600;transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease}.project-tool-icon{flex-shrink:0}.project-card .project-tool:hover{transform:translateY(-1px);background:var(--accent);border-color:var(--accent);color:#fff}.project-link{margin-top:.5rem}.project-link svg{transition:transform .25s ease}.project-link:hover svg{transform:translate(3px,-3px)}.project-preview-link{display:block;margin:-.15rem 0 1rem;border-radius:12px;overflow:hidden;border:1px solid var(--border);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.project-preview-link:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 10px 24px var(--shadow-mid)}.project-preview-img{width:100%;height:180px;object-fit:cover;display:block}.project-live-link{margin-top:1rem;display:inline-flex;align-items:center;gap:.4rem;justify-content:center;padding:.62rem 1rem;border-radius:11px;border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;text-decoration:none;font-weight:700;font-size:.9rem;box-shadow:0 8px 22px color-mix(in srgb,var(--accent) 32%,transparent);transition:transform .2s ease,filter .2s ease,box-shadow .2s ease}.project-live-link:hover{transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 10px 26px color-mix(in srgb,var(--accent) 42%,transparent)}.project-live-icon{flex-shrink:0}@media (max-width: 900px){.projects-grid{grid-template-columns:1fr}.project-card.has-image{max-width:100%}}.cta{position:relative;overflow:hidden;padding:4.5rem 0;background:linear-gradient(145deg,#1e3a8a,#1d4ed8 42%,#2563eb 72%,#0ea5e9);background-size:200% 200%;color:#fff;text-align:center;animation:ctaGradient 12s ease infinite;box-shadow:inset 0 1px #ffffff1f,0 8px 40px #1e40af47}@keyframes ctaGradient{0%,to{background-position:0% 40%}50%{background-position:100% 60%}}[data-theme=dark] .cta{background:linear-gradient(145deg,#0c4a6e,#0369a1 45%,#0284c7 85%,#22d3ee);box-shadow:inset 0 1px #ffffff0f,0 8px 40px #0284c740}.cta-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.cta-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.12;background-image:linear-gradient(rgba(255,255,255,.15) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.15) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,black 20%,transparent 75%);mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,black 20%,transparent 75%)}.cta-orb{position:absolute;border-radius:50%;filter:blur(42px);opacity:.55;animation:ctaOrbFloat 14s ease-in-out infinite}.cta-orb-a{width:280px;height:280px;background:#60a5fae6;top:-80px;left:-60px}.cta-orb-b{width:220px;height:220px;background:#22d3eebf;bottom:-40px;right:-30px;animation-delay:-4s}.cta-orb-c{width:160px;height:160px;background:#ffffff59;top:40%;left:55%;animation-delay:-7s}@keyframes ctaOrbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-15px) scale(1.05)}66%{transform:translate(-15px,10px) scale(.98)}}.cta-inner{position:relative;z-index:1}.cta-panel{max-width:720px;margin:0 auto;padding:2.25rem 2rem 2.5rem;border-radius:24px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 24px #0000001f,inset 0 1px #ffffff26;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}[data-theme=dark] .cta-panel{background:#0f172a59;border-color:#ffffff1f}.cta-section-tagline{font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffffb8;margin:0 0 1rem}.cta-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .9rem;margin:0 auto 1.25rem;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#fffffff2;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);border-radius:999px}.cta-badge-icon{flex-shrink:0;opacity:.95;animation:ctaIconPulse 2.5s ease-in-out infinite}.cta-title{color:#fff;margin:0 0 .25rem;font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(1.65rem,4vw,2.15rem);font-weight:700;line-height:1.25;text-shadow:0 2px 16px rgba(0,0,0,.12)}.cta-title:after{content:"";display:block;width:72px;height:1px;margin:1rem auto 0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.85),transparent);border-radius:2px;animation:lineGrow .8s cubic-bezier(.22,1,.36,1) .3s backwards}.cta-lead{color:#fffffff2;font-size:1.05rem;font-weight:600;margin:0 0 .75rem;line-height:1.45;text-shadow:0 1px 2px rgba(0,0,0,.12)}.cta-text{color:#ffffffe0;margin:0 0 1.75rem;font-size:.98rem;line-height:1.65;max-width:560px;margin-left:auto;margin-right:auto;text-shadow:0 1px 2px rgba(0,0,0,.08)}.cta .btn-primary{background:#fff;color:var(--accent);box-shadow:0 4px 20px #00000026}.cta .btn-primary:hover{background:#fffffff2;color:var(--accent-hover);transform:translateY(-2px)}@keyframes ctaIconPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.06)}}.contact-intro{max-width:32rem;margin:0 auto 1.5rem;text-align:center;padding:0 .5rem}.contact-tagline{margin-bottom:0;font-size:clamp(.9rem,1.9vw,1rem);line-height:1.55}.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:stretch;max-width:100%;margin:0;position:relative}.contact-wrapper:before{content:"";position:absolute;left:50%;top:.5rem;bottom:.5rem;width:1px;transform:translate(-50%);background:linear-gradient(180deg,transparent,var(--accent-soft),transparent);opacity:.75;pointer-events:none}.contact-panel{position:relative;z-index:1}.contact-form-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.contact-form-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2rem;position:relative;overflow:hidden;box-shadow:var(--shadow-card),0 0 0 1px #ffffff08,inset 0 1px #ffffff0a;transition:border-color .3s ease,box-shadow .3s ease;animation:contactInfoFloat 4s ease-in-out infinite}.contact-form-wrapper:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.02) 50%,transparent 60%);background-size:200% 200%;animation:contactShimmer 8s linear infinite;pointer-events:none;z-index:0}@keyframes contactShimmer{0%{transform:translate(-25%,-25%) rotate(0)}to{transform:translate(-25%,-25%) rotate(360deg)}}[data-theme=dark] .contact-form-wrapper{box-shadow:var(--shadow-card),0 0 0 1px #ffffff0a,0 0 20px -5px var(--accent-soft)}.contact-form-wrapper:hover{border-color:var(--accent);box-shadow:var(--shadow-card),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f}[data-theme=dark] .contact-form-wrapper:hover{box-shadow:var(--shadow-card),0 0 0 1px var(--accent),0 0 28px -4px var(--accent),0 0 56px -8px var(--accent-soft)}.contact-form-wrapper:focus-within{border-color:var(--accent);box-shadow:var(--shadow-card),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f;animation:contactFormGlow 3s ease-in-out infinite,contactInfoFloat 4s ease-in-out infinite}@keyframes contactFormGlow{0%,to{box-shadow:var(--shadow-card),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f}50%{box-shadow:var(--shadow-card),0 0 0 1px var(--accent-soft),0 0 32px -2px var(--accent),0 0 56px -8px var(--accent-soft),inset 0 1px #ffffff14}}[data-theme=dark] .contact-form-wrapper:focus-within{box-shadow:var(--shadow-card),0 0 0 1px var(--accent),0 0 28px -4px var(--accent),0 0 56px -8px var(--accent-soft)}.contact-form{display:flex;flex-direction:column;gap:1.25rem;position:relative;z-index:1}.form-group{display:flex;flex-direction:column;gap:.35rem;transition:transform .3s ease}.form-group:focus-within{transform:translate(4px)}.form-group label{font-weight:500;color:var(--text-primary);font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem}.label-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--accent);opacity:.9;transition:transform .2s ease}.form-group:focus-within .label-icon{transform:scale(1.1);opacity:1}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);color:var(--text-primary);font-family:inherit;font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease,transform .25s ease}.form-group input:hover,.form-group textarea:hover{border-color:var(--border-soft)}.form-group input,.form-group textarea{position:relative}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft),0 6px 20px var(--shadow),0 0 20px -5px var(--accent-soft);transform:scale(1.01)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-error{font-size:.8rem;color:var(--error);min-height:1.2em}.form-actions{display:flex;flex-wrap:wrap;gap:.75rem}.form-actions .btn{gap:.5rem}.form-actions .btn svg{flex-shrink:0}.form-feedback{margin-top:1rem;padding:.75rem;border-radius:10px;font-size:.9rem;animation:toastIn .24s ease}.form-feedback.success{background:#10b98126;color:var(--success)}.form-feedback.error{background:#ef44441a;color:var(--error)}.contact-info{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2rem;position:relative;overflow:hidden;box-shadow:var(--shadow-card),0 0 0 1px #ffffff08,inset 0 1px #ffffff0a;transition:border-color .3s ease,box-shadow .3s ease;animation:contactInfoFloat 4s ease-in-out infinite}@keyframes contactInfoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}[data-theme=dark] .contact-info{box-shadow:var(--shadow-card),0 0 0 1px #ffffff0a,0 0 20px -5px var(--accent-soft)}.contact-info:hover{border-color:var(--accent);box-shadow:var(--shadow-card),0 0 0 1px var(--accent-soft),0 0 24px -4px var(--accent),0 0 48px -12px var(--accent-soft),inset 0 1px #ffffff0f}[data-theme=dark] .contact-info:hover{box-shadow:var(--shadow-card),0 0 0 1px var(--accent),0 0 28px -4px var(--accent),0 0 56px -8px var(--accent-soft)}.contact-info-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.22rem;font-weight:700;margin-bottom:.45rem;color:var(--text-primary)}.contact-info-lead{margin:0 0 1rem;color:var(--text-secondary);font-size:.96rem;line-height:1.55}.contact-list{list-style:none;margin:0;padding:0}.contact-list li{display:flex;align-items:center;gap:.75rem;margin-bottom:.8rem;padding:.62rem .82rem;margin-left:-.75rem;margin-right:-.75rem;border-radius:12px;position:relative;transition:transform .3s ease,background .3s ease}.contact-list li:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;border-radius:12px;background:var(--accent-soft);transition:width .35s ease;z-index:-1}.contact-list li:hover{transform:translate(8px)}.contact-list li:hover:before{width:100%}.contact-icon{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);border-radius:12px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),background .3s ease,color .3s ease,box-shadow .3s ease}.contact-icon-brand{color:var(--text-primary)}.contact-list li:hover .contact-icon{transform:scale(1.15) rotate(5deg);background:var(--accent);color:#fff;box-shadow:0 4px 12px var(--accent-soft)}.contact-list li:hover .contact-icon-brand{color:#fff}.contact-info.visible .contact-list li:nth-child(1){animation:contactItemIn .5s ease backwards}.contact-info.visible .contact-list li:nth-child(2){animation:contactItemIn .5s ease .05s backwards}.contact-info.visible .contact-list li:nth-child(3){animation:contactItemIn .5s ease .1s backwards}.contact-info.visible .contact-list li:nth-child(4){animation:contactItemIn .5s ease .15s backwards}.contact-info.visible .contact-list li:nth-child(5){animation:contactItemIn .5s ease .2s backwards}@keyframes contactItemIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.contact-list a{color:var(--text-primary);text-decoration:none;transition:color .2s ease;display:inline-flex;align-items:center;gap:.45rem;font-weight:500}.contact-list a:hover{color:var(--accent)}.whatsapp-float{position:fixed;bottom:1.35rem;right:1.35rem;z-index:1000;width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px #25d36673,0 2px 8px #0000001f;transition:transform .22s ease,box-shadow .22s ease;text-decoration:none}.whatsapp-float:hover{transform:scale(1.07);box-shadow:0 6px 24px #25d3668c,0 2px 10px #00000024;color:#fff}.whatsapp-float:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (max-width: 480px){.whatsapp-float{width:52px;height:52px;bottom:1rem;right:1rem}.whatsapp-float svg{width:24px;height:24px}}.footer{position:relative;z-index:1;background:var(--bg-primary);border-top:1px solid var(--border);color:var(--text-primary)}.footer-shell{padding-top:2.2rem;padding-bottom:1.15rem}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:2.75rem;align-items:start}.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.footer-brand-title{margin:0 0 .55rem;font-family:Plus Jakarta Sans,sans-serif;font-size:1.35rem;font-weight:800;letter-spacing:.02em;color:transparent;background:linear-gradient(90deg,#e0f2fe,#7dd3fc 45%,#e0f2fe);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;text-shadow:0 10px 30px rgba(37,99,235,.24);animation:footerBrandGlow 3.8s ease-in-out infinite;position:relative;display:block}.footer-brand-subtitle{margin:0;color:var(--text-secondary);font-size:.96rem;animation:footerSubtitleLift 4.2s ease-in-out infinite;position:relative;display:block;width:fit-content}.footer-brand-subtitle:after{content:"";position:absolute;left:0;bottom:-.28rem;height:2px;width:100%;transform-origin:left center;transform:scaleX(.35);background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:footerLinePulse 3.2s ease-in-out infinite}@keyframes footerBrandGlow{0%,to{text-shadow:0 8px 22px rgba(37,99,235,.2);background-position:0% 50%;transform:translateY(0)}50%{text-shadow:0 14px 36px rgba(37,99,235,.42);background-position:100% 50%;transform:translateY(-2px)}}@keyframes footerSubtitleLift{0%,to{opacity:.92;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}@keyframes footerLinePulse{0%,to{transform:scaleX(.35);opacity:.55}50%{transform:scaleX(1);opacity:1}}.footer-col-title{margin:0 0 .75rem;color:var(--accent);font-size:1rem;font-weight:700}.footer-nav{display:flex;flex-direction:column;gap:.42rem}.footer-nav a{color:var(--text-secondary);text-decoration:none;font-size:.95rem;transition:color .2s ease,transform .2s ease}.footer-nav a:hover{color:var(--text-primary);transform:translate(2px)}.footer-contact-list{display:flex;flex-direction:column;gap:.5rem}.footer-contact-item{display:inline-flex;align-items:center;gap:.45rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.footer-contact-item:hover{color:var(--text-primary)}.footer-social-wrap{margin-top:1rem}.footer-social-title{margin:0 0 .55rem;color:var(--accent);font-size:.95rem;font-weight:700}.footer-social-handle{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .62rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);color:var(--text-secondary);text-decoration:none;transition:background .2s ease,border-color .2s ease,transform .2s ease}.footer-social-handle:hover{background:var(--accent-soft);border-color:color-mix(in srgb,var(--accent) 55%,transparent);color:var(--text-primary);transform:translateY(-1px)}.footer-bottom{margin-top:1.5rem;padding-top:.8rem;border-top:1px solid var(--border)}.footer-bottom-copy{margin:0;font-size:.86rem;color:var(--text-muted)}@media (max-width: 768px){.navbar-container{grid-template-columns:minmax(0,1fr) auto;column-gap:.35rem;padding:.65rem .45rem .65rem 1rem}.navbar-logo{min-width:0}.navbar-logo span{display:inline-block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-menu{position:fixed;top:56px;left:0;right:0;background:var(--navbar-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);flex-direction:column;padding:1.5rem;gap:.5rem;border-bottom:1px solid var(--navbar-border);box-shadow:0 8px 32px var(--shadow),inset 0 1px 0 var(--navbar-glass-edge);transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .3s ease,opacity .3s ease,visibility .3s ease}.navbar.open .navbar-menu{transform:translateY(0);opacity:1;visibility:visible}.navbar-menu{border-radius:0 0 18px 18px}.nav-link{width:100%;justify-content:flex-start;padding:.65rem .85rem;margin:0;border-radius:14px}.nav-link:after{display:none}.nav-link:before{border-radius:14px}.navbar-actions{gap:.25rem;justify-self:end}.btn-desktop-only{display:none}.nav-mobile-controls{display:grid}.btn-mobile-toggle{margin-left:0;padding:.5rem .35rem .5rem .5rem}.nav-mobile-controls{width:100%;margin-top:.75rem;padding-top:.85rem;border-top:1px solid var(--navbar-border);display:grid;grid-template-columns:1fr;gap:.65rem}.nav-mobile-theme,.nav-mobile-lang{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.75rem .9rem;border-radius:14px;border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);background:color-mix(in srgb,var(--accent-soft) 70%,transparent);color:var(--text-primary);font-weight:700;cursor:pointer;transition:transform .2s ease,background .2s ease,border-color .2s ease}.nav-mobile-theme:hover,.nav-mobile-lang:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent) 45%,transparent);background:color-mix(in srgb,var(--accent-soft) 92%,transparent)}.nav-mobile-theme-icon{color:var(--accent);display:inline-flex;align-items:center;justify-content:center}.nav-mobile-lang-divider{opacity:.6}.btn-mobile-toggle{display:flex}.project-live-link{width:100%;padding:.78rem 1rem;border-radius:12px;font-size:.95rem}.hero-content{grid-template-columns:1fr;text-align:center}.hero-greeting{display:inline-flex;align-items:center;justify-content:center;margin:0 auto .65rem;padding:.32rem .7rem;border-radius:999px;background:color-mix(in srgb,var(--accent-soft) 70%,transparent);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);color:var(--accent);font-size:.9rem;letter-spacing:.12em}.hero-intro{margin-left:auto;margin-right:auto}.hero-buttons,.hero-quick-links{justify-content:center}.hero-avatar{width:190px;height:190px}.avatar-initials{font-size:2.5rem}.contact-wrapper{grid-template-columns:1fr}.contact-wrapper:before{display:none}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.footer-grid{grid-template-columns:1fr;gap:1.5rem}.skills-grid{grid-template-columns:1fr}}@media (max-width: 480px){.section{padding:3rem 0}.hero{padding-top:5rem}.skills-grid{grid-template-columns:1fr}}
