/* Floating Get Free Quote + enquiry modal */

.winshield-quote-fab {
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 9990;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	min-height: 180px;
	padding: 18px 10px;
	border: none;
	border-radius: 8px 0 0 8px;
	background: #599b47;
	opacity: 0.8;
	color: #fff;
	cursor: pointer;
	box-shadow: -2px 2px 12px rgba(0, 0, 0, 0.15);
	transition: background 0.25s ease, box-shadow 0.25s ease;
}

.winshield-quote-fab:hover,
.winshield-quote-fab:focus {
	background: #599b47;
	outline: none;
	box-shadow: -3px 3px 16px rgba(0, 0, 0, 0.2);
	opacity: 1
}

.winshield-quote-fab__text {
	writing-mode: vertical-rl;
	transform: rotate(180deg);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1.2;
	white-space: nowrap;
	font-family: 'Alegreya Sans', sans-serif;
}

.winshield-quote-overlay {
	position: fixed;
	inset: 0;
	z-index: 9991;
	background: rgba(0, 0, 0, 0.55);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.winshield-quote-overlay.is-open {
	opacity: 1;
	visibility: visible;
}

.winshield-quote-modal {
	position: fixed;
	inset: 0;
	z-index: 9992;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.winshield-quote-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.winshield-quote-modal__inner {
	position: relative;
	width: 100%;
	max-width: 720px;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	padding: 36px 32px 32px;
}

.winshield-quote-modal__close {
	position: absolute;
	top: 12px;
	right: 16px;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	font-size: 28px;
	line-height: 1;
	color: #888;
	cursor: pointer;
	padding: 0;
}

.winshield-quote-modal__close:hover {
	color: #333;
}

.winshield-quote-modal__title {
	margin: 0 0 24px;
	text-align: center;
	font-size: 28px;
	font-weight: 600;
	color: #262626;
	font-family: 'Alegreya Sans', sans-serif;
}

.winshield-quote-modal__body {
	display: flex;
	align-items: center;
	gap: 24px;
}

.winshield-quote-modal__form-col {
	flex: 1;
	min-width: 0;
}

.winshield-quote-modal__art {
	flex: 0 0 200px;
	max-width: 200px;
}

.winshield-quote-modal__art svg {
	width: 100%;
	height: auto;
	display: block;
}

.winshield-quote-form__group {
	margin-bottom: 14px;
}

.winshield-quote-form__group input,
.winshield-quote-form__group textarea {
	width: 100%;
	padding: 12px 16px;
	border: 1px solid #ddd;
	border-radius: 8px;
	font-size: 15px;
	color: #333;
	background: #fff;
	font-family: 'Alegreya Sans', sans-serif;
	transition: border-color 0.2s ease;
}

.winshield-quote-form__group textarea {
	resize: vertical;
	min-height: 100px;
}

.winshield-quote-form__group input:focus,
.winshield-quote-form__group textarea:focus {
	outline: none;
	border-color: #599b47;
}

.winshield-quote-form__hp {
	position: absolute;
	left: -9999px;
	height: 0;
	width: 0;
	opacity: 0;
}

.winshield-quote-form__feedback {
	min-height: 22px;
	margin: 0 0 12px;
	font-size: 14px;
}

.winshield-quote-form__feedback.is-success {
	color: #2e8b57;
}

.winshield-quote-form__feedback.is-error {
	color: #c0392b;
}

.winshield-quote-form__submit {
	display: block;
	width: 100%;
	max-width: 200px;
	margin: 0 auto;
	padding: 14px 24px;
	border: none;
	border-radius: 8px;
	background: #599b47;
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	font-family: 'Alegreya Sans', sans-serif;
	transition: background 0.25s ease;
}

.winshield-quote-form__submit:hover:not(:disabled) {
	background: #599b47;
}

.winshield-quote-form__submit:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

body.winshield-quote-open {
	overflow: hidden;
}

@media (max-width: 767px) {
	.winshield-quote-fab {
		width: 40px;
		min-height: 150px;
		padding: 14px 8px;
	}

	.winshield-quote-fab__text {
		font-size: 12px;
	}

	.winshield-quote-modal__inner {
		padding: 28px 20px 24px;
	}

	.winshield-quote-modal__body {
		flex-direction: column;
	}

	.winshield-quote-modal__art {
		flex: none;
		max-width: 160px;
		order: -1;
	}
}
