* {box-sizing: border-box}

:root {
--fontFam: arial, helvetica, sans-serif;
--FontH1: pink;
--FontH2: Jubilat, Georgia, sans-serif;
--CalcBG: linear-gradient(to bottom right, rgba(24, 63, 102, .3), rgba(34, 89, 143, .2));
--CalcColour1:#ccc;
--CalcColour2:#ccc;
--CalcFontColour: #22598f;
--CalcMarkColour: #b58f0a;
--CalcButtonBG: pink;
--CalcButtonBGHover: pink;
--CalcButtonBorder: pink;
--CalcButtonBorderHover: pink;
--CalcButtonText: pink;
--CalcButtonTextHover: pink;
--CalcErrorColour: pink; 
--CalcIFrameBG: pink;
--CalcFormBG: pink;
--CalcFormLabelColor: var(--CalcColour2);
--SliderSlotColor: #62bed9;
--SliderButtonColor: #C3E0E5;
--SliderButtonHover: #FFF;
}

body {
	font-family: var(--fontFam);
    color: rgba(0, 0, 0, .6);
    font-weight: 400;
    line-height: 1.8em;
    vertical-align: top;
	margin: 0;
	padding: 20px 25px 0 25px;
	background: #24678d;
}

@media (max-width:640px) {
	body {
		margin: 0;
		padding: 20px 0 0 0;
	}
}

.iFrameCalc {
	border: solid 2px green;
	width: 100%;
	height: 3000px;
}

div.formSectionBox {
	width: 100%;
	border: solid 2px #ccc;
	border-radius: 8px;
	padding: 5px 0;
	margin-bottom: 20px;
}

@media (max-width:640px) {
	div.formSectionBox {
	width: 100%;
	border: solid 2px #ccc;
	border-radius: 8px;
	padding: 5px 0;
	margin-bottom: 20px;
	}
}

p {font-family: var(--fontFam);}

h2.calcPageHeading {
	font-family: var(--fontH2);
	font-style: italic;
	padding: 5px 5px 5px 5px;
	font-size: 17pt;
	text-decoration: none;
	letter-spacing: 1px;
	line-height: 150%;
	font-weight: 700;
	color: #fff;
	margin: 10px 0;
	text-align: left;
}

@media (max-width:640px) {h2.calcPageHeading {font-size: 14pt}}

h3.formSectionHeading {
	font-family: var(--fontH2);
	font-style: italic;
	padding: 5px 5px 5px 30px;
	font-size: 14pt;
	text-decoration: none;
	letter-spacing: 1px;
	line-height: 150%;
	font-weight: 700;
	color: #fff;
	margin: 10px 0;
	text-align: left;
}

@media (max-width:575px){
	h3.formSectionHeading {
		padding: 3px 5px 0 5px;
		margin: 10px 0 2px 0;
	}
}

p.regularContent, p.headerContent, p.quoteIntroPara {
    padding: 8px 30px 10px 30px;
    font-size: 17px;
    letter-spacing: 1px;
    line-height: 160%;
    color: #fff;
    margin: 0;
    text-align: left;
}

p.headerContent  {
    font-weight: 700;
    font-style: italic;
    line-height: 175%;
    padding: 5px 30px 15px 30px;
}

@media (max-width:575px){p.regularContent,p.quoteIntroPara,p.headerContent {padding: 8px 8px 10px 6px}}

div.quoteSummaryBox {
	width: 90%;
	background-color: #fff;
	border: solid 2px #ccc;
	border-radius: 8px;
	padding: 10px 10px 10px 2px;
	margin: 20px 20px 20px 30px;
}

@media (max-width:575px){
	div.quoteSummaryBox {
		width: 90%;
		margin: 20px 15px 20px 15px;
	}
}

.quoteSummaryList {
	margin:10px 12px 20px 20px;
	color:var(--CalcColour2);
}

.quoteSummaryList>li {
	font-size:17px;
	letter-spacing:1px;
	line-height:160%;
	padding-bottom:10px;
	font-weight:400;
	color: #0b2e75
}

p.calcResultsNotes {
    padding: 8px 30px 10px 30px;
    font-size: 16px;
	font-weight:400;
    letter-spacing: 1px;
    line-height: 160%;
    margin: 0;
    text-align: left;
}

@media (max-width:575px){
	p.calcResultsNotes {
    padding: 8px 6px 10px 10px;
}
	
	.quoteSummaryList {
	margin:10px 0 20px 0px;
	color:var(--CalcColour2);
	}

.quoteSummaryList>li {
	font-size:17px;
	letter-spacing:1px;
	line-height:160%;
	padding-bottom:10px;
	font-weight:400;
	color: #0b2e75;
	}
}

mark {
    background-color: transparent;
    color: #b58f0a;
}

.italic {font-style:italic}

input[type=text],textarea{
	width:100%;
	width: 240px;
	font-size:14px;
	padding:10px 10px;
	margin:1px 0 15px 0;
	display:inline-block;
	border:2px solid var(--CalcColour1);
	border-radius:4px;
	box-sizing:border-box;
	background-color:#eee;
	color:#333
}
	
input[type=message],textarea{
	width:100%;
	height:150px;
	padding:10px 10px;
	margin:1px 0 15px 0;
	display:inline-block;
	border:2px solid var(--CalcColour1);
	border-radius:4px;
	box-sizing:border-box;
	background-color:#eee;
	color:#333
}

input[type=number]{
	width:100%;
	padding:10px 10px;
	padding: 8px 1px 8px 7px;
	margin:1px 0 15px 0;
	display:inline-block;
	border:1px solid var(--CalcColour1);
	border-radius:4px;
	box-sizing:border-box;
	background-color:#eee
}

input[type=email]{
	width:100%;
	padding:10px 10px;
	margin:1px 0 15px 0;
	display:inline-block;
	border:1px solid var(--CalcColour1);
	border-radius:4px;
	box-sizing:border-box;
	background-color:#eee
}

input[type=text]:focus{
	border:1px solid var(--CalcColour1);
	background-color:#eee
}

input[type=button],input[type=reset],input[type=submit]{
	background:var(--CalcColour1);
	margin:1px 0 15px 0;
	padding:5px 18px;
	border:solid 1px #FFF;
	border-radius:8px;
	cursor:pointer;
	text-decoration:none;
	font-size:16px;
	color:#fff;
	color:#0b2e75
}

input[type="range" i] {
    appearance: auto;
    cursor: default;
    color: light-dark(rgb(16, 16, 16), rgb(255, 255, 255));
    padding: initial;
    border: initial;
	background: pink;
    margin: 4px;
}

input[type="number"].short {width: 6ch}
	
input[type=submit]:hover{
	background:#fff;
	color:#000
}

/********** Range Sliders **********/
/*Range Reset*/
input[type="range"] {
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
	cursor: pointer;
	width: 130px;
}

@media (max-width:575px){
	
	input[type="number"].short {
		width: 5ch;
		font-size: 18px;
	}
		
	input[type="range"] {width: 220px;}
}

input[type="range"]:focus {outline: none;}

/***** Chrome, Safari, Opera and Edge Chromium styles *****/
/* slider track */
input[type="range"]::-webkit-slider-runnable-track {
	background-color: var(--SliderSlotColor);
	border-radius: 3px;
	height: 6px;  
}

/* slider thumb */
input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	margin-top: -10px;
	background-color: #C3E0E5;
	height: 26px;
	width: 1rem;
}

input[type="range"]::-webkit-slider-thumb:hover {background-color: var(--SliderButtonHover);}

input[type="range"]:focus::-webkit-slider-thumb {   
	border: 1px solid #053a5f;
	outline: 1px solid var(--SliderButtonHover);
	outline-offset: 0.125rem; 
}

/* slider track */
input[type="range"]::-moz-range-track {
	background-color: var(--SliderSlotColor);
	border-radius: 3px;
	height: 6px; 
}

/* slider thumb */
input[type="range"]::-moz-range-thumb {
	border: none;
	border-radius: 0;
	background-color: #C3E0E5;
	height: 2rem;
	width: 1rem;
}

input[type="range"]::-moz-range-thumb:hover {background-color: var(--SliderButtonHover);}

input[type="range"]:focus::-moz-range-thumb {
	border: 1px solid #053a5f;
	outline: 1px solid var(--SliderButtonHover);
	outline-offset: 0.125rem; 
}

a:link.blockedForm,a:visited.blockedForm{
	background:var(--CalcColour1);
	margin:1px 0 15px 0;
	padding:5px 18px;
	border:solid 1px #FFF;
	border-radius:8px;
	cursor:pointer;
	text-decoration:none;
	font-size:16px;
	color:#fff
}

a:hover.blockedForm{background:red;color:#fff}

.calcFormLabel,.calcColumnLabelLeft,.calcColumnLabelRight{
	font-weight:500;
	color: var(--CalcFormLabelColor);
	color: #fff;
	margin:0;
	padding-left:40px
}

@media (max-width:575px){
	.calcFormLabel{padding-left:0px;padding-bottom:0px}
}

.calcColumnLabelLeft,.calcColumnLabelRight {
	color: var(--CalcColour1);
	color: #fff;
	font-weight:700;
}

.calcColumnLabelRight{padding-left:unset}

.selectDD {
	width:240px;
	height:38px;
	font-size:14px;
    padding: 5px 10px;
    margin: 1px 0 10px 0;
    display: inline-block;
    border: 2px solid var(--CalcColour1);	
    border-radius: 4px;
    box-sizing: border-box;
    background-color: #eee;
    color: #333;
}

@media (max-width:575px){
	.selectDD {
		width:280px;
		height:40px;
		font-size:16px;
		color: #666;
		background-color:#eee;
		border-radius:4px;
		margin: 0 0 5px 0;	
	}
}

.calc-container {
	display:flex;
	width:100%
}

.calc-container > div {
	margin: 2px;
	padding: 4px 5px
}

@media (max-width:575px){
	.calc-container {
		display:flex;
		width:100%;
		padding: 2px 10px
	}
	
	.calc-container > div {
		margin: 2px;
		padding: 0px 15px
	}
}

.calcCol1{width:65%}
.calcCol2{width:35%}

.quote-container {
	display: flex;
	background-color:transparent;
	width:99%;
	padding:0 0 1px 30px
}
.quote-container > div {
	background-color:#eee;
	margin: 2px;
	padding: 2px 20px;
	color: #333
}

.quoteCol1{width:60%}
.quoteCol2{width:40%}
.quoteCol3{width: 20%;text-align:right}

@media (max-width:575px){
	.calc-container {display:flex;flex-direction:column;width:100%}
	.calc-container > div {margin: 0px;padding: 5px 10px}
	.calcCol1{width:100%}
	.calcCol2{width:100%;padding:0 0 50px 100px; right:0}

	.quote-container {
		display: flex;
		flex-direction:column;
		background-color:#ccc;
		width: 100%;
		border: solid 1px #099;
		margin:0 0 15px 0
	}
	.quote-container > div {
		background-color:#ccc;
		margin:2px;
		padding:0 10px;
		color: #333
	}
	
	.quoteCol1{width:95%;font-size:14pt;font-weight:700}
	.quoteCol2{width: 95%;padding:0 50px}
	.quoteCol3{width: 95%; font-weight: 700; font-size: 16pt}
	}
}

.formError{color:#cc0000}

.promoButton {
	background: var(--col2);
	background: #183f66;
	border: solid 1px #fff;
	border-radius: 8px;
	cursor: pointer;
	text-decoration: none;
	color: #eee;
	transition: .5s;
	margin: 10px 0 5px 10px;
	padding: 6px 16px;
}

.calcInfoBox {
	border:solid 2px #22598f; 
	border-radius:8px;
	margin: 10px 10px 20px 20px;
	padding:5px 0
}

@media (max-width:575px){
	.calcInfoBox {
		margin: 10px 6px 20px 10px;
		padding:5px 0
	}
}

@media (max-width:575px) {.noMob {display:none}}
@media (min-width:576px) {.onlyMob {display:none}}

.busy {opacity: 0.4;pointer-events: none;transition: 0.5}