* {box-sizing: border-box}
:root {
--fontFam: arial, helvetica, sans-serif;
--FontH2: Jubilat, Georgia, sans-serif;
--CalcBG: linear-gradient(to bottom right, rgba(24, 63, 102, .3), rgba(34, 89, 143, .2));
--CalcColour1:#1d4e58;
--CalcColour2:#3d6671;
--CalcColour3:#51737d;
--CalcColour4:#6fa2a8;
--CalcColour5:#99cccc;
--CalcBG: var(--CalcColour3, red);
--CalcButtonBG: var(--CalcColour2, red);
--CalcButtonBGHover: var(--CalcColour4, red);
--CalcButtonText: #fff;
--CalcButtonTextHover: #fff;
--CalcButtonBorder: #fff;
--CalcButtonBorderHover: #fff;
--ResultsFontColour: var(--CalcColour3);
--CalcFormLabelColour: #fff;
--SliderButton: var(--CalcColour5);
--SliderButtonHover: #fff;
--SliderSlotColor: var(--CalcColour4);
--SliderColor: var(--CalcColour5);
}

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: var(--CalcBG);
}

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

/*.iFrameCalc {border: solid 2px red;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, p.resultsContent {
    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;
}

p.resultsContent {color:var(--CalcColour2)}

@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(--ResultsFontColour)}

.quoteSummaryList>li {
	font-size:17px;
	letter-spacing:1px;
	line-height:160%;
	padding-bottom:10px;
	font-weight:400;
	color:var(--ResultsFontColour);  /* DGH */
}

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

@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}

.flex-email-form {display: flex;align-items: center;}

.flex-email-form > div {margin: 5px;padding: 5px}

@media (max-width:575px){.flex-email-form {display: flex;flex-direction:column;align-items: center}}

input[type=text],textarea{
	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=text]:hover {background-color: #eee}
textarea:hover {background-color: #eee}

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],input[type=submit].emailButton{
	background:var(--CalcButtonBG);
	border:solid 1px var(--CalcButtonBorder);
	color:var(--CalcButtonText);
	border-radius:8px;	
	margin:1px 0 15px 0;
	padding:5px 18px;
	cursor:pointer;
	text-decoration:none;
	font-size:16px
}

input[type=text].emailField {
	width: 200px;
	background-color: #eee;
	height: 32px;
	border: solid 1px var(--CalcColour1);
	border-radius: 8px;
	color: var(--CalcColour5);
}

input[type=submit].emailButton:hover {background-color: var(--CalcColour4);border:solid 1px var(--CalcButtonBorderHover)}

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

input[type="number"].short {width: 6ch}
	
input[type=submit]:hover{
	background:var(--CalcButtonBGHover);
	border:solid 1px var(--CalcButtonBorderHover);
	color:var(--CalcButtonTextHover);
}

/*Slider 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;}

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

input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	margin-top: -10px;
	background-color: var(--SliderColor);
	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 var(--SliderColor);
	outline: 1px solid var(--SliderButtonHover);
	outline-offset: 0.125rem; 
}

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

input[type="range"]::-moz-range-thumb {
	border: none;
	border-radius: 0;
	background-color: var(--SliderColor);
	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 var(--SliderColor);
	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(--CalcFormLabelColour);	
	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(--CalcColour2);	
    border: 2px solid green;	
    border-radius: 4px;
    box-sizing: border-box;
    background-color: #eee;
    color: #333;
}

.selectDD:hover {background-color: #eee}


/* Default state for selects and custom dropdowns */
.selectDD,
.custom-select .select-selected {
	border: 1px solid #ccc;
	background-color: #eee;
	color: #333;
	box-sizing: border-box; /* stops resizing when border changes */
}

/* Error state */
.selectDD.error,
.custom-select .select-selected.error {
	border: 1px solid <?php echo $borderErr ?>;
	background-color: <?php echo $backGndErr ?>;
	color: <?php echo $fontErr ?>;
}

/* Optional error message styling */
.form-error {
	color: <?php echo $errorMessage ?>;
	padding: 0;
	margin: 0;
}

@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}
	}
}

.submitButtonAlignment {text-align:left;align-items:left}

.errorMessageBlock {
	padding: 0 0 0 30px;
	margin:0;
	text-align: center;
	height:40px
}

@media (max-width:575px){.errorMessageBlock {padding: 0;margin:0;height:60px}}

.submitButtonAlignment {text-align: left}

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

.calcButtonStandard:hover {background: var(--CalcButtonBGHover);color:var(--CalcButtonTextHover)}
.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}