/*
 * Infinita Project Management – Frontend styles.
 *
 * Uses CSS custom properties so Elementor style controls can override defaults
 * without needing to duplicate selectors per widget instance.
 */

.ipm-projects {
	--ipm-gap: 24px;
	--ipm-card-bg: #ffffff;
	--ipm-card-bg-hover: #ffffff;
	--ipm-card-border: 1px solid rgba(0, 0, 0, 0.06);
	--ipm-card-radius: 12px;
	--ipm-card-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
	--ipm-card-shadow-hover: 0 12px 28px rgba(0, 0, 0, 0.12);
	--ipm-card-padding: 20px;
	--ipm-title-color: #111827;
	--ipm-title-color-hover: #2563eb;
	--ipm-text-color: #4b5563;
	--ipm-text-color-hover: #4b5563;
	--ipm-metric-label-color: #6b7280;
	--ipm-metric-label-color-hover: #6b7280;
	--ipm-metric-value-color: #111827;
	--ipm-metric-value-color-hover: #111827;
	--ipm-button-color: #ffffff;
	--ipm-button-bg: #2563eb;
	--ipm-button-color-hover: #ffffff;
	--ipm-button-bg-hover: #1e40af;
	--ipm-image-height: 220px;
	--ipm-image-scale: 1.05;
	--ipm-pagination-gap: 6px;
	--ipm-pagination-color: #111827;
	--ipm-pagination-bg: transparent;
	--ipm-pagination-color-hover: #ffffff;
	--ipm-pagination-bg-hover: #2563eb;
	--ipm-pagination-color-active: #ffffff;
	--ipm-pagination-bg-active: #111827;
	--ipm-pagination-radius: 6px;
	--ipm-metrics-grid-vdivider: #e5e7eb;
	--ipm-metrics-grid-vdivider-width: 1px;
	--ipm-metric-icon-color: #57b33e;
	color: var(--ipm-text-color);
}

/* Grid layout */
.ipm-projects .ipm-grid {
	display: grid;
	gap: var(--ipm-gap);
	grid-template-columns: repeat(var(--ipm-columns, 3), minmax(0, 1fr));
}

.ipm-projects.ipm-layout-list .ipm-grid {
	grid-template-columns: 1fr;
}

/* Card */
.ipm-card {
	background: var(--ipm-card-bg);
	border: var(--ipm-card-border);
	border-radius: var(--ipm-card-radius);
	box-shadow: var(--ipm-card-shadow);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.ipm-card:hover,
.ipm-card:focus-within {
	background: var(--ipm-card-bg-hover);
	box-shadow: var(--ipm-card-shadow-hover);
	transform: translateY(-3px);
}

.ipm-card__media {
	display: block;
	overflow: hidden;
	margin: 0;
}

.ipm-card__media img {
	display: block;
	width: 100%;
	height: var(--ipm-image-height, 220px);
	object-fit: cover;
	object-position: center center;
	transition: transform 0.35s ease, opacity 0.35s ease, filter 0.35s ease;
}

.ipm-card:hover .ipm-card__media img,
.ipm-card:focus-within .ipm-card__media img {
	transform: scale(var(--ipm-image-scale, 1));
}

.ipm-card__body {
	padding: var(--ipm-card-padding);
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1 1 auto;
}

.ipm-card__title {
	margin: 0;
	font-size: 1.25rem;
	line-height: 1.3;
	color: var(--ipm-title-color);
}

.ipm-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.ipm-card__title a:hover,
.ipm-card__title a:focus,
.ipm-card:hover .ipm-card__title a,
.ipm-card:focus-within .ipm-card__title a {
	color: var(--ipm-title-color-hover);
}

.ipm-card__excerpt {
	margin: 0;
	color: var(--ipm-text-color);
	font-size: 0.95rem;
	transition: color 0.2s ease, text-shadow 0.2s ease;
}

.ipm-card:hover .ipm-card__excerpt,
.ipm-card:focus-within .ipm-card__excerpt {
	color: var(--ipm-text-color-hover);
}

.ipm-card__metrics {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.85rem;
}

.ipm-metric__label {
	color: var(--ipm-metric-label-color);
	font-weight: 600;
	transition: color 0.2s ease, text-shadow 0.2s ease;
}

.ipm-metric__value {
	color: var(--ipm-metric-value-color);
	font-weight: 500;
	transition: color 0.2s ease, text-shadow 0.2s ease;
}

.ipm-card:hover .ipm-metric__label,
.ipm-card:focus-within .ipm-metric__label {
	color: var(--ipm-metric-label-color-hover);
}

.ipm-card:hover .ipm-metric__value,
.ipm-card:focus-within .ipm-metric__value {
	color: var(--ipm-metric-value-color-hover);
}

.ipm-metric__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ipm-metric-icon-color);
}

.ipm-metric__icon .ipm-icon {
	width: 20px;
	height: 20px;
	display: block;
}

.ipm-metric__icon .ipm-metric-icon-img {
	width: 20px;
	height: 20px;
	display: block;
	object-fit: contain;
}

.ipm-card__metrics--grid .ipm-metric__icon {
	margin-bottom: 6px;
}

.ipm-card__metrics--table .ipm-metric__icon--table {
	flex: 0 0 auto;
	align-self: center;
	margin-inline-end: 8px;
}

.ipm-card__metrics--table .ipm-metric__icon .ipm-icon {
	width: 18px;
	height: 18px;
}

.ipm-card__metrics--table .ipm-metric__icon .ipm-metric-icon-img {
	width: 18px;
	height: 18px;
}

.ipm-card__metrics--list .ipm-metric__icon {
	flex-shrink: 0;
	margin-inline-end: 6px;
}

/* ----- Grid layout (default) ----- */
.ipm-card__metrics--grid {
	display: grid;
	gap: 10px 16px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ipm-card__metrics--grid.ipm-card__metrics--grid-cols-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Vertical lines between metric grid columns (not first column of each row). */
.ipm-card__metrics--grid.ipm-card__metrics--grid-cols-2 .ipm-metric:nth-child(2n) {
	border-inline-start: var(--ipm-metrics-grid-vdivider-width, 1px) solid var(--ipm-metrics-grid-vdivider, #e5e7eb);
	padding-inline-start: clamp(10px, 2.5vw, 16px);
}

.ipm-card__metrics--grid.ipm-card__metrics--grid-cols-3 .ipm-metric:not(:nth-child(3n + 1)) {
	border-inline-start: var(--ipm-metrics-grid-vdivider-width, 1px) solid var(--ipm-metrics-grid-vdivider, #e5e7eb);
	padding-inline-start: clamp(10px, 2.5vw, 16px);
}

.ipm-card__metrics--grid .ipm-metric {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ipm-card__metrics--grid .ipm-metric__label {
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 0.7rem;
}

/* ----- Table layout ----- */
.ipm-card__metrics--table {
	display: block;
	margin: 0;
	padding: 0;
}

.ipm-card__metrics--table .ipm-metric {
	display: flex;
	align-items: baseline;
	gap: 12px;
	padding: 8px 0;
	border-bottom: 1px solid #e5e7eb;
}

.ipm-card__metrics--table .ipm-metric:last-child {
	border-bottom: 0;
}

.ipm-card__metrics--table .ipm-metric__label {
	flex: 0 0 40%;
	margin: 0;
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.85rem;
}

.ipm-card__metrics--table .ipm-metric__value {
	flex: 1;
	margin: 0;
	text-align: left;
}

.ipm-card__metrics--table.ipm-metrics--striped .ipm-metric:nth-child(even) {
	background: #f9fafb;
}

/* ----- List layout ----- */
.ipm-card__metrics--list {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ipm-card__metrics--list .ipm-metric {
	display: flex;
	align-items: baseline;
	gap: 6px;
	position: relative;
}

.ipm-card__metrics--list .ipm-metric__label {
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.85rem;
}

.ipm-card__metrics--list .ipm-metric__separator {
	color: var(--ipm-metric-label-color);
}

.ipm-card__metrics--list.ipm-metrics--bullet-dot .ipm-metric,
.ipm-card__metrics--list.ipm-metrics--bullet-dash .ipm-metric,
.ipm-card__metrics--list.ipm-metrics--bullet-arrow .ipm-metric {
	padding-left: 18px;
}

.ipm-card__metrics--list.ipm-metrics--bullet-dot .ipm-metric::before {
	content: "\2022";
	position: absolute;
	left: 2px;
	color: var(--ipm-metric-label-color);
	font-weight: 700;
}

.ipm-card__metrics--list.ipm-metrics--bullet-dash .ipm-metric::before {
	content: "\2013";
	position: absolute;
	left: 0;
	color: var(--ipm-metric-label-color);
	font-weight: 700;
}

.ipm-card__metrics--list.ipm-metrics--bullet-arrow .ipm-metric::before {
	content: "\2192";
	position: absolute;
	left: 0;
	color: var(--ipm-metric-label-color);
	font-weight: 700;
}

/* Read-more button */
.ipm-card__more {
	margin-top: auto;
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 18px;
	border-radius: 999px;
	background: var(--ipm-button-bg);
	color: var(--ipm-button-color);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.ipm-card__more:hover,
.ipm-card__more:focus {
	background: var(--ipm-button-bg-hover);
	color: var(--ipm-button-color-hover);
	transform: translateY(-1px);
}

/* List layout specific tweaks */
.ipm-layout-list .ipm-card {
	flex-direction: row;
	align-items: stretch;
}

.ipm-layout-list .ipm-card__media {
	flex: 0 0 38%;
	max-width: 38%;
}

.ipm-layout-list .ipm-card__media img {
	height: 100%;
	min-height: var(--ipm-image-height, 220px);
}

.ipm-layout-list .ipm-card__body {
	flex: 1;
	min-width: 0;
}

/* Load More */
.ipm-load-more-wrap {
	display: flex;
	justify-content: center;
	margin-top: 32px;
}

.ipm-load-more {
	padding: 12px 28px;
	border: 0;
	border-radius: 999px;
	background: var(--ipm-button-bg);
	color: var(--ipm-button-color);
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.ipm-load-more:hover:not(:disabled) {
	background: var(--ipm-button-bg-hover);
	color: var(--ipm-button-color-hover);
	transform: translateY(-1px);
}

.ipm-load-more:disabled,
.ipm-load-more.is-loading {
	opacity: 0.7;
	cursor: progress;
}

.ipm-load-more.is-hidden {
	display: none;
}

/* Numbered pagination */
.ipm-pagination {
	margin-top: 32px;
	display: flex;
	justify-content: center;
}

.ipm-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 12px;
	margin: 0 var(--ipm-pagination-gap);
	border-radius: var(--ipm-pagination-radius);
	background: var(--ipm-pagination-bg);
	color: var(--ipm-pagination-color);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95rem;
	transition: background 0.2s ease, color 0.2s ease;
}

.ipm-pagination a.page-numbers:hover,
.ipm-pagination a.page-numbers:focus {
	background: var(--ipm-pagination-bg-hover);
	color: var(--ipm-pagination-color-hover);
}

.ipm-pagination .page-numbers.current {
	background: var(--ipm-pagination-bg-active);
	color: var(--ipm-pagination-color-active);
}

.ipm-pagination .page-numbers.dots {
	background: transparent;
	cursor: default;
}

/* Empty state */
.ipm-empty {
	padding: 40px;
	text-align: center;
	color: var(--ipm-metric-label-color);
	font-style: italic;
}

/* ----- Premium showcase card (reference layout) ----- */
.ipm-projects.ipm-design-premium {
	/* Wider gutters between project cards in the grid (row + column). */
	--ipm-gap: 40px;
}

.ipm-design-premium {
	--ipm-premium-accent: #57b33e;
	--ipm-premium-title: #000000;
	--ipm-premium-value: #000000;
	--ipm-premium-label: #888888;
	--ipm-premium-border: #eeeeee;
	--ipm-premium-divider: #c8c8c8;
	--ipm-premium-body-pad: clamp(20px, 4vw, 24px);
	/* Title: clearly larger than body copy; scales with viewport. */
	--ipm-premium-title-size: clamp(1.5rem, 3.85vw, 1.9375rem);
	/* Metric values: prominent under icons. */
	--ipm-premium-value-size: clamp(1.125rem, 2.6vw, 1.375rem);
	--ipm-premium-label-size: clamp(0.8125rem, 2vw, 0.9375rem);
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.ipm-design-premium .ipm-card--premium {
	background: #ffffff;
	border: 1px solid var(--ipm-premium-border);
	border-radius: 14px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	overflow: hidden;
	transition: box-shadow 0.3s ease, transform 0.3s ease, background 0.25s ease;
}

.ipm-design-premium .ipm-card--premium:hover,
.ipm-design-premium .ipm-card--premium:focus-within {
	background: #ffffff;
	transform: translateY(-3px);
	box-shadow: 0 10px 32px rgba(0, 0, 0, 0.09);
}

.ipm-premium-card__media {
	display: block;
	position: relative;
	width: 100%;
	margin: 0;
	/* No in-flow children: padding-bottom gives a definite 16:9 box (more reliable than aspect-ratio inside flex). */
	height: 0;
	padding-bottom: 56.25%;
	overflow: hidden;
	line-height: 0;
	background: #e8eaed;
	flex-shrink: 0;
}

.ipm-premium-card__media img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	max-width: none;
	min-width: 100%;
	min-height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.ipm-premium-card__body {
	padding: var(--ipm-premium-body-pad);
	display: flex;
	flex-direction: column;
	gap: 0;
}

.ipm-premium-card__location {
	display: flex;
	align-items: center;
	gap: 7px;
	margin: 0 0 0.5rem;
	padding: 0;
	font-size: 0.9375rem;
	line-height: 1.4;
	font-weight: 500;
	color: var(--ipm-premium-label);
	text-align: left;
	align-self: stretch;
}

.ipm-premium-card__location-icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ipm-premium-accent);
}

.ipm-premium-card__location-icon .ipm-icon--location {
	width: 16px;
	height: 16px;
	display: block;
}

.ipm-premium-card__location-text {
	min-width: 0;
}

.ipm-premium-card__title {
	margin: 0 0 1.5rem;
	padding: 0;
	font-size: var(--ipm-premium-title-size);
	font-weight: 700;
	line-height: 1.28;
	color: var(--ipm-premium-title);
	letter-spacing: -0.02em;
	text-align: left;
	align-self: stretch;
}

/* Title is not a link; keep color steady on card hover/focus. */
.ipm-design-premium .ipm-card--premium:hover .ipm-premium-card__title,
.ipm-design-premium .ipm-card--premium:focus-within .ipm-premium-card__title {
	color: var(--ipm-premium-title);
	opacity: 1;
}

.ipm-premium-card__location + .ipm-premium-card__title {
	margin-top: 0;
}

.ipm-premium-card__title:has(+ .ipm-premium-card__description) {
	margin-bottom: 0.5rem;
}

.ipm-premium-card__description {
	margin: 0 0 1.25rem;
	font-size: 0.9rem;
	line-height: 1.5;
	color: #555555;
	text-align: left;
	align-self: stretch;
}

.ipm-premium-card__description > p {
	margin: 0 0 0.65em;
}

.ipm-premium-card__description > p:last-child {
	margin-bottom: 0;
}

/* Full post body under title: keep media and floats from breaking the card. */
.ipm-premium-card__description--full {
	overflow-wrap: anywhere;
	word-break: break-word;
}

.ipm-premium-card__description--full img,
.ipm-premium-card__description--full video,
.ipm-premium-card__description--full iframe {
	max-width: 100%;
	height: auto;
}

.ipm-premium-card__description--full .wp-block-embed {
	margin-left: 0;
	margin-right: 0;
}

.ipm-premium-metrics {
	display: grid;
	grid-template-columns: repeat(var(--ipm-premium-metric-cols, 3), minmax(0, 1fr));
	gap: 0;
	margin: 0;
	padding: 0.25rem 0 0;
	align-items: stretch;
}

.ipm-premium-metric {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	text-align: center;
	gap: 0.5rem;
	padding: 0.5rem 0.625rem 0.375rem;
	min-width: 0;
}

/* Inset vertical rules between columns (do not run full height). */
.ipm-premium-metric:not(:first-child)::before {
	content: "";
	position: absolute;
	left: 0;
	top: 1rem;
	bottom: 1rem;
	width: 1px;
	background: var(--ipm-premium-divider);
	box-shadow: 0 0 0 0.5px rgba(0, 0, 0, 0.06);
	pointer-events: none;
}

.ipm-premium-metric__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--ipm-premium-accent);
	margin: 0 0 0.125rem;
	flex-shrink: 0;
}

.ipm-premium-metric__icon--empty {
	min-height: 24px;
	margin-bottom: 0.125rem;
}

.ipm-premium-metric__icon .ipm-icon {
	width: 24px;
	height: 24px;
}

.ipm-premium-metric__icon .ipm-metric-icon-img {
	width: 24px;
	height: 24px;
	display: block;
	object-fit: contain;
}

.ipm-premium-metric__value {
	display: block;
	font-size: var(--ipm-premium-value-size);
	line-height: 1.28;
	margin: 0;
	padding: 0;
	color: var(--ipm-premium-value);
}

.ipm-premium-metric__value-inner {
	display: inline-block;
	max-width: 100%;
}

.ipm-premium-metric__value-strong {
	font-weight: 700;
	color: inherit;
}

.ipm-premium-metric__value-suffix {
	font-weight: 400;
	color: inherit;
}

.ipm-premium-metric__label {
	display: block;
	margin: 0;
	padding: 0;
	font-size: var(--ipm-premium-label-size);
	font-weight: 400;
	color: var(--ipm-premium-label);
	line-height: 1.35;
	max-width: 100%;
}

.ipm-premium-card__more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 1.25rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ipm-premium-accent);
	text-decoration: none;
	align-self: flex-start;
	transition: opacity 0.2s ease;
}

.ipm-premium-card__more:hover,
.ipm-premium-card__more:focus {
	opacity: 0.8;
}

.ipm-layout-list.ipm-design-premium .ipm-card--premium {
	flex-direction: column;
}

.ipm-layout-list.ipm-design-premium .ipm-card--premium .ipm-premium-card__media {
	max-width: 100%;
	flex: none;
}

/* Responsive */
@media (max-width: 1024px) {
	.ipm-projects .ipm-grid {
		grid-template-columns: repeat(var(--ipm-columns-tablet, 2), minmax(0, 1fr));
	}
	.ipm-layout-list .ipm-card {
		flex-direction: column;
	}
	.ipm-layout-list .ipm-card__media {
		flex: 0 0 auto;
		max-width: 100%;
	}
}

@media (max-width: 640px) {
	.ipm-projects .ipm-grid {
		grid-template-columns: repeat(var(--ipm-columns-mobile, 1), minmax(0, 1fr));
	}
	.ipm-card__metrics--grid {
		grid-template-columns: 1fr !important;
	}

	.ipm-card__metrics--grid .ipm-metric {
		border-inline-start: none !important;
		padding-inline-start: 0 !important;
	}

	.ipm-design-premium .ipm-premium-metrics {
		grid-template-columns: 1fr !important;
	}

	.ipm-design-premium .ipm-premium-metric:not(:first-child)::before {
		display: none;
	}

	.ipm-design-premium .ipm-premium-metric {
		border-bottom: 1px solid var(--ipm-premium-divider);
		padding-bottom: 1.1rem;
		padding-top: 0.85rem;
	}

	.ipm-design-premium .ipm-premium-metric:first-child {
		padding-top: 0.35rem;
	}

	.ipm-design-premium .ipm-premium-metric:last-child {
		border-bottom: none;
		padding-bottom: 0.25rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.ipm-card,
	.ipm-card__media img,
	.ipm-card__more,
	.ipm-load-more,
	.ipm-card__title a {
		transition: none !important;
	}
	.ipm-card:hover,
	.ipm-card:focus-within {
		transform: none;
	}
	.ipm-card:hover .ipm-card__media img {
		transform: none;
	}
}
