@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700&display=swap');


@import './nx/nx.css';
@import './nx/nx_buttons.css';
@import './nx/nx_privacy_1.css';

:root {
	--primary: var(--p-primary-500);
	--p-primary-50:  #e9ebee;
	--p-primary-100: #ccd0d9;
	--p-primary-200: #9ba7bc;
	--p-primary-300: #6b7e9f;
	--p-primary-400: #465d8a;
	--p-primary-500: #1F2E51;
	--p-primary-600: #1b2847;
	--p-primary-700: #17223c;
	--p-primary-800: #131c31;
	--p-primary-900: #0f1628;
	--p-primary-950: #0b101d;

	--accent: #8A2643;
	--cta: #FF7748;
	--cta-hover: var(--primary);

	--text-header-font: 'Figtree', sans-serif;
	--text-medium: #8A8B8C;
	--text-header-weight: 700;
	--text-header-color: var(--primary);
	--text-subheader-font: var(--body-text-font);
	--text-subheader-color: var(--text-header-color);
	--text-subheader-size: 20px;
	--text-subheader-weight: 400;
	--page-header-subtitle-margin-top: 10px;

	--body-text-font: 'Figtree', sans-serif;
	--body-text-weight: 400;
	--body-text-color: #000;

	--bg-dark: var(--primary);
	--bg-light: #F2EBE4;
	--border-light: #ABABAC;

	--top-header-height: 28px;
	--top-header-bg: var(--p-primary-600);
	--top-header-hover: rgba(255, 255, 255, 0.7);
	--container-max-width: 1246px;

	--header-bg: var(--body-bg);
	--header-padding-y: 24px;
	--header-color: #000;
	--header-border-color: var(--border-light);
	--header-logo-height: 58px;
	--header-toggle-bg-hover: var(--primary);
	--header-font-weight: 700;
	--header-main-links-gap: 48px;
	--header-main-nav-hover-color: #585858;
	--header-main-nav-text-transform: uppercase;
	--header-active-color: #585858;
	--header-hover-decoration-display: none;
	--header-mobile-nav-bg: var(--body-bg);
	--header-mobile-color: var(--body-text-color);
	--header-mobile-weight: 700;
	--header-mobile-hover-bg-color: var(--bg-dark);
	--header-mobile-hover-color: var(--text-inverse);
	--header-mobile-border-color: var(--border-light);
	--header-join-now-height: 40px;

	--footer-bg: var(--bg-dark);
	--footer-text-color: var(--text-inverse);
	--footer-text-size: 16px;
	--footer-nav-text-lg-size: 16px;
	--footer-text-hover: #BAC0C9;
	--footer-dso-logo-height: 71px;

	--home-banner-content-mobile-gap: 16px;
	--home-banner-border-bottom-width: 0;
	--home-banner-title-text-wrap: auto;
	--home-banner-subtitle-color: var(--text-medium);
	--home-banner-subtitle-weight: 400;
	--home-banner-subtitle-xl-size: 25px;
	--home-banner-subtitle-lg-size: 22px;
	--home-banner-subtitle-md-size: 20px;
	--home-banner-subtitle-sm-size: 15px;
	--home-banner-form-title-color: var(--text-medium);
	--home-banner-form-input-border: #BCBDBD;
	--home-banner-form-wrapper-margin-top: 10px;
	--home-plans-bg-color: var(--accent);
	--home-section-title-xl-size: 45px;
	--home-section-title-lg-size: 40px;
	--home-section-title-md-size: 36px;
	--home-section-title-sm-size: 30px;
	--home-section-subtitle-size: 23px;
	--home-section-subtitle-mobile-size: 20px;
	--home-section-subtitle-color: var(--text-header-color);
	--home-section-subtitle-weight: 500;
	--home-plans-card-max-width: 513px;
	--home-plans-card-mobile-max-width: 400px;
	--home-plans-card-padding-left: 15px;
	--home-plans-card-padding-right: 15px;
	--home-plans-card-padding-bottom: 68px;
	--home-plans-card-box-shadow: 0px 12px 16px -4px rgba(16,24,40,0.1),0px 4px 6px -2px rgba(16,24,40,0.05);
	--home-plans-card-title-font: var(--text-header-font);
	--home-plans-card-title-xl-font-size: 45px;
	--home-plans-card-title-lg-font-size: 40px;
	--home-plans-card-title-md-font-size: 34px;
	--home-plans-card-title-weight: 600;
	--home-plans-card-title-color: var(--accent);
	--home-plans-card-price-margin-top: 8px;
	--home-plans-card-price-font: var(--text-header-font);
	--home-plans-card-price-color: var(--accent);
	--home-plans-card-price-amount-size: 64px;
	--home-plans-card-price-period-size: 40px;
	--home-plans-button-margin-top: 68px;
	--home-plans-button-mobile-margin-top: 68px;
	--home-advantages-bg-color: var(--body-bg);
	--home-advantages-title-color: var(--text-header-color);
	--home-advantages-title-size: 23px;
	--home-advantages-title-weight: 500;
	--home-advantages-subtitle-color: var(--text-header-color);
	--home-advantages-icon-bg-color: var(--bg-dark);
	--home-advantages-list-margin-top: 38px;
	--home-savings-bg: var(--bg-light);
	--home-savings-table-max-width: 1050px;
	--savings-summary-message-bg: var(--accent);
	--savings-summary-message-weight: 500;
	--savings-summary-message-color: var(--text-inverse);
	--savings-summary-message-icon-color: var(--text-inverse);
	--savings-table-note-padding-x: 0;
	--savings-summary-note-size: 17px;
	--home-how-background: var(--bg-dark);
	--home-step-title-size: 23px;
	--home-step-description-size: 18px;
	--home-questions-bg-color: var(--cta);
	--home-questions-title-color: var(--text-inverse);
	--home-questions-subtitle-color: var(--text-inverse);

	--savings-summary-bg: var(--bg-light);
	--savings-table-section-bg: var(--bg-light);
	--savings-table-mt: 16px;
	--custom-table-border-radius: 0;
	--custom-table-border-color: transparent;
	--custom-table-body-bg: transparent;
	--custom-table-header-bg: transparent;
	--custom-table-header-border-color: var(--cta);
	--custom-table-header-border-width: 2px;
	--custom-table-header-color: var(--text-header-color);
	--custom-table-header-font: var(--body-text-font);
	--custom-table-header-size: 22px;
	--custom-table-body-border-width: 1px;
	--custom-table-body-border-color: var(--border-light);
	--custom-table-body-color: var(--text-header-color);
	--custom-table-body-size: 22px;
	--custom-table-body-weight: 500;
	--custom-table-body-last-col-color: var(--text-header-color);
	--custom-table-mobile-body-size: 15px;
	--custom-table-row-full-bg: #D3E2E5;
	--custom-table-row-full-text-align: left;
	--custom-table-row-full-color: var(--accent);
	--custom-table-row-full-size: 20px;
	--custom-table-row-full-weight: 700;
	--custom-table-footer-full-bg: transparent;
	--custom-table-footer-border-top-color: var(--border-light);
	--custom-table-footer-border-bottom-color: var(--border-light);
	--custom-table-footer-full-color: var(--text-header-color);
	--custom-table-footer-full-font: var(--body-text-font);
	--custom-table-footer-full-size: 20px;

	--find-wrapper-bg: transparent;
	--find-content-border-color: transparent;
	--find-form-label-display: none;
	--find-steps-title-size: 40px;
	--find-steps-title-color: var(--text-header-color);
	--find-steps-subtitle-size: 20px;
	--find-steps-subtitle-color: var(--text-header-color);
	--find-steps-subtitle-weight: 400;
	--find-steps-number-active-border-color: #000;
	--find-steps-active-text-color: #000;
	--find-steps-number-inactive-border-color: #000;
	--find-steps-number-active-text-color: var(--text-header-color);
	--find-steps-inactive-text-color: #000;
	--find-steps-number-inactive-text-color: var(--text-header-color);
	--find-steps-number-text-size: 15px;
	--find-steps-number-text-weight: 700;
	--find-steps-text-size: 14px;
	--find-steps-text-weight: 400;
	--find-steps-text-color: var(--text-header-color);
	--find-steps-arrow-color: var(--primary);
	--find-steps-gap: 80px;
	--find-office-details-title-font: var(--body-text-font);
	--find-office-details-title-weight: 400;
	--find-office-details-title-color: #000;
	--find-office-details-title-size: 18px;
	--find-office-details-content-size: 16px;
	--find-office-details-content-color: #000;
	--find-office-details-content-weight: 400;
	--find-office-details-phone-color: var(--primary);
	--find-office-details-phone-hover-color: #000;
	--find-results-title-size: 22px;
	--find-results-title-font: var(--body-text-font);
	--find-results-title-weight: 400;
	--find-results-title-color: #000;
	--find-offices-width: 100%;
	--find-offices-padding: 0;
	--find-office-card-bg: var(--body-bg);
	--find-office-card-border-color: #CCCCCE;
	--find-office-select-btn-height: 37px;
	--find-office-select-btn-font-size: 14px;
	--find-office-select-btn-min-width: 120px;
	--find-map-border-width: 1px;
	--find-map-border-color: #666666;

	--faq-padding-bottom: 130px;
	--faq-gap: 100px;
	--faq-contact-radius: 16px;
	--faq-contact-bg: var(--cta);
	--faq-contact-info-title-color: var(--text-inverse);
	--faq-contact-info-text-size: 20px;
	--faq-contact-info-text-weight: 700;
	--faq-contact-info-text-color: var(--text-inverse);
	--faq-contact-info-text-weight: 400;
	--faq-contact-info-text-mt: 16px;
	--faq-contact-info-btn-width: 170px;
	--faq-close-icon-bg: var(--bg-dark);
	--faq-open-icon-bg: var(--bg-dark);
	--faq-entry-bg: #F4F4F4;
	--faq-entry-title-opened-color: var(--primary);
	--faq-entry-title-hover-color: #004a43;
	--faq-entry-border-color: transparent;
	--faq-entry-title-font: var(--body-text-font);
	--faq-entry-title-weight: 700;
	--faq-entry-title-color: var(--text-header-color);
	--faq-link-color: var(--text-header-color);
	--faq-answer-color: #8D8D8D;

	--support-max-width: 1030px;
	--support-page-bg: #F4FAFC;
	--support-wrapper-border-width: 0;
	--support-info-bg: var(--bg-dark);
	--support-info-title-font: var(--body-text-font);
	--support-info-title-size: 24px;
	--support-info-title-weight: 700;
	--support-info-text-size: 14px;
	--support-info-text-weight: 700;
	--support-info-icon-color: #BCDDF4;
	--support-form-label-size: 12px;
	--support-form-label-weight: 700;
	--support-form-label-color: var(--text-header-color);

	--join-content-border-color: transparent;
	--join-simple-stepper-title-weight: 400;
	--join-simple-stepper-form-title-weight: 400;
	--join-simple-stepper-form-title-color: #000;
	--join-simple-stepper-subtitle-weight: 400;
	--join-simple-stepper-step-2-icon-bg: var(--bg-dark);
	--join-simple-stepper-rail-color: var(--bg-dark);
	--signup-summary-border: #CDCDCE;
	--signup-summary-border-radius: 20px;
	--signup-summary-body-entry-color: #000;
	--signup-summary-body-entry-size: 16px;
	--signup-title-font: var(--body-text-font);
	--signup-title-size: 18px;
	--signup-title-weight: 500;
	--signup-summary-header-font: var(--body-text-font);
	--signup-summary-header-size: 24px;
	--signup-summary-header-weight: 500;
	--signup-summary-title-font: var(--body-text-font);
	--signup-summary-title-weight: 500;
	--singup-summary-link-hover-color: var(--text-header-color);
	--signup-summary-link-decoration: none;
	--signup-summary-disclaimer-entry-size: 14px;
	--signup-summary-disclaimer-entry-color: var(--text-medium);
	--signup-summary-total-row-size: 16px;
	--signup-summary-due-now-font: var(--body-text-font);
	--signup-summary-due-now-weight: 700;
	--signup-summary-due-now-color: #000;

	--signup-summary-due-now-bg: #E5EDF8;
	--signup-summary-totals-border-color: #19315b;

	--login-form-subtitle-display: block;
	--login-forgot-link-weight: 700;
	--login-form-title-color: var(--primary);
	--login-form-subtitle-size: 14px;
	--login-form-subtitle-weight: 700;
	--login-form-subtitle-color: var(--text-header-color);
	--login-form-label-color: var(--primary);

	--button-height: 49px;
	--button-text-size: 18px;
	--button-text-weight: 700;
	--button-border-radius: 999px;
	--button-padding-x: 30px;
}

@layer components {
	/* CTA / Primary Buttons */
	.find-select-office-btn,
	.home-advantages-button,
	.support-send-btn,
	.terms-accept-btn,
	.support-faq-link,
	.find-clear-filters-btn,
	.header-logout-btn,
	.submit-reset-btn,
	.login-forgot-submit-btn,
	.login-btn,
	.checkout-success-btn,
	.savings-summary-btn,
	.home-features-join-btn,
	.home-plans-join-btn,
	.home-banner-find-btn,
	.header-join-now-btn {
		background-color: var(--cta);
		color: var(--text-inverse);

		&:hover:not(:disabled) {
			background-color: var(--cta-hover);
			color: var(--text-inverse);
		}
	}

	/* CTA / Primary Buttons */
	.home-savings-btn {
		background-color: var(--cta);
		color: var(--text-inverse);

		&:hover:not(:disabled) {
			background-color: var(--primary);
			color: var(--text-inverse);
		}
	}

	/* White / CTA Buttons */
	.home-how-btn {
		background-color: white;
		color: var(--cta);

		&:hover:not(:disabled) {
			background-color: var(--cta);
			color: var(--text-inverse);
		}
	}

	/* Primary / Accent */
	.find-form-search-btn {
		background-color: var(--primary);
		color: var(--text-inverse);

		&:hover:not(:disabled) {
			background-color: var(--accent);
			color: var(--text-inverse);
		}
	}

	/* Primary / CTA */
	.start-btn {
		background-color: var(--primary);
		color: var(--text-inverse);

		&:hover:not(:disabled) {
			background-color: var(--cta);
		}
	}

	/* Primary / Opacity */
	.home-questions-faq-btn {
		background-color: var(--primary);
		color: var(--text-inverse);

		&:hover {
			opacity: .85;
		}
	}

	/* CTA / Opacity */
	.faq-contact-btn,
	.home-questions-contact-btn {
		background-color: white;
		color: var(--primary);

		&:hover {
			opacity: .85;
		}
	}

	/* Outlined Dark Buttons */
	.add-dependent-btn,
	.login-go-back-btn,
	.find-form-clear-btn {
		background-color: var(--body-bg);
		border-color: var(--primary);
		color: var(--primary);

		&:hover {
			background-color: var(--primary);
			color: var(--text-inverse);
		}
	}

	/* Fixed width lg */
	.savings-summary-btn,
	.home-how-btn,
	.home-savings-btn,
	.home-advantages-button,
	.home-plans-join-btn {
		width: 330px;
	}

	.support-link {
		border-radius: 10px;
		border-color: var(--border-light);
		background-color: var(--body-bg);
		height: 32px !important;
		font-size: 12px !important;
		color: var(--primary);
		font-weight: 700;

		&:hover {
			color: #004a43;
		}
	}
}

.home {
	--custom-table-body-last-border-width: 1px;

	.main-content {
		--button-text-size: 22px;
	}

	.home-banner {
		--button-text-size: 17px;
	}

	.home-plans {
		--home-section-title-color: var(--text-inverse);
		--home-section-subtitle-color: var(--text-inverse);
	}

	.home-questions-contact-btn,
	.home-questions-faq-btn {
		min-width: 180px;
	}


	.home-plans {
		--home-section-subtitle-size: 24px;
	}
}

.header {
	--button-text-size: 14px;
}

.support .main-content .btn {
	font-size: 12px;
	padding-left: 30px;
	padding-right: 30px;
}

.join-now {
	--text-header-color: #000;
	--text-subheader-color: #000;
}




