/* ==========================================================================
   Zinka Theme – Components
   Cards, Buttons, Media, Section-specific styles
   ========================================================================== */

/* --------------------------------------------------------------------------
   Component: Image Card
   -------------------------------------------------------------------------- */
.image-card {
	border-radius: var(--radius-lg);
	overflow: hidden;
	position: relative;
}

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

.image-card--tall {
	aspect-ratio: 3 / 4;
}

.image-card--landscape {
	aspect-ratio: 4 / 3;
}

/* --------------------------------------------------------------------------
   Component: Text Info Card (light card with border)
   -------------------------------------------------------------------------- */
.text-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border-soft);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	display: flex;
	flex-direction: column;
	justify-content: center;
}

@media (min-width: 768px) {
	.text-card {
		padding: var(--space-8);
	}
}

.text-card__title {
	margin-bottom: var(--space-4);
}

.text-card__content {
	margin-bottom: var(--space-4);
}

.text-card__content:last-child {
	margin-bottom: 0;
}

.text-card__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.text-card__list li {
	position: relative;
	padding-left: var(--space-6);
	margin-bottom: var(--space-3);
	font-size: clamp(0.9375rem, 1.2vw, 1.0625rem);
	line-height: 1.5;
	color: var(--color-text-muted);
}

.text-card__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--color-accent);
}

/* --------------------------------------------------------------------------
   Component: Service Card (dark navy card)
   -------------------------------------------------------------------------- */
.service-card {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--space-8);
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

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

.service-card h3 {
	color: var(--color-white);
	margin-bottom: var(--space-4);
	font-size: clamp(1.125rem, 1.8vw, 1.375rem);
}

.service-card p {
	color: rgba(255, 255, 255, 0.85);
	flex-grow: 1;
	margin-bottom: var(--space-6);
}

.service-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: var(--radius-full);
	background-color: var(--color-accent);
	color: var(--color-white);
	font-size: 1.25rem;
	font-weight: var(--fw-bold);
	transition: background-color 0.2s ease, transform 0.2s ease;
	align-self: flex-start;
	text-decoration: none;
}

.service-card__cta:hover {
	background-color: var(--color-accent-hover);
	transform: scale(1.1);
}

.service-card__cta svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

/* --------------------------------------------------------------------------
   Component: Download Button Card
   -------------------------------------------------------------------------- */
.download-card {
	display: block;
	background-color: var(--color-primary);
	color: var(--color-white);
	border-radius: var(--radius-md);
	padding: var(--space-5) var(--space-6);
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.download-card:hover {
	background-color: var(--color-primary-hover);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.download-card__title {
	display: block;
	font-family: var(--font-heading);
	font-weight: var(--fw-semibold);
	font-size: 1rem;
	margin-bottom: var(--space-1);
}

.download-card__meta {
	display: block;
	font-size: 0.8125rem;
	opacity: 0.75;
}

/* --------------------------------------------------------------------------
   Component: Link CTA (with arrow icon)
   -------------------------------------------------------------------------- */
.link-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-family: var(--font-heading);
	font-weight: var(--fw-semibold);
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-text);
	transition: color 0.2s ease, gap 0.2s ease;
}

.link-cta:hover {
	color: var(--color-accent);
	gap: var(--space-3);
}

.link-cta span {
	font-size: 1.125rem;
	line-height: 1;
}

/* --------------------------------------------------------------------------
   Section: Hero
   -------------------------------------------------------------------------- */
.hero {
	padding-block: var(--space-12);
	overflow: hidden;
}

@media (min-width: 768px) {
	.hero {
		padding-block: var(--space-16);
	}
}

@media (min-width: 1024px) {
	.hero {
		padding-block: var(--space-20);
		min-height: 70vh;
		display: flex;
		align-items: center;
	}
}

.hero__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}

@media (min-width: 768px) {
	.hero__grid {
		grid-template-columns: 1.05fr 0.95fr;
		gap: var(--space-12);
	}
}

.hero__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

.hero__logo {
	max-width: 180px;
}

.hero__logo img {
	width: 100%;
	height: auto;
}

.hero h1 {
	max-width: 14ch;
}

.hero__lead {
	max-width: 48ch;
	font-size: clamp(1rem, 1.3vw, 1.1875rem);
}

.hero__media {
	border-radius: var(--radius-xl);
	overflow: hidden;
}

.hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 4 / 3;
}

@media (min-width: 768px) {
	.hero__media img {
		aspect-ratio: auto;
		min-height: 400px;
	}
}

/* --------------------------------------------------------------------------
   Section: Reasons (Alternating Image + Text Grid)
   -------------------------------------------------------------------------- */
.reasons {
	padding-block: var(--space-16);
}

@media (min-width: 1024px) {
	.reasons {
		padding-block: var(--space-20);
	}
}

.reasons > .container > h2 {
	margin-bottom: var(--space-12);
}

.alternating-grid {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}

@media (min-width: 768px) {
	.alternating-grid {
		gap: var(--space-10);
	}
}

.row-block {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	align-items: stretch;
}

@media (min-width: 768px) {
	.row-block {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-8);
	}
}

.row-block .image-card {
	min-height: 280px;
}

@media (min-width: 768px) {
	.row-block .image-card {
		min-height: 320px;
	}
}

/* Reverse order on desktop for alternating layout */
@media (min-width: 768px) {
	.row-block--reverse .image-card {
		order: 2;
	}
	.row-block--reverse .text-card {
		order: 1;
	}
}

/* --------------------------------------------------------------------------
   Section: Services
   -------------------------------------------------------------------------- */
.services {
	padding-block: var(--space-16);
}

@media (min-width: 1024px) {
	.services {
		padding-block: var(--space-20);
	}
}

.services > .container > h2 {
	margin-bottom: var(--space-12);
}

.services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 768px) {
	.services__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.services__grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--space-8);
	}
}

/* --------------------------------------------------------------------------
   Section: Downloads
   -------------------------------------------------------------------------- */
.downloads {
	padding-block: var(--space-16);
}

@media (min-width: 1024px) {
	.downloads {
		padding-block: var(--space-20);
	}
}

.downloads__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: center;
}

@media (min-width: 768px) {
	.downloads__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-12);
	}
}

.downloads__media {
	min-height: 300px;
}

@media (min-width: 768px) {
	.downloads__media {
		min-height: 400px;
	}
}

.downloads__content h2 {
	margin-bottom: var(--space-8);
}

.download-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

/* --------------------------------------------------------------------------
   Section: Highlight Split
   -------------------------------------------------------------------------- */
.highlight-split {
	padding-block: var(--space-16);
}

@media (min-width: 1024px) {
	.highlight-split {
		padding-block: var(--space-24);
	}
}

.highlight-split__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}

@media (min-width: 768px) {
	.highlight-split__grid {
		grid-template-columns: 0.9fr 1.1fr;
		gap: var(--space-12);
	}
}

.highlight-split__content h2 {
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	margin-bottom: var(--space-6);
	line-height: 0.95;
}

.highlight-split__content p {
	font-size: clamp(1rem, 1.3vw, 1.1875rem);
	max-width: 50ch;
}

.highlight-split__media {
	border-radius: var(--radius-xl);
	overflow: hidden;
	min-height: 300px;
}

@media (min-width: 768px) {
	.highlight-split__media {
		min-height: 450px;
	}
}

.highlight-split__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* --------------------------------------------------------------------------
   Section: Contact CTA
   -------------------------------------------------------------------------- */
.contact-cta {
	padding-block: var(--space-20);
}

@media (min-width: 1024px) {
	.contact-cta {
		padding-block: var(--space-24);
	}
}

.contact-cta .eyebrow {
	margin-bottom: var(--space-4);
}

.contact-cta h2 {
	font-size: clamp(2rem, 4vw, 3.25rem);
	margin-bottom: var(--space-12);
	max-width: 18ch;
}

.contact-cta__details {
	margin-top: var(--space-12);
}

.contact-cta__details h3 {
	margin-bottom: var(--space-6);
	font-size: 1.125rem;
}

.contact-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.contact-list li {
	font-size: clamp(0.9375rem, 1.1vw, 1.0625rem);
	color: var(--color-text-muted);
}

.contact-list a {
	color: var(--color-text-muted);
	transition: color 0.2s ease;
}

.contact-list a:hover {
	color: var(--color-accent);
}

/* --------------------------------------------------------------------------
   Contact Form (native theme implementation)
   -------------------------------------------------------------------------- */
.zinka-contact-form {
	margin-top: var(--space-10);
	max-width: 600px;
}

.zinka-contact-form .form-group {
	margin-bottom: var(--space-5);
}

.zinka-contact-form label {
	display: block;
	font-family: var(--font-heading);
	font-weight: var(--fw-semibold);
	font-size: 0.875rem;
	margin-bottom: var(--space-2);
	color: var(--color-text);
}

.zinka-contact-form input[type="text"],
.zinka-contact-form input[type="email"],
.zinka-contact-form input[type="tel"],
.zinka-contact-form textarea {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-body);
	font-size: 1rem;
	border: 1px solid var(--color-border-soft);
	border-radius: var(--radius-sm);
	background-color: var(--color-white);
	color: var(--color-text);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.zinka-contact-form input:focus,
.zinka-contact-form textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(22, 52, 86, 0.15);
	outline: none;
}

.zinka-contact-form textarea {
	min-height: 120px;
	resize: vertical;
}

.zinka-contact-form .btn-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-8);
	font-family: var(--font-heading);
	font-weight: var(--fw-semibold);
	font-size: 0.9375rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.zinka-contact-form .btn-submit:hover {
	background-color: var(--color-primary-hover);
	transform: translateY(-1px);
}

.zinka-contact-form .form-message {
	padding: var(--space-4);
	border-radius: var(--radius-sm);
	margin-top: var(--space-4);
	font-size: 0.9375rem;
}

.zinka-contact-form .form-message--success {
	background-color: #E8F5E9;
	color: #2E7D32;
	border: 1px solid #A5D6A7;
}

.zinka-contact-form .form-message--error {
	background-color: #FFEBEE;
	color: #C62828;
	border: 1px solid #EF9A9A;
}

/* --------------------------------------------------------------------------
   Editor Styles (Gutenberg compatibility)
   -------------------------------------------------------------------------- */
.wp-block-group.alignfull {
	max-width: none;
}

.entry-content > * {
	max-width: var(--container-max);
	margin-inline: auto;
}

.entry-content > .alignfull {
	max-width: none;
}

/* --------------------------------------------------------------------------
   Scroll Animations (progressive enhancement, JS adds classes)
   -------------------------------------------------------------------------- */
.animate-on-scroll {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.animate-on-scroll.is-visible {
	opacity: 1;
	transform: translateY(0);
}
