/* ============================================
   CONTACT PAGE - RESTRUCTURED
   ============================================ */

/* --- HERO - TEXT ONLY --- */
.garage-contact-hero {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 100vh;
	overflow: hidden;
	isolation: isolate;
}

.garage-contact-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
}

.garage-contact-hero__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(100px);
}

.garage-contact-hero__orb--1 {
	width: 500px;
	height: 500px;
	top: -100px;
	right: -100px;
	background: var(--clr-primary-400, #ff4d57);
	opacity: 0.1;
	animation: orbFloat 12s ease-in-out infinite;
}

.garage-contact-hero__orb--2 {
	width: 350px;
	height: 350px;
	bottom: -80px;
	left: -80px;
	background: var(--clr-accent-400, #f5f5f5);
	opacity: 0.07;
	animation: orbFloat 16s ease-in-out infinite reverse;
}

.garage-contact-hero__content {
	max-width: 42rem;
	margin-inline: auto;
	display: grid;
	gap: var(--space-lg);
	justify-items: center;
}

.garage-contact-hero__content .u-eyebrow {
	justify-content: center;
}

.garage-contact-hero__title {
	margin: 0;
	font-family: var(--ff-heading);
	font-size: clamp(2.4rem, 5vw, 3.8rem);
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--text-strong);
}

.garage-contact-hero__text {
	font-size: var(--fs-400);
	line-height: 1.6;
	color: var(--text-muted);
	margin: 0;
	max-width: 34rem;
}

.garage-contact-hero__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: center;
}

.garage-tag {
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 1rem;
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 999px;
	font-size: var(--fs-200);
	color: var(--text-soft);
}

.garage-contact-hero__scroll {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	font-size: var(--fs-100);
	color: var(--text-muted);
	opacity: 0.6;
	animation: scrollPulse 2s ease-in-out infinite;
}

.garage-contact-hero__scroll svg {
	animation: scrollBounce 1.5s ease-in-out infinite;
}

/* --- CONTACT GRID (INFO + FORM) --- */
.garage-contact-grid {
	display: grid;
	gap: var(--space-2xl);
}

.garage-contact-info {
	display: grid;
	gap: var(--space-md);
}

.garage-contact-info__card {
	display: flex;
	gap: var(--space-lg);
	padding: var(--space-xl);
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.06);
	border-radius: var(--radius-lg);
	transition: all 0.35s ease;
}

.garage-contact-info__card:hover {
	background: rgba(255,255,255,0.04);
	border-color: rgba(193,18,31,0.25);
	transform: translateX(4px);
}

.garage-contact-info__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: linear-gradient(135deg, rgba(193,18,31,0.15), rgba(245,245,245,0.08));
	border-radius: var(--radius-md);
	color: var(--clr-primary-400);
	flex-shrink: 0;
	transition: all 0.35s ease;
}

.garage-contact-info__card:hover .garage-contact-info__icon {
	background: linear-gradient(135deg, var(--clr-primary-400), var(--clr-accent-400));
	color: var(--clr-neutral-900);
}

.garage-contact-info__card h3 {
	margin: var(--space-xs) 0 var(--space-sm);
	font-size: var(--fs-400);
	color: var(--text-strong);
}

.garage-contact-info__link {
	display: inline-block;
	font-family: var(--ff-mono, monospace);
	font-size: var(--fs-300);
	color: var(--clr-primary-400);
	text-decoration: none;
	margin-block-end: var(--space-xs);
	transition: color 0.3s ease;
}

.garage-contact-info__link:hover {
	color: var(--clr-accent-400);
}

.garage-contact-info__address {
	font-family: var(--ff-mono, monospace);
	font-size: var(--fs-300);
	color: var(--text-soft);
	margin: var(--space-xs) 0;
}

.garage-contact-info__card p {
	font-size: var(--fs-200);
	color: var(--text-muted);
	line-height: 1.6;
	margin: 0;
}

/* --- FORM --- */
.garage-contact-form-wrap {
	display: flex;
}

.garage-contact-form {
	width: 100%;
	padding: var(--space-2xl);
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 15px;
	display: grid;
	gap: var(--space-md);
	align-content: start;
}

.garage-contact-form__header {
	padding-bottom: var(--space-sm);
}

.garage-contact-form__header h3 {
	margin: var(--space-xs) 0 0;
	font-size: var(--fs-400);
	color: var(--text-strong);
}

.garage-contact-form__note {
	text-align: center;
	font-size: var(--fs-200);
	color: var(--text-muted);
	margin: 0;
	transition: color 0.3s ease;
}

[data-form-state="success"] .garage-contact-form__note {
	color: var(--clr-accent-400);
}

[data-form-state="error"] .garage-contact-form__note {
	color: var(--clr-primary-400);
}

[data-form-state="loading"] .garage-contact-form__note {
	color: var(--clr-primary-400);
}

/* --- FLOATING FIELDS --- */
.garage-floating-field {
	position: relative;
}

.garage-input {
	width: 100%;
	padding: 0.85rem 1rem;
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: var(--radius-md);
	color: var(--text-strong);
	font-family: var(--ff-base);
	font-size: var(--fs-300);
	outline: none;
	transition: all 0.3s ease;
	box-sizing: border-box;
}

textarea.garage-input {
	resize: vertical;
	min-height: 100px;
}

.garage-input:focus {
	border-color: var(--clr-primary-400);
	background: rgba(193,18,31,0.08);
	box-shadow: 0 0 0 3px rgba(193,18,31,0.12);
}

.garage-floating-field label {
	position: absolute;
	left: 1rem;
	top: 0.85rem;
	color: var(--text-muted);
	font-size: var(--fs-300);
	pointer-events: none;
	transition: all 0.25s ease;
}

.garage-input:focus + label,
.garage-input:not(:placeholder-shown) + label {
	transform: translateY(-1.65rem) scale(0.8);
	color: var(--clr-primary-400);
	background: #000000;
	padding: 0 0.3rem;
}

.garage-input[aria-invalid="true"] {
	border-color: var(--clr-primary-400);
	box-shadow: 0 0 0 3px rgba(193,18,31,0.12);
	animation: shake 0.4s ease;
}

.garage-btn--full {
	width: 100%;
	justify-content: center;
	padding: 0.95rem 1.5rem;
}

/* --- MAP --- */
.garage-map-wrapper {
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid rgba(255,255,255,0.08);
}

.garage-map-container {
	width: 100%;
	height: 400px;
	background: #000000;
}

.garage-map-container .leaflet-container {
	width: 100% !important;
	height: 100% !important;
	background: #000000 !important;
}

.garage-map-container .leaflet-control-zoom a {
	background: rgba(0,0,0,0.95) !important;
	color: var(--clr-accent-400) !important;
	border: 1px solid rgba(255,255,255,0.15) !important;
	border-radius: 6px !important;
}

.garage-map-container .leaflet-control-attribution {
	display: none !important;
}

.garage-map-container .leaflet-popup-content-wrapper {
	background: rgba(0,0,0,0.98) !important;
	color: var(--clr-accent-400) !important;
	border-radius: 8px !important;
	border: 1px solid rgba(255,255,255,0.1) !important;
}

.garage-map-container .leaflet-popup-tip {
	background: rgba(0,0,0,0.98) !important;
}

.garage-map-card__info {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: 1rem 1.5rem;
	background: rgba(255,255,255,0.02);
	border-top: 1px solid rgba(255,255,255,0.05);
	flex-wrap: wrap;
}

.garage-map-card__address {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--fs-200);
	color: var(--text-soft);
}

.garage-map-card__address svg {
	color: var(--clr-primary-400);
	flex-shrink: 0;
}

/* --- CTA BLOCK --- */
.garage-cta-block {
	border-radius: var(--radius-xl);
	background: linear-gradient(135deg, rgba(76,201,240,0.08), rgba(255,60,138,0.05));
	border: 1px solid rgba(255,255,255,0.08);
}

.garage-cta-block__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-xl);
	padding: var(--space-2xl) var(--space-3xl);
	flex-wrap: wrap;
}

.garage-cta-block__content {
	display: grid;
	gap: var(--space-xs);
}

.garage-cta-block__title {
	margin: 0;
	font-family: var(--ff-heading);
	font-size: var(--fs-500);
	color: var(--text-strong);
	max-width: 32rem;
}

.garage-cta-block__actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
}

/* --- ANIMATIONS --- */
@keyframes orbFloat {
	0%, 100% { transform: translate(0,0) scale(1); }
	33% { transform: translate(2%,-3%) scale(1.05); }
	66% { transform: translate(-1%,2%) scale(0.95); }
}

@keyframes shake {
	0%, 100% { transform: translateX(0); }
	25% { transform: translateX(-5px); }
	75% { transform: translateX(5px); }
}

@keyframes scrollPulse {
	0%, 100% { opacity: 0.4; }
	50% { opacity: 0.8; }
}

@keyframes scrollBounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(6px); }
}

/* --- SCROLL ANIMATION --- */
[data-scroll-animate] {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

[data-scroll-animate].is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* --- RESPONSIVE --- */
@media (min-width: 768px) {
	.garage-contact-grid {
		grid-template-columns: 1fr 1fr;
		align-items: start;
	}
}

@media (max-width: 767px) {
	.garage-contact-hero__title {
		font-size: 2rem;
	}

	.garage-contact-info__card {
		flex-direction: column;
		text-align: center;
	}

	.garage-contact-info__icon {
		margin-inline: auto;
	}

	.garage-contact-form {
		padding: var(--space-xl);
	}

	.garage-map-container {
		height: 280px;
	}

	.garage-map-card__info {
		flex-direction: column;
		text-align: center;
	}

	.garage-cta-block__inner {
		flex-direction: column;
		text-align: center;
		padding: var(--space-xl);
	}

	.garage-cta-block__actions {
		justify-content: center;
	}
}