/*
Theme Name: Astra Child
Template: astra
Author: PyM
Description: Child theme de Astra para personalizaciones por código de constructorapym.
Version: 1.0.1
Text Domain: astra-child
*/

/* ===================== Grilla del loop de proyectos ===================== */
/* Espaciado uniforme entre tarjetas (el original era 9px, muy apretado) */
.elementor-widget-loop-grid .elementor-grid{
  --grid-column-gap:26px !important;
  --grid-row-gap:26px !important;
  gap:26px !important;
}
/* CLAVE: fila de altura FIJA (Elementor ponia grid-auto-rows:1fr). Cada fila = 300px. */
.elementor-widget-loop-grid .elementor-loop-container{
  grid-auto-rows:300px !important;
}
/* Y TODOS los wrappers de Elementor llenan el 100% de esa fila, incluida la tarjeta.
   (Elementor fuerza .e-con{height:100%} y paddings que descuadraban todo.) */
.elementor-widget-loop-grid .e-loop-item,
.elementor-widget-loop-grid .e-loop-item > .e-con,
.elementor-widget-loop-grid .e-loop-item .e-con-inner,
.elementor-widget-loop-grid .e-loop-item .elementor-widget-shortcode,
.elementor-widget-loop-grid .e-loop-item .elementor-widget-container,
.elementor-widget-loop-grid .e-loop-item .elementor-shortcode,
.elementor-widget-loop-grid .e-loop-item .pym-card{
  height:100% !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0 !important;
}
@media (max-width:1024px){ .elementor-widget-loop-grid .elementor-loop-container{ grid-auto-rows:260px !important; } }
@media (max-width:767px){  .elementor-widget-loop-grid .elementor-loop-container{ grid-auto-rows:240px !important; } }
/* Separar la grilla del titulo "PROYECTOS" para que no lo tape (hay margin negativo arriba) */
.elementor-widget-loop-grid{ margin-top:40px !important; }

/* ===================== Tarjeta de proyecto ===================== */
.pym-card{
  display:block;
  position:relative;
  width:100%;
  height:300px;            /* altura FIJA uniforme: evita solapamiento entre filas */
  border-radius:12px;
  overflow:hidden;
  text-decoration:none;
  background:#cfcfcf;       /* fallback para proyectos sin imagen */
  box-shadow:0 4px 16px rgba(0,0,0,.10);
  transition:box-shadow .3s ease, transform .3s ease;
}
@media (max-width:1024px){ .pym-card{ height:260px; } }
@media (max-width:767px){ .pym-card{ height:240px; } }
.pym-card:hover{
  box-shadow:0 12px 30px rgba(0,0,0,.20);
  transform:translateY(-4px);
}
.pym-card__img{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transition:transform .6s ease;
}
.pym-card:hover .pym-card__img{ transform:scale(1.07); }
.pym-card__overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:16px 18px;
  background:linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.25) 28%, rgba(0,0,0,0) 52%);
  color:#fff;
}
.pym-card__loc{
  font-size:.9rem;
  font-weight:600;
  color:#fff;
  text-shadow:0 1px 3px rgba(0,0,0,.55);
}
/* Acento rojo sutil: una linea que aparece al hover */
.pym-card::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  height:4px; width:0;
  background:#c81010;
  transition:width .35s ease;
}
.pym-card:hover::after{ width:100%; }

/* ===================== Boton "Cargar mas" ===================== */
.e-loop__load-more{ text-align:center; margin-top:36px; }
/* El ancla es un marcador invisible: que NO tenga fondo ni tamaño (era el ovalo negro) */
.e-load-more-anchor{ background:none !important; padding:0 !important; min-height:0 !important; display:block !important; height:0 !important; }
.e-load-more-spinner{ background:none !important; }
/* Solo el boton real */
.e-loop__load-more .elementor-button{
  display:inline-block !important;
  background:#1a1a1a !important;
  color:#fff !important;
  padding:14px 40px !important;
  border:0 !important;
  border-radius:50px !important;
  font-size:.8rem !important;
  font-weight:600 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  transition:background .25s ease, transform .25s ease, box-shadow .25s ease !important;
}
.e-loop__load-more .elementor-button:hover{
  background:#c81010 !important;
  transform:translatey(-2px) !important;
  box-shadow:0 8px 20px rgba(200,16,16,.30) !important;
}

/* ===================== Carrusel de destacados ===================== */
.pym-carousel{ position:relative; overflow:hidden; border-radius:0; }
.pym-carousel__track{ display:flex; transition:transform .6s ease; will-change:transform; }
.pym-carousel__slide{
  position:relative; min-width:100%; aspect-ratio:16/7;
  background-size:cover; background-position:center; text-decoration:none;
}
.pym-carousel__caption{
  position:absolute; left:0; right:0; bottom:0;
  padding:48px 6% 30px;
  background:linear-gradient(to top, rgba(0,0,0,.75), rgba(0,0,0,0));
  color:#fff;
}
.pym-carousel__caption span{
  font-size:1rem;
  font-weight:600;
  letter-spacing:.02em;
  text-shadow:0 1px 5px rgba(0,0,0,.6);
}
.pym-carousel__btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border:0; cursor:pointer;
  background:rgba(0,0,0,.4); color:#fff; font-size:1.5rem; line-height:1;
  display:flex; align-items:center; justify-content:center; border-radius:50%;
  transition:background .2s;
}
.pym-carousel__btn:hover{ background:rgba(200,16,16,.9); }
.pym-carousel__btn--prev{ left:18px; }
.pym-carousel__btn--next{ right:18px; }
.pym-carousel__dots{
  position:absolute; bottom:16px; left:0; right:0;
  display:flex; gap:7px; justify-content:center; align-items:center;
}
.pym-carousel__dot{
  width:7px; height:7px; padding:0; border:0; cursor:pointer;
  border-radius:50px;
  background:rgba(255,255,255,.45);
  transition:width .3s ease, background .3s ease;
}
.pym-carousel__dot:hover{ background:rgba(255,255,255,.75); }
.pym-carousel__dot.is-active{ width:24px; background:#fff; }

@media (max-width:768px){
  .pym-carousel__slide{ aspect-ratio:4/3; }
  .pym-carousel__caption h3{ font-size:1.1rem; }
}

/* ===================== Pie de página a medida ===================== */
/* El footer a medida (HFE) reemplaza al de Astra: ocultamos el nativo de Astra */
.site-primary-footer-wrap,
.site-below-footer-wrap,
.ast-below-footer-wrap{ display:none !important; }

/* Footer a TODO el ancho: anulamos la caja "boxed" de Elementor (template 1085) */
.elementor-1085,
.elementor-1085 .elementor-container,
.elementor-1085 .elementor-column,
.elementor-1085 .elementor-widget-wrap,
.elementor-1085 .elementor-element-populated,
.elementor-1085 .elementor-widget-shortcode,
.elementor-1085 .elementor-shortcode{
  max-width:100% !important;
  width:100% !important;
  padding:0 !important;
  margin:0 !important;
  border-radius:0 !important;
}

.pym-footer{
  background:#1b1b1b;
  color:#cfcfcf;
  padding:60px 6% 0;
  font-size:.92rem;
  line-height:1.7;
}
.pym-footer *{ box-sizing:border-box; }
.pym-footer__grid{
  max-width:1280px; margin:0 auto;
  display:grid;
  grid-template-columns:1.9fr 1fr 1.4fr;
  gap:48px;
  padding-bottom:42px;
}
.pym-footer__brand{ max-width:340px; }
.pym-footer__logo{ width:115px; max-width:60%; height:auto; margin-bottom:20px; display:block; }
.pym-footer__tagline{ color:#9a9a9a; margin:0 0 24px; font-size:.85rem; line-height:1.65; }
.pym-footer__social{ display:flex; gap:10px; }
.pym-footer__social a{
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.08); color:#d8d8d8;
  transition:background .25s, color .25s, transform .25s;
}
.pym-footer__social a:hover{ background:#c81010; color:#fff; transform:translateY(-3px); }
.pym-footer__title{
  color:#fff; font-size:1.02rem; font-weight:700; margin:0 0 22px;
  position:relative; padding-bottom:11px;
}
.pym-footer__title::after{
  content:""; position:absolute; left:0; bottom:0;
  width:34px; height:3px; background:#c81010; border-radius:2px;
}
.pym-footer__links,
.pym-footer__contact,
.pym-footer__hours{ list-style:none; margin:0; padding:0; }
.pym-footer__links li{ margin-bottom:11px; }
.pym-footer__links a{ color:#bdbdbd; text-decoration:none; transition:color .2s, padding-left .2s; }
.pym-footer__links a:hover{ color:#fff; padding-left:6px; }
.pym-footer__contact li{ display:flex; gap:11px; align-items:flex-start; margin-bottom:15px; }
.pym-footer__contact a{ color:#bdbdbd; text-decoration:none; transition:color .2s; }
.pym-footer__contact a:hover{ color:#fff; }
.pym-footer__contact span:last-child{ color:#bdbdbd; }
.pym-footer__ico{ color:#c81010; flex-shrink:0; margin-top:2px; display:flex; }
.pym-footer__hours li{
  display:flex; justify-content:space-between; gap:12px; margin-bottom:9px;
  border-bottom:1px solid rgba(255,255,255,.07); padding-bottom:9px;
}
.pym-footer__hours span{ color:#a8a8a8; }
.pym-footer__hours strong{ color:#fff; font-weight:600; white-space:nowrap; }
.pym-footer__bottom{
  max-width:1280px; margin:0 auto;
  border-top:1px solid rgba(255,255,255,.1);
  padding:20px 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px;
  font-size:.8rem; color:#8a8a8a;
}
@media (max-width:1024px){
  .pym-footer__grid{ grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width:600px){
  .pym-footer{ padding:44px 7% 0; }
  .pym-footer__grid{ grid-template-columns:1fr; gap:30px; }
  .pym-footer__bottom{ flex-direction:column; text-align:center; }
}

/* ===================== Pagina Contacto: separar mapa del formulario ===================== */
.elementor-25 .elementor-element-5d040fa{
  --column-gap:48px !important;
  --gap:48px 48px !important;
  gap:48px !important;
  column-gap:48px !important;
}
