/**
 * Contact Page Styles
 *
 * Card styles are now in components/feature-card.css
 */

/* ==========================================================================
   Contact Page Container
   ========================================================================== */

.contact-page > h1:first-child,
.contact-page > .wp-block-heading:first-child {
	margin-top: 0;
}

/* ==========================================================================
   Contact Grid
   ========================================================================== */

.contact-grid {
	display: grid;
	grid-template-columns: 1fr 2fr 1fr;
	gap: 1.5rem;
	max-width: 960px;
	margin: 0 auto 3rem;
	align-items: center;
}

/* ==========================================================================
   Contact Cards (Book Online & Text Us)
   ========================================================================== */

.contact-card {
	background: var(--wp--preset--color--neutral);
	border-radius: var(--card-radius);
	padding: 2rem 1.5rem;
	text-align: center;
}

.contact-card .feature-icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: rgba(223, 59, 38, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.25rem;
	color: var(--wp--preset--color--primary);
}

.contact-card-title {
	font-size: 1.1875rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
}

.contact-card-desc {
	font-size: 0.9375rem;
	color: var(--wp--preset--color--text);
	margin: 0 0 1.25rem;
	line-height: 1.5;
}

.contact-card-btn {
	display: inline-block;
	padding: 0.75rem 1.5rem;
	background: var(--wp--preset--color--primary);
	color: #ffffff;
	border-radius: 9999px;
	font-weight: 600;
	font-size: 0.9375rem;
	text-decoration: none;
	transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.contact-card-btn:hover {
	background: var(--wp--preset--color--primary-dark);
	transform: translateY(-1px);
	color: #ffffff;
}

.contact-card-btn:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
}

/* ==========================================================================
   Contact Form Section
   ========================================================================== */

.contact-form-section {
	background: var(--wp--preset--color--neutral);
	border-radius: var(--card-radius);
	padding: 2rem;
}

.contact-form-title {
	font-size: 1.1875rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
	text-align: center;
}

.contact-form-section .quote-form-wrapper {
	background: none;
	padding: 0;
	border: none;
	border-radius: 0;
}

/* ==========================================================================
   Business Hours
   ========================================================================== */

.contact-hours {
	max-width: 400px;
	margin: 0 auto 3rem;
	text-align: center;
}

.contact-hours-title {
	margin-bottom: 1.5rem;
}

.contact-hours-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.contact-hours-item {
	display: flex;
	justify-content: space-between;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.contact-hours-item:last-child {
	border-bottom: none;
}

.contact-hours-day {
	font-weight: 600;
}

.contact-hours-closed {
	opacity: 0.6;
}

/* ==========================================================================
   Google Map
   ========================================================================== */

.contact-map.wp-block-group {
	max-width: 1140px;
	margin: 0 auto;
}

#contact-map-container {
	width: 100%;
	height: 450px;
	border-radius: var(--card-radius);
	box-shadow: var(--card-shadow);
	overflow: hidden;
}

/* Map Tooltip Styles */
.contact-map .map-tooltip {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	padding: 0.125rem 0;
}

.contact-map .map-tooltip-name {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
}

.contact-map .map-tooltip-address {
	font-size: 0.8125rem;
	color: var(--wp--preset--color--text);
}

/* Override Google Maps InfoWindow styles */
.contact-map .gm-style .gm-style-iw-c {
	padding: 0.625rem 0.875rem !important;
	border-radius: 8px !important;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12) !important;
}

.contact-map .gm-style .gm-style-iw-d {
	overflow: hidden !important;
}

.contact-map .gm-style .gm-style-iw-tc {
	filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.08));
}

/* ==========================================================================
   Tablet Styles
   ========================================================================== */

@media (min-width: 768px) and (max-width: 1023px) {
	.contact-grid {
		grid-template-columns: 1fr 1fr;
	}

	.contact-grid .contact-form-section {
		grid-column: 1 / -1;
		order: -1;
	}
}

/* ==========================================================================
   Mobile Styles
   ========================================================================== */

@media (max-width: 767px) {
	.contact-grid {
		grid-template-columns: 1fr;
		padding: 0 var(--content-padding-mobile);
	}

	.contact-form-section {
		padding: 1.5rem;
	}

	#contact-map-container {
		height: 300px;
		border-radius: 0;
	}
}
