:root {
	--dark: #0c2b48;
	--yellow: #f3d795;
	--dark-light: rgba(12, 43, 72, 0.162);
}

.questrial-regular {
	font-family: 'Questrial', sans-serif;
	font-weight: 400;
	font-style: normal;
}
.prata-regular {
	font-family: 'Prata', serif;
	font-weight: 400;
	font-style: normal;
}
.alata-regular {
	font-family: 'Alata', sans-serif;
	font-weight: 400;
	font-style: normal;
}
* {
	font-family: 'Alata', sans-serif;
}

html {
	scroll-behavior: smooth;
}

.background-dark {
	background-color: var(--dark) !important;
}
.background-yellow {
	background-color: var(--yellow) !important;
}

.background-dark-light {
	background-color: var(--dark-light) !important;
	border-color: var(--dark-light) !important;
}

.background-dark-fullwidth {
	position: relative !important;
	box-shadow: 0 0 0 100vmax var(--dark) !important;
	clip-path: inset(0 -100vmax) !important;
	background-color: var(--dark) !important;
}

.text-color-dark {
	color: var(--dark) !important;
}
.text-color-yellow,
.text-color-yellow > * {
	color: var(--yellow) !important;
}
.text-color-white {
	color: white !important;
}

.text-color-black {
	color: black;
}
.navbar-brand {
	font-size: 2rem;
}
/* .carousel-item {
  height: 100px;
  margin-bottom: 20px;
} */

.container-diferenciador {
	padding: 0px 10%;
	text-align: center;
}

.header-title-section {
	display: flex;
	justify-content: center;
	margin-top: 50px;
}
.header-title {
	background-color: var(--yellow);
	border-radius: 50px;
	color: var(--dark);
	padding: 10px 30px;
	width: fit-content;
	font-weight: bolder;
}

.header-subtitle {
	/*  margin: 15px 0px 30px 0px; */
	text-align: center;
	font-weight: bolder;
	color: var(--dark);
}

.contact-form {
	border: 1px solid var(--dark);
	padding: 30px 20px;
	border-radius: 25px;
	width: 80%;
}

.contact-form-input {
	background-color: rgba(141, 141, 141, 0.242);
}

.contact-form-input::placeholder {
	color: #212529bf;
	font-weight: lighter;
	font-size: smaller;
	opacity: 0.5;
}

.btn-contact-form {
	background-color: var(--dark);
	color: var(--yellow);
}
.btn-contact-form:hover {
	background-color: var(--dark);
	color: var(--yellow);
}

i {
	font-size: 4rem;
	margin-bottom: 1rem;
}

.card-title {
	text-align: center;
	/* margin-bottom: 1rem; */
	/* min-height: 3.5rem; */
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

.card-subtitle-services {
	font-weight: lighter;
	text-align: center;

	margin-bottom: auto; /* Para centrar verticalmente */
}

.card-size-medium {
	height: 28rem;
	border: none !important;
}

.card-size-large {
	height: 22rem;
	border: none !important;
}

/* 1) Quita completamente cualquier borde o fondo blanco en la .card */
.card-size-medium,
.card-size-large {
	border: none !important;
	background-color: transparent !important;
}

/* 2) Asegura que al hacer hover tampoco aparezca ningún borde blanco */
/* .card-size-medium:hover,
.card-size-large:hover {
  transform: translateY(-6px);
  border: none !important;
  background-color: transparent !important;
  box-shadow: 0 12px 20px rgba(0, 0, 0, 0.15);
} */

/* 3) (Opcional) Si tu .card-body tiene un fondo propio distinto, 
       también confirma que sea transparente o coincida con el overlay */
.card-body-services {
	background-color: transparent !important;
}

/* ---------------------------------------------------
   1) Aplica la imagen de fondo y el degradado full-width
   --------------------------------------------------- */

/* Contenedor padre (full-width) tiene `position: relative` */
#porque {
	padding: 0; /* elimina paddings extra de Bootstrap */
	margin: 0; /* si quieres, puedes controlar top/bottom con mt-5/mb-5 */
	overflow: hidden; /* para que nada “sobresalga” */
}

/* Div que realmente mostrará la foto + degradado */
.porque-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	/* Aquí pones la ruta a tu imagen - asegúrate de la ruta relativa al CSS */
	background: linear-gradient(
			rgba(0, 0, 0, 0.4),
			/* capa oscura (40%) arriba */ rgba(0, 0, 0, 0.2)
				/* capa oscura (40%) abajo */
		),
		url('../img/justicia.png') center/cover no-repeat;
	z-index: 1; /* va detrás del contenido */
}

/* ---------------------------------------------------
   2) Asegura que el contenido quede encima del fondo
   --------------------------------------------------- */
#porque .container {
	position: relative;
	z-index: 2;
	padding-top: 12rem; /* si quieres separar un poco del tope */
	padding-bottom: 12rem; /* y un poco de padding inferior también */
}

/* ---------------------------------------------------
   3) Opcional: limita el ancho del “contenedor-porque”
   --------------------------------------------------- */
.container-porque {
	width: 60%;
	margin: 0 auto;
	/* Si deseas más responsividad: */
	/* @media (max-width: 768px) { .container-porque { width: 90%; } } */
}

.container-porque {
	width: 60%;
	margin: 0 auto;
}

.card-porque {
	height: 18rem;
	width: 30rem;
	border-radius: 30px;
	background: linear-gradient(145deg, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.8));

	/*  box-shadow: 15px 15px 30px rgba(0, 0, 0, 0.111),
    -15px -15px 30px rgba(255, 255, 255, 0.05); */
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-porque > .card-body {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-direction: column;
	padding: 2px;
	margin-top: 15px;
}

.btn-instagram {
	background: transparent;
	padding: 5px 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.btn-instagram:hover {
	background-color: rgba(243, 215, 149, 0.15);
}

.btn-instagram svg {
	fill: var(--yellow);
	width: 24px;
	height: 24px;
	transition: transform 0.3s ease;
}

.btn-instagram:hover svg {
	transform: scale(1.15); /* Aumenta 15% el tamaño */
}

.image-container {
	position: relative; /* Establecemos el contenedor como punto de referencia para el posicionamiento absoluto */
	width: 100%; /* O el ancho que desees */
	height: 500px; /* Debe coincidir con la altura de la imagen */
	overflow: hidden; /* Asegura que el contenido superpuesto no se salga del contenedor */
}

.quote-overlay {
	position: absolute; /* Posicionamos la capa de la cita absolutamente dentro del contenedor */
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex; /* Usamos flexbox para centrar el texto fácilmente */
	justify-content: flex-end; /* Alinea el texto a la derecha */
	align-items: center; /* Centra el texto verticalmente */
	padding-right: 20px; /* Espacio a la derecha para que no toque el borde */
	box-sizing: border-box; /* Incluye el padding en el ancho y alto */
	pointer-events: none; /* Permite que los clics pasen a la imagen si es necesario */
}

.quote-text {
	background-color: rgba(
		0,
		0,
		0,
		0.5
	); /* Fondo semitransparente para el texto */
	color: white;
	padding: 20px;
	border-radius: 5px;
	text-align: right; /* Alinea el texto dentro del bloque a la derecha */
	max-width: 50%; /* Limita el ancho del bloque de la cita */
	font-style: italic;
	font-size: 1.2em;
	margin: 0; /* Elimina los márgenes predeterminados del blockquote */
}

.quote-text::before {
	content: open-quote; /* Agrega comillas de apertura */
	font-size: 2em;
	margin-right: 5px;
	vertical-align: top;
}

.quote-text::after {
	content: close-quote; /* Agrega comillas de cierre */
	font-size: 2em;
	margin-left: 5px;
	vertical-align: bottom;
}
/* Estilos base para el carousel (puede que ya tengas algunos) */
#carouselExampleIndicators {
	margin: 0 auto; /* Centrar el carousel horizontalmente */
	width: 100%; /* Ocupa el 80% del ancho en pantallas más grandes */
}

/* Estilo para el enlace-CTA dentro de blockquote */
.cta-link em {
	display: inline-block;
	background-color: var(--yellow);
	color: var(--dark);
	padding: 0.5rem 1rem;
	border-radius: 1.5rem;
	text-decoration: none;
	font-style: normal; /* quita cursiva si no la deseas */
	font-weight: 600;
	transition: background-color 0.3s ease, transform 0.2s ease;
}
#servicios > .row > .col-12 {
	margin-bottom: 30px;
}

/* 1) Base para .card-body-services: 
   - posición relativa para contener el pseudoelemento
   - textos en color blanco */
.card-body-services {
	position: relative;
	color: #fff; /* texto en blanco */
	background-size: cover; /* la imagen ocupa todo el contenedor */
	background-position: center;
	background-repeat: no-repeat;
	display: flex;
	flex-direction: column;
	justify-content: flex-end; /* el contenido (icono, título, texto) se alinea abajo */
	padding: 6rem 2rem 2rem 2rem; /* ajusta según espacio deseado */
	min-height: 20rem; /* altura mínima para que el fondo luzca bien */
	overflow: hidden;
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 100%;

	justify-content: start;
}

/* 2) Degradado oscuro encima de la imagen (pero debajo del contenido):
   - usa ::before para superponer una capa semitransparente */
.card-body-services::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.5) 1%,
		rgba(0, 0, 0, 0.9) 100%
	);
	z-index: 1;
	pointer-events: none;
	border: transparent !important;
}

/* 3) Hacer que todo el contenido (icono, título, párrafo) quede por encima del degradado */
.card-body-services > * {
	position: relative;
	z-index: 2;
}

/* 4) Opcional: estilo para el botón interno si lo tuvieses */
.card-body-services .btn-info {
	margin-top: 1rem;
	align-self: flex-start; /* o flex-end según te convenga */
	color: #fff;
	background: transparent;
	transition: background-color 0.3s ease, color 0.3s ease;
}
.card-body-services .btn-info:hover {
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
}

/* Hover: un poco más oscuro y ligero desplazamiento hacia arriba */
.cta-link em:hover {
	background-color: rgba(243, 215, 149, 0.8); /* ajusta al nivel deseado */
	transform: translateY(-2px);
}

/* Active (clic): efecto “presionado” */
.cta-link em:active {
	transform: translateY(0);
	background-color: rgba(243, 215, 149, 1);
}

.faq-section-title {
	font-size: medium;
	margin-bottom: 15px;
	font-stretch: expanded;
}

.footer-full-page {
	/* Usando la variable dark para el fondo */
	background-color: var(--dark, #1a1a1a);
	color: #ffffff; /* Color principal del texto */
	padding-top: 50px;
	padding-bottom: 50px;
}

.footer-title {
	color: var(--yellow, #ffc107); /* Color de acento para los títulos */
	font-size: 1.15rem;
	font-weight: 700;
	border-bottom: 2px solid rgba(255, 255, 255, 0.1);
	padding-bottom: 10px;
}

/* Enlaces y listas */
.footer-list li a {
	color: rgba(255, 255, 255, 0.75); /* Enlaces en gris claro */
	text-decoration: none;
	transition: color 0.3s;
	font-size: 0.95rem;
}

.footer-list li a:hover {
	color: var(--yellow, #ffc107); /* Efecto hover */
}

.footer-icon {
	color: var(--yellow, #ffc107);
	width: 20px; /* Asegura alineación uniforme de los íconos */
	text-align: center;
	font-size: 25px;
}

.footer-logo {
	max-height: 120px; /* Ajusta este valor al tamaño correcto de tu logo */
	width: auto;
}

/* ---------------------------------- */
/* MAPA DE GOOGLE (RESPONSIVE) */
/* ---------------------------------- */
.map-container {
	width: 100%;
	/* Altura fija para evitar el colapso del iframe en móviles */
	max-height: 300px;
	overflow: hidden;
	border-radius: 8px;
}

.map-container iframe {
	/* El iframe ya tiene width="100%", pero aseguramos que cubra el contenedor */
	display: block;
	width: 100%;
	height: 100%;
}

/* ---------------------------------- */
/* Créditos y Redes Sociales */
/* ---------------------------------- */
.social-icon {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	background-color: rgba(255, 255, 255, 0.1);
	color: #ffffff;
	border-radius: 50%;
	margin-right: 10px;
	transition: background-color 0.3s;
}

.social-icon:hover {
	background-color: var(--yellow, #ffc107);
	color: var(--dark, #1a1a1a);
}

.footer-legal {
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.5;
}

/* Estilos para el bloque de atribución (HECHO CON CORAZÓN) */
.footer-brand {
	font-size: 0.8rem;
	font-weight: 500;
	line-height: 1.5;
	text-transform: uppercase;
}

.footer-brand .footer-link {
	color: rgba(255, 255, 255, 0.65);
	text-decoration: none;
	transition: color 0.3s;
	display: inline-block;
}

.footer-brand .footer-link:hover {
	color: var(--yellow, #ffc107);
}

.heart {
	display: inline-block;
	color: var(--yellow, #ffc107);
	animation: pulse 1.5s infinite;
}

.brand-name {
	font-weight: 700;
	color: rgba(255, 255, 255, 0.9);
}

@keyframes pulse {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.1);
	}
	100% {
		transform: scale(1);
	}
}

/******************************************************************** ANIMATIONS */
/******************************************************************** ANIMATIONS */

/******************************************************************** ANIMATIONS */

/* keyframes */
@keyframes up {
	from {
		opacity: 0;
		transform: translateY(50px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes zoomIn {
	from {
		opacity: 0;
		transform: scale(0.95);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

/* base: oculto */
.animate-up,
.animate-fade,
.animate-zoom {
	opacity: 0;
}

/* al añadir .show se dispara la animación, respeta --delay y no revierte jamás */
.animate-up.show {
	animation: up 0.8s ease-out var(--delay, 0s) forwards;
}
.animate-fade.show {
	animation: fadeIn 0.6s ease var(--delay, 0s) forwards;
}
.animate-zoom.show {
	animation: zoomIn 0.6s ease-out var(--delay, 0s) forwards;
}
/*************************/

/*************************/

/*************************/

/* MOBILE */
@media screen and (max-width: 600px) {
	.navbar-brand {
		font-size: 1rem;
	}
	.carousel-item {
		height: 400px;
	}

	.contact-form {
		width: 100%;
	}
	#carouselExampleIndicators {
		height: 400px; /* Ocupa el 50% del ancho en pantallas pequeñas */
	}

	.quote-overlay {
		padding-right: 0px;
	}
	.quote-text {
		font-size: 0.8em;
		max-width: 70%;
	}
	.card-size-medium,
	.card-size-large {
		height: 25rem;
	}

	.card-size-medium:hover,
	.card-size-large:hover {
		transform: none;
		box-shadow: none;
		border: none;
	}

	.container-porque {
		width: 90%; /* Más ancho en pantallas pequeñas */
	}
}
