/* ==========================================================================
   Subscribe Banner
   Figma: node 52422:6436
   ========================================================================== */

/* ── Section ── */

.subscribe-banner {
	padding: 100px 0;
	background: linear-gradient(
		192deg,
		rgba(245, 56,  56,  0.10) 0%,
		rgba(255, 212, 96,  0.10) 42%,
		rgba(253, 176, 87,  0.10) 100%
	);
}

/* ── Card ── */

.subscribe-banner__card {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 0 10px 0 rgba(204, 204, 204, 0.25);
	overflow: hidden;
	display: flex;
	align-items: center;
	gap: 48px;
	position: relative;
	max-width: 1160px;
    margin: 0 auto;
}

.subscribe-banner__card::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 52%;
	height: 100%;
	background: url(../img/card-grid.svg);
	background-size: cover;
	background-position: right center;
	background-repeat: no-repeat;
	z-index: 0;
}

/* ── Left column ── */

.subscribe-banner__left {
	padding: 48px 0 48px 48px;
	flex: 0 0 524px;
	max-width: 524px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	position: relative;
	z-index: 1;
}

/* ── Text block ── */

.subscribe-banner__text {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.subscribe-banner__eyebrow {
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 700;
	color: #3978F2;
	line-height: 24px;
	letter-spacing: 0.032px;
	text-transform: uppercase;
	margin: 0;
}

.subscribe-banner__heading {
	font-family: var(--font-figtree);
	font-size: 24px;
	font-weight: 600;
	color: var(--nav-dark);
	line-height: 32px;
	letter-spacing: 0;
	margin: 0;
}

/* ── Form ── */

.subscribe-banner__form {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* Honeypot — visually hidden but NOT display:none (some bots skip those) */
.subscribe-banner__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Row: input + button */
.subscribe-banner__row {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

/* Field wrapper (holds input + error message) */
.subscribe-banner__field {
	flex: 1 1 0;
	min-width: 0;
	max-width: 320px;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* ── Input ── */

.subscribe-banner__input {
	width: 100%;
	height: 48px;
	padding: 0 20px;
	border: 1px solid #EAECEE;
	border-radius: 8px;
	background: #fff;
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 400;
	color: var(--nav-dark);
	line-height: 24px;
	outline: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

.subscribe-banner__input::placeholder {
	color: #848c97;
}

/* Hover */
.subscribe-banner__input:hover {
	border-color: var(--input-stroke-active);
}

/* Focus */
.subscribe-banner__input:focus {
	border-color: #3978F2;
	box-shadow: 0 0 0 3px rgba(57, 120, 242, 0.12);
}

/* Valid (after interaction) */
.subscribe-banner__input:not(:placeholder-shown):valid {
	border-color: #EAECEE;
}

/* Error state — applied via JS */
.subscribe-banner__input.has-error {
	border-color: #F53838;
	box-shadow: 0 0 0 3px rgba(245, 56, 56, 0.10);
}

.subscribe-banner__input.has-error:focus {
	border-color: #F53838;
	box-shadow: 0 0 0 3px rgba(245, 56, 56, 0.15);
}

/* Error message */
.subscribe-banner__input-error {
	font-family: var(--font-figtree);
	font-size: 13px;
	font-weight: 400;
	color: #F53838;
	line-height: 18px;
	min-height: 0;
}

/* ── Button ── */

.subscribe-banner__btn {
	flex-shrink: 0;
	height: 48px;
	padding: 0 24px;
	border: none;
	border-radius: 6px;
	background: var(--primary-blue);
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.032px;
	line-height: 24px;
	cursor: pointer;
	transition: box-shadow 0.2s ease-in-out, background-color 0.2s ease-in-out, color 0.2s ease-in-out, border-color 0.2s ease-in-out;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	white-space: nowrap;
}

.subscribe-banner__btn:hover:not(:disabled) {
	background: var(--primary-blue);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

.subscribe-banner__btn:active:not(:disabled) {
	background: var(--blue-200);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

.subscribe-banner__btn:disabled {
	background: var(--disable-button);
	color: #fff;
	box-shadow: unset;
	cursor: not-allowed;
}

/* Spinner — shown while loading */
.subscribe-banner__btn-spinner {
	display: none;
	width: 16px;
	height: 16px;
	border: 2px solid rgba(255, 255, 255, 0.35);
	border-top-color: #fff;
	border-radius: 50%;
	animation: sub-spin 0.6s linear infinite;
	flex-shrink: 0;
}

.subscribe-banner__btn.is-loading .subscribe-banner__btn-label {
	opacity: 0.7;
}

.subscribe-banner__btn.is-loading .subscribe-banner__btn-spinner {
	display: block;
}

@keyframes sub-spin {
	to { transform: rotate(360deg); }
}

/* ── Disclaimer ── */

.subscribe-banner__disclaimer {
	font-family: var(--font-figtree);
	font-size: 14px;
	font-weight: 400;
	color: #848c97;
	line-height: 20px;
	text-transform: capitalize;
	margin: 0;
}

/* ── Success message ── */

.subscribe-banner__success {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-figtree);
	font-size: 15px;
	font-weight: 500;
	color: #3978F2;
	line-height: 24px;
}

.subscribe-banner__success[hidden] {
	display: none;
}

/* ── Right column (image) ── */

.subscribe-banner__right {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
	align-self: stretch;
	z-index: 1;
}

.subscribe-banner__image {
	max-height: 270px;
	width: auto;
	height: 100%;
	display: block;
	object-fit: contain;
}

/* ── Responsive ── */
@media (max-width: 1200px) {
	.subscribe-banner__left {
		flex: 1 1 0;
	}
	.subscribe-banner__image {
		max-width: 100%;
		height: auto;
		max-height: unset;
	}
}
@media (max-width: 1100px) {
	.subscribe-banner__left {
		flex: 0 0 420px;
		max-width: 420px;
	}
}
@media (max-width: 992px) {
	.subscribe-banner__card::before {
		display: none;
	}
	.subscribe-banner__card {
		padding: 48px;
	}
	.subscribe-banner__right {
		display: none;
	}
	.subscribe-banner__left {
		max-width: 100%;
		padding: 0;
		flex: unset;
	}
}
@media (max-width: 900px) {
	.subscribe-banner__card {
		flex-direction: column;
		align-items: stretch;
		gap: 32px;
	}

	.subscribe-banner__left {
		flex: none;
		max-width: 100%;
	}

	.subscribe-banner__right {
		justify-content: center;
	}

	.subscribe-banner__image {
		max-height: 220px;
	}
}

@media (max-width: 600px) {
	.subscribe-banner__card {
		padding: 140px 24px 24px;
	}
	.subscribe-banner__card::after {
		content: '';
		position: absolute;
		top: -315px;
		left: 50%;
		transform: translateX(-50%);
		width: 407.158px;
		height: 407.158px;
		flex-shrink: 0;
		border-radius: 407.158px;
		background: linear-gradient(211deg, rgba(245, 56, 56, 0.50) 0%, rgba(255, 212, 96, 0.50) 41.67%, rgba(253, 176, 87, 0.50) 100%);
	}
	.subscribe-banner__heading {
		font-size: 20px;
		line-height: 28px;
	}

	.subscribe-banner__row {
		flex-direction: column;
		gap: 12px;
	}

	.subscribe-banner__btn {
		width: 100%;
		justify-content: center;
	}

	.subscribe-banner__right {
		display: none;
	}
	.subscribe-banner__field {
		max-width: 100%;
	}
}

/* ==========================================================================
   HubSpot embed overrides
   Scoped to #hs-subscribe-form, #hs-footer-form, and
   .subscribe-banner__hs-form (covers dynamic block instance IDs).
   ========================================================================== */

/* ── Layout: row (input + button side by side) ── */

#hs-subscribe-form .hs-form,
#hs-footer-form .hs-form {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	margin: 0;
}

/* Subscribe banner: row — wraps if button text too wide */
#hs-subscribe-form .hs-form {
	flex-direction: row;
	flex-wrap: wrap;
}

/* Footer form: column */
#hs-footer-form .hs-form {
	flex-direction: column;
}

#hs-subscribe-form .hs_email,
#hs-footer-form .hs_email {
	flex: 1 1 0;
	min-width: 0;
	max-width: 320px;
	margin: 0;
}

#hs-subscribe-form .hs_submit,
#hs-footer-form .hs_submit {
	flex-shrink: 0;
	margin: 0;
}

#hs-subscribe-form .hs-form-field,
#hs-footer-form .hs-form-field {
	margin: 0;
	width: 100%;
	max-width: 100%;
}

#hs-subscribe-form .input,
#hs-footer-form .input {
	margin: 0;
}

/* ── Label (screen-reader only) ── */

#hs-subscribe-form .hs-form-field > label,
#hs-footer-form .hs-form-field > label {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

/* ── Input ── */

#hs-subscribe-form .hs-input,
#hs-footer-form .hs-input {
	width: 100%;
	max-width: 400px;
	height: 48px;
	padding: 0 20px;
	border: 1px solid #EAECEE;
	border-radius: 8px;
	background: #fff;
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 400;
	color: var(--nav-dark);
	line-height: 24px;
	outline: none;
	box-shadow: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
	margin: 0;
}

/* Subscribe banner: Figma input min-width (323px) */
#hs-subscribe-form .hs_email {
	min-width: 323px;
}

#hs-subscribe-form .hs-input::placeholder,
#hs-footer-form .hs-input::placeholder {
	color: #848c97;
}

#hs-subscribe-form .hs-input:hover:not(:focus),
#hs-footer-form .hs-input:hover:not(:focus) {
	border-color: var(--input-stroke-active);
}

#hs-subscribe-form .hs-input:focus,
#hs-footer-form .hs-input:focus {
	border-color: #3978F2;
	box-shadow: 0 0 0 3px rgba(57, 120, 242, 0.12);
}

#hs-subscribe-form .hs-input.error,
#hs-footer-form .hs-input.error {
	border-color: #F53838;
	box-shadow: 0 0 0 3px rgba(245, 56, 56, 0.10);
}

/* ── Error messages ── */

#hs-subscribe-form .hs-error-msgs,
#hs-footer-form .hs-error-msgs {
	list-style: none;
	margin: 4px 0 0;
	padding: 0;
}

#hs-subscribe-form .hs-error-msg,
#hs-footer-form .hs-error-msg {
	font-family: var(--font-figtree);
	font-size: 13px;
	font-weight: 400;
	color: #F53838;
	line-height: 18px;
}

/* ── Submit button ── */

#hs-subscribe-form .hs-button,
#hs-footer-form .hs-button {
	height: 48px;
	padding: 0 24px;
	border: none;
	border-radius: 6px;
	background: var(--primary-blue);
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.032px;
	line-height: 24px;
	cursor: pointer;
	transition: box-shadow 0.2s ease-in-out, background-color 0.2s ease-in-out, color 0.2s ease-in-out, border-color 0.2s ease-in-out;
	white-space: nowrap;
	-webkit-appearance: none;
	appearance: none;
}

#hs-subscribe-form .hs-button:hover,
#hs-footer-form .hs-button:hover {
	background: var(--primary-blue);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

#hs-subscribe-form .hs-button:active,
#hs-footer-form .hs-button:active {
	background: var(--blue-200);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

/* ── Hide HubSpot extra content ── */

#hs-subscribe-form .hs-richtext,
#hs-footer-form .hs-richtext {
	display: none;
}

#hs-subscribe-form .hs-form-field:not(.hs_email),
#hs-footer-form .hs-form-field:not(.hs_email) {
	display: none;
}

/* ── GDPR / legal consent ── */

#hs-subscribe-form .legal-consent-container,
#hs-footer-form .legal-consent-container {
	font-family: var(--font-figtree);
	font-size: 13px;
	color: #848c97;
	flex-basis: 100%;
}

#hs-footer-form {
	width: 100%;
}
#hs-footer-form .hs-form,
#hs-footer-form .input,
#hs-footer-form .hs-form-field {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
#hs-footer-form .input,
#hs-footer-form .hs-input {
	max-width: 575px;
}

#hs-footer-form .hs-button {
	border-radius: 6px;
	font-weight: 700;
}

/* ── Footer form: success state ── */
#hs-footer-form .submitted-message {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	text-align: center;
}

#hs-footer-form .submitted-message::before {
	content: '';
	display: block;
	width: 32px;
	height: 32px;
	flex-shrink: 0;
	margin-bottom: 8px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none'%3E%3Ccircle cx='16' cy='16' r='16' fill='%2334B53A'/%3E%3Cpath d='M10 16.5L14 20.5L22.5 11.5' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
}

#hs-footer-form .submitted-message p {
	font-family: var(--font-figtree, 'Figtree', sans-serif);
	font-size: 14px;
	font-weight: 400;
	line-height: 20px;
	margin: 0;
}

#hs-footer-form .submitted-message p:first-of-type {
	color: #34b53a;
	text-transform: capitalize;
}

#hs-footer-form .submitted-message p:not(:first-of-type) {
	color: #2d4059;
}

/* ── Responsive ── */
@media (max-width: 640px) {
	#hs-footer-form .hs-form {
		flex-direction: column;
		gap: 12px;
	}

	#hs-footer-form .hs_email {
		max-width: 100%;
		width: 100%;
	}

	#hs-footer-form .hs-button {
		width: 100%;
	}
}

@media (max-width: 768px) {
	#hs-subscribe-form .hs_submit.hs-submit {
		width: 100%;
	}
}

@media (max-width: 600px) {
	#hs-subscribe-form .hs-form {
		flex-direction: column;
		gap: 12px;
	}

	#hs-subscribe-form .hs_email {
		max-width: 100%;
		width: 100%;
	}

	#hs-subscribe-form .hs-input {
		min-width: 0;
		width: 100%;
	}

	#hs-subscribe-form .hs-button {
		width: 100%;
	}
}

/* ==========================================================================
   HubSpot overrides for block instances (dynamic IDs like hs-subscribe-form-xxx)
   Mirrors all #hs-subscribe-form rules above using the shared class selector.
   ========================================================================== */

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-form {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 16px;
	margin: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs_email {
	flex: 1 1 0;
	min-width: 323px;
	max-width: 320px;
	margin: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs_submit {
	flex-shrink: 0;
	margin: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-form-field {
	margin: 0;
	width: 100%;
	max-width: 100%;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .input {
	margin: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-form-field > label {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input {
	width: 100%;
	max-width: 400px;
	height: 48px;
	padding: 0 20px;
	border: 1px solid #EAECEE;
	border-radius: 8px;
	background: #fff;
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 400;
	color: var(--nav-dark);
	line-height: 24px;
	outline: none;
	box-shadow: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
	margin: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input::placeholder {
	color: #848c97;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input:hover:not(:focus) {
	border-color: var(--input-stroke-active);
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input:focus {
	border-color: #3978F2;
	box-shadow: 0 0 0 3px rgba(57, 120, 242, 0.12);
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input.error {
	border-color: #F53838;
	box-shadow: 0 0 0 3px rgba(245, 56, 56, 0.10);
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-error-msgs {
	list-style: none;
	margin: 4px 0 0;
	padding: 0;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-error-msg {
	font-family: var(--font-figtree);
	font-size: 13px;
	font-weight: 400;
	color: #F53838;
	line-height: 18px;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-button {
	height: 48px;
	padding: 0 24px;
	border: none;
	border-radius: 6px;
	background: var(--primary-blue);
	font-family: var(--font-figtree);
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.032px;
	line-height: 24px;
	cursor: pointer;
	transition: box-shadow 0.2s ease-in-out, background-color 0.2s ease-in-out;
	white-space: nowrap;
	-webkit-appearance: none;
	appearance: none;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-button:hover {
	background: var(--primary-blue);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-button:active {
	background: var(--blue-200);
	box-shadow: 0 0 12px 0 rgba(57, 120, 242, 0.50);
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-richtext {
	display: none;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-form-field:not(.hs_email) {
	display: none;
}

.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .legal-consent-container {
	font-family: var(--font-figtree);
	font-size: 13px;
	color: #848c97;
	flex-basis: 100%;
}

@media (max-width: 768px) {
	.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs_submit.hs-submit {
		width: 100%;
	}
}

@media (max-width: 600px) {
	.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-form {
		flex-direction: column;
		gap: 12px;
	}

	.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs_email {
		max-width: 100%;
		min-width: 0;
		width: 100%;
	}

	.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-input {
		min-width: 0;
		width: 100%;
	}

	.subscribe-banner__hs-form:not(#hs-subscribe-form):not(#hs-footer-form) .hs-button {
		width: 100%;
	}
}
