/**
 * Page Grid Block Front-end CSS
 * Updated with enhanced mobile responsiveness
 */

/* Background Colors - Named Colors */
.page-grid.bg-dark-blue,
.page-grid-section .bg-dark-blue {
	background-color: #0F293E;
}

.page-grid.bg-dark-brown,
.page-grid-section .bg-dark-brown {
	background-color: #290B0B;
}

.page-grid.bg-burgundy,
.page-grid-section .bg-burgundy {
	background-color: #800020;
}

.page-grid.bg-gold,
.page-grid-section .bg-gold {
	background-color: #B8860B;
}

.page-grid.bg-copper,
.page-grid-section .bg-copper {
	background-color: #B87333;
}

.page-grid.bg-periwinkle,
.page-grid-section .bg-periwinkle {
	background-color: #CCCCFF;
}

.page-grid.bg-deep-blue,
.page-grid-section .bg-deep-blue {
	background-color: #00008B;
}

.page-grid.bg-dark-red,
.page-grid-section .bg-dark-red {
	background-color: #8B0000;
}

.page-grid.bg-white,
.page-grid-section .bg-white {
	background-color: #FFFFFF;
}

.page-grid.bg-black,
.page-grid-section .bg-black {
	background-color: #000000;
}

/* Text Colors */
.page-grid.text-white,
.page-grid.text-white h1,
.page-grid.text-white h2,
.page-grid.text-white h3,
.page-grid.text-white h4,
.page-grid.text-white h5,
.page-grid.text-white h6,
.page-grid.text-white p,
.page-grid.text-white .page-grid-title,
.page-grid.text-white .page-grid-description,
.page-grid-section.text-white,
.page-grid-section.text-white h1,
.page-grid-section.text-white h2,
.page-grid-section.text-white h3,
.page-grid-section.text-white h4,
.page-grid-section.text-white h5,
.page-grid-section.text-white h6,
.page-grid-section.text-white p,
.page-grid-section.text-white .page-grid-title,
.page-grid-section.text-white .page-grid-description {
	color: #FFFFFF;
}

.page-grid.text-black,
.page-grid.text-black h1,
.page-grid.text-black h2,
.page-grid.text-black h3,
.page-grid.text-black h4,
.page-grid.text-black h5,
.page-grid.text-black h6,
.page-grid.text-black p,
.page-grid.text-black .page-grid-title,
.page-grid.text-black .page-grid-description,
.page-grid-section.text-black,
.page-grid-section.text-black h1,
.page-grid-section.text-black h2,
.page-grid-section.text-black h3,
.page-grid-section.text-black h4,
.page-grid-section.text-black h5,
.page-grid-section.text-black h6,
.page-grid-section.text-black p,
.page-grid-section.text-black .page-grid-title,
.page-grid-section.text-black .page-grid-description {
	color: #000000;
}

.page-grid.text-dark-blue,
.page-grid.text-dark-blue h1,
.page-grid.text-dark-blue h2,
.page-grid.text-dark-blue h3,
.page-grid.text-dark-blue h4,
.page-grid.text-dark-blue h5,
.page-grid.text-dark-blue h6,
.page-grid.text-dark-blue p,
.page-grid.text-dark-blue .page-grid-title,
.page-grid.text-dark-blue .page-grid-description,
.page-grid-section.text-dark-blue,
.page-grid-section.text-dark-blue h1,
.page-grid-section.text-dark-blue h2,
.page-grid-section.text-dark-blue h3,
.page-grid-section.text-dark-blue h4,
.page-grid-section.text-dark-blue h5,
.page-grid-section.text-dark-blue h6,
.page-grid-section.text-dark-blue p,
.page-grid-section.text-dark-blue .page-grid-title,
.page-grid-section.text-dark-blue .page-grid-description {
	color: #0F293E;
}

/* Eyebrow Styles */
.page-grid-section .eyebrow {
	font-family: 'DM Sans', sans-serif;
	font-size: 18px;
	font-style: normal;
	font-weight: 400;
	line-height: 22px;
	letter-spacing: 6.72px;
	text-transform: uppercase;
	margin-bottom: 10px;
	display: block;
}

/* Eyebrow style variations */
.page-grid-section .eyebrow-style-uppercase {
	font-weight: 400;
	text-transform: uppercase;
}

.page-grid-section .eyebrow-style-default {
	font-weight: 400;
	text-transform: uppercase;
}

.page-background-style{
	height: 50%;
}

.page-grid-section .eyebrow-style-bold {
	font-weight: 700;
	text-transform: uppercase;
}

.page-grid-section .eyebrow-style-elegant {
	font-style: italic;
}

/* Title and Description Styles */
.page-grid .page-grid-title,
.page-grid-section .page-grid-title {
	font-family: 'Hedvig Letters Serif', serif;
	font-size: 48px;
	line-height: 114%;
	margin-bottom: 32px;
	font-weight: 400;
	text-align: left;
}

.page-grid .page-grid-description,
.page-grid-section .page-grid-description {
	font-family: 'DM Sans', sans-serif;
	font-size: 18px;
	letter-spacing: -0.48px;
	margin-bottom: 48px;
	text-align: left;
}

/* Default Button Style */
.page-grid .wp-block-button .wp-block-button__link,
.page-grid-section .wp-block-button .wp-block-button__link {
	background-color: #AA632C;
	color: #FFFFFF;
	font-family: 'DM Sans', sans-serif;
	font-size: 18px;
	line-height: 21px;
	font-weight: 400;
	padding: 10px 20px;
	border-radius: 5px;
	text-decoration: none;
	transition: all 0.3s ease;
	display: inline-block;
	width: fit-content;
	align-self: center;
}

.page-grid .wp-block-button .wp-block-button__link:hover,
.page-grid-section .wp-block-button .wp-block-button__link:hover {
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.30), 0 1px 3px 0 rgba(0, 0, 0, 0.15);
	transition: 300ms ease-in;
}

/* Page Grid Styles */
.page-grid-section {
	position: relative;
	min-height: 676px;
	width: 100%;
	padding: 117px 0;
	background-color: #FFFFFF;
}

/* Background bottom section */
.page-grid-section .absolute.w-full.left-0.right-0.bottom-0 {
	position: absolute;
	width: 100%;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 5;
}

/* Support for hex colors */
.page-grid-section [class*="bg-hex-"] {
	/* Note: Hex colors will need to be handled with inline styles or JavaScript */
}

.page-grid-container {
	display: flex;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 30px;
	position: relative;
	flex-direction: column;
	z-index: 10; /* Ensure content stays above the background */
}

@media (max-width: 1500px) {
	.page-grid-container {
		max-width: 1200px;
	}
}

@media (max-width: 1500px) {
	.page-grid-section .eyebrow {
		font-size: 16px !important;
	}

	.page-grid .page-grid-description,
	.page-grid-section .page-grid-description {
		font-size: 16px !important;
	}

	.page-grid-content-column .flex .midfield-description p,
	.page-grid-content-column .flex .midfield-description li {
		font-size: 16px !important;
	}

	.page-grid .wp-block-button .wp-block-button__link,
	.page-grid-section .wp-block-button .wp-block-button__link {
		font-size: 16px !important;
	}

	.pagegrid-cta-link {
		font-size: 16px !important;
	}
}

/* Content Column */
.page-grid-content-column {
	display: flex;
	flex-direction: row !important;
	justify-content: space-between !important;
	align-items: flex-start !important;
	margin-bottom: 40px;
	width: 100%;
}

/* Content Wrapper */
.page-grid-content-wrapper {
	flex: 1 1 70%;
	padding-right: 30px;
	max-width: 70%;
	text-align: left;
}

/* Container for navigation buttons and optional midfield description */
.page-grid-content-column .flex {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	width: 100%;
	align-self: end;
	margin-bottom: 12px;
	justify-self: end;
}

/**
 * Midfield Description WYSIWYG Styles
 */

/* Base container for midfield description */
.page-grid-content-column .flex .midfield-description {
	flex: 1;
	/*max-width: calc(100% - 120px);*/
}

/* Default paragraph and list item styles for midfield description */
.page-grid-content-column .flex .midfield-description p,
.page-grid-content-column .flex .midfield-description li {
	font-family: 'DM Sans', sans-serif;
	font-size: 18px;
	letter-spacing: -0.48px;
	margin-bottom: 22px;
	line-height: 1.5;
}

/* List styles for midfield description */
.page-grid-content-column .flex .midfield-description ul {
	padding-left: 20px;
	margin-bottom: 16px;
}

.page-grid-content-column .flex .midfield-description ol {
	padding-left: 20px;
	margin-bottom: 16px;
}

/* Header styles for midfield description - match innerblock headers */
.page-grid-content-column .flex .midfield-description h1,
.page-grid-content-column .flex .midfield-description h2,
.page-grid-content-column .flex .midfield-description h3,
.page-grid-content-column .flex .midfield-description h4,
.page-grid-content-column .flex .midfield-description h5,
.page-grid-content-column .flex .midfield-description h6 {
	font-family: 'Hedvig Letters Serif', serif;
	font-size: 48px;
	line-height: 114%;
	margin-bottom: 24px;
	font-weight: 400;
}

/* Grid Column */
.grid-column-page {
	flex: 0 0 100%;
	position: relative;
	height: auto;
	z-index: 10;
}

/* Grid Track - Adaptive layout based on card count */
.grid-track-page {
	display: grid;
	margin-bottom: 30px;
	width: 100%;
}

/* Class specifically for different card counts */
.grid-track-page.two-cards {
	grid-template-columns: repeat(2, 1fr);
}

.grid-track-page.three-cards {
	grid-template-columns: repeat(3, 1fr);
}

.grid-track-page.four-cards {
	grid-template-columns: repeat(4, 1fr);
}

.grid-item-page {
	position: relative;
	height: auto;
}

.grid-image-page {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	aspect-ratio: 1/1;
	transition: transform 0.3s ease; /* Add smooth transition for hover effect */
}

/* Image hover effect - 1.1 scale zoom */
.page-item-card:hover .grid-image-page {
	transform: scale(1.1);
}

/* Card styling for page items */
.page-item-card {
	position: relative;
	display: flex;
	flex-direction: column;
	z-index: 10;
	height: 100%;
	transition: transform 0.3s ease;
	overflow: hidden; /* Ensure image doesn't overflow on hover */
}

.page-item-link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
}

/* Hover effect for arrow buttons */
.page-item-link:hover .page-item-arrow svg {
	transform: translateX(5px);
	transition: transform 0.3s ease;
}

/* Make sure the SVG has a transition */
.page-item-arrow svg {
	transition: transform 0.3s ease;
}

/* Container for title and description */
.page-item-info {
	padding-top: 32px;
	color: #FFFFFF;
	width: 100%;
	padding: 20px;
	position: relative;
	z-index: 10;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;

}

/* Name styling */
.page-item-name {
	font-family: 'Hedvig Letters Serif', serif;
	font-size: 20px;
	line-height: 1.2;
	margin: 0 0 10px 0;
	font-weight: 400;

	color: #FFFFFF !important;
}

/* Description styling */
.page-item-description {
	font-family: 'DM Sans', sans-serif;
	font-size: 16px;
	line-height: 1.4;
	margin: 0 0 20px 0;
	color: #FFFFFF !important;
	max-width: 365px;
}

/* Learn more arrow link styling */
.page-item-arrow {
	display: flex;
	align-items: center;
	margin-top: auto;
}

.learn-more {
	font-family: 'DM Sans', sans-serif;
	font-size: 16px;
	margin-right: 10px;
	font-weight: 500;
}

/* Reset color overrides from parent elements */
.text-black .page-item-info,
.text-dark-blue .page-item-info {
	color: #FFFFFF;
}

.text-black .page-item-name,
.text-dark-blue .page-item-name,
.text-black .page-item-position,
.text-dark-blue .page-item-position {
	color: #FFFFFF !important;
}

/* CTA Link Styling */
.pagegrid-cta-link {
	background-color: #AA632C;
	color: #FFFFFF;
	font-family: 'DM Sans', sans-serif;
	font-size: 18px;
	line-height: 21px;
	font-weight: 400;
	padding: 10px 20px;
	border-radius: 5px;
	text-decoration: none;
	transition: all 0.3s ease;
	display: inline-block;
	width: fit-content;
	margin-top: 30px;
	align-self: center;
}

.pagegrid-cta-link:hover {
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.30), 0 1px 3px 0 rgba(0, 0, 0, 0.15);
	transition: 300ms ease-in;
}

/* Responsive adjustments - Tablet */
@media (max-width: 1024px) {
	.page-grid-container {
		flex-direction: column;
		padding: 0 20px;
	}

	.page-grid-content-column {
		flex-direction: column !important;
		align-items: center !important;
	}

	.page-grid-content-wrapper {
		flex: 1 1 100%;
		max-width: 100%;
		padding-right: 0;
		margin-bottom: 20px;;
	}

	.page-grid-content-column .flex {
		width: 100%;
		align-items: center;
		margin-top: 0;
		flex-direction: column;
	}


	.grid-column-page {
		flex: 0 0 100%;
		width: 100%;
	}

	.grid-track-page {
		grid-template-columns: repeat(2, 1fr);
	}

	.page-grid-section {
		min-height: auto;
		padding: 60px 0;
	}

	.page-item-name {
		font-size: 22px;
	}

	/* Responsive adjustments for midfield description */
	.page-grid-content-column .flex .midfield-description {
		max-width: 100%;
		margin-bottom: 20px;
	}

	.page-grid-content-column .flex .midfield-description h1,
	.page-grid-content-column .flex .midfield-description h2 {
		font-size: 36px;
	}

	.page-grid-content-column .flex .midfield-description h3 {
		font-size: 28px;
	}

	.page-grid-content-column .flex .midfield-description p,
	.page-grid-content-column .flex .midfield-description li {
		font-size: 16px;
	}
}

/* Responsive adjustments - Mobile - Enhanced to match screenshot */
@media (max-width: 768px) {


	.page-background-style{
		height: 82%;
	}

	.page-item-info {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	.page-background-style-mobile{
		position: absolute;
		left: -20px;
		right: -20px;
		bottom: 0;
		z-index: -1;
		height: 75%;
	}

	.page-grid-content-wrapper{
		margin-top: 40px;
		margin-bottom: 0 !important;
	}

	.page-grid .page-grid-title,
	.page-grid-section .page-grid-title {
		font-size: 42px;
	}


	.page-grid-section {
		padding: 40px 0;
	}

	/* Adjust header and description styles */
	.page-grid-title {
		font-size: 32px;
		text-align: left !important;
		margin-bottom: 20px;
	}

	.page-grid-description {
		text-align: left !important;
		margin-bottom: 30px;
	}

	.page-grid-content-wrapper {
		text-align: left;
	}

	/* Force all content to be left-aligned */
	.page-grid .page-grid-title,
	.page-grid-section .page-grid-title {
		text-align: left !important;
	}

	.page-grid .page-grid-description,
	.page-grid-section .page-grid-description {
		text-align: left !important;
	}

	/* Adjust grid to single column on mobile */
	.grid-track-page,
	.grid-track-page.two-cards,
	.grid-track-page.three-cards,
	.grid-track-page.four-cards {
		grid-template-columns: 1fr;
		gap: 62px; /* Reduced gap between vertical cards */
	}



	.page-item-card {
		border-radius: 0; /* Remove border radius on mobile */
		box-shadow: none; /* Remove shadow on mobile */
	}


	.page-item-name {
		font-size: 24px;
		margin-bottom: 24px;
	}

	.page-item-description {
		font-size: 16px;
		margin-bottom: 24px;
		line-height: 1.5;
	}

	/* Adjust Learn More styling */
	.page-item-arrow {
		display: flex;
		align-items: center;
	}

	.learn-more {
		font-size: 16px;
		font-weight: 500;
	}

	/* Make CTA button align with other content */
	.pagegrid-cta-link {
		margin-top: 20px;
		align-self: flex-start;
	}

	/* Eyebrow text alignment */
	.page-grid-section .eyebrow {
		text-align: left;
		font-size: 14px;
		letter-spacing: 4px;
		margin-bottom: 16px;
	}

	.page-grid-content-column{
		margin-bottom: 0 !important;
	}

	/* Mobile style for midfield description */
	.page-grid-content-column .flex .midfield-description {
		width: 100%;
		max-width: 100%;
		margin-bottom: 15px;
	}

	.page-grid-content-column .flex .midfield-description h1,
	.page-grid-content-column .flex .midfield-description h2 {
		font-size: 28px;
		text-align: left;
	}

	.page-grid-content-column .flex .midfield-description h3 {
		font-size: 24px;
	}

	.page-grid-content-column .flex .midfield-description p,
	.page-grid-content-column .flex .midfield-description li {
		font-size: 16px;
		text-align: left;
	}

	/* Ensure buttons layout properly on mobile */
	.page-grid-content-column .flex {
		flex-direction: column;
		align-items: flex-start;
	}


	/* Fix layout issues specific to the vertical mobile card view */
	.page-grid-section {
		padding-top: 20px;
		padding-bottom: 20px;
	}

	.grid-column-page {
		margin-top: 20px;
	}

}
