
/* HERO */
.hero{
  min-height:auto;
  display:flex;align-items:center;justify-content:center;
  padding:10rem 1.75rem 4rem;
  text-align:center;
  position:relative;
  background:linear-gradient(180deg,#eaeff5 0%,#e0e8f2 40%,#d8e2ee 100%);
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(59,130,246,.1) 1px,transparent 1px);
  background-size:32px 32px;
  z-index:0;
  pointer-events:none;
}
.hero-blob-1{
  position:absolute;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(96,165,250,.10),transparent 70%);
  top:-15%;right:-10%;
  filter:blur(60px);
  z-index:0;
  pointer-events:none;
}
.hero-blob-2{
  position:absolute;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.08),transparent 70%);
  bottom:-10%;left:-8%;
  filter:blur(50px);
  z-index:0;
  pointer-events:none;
}
.hero-blob-3{
  position:absolute;
  width:300px;height:300px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(147,197,253,.07),transparent 70%);
  top:40%;left:50%;
  transform:translate(-50%,-50%);
  filter:blur(40px);
  z-index:0;
  pointer-events:none;
}
.hero-inner{max-width:840px;margin:0 auto;position:relative;z-index:3}
.hero-title{
  font-size:clamp(2.6rem,7.5vw,5.4rem);
  margin-bottom:1.5rem;
  letter-spacing:-0.045em;
  font-weight:800;
  line-height:1.1;
}
.title-line{
  display:block;
  color:var(--slate-900);
  font-style:normal;
  font-weight:800;
  opacity:0;
  transform:translateY(40px);
  animation:heroSlideUp 0.8s ease-out forwards;
}
.title-line:nth-child(1){animation-delay:0.1s}
.title-line:nth-child(2){animation-delay:0.2s}
.title-line:nth-child(3){animation-delay:0.3s}
.title-blue{color:var(--blue-500)}
@keyframes heroSlideUp{
  to{opacity:1;transform:translateY(0)}
}
@keyframes heroSubBlur{
  from{opacity:0;filter:blur(10px)}
  to{opacity:1;filter:blur(0)}
}
.hw{
  display:inline-block;
  opacity:0;
  filter:blur(8px);
  animation:heroSubBlur .6s ease-out forwards;
}
.hero-sub{
  font-size:clamp(1.1rem,2.2vw,1.35rem);
  color:var(--slate-600);
  max-width:720px;
  margin:0 auto 2.5rem;
  line-height:1.55;
  white-space:nowrap;
}

/* SECTIONS */
.section{
  position:relative;z-index:1;
  padding:5rem 2rem;
  max-width:1180px;margin:0 auto;
  background:transparent;
}
.section-animate{opacity:0;transform:translateY(40px);transition:opacity 0.8s ease,transform 0.8s ease}
.section-animate.visible{opacity:1;transform:translateY(0)}

.eyebrow{
  display:inline-block;
  font-family:'Poppins',sans-serif;
  font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-500);
  margin-bottom:1rem;
  padding:.35rem .75rem;
  background:rgba(59,130,246,.08);
  border-radius:999px;
}

.section-heading{
  font-size:clamp(1.8rem,4vw,2.6rem);
  color:var(--slate-900);
  margin-bottom:1.1rem;
  letter-spacing:-0.03em;
  text-align:center;
}
.section-sub{
  font-size:1.08rem;color:var(--slate-600);
  max-width:680px;line-height:1.7;
  text-align:center;
  margin:0 auto 3rem;
}

/* GLASS CARDS */
.pain-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;margin-top:3rem;
}
.pain-card{
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--slate-200);
  border-radius:20px;
  padding:2.5rem 2rem;
  text-align:center;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.pain-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 30px rgba(59,130,246,.08);
  border-color:#93c5fd;
}
.pain-card-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(96,165,250,.06));
  color:var(--blue-500);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1rem;
}
.pain-card-icon svg{width:20px;height:20px}
#caso-solucion .pain-card-icon{margin:0 auto 1rem}
#servicios-cards .pain-card{text-align:left}
#servicios-cards .pain-card-icon{margin:0 0 1.25rem}
#casos-cards .pain-card{text-align:left;padding-top:3.35rem}
#casos-cards .pain-card.pain-card--caso{position:relative}
.caso-badge{
  position:absolute;top:1.35rem;right:1.35rem;
  font-size:.72rem;font-weight:700;
  color:#fff;background:var(--blue-500);
  padding:.42rem .85rem;border-radius:999px;
  white-space:normal;max-width:min(200px,55%);text-align:right;line-height:1.25;
  box-shadow:0 2px 10px rgba(37,99,235,.28);
  z-index:1;
}
#casos-cards .pain-card h3{font-size:1.08rem;line-height:1.38;margin-top:.35rem;margin-bottom:.85rem}
.caso-block-title{
  font-family:'Poppins',sans-serif;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue-500);margin-top:1.15rem;margin-bottom:.45rem;
}
#casos-cards .pain-card .caso-block-title--first{margin-top:.55rem}
#casos-cards .pain-card .caso-block-text{font-size:.94rem;color:var(--slate-600);line-height:1.7;margin:0}
#casos-cards .pain-card .eyebrow{margin-right:6.5rem}
#casos-cards .pain-card .service-bullets{margin-top:.35rem}
.caso-detail-inner{max-width:720px;margin:0 auto}
.caso-solucion-title{
  font-size:1.6rem;
  color:var(--slate-900);
  margin-bottom:1.5rem;
  text-align:center;
}
.caso-solucion-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1rem;
}
.caso-solucion-card{
  background:linear-gradient(135deg,#0B0F14,#101318);
  border:1px solid rgba(11,27,54,.28);
  border-radius:16px;
  padding:1.5rem;
  text-align:center;
}
.caso-solucion-card h4{
  color:#fff;
  font-size:.95rem;
  margin:0 0 .4rem;
}
.caso-solucion-card p{
  color:rgba(255,255,255,.65);
  font-size:.82rem;
  line-height:1.6;
  margin:0;
}
.caso-detail-inner .section-heading{text-align:left;margin-bottom:1rem}
.caso-detail-inner > p{font-size:1.05rem;color:var(--slate-600);line-height:1.8;margin:0}
.metric-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.5rem;
  margin-top:.25rem;
}
.metric-card{
  background:linear-gradient(145deg,var(--blue-500) 0%,#1e40af 100%);
  color:#fff;
  border-radius:10px;
  padding:.5rem .65rem;
  text-align:center;
  box-shadow:0 4px 14px rgba(37,99,235,.18);
  font-size:.8rem;font-weight:500;line-height:1.25;
  font-family:'Poppins',sans-serif;
  white-space:nowrap;
}
@media(max-width:768px){
  .metric-grid{gap:.45rem;grid-template-columns:1fr}
  .metric-card{padding:.48rem .6rem;font-size:.78rem;border-radius:9px;white-space:normal}
}
.caso-conclusion{
  background:rgba(59,130,246,.08);
  border:1px solid rgba(59,130,246,.22);
  border-radius:20px;
  padding:2rem 2.25rem;
  margin-top:.5rem;
}
.caso-conclusion p{
  font-size:1.1rem;color:var(--slate-800);
  font-style:italic;line-height:1.65;margin:0;
}
.pain-card h3{font-size:1.15rem;margin-bottom:.55rem;letter-spacing:-0.02em;color:var(--slate-900)}
.pain-card p{font-size:.94rem;color:var(--slate-600);line-height:1.7}
.service-bullets{list-style:none;margin-top:.75rem;display:flex;flex-direction:column;gap:.35rem;text-align:left}
.service-bullets li{font-size:.85rem;color:var(--slate-500);display:flex;align-items:center;gap:.5rem}

@media(max-width:768px){
  .hero{padding:7.75rem 1.25rem 4rem;min-height:auto}
  .hero-title{font-size:clamp(2.2rem,8vw,3.2rem)}
  .hero-sub{font-size:1rem;white-space:normal;margin-bottom:2rem}
  .section{padding:4.25rem 1.1rem}
  .section-sub{margin:0 auto 2.25rem}
  .pain-grid{gap:1.1rem;margin-top:2.25rem}
  .pain-card{padding:1.65rem 1.35rem;border-radius:18px}
  .pain-card-icon{width:44px;height:44px;border-radius:12px;margin:0 auto 1rem}
  .caso-conclusion{padding:1.5rem 1.35rem;border-radius:18px}
  .caso-conclusion p{font-size:1rem}
}

@media(max-width:480px){
  .hero{padding:6.25rem .9rem 3rem}
  .section{padding:3rem .9rem}
  .section-sub{font-size:1rem;margin:0 auto 1.75rem}
  .pain-grid{gap:1rem;margin-top:1.75rem}
  .pain-card{padding:1.35rem 1.1rem}
  .pain-card h3{font-size:1.08rem}
  .pain-card p{font-size:.9rem;line-height:1.6}
  .service-bullets li{font-size:.82rem}
  .caso-conclusion{padding:1.25rem 1.1rem}
  .caso-conclusion p{font-size:.95rem}
}
