:root{
  --blue: #009FE3;
  --pink: #E6007E;
  --yellow: #FFCC00;
  --dark: #000000;
  --bg: #ffffff;
  --muted: #666666;
}

*{box-sizing:border-box}
body{font-family:Arial,Helvetica,sans-serif;margin:0;color:var(--dark);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
.container{max-width:1100px;margin:0 auto;padding:0 18px}

.site-header{background:var(--dark);border-bottom:1px solid rgba(255,255,255,0.06);position:sticky;top:0;z-index:20}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{font-weight:700;color:var(--yellow);font-size:1.1rem}
.logo img{height:48px;width:auto;display:block}
.main-nav a{margin-left:18px;color:#ffffff;text-decoration:none;font-size:14px}
.main-nav a:hover{color:var(--yellow)}

.nav-actions{display:flex;align-items:center;gap:12px}
.menu-toggle{display:none;width:40px;height:40px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:rgba(255,255,255,.08);padding:0;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}
.menu-toggle span{width:18px;height:2px;border-radius:999px;background:#fff;transition:transform .2s ease,opacity .2s ease}
.menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.is-open span:nth-child(2){opacity:0}
.menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.menu-whatsapp,.btn.whatsapp-hero,.footer-whatsapp{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:#25D366;color:#fff;text-decoration:none;font-family:inherit;font-size:.92rem;font-weight:700;line-height:1;letter-spacing:0;border:1px solid rgba(0,0,0,.08);border-radius:999px;box-shadow:0 8px 18px rgba(37,211,102,.22);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}
.menu-whatsapp:hover,.btn.whatsapp-hero:hover,.footer-whatsapp:hover{background:#1ebe5d;transform:translateY(-1px);box-shadow:0 12px 24px rgba(37,211,102,.28)}
.menu-whatsapp{min-height:38px;padding:0 14px;margin-left:18px}
.menu-whatsapp .wa-icon img{height:19px;width:19px;display:block}

.hero{position:relative;min-height:520px;padding:96px 0;background:url("assets/fondo.png") center/cover no-repeat;color:var(--dark);display:flex;align-items:center}
.hero-inner{max-width:620px;position:relative;z-index:1;margin-left:0;text-align:center;display:flex;flex-direction:column;align-items:center;animation:fadeUp .8s ease both}
.hero-kicker{display:inline-block;margin:0 0 18px;padding:0;font-weight:700}
.kicker-item{display:inline-flex;align-items:center;gap:6px;margin:0 5px}
.kicker-item::before{content:"";width:8px;height:8px;border-radius:50%;display:inline-block}
.blue-dot::before{background:var(--blue)}
.yellow-dot::before{background:var(--yellow)}
.red-dot::before{background:var(--pink)}
.text-blue{color:var(--blue)}
.text-yellow{color:var(--yellow)}
.text-red{color:var(--pink)}
.hero h1{margin:0;font-size:3rem;line-height:1.05}
.hero h1,.hero-kicker,.hero-copy,.hero-cta{text-shadow:-1px -1px 0 #fff,1px -1px 0 #fff,-1px 1px 0 #fff,1px 1px 0 #fff}
.hero-copy{max-width:560px;margin:22px 0 28px;font-size:1.15rem;line-height:1.5;opacity:.95}
.btn{display:inline-block;padding:12px 18px;border-radius:6px;border:none;background:#eee;color:var(--dark);text-decoration:none;cursor:pointer}
.btn.primary{background:var(--dark);color:white}
.btn.whatsapp-hero{min-height:46px;padding:0 22px;font-size:1rem}
.btn.whatsapp-hero img{width:21px;height:21px;display:block}
.hero-cta{margin:18px 0 0;font-size:.98rem;line-height:1.4;font-weight:700}

.benefits-strip{background:#fff;padding:18px 0}
.benefits-inner{display:grid;grid-template-columns:repeat(4,1fr);background:#050505;color:#fff;border-radius:8px;padding:18px 22px;box-shadow:0 12px 28px rgba(0,0,0,.12);animation:fadeUp .7s ease .18s both}
.benefit-item{display:flex;align-items:center;gap:14px;min-height:70px;padding:0 18px;border-right:1px solid rgba(255,255,255,.35);animation:fadeUp .65s ease both}
.benefit-item:nth-child(2){animation-delay:.08s}
.benefit-item:nth-child(3){animation-delay:.16s}
.benefit-item:nth-child(4){animation-delay:.24s}
.benefit-item:first-child{padding-left:0}
.benefit-item:last-child{border-right:none;padding-right:0}
.benefit-icon{width:42px;height:42px;flex:0 0 42px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.benefit-icon path:first-child,.benefit-icon circle{stroke-width:1.8}
.benefit-item h2{margin:0 0 5px;font-size:.78rem;line-height:1.2;text-transform:uppercase;color:#fff}
.benefit-item p{margin:0;font-size:.72rem;line-height:1.25;color:rgba(255,255,255,.82)}
.icon-blue{color:var(--blue)}
.icon-pink{color:var(--pink)}
.icon-yellow{color:var(--yellow)}
.icon-white{color:#fff}

.servicios{padding:42px 18px 52px}
.section-title{text-align:center;margin-bottom:20px}
.section-title h2{margin:0 0 6px;font-size:1.35rem;text-transform:uppercase;line-height:1.1}
.title-bars{display:inline-flex;width:128px;height:5px;border-radius:999px;background:linear-gradient(90deg,var(--blue) 0 33%,var(--pink) 33% 66%,var(--yellow) 66% 100%);animation:growLine .7s ease both}
.service-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.service-card{position:relative;overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 12px 28px rgba(0,0,0,.1);border:1px solid #ececec;animation:fadeUp .7s ease both;transition:transform .22s ease,box-shadow .22s ease}
.service-card:nth-child(2){animation-delay:.08s}
.service-card:nth-child(3){animation-delay:.16s}
.service-card:nth-child(4){animation-delay:.24s}
.service-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(0,0,0,.14)}
.service-media{position:relative;z-index:1;height:132px;background:linear-gradient(135deg,#f2f2f2,#dedede);overflow:hidden}
.service-media::after{content:"Espacio para imagen";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#777;font-size:.78rem;font-weight:700;text-transform:uppercase}
.service-media img{position:relative;z-index:1;width:100%;height:100%;display:block;object-fit:cover;transition:transform .35s ease}
.service-card:hover .service-media img{transform:scale(1.05)}
.service-body{position:relative;z-index:2;padding:24px 44px 18px 18px;min-height:128px;background:#fff}
.service-badge{position:absolute;z-index:3;top:-20px;left:18px;width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;font-weight:800;box-shadow:0 8px 18px rgba(0,0,0,.18)}
.service-body h3{margin:0 0 8px;font-size:.95rem;line-height:1.1;text-transform:uppercase}
.service-body p{margin:0;font-size:.78rem;line-height:1.35;color:#171717}
.service-link{position:absolute;right:16px;bottom:18px;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;font-size:1.7rem;line-height:1;font-weight:700;transition:transform .2s ease}
.service-link:hover{transform:translateX(3px)}
.service-badge.icon-blue,.service-link.icon-blue{background:var(--blue)}
.service-badge.icon-pink,.service-link.icon-pink{background:var(--pink)}
.service-badge.icon-yellow,.service-link.icon-yellow{background:var(--yellow)}
.service-badge.icon-dark,.service-link.icon-dark{background:var(--dark)}
.accent-blue h3{color:var(--blue)}
.accent-pink h3{color:var(--pink)}
.accent-yellow h3{color:#d6a900}
.accent-dark h3{color:var(--dark)}

.site-footer{background:#050505;color:#fff;padding:46px 0 18px}
.footer-inner{display:grid;grid-template-columns:1.1fr 1.3fr 1fr;gap:34px;align-items:start;animation:fadeUp .75s ease both}
.footer-brand img{width:120px;height:auto;display:block;margin-bottom:16px}
.footer-brand p,.footer-action p{margin:0;color:rgba(255,255,255,.76);line-height:1.5}
.footer-contact h2,.footer-action h2{margin:0 0 16px;font-size:1rem;text-transform:uppercase}
.footer-contact ul{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.footer-contact li{display:grid;gap:3px}
.footer-contact span{font-size:.8rem;font-weight:600;text-transform:none;color:rgba(255,255,255,.58)}
.footer-contact a,.footer-contact p{margin:0;color:rgba(255,255,255,.84);text-decoration:none;line-height:1.35;overflow-wrap:anywhere}
.footer-contact a:hover{color:var(--yellow)}
.footer-whatsapp{min-height:44px;margin-top:18px;padding:0 18px;font-size:.94rem}
.footer-whatsapp img{width:20px;height:20px;display:block}
.footer-bottom{margin-top:34px;padding-top:18px;border-top:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.62)}

.floating-whatsapp{position:fixed;right:22px;bottom:22px;z-index:30;width:58px;height:58px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#25D366;box-shadow:0 14px 30px rgba(37,211,102,.34);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}
.floating-whatsapp:hover{background:#1ebe5d;transform:translateY(-2px) scale(1.03);box-shadow:0 18px 34px rgba(37,211,102,.42)}
.floating-whatsapp img{width:30px;height:30px;display:block}

@media(max-width:768px){
  .container{padding:0 16px}
  .header-inner{padding-left:10px;padding-right:10px}
  .header-inner{padding-top:16px;padding-bottom:16px;gap:16px}
  .nav-actions{gap:8px}
  .menu-toggle{display:inline-flex;width:48px;height:48px;gap:6px}
  .menu-toggle span{width:22px;height:2px}
  .menu-toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .menu-toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .main-nav{position:absolute;top:100%;left:0;right:0;width:100vw;display:grid;gap:0;background:#050505;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 18px 30px rgba(0,0,0,.24);padding:10px 0 16px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease}
  .main-nav.is-open{opacity:1;visibility:visible;transform:translateY(0)}
  .main-nav a{margin:0 14px;padding:16px 12px;border-bottom:1px solid rgba(255,255,255,.1);font-size:.92rem;font-weight:700;letter-spacing:.02em}
  .menu-whatsapp{display:inline-flex;width:calc(100% - 56px);max-width:340px;min-height:42px;margin:16px 28px 4px;padding:0 16px;font-size:.92rem;border-bottom:none}
  .hero{min-height:500px;padding:54px 0;background:url("assets/fondo.png") center top/cover no-repeat}
  .hero-inner{width:min(100%,360px);margin:0 auto;text-align:center}
  .hero-kicker{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-bottom:16px;font-size:.9rem}
  .kicker-item{margin:0}
  .hero h1{font-size:2.25rem;line-height:1.08}
  .hero-copy{margin:18px 0 24px;font-size:1rem;line-height:1.45}
  .btn.whatsapp-hero{min-height:44px;padding:0 20px}
  .hero-cta{max-width:300px;font-size:.92rem}
  .benefits-strip{padding:0 0 18px}
  .benefits-inner{grid-template-columns:1fr;border-radius:0;padding:24px 28px}
  .benefit-item{min-height:auto;align-items:flex-start;gap:16px;padding:20px 0;border-right:none;border-bottom:1px solid rgba(255,255,255,.18)}
  .benefit-item:first-child{padding-top:0}
  .benefit-item:last-child{padding-bottom:0;border-bottom:none}
  .benefit-icon{width:34px;height:34px;flex-basis:34px;margin-top:2px}
  .benefit-item h2{margin-bottom:7px;font-size:.92rem}
  .benefit-item p{font-size:.84rem;line-height:1.4}
  .servicios{padding:44px 16px 48px}
  .section-title{margin-bottom:26px}
  .section-title h2{font-size:1.15rem}
  .title-bars{width:112px}
  .service-cards{grid-template-columns:1fr}
  .service-media{height:170px}
  .service-body{min-height:auto;padding:24px 48px 20px 18px}
  .logo img{height:48px}
  .site-footer{padding:38px 0 18px}
  .footer-inner{grid-template-columns:1fr;gap:26px}
  .footer-brand img{width:104px}
  .footer-whatsapp{width:100%;max-width:280px}
  .floating-whatsapp{right:16px;bottom:16px;width:54px;height:54px}
  .floating-whatsapp img{width:28px;height:28px}
}

@media(max-width:420px){
  .container{padding:0 14px}
  .header-inner{padding:14px 10px}
  .logo img{height:42px}
  .hero{min-height:470px;padding:44px 0;background-position:center top}
  .hero h1{font-size:1.95rem}
  .hero-copy{font-size:.94rem}
  .benefits-inner{padding:22px 22px}
  .benefit-item{gap:14px}
  .benefit-icon{width:32px;height:32px;flex-basis:32px}
  .servicios{padding-top:38px}
  .section-title{margin-bottom:22px}
  .service-media{height:150px}
  .service-body p{font-size:.76rem}
  .footer-contact a,.footer-contact p{font-size:.92rem}
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes growLine{
  from{opacity:0;transform:scaleX(.35)}
  to{opacity:1;transform:scaleX(1)}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}

/* Accents for links and highlights */
a{color:var(--dark)}
