@import url('../../style.css');

.last-section-header{
    margin-bottom: var(--spacing-2xl);
    /* margin-top: var(--spacing-4xl); */
}
.last-section-header h2{
	color: var(--color-dark);
	font-style: italic;
	font-size: var(--text-5xl);
	font-weight: 900;
	text-align: center;
}

.bento-card__excerpt{
	    font-size: var(--text-base);
    color: var(--color-white);
    line-height: var(--leading-relaxed);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
		display: none;
}


/* ===========================
   BENTO GRID
   =========================== */

.bento-section {
	margin-bottom: 150px;
}

.bento-grid {
	display: grid;
	grid-template-columns: 7fr 3fr;
	gap: 1.5rem;
}

/* Shared card base */
.bento-card {
	border-radius: var(--radius-xl);
	overflow: hidden;
	/* box-shadow: var(--shadow-md); */
	transition: box-shadow var(--transition-base), transform var(--transition-base);
	position: relative;
}

.bento-card:hover {
	box-shadow: var(--shadow-xl);
	transform: translateY(-4px);
}

/* Overlay clickable en toda la card */
.bento-card__link {
	position: absolute;
	inset: 0;
	z-index: 0;
	border-radius: inherit;
}

/* Shared CTA button */
.bento-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: 3px solid var(--color-white);
	color: var(--color-white);
	text-decoration: none;
	flex-shrink: 0;
	transition: transform var(--transition-base);
}

.bento-card__btn svg {
	width: 32px;
	height: 32px;
	flex-shrink: 0;
}

.bento-card:hover .bento-card__btn {
	transform: translate(4px, -4px);
}


/* ===========================
   Card 1 y Card 2: layout split interno
   izda/dcha separadas por gap interno
   =========================== */

.bento-card--1 {
	grid-column: 1 / -1;
}

.bento-card--1 .bento-card__inner {
	display: grid;
	grid-template-columns: 3fr 7fr;
	gap: 1.5rem;
	height: 340px;
}

.bento-card--2 .bento-card__inner {
	display: grid;
	grid-template-columns: 4fr 3fr;
	gap: 1.5rem;
	height: 340px;
}


.bento-card__text-panel {
	padding: var(--spacing-xl);
	display: flex;
	flex-direction: column;
	position: relative;
	border-radius: var(--radius-xl);
}

.bento-card--1 .bento-card__text-panel {
	background-color: var(--color-primary);
}

.bento-card--2 .bento-card__text-panel {
	background-color: var(--color-primary);
}

/* Sección de imagen */
.bento-card__image-panel {
	border-radius: var(--radius-xl);
	overflow: hidden;
	background-color: #f5c6d0;
}

.bento-card__image-panel img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}


/* CTA Card 1: abajo-izquierda */
.bento-card--1 .bento-card__btn {
	position: absolute;
	    bottom: 30px;
    right: 15px;
}

/* CTA Card 2: abajo-derecha */
.bento-card--2 .bento-card__btn {
	position: absolute;
	    bottom: 30px;
    right: 15px;
}


/* ===========================
   Card 3: usa estilos de related-card
   =========================== */

.bento-grid .related-card {
	height: 340px;
	position: relative;
}

.bento-grid .related-card__body {
	position: static;
	overflow: hidden;
	min-height: 0;
}


/* ===========================
   Responsive
   =========================== */

@media (max-width: 1024px) {
	.bento-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem; 
	}

	.bento-card--1 {
		grid-column: 1;
	}

	.bento-card--2 .bento-card__inner {
		height: 280px;
	}
}

@media (max-width: 640px) {
	:root {
		--home-mobile-card-height: 340px;
		--home-mobile-text-height: 130px;
		--home-mobile-image-height: 210px;
	}

	.bento-card {
		display: flex;
		flex-direction: column;
		height: var(--home-mobile-card-height);
		max-height: var(--home-mobile-card-height);
	}

	.bento-card--1 .bento-card__inner,
	.bento-card--2 .bento-card__inner {
		display: flex;
		flex-direction: column;
		flex: 1;
		gap: 0;
		height: auto;
	}

	.bento-card--2 .bento-card__image-panel {
		order: 2;
	}

	.bento-card--2 .bento-card__text-panel {
		order: 1;
	}

	.bento-card__text-panel {
		flex: 0 0 auto;
		height: var(--home-mobile-text-height);
		min-height: var(--home-mobile-text-height);
		border-radius: 0;
		padding: var(--spacing-lg);
		position: static;
		overflow: hidden;
	}

	.bento-card__image-panel {
		flex: 0 0 auto;
		min-height: 0;
		height: var(--home-mobile-image-height);
		aspect-ratio: 16 / 9;
		border-radius: var(--radius-xl);
		margin-top: -20px;
	}

	.bento-card__btn {
		bottom: var(--spacing-md);
		z-index: 1;
	}

	body.home .bento-section .related-card:not(.related-card--hero),
	body.blog .bento-section .related-card:not(.related-card--hero),
	body.home .category-section .related-card:not(.related-card--hero),
	body.blog .category-section .related-card:not(.related-card--hero) {
		height: var(--home-mobile-card-height);
		max-height: var(--home-mobile-card-height);
	}

	body.home .bento-section .related-card:not(.related-card--hero) .related-card__text,
	body.blog .bento-section .related-card:not(.related-card--hero) .related-card__text,
	body.home .category-section .related-card:not(.related-card--hero) .related-card__text,
	body.blog .category-section .related-card:not(.related-card--hero) .related-card__text {
		height: var(--home-mobile-text-height);
		min-height: var(--home-mobile-text-height);
		overflow: hidden;
		padding: var(--spacing-lg);
	}

	body.home .bento-section .related-card:not(.related-card--hero) .related-card__image-link,
	body.blog .bento-section .related-card:not(.related-card--hero) .related-card__image-link,
	body.home .category-section .related-card:not(.related-card--hero) .related-card__image-link,
	body.blog .category-section .related-card:not(.related-card--hero) .related-card__image-link {
		flex: 0 0 auto;
		height: var(--home-mobile-image-height);
		aspect-ratio: 16 / 9;
	}

	body.home .bento-section .related-card:not(.related-card--hero) .related-card__title,
	body.blog .bento-section .related-card:not(.related-card--hero) .related-card__title,
	body.home .category-section .related-card:not(.related-card--hero) .related-card__title,
	body.blog .category-section .related-card:not(.related-card--hero) .related-card__title,
	body.home .bento-card .related-card__title,
	body.blog .bento-card .related-card__title {
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
		text-overflow: ellipsis;
		line-height: var(--leading-tight);
		height: calc(var(--leading-tight) * 3em);
		min-height: calc(var(--leading-tight) * 3em);
		max-height: calc(var(--leading-tight) * 3em);
		margin-bottom: 0;
	}

	body.home .bento-section .related-card:not(.related-card--hero) .related-card__title a,
	body.blog .bento-section .related-card:not(.related-card--hero) .related-card__title a,
	body.home .category-section .related-card:not(.related-card--hero) .related-card__title a,
	body.blog .category-section .related-card:not(.related-card--hero) .related-card__title a,
	body.home .bento-card .related-card__title a,
	body.blog .bento-card .related-card__title a {
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
		text-overflow: ellipsis;
		line-height: var(--leading-tight);
		height: calc(var(--leading-tight) * 3em);
		min-height: calc(var(--leading-tight) * 3em);
		max-height: calc(var(--leading-tight) * 3em);
	}

	body.home .bento-section .related-card:not(.related-card--hero) .related-card__body,
	body.blog .bento-section .related-card:not(.related-card--hero) .related-card__body,
	body.home .category-section .related-card:not(.related-card--hero) .related-card__body,
	body.blog .category-section .related-card:not(.related-card--hero) .related-card__body {
		display: flex;
		flex-direction: column;
		height: 100%;
	}

	body.home .related-card:not(.related-card--hero) .related-card__image-link,
	body.blog .related-card:not(.related-card--hero) .related-card__image-link {
		position: relative;
	}

	body.home .related-card:not(.related-card--hero) .related-card__btn,
	body.blog .related-card:not(.related-card--hero) .related-card__btn,
	body.home .related-card:not(.related-card--hero) .related-card__image-link .related-card__btn,
	body.blog .related-card:not(.related-card--hero) .related-card__image-link .related-card__btn {
		right: var(--spacing-md);
		bottom: var(--spacing-md);
	}

}


/* ===========================
   LICENCIAS BENTO GRID
   =========================== */

.lic-bento-section {
	margin-bottom: var(--spacing-2xl);
	background-color: var(--color-dark);
	color: var(--color-white);
	padding-top: var(--spacing-md);
	padding-bottom: var(--spacing-4xl);
}
.lic-bento-section h2 a , .lic-bento-section .category-section-link{
	color: var(--color-white);
}
.lic-bento-section .category-section-link::before {
	background-color: var(--color-white);
}
/*
.category-section{
	margin: var(--spacing-4xl) 0;

}
*/
section.category-section.section-eventos {
    padding-bottom: 4rem;
}


/* Outer grid: 40% left / 60% right */
.lic-bento-grid {
	display: grid;
	grid-template-columns: 2fr 3fr;
	gap: 1.5rem;
	height: 680px;
}

/* Right panel: two rows stacked */
.lic-right {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	min-height: 0;
}

.lic-right__top,
.lic-right__bottom {
	flex: 1;
	display: grid;
	gap: 1.5rem;
	min-height: 0;
}

/* Top row: image card ~60% / text card ~40% */
.lic-right__top {
	grid-template-columns: 3fr 2fr;
}

/* Bottom row: card 4 (1fr) + card 5 doble ancho (2fr) */
.lic-right__bottom {
	grid-template-columns: 1fr 2fr;
}

/* ---- Shared card base ---- */
.lic-card {
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	background-color: #3c5a8a;
}

.lic-card__link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

/* Ocultar markup exclusivo de móvil en desktop */
.lic-card__mobile-body {
	display: none;
}

/* ---- Card 1: imagen full-bleed columna izquierda ---- */
.lic-card--1 {
	background-color: #1a1a2e;
}

.lic-card--1 img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ---- Card 2: imagen horizontal que llena la card ---- */
.lic-card--2 {
	background-color: var(--color-primary);
}

.lic-card--2 img {
	width: 100%;
	height: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	display: block;
}

/* ---- Cards 3 y 4: solo texto ---- */
.lic-card--3,
.lic-card--4 {
	display: flex;
	flex-direction: column;
}

.lic-card--3 .related-card__text,
.lic-card--4 .related-card__text {
	flex: 1;
	min-height: 0;
}

/* La imagen de card 4 solo aparece en móvil */
.lic-card--4 .lic-card--4__mobile-img {
	display: none;
}

/* ---- Card 5: texto arriba + imagen abajo ---- */
.lic-card--5 {
	display: flex;
	flex-direction: column;
}

.lic-card--5 .related-card__text {
	padding: var(--spacing-lg) var(--spacing-xl) var(--spacing-md);
	flex: 0 0 auto;
	min-height: unset;
}

.lic-card__mixed-image {
	flex: 1;
	position: relative;
	overflow: hidden;
	min-height: 0;
}

.lic-card__mixed-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ---- Contenido de texto ---- */
.lic-card__content {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.lic-card__title {
	color: var(--color-white);
	font-weight: 700;
	text-transform: uppercase;
	font-size: var(--text-lg);
	line-height: var(--leading-tight);
	margin: 0 0 var(--spacing-sm);
}

.lic-card__excerpt {
	color: var(--color-white);
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	line-clamp: 3;
	overflow: hidden;
	opacity: 0.9;
}

/* ---- Botón circular rojo ---- */
.lic-card__cta {
	position: absolute;
	bottom: var(--spacing-md);
	right: var(--spacing-md);
	z-index: 2;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background-color: #d83553;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: transform var(--transition-base);
	flex-shrink: 0;
}

.lic-card__cta svg {
	width: 24px;
	height: 24px;
}

.lic-card:hover .lic-card__cta {
	transform: translate(3px, -3px);
}

/* El botón sobre la imagen en card 5 queda dentro de .lic-card__mixed-image */
.lic-card__cta--over-image {
	position: absolute;
}


/* ===========================
   Responsive — Licencias Bento
   =========================== */

@media (max-width: 1024px) {
	.lic-bento-grid {
		grid-template-columns: 1fr;
		height: auto;
		
	}

	.lic-card--1 {
		height: 360px;
	}

	.lic-right {
		height: auto;
		gap: 1.5rem;
	}

	.lic-right__top,
	.lic-right__bottom {
		height: 280px;
		gap: 1.5rem;
	}
}

@media (max-width: 640px) {
	/* Ocultar cards duplicadas visualmente en móvil */
	.lic-card--1,
	.lic-card--3 {
		display: none;
	}

	/* Grid principal: una columna, altura libre */
	.lic-bento-grid {
		grid-template-columns: 1fr;
		height: auto;
	}

	/* Panel derecho: columna, altura libre */
	.lic-right {
		height: auto;
	}

	/* Filas: una columna, altura libre (sobreescribe el 280px del 1024px) */
	.lic-right__top,
	.lic-right__bottom {
		grid-template-columns: 1fr;
		height: auto;
		flex: none;
	}

	/* Cards visibles: misma altura que related-card */
	.lic-card--2,
	.lic-card--4,
	.lic-card--5 {
		display: flex;
		flex-direction: column;
		height: var(--home-mobile-card-height);
		max-height: var(--home-mobile-card-height);
	}

	/* Card 2: ocultar imagen desktop, activar cuerpo móvil */
	.lic-card--2 .lic-card__desktop-img {
		display: none;
	}

	.lic-card--2 .lic-card__mobile-body {
		display: flex;
		flex-direction: column;
		flex: 1;
		position: relative;
	}

	.lic-card--2 .lic-card__mobile-body .related-card__text {
		flex: 0 0 auto;
		height: var(--home-mobile-text-height);
		min-height: var(--home-mobile-text-height);
		overflow: hidden;
		padding: var(--spacing-lg);
	}

	.lic-card--2 .lic-card__mobile-body .related-card__image-link {
		flex: 0 0 auto;
		min-height: 0;
		height: var(--home-mobile-image-height);
		aspect-ratio: 16 / 9;
	}

	/* Card 4: en móvil el texto se fija y la imagen llena el resto */
	.lic-card--4 .related-card__text {
		flex: 0 0 auto;
		height: var(--home-mobile-text-height);
		min-height: var(--home-mobile-text-height);
		overflow: hidden;
	}

	.lic-card--4 .lic-card--4__mobile-img {
		display: block;
		flex: 0 0 auto;
		min-height: 0;
		height: var(--home-mobile-image-height);
		aspect-ratio: 16 / 9;
	}

	/* Card 5: imagen inferior con altura libre */
	.lic-card--5 .related-card__text {
		flex: 0 0 auto;
		height: var(--home-mobile-text-height);
		min-height: var(--home-mobile-text-height);
		overflow: hidden;
	}

	.lic-card--5 .lic-card__mixed-image {
		flex: 0 0 auto;
		min-height: 0;
		height: var(--home-mobile-image-height);
		aspect-ratio: 16 / 9;
	}
}

/* ===========================
   BANNER DOS — suscripción full width
   =========================== */
.banner-dos-section {
	width: 100%;
	max-width: var(--container-2xl);
	padding: 0 var(--spacing-md);
	margin-right: auto;
	margin-left: auto;
	margin-bottom: var(--spacing-4xl);
	
}
.banner-dos {
	background-color: var(--color-primary);
	border-radius: var(--radius-xl);
	width: 100%;
	max-width: var(--container-2xl);
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	padding: var(--spacing-xl) var(--spacing-2xl);
	gap: var(--spacing-xl);
	overflow: visible;
	position: relative;
}

/* ---- Columna izquierda: título + radios ---- */
.banner-dos-left {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.banner-dos-left h3 {
	color: var(--color-white);
	font-family: var(--font-heading);
	font-size: var(--text-4xl);
	text-transform: uppercase;
	line-height: var(--leading-tight);
	margin: 0;
}

.banner-dos-left h3 .last-news {
	color: var(--color-secondary);
	display: block;
}

.banner-dos-left .block-radio {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin: 0;
}

.banner-dos-left .block-radio p {
	color: var(--color-white);
	margin: 0;
	white-space: nowrap;
	font-size: var(--text-sm);
}

.banner-dos-left .radio-group {
	display: flex;
	gap: var(--spacing-md);
	justify-content: flex-start;
	flex-wrap: nowrap;
}

/* ---- Columna central: imagen ---- */
.banner-dos-center {
	flex: 0 0 auto;
	display: flex;
	align-items: flex-end;
	align-self: flex-end;
}

.banner-dos-center img {
	width: 300px;
	height: auto;
	display: block;
	position: relative;
	bottom: 100px;
	right: 25px;
}

/* ---- Columna derecha: formulario ---- */
.banner-dos-right {
	flex: 0 0 340px;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.banner-dos-right input[type="email"] {
	width: 100%;
	padding: var(--spacing-md) var(--spacing-lg);
	border: none;
	border-radius: var(--radius-lg);
	font-size: var(--text-base);
	font-family: var(--font-body);
	color: var(--color-text);
	background-color: var(--color-white);
	outline: none;
}

.banner-dos-right input[type="email"]::placeholder {
	color: var(--color-text-light);
}



.banner-dos-right .btn-secondary:hover {
	filter: brightness(1.08);
}

.banner-dos-politica {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.banner-dos-right .politica-check {
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
	max-width: none;
	justify-content: flex-end;
}

.banner-dos-right .politica-check a {
	color: rgba(255, 255, 255, 0.85);
}

.banner-dos-right .politica-text {
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.65);
	text-align: right;
	margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
	.banner-dos {
		flex-wrap: wrap;
		padding: var(--spacing-xl) var(--spacing-lg);
		gap: var(--spacing-lg);
	}

	

	.banner-dos-right {
		flex: 1 1 280px;
	}
}

@media (max-width: 640px) {
	.banner-dos {
		flex-direction: column;
		align-items: stretch;
		padding: 0 var(--spacing-md);
		padding-top: var(--spacing-4xl);
		padding-bottom: var(--spacing-2xl);
	}
	.banner-dos-center {
	position: absolute;	
	width: 200px;
	bottom: 300px;
	right: 35px;
	}

	.banner-dos-left h3 {
		font-size: var(--text-2xl);
		text-align: center;
	}

	.banner-dos-left .block-radio {
		flex-direction: column;
		align-items: center;
		gap: var(--spacing-sm);
	}

	.banner-dos-right {
		flex: none;
		width: 100%;
	}

	.banner-dos-right .politica-check,
	.banner-dos-right .politica-text {
		text-align: left;
		justify-content: flex-start;
	}
}


/* ===========================
   BANNER BUSINESS
   =========================== */

.banner-business {
	max-width: var(--container-2xl);
	margin-top: var(--spacing-2xl);
	margin-bottom: var(--spacing-2xl);
	margin-left: auto;
	padding: 0 var(--spacing-md);
	margin-right: auto;
}

.banner-business a {
	display: block;
	line-height: 0;
}

.banner-business picture {
	display: block;
}

.banner-business img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius-xl);
}
@media(max-width: 640px){
	.banner-business{
		padding: 0 var(--spacing-md);
		
	}
}

body.home .site-main {
	position: relative;
}
body.home .site-main  {
	background-image: url('../circulo-izq.svg');
	background-repeat: no-repeat;
	background-size: 450px;
}

section.category-section.section-business {
	padding-top: var(--spacing-2xl);
	padding-bottom: var(--spacing-2xl);
}
section.category-section.section-eventos {
    background-image: url('../circulo-top.svg');
    background-position: left bottom;
    background-repeat: no-repeat;
    background-size: 750px;
}

@media (max-width: 768px) {
	body.home .site-main::before {
		display: none;
	}
	section.category-section.section-eventos {
		background-image: none;
	}
}

section.category-section.section-business .category-section-header {
	margin-top: 0;
}

section.category-section.section-business {
	  background-image: url('../bg-bussines.svg');
    background-position: right top;
    background-repeat: no-repeat;
    background-size: 350px;
}

.bento-section .related-card__title a, .section-business .related-card__title a {
	display: -webkit-box;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: var(--leading-tight);
	min-height: calc(var(--leading-tight) * 5em);
}