/* Pasar variables a un fichero */
:root {
    --rojo-principal: #EC0044;
    --rojo-secundario: #78232F;
    /*hover*/
    --gris-principal: #F6F6F6;
    --gris-secundario: #58585A;
    --linea-gris: #D1D2D4;
    --blanco: #FFFFFF;
    --negro: #000000;
}


/* Botones especiales rojos */
.hero-btn-rojo {

    transition: all 0.3s ease;
    cursor: pointer;
    line-height: 25px;
}

.hero-btn-rojo:hover .elementor-icon,
.hero-btn-rojo:hover .elementor-icon-box-title span,
.hero-btn-rojo:hover .elementor-icon-box-description,
.hero-btn-rojo:hover .home-btn-rojo-desc > p
{
    color: var(--rojo-principal) !important;
}

.hero-btn-rojo:hover .elementor-icon svg {
    fill: var(--rojo-principal) !important;
    transition: fill 0.3s ease;
}

.home-btn-rojo {
    transition: all 0.3s ease;
    cursor: pointer;
    line-height: 25px;
    border: 2px solid transparent; 
}

.home-btn-rojo:hover {
    border-color: var(--rojo-principal);
    background-color: var(--blanco) !important;
}

.home-btn-rojo:hover .elementor-icon svg {
    fill: var(--rojo-principal) !important;
    transition: fill 0.3s ease;
}

.home-btn-rojo:hover span,
.home-btn-rojo:hover a {
    color: var(--rojo-principal) !important;
}

.hero-btn-rojo.estadisticas .elementor-icon-box-title span,
.hero-btn-rojo.estadisticas .elementor-icon-box-description {
    line-height: 12px !important; 
}

.hero-btn-rojo.estadisticas .elementor-icon-box-icon .elementor-icon svg {
    transform: scale(0.8); 
    transform-origin: center;
}

.hero-btn-gris {
    transition: all 0.3s ease;
    cursor: pointer; 
    border: unset !important;
    border: 2px solid transparent !important;
    display: inline-block; 
}

/* Mantener estilos existentes del contenido y icono */
.hero-btn-gris .elementor-icon-box-content {
    margin-top: -10px !important;
    padding-bottom: 20px !important;
}

.hero-btn-gris .elementor-icon-box-icon .elementor-icon {
    border-radius: 5px !important;
    overflow: hidden;
    padding-left: 5px !important;
    padding-right: 5px !important;
}

.hero-btn-gris:hover {
    transition: all 0.3s ease;
    cursor: pointer; 
    border: 2px solid var(--negro) !important; 
    display: inline-block; 
    background-color: var(--blanco) !important;
}

/* Hover de hero-btn-gris: transición uniforme */
.hero-btn-gris:hover {
    transition: all 0s ease;
}

/* Texto dentro del bloque */
.hero-btn-gris:hover .elementor-widget-text-editor p {
    color: var(--negro) !important;
    transition: color 0s ease;
}

/* Todos los fondos que cambian a negro */
.hero-btn-gris:hover .elementor-icon-box-content,
.hero-btn-gris:hover .elementor-icon-box-icon .elementor-icon a,
.hero-btn-gris:hover .btn-gris-caja {
    background-color: var(--negro) !important;
    transition: background-color 0s ease;
}

/* Borde del icono */
.hero-btn-gris:hover .elementor-icon-box-icon .elementor-icon {
    border-color: var(--negro) !important;
    transition: border-color 0s ease;
}

.hero-btn-gris:hover .elementor-icon {
   background-color: var(--negro) !important;
    border-color: var(--negro) !important;  
    border-style: solid !important;            
    border-width: 3px !important;  
}

#cortedearbitraje:hover div.elementor-icon-box-icon > a, #solicitudes:hover div.elementor-icon-box-icon > a,
#audiencia:hover div.elementor-icon-box-icon > a{
  background-color:var(--negro) !important;
	border-color: var(--negro) !important;
}

.home-logo {
  font-family: Arial, Helvetica, sans-serif;
  text-align: center;
  color: #58585A;
  letter-spacing: 2px;
  font-weight: 300;
  margin: 0;
}

.home-linea-superior,
.home-linea-inferior {
  display: inline-block;
  font-size: 32px; 
}

/* Texto rojo */
.home-rojo {
  color: #EC0044;
  font-weight: 600;
  font-size: 50px;
}

/* Línea del mismo ancho que el texto */
.home-linea {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #58585A;
  margin: 8px auto;
}





/* Personalizar la seccion de blog */
/* ------------------------------- */
.hero-blog article
{
	 background-color: var(--blanco) !important;
	 border: 1px solid var(--linea-gris) !important;
}

.hero-blog article .elementor-post__read-more-wrapper a
{
	background-color: var(--rojo-principal) !important;
	padding: 10px;
	font-size: 16px;
}

.hero-blog article .elementor-post__read-more-wrapper a:hover
{
	background-color: var(--rojo-secundario) !important;
}

/* Solo fechas dentro del loop-carousel */
.elementor-widget-loop-carousel .elementor-widget-text-editor {
    text-transform: capitalize;
}


/* Limitar títulos en el carrusel de Elementor a 3 líneas */
.swiper .elementor-widget-theme-post-title .elementor-heading-title {
    display: -webkit-box;
    -webkit-line-clamp: 3; 
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}


/* Invertir orden de fecha y título en el widget Posts de Elementor */
#evento-destacado  .elementor-post__text {
    display: flex;
    flex-direction: column;
}

#evento-destacado  .elementor-post__meta-data {
    order: -1; 
    margin-bottom: 10px;
    text-transform: capitalize;
}

#evento-destacado  .elementor-post__title {
    order: 2;
}

@media (max-width: 1024px) {
    #evento-destacado .elementor-post__title {
        display: -webkit-box;     
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 4;   
        overflow: hidden;          
        text-overflow: ellipsis;    
    }
}

/* Estadisticas */
/* ------------------------------- */

.datos-estadisticos {
    font-size: 20px !important;
    text-transform: uppercase;
   
}

@media (max-width: 1024px) and (min-width: 768px) {
  .home-estadisticas-3,
  .home-estadisticas-2 {
    width: 100% !important;
  }
}
