/* Site replica CSS - estilo inspirado en fibermark but original */
:root{
  /* Base purple palette unified on #4f366e */
  --purple-base: #4f366e; /* requested base */
  --purple-light: #6b4f86; /* lighter tint */
  --purple-dark:  #3a244f; /* darker tint */
  --purple-grad: linear-gradient(180deg,var(--purple-light),var(--purple-dark));
  --purple-1: var(--purple-light);
  --purple-2: var(--purple-dark);
  --brand-purple: var(--purple-base);
  --brand-purple-2: var(--purple-dark);
  --accent:#a6c90a;
  --accent-bright:#76ff03;
  --bg:#f9f9f9;
  --text-dark:#111;
  --max-width:1280px;
  /* Typographic scale */
  --fs-h1: 2rem;       /* 32px */
  --fs-h2: 1.5rem;     /* 24px */
  --fs-h3: 1.125rem;   /* 18px */
  --fs-body: 1rem;     /* 16px */
  --fs-small: .875rem; /* 14px */
  --fs-form: .95rem;   /* 15px */
  /* Page gutter for white space at sides */
  --page-gutter: 128px;
  /* fibermark brand variables */
  --brand-accent: #A2D700;  /* rgb(162,215,0) */
  --pill-left-bg: #A2D700;
}

.section-hero-modern{background:radial-gradient(circle at top left,rgba(79,54,110,.95),rgba(58,38,95,.95)),var(--purple-grad);color:#fff;overflow:hidden;position:relative}
.section-hero-modern:before{content:'';position:absolute;top:0;left:50%;width:620px;height:620px;background:rgba(255,255,255,.08);border-radius:50%;transform:translateX(-50%);filter:blur(40px);}
.section-hero-modern .hero-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:32px;padding:80px 0;}
.section-hero-modern .hero-copy{max-width:620px}
.section-hero-modern .hero-title{font-size:clamp(3rem,6vw,4.5rem);line-height:0.95;font-weight:900;letter-spacing:-0.05em;text-transform:uppercase;margin:0;}
.section-hero-modern .hero-subtitle{display:inline-flex;padding:10px 18px;border-radius:999px;background:rgba(100,221,23,.12);color:var(--accent);text-transform:uppercase;font-weight:800;letter-spacing:.18em;font-size:.95rem;margin-top:22px;}
.section-hero-modern .hero-text{margin:24px 0 0;max-width:520px;font-size:1.05rem;line-height:1.8;color:rgba(255,255,255,.92);}
.section-hero-modern .hero-visual{flex:1;min-width:320px;max-width:520px;position:relative;}
.section-hero-modern .hero-visual img{width:100%;height:auto;display:block;border-radius:32px;box-shadow:0 32px 80px rgba(0,0,0,.28);}

.plans-grid{display:grid;grid-template-columns:repeat( auto-fit,minmax(260px,1fr) );gap:22px;max-width:1140px;margin:0 auto;padding:48px 0;}
.plan-card{display:flex;flex-direction:column;border-radius:18px;overflow:hidden;box-shadow:0 18px 40px rgba(21,12,45,.12);background:linear-gradient(180deg,#fff,#fff);transition:transform .22s ease,box-shadow .22s ease}
.plan-card:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(21,12,45,.16)}
.plan-card-top{background:linear-gradient(180deg,var(--purple-light),var(--purple-dark));color:#fff;padding:28px 22px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.plan-card-top .plan-label{font-size:.85rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;opacity:.9}
.plan-card-top .plan-speed{font-size:3.6rem;font-weight:900;line-height:1;display:flex;align-items:baseline;gap:10px}
.plan-card-top .plan-speed .number{font-size:3.6rem}
.plan-card-top .plan-speed .unit{font-size:1.1rem;opacity:.9}
.plan-card-top .plan-features{margin-top:6px;font-size:.95rem;color:rgba(255,255,255,.92)}
.plan-card-bottom{background:var(--accent);color:var(--text-dark);padding:20px;display:flex;flex-direction:column;gap:12px;align-items:center}
.plan-card-bottom .plan-price{font-size:2.4rem;font-weight:900;margin:0}
.plan-card-bottom .plan-period{font-size:.95rem;text-transform:none;opacity:.95;margin-top:0}
.plan-card-bottom .plan-cta{margin-top:6px;display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;background:var(--purple-2);color:#fff;font-weight:800;text-decoration:none;box-shadow:0 8px 20px rgba(0,0,0,.12)}
.plan-card-bottom .plan-meta{font-size:.92rem;color:rgba(0,0,0,.6)}

/* small decorative corner accent */
.plan-card::after{content:'';position:absolute;pointer-events:none}

@media (min-width:900px){
  /* Use a two-column grid per card: left content + right CTA/meta column (320px)
     This guarantees the green column sits flush to the card's right edge. */
  .plan-card{display:grid;grid-template-columns:1fr 320px;gap:0;align-items:stretch;height:100%}
  .plan-card-top{padding:28px}

  /* Force a 3-column overall layout and equal row heights so all cards look uniform */
  .plans-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:280px;align-items:stretch}

  /* Right column (green) fills its grid cell entirely */
  .plan-card-bottom{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:20px;margin-top:0 !important;height:100%}

  /* Remove intentional visual offset so all cards align uniformly */
  .plan-card--center{grid-column:2; margin-top:0}

  /* Make the 500 Mbps (5th) and 1000 Mbps (6th) cards narrower and centered
     inside their grid cell so they visually appear centered with space left/right */
  .plans-grid > .plan-card:nth-of-type(5),
  .plans-grid > .plan-card:nth-of-type(6){
    margin:0 auto; /* center via auto margins */
    width:360px;
    max-width:110%;
  }

  /* Image-only card styles (fills the empty slot) */
  .plan-card--image{
    display:block;
    background:transparent;
    padding:0;
    border-radius:0;
    box-shadow:none;
    overflow:hidden;
  }
  .plan-card--image .plan-card-image{width:100%;height:100%;display:block}
  .plan-card--image img{width:100%;height:100%;object-fit:cover;border-radius:0;display:block}
}

@media (max-width:640px){
  .plan-card{border-radius:14px}
  .plan-card-top .plan-speed{font-size:2.6rem}
  .plan-card-bottom .plan-price{font-size:1.6rem}
  .plan-card-bottom .plan-cta{padding:10px 14px}

  /* Restore left-aligned buttons on very small screens for better flow */
  .plan-card-bottom{align-items:flex-start}
}

/* Mobile: add white side gutters so cards don't touch screen edges */
@media (max-width:640px){
  .plans-grid{padding-left:18px;padding-right:18px}
  .plans-grid > .plan-card{margin-left:6px;margin-right:6px;background:#fff}
  .plans-grid > .plan-card:first-child{margin-top:6px}
}

/* Compatibility: map older markup classes to the new layout */
.plan-card-left{display:block}
.plan-card-right{display:block}
.plan-card-left{padding:0}
.plan-card-right{padding:0}
.plan-card-left{background:transparent}
.plan-card-right{background:transparent}
.plan-card-left .plan-speed{font-size:inherit}
.plan-card-left .plan-label{font-size:.85rem}
.plan-card-right .plan-price{font-size:inherit}

.cta-panel{background:var(--accent);color:#fff;padding:60px 0;}
.cta-panel .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;}
.cta-panel h2{margin:0;font-size:clamp(2rem,3vw,3rem);font-weight:900;line-height:1.05;color:#fff}
.cta-panel p{margin:0;max-width:560px;font-size:1rem;line-height:1.75;opacity:.95;color:#fff}
.cta-panel .cta-pill{display:inline-flex;align-items:center;gap:12px;padding:18px 26px;border-radius:999px;background:var(--purple-2);color:#fff;font-weight:800;text-decoration:none;box-shadow:0 18px 40px rgba(243, 243, 243, 0.18);}

.section-split{display:flex;gap:32px;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto;padding:80px 0;}
.section-split .text-block{flex:1;}
.section-split .image-block{flex:1;}
.section-split .image-block img{width:100%;height:auto;border-radius:28px;box-shadow:0 24px 60px rgba(38,0,71,.14);}
.section-split-title{font-size:clamp(2.5rem,5vw,3.8rem);line-height:1;letter-spacing:-.05em;margin:0;font-weight:900;color:#1a0b3a;}
.section-split-text{margin:24px 0 0;font-size:1rem;line-height:1.8;color:#333;}
.info-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin:0 auto;padding:40px 0;max-width:1140px;}
.info-card{background:#fff;border:1px solid rgba(79,54,110,.16);border-radius:24px;padding:32px;box-shadow:0 20px 50px rgba(38,0,71,.08);}
.info-card h3{margin-top:0;font-size:1.25rem;color:var(--purple-dark);font-weight:800;}
.info-card p{margin:16px 0 0;color:#444;line-height:1.75;}
.values-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;max-width:1140px;margin:0 auto;padding:40px 0;}
.value-card{background:#fff;border:1px solid rgba(100,221,23,.18);border-radius:24px;padding:28px;text-align:center;box-shadow:0 20px 50px rgba(38,0,71,.06);}
.value-icon{width:64px;height:64px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;margin:0 auto 16px;background:rgba(100,221,23,.14);color:var(--purple-2);font-size:1.4rem;}
.value-card h4{margin:0;font-size:1.1rem;color:#1a0b3a;font-weight:800;}
.value-card p{margin:14px 0 0;line-height:1.7;color:#555;}

.service-section{padding:80px 0;background:var(--bg);}
.service-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;max-width:1140px;margin:0 auto;}
.service-card{border-radius:28px;overflow:hidden;box-shadow:0 24px 60px rgba(38,0,71,.08);}
.service-card-dark{background:var(--purple-grad);color:#fff;padding:36px;}
.service-card-dark h3{margin:0 0 16px;font-size:1.8rem;color:#fff;}
.service-card-dark p{margin:0;color:rgba(255,255,255,.92);line-height:1.75;}
.service-card-light{background:#fff;color:#1a0b3a;padding:36px;}
.service-card-light h3{margin:0 0 16px;font-size:1.8rem;color:var(--purple-dark);}
.service-card-light p{margin:0;color:#333;line-height:1.75;}
.faq-section{padding:80px 0;}
.faq-wrapper{max-width:900px;margin:0 auto;}
.faq-item{background:#fff;border-radius:20px;box-shadow:0 18px 40px rgba(38,0,71,.08);margin-bottom:16px;overflow:hidden;}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;cursor:pointer;font-weight:800;color:#1a0b3a;}
.faq-question .faq-toggle{width:32px;height:32px;border-radius:999px;border:1px solid rgba(74,20,140,.2);display:inline-flex;align-items:center;justify-content:center;color:var(--purple-2);transition:transform .25s ease;}
.faq-answer{display:none;padding:0 28px 24px;color:#4e4e4e;line-height:1.75;}
.faq-item.open .faq-answer{display:block;}
.faq-item.open .faq-toggle{transform:rotate(45deg);}

@media (max-width:980px){
  .section-hero-modern .hero-inner{flex-direction:column;align-items:flex-start;padding:60px 0;}
  .section-split{flex-direction:column;padding:60px 0;}
  .info-cards,.values-grid,.service-grid{grid-template-columns:1fr;}
  .plan-card{grid-template-columns:1fr;}
}

/* Tweak title sizes on mobile to avoid overflow and visual crowding */
@media (max-width:768px){
  .section-hero-modern .hero-title{font-size:2.2rem}
  .section-hero-modern .hero-subtitle{font-size:.85rem;padding:8px 14px}
  .section-hero-modern .hero-text{font-size:.98rem}
  .section-split-title{font-size:1.5rem}
}

@media (max-width:480px){
  .section-hero-modern .hero-title{font-size:1.9rem}
  .section-split-title{font-size:1.35rem}
}

/* Add consistent side spacing for titles and paragraphs on small screens */
@media (max-width:768px){
  .hero-copy,
  .section-split .text-block,
  .empresa-copy-inner,
  .empresa-propuesta-inner,
  .info-card,
  .section-hero-modern .hero-visual{
    padding-left:20px;
    padding-right:20px;
  }

  .section-hero-modern .hero-title,
  .section-split-title,
  .empresa-propuesta-pill,
  .empresa-copy-block h2{
    padding-left:8px;
    padding-right:8px;
    margin-left:0;
    margin-right:0;
  }

  .section-split-text,
  .section-hero-modern .hero-text,
  .info-card p{
    padding-left:8px;
    padding-right:8px;
    margin-top:12px;
    margin-bottom:12px;
  }
}

@media (max-width:640px){
  :root{--page-gutter:24px;}
  .section-hero-modern .hero-inner{padding:40px 0;}
  .section-hero-modern .hero-title{font-size:2.8rem;}
  .section-hero-modern .hero-copy{width:100%;}
  .plan-card{grid-template-columns:1fr;}
  .section-split{padding:40px 0;}
}
*{box-sizing:border-box}
body{margin:0;font-family:'Montserrat', Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;color:#111;background:var(--bg)}
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--page-gutter)}
/* Make header containers edge-aligned so header elements stick to viewport edges
   without changing existing HTML. Keeps small horizontal padding for breathing room. */
header .container,
.topbar-sales .container,
header #mobileMenu .container{
  max-width:100%;
  margin:0;
  padding-left:16px;
  padding-right:16px;
}
.bg-white{background:#fff}
.topbar{background:#fff;border-bottom:1px solid #eee;font-size:0.95rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:8px 20px}
.topbar-sales{display:none;background:transparent;border-bottom:0}
.topbar-sales .container{padding:4px 0}
.topbar-sales .sales-link{display:inline-flex;background:#a6c90a;color:#ffffff;padding:8px 12px;border-radius:18px;font-weight:800;text-decoration:none;box-shadow:0 8px 18px rgba(0,0,0,0.08);align-items:center;gap:8px}
.topbar-sales .sales-link .sales-icon{color:#ffffff}
.header{background:#fff}
 .header .header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
/* Aumentar espacio vertical en los contenedores dentro del header */
.logo{font-weight:800;color:var(--purple-2);font-size:28px}
.nav{display:flex;gap:22px;align-items:center}
.nav a{color:#4b2b5a;text-decoration:none;font-weight:600}

/* Active / current page styling for header nav */
.nav a.active,
.nav a.current,
header a.active,
header a.current{
  color:var(--accent) !important;
}
/* place decorative bar without affecting layout */
header a{position:relative}
header a.active::after,
header a.current::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-6px;
  height:3px;
  width:28px;
  background:var(--accent);
  border-radius:3px;
}
/* Override hardcoded Tailwind-like utility on the home link when not active */
header a[href$="index.html"]:not(.active){
  color:#4b2b5a !important;
}
.actions{display:flex;gap:12px;align-items:center}
.btn{padding:10px 16px;border-radius:999px;text-decoration:none;display:inline-block}
.btn-primary{background:var(--purple-2);color:#fff;padding:12px 20px;border-radius:30px}
.btn-ghost{background:transparent;color:var(--purple-2);border:1px solid transparent}
.btn-wsp{background:var(--accent);color:#fff;padding:10px 14px;border-radius:10px;font-weight:800;display:inline-block}

.btn-group{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.card .btn-group .btn-primary{border-radius:8px;padding:10px 14px}
.card .btn-group .btn-wsp{border-radius:8px;padding:10px 14px}
.cta-hot{background:var(--accent);color:#fff;padding:10px 14px;border-radius:10px}

/* Hero */
.hero{background:linear-gradient(90deg,var(--purple-light),var(--purple-dark));color:#fff;padding:0}
.hero-inner{display:flex;gap:32px;align-items:center;justify-content:center}
.hero-carousel-full{width:100%;position:relative;overflow:hidden}
.hero-carousel-full .carousel{position:relative;width:100%;max-width:none;border-radius:0;overflow:hidden;margin:0}
.hero-carousel-full .carousel .slides{position:relative;width:100%;height:600px;background:var(--purple-grad)}
.hero-carousel-full .carousel .slide{position:absolute;inset:0;display:none;align-items:center;justify-content:center}
.hero-carousel-full .carousel .slide.active{display:flex}
.hero-carousel-full .carousel img{width:100%;height:600px;object-fit:contain;object-position:center;display:block}

.hero{position:relative;overflow:hidden;margin-bottom:0}
.hero::after{display:none;}
.hero-carousel-full.hero-one-slide{position:relative;width:100%;overflow:hidden}
.hero-main-image{width:100%;height:auto;object-fit:cover;object-position:center;display:block;max-width:none}

.empresa-hero{padding:0;margin:0;overflow:hidden;background:transparent}
.empresa-hero-fullwidth{width:100%;overflow:hidden;display:flex;justify-content:center}
.empresa-hero-image{width:100%;height:auto;display:block;object-fit:contain;object-position:center center;margin:0}

.empresa-header-logo{height:96px;width:auto;max-width:300px;object-fit:contain}
.empresa-header-logo--mobile{height:34px;max-width:150px}

/* Make logo visually much larger without increasing header height
  The anchor with class .logo-wrap acts as a fixed-height frame; the image is positioned absolute
  and can overflow the header while the header layout remains the same. */
.logo-wrap{position:relative;display:inline-block;height:64px;overflow:visible}
.logo-wrap img.empresa-header-logo{position:absolute;left:0;top:50%;transform:translateY(-50%);height:160px;max-height:none;width:auto}
.logo-wrap img.empresa-header-logo.empresa-header-logo--mobile{height:120px}

/* Mobile header tweaks: increase vertical space, lower logo and menu */
@media (max-width:768px){
  .empresa-header-logo--mobile{height:48px;max-width:220px}
  #navToggle{transform:none}
  /* show topbar only on mobile */
  .topbar-sales{display:block}
}

@media (max-width:768px){
  .empresa-header-logo{height:74px;max-width:220px}
  .empresa-header-logo--mobile{height:48px;max-width:220px}
}

@media (max-width:640px){
  .empresa-hero{height:80vh;background:linear-gradient(180deg,var(--purple-dark),var(--purple-base))}
  .empresa-hero-fullwidth{height:100%}
  .empresa-hero-fullwidth picture{display:block;width:100%;height:100%}
  .empresa-hero-image{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
}

/* Mobile: hero should fill remaining viewport height and full width */
@media (max-width:768px){
  /* approximate header + topbar combined height is 110px on mobile */
  .hero-carousel-full .carousel .slides{height:calc(100vh - 110px) !important}
  .hero-carousel-full .carousel img, .hero-main-image{width:100%;height:100%;object-fit:cover;object-position:center top}
  .hero{min-height:calc(100vh - 110px)}
}

/* Mobile menu slide animation */
#mobileMenu{transition:transform .34s cubic-bezier(.2,.9,.2,1),opacity .28s ease;will-change:transform,opacity}
#mobileMenu.menu-slide-pre{opacity:0;transform:translateY(-8px)}
#mobileMenu.menu-slide-open{opacity:1;transform:none}

/* Improve mobile menu link spacing and touch targets */
#mobileMenu nav{padding-top:8px;padding-bottom:18px}
#mobileMenu nav a{display:block;padding:12px 8px;border-radius:8px}
#mobileMenu nav a:active{opacity:0.85}

/* ensure hero sections have no bottom gap */
.hero-carousel-full,
.empresa-hero,
.empresa-hero-fullwidth{margin-bottom:0;padding-bottom:0}

.empresa-copy-block{background:radial-gradient(circle at top center,rgba(79,54,110,.18) 0,rgba(79,54,110,0) 36%),linear-gradient(180deg,var(--purple-dark),var(--purple-base));color:#fff;margin:0;padding:46px 0 34px;min-height:auto;display:flex;align-items:center;justify-content:center}
.empresa-copy-inner{max-width:1140px;margin:0 auto;padding:0 28px;text-align:center}

@media (max-width:900px){
  .empresa-copy-inner{padding:0 24px;max-width:920px}
}
.empresa-copy-block h2{font-size:clamp(1.6rem,2vw,2.15rem);line-height:1.08;margin:0 0 22px;font-weight:800;max-width:920px;margin-left:auto;margin-right:auto}
.empresa-copy-block p{max-width:840px;margin:0 auto;color:rgba(255,255,255,.9);line-height:1.9;font-size:1.05rem}

.empresa-propuesta{background:#fff;padding:28px 0 48px}
.empresa-propuesta-inner{max-width:1080px;margin:0 auto;text-align:center;position:relative}
.empresa-propuesta-kicker{margin:0 0 14px;font-size:13px;font-weight:800;letter-spacing:1.2px;color:var(--purple-base);text-transform:uppercase}
.empresa-propuesta-pill{position:relative;z-index:0;display:block;width:min(100%,940px);min-height:72px;margin:0 auto -18px;padding:18px 36px;border-radius:10px;background:var(--purple-base);color:#fff;font-family:'Montserrat',sans-serif;font-size:var(--fs-h1);font-weight:800;line-height:1.15;box-shadow:0 12px 26px rgba(58,38,95,.16)}
.empresa-propuesta-card{position:relative;z-index:1;max-width:980px;margin:0 auto;background:transparent;border-radius:12px;padding:0;box-shadow:none;overflow:hidden}
.empresa-propuesta-visual{background:transparent;border-radius:12px;overflow:hidden;display:flex;justify-content:center}
.empresa-propuesta-visual img{width:100%;max-width:980px;height:auto;display:block;object-fit:cover;object-position:center center}
.empresa-propuesta-note{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);display:inline-flex;align-items:center;justify-content:center;margin:0;padding:8px 18px;border-radius:999px;background:#fff;color:#7a3d00;font-size:clamp(.72rem,.95vw,.88rem);line-height:1.25;font-weight:600;max-width:92%;white-space:nowrap;z-index:2;box-shadow:0 8px 20px rgba(35,0,60,.12)}
.empresa-propuesta-note strong{color:#a6c90a}

/* Fix: allow the proposal note to wrap on small screens and avoid overflow */
.empresa-propuesta-note{white-space:normal;word-break:break-word;text-align:center;hyphens:auto}
@media (max-width:768px){
  .empresa-propuesta-note{font-size:.85rem;padding:10px 14px;left:50%;right:16px;max-width:calc(100% - 32px);transform:translateX(-50%);bottom:12px}
}

/* Mobile: stack propuesta card, make note flow below image for better readability */
@media (max-width:768px){
  .empresa-propuesta-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px 8px}
  .empresa-propuesta-visual{width:100%;display:block}
  .empresa-propuesta-visual img{width:100%;max-width:420px;height:auto;border-radius:12px}
  .empresa-propuesta-note{position:static;left:auto;right:auto;transform:none;display:block;margin:0 auto;padding:10px 14px;border-radius:12px;max-width:100%;box-shadow:0 8px 20px rgba(35,0,60,.08);text-align:center}
  .empresa-propuesta-note strong{display:block;color:#a6c90a;margin-bottom:6px}
}

.empresa-oferta{background:#fff;padding:18px 0 42px}
.empresa-oferta-inner{max-width:1120px;margin:0 auto;text-align:center}
.empresa-oferta-title{margin:0 0 20px;color:var(--purple-base);font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);font-weight:800;line-height:1.1;letter-spacing:.4px}
.empresa-oferta-grid{display:grid;grid-template-columns:repeat(5, minmax(0, 1fr));gap:16px;align-items:stretch}
.empresa-oferta-card{background:#a7ca0b;border-radius:18px;padding:14px 12px 16px;box-shadow:0 14px 32px rgba(88,50,126,.12);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:250px}
.empresa-oferta-image{width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.empresa-oferta-image img{width:75%;height:75%;object-fit:contain;display:block;border-radius:12px}
.empresa-oferta-card h3{margin:0;color:#fff;font-family:'Montserrat',sans-serif;font-size:var(--fs-small);line-height:1.2;font-weight:700;text-align:center}

@media (max-width:1100px){
  .empresa-oferta-grid{grid-template-columns:repeat(3, minmax(0, 1fr))}
}

@media (max-width:700px){
  .empresa-oferta-grid{grid-template-columns:repeat(2, minmax(0, 1fr));gap:12px}
  .empresa-oferta-card{min-height:220px}
}

@media (max-width:480px){
  .empresa-oferta-grid{grid-template-columns:1fr}
}

.empresa-soluciones{background:#fff;padding:8px 0 44px}
.empresa-soluciones-inner{max-width:1120px;margin:0 auto}
.empresa-soluciones-top{position:relative;display:grid;grid-template-columns:1.2fr .9fr;gap:14px;align-items:stretch;margin-top:8px}
.empresa-soluciones-sticker{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:48px;height:48px;z-index:5}
.empresa-soluciones-sticker img{width:100%;height:100%;display:block;object-fit:contain}
.empresa-soluciones-card{position:relative;overflow:hidden;border-radius:16px}
.empresa-soluciones-card--soft{min-height:170px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.empresa-soluciones-card--left{background:linear-gradient(90deg,#f4dfcf 0%,#f9ecdf 45%,#f7efe7 100%)}
.empresa-soluciones-card--right{background:linear-gradient(90deg,var(--purple-light) 0%,var(--purple-dark) 100%);color:#fff}
.empresa-soluciones-copy{max-width:58%;position:relative;z-index:1}
.empresa-soluciones-copy--compact{max-width:100%}
.empresa-soluciones-label{margin:0 0 8px;font-family:'Montserrat',sans-serif;font-size:var(--fs-small);line-height:1.1;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#a6c90a}
.empresa-soluciones-label--warm{color:#a6c90a}
.empresa-soluciones-label--dark{color:#ffd9ff}
.empresa-soluciones-copy h3,.empresa-soluciones-bg-copy h3{margin:0;color:var(--purple-base);font-family:'Montserrat',sans-serif;font-size:var(--fs-h3);line-height:1.2;font-weight:800}
.empresa-soluciones-copy p,.empresa-soluciones-copy li,.empresa-soluciones-bg-copy h3{font-family:'Montserrat',sans-serif}
.empresa-soluciones-copy ul{margin:12px 0 0;padding:0 0 0 18px;color:var(--purple-base);font-size:13px;line-height:1.5}
.empresa-soluciones-copy li{margin:0 0 4px}
.empresa-soluciones-figure{flex:0 0 34%;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}
.empresa-soluciones-figure img{width:100%;max-width:180px;height:auto;display:block;object-fit:contain}
.empresa-soluciones-card--left{padding:18px 18px 18px 18px}
.empresa-soluciones-card--left .empresa-soluciones-figure{position:absolute;left:0;top:0;bottom:0;width:44%;max-width:none;z-index:1;align-items:center;justify-content:flex-start;pointer-events:none}
.empresa-soluciones-card--left .empresa-soluciones-figure img{max-width:175px;transform:translateX(10px)}
.empresa-soluciones-card--left .empresa-soluciones-copy{position:relative;z-index:3;max-width:58%;margin-left:auto;padding-left:10px}
.empresa-soluciones-card--left .empresa-soluciones-copy h3,.empresa-soluciones-card--left .empresa-soluciones-copy ul{position:relative;z-index:3}
.empresa-soluciones-card--right .empresa-soluciones-copy h3{color:#fff;margin-bottom:8px}
.empresa-soluciones-card--right .empresa-soluciones-copy p{margin:0;color:rgba(255,255,255,.92);font-size:13px;line-height:1.45}
.empresa-soluciones-title{margin:22px auto 18px;max-width:760px;text-align:center;color:var(--purple-base);font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);line-height:1.15;font-weight:800;letter-spacing:.7px}
.empresa-soluciones-bottom{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch}
.empresa-soluciones-card--bg{min-height:210px;background-size:cover;background-position:center center;padding:18px 18px 18px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.empresa-soluciones-card--bg::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,248,242,.82) 0%,rgba(255,248,242,.66) 46%,rgba(255,248,242,.08) 100%);z-index:0}
.empresa-soluciones-card--bg-alt::before{background:linear-gradient(90deg,rgba(97,42,144,.82) 0%,rgba(97,42,144,.58) 54%,rgba(97,42,144,.06) 100%)}
.empresa-soluciones-bg-copy{position:relative;z-index:1;max-width:64%}
.empresa-soluciones-bg-copy--light h3{color:#fff}
.empresa-soluciones-bg-copy h3{font-size:var(--fs-h3);line-height:1.35}
.empresa-soluciones-side-icon{position:relative;z-index:1;flex:0 0 28%;display:flex;align-items:center;justify-content:center}
.empresa-soluciones-side-icon img{width:100%;max-width:120px;height:auto;display:block;object-fit:contain}
.empresa-soluciones-side-icon--alt img{max-width:110px}

/* Centered card style (no background images) */
.empresa-soluciones-card--styled{min-height:220px;padding:22px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;background:linear-gradient(180deg,rgba(79,54,110,0.04),rgba(79,54,110,0.08));border:1px solid rgba(79,54,110,0.08);box-shadow:0 10px 24px rgba(36,20,56,0.06);overflow:hidden}
.empresa-soluciones-card--styled .empresa-soluciones-bg-copy{max-width:100%}
.empresa-soluciones-card--styled .empresa-soluciones-bg-copy h3{color:var(--purple-base);font-size:1.05rem;margin:0}
.empresa-soluciones-card--styled .empresa-soluciones-side-icon{flex:0 0 auto;margin-bottom:6px}
.empresa-soluciones-card--styled .empresa-soluciones-side-icon img{width:84px;height:auto;display:block;margin:0 auto}

/* Alternate stronger purple variant */
.empresa-soluciones-card--styled.empresa-soluciones-card--alt{background:linear-gradient(135deg,var(--purple-base),var(--purple-dark));color:#fff;border:1px solid rgba(255,255,255,0.06)}
.empresa-soluciones-card--styled.empresa-soluciones-card--alt .empresa-soluciones-bg-copy h3{color:#fff}
.empresa-soluciones-card--styled.empresa-soluciones-card--alt .empresa-soluciones-side-icon img{filter:drop-shadow(0 4px 12px rgba(0,0,0,0.18));}

@media (max-width:900px){
  .empresa-soluciones-top,.empresa-soluciones-bottom{grid-template-columns:1fr}
  .empresa-soluciones-sticker{top:-18px}
  .empresa-soluciones-card--soft,.empresa-soluciones-card--bg{min-height:auto;flex-direction:column;align-items:flex-start}
  .empresa-soluciones-copy,.empresa-soluciones-bg-copy{max-width:100%}
  .empresa-soluciones-card--left .empresa-soluciones-figure{position:relative;width:auto;max-width:none;top:auto;bottom:auto;left:auto;justify-content:center;align-items:center;pointer-events:auto}
  .empresa-soluciones-card--left .empresa-soluciones-copy{margin-left:0;padding-left:0}
  .empresa-soluciones-figure,.empresa-soluciones-side-icon{align-self:center}
}

@media (max-width:560px){
  .empresa-soluciones-card--soft,.empresa-soluciones-card--bg{padding:16px}
  .empresa-soluciones-title{margin:18px auto 14px}
}

.empresa-catalogo{background:#fff;padding:10px 0 44px}
.empresa-catalogo-inner{max-width:1120px;margin:0 auto}
.empresa-catalogo-title{margin:0 0 18px;text-align:center;color:var(--purple-base);font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);line-height:1.15;font-weight:800;letter-spacing:.7px}
.empresa-catalogo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.empresa-catalogo-card{background:linear-gradient(180deg,var(--purple-light),var(--purple-dark));border-radius:16px;padding:22px 16px 20px;min-height:340px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 16px 32px rgba(88,50,126,.12)}
.empresa-catalogo-icon{width:150px;height:150px;border-radius:999px;background:#fff;display:flex;align-items:center;justify-content:center;margin:2px 0 14px;box-shadow:0 10px 22px rgba(35,0,60,.14)}
.empresa-catalogo-icon img{width:122px;height:122px;object-fit:contain;display:block}
.empresa-catalogo-card h3{margin:12px 0 0;color:#fff;font-family:'Montserrat',sans-serif;font-size:var(--fs-h3);line-height:1.18;font-weight:800}
.empresa-catalogo-card p{margin:12px 0 0;color:rgba(255,255,255,.94);font-family:'Montserrat',sans-serif;font-size:var(--fs-body);line-height:1.5}

@media (max-width:900px){
  .empresa-catalogo-grid{grid-template-columns:1fr}
  .empresa-catalogo-card{min-height:auto}
}

.empresa-soporte{background:linear-gradient(180deg,var(--purple-dark),var(--purple-base));padding:0;margin:0;min-height:80vh;display:flex;flex-direction:column;overflow:hidden}
.empresa-soporte-hero{position:relative;width:100%;overflow:hidden;flex:1 1 auto;min-height:0;background:linear-gradient(180deg,var(--purple-dark),var(--purple-base))}
.empresa-soporte-hero img{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:cover;object-position:center center}
.empresa-soporte-card{position:absolute;left:5%;top:16%;max-width:min(360px,42vw);background:rgba(31,16,54,.72);backdrop-filter:blur(4px);border-radius:8px;padding:18px 20px;box-shadow:0 18px 36px rgba(0,0,0,.18)}
.empresa-soporte-card h2{margin:0;color:#fff;font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);line-height:1.18;font-weight:800;letter-spacing:.2px}
.empresa-soporte-info{margin:0;background:#bfe5f7;color:var(--purple-base);padding:0 24px;text-align:center;font-family:'Montserrat',sans-serif;font-size:var(--fs-body);line-height:1.55;flex:0 0 132px;display:flex;align-items:center;justify-content:center}

@media (max-width:900px){
  .empresa-soporte-card{left:4%;top:14%;max-width:min(300px,76vw);padding:14px 16px}
}

@media (max-width:640px){
  .empresa-soporte{min-height:80vh}
  .empresa-soporte-card{left:14px;top:14px;max-width:calc(100% - 28px)}
  .empresa-soporte-info{flex-basis:118px;padding:0 14px}
}

.empresa-contact-strip{background:#fff;padding:36px 0}
.empresa-contact-strip-inner{max-width:760px;margin:0 auto;text-align:center;color:var(--purple-base);font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);font-weight:800;line-height:1.45;letter-spacing:.35px;min-height:150px;display:flex;align-items:center;justify-content:center}

.empresa-contact-hero,.empresa-form-hero{position:relative;width:100%;height:80vh;overflow:hidden;background:#e8f6fb}
.empresa-contact-hero-bg,.empresa-form-hero-bg{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:cover;object-position:center center}
.empresa-contact-hero-card,.empresa-form-hero-card{position:absolute;z-index:2;background:rgba(45,20,70,.72);backdrop-filter:blur(4px);border-radius:8px;box-shadow:0 18px 36px rgba(0,0,0,.2);color:#fff;font-family:'Montserrat',sans-serif}
.empresa-contact-hero-card{left:71%;top:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:min(420px,46vw);padding:20px 22px;text-align:center}
.empresa-form-hero-card{right:8%;top:50%;left:auto;bottom:auto;transform:translateY(-50%);width:min(350px,34vw);padding:16px 18px;background:rgba(0,0,0,.82)}
.empresa-contact-hero-kicker,.empresa-form-hero-kicker{margin:0 0 8px;font-family:'Montserrat',sans-serif;font-size:12px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;opacity:.95}
.empresa-contact-hero-kicker--mt{margin-top:14px}
.empresa-contact-hero-card h2,.empresa-form-hero-card h2{margin:0 0 12px;font-family:'Montserrat',sans-serif;font-size:var(--fs-h2);line-height:1.1;font-weight:800}
.empresa-contact-hero-phone,.empresa-contact-hero-mail{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:10px 14px;border-radius:999px;background:#b2ca1a;color:#32114b;text-decoration:none;font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.1;font-size:var(--fs-small)}
.empresa-contact-hero-phone{gap:8px}
.empresa-contact-hero-mail{background:#b2ca1a;font-size:14px;word-break:break-all}
.empresa-form-hero-form{display:grid;grid-template-columns:1fr;gap:8px;font-family:'Montserrat',sans-serif}
.empresa-form-hero-form label{display:flex;flex-direction:column;gap:6px}
.empresa-form-hero-form label span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.empresa-form-hero-form input,.empresa-form-hero-form textarea{width:100%;border:0;border-radius:999px;padding:9px 14px;font-family:'Montserrat',sans-serif;font-size:var(--fs-form);line-height:1.25;background:rgba(255,255,255,.98);color:#32114b;outline:none}
.empresa-form-hero-form input::placeholder,.empresa-form-hero-form textarea::placeholder{color:#b8b8b8;opacity:1;font-family:'Montserrat',sans-serif;font-size:var(--fs-form)}
.empresa-form-hero-form textarea{display:none}
.empresa-form-hero-form button{border:0;border-radius:999px;padding:10px 18px;background:#b2ca1a;color:#32114b;font-family:'Montserrat',sans-serif;font-size:var(--fs-form);font-weight:800;cursor:pointer;box-shadow:0 10px 18px rgba(0,0,0,.14);width:112px;align-self:center;text-transform:none}

@media (max-width:900px){
  .empresa-contact-hero-card,.empresa-form-hero-card{width:min(360px,86vw)}
  .empresa-contact-hero-card{left:66%;width:min(360px,88vw)}
  .empresa-form-hero-card{right:4%;width:min(340px,80vw)}
}

@media (max-width:640px){
  .empresa-hero{background:linear-gradient(180deg,var(--purple-dark) 0%,var(--purple-base) 100%);padding:18px 0 0}
  .empresa-hero-fullwidth{padding:0 16px;justify-content:center}
  .empresa-hero-image{width:100%;max-width:430px;margin:0 auto;display:block;border-radius:0}
  .empresa-contact-hero,.empresa-form-hero{height:80vh}
  .empresa-contact-hero-card{left:50%;top:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:calc(100% - 28px)}
  .empresa-form-hero-card{right:14px;left:14px;top:50%;bottom:auto;transform:translateY(-50%);width:auto}
  .empresa-contact-strip{padding:28px 0}
  .empresa-contact-strip-inner{font-size:1rem;min-height:124px}
}

/* Carousel */
.carousel{position:relative;width:100%;max-width:1100px;border-radius:12px;overflow:hidden}
.carousel{position:relative;width:100%;max-width:var(--max-width);border-radius:12px;overflow:hidden;margin:0 auto}
.carousel .slides{position:relative;width:100%;height:560px}
.carousel .slide{position:absolute;inset:0;display:none;align-items:center;justify-content:center}
.carousel .slide.active{display:flex}
.carousel img{width:auto;height:560px;max-width:100%;object-fit:contain;object-position:center;display:block}
.carousel-prev,.carousel-next{display:none}
  .carousel-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:18px;display:flex;gap:8px;justify-content:center;padding:0;z-index:40;pointer-events:auto}
  .carousel-dots button{width:12px;height:12px;border-radius:999px;border:0;background:rgba(255,255,255,0.35);cursor:pointer;box-shadow:0 4px 10px rgba(0,0,0,.18)}
  .carousel-dots button.active{background:var(--accent);box-shadow:0 6px 14px rgba(0,0,0,.22)}

/* Service pills (categorías) — diseño estilo banner con borde naranja y pills blancas */
.service-tabs{display:flex;gap:0;align-items:stretch;justify-content:center;max-width:1100px;margin:20px auto;border-radius:28px;padding:4px;border:2px solid var(--pill-left-bg);background:transparent;box-shadow:0 6px 20px rgba(88,50,126,0.08);position:relative;z-index:30}
.service-tabs .pill{display:flex;align-items:center;gap:10px;padding:14px 34px;border:0;background:#fff;cursor:pointer;font-weight:800;font-size:15px;color:var(--brand-purple);min-width:220px;justify-content:center;transition:background .18s ease,color .18s ease,transform .12s ease}
.service-tabs .pill .icon{display:inline-block;font-size:18px;line-height:1}
.service-tabs .pill .text{display:inline-block}
.service-tabs .pill + .pill{border-left:2px solid var(--pill-left-bg)}
.service-tabs .pill:hover{transform:translateY(-2px)}
.service-tabs .pill:focus{outline:2px solid rgba(88,50,126,0.08);outline-offset:3px}
.service-tabs .pill.active{background:var(--pill-left-bg);color:#fff;box-shadow:inset 0 -4px 0 rgba(0,0,0,0.04);transform:none}
.service-tabs .pill:first-child{border-top-left-radius:20px;border-bottom-left-radius:20px}
.service-tabs .pill:last-child{border-top-right-radius:20px;border-bottom-right-radius:20px}

@media (max-width:800px){
  .service-tabs{flex-wrap:wrap;border-radius:12px}
  .service-tabs .pill{min-width:140px;padding:10px 12px;font-size:13px}
}

/* Tabs */
.tabs{display:flex;gap:10px;background:#fff;padding:12px;border-radius:12px;margin-top:28px;justify-content:center}
.tab{padding:12px 18px;border-radius:8px;background:transparent;border:0;font-weight:700}
.tab.active{background:var(--accent);color:#fff}

/* Cards */
.cards{display:flex;gap:18px;padding:28px 0;justify-content:center;flex-wrap:wrap;align-items:flex-start;max-width:1100px;margin:0 auto}

/* Stronger selector to override utility classes and ensure cards are centered */
#plans.cards{
  display:flex !important;
  gap:18px !important;
  padding:28px 0 !important;
  justify-content:center !important;
  flex-wrap:wrap !important;
  align-items:flex-start !important;
  max-width:1100px !important;
  margin:0 auto !important;
}
.card{flex:0 0 221px;width:221px;height:788.016px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 10px 26px rgba(35,0,60,.06);text-align:center;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;margin:0 6px}
.card h3{margin:12px 0}
.card .plan-img{width:100%;height:300px;object-fit:cover;display:block;margin:0 0 12px;border-radius:8px}

/* Features */
.features{background:#fff;padding:0;border-top:0;border-bottom:0}

/* Benefits / feature cards band (white cards on purple background) */
.benefits-band{background:var(--brand-purple);padding:4px 0 4px 0;color:#fff;text-align:center;border-top:0;margin-top:0}
.benefits-inner{max-width:1400px;margin:0 auto;padding:0 12px;display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}
.benefit-card{background:transparent;padding:0;width:200px;height:220px;display:flex;align-items:center;justify-content:center;text-align:center}
.benefit-frame{background:transparent;border-radius:0;padding:0;width:100%;height:100%;box-shadow:none;display:flex;align-items:center;justify-content:center}
.benefit-frame img{max-width:100%;max-height:100%;object-fit:contain;display:block;margin:auto}

@media (max-width:980px){
  .benefits-inner{flex-direction:column;align-items:center}
  .benefit-card{width:86%;max-width:420px;height:auto;padding:12px}
  .benefit-frame{width:100%;height:auto;padding:8px}
  .benefit-frame img{max-width:100%;height:auto}
}

.benefits-heading{max-width:1088px;margin:8px auto 4px auto;padding:0;text-align:center;color:#ffffff;font-weight:800;letter-spacing:0.6px;text-transform:uppercase;font-size:18px}
.benefits-band .benefits-heading{display:block;width:100%}

/* Larger heading on desktop */
@media (min-width:981px){
  .benefits-heading{font-size:32px;margin-top:12px}
  /* Make benefit images and cards larger for desktop screens */
  .benefits-inner{gap:22px}
  .benefit-card{width:260px;height:260px}
  .benefit-frame{width:220px;height:220px}
  .benefit-frame img{max-width:100%;max-height:100%;object-fit:contain}
}

/* Features hero (image + centered thumbnail) */
.features-hero{background:var(--brand-purple);padding:0 0 2px 0}
.features-hero-inner{max-width:1088px;margin:0 auto;padding:0 16px;text-align:center}
.features-hero-img{width:100%;max-width:1088px;height:260px;object-fit:contain;display:block;margin:0 auto;border-radius:8px}

@media (max-width:980px){
  .features-hero-img{height:170px}
}

/* Client features: transparent cards only */
.client-features{background:var(--brand-purple);padding:0 0 4px 0;color:#fff}
.client-features .container{max-width:1088px;margin:0 auto;padding:0 16px}
.client-features-title{margin:0 0 4px 0;text-align:center;color:#fff;font-weight:800;font-size:18px}
.client-features-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:16px;align-items:stretch}
.client-feature-card{background:transparent;border:0;padding:0;display:flex;align-items:center;justify-content:center;min-height:0}
.client-feature-card img{width:100%;height:auto;display:block;object-fit:contain}

@media (max-width:980px){
  .client-features-grid{grid-template-columns:1fr;gap:12px}
  .client-feature-card img{max-width:420px;margin:0 auto}
}

/* News band: 3 white cards on purple background */
.news-band{background:var(--brand-purple);padding:10px 0 18px 0;color:#fff}
.news-band .container{max-width:1088px;margin:0 auto;padding:0 16px}
.news-title{margin:0 0 12px 0;text-align:center;color:#fff;font-weight:800;font-size:18px;letter-spacing:0.4px}
.news-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:14px;align-items:stretch;grid-auto-rows:1fr}
.news-card{background:#fff;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;height:100%;min-height:390px;box-shadow:0 8px 18px rgba(0,0,0,0.14)}
.news-card img{width:calc(100% - 22px);height:188px;object-fit:cover;object-position:center center;display:block;flex:0 0 auto;background:#fff;margin:11px 11px 0;border-radius:10px}
.news-content{padding:8px 10px 10px 10px;display:flex;flex-direction:column;gap:6px;color:#5b2c7a;flex:0 0 auto}
.news-tag{display:inline-flex;align-items:center;align-self:flex-start;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:6px 10px;border-radius:999px}
.news-content h4{margin:0;font-size:14px;line-height:1.2;font-weight:800;color:#5b2c7a;min-height:30px}
.news-content p{margin:0;font-size:12px;line-height:1.35;color:#777;display:-webkit-box;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:42px}
.news-btn{align-self:flex-end;margin-top:2px;display:inline-block;background:var(--accent);color:#fff;text-decoration:none;font-size:12px;font-weight:800;padding:8px 18px;border-radius:999px}

@media (max-width:980px){
  .news-grid{grid-template-columns:1fr}
  .news-card img{width:calc(100% - 18px);height:200px;margin:9px 9px 0}
}

/* Footer */
.footer{background:var(--brand-purple);padding:40px 0;border-top:0;color:#fff}
.footer .cols{display:flex;gap:28px;flex-wrap:wrap;align-items:flex-start}
.footer .col{flex:1;min-width:220px}
.footer h4{color:#ffd9ff;margin:0 0 8px 0;font-size:15px}
.footer ul{margin:0;padding:0}
.footer li{list-style:none;color:rgba(255,255,255,0.92);}
.footer a{color:#fff;text-decoration:none}
.footer a:hover{text-decoration:underline}

/* Social icons in footer */
.footer .social-icons .social-icon{width:36px;height:36px;border-radius:999px;background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--brand-purple);text-decoration:none}
.footer .social-icons .social-icon svg{width:18px;height:18px}
.footer .social-icons .social-icon:hover{filter:brightness(.95)}

/* Footer column alignment: logo left, menu center, social right */
.footer .footer-logo{display:flex;flex-direction:column;align-items:flex-start;text-align:left}
.footer .footer-menu{text-align:center}
.footer .footer-social{display:flex;flex-direction:column;align-items:flex-end;text-align:right}
.footer .footer-social .social-icon{width:42px;height:42px;border-radius:999px;background:#fff;color:var(--brand-purple);display:inline-flex;align-items:center;justify-content:center}
.footer .footer-social .social-icon svg{width:20px;height:20px}
.footer .footer-social .social-icon:hover{transform:translateY(-2px);transition:transform .16s ease}

.whatsapp-float{position:fixed;right:24px;bottom:24px;z-index:50;display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:999px;background:#25d366;color:#fff;text-decoration:none;font-family:'Montserrat',sans-serif;font-weight:800;box-shadow:0 18px 30px rgba(0,0,0,.22)}
.whatsapp-float svg{width:20px;height:20px;flex:0 0 20px}
.whatsapp-float:hover{filter:brightness(.95)}

.floating-cta-container{position:fixed;bottom:20px;right:20px;z-index:999;display:flex;flex-direction:row;align-items:center;gap:8px}
.floating-cta{display:inline-flex;align-items:center;gap:10px;padding:14px 16px;border-radius:10px;text-decoration:none;box-shadow:0 18px 30px rgba(0,0,0,0.18);font-family:'Montserrat',Arial,sans-serif;min-width:220px}
.floating-cta-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border-radius:8px}
.floating-cta-label{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}
.floating-cta-line1{font-size:0.78rem;font-weight:400;color:inherit}
.floating-cta-line2{font-size:0.95rem;font-weight:700;color:inherit}
.floating-cta-phone{background:#ffffff;color:#333;border:1px solid #a6c90a}
.floating-cta-phone .floating-cta-icon{color:#a6c90a}
.floating-cta-whatsapp{background:#25D366;color:#ffffff;border:1px solid rgba(255,255,255,0.18);box-shadow:0 0 24px rgba(37,211,102,0.28)}
.floating-cta-whatsapp .floating-cta-icon{color:#ffffff}

@media (max-width: 640px){
  /* Keep floating CTAs compact and anchored to bottom-right on mobile */
  .floating-cta-container{flex-direction:column;right:14px;bottom:14px;gap:10px;width:auto;align-items:flex-end}
  .floating-cta{min-width:44px;padding:10px 12px;border-radius:12px;gap:8px;box-shadow:0 12px 22px rgba(0,0,0,0.16)}
  .floating-cta-icon{width:28px;height:28px}
  .floating-cta-label{display:none}
}

@media (max-width:640px){
  .whatsapp-float{right:14px;bottom:14px;padding:12px 14px}
  .whatsapp-float span{font-size:13px}
}


  .benefits-band{padding-top:8px}
  .benefits-heading{margin-top:6px}
/* Responsive */
@media (max-width: 980px){
  .hero-inner{flex-direction:column;text-align:center}
  .hero-right{width:100%}
  .nav{display:none}
  .nav.open{display:flex;flex-direction:column;position:absolute;left:20px;right:20px;top:70px;background:#fff;padding:12px;border-radius:8px}
  .cards{flex-direction:column}
  .tabs{overflow-x:auto}

  /* reduce carousel height on small screens */
  .carousel .slides{height:360px}
  .carousel img{height:360px}
}

/* Make selected images ignore the page gutter and go full-bleed */
.hero-carousel-full .carousel img,
.empresa-hero-fullwidth img,
.promo-slide img,
.promo-carousel .promo-slide img,
.carousel img,
.empresa-soporte-hero img,
.empresa-contact-hero-bg,
.empresa-form-hero-bg{
  display:block;
  width: calc(100% + 2 * var(--page-gutter));
  max-width: none;
  margin-left: calc(var(--page-gutter) * -1);
  margin-right: calc(var(--page-gutter) * -1);
}

.empresa-hero-fullwidth .empresa-hero-image{
  width:100%;
  max-width:100%;
  margin-left:0;
  margin-right:0;
}

.empresa-propuesta-visual img{
  width:min(100%,980px);
  max-width:980px;
  margin:0 auto;
  display:block;
  object-fit:cover;
  object-position:center center;
}
@media (max-width:900px){
  :root{--page-gutter:24px}
  .hero-carousel-full .carousel img,
  .empresa-hero-fullwidth img,
  .promo-slide img,
  .promo-carousel .promo-slide img,
  .carousel img,
  .empresa-soporte-hero img,
  .empresa-contact-hero-bg,
  .empresa-form-hero-bg{
    width: calc(100% + 2 * var(--page-gutter));
    margin-left: calc(var(--page-gutter) * -1);
    margin-right: calc(var(--page-gutter) * -1);
  }

  .empresa-hero-fullwidth .empresa-hero-image{
    width:100%;
    margin-left:0;
    margin-right:0;
  }
}

/* Fallback: force a mobile background for empresa hero if <picture> selection fails */
/* no mobile background fallback needed anymore */

/* Promo carousel (full width, before footer) */
.promo-carousel-band{width:100%;padding:0;margin:0;background:transparent;margin-bottom:0}
.promo-carousel{position:relative;width:100%;overflow:hidden;display:block;padding:0;margin:0}
.promo-carousel .promo-carousel-slides{display:flex;width:100%;transition:transform .6s ease;will-change:transform;gap:0;height:480px;overflow:hidden}
.promo-slide{flex:0 0 100%;display:flex;align-items:center;justify-content:center;min-height:480px;padding:0;height:480px}
.promo-slide img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;border-radius:0}
.promo-carousel-prev,.promo-carousel-next{display:none !important}
.promo-carousel-prev,.promo-carousel-next{position:absolute;top:50%;transform:translateY(-50%);z-index:30;background:rgba(0,0,0,0.35);color:#fff;border:0;border-radius:50%;width:44px;height:44px;font-size:22px;align-items:center;justify-content:center;cursor:pointer}
.promo-carousel-prev{left:18px}
.promo-carousel-next{right:18px}
.promo-carousel-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:14px;display:flex;gap:8px;z-index:30}
.promo-carousel-dots button{width:10px;height:10px;border-radius:999px;border:0;background:rgba(0,0,0,0.18);cursor:pointer}
.promo-carousel-dots button.active{background:var(--accent)}

.promo-floating-card{position:absolute;left:6%;top:50%;transform:translateY(-50%);background:rgba(11,6,23,0.60);color:#fff;padding:12px 14px;border-radius:10px;box-shadow:0 12px 30px rgba(0,0,0,0.28);max-width:260px;max-height:220px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;gap:8px;z-index:40}
.promo-floating-card h3{margin:4px 0 6px;font-size:16px;color:#ffffff;line-height:1.15}
.promo-floating-card p{font-size:13px;color:rgba(255,255,255,0.95);line-height:1.3;margin:0;max-height:88px;overflow:hidden}
.promo-floating-card .promo-floating-btn{display:inline-block;margin-top:6px;background:var(--accent);color:#fff;padding:8px 12px;border-radius:8px;text-decoration:none;font-weight:800;align-self:start}

@media (max-width:900px){
  .promo-carousel{padding:0}
  .promo-carousel .promo-carousel-slides{height:360px}
  .promo-slide{min-height:360px;height:360px}
  .promo-slide img{height:100%;object-fit:cover}
  .promo-floating-card{position:relative;right:auto;left:auto;top:auto;transform:none;margin:12px auto 0 auto;max-width:92%;}
  .promo-carousel-dots{position:relative;left:auto;transform:none;bottom:auto;margin-top:12px}
}

/* CTA hero (green) placed between promo and client-features */
.cta-hero{background:var(--brand-purple);padding:18px 0}
.cta-hero-inner{max-width:var(--max-width);margin:0 auto;padding:0 20px}
.cta-box{background:var(--accent);border-radius:14px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 10px 26px rgba(0,0,0,0.12);max-width:980px;margin:0 auto}
.cta-content{color:#fff}
.cta-kicker{margin:0;font-size:14px;opacity:0.95}
.cta-title{margin:6px 0 0;font-size:36px;line-height:1;letter-spacing:-0.5px}
.cta-actions{display:flex;align-items:center}
.cta-btn{background:var(--brand-purple);border-radius:14px;padding:10px 18px;box-shadow:0 8px 22px rgba(88,50,126,0.18);font-weight:800}

@media (max-width:980px){
  .cta-box{flex-direction:column;align-items:flex-start;padding:16px}
  .cta-title{font-size:28px}
  .cta-actions{width:100%;display:flex;justify-content:flex-end}
}

/* ==========================================================
   Ajustes solicitados: animaciones globales, logo, teléfonos
   y carrusel de beneficios.
   ========================================================== */
html{scroll-behavior:smooth}
body{overflow-x:hidden}

/* Teléfonos visibles en header */
.topbar-sales .flex{gap:8px;flex-wrap:wrap}
.topbar-sales .sales-link-secondary{background:#4f366e;color:#fff}
header a[href^="tel:"]{white-space:nowrap}
@media (max-width:768px){
  .topbar-sales .flex{justify-content:center!important;padding-left:10px;padding-right:10px}
  .topbar-sales .sales-link{font-size:12px;padding:8px 10px}
}

/* Logo más grande y más visible */
.logo-wrap{height:82px;min-width:210px;display:inline-flex;align-items:center;overflow:visible}
.logo-wrap img.empresa-header-logo{height:190px;max-width:380px;filter:drop-shadow(0 10px 18px rgba(58,36,79,.16))}
.empresa-header-logo{height:112px;max-width:340px}
@media (max-width:768px){
  .logo-wrap{height:78px;min-width:150px}
  .logo-wrap img.empresa-header-logo.empresa-header-logo--mobile{height:138px;max-width:none}
  .empresa-header-logo--mobile{height:70px;max-width:240px}
}
@media (max-width:420px){
  .logo-wrap{height:70px;min-width:132px}
  .logo-wrap img.empresa-header-logo.empresa-header-logo--mobile{height:118px}
}

/* Animaciones de carga y scroll - VERSIÓN MEJORADA Y VISIBLE */
.scroll-reveal{will-change:transform,opacity,visibility}

/* Estado inicial de los elementos - ocultos pero listos para animación */
.js-enabled .scroll-reveal{
  opacity: 0;
  transform: translate3d(0, 50px, 0);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  transition-delay: var(--reveal-delay, 0ms);
}

/* Diferentes direcciones de animación */
.js-enabled .scroll-reveal[data-animate="from-left"]{
  transform: translate3d(-80px, 0, 0);
}
.js-enabled .scroll-reveal[data-animate="from-right"]{
  transform: translate3d(80px, 0, 0);
}
.js-enabled .scroll-reveal[data-animate="zoom"]{
  transform: translate3d(0, 0, 0) scale(0.85);
}
.js-enabled .scroll-reveal[data-animate="fade-up"]{
  transform: translate3d(0, 40px, 0);
}

/* Estado visible - animación activada */
.js-enabled .scroll-reveal.is-visible,
.js-enabled .scroll-reveal.visible{
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

/* Animación especial para el header */
.page-loaded header.scroll-reveal.is-visible{
  animation: fmHeaderDrop 0.8s cubic-bezier(0.2, 0.75, 0.2, 1) both;
}

/* Animación de carga del hero */
.load-reveal.is-visible{
  animation: fmHeroLoad 1.2s cubic-bezier(0.2, 0.75, 0.2, 1) both;
}

/* Efectos hover en tarjetas */
.plan-card,.service-card,.info-card,.value-card,.news-card,.empresa-soluciones-card,.benefit-card{
  transition-property: transform, box-shadow, opacity, filter;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.plan-card:hover,.service-card:hover,.info-card:hover,.value-card:hover,.news-card:hover,.empresa-soluciones-card:hover,.benefit-card:hover{
  transform: translateY(-8px);
}

/* Keyframes para animaciones */
@keyframes fmHeaderDrop{
  from{opacity: 0; transform: translateY(-30px);}
  to{opacity: 1; transform: translateY(0);}
}

@keyframes fmHeroLoad{
  0%{opacity: 0; transform: scale(1.05);}
  100%{opacity: 1; transform: scale(1);}
}

/* Animación de entrada para elementos específicos */
@keyframes fadeInUp{
  from{opacity: 0; transform: translate3d(0, 60px, 0);}
  to{opacity: 1; transform: translate3d(0, 0, 0);}
}

@keyframes fadeInLeft{
  from{opacity: 0; transform: translate3d(-60px, 0, 0);}
  to{opacity: 1; transform: translate3d(0, 0, 0);}
}

@keyframes fadeInRight{
  from{opacity: 0; transform: translate3d(60px, 0, 0);}
  to{opacity: 1; transform: translate3d(0, 0, 0);}
}

@keyframes scaleIn{
  from{opacity: 0; transform: scale(0.9);}
  to{opacity: 1; transform: scale(1);}
}

/* Clases de utilidad para animaciones manuales */
.animate-fade-in-up{
  animation: fadeInUp 0.8s ease forwards;
}
.animate-fade-in-left{
  animation: fadeInLeft 0.8s ease forwards;
}
.animate-fade-in-right{
  animation: fadeInRight 0.8s ease forwards;
}
.animate-scale-in{
  animation: scaleIn 0.8s ease forwards;
}

/* Reducirmotion para accesibilidad */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior: auto}
  .js-enabled .scroll-reveal,
  .load-reveal.is-visible,
  .page-loaded header.scroll-reveal.is-visible{
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
}

/* Carrusel de ¿Por qué elegirnos? */
.benefits-band{padding:18px 0 24px;background:linear-gradient(180deg,var(--brand-purple),var(--purple-dark))}
.benefits-heading{margin:4px auto 18px;font-size:clamp(1.55rem,3vw,2.35rem);letter-spacing:.8px}
.benefits-carousel{position:relative;max-width:1180px;margin:0 auto;padding:0 68px 24px}
.benefits-viewport{overflow:hidden;border-radius:28px;padding:6px 0}
.benefits-inner{display:flex!important;flex-wrap:nowrap!important;align-items:stretch!important;justify-content:flex-start!important;gap:22px!important;transition:transform .7s cubic-bezier(.2,.75,.2,1);will-change:transform;padding:0 2px}
.benefit-card{flex:0 0 calc((100% - 44px)/3)!important;width:auto!important;height:260px!important;min-width:0;padding:0!important;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:26px;box-shadow:0 20px 45px rgba(0,0,0,.14);backdrop-filter:blur(10px)}
.benefit-frame{width:100%!important;height:100%!important;padding:18px!important;border-radius:26px;background:rgba(255,255,255,.04)}
.benefit-frame img{width:100%;height:100%;max-height:100%!important;object-fit:contain;transition:transform .5s ease,filter .5s ease}
.benefit-card:hover .benefit-frame img{transform:scale(1.045);filter:drop-shadow(0 12px 18px rgba(0,0,0,.2))}
.benefits-nav{position:absolute;top:46%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border:0;border-radius:999px;background:#fff;color:var(--brand-purple);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 16px 35px rgba(0,0,0,.18);cursor:pointer;transition:transform .25s ease,opacity .25s ease,background .25s ease}
.benefits-nav svg{width:24px;height:24px}
.benefits-nav:hover{transform:translateY(-50%) scale(1.06);background:var(--accent);color:#fff}
.benefits-nav:disabled{opacity:.38;cursor:default;transform:translateY(-50%)}
.benefits-prev{left:8px}
.benefits-next{right:8px}
.benefits-dots{position:absolute;left:50%;bottom:0;transform:translateX(-50%);display:flex;gap:8px;align-items:center;justify-content:center}
.benefits-dots button{width:10px;height:10px;border:0;border-radius:999px;background:rgba(255,255,255,.34);cursor:pointer;transition:width .25s ease,background .25s ease}
.benefits-dots button.active{width:28px;background:var(--accent)}
@media (max-width:1023px){
  .benefits-carousel{padding-left:56px;padding-right:56px}
  .benefit-card{flex-basis:calc((100% - 22px)/2)!important;height:250px!important}
}
@media (max-width:639px){
  .benefits-band{padding-top:20px}
  .benefits-carousel{padding-left:44px;padding-right:44px}
  .benefit-card{flex-basis:100%!important;height:250px!important}
  .benefits-nav{width:38px;height:38px}
  .benefits-prev{left:2px}.benefits-next{right:2px}
}

/* Contacto empresas/negocios: dos números separados */
.empresa-contact-phone-list{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:8px}
.empresa-contact-phone-list .empresa-contact-hero-phone{margin:0}
@media (max-width:640px){
  .empresa-contact-phone-list{flex-direction:column;align-items:center}
  .empresa-contact-phone-list .empresa-contact-hero-phone{width:100%;justify-content:center}
}
/* Correcciones finales del carrusel para neutralizar reglas antiguas en responsive */
.benefits-inner{flex-direction:row!important}
.benefit-card{max-width:none!important}


/* === Final reveal-on-scroll + Internet dedicado redesign === */
.js-enabled .scroll-reveal{
  opacity:0;
  transform:translate3d(0,44px,0);
  transition:opacity .72s cubic-bezier(.2,.75,.2,1), transform .72s cubic-bezier(.2,.75,.2,1), filter .72s cubic-bezier(.2,.75,.2,1);
  transition-delay:var(--reveal-delay,0ms);
  filter:blur(3px);
}
.js-enabled .scroll-reveal[data-animate="from-left"]{transform:translate3d(-56px,0,0)}
.js-enabled .scroll-reveal[data-animate="from-right"]{transform:translate3d(56px,0,0)}
.js-enabled .scroll-reveal[data-animate="zoom"]{transform:translate3d(0,22px,0) scale(.94)}
.js-enabled .scroll-reveal[data-animate="fade-up"]{transform:translate3d(0,44px,0)}
.js-enabled .scroll-reveal.is-visible,
.js-enabled .scroll-reveal.visible{opacity:1;transform:translate3d(0,0,0) scale(1);filter:blur(0)}
.scroll-reveal{backface-visibility:hidden;transform-style:preserve-3d}

.dedicated-body{background:#f6f3fb;color:#1f1830}
.dedicated-page{background:#f7f4fb;overflow:hidden}
.dedicated-page *{box-sizing:border-box}
.dedicated-container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.dedicated-page > section{position:relative;padding:clamp(54px,7vw,92px) 0;min-height:auto;max-height:none;overflow:hidden}
.dedicated-hero{display:flex;align-items:center;color:#fff;min-height:min(720px,calc(100vh - 128px));padding:clamp(56px,7vw,86px) 0!important}
.dedicated-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)}
.dedicated-hero:after{content:"";position:absolute;right:-8%;top:8%;width:360px;height:360px;border-radius:999px;background:rgba(166,201,10,.22);filter:blur(60px)}
.dedicated-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:clamp(28px,5vw,70px);align-items:center}
.dedicated-hero-copy h1{margin:14px 0 0;font-size:clamp(2.6rem,6vw,5.5rem);line-height:.93;letter-spacing:-.07em;font-weight:900;max-width:850px}
.dedicated-lead{margin:24px 0 0;max-width:690px;font-size:clamp(1.02rem,1.6vw,1.22rem);line-height:1.75;color:rgba(255,255,255,.9)}
.dedicated-kicker{display:inline-flex;align-items:center;gap:10px;margin:0;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:900;color:#a6c90a}
.dedicated-kicker:before{content:"";width:38px;height:2px;border-radius:999px;background:currentColor}
.dedicated-kicker.dark{color:var(--purple-base)}
.dedicated-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.dedicated-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:13px 22px;border-radius:999px;text-decoration:none;font-weight:900;transition:transform .24s ease,box-shadow .24s ease,background .24s ease;color:inherit}
.dedicated-btn:hover{transform:translateY(-3px)}
.dedicated-btn-primary{background:#a6c90a;color:#141414;box-shadow:0 18px 36px rgba(166,201,10,.28)}
.dedicated-btn-ghost{border:1px solid rgba(255,255,255,.28);color:#fff;background:rgba(255,255,255,.08);backdrop-filter:blur(10px)}
.dedicated-hero-card{padding:28px;border-radius:32px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);box-shadow:0 30px 90px rgba(0,0,0,.25);backdrop-filter:blur(18px)}
.dedicated-card-label{display:inline-flex;margin-bottom:16px;color:#a6c90a;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:900}
.dedicated-hero-card ul{margin:0;padding:0;display:grid;gap:14px;list-style:none;color:rgba(255,255,255,.9);line-height:1.55}
.dedicated-hero-card li{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.16)}
.dedicated-hero-card li:last-child{border-bottom:0}
.dedicated-mini-link{display:inline-flex;margin-top:18px;padding:12px 18px;border-radius:999px;background:#fff;color:var(--purple-base);font-weight:900;text-decoration:none}
.dedicated-intro-section{background:#fff}
.dedicated-intro-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.86fr);gap:36px;align-items:center}
.dedicated-copy-panel{padding:clamp(28px,5vw,54px);border-radius:34px;background:linear-gradient(135deg,#fff,#f6f1ff);box-shadow:0 24px 70px rgba(79,54,110,.11);border:1px solid rgba(79,54,110,.08)}
.dedicated-copy-panel h2,.dedicated-section-heading h2,.dedicated-sla-card h2,.dedicated-faq-grid h2,.dedicated-cta-card h2{margin:14px 0 0;color:#201133;font-size:clamp(2rem,4vw,3.5rem);line-height:1;letter-spacing:-.055em;font-weight:900}
.dedicated-copy-panel p:not(.dedicated-kicker),.dedicated-sla-card p,.dedicated-faq-list p,.dedicated-cta-card p{margin:18px 0 0;color:#5c5267;line-height:1.78;font-size:1rem}
.dedicated-image-panel{min-height:360px;border-radius:34px;overflow:hidden;box-shadow:0 32px 80px rgba(79,54,110,.18);background:#e8e1ef}
.dedicated-image-panel img{width:100%;height:100%;min-height:360px;object-fit:cover;display:block}
.dedicated-carousel-section{background:radial-gradient(circle at top left,rgba(166,201,10,.18),transparent 34%),linear-gradient(135deg,#f8f5ff,#fff)}
.dedicated-section-heading{max-width:760px;margin:0 0 28px}
.dedicated-section-heading.centered{text-align:center;margin-left:auto;margin-right:auto}
.dedicated-section-heading.centered .dedicated-kicker{justify-content:center}
.dedicated-carousel{position:relative;border-radius:38px;overflow:hidden;box-shadow:0 34px 90px rgba(32,17,51,.18);background:#201133;min-height:420px;height:min(58vh,560px);max-height:620px;outline:none}
.dedicated-carousel-track,.dedicated-slide{position:absolute;inset:0}
.dedicated-slide{opacity:0;pointer-events:none;transition:opacity .65s ease,transform .65s ease;transform:scale(1.015)}
.dedicated-slide.is-active{opacity:1;pointer-events:auto;transform:scale(1)}
.dedicated-slide img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.04)}
.dedicated-slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(32,17,51,.88),rgba(32,17,51,.42),rgba(32,17,51,.05))}
.dedicated-slide-content{position:absolute;z-index:2;left:clamp(24px,6vw,72px);bottom:clamp(28px,6vw,70px);max-width:560px;color:#fff}
.dedicated-slide-content span{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:16px;background:#a6c90a;color:#161616;font-weight:900;box-shadow:0 14px 30px rgba(166,201,10,.25)}
.dedicated-slide-content h3{margin:18px 0 0;font-size:clamp(2rem,4vw,4rem);letter-spacing:-.05em;line-height:.98;font-weight:900;color:#fff}
.dedicated-slide-content p{margin:14px 0 0;color:rgba(255,255,255,.9);font-size:1.05rem;line-height:1.65;max-width:490px}
.dedicated-carousel-btn{position:absolute;z-index:4;top:50%;transform:translateY(-50%);width:48px;height:48px;border:0;border-radius:999px;background:rgba(255,255,255,.9);color:var(--purple-base);font-size:32px;line-height:1;cursor:pointer;box-shadow:0 12px 30px rgba(0,0,0,.2);transition:transform .2s ease,background .2s ease}
.dedicated-carousel-btn:hover{transform:translateY(-50%) scale(1.06);background:#a6c90a;color:#111}
.dedicated-carousel-prev{left:18px}.dedicated-carousel-next{right:18px}
.dedicated-carousel-dots{position:absolute;z-index:4;left:50%;bottom:20px;transform:translateX(-50%);display:flex;gap:8px}
.dedicated-carousel-dots button{width:11px;height:11px;border:0;border-radius:999px;background:rgba(255,255,255,.45);cursor:pointer;transition:width .25s ease,background .25s ease}
.dedicated-carousel-dots button.is-active{width:32px;background:#a6c90a}
.dedicated-plans-section{background:#f6f3fb}
.dedicated-plans-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin-top:30px}
.dedicated-plan-card{position:relative;padding:32px;border-radius:30px;background:#fff;border:1px solid rgba(79,54,110,.1);box-shadow:0 22px 60px rgba(79,54,110,.1);overflow:hidden;display:flex;flex-direction:column;min-height:285px}
.dedicated-plan-card:before{content:"";position:absolute;inset:0 0 auto 0;height:8px;background:#a6c90a}
.dedicated-plan-card.featured{background:linear-gradient(180deg,var(--purple-base),var(--purple-dark));color:#fff;transform:translateY(-10px)}
.dedicated-plan-card span{font-size:.9rem;letter-spacing:.14em;text-transform:uppercase;font-weight:900;color:var(--purple-base)}
.dedicated-plan-card.featured span{color:#a6c90a}
.dedicated-plan-card strong{display:block;margin-top:18px;font-size:clamp(2.1rem,4vw,3.4rem);line-height:1;font-weight:900;color:inherit;letter-spacing:-.05em}
.dedicated-plan-card p{margin:18px 0 28px;line-height:1.7;color:#5d5368}.dedicated-plan-card.featured p{color:rgba(255,255,255,.85)}
.dedicated-plan-card a{margin-top:auto;display:inline-flex;align-self:flex-start;padding:12px 20px;border-radius:999px;background:#a6c90a;color:#111;font-weight:900;text-decoration:none}
.dedicated-sla-section{background:#fff}
.dedicated-sla-card{display:grid;grid-template-columns:minmax(0,.9fr) minmax(360px,1fr);gap:30px;align-items:center;padding:clamp(30px,5vw,56px);border-radius:38px;background:linear-gradient(135deg,#f9f7ff,#fff);box-shadow:0 24px 80px rgba(79,54,110,.11);border:1px solid rgba(79,54,110,.08)}
.dedicated-metrics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:0}
.dedicated-metric{padding:24px 16px;border-radius:24px;background:#fff;text-align:center;box-shadow:0 16px 42px rgba(79,54,110,.09);border:1px solid rgba(79,54,110,.08)}
.dedicated-metric dt{font-weight:800;color:#5b5265}.dedicated-metric dd{margin:10px 0 0;color:var(--purple-base);font-size:clamp(1.8rem,3vw,2.7rem);font-weight:900;letter-spacing:-.04em}
.dedicated-faq-section{background:#f6f3fb}.dedicated-faq-grid{display:grid;grid-template-columns:minmax(0,.72fr) minmax(0,1fr);gap:38px;align-items:start}.dedicated-faq-list{display:grid;gap:16px}.dedicated-faq-list details{padding:22px 24px;border-radius:24px;background:#fff;box-shadow:0 18px 46px rgba(79,54,110,.09);border:1px solid rgba(79,54,110,.08)}.dedicated-faq-list summary{cursor:pointer;font-weight:900;color:#25143a;line-height:1.45}.dedicated-faq-list summary::marker{color:#a6c90a}
.dedicated-final-cta{background:linear-gradient(135deg,var(--purple-base),var(--purple-dark));color:#fff;padding:clamp(46px,6vw,72px) 0!important}.dedicated-cta-card{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(26px,5vw,44px);border:1px solid rgba(255,255,255,.18);border-radius:34px;background:rgba(255,255,255,.08);box-shadow:0 28px 80px rgba(0,0,0,.22);backdrop-filter:blur(14px)}.dedicated-cta-card h2{color:#fff}.dedicated-cta-card p{color:rgba(255,255,255,.84);max-width:620px}
@media (max-width:900px){
  .dedicated-page > section{padding:50px 0}.dedicated-hero{min-height:auto;padding:54px 0!important}.dedicated-hero-grid,.dedicated-intro-grid,.dedicated-sla-card,.dedicated-faq-grid{grid-template-columns:1fr}.dedicated-hero-card{max-width:100%}.dedicated-image-panel,.dedicated-image-panel img{min-height:300px}.dedicated-plans-grid,.dedicated-metrics-grid{grid-template-columns:1fr}.dedicated-plan-card.featured{transform:none}.dedicated-carousel{height:min(62vh,500px);min-height:390px}.dedicated-slide:after{background:linear-gradient(0deg,rgba(32,17,51,.9),rgba(32,17,51,.35),rgba(32,17,51,.08))}.dedicated-slide-content{left:24px;right:24px;bottom:54px}.dedicated-carousel-btn{display:none}.dedicated-cta-card{align-items:flex-start;flex-direction:column}.dedicated-container{width:min(100% - 28px,1180px)}
}
@media (max-width:560px){
  .dedicated-hero-copy h1{font-size:2.5rem}.dedicated-copy-panel h2,.dedicated-section-heading h2,.dedicated-sla-card h2,.dedicated-faq-grid h2,.dedicated-cta-card h2{font-size:2rem}.dedicated-actions{flex-direction:column}.dedicated-btn{width:100%}.dedicated-carousel{height:430px;min-height:430px;border-radius:28px}.dedicated-slide-content h3{font-size:2rem}.dedicated-slide-content p{font-size:.95rem}.dedicated-hero-card{padding:22px;border-radius:26px}.dedicated-copy-panel{padding:26px;border-radius:26px}.dedicated-plan-card{min-height:250px}.dedicated-final-cta .dedicated-btn{width:100%}
}
@media (prefers-reduced-motion:reduce){.dedicated-slide,.dedicated-carousel-btn,.dedicated-carousel-dots button{transition:none!important}}


/* === Fix final: Reveal on Scroll robusto + cards PNG transparentes empresa.html === */
.js-enabled .scroll-reveal{
  opacity:0!important;
  transform:translate3d(0,48px,0)!important;
  filter:blur(4px);
  transition:opacity .85s cubic-bezier(.2,.75,.2,1), transform .85s cubic-bezier(.2,.75,.2,1), filter .85s cubic-bezier(.2,.75,.2,1)!important;
  transition-delay:var(--reveal-delay,0ms)!important;
}
.js-enabled .scroll-reveal[data-animate="from-left"]{transform:translate3d(-64px,0,0)!important}
.js-enabled .scroll-reveal[data-animate="from-right"]{transform:translate3d(64px,0,0)!important}
.js-enabled .scroll-reveal[data-animate="zoom"]{transform:translate3d(0,28px,0) scale(.9)!important}
.js-enabled .scroll-reveal[data-animate="fade-up"]{transform:translate3d(0,48px,0)!important}
.js-enabled .scroll-reveal.is-visible,
.js-enabled .scroll-reveal.visible{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
  filter:blur(0)!important;
}

.empresa-soluciones--png{
  background:linear-gradient(180deg,#fff 0%,#f7f4fb 100%);
  padding:clamp(34px,5vw,70px) 0!important;
  overflow:hidden;
}
.empresa-soluciones--png .empresa-soluciones-title{
  margin:0 auto clamp(20px,3vw,34px)!important;
}
.empresa-png-card-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:clamp(12px,1.6vw,22px);
  align-items:center;
  justify-items:center;
  width:100%;
}
.empresa-png-card{
  width:100%;
  min-height:clamp(210px,24vw,330px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0!important;
  margin:0;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.empresa-png-card img{
  width:100%;
  height:clamp(210px,24vw,330px);
  object-fit:contain;
  display:block;
  background:transparent!important;
  filter:drop-shadow(0 18px 24px rgba(36,20,56,.16));
  transition:transform .35s ease,filter .35s ease;
}
.empresa-png-card:hover img{
  transform:translateY(-8px) scale(1.035);
  filter:drop-shadow(0 24px 30px rgba(36,20,56,.22));
}
@media (max-width:1100px){
  .empresa-png-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:700px){
  .empresa-png-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .empresa-png-card{min-height:210px}
  .empresa-png-card img{height:210px}
}
@media (max-width:420px){
  .empresa-png-card-grid{grid-template-columns:1fr}
  .empresa-png-card{min-height:240px}
  .empresa-png-card img{height:240px;max-width:320px}
}


/* === Ajuste final solicitado: menú mobile centrado y contacto sin animación === */
@media (max-width: 767px){
  #mobileMenu{
    background: radial-gradient(circle at top center, rgba(166,201,10,.18), transparent 38%), #4f366e !important;
    color:#fff;
    padding:0 !important;
  }
  #mobileMenu > .container{
    width:100%;
    max-width:none;
    min-height:100% !important;
    padding:22px 18px 28px !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
  }
  #mobileMenu > .container > .flex:first-child{
    width:100%;
    justify-content:center !important;
    align-items:center !important;
    margin:0 auto 20px !important;
  }
  #mobileMenu > .container > .flex:first-child > div{
    width:100%;
    max-width:310px;
    margin:0 auto;
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    justify-content:center !important;
    gap:10px !important;
    text-align:center !important;
  }
  #mobileMenu > .container > .flex:first-child span{
    display:none !important;
  }
  #mobileMenu > .container > .flex:first-child a{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:38px;
    padding:10px 12px !important;
    border:1px solid rgba(255,255,255,.18);
    border-radius:999px;
    background:rgba(255,255,255,.08);
    color:#fff !important;
    font-size:10px !important;
    line-height:1.15 !important;
    font-weight:800 !important;
    letter-spacing:.35px !important;
    text-transform:uppercase;
    box-shadow:0 8px 18px rgba(22,7,38,.16);
  }
  #mobileMenu > .container > .flex:first-child a.text-\[\#a6c90a\],
  #mobileMenu > .container > .flex:first-child a.active{
    color:#a6c90a !important;
    border-color:rgba(166,201,10,.45);
    background:rgba(166,201,10,.12);
  }
  #mobileMenu .flex-1{
    width:100%;
    flex:0 0 auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
  }
  #mobileMenu nav{
    width:min(100%,285px);
    margin:0 auto !important;
    padding:0 !important;
    display:grid !important;
    gap:12px !important;
    text-align:center !important;
  }
  #mobileMenu nav a{
    width:100%;
    min-height:48px;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:13px 18px !important;
    border-radius:18px !important;
    background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.12);
    color:#fff !important;
    font-size:15px !important;
    line-height:1.15 !important;
    font-weight:800 !important;
    letter-spacing:.1px;
    box-shadow:0 12px 26px rgba(22,7,38,.13);
  }
  #mobileMenu nav a:hover,
  #mobileMenu nav a:focus-visible{
    background:rgba(255,255,255,.12);
    outline:none;
  }
  #mobileMenu nav a:last-child{
    margin-top:4px !important;
    background:#a6c90a !important;
    border-color:#a6c90a !important;
    color:#32114b !important;
    border-radius:999px !important;
    min-height:46px;
    box-shadow:0 14px 28px rgba(166,201,10,.22);
  }

  #mobileMenu a::after{display:none !important;content:none !important;}
  #mobileMenu nav a.active{
    color:#a6c90a !important;
    border-color:rgba(166,201,10,.42);
    background:rgba(166,201,10,.10);
  }
  #mobileMenu nav a:last-child.active{
    color:#32114b !important;
  }
}

/* La sección de contacto no debe usar reveal porque su card se posiciona con transform. */
#contacto[data-no-reveal],
#contacto[data-no-reveal] *{
  opacity:1 !important;
  filter:none !important;
}
#contacto[data-no-reveal] .scroll-reveal,
#contacto[data-no-reveal].scroll-reveal{
  transition:none !important;
}
#contacto[data-no-reveal] .empresa-contact-hero-bg,
#contacto[data-no-reveal] .empresa-contact-hero-bg.scroll-reveal{
  transform:none !important;
}
#contacto[data-no-reveal] .empresa-contact-hero-card,
#contacto[data-no-reveal] .empresa-contact-hero-card.scroll-reveal,
#contacto[data-no-reveal] .empresa-contact-hero-card.scroll-reveal.is-visible,
#contacto[data-no-reveal] .empresa-contact-hero-card.scroll-reveal.visible{
  transform:translate(-50%,-50%) !important;
  opacity:1 !important;
  filter:none !important;
  transition:none !important;
}
