/* End custom CSS */

.elementor-43017 .elementor-element.elementor-element-b380a99 {
	--display: flex;
	--min-height: 400px;
	--flex-direction: column;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--justify-content: center;
	--align-items: center;
	--gap: 0px 0px;
	--row-gap: 0px;
	--column-gap: 0px;
	--margin-top: 0px;
	--margin-bottom: 0px;
	--margin-left: 0px;
	--margin-right: 0px;
	--padding-top: 140px;
	--padding-bottom: 4px;
	--padding-left: 0px;
	--padding-right: 0px;
}

.elementor-43017 .elementor-element.elementor-element-b380a99:not(.elementor-motion-effects-element-type-background), .elementor-43017 .elementor-element.elementor-element-b380a99 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
	background-image: url("https://usewhale.io/nitropack_static/dYCKVbRLfYKfcqiQliugswUtPKmzFGqU/assets/images/optimized/rev-c9105d9/usewhale.io/wp-content/uploads/2024/07/headerV5.svg");
	background-position: top center;
	background-repeat: no-repeat;
	background-size: cover;
}

.elementor-43017 .elementor-element.elementor-element-b380a99:not(.elementor-motion-effects-element-type-background).nitro-lazy, .elementor-43017 .elementor-element.elementor-element-b380a99 > .elementor-motion-effects-container > .elementor-motion-effects-layer.nitro-lazy {
	background-image: none !important;
}

.elementor-43017 .elementor-element.elementor-element-b380a99.e-con {
	--align-self: center;
}

.elementor-43017 .elementor-element.elementor-element-fa9ee17 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--justify-content: center;
	--align-items: center;
	--gap: 28px 0px;
	--row-gap: 28px;
	--column-gap: 0px;
	--margin-top: 32px;
	--margin-bottom: 32px;
	--margin-left: 0px;
	--margin-right: 0px;
	--padding-top: 0px;
	--padding-bottom: 0px;
	--padding-left: 0px;
	--padding-right: 0px;
}

.elementor-43017 .elementor-element.elementor-element-fa9ee17.e-con {
	--flex-grow: 0;
	--flex-shrink: 0;
}

.elementor-43017 .elementor-element.elementor-element-219852d > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-219852d {
	text-align: center;
}

.elementor-43017 .elementor-element.elementor-element-219852d .elementor-heading-title {
	font-family: var(--e-global-typography-d635cf0-font-family), Inter;
	font-size: var(--e-global-typography-d635cf0-font-size);
	font-weight: var(--e-global-typography-d635cf0-font-weight);
	line-height: var(--e-global-typography-d635cf0-line-height);
	letter-spacing: var(--e-global-typography-d635cf0-letter-spacing);
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-b05c1fd {
	--display: flex;
	--min-height: 0px;
	--flex-direction: row;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: 100%;
	--container-widget-flex-grow: 1;
	--container-widget-align-self: stretch;
	--flex-wrap-mobile: wrap;
	--justify-content: flex-start;
	--align-items: flex-start;
	--gap: 32px 32px;
	--row-gap: 32px;
	--column-gap: 32px;
	--border-radius: 12px 12px 12px 12px;
	box-shadow: 0px 0px 25px 0px rgba(0, 0, 0, .18);
	--margin-top: 40px;
	--margin-bottom: 0px;
	--margin-left: 0px;
	--margin-right: 0px;
	--padding-top: 40px;
	--padding-bottom: 40px;
	--padding-left: 40px;
	--padding-right: 40px;
}

.elementor-43017 .elementor-element.elementor-element-b05c1fd:not(.elementor-motion-effects-element-type-background), .elementor-43017 .elementor-element.elementor-element-b05c1fd > .elementor-motion-effects-container > .elementor-motion-effects-layer {
	background-color: var(--e-global-color-c550a3b);
}

.elementor-43017 .elementor-element.elementor-element-c3a24ab {
	--display: flex;
	--min-height: 0px;
	--flex-direction: column;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--justify-content: center;
	--align-items: flex-start;
	--gap: 32px 32px;
	--row-gap: 32px;
	--column-gap: 32px;
}

.elementor-43017 .elementor-element.elementor-element-99275ea > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-99275ea {
	text-align: start;
}

.elementor-43017 .elementor-element.elementor-element-99275ea .elementor-heading-title {
	font-family: var(--e-global-typography-b9689a7-font-family), Inter;
	font-size: var(--e-global-typography-b9689a7-font-size);
	font-weight: var(--e-global-typography-b9689a7-font-weight);
	line-height: var(--e-global-typography-b9689a7-line-height);
	letter-spacing: var(--e-global-typography-b9689a7-letter-spacing);
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-2266199 {
	width: var(--container-widget-width, 713px);
	max-width: 713px;
	--container-widget-width: 713px;
	--container-widget-flex-grow: 0;
	text-align: start;
	font-family: var(--e-global-typography-51ec25d-font-family), Inter;
	font-size: var(--e-global-typography-51ec25d-font-size);
	font-weight: var(--e-global-typography-51ec25d-font-weight);
	line-height: var(--e-global-typography-51ec25d-line-height);
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-2266199 > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-2266199.elementor-element {
	--flex-grow: 0;
	--flex-shrink: 0;
}

.elementor-43017 .elementor-element.elementor-element-4667642 {
	--display: flex;
	--min-height: 0px;
	--flex-direction: column;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--justify-content: center;
	--align-items: flex-start;
	--gap: 32px 32px;
	--row-gap: 32px;
	--column-gap: 32px;
}

.elementor-43017 .elementor-element.elementor-element-b3c7867 > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-b3c7867 {
	text-align: start;
}

.elementor-43017 .elementor-element.elementor-element-b3c7867 .elementor-heading-title {
	font-family: "Nunito", Inter;
	font-size: 26px;
	font-weight: 700;
	line-height: 30px;
	letter-spacing: 0px;
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-5c33290 {
	width: var(--container-widget-width, 713px);
	max-width: 713px;
	--container-widget-width: 713px;
	--container-widget-flex-grow: 0;
	text-align: start;
	font-family: var(--e-global-typography-51ec25d-font-family), Inter;
	font-size: var(--e-global-typography-51ec25d-font-size);
	font-weight: var(--e-global-typography-51ec25d-font-weight);
	line-height: var(--e-global-typography-51ec25d-line-height);
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-5c33290 > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-5c33290.elementor-element {
	--flex-grow: 0;
	--flex-shrink: 0;
}

.elementor-43017 .elementor-element.elementor-element-6b34247 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: calc(( 1 - var(--container-widget-flex-grow) ) * 100%);
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--align-items: center;
}

.elementor-43017 .elementor-element.elementor-element-b0f95f1 {
	width: var(--container-widget-width, 800px);
	max-width: 800px;
	--container-widget-width: 800px;
	--container-widget-flex-grow: 0;
}

.elementor-43017 .elementor-element.elementor-element-b0f95f1 > .elementor-widget-container {
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0px 0px;
}

.elementor-43017 .elementor-element.elementor-element-50aceb9 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
	--margin-top: 80px;
	--margin-bottom: 80px;
	--margin-left: 0px;
	--margin-right: 0px;
}

.elementor-43017 .elementor-element.elementor-element-1dfa12d > .elementor-widget-container {
	margin: 0px 0px 12px 0px;
}

.elementor-43017 .elementor-element.elementor-element-1dfa12d {
	font-family: "Nunito", Inter;
	font-size: 18px;
	font-weight: 500;
	line-height: 26px;
	letter-spacing: -.065px;
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-7fcdb3d > .elementor-widget-container {
	margin: 0px 0px 12px 0px;
}

.elementor-43017 .elementor-element.elementor-element-7fcdb3d {
	font-family: "Nunito", Inter;
	font-size: 18px;
	font-weight: 500;
	line-height: 26px;
	letter-spacing: -.065px;
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-7a898b1 > .elementor-widget-container {
	padding: 24px 24px 24px 24px;
}

.elementor-43017 .elementor-element.elementor-element-7a898b1 img {
	border-radius: 24px 24px 24px 24px;
}

.elementor-43017 .elementor-element.elementor-element-f438f47 > .elementor-widget-container {
	margin: 12px 0px 16px 0px;
}

.elementor-43017 .elementor-element.elementor-element-f438f47 .elementor-heading-title {
	color: #354093;
}

.elementor-43017 .elementor-element.elementor-element-e589914 > .elementor-widget-container {
	margin: 0px 0px 12px 0px;
}

.elementor-43017 .elementor-element.elementor-element-e589914 {
	font-family: "Nunito", Inter;
	font-size: 18px;
	font-weight: 500;
	line-height: 26px;
	letter-spacing: -.065px;
	color: var(--e-global-color-f2fc99c);
}

.elementor-43017 .elementor-element.elementor-element-9912751 > .elementor-widget-container {
	padding: 24px 24px 24px 24px;
}

.elementor-43017 .elementor-element.elementor-element-9912751 img {
	border-radius: 24px 24px 24px 24px;
}

.elementor-43017 .elementor-element.elementor-element-4ff7856 {
	--display: flex;
	--margin-top: 0px;
	--margin-bottom: 0px;
	--margin-left: 0px;
	--margin-right: 0px;
	--padding-top: 0px;
	--padding-bottom: 0px;
	--padding-left: 0px;
	--padding-right: 0px;
}

@media (min-width:768px) {
	.elementor-43017 .elementor-element.elementor-element-b380a99 {
		--content-width: 801px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-fa9ee17 {
		--width: 970px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-b05c1fd {
		--width: 100%;
	}
	
	.elementor-43017 .elementor-element.elementor-element-c3a24ab {
		--width: 100%;
	}
	
	.elementor-43017 .elementor-element.elementor-element-4667642 {
		--width: 100%;
	}
	
	.elementor-43017 .elementor-element.elementor-element-50aceb9 {
		--content-width: 800px;
	}
}

@media (max-width:1024px) and (min-width:768px) {
	.elementor-43017 .elementor-element.elementor-element-fa9ee17 {
		--width: 100%;
	}
}

@media (max-width:1024px) {
	.elementor-43017 .elementor-element.elementor-element-b380a99 {
		--min-height: 400px;
		--padding-top: 64px;
		--padding-bottom: 72px;
		--padding-left: 0px;
		--padding-right: 0px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-fa9ee17 {
		--padding-top: 0px;
		--padding-bottom: 0px;
		--padding-left: 50px;
		--padding-right: 50px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-219852d .elementor-heading-title {
		font-size: var(--e-global-typography-d635cf0-font-size);
		line-height: var(--e-global-typography-d635cf0-line-height);
		letter-spacing: var(--e-global-typography-d635cf0-letter-spacing);
	}
	
	.elementor-43017 .elementor-element.elementor-element-99275ea .elementor-heading-title {
		font-size: var(--e-global-typography-b9689a7-font-size);
		line-height: var(--e-global-typography-b9689a7-line-height);
		letter-spacing: var(--e-global-typography-b9689a7-letter-spacing);
	}
	
	.elementor-43017 .elementor-element.elementor-element-2266199 {
		font-size: var(--e-global-typography-51ec25d-font-size);
		line-height: var(--e-global-typography-51ec25d-line-height);
	}
	
	.elementor-43017 .elementor-element.elementor-element-5c33290 {
		font-size: var(--e-global-typography-51ec25d-font-size);
		line-height: var(--e-global-typography-51ec25d-line-height);
	}
	
	.elementor-43017 .elementor-element.elementor-element-6b34247 {
		--padding-top: 30px;
		--padding-bottom: 30px;
		--padding-left: 30px;
		--padding-right: 30px;
	}
}

@media (max-width:767px) {
	.elementor-43017 .elementor-element.elementor-element-b380a99 {
		--content-width: 100%;
		--padding-top: 100px;
		--padding-bottom: 0px;
		--padding-left: 30px;
		--padding-right: 30px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-fa9ee17 {
		--margin-top: 0px;
		--margin-bottom: 0px;
		--margin-left: 0px;
		--margin-right: 0px;
		--padding-top: 0px;
		--padding-bottom: 0px;
		--padding-left: 0px;
		--padding-right: 0px;
	}
	
	.elementor-43017 .elementor-element.elementor-element-219852d .elementor-heading-title {
		font-size: var(--e-global-typography-d635cf0-font-size);
		line-height: var(--e-global-typography-d635cf0-line-height);
		letter-spacing: var(--e-global-typography-d635cf0-letter-spacing);
	}
	
	.elementor-43017 .elementor-element.elementor-element-b05c1fd {
		--width: 100%;
		--flex-direction: column;
		--container-widget-width: 100%;
		--container-widget-height: initial;
		--container-widget-flex-grow: 0;
		--container-widget-align-self: initial;
		--flex-wrap-mobile: wrap;
		--justify-content: center;
		--gap: 24px 24px;
		--row-gap: 24px;
		--column-gap: 24px;
		--flex-wrap: wrap;
	}
	
	.elementor-43017 .elementor-element.elementor-element-c3a24ab {
		--flex-direction: column;
		--container-widget-width: 100%;
		--container-widget-height: initial;
		--container-widget-flex-grow: 0;
		--container-widget-align-self: initial;
		--flex-wrap-mobile: wrap;
		--justify-content: center;
		--gap: 24px 24px;
		--row-gap: 24px;
		--column-gap: 24px;
		--flex-wrap: wrap;
	}
	
	.elementor-43017 .elementor-element.elementor-element-99275ea .elementor-heading-title {
		font-size: var(--e-global-typography-b9689a7-font-size);
		line-height: var(--e-global-typography-b9689a7-line-height);
		letter-spacing: var(--e-global-typography-b9689a7-letter-spacing);
	}
	
	.elementor-43017 .elementor-element.elementor-element-2266199 {
		font-size: var(--e-global-typography-51ec25d-font-size);
		line-height: var(--e-global-typography-51ec25d-line-height);
	}
	
	.elementor-43017 .elementor-element.elementor-element-4667642 {
		--flex-direction: column;
		--container-widget-width: 100%;
		--container-widget-height: initial;
		--container-widget-flex-grow: 0;
		--container-widget-align-self: initial;
		--flex-wrap-mobile: wrap;
		--justify-content: center;
		--gap: 24px 24px;
		--row-gap: 24px;
		--column-gap: 24px;
		--flex-wrap: wrap;
	}
	
	.elementor-43017 .elementor-element.elementor-element-5c33290 {
		font-size: var(--e-global-typography-51ec25d-font-size);
		line-height: var(--e-global-typography-51ec25d-line-height);
	}
	
	.elementor-43017 .elementor-element.elementor-element-50aceb9 {
		--margin-top: 50px;
		--margin-bottom: 50px;
		--margin-left: 0px;
		--margin-right: 0px;
		--padding-top: 30px;
		--padding-bottom: 30px;
		--padding-left: 30px;
		--padding-right: 30px;
	}
}

/* Start custom CSS for html, class: .elementor-element-b0f95f1 */

/* Scoped Styles for the Whale ROI Calculator */
#calculator {
	/* CSS Variables (scoped to the calculator) */
	--primary-color: #354094;
	--secondary-color: #1f2971;
	--accent-color: #5e6cd5;
	--body-font: "nunito", sans-serif;
	--bg-color: #fff;
	--text-color: #354094;
	font-family: var(--body-font);
	line-height: 1.6;
	background-color: var(--bg-color);
	color: var(--text-color);
}

/* Apply box-sizing to all calculator elements */
#calculator * {
	box-sizing: border-box;
}

/* MAIN TITLE > "WHALE ROI CALCULATOR" */
#calculator #main_title {
	text-align: center;
	font-family: var(--body-font);
	font-weight: 600;
	font-size: 56px;
	margin: 30px 0 60px;
	color: var(--primary-color);
}

/* Optional container (if used inside your widget) */
#calculator .container {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
}

/* Headings */
#calculator h1, #calculator h2 {
	text-align: center;
	color: var(--primary-color);
	font-family: var(--body-font);
}

/* Input Section */
#calculator .input-section {
	background-color: var(--bg-color);
	border-radius: 8px;
	padding: 20px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, .1);
	margin-bottom: 20px;
}

/* Slider Styles */
#calculator .slider-container {
	display: flex;
	align-items: center;
	margin-bottom: 15px;
}

#calculator .slider-container label {
	flex: 0 0 250px;
	font-weight: bold;
}

#calculator input[type="range"] {
	flex: 1;
	margin: 0 10px;
}

#calculator .slider-container span {
	min-width: 30px;
	text-align: right;
}

/* Table Styles */
#calculator table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 20px;
}

#calculator th, #calculator td {
	padding: 12px;
	text-align: left;
	border-bottom: 1px solid #ddd;
}

#calculator th {
	background-color: #f2f2f2;
	font-weight: bold;
}

/* ROI Boxes */
#calculator .roi-boxes {
	display: flex;
	gap: 20px;
	margin-top: 20px;
}

#calculator .savings-box, #calculator .roi-percent-box {
	flex: 1;
	padding: 15px;
	border-radius: 8px;
	color: #fff;
	text-align: center;
}

#calculator .savings-box {
	background-color: var(--accent-color);
}

#calculator .roi-percent-box {
	background-color: var(--secondary-color);
}

#calculator .roi-boxes h2 {
	margin-top: 0;
	font-size: 1.2em;
	color: #fff;
}

#calculator .roi-boxes h1 {
	margin-bottom: 0;
	font-size: 1.8em;
	color: #fff;
}

/* Responsive Styles */
@media (max-width: 768px) {
	#calculator .slider-container {
		flex-direction: column;
		align-items: flex-start;
	}
	
	#calculator .slider-container label {
		margin-bottom: 5px;
	}
	
	#calculator .roi-boxes {
		flex-direction: column;
	}
}
