* {box-sizing: border-box}
:root {
--CalcBG: #D9E8F6;
--CalcBG: #22598f;
--CalcColour1:#ffffff;
--CalcColour2:#ffffff;

		--CalcColour1:YELLOW;
		--CalcColour2:PINK;

		--CalcFontColour: #22598f;
		--CalcMarkColour: #b58f0a;
		--CalcButtonBG: pink;
	
--ButtonBackgroundDefault: #183f66;

		--fontFam: arial, helvetica, sans-serif;
--fontFam: "Mulish", sans-serif;		
--FontH2: Jubilat, Georgia, sans-serif;
--CalcColour1:#002c36;
--CalcColour2:#4a7299;
--CalcColour3:#427193;
--CalcColour4:#22598f;
--CalcColour5:#D9E8F6;
--CalcBG: var(--CalcColour2, red);
--CalcButtonBG: var(--CalcColour2, red);
--CalcButtonBGHover: var(--CalcColour4, red);
--CalcButtonText: #fff;
--CalcButtonTextHover: #fff;
--CalcButtonBorder: var(--CalcColour5);
--CalcButtonBorderHover: #fff;
--FontColourMain: #fff;
--ResultsFontColour: var(--CalcColour3);
--CalcFormLabelColour: #fff;
--SliderButton: var(--CalcColour5);
--SliderButtonHover: #fff;
--SliderSlotColor: var(--CalcColour5);
--SliderColor: var(--CalcColour3);

--ResultsSectionHeading: #ddd;
--ResultsLineItem: #fff;

--PaymentPanelOuter: red;
--PaymentPanelInner: pink;
--PaymentContentOuter: var(--CalcColour2);
--PaymentContentInner: var(--CalcColour2);
}

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: white;
	background-image: linear-gradient(to right, rgb(24, 63, 102, 0.7), rgb(24, 63, 102, 9.5));
}

.content {
	padding: 20px 0 0 0;
	background: #fff;
	box-shadow: 0 0 10px rgba(0,0,0,0.1);
}

/* Mobile/Desktop fallback heights */
@media (max-width: 768px) {
	body::after {
	content: '';
	display: block;
	height: 5px;
	}
}

@media (min-width: 769px) {
	body::after {
	content: '';
	display: block;
	height: 5px;
	}
}

div.formSectionBox {
	width: 100%;
	border: solid 2px #eee;
	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}
	}


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

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: var(--FontColourMain);
	margin: 10px 0;
	text-align: left;
}


p.regularContent, 
p.headerContent,
p.regularContentIndented, 
p.headerContentIndented,
p.regularContentWhite, 
p.headerContentWhite  {
    padding: 8px 30px 10px 30px;
    font-size: 17px;
    letter-spacing: 1px;
    line-height: 160%;
    color: var(--CalcColour2);
    color: var(--FontColourMain);
    margin: 0;
    text-align: left;
}

.paymentSectionContent {
    padding: 8px 30px 10px 30px;
    font-size: 17px;
    letter-spacing: 1px;
    line-height: 160%;
    color: var(--PaymentContentInner);
    margin: 0;
    text-align: left;
	text-decoration:italic
}

@media (max-width:575px){
	.paymentPlanBoxDemoNotes {margin: 0 15px 20px 15px}
	.paymentSectionContent {padding: 8px 10px 10px 10px;}
}

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

p.regularContentWhite, p.headerContentWhite  {color: #fff}
p.regularContentIndented, p.headerContentIndented  {padding-left:50px}
@media (max-width:575px){p.regularContentIndented, p.headerContentIndented  {padding-left:20px}}


.ulGen2 {
	margin:10px 0 20px 30px;
	color:var(--CalcColour2);
}

.ulGen2>li {
	font-size:17px;
	letter-spacing:1px;
	line-height:150%;
	font-weight:400;
	color:var(--CalcColour2);
}

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

.italic {font-style:italic}

/* FORM */
input[type=text],textarea{
	width:100%;
	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:#666
}
	
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:#666
}

input[type=number]{
	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=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(--CalcColour2);
	margin:1px 0 15px 0;
	padding:6px 18px;
	border:1px solid var(--CalcButtonBorder);
	border-radius:8px;
	cursor:pointer;
	text-decoration:none;
	font-size:16px;
	color:#fff
}
	
input[type=submit]:hover{
	background:var(--CalcColour2);
	border:solid 1px #FFF;
	color:#fff
}

input[type="submit"].editButton {
	width: 250px;
	height: 40px;
	padding: 0 5px;
	margin-left: 30px;
	border: solid 1px #fff;
	background: url(edit-icon.png) var(--CalcColour2) no-repeat left;
	color: #fff;
	cursor: pointer;
}
input[type="submit"].editButton:hover {
	border: solid 1px #fff;
	background: url(edit-icon.png) var(--CalcColour4) no-repeat left;
	
	}

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}

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: 8ch}
	
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: 150px;
}

@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);
	border: solid 1px #fff;
	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; 
}

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

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

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

.calcColumnLabelRight{padding-left:unset}

.selectDD {
	width:240px;
	height:38px;
	font-size:13px;
    padding: 10px 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: #666;
}

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

.calc-container-outer {max-width: 1280px}
.calc-container {display:flex;width:100%}
.calc-container > div {margin: 2px;padding: 4px 5px}
.calcCol1{width:65%}
.calcCol2{width:35%}

.quote-container {
	display: flex;
	background-color:transparent;
	width:94%;
	margin:0 auto;
	padding:0 0 0 0;
	gap: 2px;
}
.quote-container > div {}

.quoteSectionHeading{width:100%;background-color:var(--ResultsSectionHeading);padding:4px 2px 4px 12px;margin: 2px 0 2px 0;}
.quoteCol1{width:60%;background-color:var(--ResultsLineItem);padding:4px 2px 4px 12px;margin: 2px 1px 2px 0;}
.quoteCol2{width:40%;background-color:var(--ResultsLineItem);padding:4px 2px 4px 20px;margin: 2px 0 2px 1px;}
.quoteCol3{width: 20%;background-color:var(--ResultsLineItem);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;
		margin:0 0 0 0;
		padding:0 0 0 0;
		gap: 0 20px;		
	}
	.quote-container > div {width:100%;margin:0}
	.quoteSectionHeading{width:97%;margin:0 auto;font-size:14pt;font-weight:700;padding:6px 5px 6px 10px;background-color:var(--ResultsSectionHeading);margin:0 0 3px 0}

	.quoteCol1{width:98%;margin:0 auto;font-size:13pt;font-weight:700;padding:3px 5px 0 12px;background-color:var(--ResultsLineItem)}
	.quoteCol2{width:98%;margin:0 auto;padding:0 5px 16px 20px;background-color:var(--ResultsLineItem)}
	.quoteCol3{width:98%;margin:0 auto;font-weight: 700; font-size: 16pt}
	}
}

.formError{color:#cc0000}
.bold{font-weight:700}

.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;
}

.calcFlowButtonDefault {
	background: var(--CalcColour2);
    margin: 1px 0 15px 0;
    padding: 6px 18px;
    border: 1px solid var(--CalcButtonBorder);
    border-radius: 8px;
    cursor: pointer;
    text-decoration: none;
    font-size: 16px;
    color: #fff;
}

.calcFlowButtonDefault:hover {
	background: var(--CalcColour4);
    border: 1px solid var(--CalcButtonBorderHover);
    color: #fff;
}

/* HELP INFO POPUPS START */


.imageInContentDiv{
	max-width:100%;
	padding:0;
	margin:0
	}

.thumbDisplayAll2,.thumbDisplayAll3{
	float:left;
	height:auto;
	margin:5px;
	z-index:1000
	}
	
.thumbDisplayAll2{
	width:47%;
	height:auto
	}
	
.thumbDisplayAll3{
	width:30%;
	height:auto
	}

img.thumbNail{
	width:100%;
	height:auto;
	cursor:zoom-in;
	margin:3px;
	box-shadow:5px 5px 5px #999
	}
	
img.thumbNail:hover{
	box-shadow:5px 5px 5px #666;
	opacity:.8
	}

figcaption,figcaption.set2,figcaption.set3{
	color:var(--LBCaptionColour);
	font-size:11pt;
	font-style:italic;
	padding:4px;
	text-align:center;
	font-weight:400;
	clear:left
	}
	
@media only screen and (max-width:575px){
	.thumbDisplayAll2{
		width:100%;
		height:auto
	}
	
	.thumbDisplayAll3{
		width:100%;
		height:auto
		}
		
	.thumbMobNo{
		display:none
		}
		
	img.thumbNail{
		width:95%;
		height:auto;
		cursor:zoom-in;
		padding-right:0
		}
		
	figcaption.set2,figcaption.set3{display:none}
}

/*
.lightBox{
	display:none;
	position:fixed;
	z-index:2000;
		padding-top:80px;  // removed on advice
	left:0;
	top:0;
	width:100%;
	height:100%;
	overflow:auto;
	background-color:rgba(0,0,0,.6);
		justify-content: center;  // added on advice
		align-items: center;  // added on advice
	
	
	}

.lightBoxDGH {
	display: none;
	position: fixed;
	z-index: 2000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.6);

	// Flexbox centering
	display: flex;
	justify-content: center;
	align-items: center;

	// Prevent scrollbars unless necessary 
	overflow: auto;
}

.lightBox-content{
	position:relative;
	margin:auto;
	margin-bottom:0;
	padding:0;
	padding-bottom:0;
	width:95%;
	max-width:800px
	}
*/
	
.faqBoxInOverlay {
	border:solid 2px #ccc;
	border-radius: 8px;
	padding: 5px 16px;
	background-color:#ccc
}	
	
.infoContent {color:#222;}
.infoContentTitle {color:#222;font-weight:700}

/*
@media only screen and (max-width:575px){
	.lightBox-content{
		position:relative;
		margin:auto;
		margin-bottom:0;
		padding:0;
		padding-bottom:0;
		width:100%;
		max-width:800px
		}
}

.closeButton{
	position:absolute;
	top:0;
	right:0;
	font-size:28px;
	color:#fff;
	font-weight:700;

	background-color:rgba(0,0,0,.5);
	background-color:#444;

	padding:0 10px;
	border-top:solid 2px #ccc;	
	border-right:solid 2px #ccc;	
	
	border-radius:0 7px 0 7px
	}
	
.closeButton:focus,.closeButton:hover{
	color:#666;
	text-decoration:none;
	cursor:pointer;
	background:#ccc;
	transition:.4s ease
	}

.mySlides{display:none}

.next,.prev{
	cursor:pointer;
	position:absolute;
	bottom:0;
	width:auto;
	padding:10px 16px;
	margin-top:-50px;
	color:#fff;
	font-weight:700;
	font-size:20px;
	transition:.6s ease;
	border-radius:0 7px 0 0;
	user-select:none;
	-webkit-user-select:none;
	text-decoration:none;
	background-color:rgba(0,0,0,.5)
	}

.next{
	right:0;border-radius:7px 0 0 0
	}
	
.next:hover,.prev:hover{
	background:#ccc;
	transition:.4s ease;
	color:#099}

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

h3.slideCaption{
	color:#fff;
	font-size:18px;
	top:0;
	left:0;
	position:absolute;
	font-weight:700;
	text-shadow:3px 3px 3px #000;
	padding:5 20 5 20;
	margin:0;
	border:solid 2px #000;
	background-color:rgba(0,0,0,.7)
	}

@media only screen and (max-width:575px){
	h3.slideCaption{
		padding:10px 20px 12px 20px;
		background-color:rgba(0,0,0,.7)
		}
}

img.slideOverlay{
	width:100%;
	height:auto;
	padding:0;
	margin:0
	}

A:link.largeImageLink,A:visited.largeImageLink{
	font-size:9pt;
	color:#099;
	text-decoration:none;
	text-align:center;
	margin:0 auto
	}
	
A:hover.largeImageLink{color:var(--col2)}

@media only screen and (max-width:575px){
	A:link.largeImageLink,A:visited.largeImageLink{
		color:var(--col1);
		text-decoration:none;
		text-align:center;
		margin:5 auto
		}
	
	A:hover.largeImageLink{color:var(--col2)}
}


/* HELP INFO POPUPS END */


/* Info Expander Control start */

.info-section {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.8s ease, opacity 0.8s ease;
	margin:0;
	padding:0 0 0 30px
}

.info-section.open {
	max-height: 1500px;
	opacity: 1;
}

@media (max-width:575px) {
	.info-section.open {
	height:auto;
	max-height: 2000px;
	opacity: 1;
	}
}

.websiteDetailsBox{
	margin: 0 150px 20px 10px;
	background-color: #eee;
	background-image:linear-gradient(to bottom right, rgba(24, 63, 102, 0), rgba(49, 107, 164, .1));
	padding: 5px 10px 5px 15px;
	border: solid 1px #183f66
	}
	
@media (max-width:640px){
	.websiteDetailsBox{
		margin: 5px 5px 30px 5px;
		padding: 5px 5px 5px 0;
		background-color: #fff;
		background-image:linear-gradient(to bottom right, rgba(24, 63, 102, 0), rgba(49, 107, 164, .2));
		border-right: solid 1px #333;
		border-bottom: solid 1px #333;
		height:auto;
		}
}

.heading,.heading2 {
	cursor: pointer;
	margin: 1px 0;
	line-height:180%;
	font-weight: bold;
	color: #22598f;
}

.heading:hover {color: #fba621}


.headingRow {
	display: flex;
	width:100%;
	padding:0
}

.headingRow>div {
	width:48%;
	margin:5px auto;
	padding:0px
}


.headingRowSingle {
	display: flex;
	width:100%;
	padding:0
}

.headingRowSingle>div {
	width:99%;
	margin:5px auto;
	padding:0px
}

@media (max-width:575px) {
	.headingRowSingle>div {width:100%}
}

/* Info Expander Control end */


/* Info modal start */
/*
.lightBox {
  display: none;
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.4);
  z-index: 9999;
}
*/

.lightBox {
  display: none;
  position: fixed;         /* Fixed covers the viewport */
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;           /* Full viewport height */
  background: rgba(0,0,0,0.4);
  z-index: 9999;
  overflow: auto;          /* Allows content to scroll if needed */
}

.lightBox-content {
	position: absolute;
	background: #fff;
	border:solid 1px #333;
	border-radius: 8px;
	padding: 5px 12px 10px 12px;
	color:var(--CalcColour2);
	width: 75vw;
	box-shadow: 4px 4px 10px rgba(0,0,0,0.5);
}

@media (max-width:575px){
	.lightBox-content {
		padding: 10px;
		width: 90vw;
		box-shadow: unset;
	}
}

.closeButton {
	position: absolute;
	top: 2px;
	right: 10px;
	font-size: 24px;
	cursor: pointer;
	color: #333;
}
.closeButton:hover {color: #f00}

/* Info modal end */




/* GLOBAL STYING */
.indented {margin-left:20px}
.indented0 {margin-left:0}
.indented10 {margin-left:10px}
.indented30 {margin-left:30px}
.indented45 {margin-left:45px}
.indented60 {margin-left:60px}
.indentedUl {margin-left:10px}
.italic {font-style:italic}
.bold {font-weight:700}
.bolded {font-weight:700}
.white {color:#fff}

@media screen and (max-width:575px) {
	.indentedUl {margin-left:0;padding-left:10px}
	.indented {margin-left:0}
	.indented0 {margin-left:0}
	.indented10 {margin-left:0;padding-left:10px}
	.indented30 {margin-left:10px}
	.indented45 {margin-left:10px}
	.indented60 {margin-left:0}
	ul.indented {margin-left:0;padding-left:5px}
	ul.indented>li {margin-left:0;padding-left:4px}
	ul.indented30, ul.indented45 {margin-left:8px;padding-left:13px}
}

.paymentPlanBox {
	border:solid 2px var(--CalcColour1);
	padding:10px 15px 20px 25px;
	width:94%;
	margin:0 auto;
	background-color:var(--CalcColour5)
}

.paymentPlanBoxDemoNotes {
	border: dotted 2px var(--CalcColour2); 
	margin:0 20px 20px 20px;
	padding: 10px 0 0 0;
	background-color:#fff
}

@media (max-width:575px){
	.paymentPlanBox {
	border:solid 2px var(--CalcColour1);
	margin:0 5px 20px 5px; 
	padding:10px 3px 20px 3px;
	background-color:var(--CalcColour5)
	}
}


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

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

