:root{
  --navy:#040D1A;--blue:#0E4AFF;--sky:#00B4FF;--accent:#00FFCC;
  --glass:rgba(255,255,255,0.06);--glass-border:rgba(255,255,255,0.12);
  --white:#FFFFFF;--muted:rgba(255,255,255,0.5);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',sans-serif;background:var(--navy);color:#fff;overflow-x:hidden;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:0 5%;height:70px;background:rgba(4,13,26,0.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);}
.logo{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;letter-spacing:-1px;color:#fff;text-decoration:none;}
.logo span{color:var(--accent);}
.nav-links{display:flex;gap:0;list-style:none;align-items:center;}
.nav-item{position:relative;}
.nav-item>a{text-decoration:none;color:var(--muted);font-size:.85rem;font-weight:500;letter-spacing:.5px;transition:color .2s;padding:.5rem 1rem;display:flex;align-items:center;gap:.3rem;white-space:nowrap;}
.nav-item>a:hover{color:#fff;}
.nav-arrow{font-size:.6rem;transition:transform .2s;}
.nav-item:hover .nav-arrow{transform:rotate(180deg);}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:rgba(4,13,26,0.97);border:1px solid var(--glass-border);border-radius:12px;padding:.5rem;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .2s,transform .2s;backdrop-filter:blur(20px);z-index:600;}
.nav-item:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0);}
.dropdown a{display:block;padding:.55rem .9rem;color:var(--muted);text-decoration:none;font-size:.83rem;border-radius:7px;transition:all .15s;}
.dropdown a:hover{color:#fff;background:rgba(14,74,255,.2);}
.dropdown a .d-ico{margin-right:.5rem;}
.nav-cta{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;border:none;padding:.6rem 1.6rem;border-radius:30px;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s;box-shadow:0 0 20px rgba(0,180,255,.3);margin-left:1rem;white-space:nowrap;}
.nav-cta:hover{opacity:.85;transform:translateY(-1px);}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;padding:120px 5% 80px;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.bg-img{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1558655146-d09347e92766?w=1600&q=80') center/cover no-repeat;opacity:.1;filter:saturate(1.5);}
.bg-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 20% 50%,rgba(14,74,255,.35) 0%,transparent 60%),radial-gradient(ellipse 60% 60% at 80% 20%,rgba(0,180,255,.2) 0%,transparent 55%),radial-gradient(ellipse 50% 70% at 70% 80%,rgba(0,255,204,.08) 0%,transparent 50%);}
.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;}
.shape{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:floatShape 8s ease-in-out infinite;}
.s1{width:400px;height:400px;background:rgba(14,74,255,.2);top:-100px;right:5%;animation-delay:0s;}
.s2{width:300px;height:300px;background:rgba(0,255,204,.1);bottom:10%;left:10%;animation-delay:-3s;}
.s3{width:200px;height:200px;background:rgba(0,180,255,.15);top:30%;right:25%;animation-delay:-5s;}
@keyframes floatShape{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-30px) scale(1.05);}}

.hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;background:rgba(0,255,204,.08);border:1px solid rgba(0,255,204,.25);border-radius:30px;padding:.4rem 1.1rem;font-size:.75rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:1.8rem;animation:cascadeIn .6s .1s both;}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:puls 1.5s infinite;}
@keyframes puls{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.6);}}
.hero h1{font-family:'Syne',sans-serif;font-size:clamp(2.8rem,5vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-2px;margin-bottom:1.5rem;animation:cascadeIn .7s .2s both;}
.grad{background:linear-gradient(90deg,var(--sky),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero p{font-size:1.1rem;line-height:1.75;color:rgba(255,255,255,.6);max-width:460px;margin-bottom:2.5rem;animation:cascadeIn .7s .35s both;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:cascadeIn .7s .5s both;}
.btn-glow{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;padding:.9rem 2.2rem;border-radius:40px;border:none;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:600;text-decoration:none;cursor:pointer;box-shadow:0 0 30px rgba(0,180,255,.4);transition:box-shadow .2s,transform .2s;display:inline-block;}
.btn-glow:hover{box-shadow:0 0 50px rgba(0,180,255,.6);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:#fff;padding:.9rem 2.2rem;border-radius:40px;border:1px solid var(--glass-border);font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:500;text-decoration:none;cursor:pointer;backdrop-filter:blur(10px);transition:border-color .2s,background .2s;display:inline-block;}
.btn-ghost:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.05);}

/* Hero device */
.hero-right{animation:cascadeIn .8s .3s both;position:relative;}
.float-badge{position:absolute;background:linear-gradient(135deg,var(--blue),var(--sky));border-radius:12px;padding:.7rem 1.1rem;font-size:.78rem;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.4);white-space:nowrap;z-index:2;}
.float-badge.b1{top:-20px;right:-10px;animation:floatBadge 3s ease-in-out infinite;}
.float-badge.b2{bottom:20px;left:-20px;animation:floatBadge 3s 1.5s ease-in-out infinite;}
@keyframes floatBadge{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.device{background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:20px;overflow:hidden;backdrop-filter:blur(20px);filter:drop-shadow(0 30px 80px rgba(0,0,0,.5));}
.device-topbar{background:rgba(0,0,0,.3);padding:.7rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--glass-border);}
.d-dot{width:10px;height:10px;border-radius:50%;}
.d-dot.r{background:#ff5f57;}.d-dot.y{background:#ffbd2e;}.d-dot.g{background:#28c840;}
.d-url{flex:1;background:rgba(255,255,255,.07);border-radius:4px;padding:.25rem .8rem;font-size:.7rem;color:rgba(255,255,255,.4);margin-left:.5rem;}
.device-body{padding:1.2rem;}
.mini-templates{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;}
.mini-t{border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:transform .2s,border-color .2s;}
.mini-t:hover{transform:scale(1.03);border-color:var(--accent);}
.mini-t-img{height:80px;background-size:cover;background-position:center top;}
.mini-t-label{background:rgba(0,0,0,.5);padding:.4rem .6rem;font-size:.65rem;font-weight:600;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.5px;}

/* MARQUEE */
.marquee-wrap{padding:1.5rem 0;overflow:hidden;background:linear-gradient(90deg,var(--blue),var(--sky),var(--accent),var(--sky),var(--blue));background-size:300%;animation:gradShift 6s ease infinite;}
@keyframes gradShift{0%,100%{background-position:0%;}50%{background-position:100%;}}
.marquee-track{display:flex;gap:3rem;animation:marquee 22s linear infinite;white-space:nowrap;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.marquee-item{font-family:'Syne',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:2px;text-transform:uppercase;color:rgba(0,0,0,.55);display:inline-flex;align-items:center;gap:1rem;}
.marquee-item::after{content:'✦';color:rgba(0,0,0,.3);}

/* SECTION BASE */
.section-eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;}
.section-header{text-align:center;margin-bottom:3.5rem;}
.section-header h2{font-family:'Syne',sans-serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin-bottom:1rem;}
.section-header p{font-size:1.05rem;color:var(--muted);max-width:500px;margin:0 auto;line-height:1.7;}

/* SERVICIOS / LO QUE HACEMOS */
.servicios-section{padding:100px 5%;position:relative;overflow:hidden;}
.servicios-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 80% 50%,rgba(0,255,204,.06) 0%,transparent 60%);pointer-events:none;}
.servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.serv-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:18px;padding:2rem 1.8rem;cursor:default;transition:all .3s;opacity:0;transform:translateY(30px);}
.serv-card.visible{animation:cardIn .5s ease forwards;}
.serv-card:hover{background:rgba(14,74,255,.12);border-color:rgba(0,180,255,.3);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.3);}
.serv-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--blue),var(--sky));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.4rem;box-shadow:0 8px 24px rgba(14,74,255,.3);}
.serv-card h3{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:.7rem;color:#fff;}
.serv-card p{font-size:.88rem;color:var(--muted);line-height:1.65;}
.serv-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:1.2rem;}
.serv-tag{font-size:.65rem;font-weight:600;padding:.25rem .65rem;border-radius:4px;background:rgba(0,255,204,.07);color:var(--accent);border:1px solid rgba(0,255,204,.15);}
.serv-card.featured{background:linear-gradient(135deg,rgba(14,74,255,.2),rgba(0,180,255,.1));border-color:rgba(0,180,255,.3);}
.serv-card.featured .serv-icon{background:linear-gradient(135deg,var(--accent),var(--sky));}

/* DISEÑOS (ex templates) */
.templates-section{padding:100px 5%;position:relative;overflow:hidden;}
.templates-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(14,74,255,.15) 0%,transparent 60%);pointer-events:none;}
.cat-filters{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem;position:relative;z-index:1;}
.cat-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--muted);padding:.5rem 1.3rem;border-radius:30px;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;}
.cat-btn.active,.cat-btn:hover{background:linear-gradient(135deg,var(--blue),var(--sky));border-color:transparent;color:#fff;box-shadow:0 0 20px rgba(0,180,255,.3);}
.templates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.template-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;cursor:pointer;position:relative;opacity:0;transform:translateY(40px);transition:transform .35s cubic-bezier(.25,.8,.25,1),box-shadow .35s,border-color .35s;}
.template-card.visible{animation:cardIn .5s ease forwards;}
.template-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px var(--accent);border-color:var(--accent);}
@keyframes cardIn{to{opacity:1;transform:translateY(0);}}
.tcard-preview{height:220px;position:relative;overflow:hidden;background:#0a1628;}
.tcard-preview img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform 8s ease;filter:brightness(.9) saturate(1.1);}
.template-card:hover .tcard-preview img{transform:translateY(-40%);}
.tcard-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(4,13,26,.95));}
.tcard-badge{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:20px;padding:.3rem .8rem;font-size:.68rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent);}
.tcard-body{padding:1.4rem;}
.tcard-profession{font-size:.72rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--sky);margin-bottom:.4rem;}
.tcard-name{font-family:'Syne',sans-serif;font-size:1.15rem;font-weight:700;margin-bottom:.5rem;color:#fff;}
.tcard-desc{font-size:.85rem;color:var(--muted);line-height:1.55;margin-bottom:1rem;}
.tcard-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.2rem;}
.tcard-tag{font-size:.65rem;font-weight:600;padding:.25rem .6rem;border-radius:4px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.08);}
.tcard-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--glass-border);padding-top:1rem;}
.tcard-action{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;padding:.5rem 1.2rem;border-radius:20px;font-size:.8rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:box-shadow .2s;}
.tcard-action:hover{box-shadow:0 0 20px rgba(0,180,255,.4);}
.tcard-cms{font-size:.75rem;color:var(--muted);}

/* PORTFOLIO */
.portfolio-section{padding:100px 5%;position:relative;overflow:hidden;}
.portfolio-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 60%,rgba(0,255,204,.05) 0%,transparent 60%);pointer-events:none;}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:1200px;margin:0 auto 1.5rem;position:relative;z-index:1;}
.portfolio-grid .big{grid-column:span 2;}
.port-card{border-radius:16px;overflow:hidden;position:relative;cursor:pointer;opacity:0;transform:translateY(30px);aspect-ratio:16/10;background:#0a1628;}
.port-card.big{aspect-ratio:16/8;}
.port-card.visible{animation:cardIn .5s ease forwards;}
.port-img{width:100%;height:100%;object-fit:cover;filter:brightness(.75) saturate(1.1);transition:transform .5s ease,filter .5s ease;}
.port-card:hover .port-img{transform:scale(1.05);filter:brightness(.6) saturate(1.3);}
.port-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,13,26,.9) 0%,transparent 50%);opacity:0;transition:opacity .3s;}
.port-card:hover .port-overlay{opacity:1;}
.port-info{position:absolute;bottom:0;left:0;right:0;padding:1.4rem;transform:translateY(10px);opacity:0;transition:all .3s;}
.port-card:hover .port-info{transform:translateY(0);opacity:1;}
.port-cat{font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:.3rem;}
.port-name{font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.4rem;}
.port-desc{font-size:.82rem;color:rgba(255,255,255,.7);}
.port-tag-wrap{position:absolute;top:12px;left:12px;}
.port-label{background:rgba(0,0,0,.6);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:20px;padding:.3rem .8rem;font-size:.68rem;font-weight:700;color:#fff;}

/* RESEÑAS / CAROUSEL */
.resenas-section{padding:100px 5%;background:rgba(0,0,0,.2);overflow:hidden;}
.reviews-carousel{position:relative;max-width:1200px;margin:0 auto;}
.reviews-track-wrap{overflow:hidden;}
.reviews-track{display:flex;gap:1.5rem;transition:transform .5s cubic-bezier(.25,.8,.25,1);}
.review-card{min-width:calc(33.333% - 1rem);background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:1.8rem;flex-shrink:0;}
.review-stars{color:#FFD700;font-size:1rem;margin-bottom:1rem;letter-spacing:2px;}
.review-text{font-size:.92rem;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:1.4rem;font-style:italic;}
.review-author{display:flex;align-items:center;gap:.9rem;border-top:1px solid var(--glass-border);padding-top:1rem;}
.review-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--sky));display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0;}
.review-name{font-weight:600;font-size:.9rem;color:#fff;}
.review-role{font-size:.75rem;color:var(--muted);}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;}
.carr-btn{width:44px;height:44px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.carr-btn:hover{background:rgba(14,74,255,.3);border-color:var(--blue);}
.carr-dots{display:flex;gap:.5rem;}
.carr-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);cursor:pointer;transition:all .2s;}
.carr-dot.active{background:var(--accent);width:24px;border-radius:4px;}

/* CMS */
.cms-section{padding:100px 5%;}
.cms-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.cms-feats{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.2rem;}
.cms-feat{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;opacity:0;transform:translateX(-30px);transition:opacity .5s,transform .5s,border-color .2s;}
.cms-feat.visible{opacity:1;transform:translateX(0);}
.cms-feat:hover{border-color:rgba(0,255,204,.2);}
.cms-icon{width:42px;height:42px;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--sky));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.cms-feat h4{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:.3rem;}
.cms-feat p{font-size:.85rem;color:var(--muted);line-height:1.5;}
.dash-wrap{background:rgba(255,255,255,.03);border:1px solid var(--glass-border);border-radius:20px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4);}
.dash-top{background:rgba(0,0,0,.3);padding:.8rem 1.2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--glass-border);}
.dash-title-txt{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.5);}
.d2{display:flex;gap:.4rem;}.d2 div{width:9px;height:9px;border-radius:50%;}
.dash-body2{display:grid;grid-template-columns:170px 1fr;}
.dash-sidebar2{background:rgba(0,0,0,.2);padding:1rem;border-right:1px solid var(--glass-border);}
.dmenu{padding:.55rem .8rem;border-radius:6px;font-size:.75rem;color:rgba(255,255,255,.4);margin-bottom:.3rem;cursor:pointer;transition:all .2s;}
.dmenu.act{background:rgba(14,74,255,.3);color:#fff;}
.dash-main2{padding:1.2rem;}
.dlbl{font-size:.68rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem;}
.drow{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.6rem;margin-bottom:1rem;}
.dcard{background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:8px;padding:.8rem;}
.dcard .dn{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:700;color:#fff;}
.dcard .dl{font-size:.65rem;color:var(--muted);margin-top:.2rem;}
.dblock{background:rgba(255,255,255,.03);border:1px solid var(--glass-border);border-radius:8px;padding:1rem;}
.dfield{margin-bottom:.8rem;}
.dfield label{font-size:.65rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.3rem;}
.dfield .dval{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:.5rem .7rem;font-size:.75rem;color:rgba(255,255,255,.7);}
.dsave{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;border:none;padding:.5rem 1.2rem;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;margin-top:.8rem;}

/* PROFESIONES */
.prof-section{padding:100px 5%;position:relative;overflow:hidden;}
.prof-section::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=1600&q=80') center/cover no-repeat;opacity:.04;}
.prof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1100px;margin:2rem auto 0;position:relative;z-index:1;}
.prof-item{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:1.5rem 1.2rem;text-align:center;cursor:pointer;opacity:0;transform:translateY(20px);}
.prof-item.visible{animation:cardIn .4s ease forwards;}
.prof-item:hover{background:rgba(14,74,255,.15);border-color:rgba(0,180,255,.3);transform:translateY(-5px);}
.prof-emoji{font-size:2rem;margin-bottom:.7rem;display:block;}
.prof-name{font-size:.9rem;font-weight:600;color:#fff;margin-bottom:.3rem;}
.prof-sub{font-size:.75rem;color:var(--muted);}

/* PROCESO */
.process-section{padding:100px 5%;}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1100px;margin:3rem auto 0;position:relative;}
.proc-steps::before{content:'';position:absolute;top:36px;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,var(--blue),var(--sky),var(--accent),transparent);z-index:0;}
.proc-step{text-align:center;padding:0 1rem;position:relative;z-index:1;opacity:0;transform:translateY(30px);}
.proc-step.visible{animation:cardIn .5s ease forwards;}
.proc-num{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--navy),rgba(14,74,255,.4));border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:var(--sky);margin:0 auto 1.5rem;box-shadow:0 0 30px rgba(14,74,255,.3);}
.proc-step h4{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;margin-bottom:.5rem;}
.proc-step p{font-size:.85rem;color:var(--muted);line-height:1.6;}

/* CTA */
.cta-section{padding:120px 5%;text-align:center;position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1547658719-da2b51169166?w=1600&q=80') center/cover no-repeat;opacity:.07;filter:saturate(0);}
.cta-glow{position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(14,74,255,.25) 0%,transparent 70%);pointer-events:none;}
.cta-section h2{font-family:'Syne',sans-serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-2px;margin-bottom:1.2rem;position:relative;z-index:1;}
.cta-section>p{font-size:1.1rem;color:var(--muted);max-width:480px;margin:0 auto 2.5rem;line-height:1.7;position:relative;z-index:1;}
.cta-form{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;max-width:540px;margin:0 auto;}
.cta-input{flex:1;min-width:200px;padding:.9rem 1.4rem;border-radius:40px;border:1px solid var(--glass-border);background:rgba(255,255,255,.07);color:#fff;font-family:'Outfit',sans-serif;font-size:.95rem;backdrop-filter:blur(10px);outline:none;transition:border-color .2s,box-shadow .2s;}
.cta-input:focus{border-color:var(--accent);box-shadow:0 0 20px rgba(0,255,204,.15);}
.cta-input::placeholder{color:rgba(255,255,255,.3);}
.cta-contact{margin-top:3rem;display:flex;gap:3rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;}
.cta-ci{display:flex;align-items:center;gap:.7rem;font-size:.9rem;color:var(--muted);}
.cta-ci strong{color:#fff;}

/* FOOTER */
footer{background:rgba(0,0,0,.5);backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);padding:2rem 5%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.fl{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:800;color:#fff;}
.fl span{color:var(--accent);}
footer p{font-size:.78rem;color:rgba(255,255,255,.25);}

/* WHATSAPP FLOTANTE */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:.6rem;}
.wa-bubble{background:#25D366;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:transform .2s,box-shadow .2s;animation:waPulse 2.5s ease-in-out infinite;}
.wa-bubble:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.7);}
.wa-bubble svg{width:32px;height:32px;fill:#fff;}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5);}50%{box-shadow:0 4px 30px rgba(37,211,102,.8),0 0 0 8px rgba(37,211,102,.1);}}
.wa-tooltip{background:rgba(4,13,26,.95);border:1px solid var(--glass-border);border-radius:10px;padding:.7rem 1rem;font-size:.82rem;color:#fff;backdrop-filter:blur(10px);opacity:0;pointer-events:none;transform:translateX(10px);transition:all .25s;max-width:200px;text-align:right;}
.wa-tooltip strong{display:block;font-size:.85rem;color:var(--accent);margin-bottom:.2rem;}
.wa-float:hover .wa-tooltip{opacity:1;pointer-events:all;transform:translateX(0);}

@keyframes cascadeIn{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

@media(max-width:1000px){
  .hero-content,.cms-inner{grid-template-columns:1fr;}
  .hero-right{display:none;}
  .templates-grid,.prof-grid,.servicios-grid,.portfolio-grid{grid-template-columns:1fr 1fr;}
  .portfolio-grid .big{grid-column:span 1;}
  .proc-steps{grid-template-columns:1fr 1fr;}
  .proc-steps::before{display:none;}
  .review-card{min-width:calc(50% - .75rem);}
}
@media(max-width:600px){
  .templates-grid,.prof-grid,.servicios-grid,.portfolio-grid{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .review-card{min-width:calc(100% - 0rem);}
}