/* Home-only styles. Scope to .ev-* sections to avoid collisions. */
.ev-services, .ev-cases, .ev-process, .ev-differentials,
.ev-kpis, .ev-blog-teaser, .ev-cta, .ev-faqs, .ev-lead { padding: clamp(2rem, 3vw, 3.5rem) 0; }

.ev-services__grid, .ev-cases__grid, .ev-kpis__grid, .ev-blog__grid,
.ev-differentials__grid, .ev-process__steps { display: grid; gap: clamp(.75rem, 2vw, 1.25rem); align-items: stretch; }

@media (min-width: 640px){
  .ev-services__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .ev-differentials__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .ev-blog__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 960px){
  .ev-services__grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .ev-cases__grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .ev-kpis__grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .ev-differentials__grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .ev-blog__grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .ev-process__steps { grid-template-columns: repeat(4, minmax(0,1fr)); }
}

/* Cards coherentes y estables (evitar CLS) */
.ev-service-card, .ev-case, .ev-post, .ev-diff-card,
.wp-block-uagb-counter { border: 1px solid var(--border); border-radius: var(--radius-md);
  padding: clamp(.875rem, 1.8vw, 1.25rem); background: #fff; box-shadow: var(--shadow-sm);
  min-height: 120px; display: flex; flex-direction: column; justify-content: flex-start;
  contain: layout;
}
.ev-service-card a { color: inherit; text-decoration: none; outline-offset: 3px; }
.ev-service-card h3, .ev-case h3, .ev-post h3 { margin-bottom: .35rem; font-size: clamp(1.05rem, 2.2vw, 1.25rem); color: #1a1a1a; font-weight: 600; }
.ev-service-card p { margin: 0; color: #4a4a4a; }

/* Tipografía secciones Home */
.ev-services h2, .ev-cases h2, .ev-process h2, .ev-differentials h2,
.ev-blog-teaser h2, .ev-cta h2, .ev-faqs h2 { 
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  line-height: 1.25; color: var(--text);
  margin-bottom: clamp(.75rem, 1.5vw, 1rem);
}
.ev-services h3, .ev-cases h3, .ev-process h3, .ev-differentials h3,
.ev-blog-teaser h3 { font-size: clamp(1.05rem, 2.5vw, 1.25rem); line-height: 1.3; color: var(--text); }
.ev-differentials h3 { font-weight: 400; }
.ev-blog-teaser p { color: var(--text-light); }

/* Estados accesibles */
.ev-service-card:focus-within, .ev-post:focus-within, .ev-diff-card:focus-within { box-shadow: var(--shadow); }
.ev-service-card a:focus-visible, .ev-cta .button:focus-visible,
.ev-blog-teaser a:focus-visible { outline: 3px solid var(--accent-yellow); outline-offset: 3px; }

/* Hovers sin saltos de layout */
@media (hover:hover){
  .ev-service-card:hover, .ev-diff-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); transition: transform .2s ease, box-shadow .2s ease; }
}

.ev-process__steps li { list-style: none; border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: clamp(.875rem, 2vw, 1.25rem); background: #fff; box-shadow: var(--shadow-sm);
  min-height: 100%; }

/* Imágenes e iconos en tarjetas (evitar saltos) */
.ev-service-card img, .ev-post img { width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; border-radius: var(--radius-md); }

.ev-differentials__list { display: grid; gap: .5rem; margin: 0; padding-left: 1.1rem; }
.ev-differentials__list li { list-style: disc; }

.ev-cta { background: linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.35)), url('../img/cta/diagnostico-cta.webp') center/cover no-repeat; color: #fff; text-align: center; padding: clamp(2rem, 4vw, 3rem) 0; }
.ev-cta a.button { color: #fff; min-height: 44px; padding: .75rem 1.25rem; border-radius: var(--radius-full, 9999px); box-shadow: var(--shadow); transition: background-color .2s ease, box-shadow .2s ease; }
.ev-cta a.button:hover { box-shadow: var(--shadow-md); }
.ev-cta h2 { font-size: clamp(2.25rem, 5vw, 3.5rem); line-height: 1.12; color: #fff; text-shadow: 0 2px 4px rgba(0,0,0,.28); margin-bottom: .6rem; letter-spacing: .2px; }
.ev-cta p { color: #fff; opacity: .96; font-size: clamp(1.0625rem, 2.4vw, 1.3125rem); line-height: 1.5; margin: 0 auto 1.25rem auto; max-width: 58ch; text-shadow: 0 1px 2px rgba(0,0,0,.22); }
.ev-cta .button { font-weight: 700; padding: 1rem 1.5rem; }
.ev-cta .button.primary { background-color: var(--primary); color: #fff; border: 1px solid rgba(0,0,0,0.06); border-radius: var(--radius-full); box-shadow: var(--shadow-lg); transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.ev-cta .button.primary:hover { background-color: var(--primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.ev-cta .button.primary:focus-visible { outline: 3px solid var(--accent-yellow); outline-offset: 3px; }

.ev-faqs details { border: 1px solid var(--border); border-radius: var(--radius-md); background: #fff; padding: .75rem 1rem; }
.ev-faqs details + details { margin-top: .75rem; }
.ev-faqs summary { cursor: pointer; font-weight: 600; display: flex; align-items: center; justify-content: space-between; position: relative; padding-right: 2.25rem; list-style: none; }
.ev-faqs summary::-webkit-details-marker { display: none; }
.ev-faqs summary::after { content: ""; width: 22px; height: 22px; margin-left: 1rem; flex-shrink: 0; background: linear-gradient(currentColor,currentColor) center/100% 2px no-repeat, linear-gradient(currentColor,currentColor) center/2px 100% no-repeat; transition: background-size .25s ease, transform .25s ease, opacity .25s ease; }
.ev-faqs details[open] summary::after { background-size: 100% 2px, 0 0; }
.ev-faqs summary:focus-visible { outline: 3px solid var(--accent-yellow); outline-offset: 3px; }

.ev-lead .ev-lead__row { display: grid; gap: .75rem; margin-bottom: .75rem; }
@media (min-width: 720px){
  .ev-lead .ev-lead__row:first-child { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .ev-lead .ev-lead__row:nth-child(2) { grid-template-columns: 1fr 2fr; }
}

/* Blog teaser: grid estable y legible */
.ev-blog-teaser .ev-post { display: flex; flex-direction: column; gap: .5rem; }
.ev-blog-teaser .ev-post a { text-underline-offset: 2px; }
.ev-blog-teaser .ev-post a:hover { text-decoration: underline; }

/* Botones dentro de secciones de Home (paleta existente) */
.ev-services .button.primary, .ev-cases .button.primary, .ev-blog-teaser .button.primary { 
  background-color: var(--primary); color: var(--blanco-puro); border: 1px solid rgba(0,0,0,0.06); border-radius: var(--radius-full);
  padding: .6rem 1.1rem; box-shadow: var(--shadow); transition: background-color .2s ease, box-shadow .2s ease; }
.ev-services .button.primary:hover, .ev-cases .button.primary:hover, .ev-blog-teaser .button.primary:hover { 
  background-color: var(--primary-dark); box-shadow: var(--shadow-md); }
.ev-services .button.secondary, .ev-cases .button.secondary, .ev-blog-teaser .button.secondary { 
  background-color: var(--blanco-puro); color: var(--primary); border: 1px solid var(--border); border-radius: var(--radius-full);
  padding: .6rem 1.1rem; }
.ev-services .button.secondary:hover, .ev-cases .button.secondary:hover, .ev-blog-teaser .button.secondary:hover { 
  background-color: var(--bg-alt); }

/* Reduce motion respetando preferencia */
@media (prefers-reduced-motion: reduce){
  .ev-service-card:hover, .ev-diff-card:hover { transform: none; }
}

/* CTA: aumentar altura en desktop */
@media (min-width: 1024px){
  .ev-cta { min-height: 1080px; background-position: center center; }
  .ev-cta .container { min-height: inherit; display: grid; place-items: center; }
}
