/**
 * Image Cards Plugin — Frontend Styles
 * Lightweight, responsive, and Elementor-compatible.
 */

/* ============================================================
   Wrapper
   ============================================================ */
.icp-cards-wrapper {
	--icp-gap: 24px;
	--icp-cols: 3;
	width: 100%;
}

/* ============================================================
   Grid Layout
   ============================================================ */
.icp-layout-grid {
	display: grid;
	grid-template-columns: repeat(var(--icp-cols), 1fr);
	gap: var(--icp-gap);
}

/* Dynamic column helpers set via inline style + CSS custom property */
.icp-cols-1 { --icp-cols: 1; }
.icp-cols-2 { --icp-cols: 2; }
.icp-cols-3 { --icp-cols: 3; }
.icp-cols-4 { --icp-cols: 4; }
.icp-cols-5 { --icp-cols: 5; }
.icp-cols-6 { --icp-cols: 6; }

/* ============================================================
   Flex Layout
   ============================================================ */
.icp-layout-flex {
	display: flex;
	flex-wrap: wrap;
	gap: var(--icp-gap);
}

.icp-layout-flex .icp-card-item {
	flex: 1 1 calc(33.333% - var(--icp-gap));
	min-width: 220px;
}

/* ============================================================
   Card Item
   ============================================================ */
.icp-card-item {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.icp-card-item:hover {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.10);
	transform: translateY(-2px);
}

/* ============================================================
   Card Image
   ============================================================ */
.icp-card-image {
	width: 100%;
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.icp-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}

.icp-card-item:hover .icp-card-image img {
	transform: scale(1.04);
}

/* ============================================================
   Card Body
   ============================================================ */
.icp-card-body {
	padding: 16px 20px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.icp-card-title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 600;
	line-height: 1.4;
	color: inherit;
}

.icp-card-content {
	font-size: 0.9rem;
	line-height: 1.6;
	color: #555;
	flex: 1;
}

.icp-card-content p:first-child { margin-top: 0; }
.icp-card-content p:last-child  { margin-bottom: 0; }

/* ============================================================
   No Cards Message
   ============================================================ */
.icp-no-cards {
	color: #888;
	font-style: italic;
}

/* ============================================================
   Load More
   ============================================================ */
.icp-load-more-wrap {
	text-align: center;
	margin-top: 32px;
}

.icp-load-more-btn {
	display: inline-block;
	padding: 10px 32px;
	background: #0073aa;
	color: #fff;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-size: 0.95rem;
	font-weight: 500;
	transition: background 0.2s ease;
}

.icp-load-more-btn:hover,
.icp-load-more-btn:focus {
	background: #005d8c;
	outline: 2px solid #005d8c;
	outline-offset: 2px;
}

.icp-load-more-btn:disabled {
	background: #ccc;
	cursor: not-allowed;
}

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

/* Tablet */
@media (max-width: 1024px) {
	.icp-layout-grid.icp-cols-5,
	.icp-layout-grid.icp-cols-6 {
		--icp-cols: 3;
	}

	.icp-layout-grid.icp-cols-4 {
		--icp-cols: 2;
	}
}

/* Mobile */
@media (max-width: 640px) {
	.icp-layout-grid {
		--icp-cols: 1 !important;
	}

	.icp-layout-flex .icp-card-item {
		flex: 1 1 100%;
	}

	.icp-cards-wrapper {
		--icp-gap: 16px;
	}
}
