/* Zipni Portfolio — block styles */

/* ===== Single: Before/After ===== */

.zipni-ba-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.zipni-ba-card {
	background: var(--wp--preset--color--surface, #fff);
	border: 1px solid var(--wp--preset--color--border, #eaeaea);
	border-radius: 1rem;
	padding: 1.25rem;
	text-align: center;
	margin: 0;
}

.zipni-ba-card--after {
	border-color: var(--wp--preset--color--accent, #d63031);
	border-width: 2px;
}

.zipni-ba-label {
	display: block;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
	font-weight: 600;
	color: var(--wp--preset--color--text-secondary, #666);
	margin-bottom: 0.75rem;
}

.zipni-ba-card--after .zipni-ba-label {
	color: var(--wp--preset--color--accent, #d63031);
}

.zipni-ba-card img {
	width: 100%;
	border-radius: 0.5rem;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	background: #fafafa;
}

.zipni-ba-card--after img {
	object-fit: cover;
}

/* Single: meta badges */

.zipni-portfolio-badges {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}

.zipni-badge {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: 2rem;
	font-size: var(--wp--preset--font-size--xs, 0.75rem);
	font-weight: 500;
	background: var(--wp--preset--color--surface-alt, #faf5f5);
	color: var(--wp--preset--color--text-secondary, #666);
}

.zipni-badge--accent {
	background: var(--wp--preset--color--accent-light, #fde8e8);
	color: var(--wp--preset--color--accent, #d63031);
}

/* Single: description */

.zipni-portfolio-description {
	font-size: var(--wp--preset--font-size--md, 1rem);
	line-height: 1.7;
	color: var(--wp--preset--color--text-primary, #1a1a1a);
	margin-bottom: 2rem;
}

/* Single: figcaption */

.zipni-ba-card figcaption {
	font-size: var(--wp--preset--font-size--xs, 0.75rem);
	color: var(--wp--preset--color--text-secondary, #666);
	margin-top: 0.5rem;
	line-height: 1.4;
}

/* Single: cross-links */

.zipni-portfolio-crosslinks {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 1rem;
	margin-top: 2rem;
	padding: 1rem 1.25rem;
	background: var(--wp--preset--color--surface, #fff);
	border: 1px solid var(--wp--preset--color--border, #eaeaea);
	border-radius: 0.75rem;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
}

.zipni-portfolio-crosslinks span {
	font-weight: 600;
	color: var(--wp--preset--color--text-secondary, #666);
}

.zipni-portfolio-crosslinks a {
	color: var(--wp--preset--color--accent, #d63031);
	text-decoration: none;
}

.zipni-portfolio-crosslinks a:hover {
	text-decoration: underline;
}

/* Single: CTA */

.zipni-portfolio-cta {
	text-align: center;
	padding: 2rem;
	background: var(--wp--preset--color--surface-alt, #faf5f5);
	border-radius: 1rem;
	margin-top: 2rem;
}

.zipni-portfolio-cta p {
	margin: 0 0 1rem;
	color: var(--wp--preset--color--text-secondary, #666);
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
}

.zipni-portfolio-cta a {
	display: inline-block;
	padding: 0.75rem 2rem;
	background: var(--wp--preset--color--accent, #d63031);
	color: #fff;
	border-radius: 0.5rem;
	font-weight: 600;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
	text-decoration: none;
	transition: background-color 0.2s;
}

.zipni-portfolio-cta a:hover {
	background: var(--wp--preset--color--accent-hover, #b71c1c);
}

/* ===== Archive: Grid ===== */

.zipni-portfolio-filters {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 2rem;
}

.zipni-portfolio-filters a {
	padding: 0.375rem 1rem;
	border-radius: 2rem;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
	font-weight: 500;
	text-decoration: none;
	color: var(--wp--preset--color--text-secondary, #666);
	background: var(--wp--preset--color--surface-alt, #faf5f5);
	transition: background-color 0.2s, color 0.2s;
}

.zipni-portfolio-filters a:hover {
	background: var(--wp--preset--color--border, #eaeaea);
	color: var(--wp--preset--color--text-primary, #1a1a1a);
}

.zipni-portfolio-filters a.is-active {
	background: var(--wp--preset--color--accent, #d63031);
	color: #fff;
}

.zipni-portfolio-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.zipni-portfolio-card {
	display: block;
	background: var(--wp--preset--color--surface, #fff);
	border: 1px solid var(--wp--preset--color--border, #eaeaea);
	border-radius: 1rem;
	overflow: hidden;
	text-decoration: none;
	transition: box-shadow 0.2s, border-color 0.2s;
}

.zipni-portfolio-card:hover {
	border-color: var(--wp--preset--color--accent, #d63031);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.zipni-portfolio-card img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
}

.zipni-portfolio-card__body {
	padding: 1rem;
}

.zipni-portfolio-card__title {
	margin: 0 0 0.5rem;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #1a1a1a);
	line-height: 1.3;
}

.zipni-portfolio-card__badge {
	font-size: var(--wp--preset--font-size--xs, 0.75rem);
	color: var(--wp--preset--color--text-secondary, #666);
}

/* Archive: pagination */

.zipni-portfolio-pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 2rem;
}

.zipni-portfolio-pagination a,
.zipni-portfolio-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.75rem;
	border-radius: 0.5rem;
	font-size: var(--wp--preset--font-size--sm, 0.875rem);
	text-decoration: none;
	color: var(--wp--preset--color--text-secondary, #666);
	background: var(--wp--preset--color--surface-alt, #faf5f5);
	transition: background-color 0.2s;
}

.zipni-portfolio-pagination a:hover {
	background: var(--wp--preset--color--border, #eaeaea);
}

.zipni-portfolio-pagination .current {
	background: var(--wp--preset--color--accent, #d63031);
	color: #fff;
}

/* ===== Carousel ===== */

.zipni-carousel__thumbs {
	scrollbar-width: thin;
}

.zipni-thumb {
	flex-shrink: 0;
	width: 80px;
	height: 80px;
	border-radius: 0.75rem;
	overflow: hidden;
	border: 2px solid transparent;
	padding: 0;
	cursor: pointer;
	background: none;
	transition: border-color 0.2s;
}

.zipni-thumb--active {
	border-color: var(--wp--preset--color--accent, #d63031);
}

.zipni-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

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

@media (max-width: 768px) {
	.zipni-ba-grid {
		grid-template-columns: 1fr;
	}

	.zipni-portfolio-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}
}

@media (max-width: 480px) {
	.zipni-portfolio-grid {
		grid-template-columns: 1fr;
	}
}
