/* ============================================================
   Lazuli Coast Club Blog Carousel
   ============================================================ */

/* ---- Variables ---- */
.lazuli-bc {
	--lazuli-accent: #008bc1;
	--lazuli-edge: 16px;
	--lazuli-gap: 20px;
	--lazuli-grid-gap: 24px;
	--lazuli-grid-rgap: 44px;
}

/* ---- Swiper core (por seguridad, scoped) ---- */
.lazuli-carousel {
	position: relative;
	overflow: hidden;
	list-style: none;
	padding: 0;
	z-index: 1;
}
.lazuli-carousel .swiper-wrapper {
	position: relative;
	display: flex;
	width: 100%;
	box-sizing: content-box;
	transition-property: transform;
}
.lazuli-carousel .swiper-slide {
	flex-shrink: 0;
	position: relative;
	height: auto; /* tarjetas de igual alto */
}

/* ---- Anchos 30 / 30 / 40 (solo escritorio) ---- */
@media (min-width: 1025px) {
	.lazuli-carousel .lazuli-slide {
		width: calc(30% - var(--lazuli-edge));
	}
	.lazuli-carousel .lazuli-slide[data-pos="2"] {
		width: calc(40% - var(--lazuli-edge));
	}
}

/* ---- Tarjeta ---- */
.lazuli-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: transparent;
	border: none;
}
.lazuli-card__media {
	display: block;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: #f0f0f0;
}
.lazuli-slide[data-pos="2"] .lazuli-card__media {
	aspect-ratio: 5 / 4;
}
.lazuli-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .5s ease;
}
.lazuli-card:hover .lazuli-card__media img {
	transform: scale(1.05);
}
.lazuli-card__body {
	padding: 16px 0 0;
}
.lazuli-card__date {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
	color: var(--lazuli-accent);
}
.lazuli-card__date svg {
	flex-shrink: 0;
}
.lazuli-card__date span {
	font-size: 12px;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: #888;
}
.lazuli-card__title {
	margin: 0 0 14px;
	font-size: 20px;
	line-height: 1.25;
	text-transform: uppercase;
	font-weight: 500;
	color: rgb(22, 22, 46);
}
.lazuli-card__title a {
	color: inherit;
	text-decoration: none;
}
.lazuli-card__title a:hover {
	color: var(--lazuli-accent);
}
.lazuli-card__excerpt {
	font-size: 15px;
	line-height: 1.6;
	color: #6a6a6a;
	margin-bottom: 16px;
}
.lazuli-card__more {
	display: inline-block;
	color: var(--lazuli-accent);
	font-size: 15px;
	text-decoration: none;
	border-bottom: 1px solid var(--lazuli-accent);
	padding-bottom: 2px;
	transition: opacity .2s;
}
.lazuli-card__more:hover {
	opacity: .75;
}

/* ---- Controles ---- */
.lazuli-bc__controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 18px;
	margin-top: 30px;
}
.lazuli-prev,
.lazuli-next {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	cursor: pointer;
	color: #333;
	padding: 4px;
	transition: color .2s;
}
.lazuli-prev:hover,
.lazuli-next:hover,
.lazuli-prev:focus,
.lazuli-next:focus,
.lazuli-prev:active,
.lazuli-next:active {
	background: transparent !important;
	box-shadow: none !important;
	color: var(--lazuli-accent);
}
.lazuli-prev.swiper-button-disabled,
.lazuli-next.swiper-button-disabled {
	opacity: .3;
	cursor: default;
}

/* Puntos / cuadritos (forzados a mostrarse sobre el tema) */
.lazuli-pagination {
	position: static !important;
	display: inline-flex !important;
	align-items: center;
	gap: 8px;
	width: auto !important;
	height: auto !important;
}
.lazuli-pagination .swiper-pagination-bullet {
	display: inline-block !important;
	width: 9px !important;
	height: 9px !important;
	margin: 0 !important;
	border-radius: 2px;
	background: #cfcfcf;
	opacity: 1 !important;
	transition: background .2s;
	cursor: pointer;
}
.lazuli-pagination .swiper-pagination-bullet-active {
	background: #333;
}

/* ---- Tablet / móvil: tarjetas uniformes ---- */
@media (max-width: 1024px) {
	.lazuli-slide[data-pos="2"] .lazuli-card__media {
		aspect-ratio: 3 / 4;
	}
}
@media (max-width: 767px) {
	.lazuli-card__title { font-size: 18px; }
}

/* ============================================================
   Diseño: Cuadrícula (Grid)
   La grande alterna de lado por fila (diagonal).
   ============================================================ */
.lazuli-grid {
	display: flex;
	flex-wrap: wrap;
	column-gap: var(--lazuli-grid-gap);
	row-gap: var(--lazuli-grid-rgap);
}
.lazuli-grid-item {
	width: calc((100% - 2 * var(--lazuli-grid-gap)) * 0.3);
}
.lazuli-grid-item--big {
	width: calc((100% - 2 * var(--lazuli-grid-gap)) * 0.4);
}
.lazuli-grid-item--big .lazuli-card__media {
	aspect-ratio: 5 / 4;
}

/* Grid responsive: 2 columnas en tablet, 1 en móvil */
@media (max-width: 1024px) {
	.lazuli-grid-item,
	.lazuli-grid-item--big {
		width: calc((100% - var(--lazuli-grid-gap)) * 0.5);
	}
	.lazuli-grid-item--big .lazuli-card__media {
		aspect-ratio: 3 / 4;
	}
}
@media (max-width: 600px) {
	.lazuli-grid-item,
	.lazuli-grid-item--big {
		width: 100%;
	}
}

/* ============================================================
   Botón "Ver Más"
   ============================================================ */
.lazuli-more-wrap {
	text-align: center;
	margin-top: 40px;
}
.lazuli-more-btn {
	display: inline-block;
	color: var(--lazuli-accent);
	font-size: 15px;
	text-decoration: none;
	border-bottom: 1px solid var(--lazuli-accent);
	padding-bottom: 3px;
	transition: opacity .2s;
}
.lazuli-more-btn:hover {
	opacity: .75;
}
