@charset "UTF-8";
@font-face {font-family: Balto-L; src: url(Balto-Light.woff2) format("woff2"), url(https://www.red-ochre.com/assets/Balto-Light.woff) format("woff");font-display:swap;}
@font-face {font-family: Balto-B; src: url(Balto-Book.woff2) format("woff2"), url(https://www.red-ochre.com/assets/Balto-Book.woff) format("woff");font-display:swap;}
@font-face {font-family: Balto-M; src: url(Balto-Medium.woff2) format("woff2"), url(https://www.red-ochre.com/assets/Balto-Medium.woff) format("woff");font-display:swap;}
@font-face {font-family: Balto-Bo; src: url(Balto-Bold.woff2) format("woff2"), url(https://www.red-ochre.com/assets/Balto-Bold.woff) format("woff");font-display:swap;}


/* cleaning code 28.01.24 */
:root {font-size:85%;}
html { height: 100%;}
header, section, footer, aside, nav, main, article, figure {display: block; }
body {
	margin: 0;
	font-family:'Balto-B', Arial, sans-serif;
	background-color: #0a0e10;
  	color: #a3a3a3;
	min-height: 100%;
	margin-bottom: -15px;
	scroll-behavior: smooth;
}

#RO {margin-left: auto; margin-right: auto; max-width: 1600px;} /* Defines the constraints of the main portion of the page. */

nav, main, footer {padding: 0 50px; max-width: 100%; background-color: #141b1f;}

a {outline: 0;}

/* #myTopnav {} #myTopnav is an ID for the responsiv header.*/

.topnav {display: block;overflow: hidden; padding-top: 3rem;text-decoration: none;  font-family: 'Balto-B'; font-size: 1rem; line-height: 1rem;}
.topnav .icon {display: none;} /* Hide the link that should open and close the topnav on small screens */

/* Style the links inside the navigation bar */
.topnav a:hover {display:inline-block;color: white; text-decoration: none;}/* Change the style of links on hover */

/* Style the links inside the left side of navigation */
.nav_left a {float: left;color: #a3a3a3;text-decoration: none;margin-left:45px;}
.nav_left p{ float: left; color: white; margin-left:45px;}
.nav_left_first{margin-left: 5px!important;}

/* Style the links inside the right side of navigation */
.nav_right_img {float: right;}
.nav_right_img img {max-width: 20px;}
.nav_right_img a{margin-left: 22px;}


/* Navigation overlay start */
.RO_overlay {
	height: 0%;
	width: 100%;
	position: fixed;
	z-index: 1;
	top: 0;
	left: 0;
	background-image:linear-gradient(to bottom, rgba(20,27,31,1), rgba(20,27,31,0.9));
	overflow-y: hidden;
	transition: 0.5s;
}

.RO_overlay-content {position: relative; top: 25%; width: 100%; text-align: center; margin-top: 10px;}
.RO_overlay a {padding: 6px;text-decoration: none;color:#535252; font-family:'Balto-M'; font-size:2rem; display: block;transition: 0.3s;}
.RO_overlay-content a {font-family:'Balto-Bo';color:#a3a3a3;}
.RO_overlay-content a:hover, .overlay-content a:focus {color: #B52015;}
.RO_overlay .closebtn {position: absolute;top: 11px;right: 20px; font-size: 40px;}
.RO_overlay_social {margin-top: 15%;}
.RO_overlay_social a  {font-size:1.5rem;}
/* Navigation overlay end */


/* W3 school version - Scroll to top */

#myBtn {
	display: none;
	position: fixed;
	bottom: 15%;
	right: calc((100% - 1677px) / 2);
	z-index: 99;
	border: none;
	outline: none;
	color: #a3a3a3;
	background-color:rgba(20, 27, 31, 0);
	cursor: pointer;
	padding:0px;
	/* margin-bottom: 10px; */

  }
.scrollUp_Btn {
	transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
	display: inline-flex;
	/* text-align: center; */
}

  .ScrollButton_arrow {font-size: 0.9rem; line-height: 1;}

  .ScrollButton_arrow::before {
	content: "\27F5"; 
	font-size: 1.6rem; 
	margin-right: 0.35em;
	vertical-align: -8%;
  }

	#myBtn:hover {
	background-color:rgba(20, 27, 31, 0);
	color: white;
  }

/* End of naviation styling. */

.hr_main {
	display: block;
	max-width: 1600px;
	height: 1px;
	border: 0;
	border-bottom: 1px solid #535252;
	margin-block-start: 0;
	margin-block-end: 0;
}

.hr_main_pad {
	display: block;
	padding-bottom: 3rem;
	max-width: 1600px;
	height: 1px;
	border: 0;
	border-top: 1px solid #535252;
	margin-block-start: 0;
	margin-block-end: 0;
}


p {font-family: 'Balto-B'; font-size:1rem; margin: 0; color:#a3a3a3; margin-bottom: 1.5rem;}
p:last-of-type{margin-bottom: 0rem;}

p a {text-decoration: none;}
p a:hover {color: white; text-decoration: none;}

.p_margin {margin-left: 40px;margin-right: 40px;}

#myStraplineText {display: block;height:14.1rem;} /* Creates the space for the animated text. */
#RO_logo{padding-left: 40px; padding-right: 40px; margin-top: 1.5rem; margin-bottom: 1.5rem;}
.RO_Headline{color:#B52015; font-family:'Balto-Bo'; font-size:2.8rem; line-height:2.2rem; padding-top: 3rem; margin:0;} /*H1 - Headline bold.*/

.logo_strap {color:#a3a3a3; font-family:'Balto-L'; font-weight: normal; font-size:3.6rem; line-height:3.6rem; margin:0;}/* H1 - Animated strapline in Secondary font.*/
.RO_Secondary{color:#B52015; font-family:'Balto-Bo'; font-size:1.5rem;line-height:1.5rem; margin:0;}/* H2 - Headline bold title. */
.cat_strap{color:white; font-family:'Balto-B'; font-size: 1.2rem; line-height:1.2rem; font-weight: normal; margin:0; padding-bottom: 0.5rem;}/* H3 - - White category subheading. */
.cat_strap_m{color:white; font-family:'Balto-B'; font-size: 1.2rem; line-height:1.2rem; font-weight: normal; margin:0; padding-bottom: 0.5rem;}/* H3 - - White category subheading. */
.Strapline {font-family: 'Balto-B'; font-weight: normal; font-size:1rem; margin: 0 0 0 0; color:#a3a3a3; padding: 3rem 0;}

#RO_quote{margin-top: 2rem; margin-bottom:0; }
.R-O_logo {height:2rem; padding-right: 8px;}

.RO_red {color:#B52015;}

.Hero_text_links{ 
	width: 100%;
	display: flex;
	justify-content: space-between;
	float: left;
	text-decoration: none;
	font-family: 'Balto-B';
}

.Hero_text_block p { padding-bottom:2rem; color:#a3a3a3; font-family:'Balto-L'; font-weight: normal; font-size:3rem; line-height:2.8rem; margin:0;} 
.Hero_text_block p:last-of-type { padding-bottom:0;}
.Htb_pad{padding: 3rem 0;}

.Hero_block_third a, .Hero_link_third_right a, .Hero_link_third_left a {color: #a3a3a3; font-size:1rem; text-decoration: none; padding: 0 18px 0 0;}
.Hero_block_third a:hover, .Hero_link_third_right a:hover {color: #fff;}

.red_block_third  a, .red_block_full a {color: #fff; font-size:1rem; text-decoration: none; display: block; height: 100%; width: 100%;} 
.red_block_third  a:hover, .red_block_full a:hover  {color: #fff;}

.link-arrow {background-repeat:no-repeat; 
	background-size:100%;
	background-image:url("assets/arrow_white.svg");
	background-position:top 3px right;
	background-size:14px 10px;
	display:inline-block;
}

.RO_Footer_Heading{color:#B52015; font-family:'Balto-B'; font-weight: normal; font-size: 1rem; margin:0;}
.bottom-pad {padding-bottom: 3rem;}
.p_pad {padding: 3rem 0;}
.p_pad_bottom {padding-bottom:3rem;}

/* .full_width_text p {margin-bottom: 2rem; padding-bottom: 0;} */
.full_width_text p:last-child {margin-bottom: 0rem;}
.full_width_text p a {font-weight: 600; color:#a3a3a3;}
.full_width_text p a:hover {color:white;}

ul{ color:#a3a3a3; padding:0; margin:0 0 1rem 20px; font-size: 1rem; line-height: 1.2rem;}

.flex_container {
 	display: flex;
 	flex-wrap: wrap;
 	flex-direction: row;
  	align-content:flex-start;
  	justify-content:space-between;
	padding-bottom: 3rem;
}
/* flex text used in Services */
.flex_cont_text {
  	display: flex;
 	flex-wrap: wrap;
  	flex-direction: row;
  	align-content:flex-start;
  	justify-content:space-between;
	padding-bottom: 3rem;
}

.flex_full_width {max-width:100%; margin: 0px; padding-bottom: 1%;} /* if three thirds */
.flex_third {max-width: 32.5%; margin: 0px;padding-bottom: 0.9%;} /* if a third and two thirds */
.flex_1third {max-width: 33.5%; margin: 0px;padding-bottom: 0.9%;} /* img 865x537 works for even margins */
.flex_2thirds {max-width: 66.25%; margin: 0px;padding-bottom: 0.9%;}

.flex_container p:last-child { margin-bottom:0;}
/*.flex_container img {margin-bottom: -3px;}  why do we need this? I don't think we do*/ 
.image-container img {padding-bottom:0px;} /* fixing the slider images misaligning */

.f_3_text {width: 32.5%; color:#a3a3a3;}

.columns_3 {column-count: 3; column-gap: 18px; padding-bottom: 3rem; column-fill: balance;}

.flex_portrait_text {
	justify-content:left;
}
.Portrait_third {width: 32.5%; justify-content:center;}
/* .Portrait_third p, H3 {margin-left: 2%;} */
.Portrait_2thirds {max-width: 66.5%;}
.Potrait_Name {color:#B52015; font-family:'Balto-B'; font-size:1rem;line-height:1rem; margin:0;}/* H2 - Headline bold title. */
.mySlides1, .mySlides2, .mySlides3 {width: 100%;}
/* .mySlides1, .mySlides2, .mySlides3 {width: 80%; padding:10%; border: 1px solid #535252;} */

.red_block_third {width: 32.5%; height:50px; margin: 0 0 2rem 0; color:#a3a3a3;  background-color:#B52015; text-align: center; vertical-align: middle; line-height: 50px;}
.red_block_full {width: 100%; height:50px; margin: 0; color:#a3a3a3;  background-color:#B52015; text-align: center; vertical-align: middle; line-height: 50px;}
.Hero_block_third {width: 32.5%; height:10px; margin: 0; padding: 0px 0px 10px 0px; color:#a3a3a3;}
.Hero_link_third_right {width: 32.5%; line-height: 15px; color:#a3a3a3; margin-top: 35px; text-align: right;}
.Hero_link_third_left {width: 32.5%; line-height: 15px; color:#a3a3a3; margin-top: 0px; text-align: left;}
/* link underline border-bottom: 1px solid #535252; */

.top_border {border-top: 1px solid #535252; width:100%}
.top_bottom_border {border-top: 1px solid #535252; border-bottom: 1px solid #535252;width:100%}

.no_B_pad {padding-bottom: 0;}

.Jotform_container {
	align-content: flex-start;
	background-color: #141b1f;
	display: flex;
	display: -webkit-flex; /* Safari */
	flex-wrap: wrap;
	flex-direction: row;
	align-content:flex-start;
	justify-content:space-between;
	padding: 0px;
	margin:-20px -12px 0 -12px;
}

.contact_thank_you {padding:9rem 0 15rem 0}

#Footer{color: white; padding-bottom: 0rem;}

footer a, footer p {color: #a3a3a3;
	text-decoration: none;
	font-family: 'Balto-B';
	font-size: 1rem;}
	
footer a:hover {color: white;}
	
.footer_flex {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	align-content:flex-start;
	justify-content:space-between;
	padding-bottom: 3rem;
}
	
	.foot_unit_L {width: 51%; margin: 0px; padding-bottom: 1rem;}
	.foot_unit_R {width: 49%; margin: 0px;padding-bottom: 1rem;}
	.foot_unit p {padding: 0;}
	.foot_left {display: flex; max-width: 32.5%; float: left; width:100%;}
	.foot_right {display: flex; max-width: 66.5%; float: left; width:100%;}
	/* .footer_third {width: 32%;} */
	.footer_social_img  {display: flex; max-width: 100%; float: left; width:100%; margin-bottom:0; padding-bottom: 0;}
	.footer_social_img a {float: left;display: block; margin: 0 22px 1rem 0px;}
	.footer_social_img img {max-width:20px;}

	#Footer .R-O_logo {padding-bottom: 0px;}

/* Footer boxes order*/
	/* Safari 6.1+ */
	div#careers_footer  	{-webkit-order: 1; order:1;}
	div#media_footer 		{-webkit-order: 2; order:2;} 
	div#phone_footer		{-webkit-order: 3; order:3;}
	div#social_footer 		{-webkit-order: 4; order:4;}
	div#address_footer 		{-webkit-order: 5; order:5;}
	div#blank_footer 		{-webkit-order: 6; order:6;}


.clear {clear: both;}
.privacy {width:50%;}
.privacy a {font-size:1rem;}
.copyright {font-size: .8rem; line-height:1rem; padding: 0 0 3rem 0; max-width:250px;}


/* RESPONSIVE !!!!! */

/* When the screen is less than 1600 pixels wide, 'Scroll to top' button needs to adjust */
@media screen and (max-width: 1599px){ #myBtn {right: -40px;}

}

/* When the screen is less than 1050 pixels wide, shrink the image bottom margin */
@media screen and (max-width: 1050px){
.flex_container img {padding-bottom: 1px;}  /* why??? don't think we need it*/
.image-container img {padding-bottom:0px;} /* fixing the slider images misaligning */
.flex_third, .flex_1third, .flex_2thirds {padding-bottom: 0.75%;}
}

/* When the screen is less than 910 pixels wide, shrink the image bottom margin */
@media screen and (max-width: 910px){
	nav, main, footer {padding: 0 25px;}
	.image-container img {padding-bottom:0px;} 
	.R-O_logo {height:1.5rem; padding-right: 6px;}
	.RO_Headline{font-size:2.1rem; line-height:2.1rem;}
	.copyright p{font-size: 1rem;}
	.copyright {max-width:180px;}
	#myBtn {right: -50px;}
	}

/* When the screen is less than 842 pixels wide, fixing Jotform box spacing  */
@media screen and (max-width: 842px) {
	.ScrollButton_arrow { font-size: 1rem;}
	}


/* When the screen is less than 770 pixels wide, minimise the image bottom margin (used to be 800)  */
@media screen and (max-width: 770px) {
	.main {width: 80%;}
	.flex_container img {padding-bottom: 1px;}  /*why??? */
	.image-container img {padding-bottom:0px;} /* fixing the slider images misaligning */
	.contact_thank_you {padding:6rem 0 12rem 0}

	.footer_notices {display: flex; flex-direction: column;} /* putting the two notices in a box and shifting alignment to left */
	.privacy {order: 1;} 
	.copyright {order: 2;}
	.copyright p {float: left; font-size: 1rem;}
}

/* When the screen is less than 650 pixels wide, the smallest size. Used to be 568*/
@media screen and (max-width: 650px){
	.nav, .main, .footer {padding: 0 25px;}
	/* padding was 20px */
		.nav_left a {display: none;}
		.nav_left p {display: none;}
		.nav_left hr {display: none;}
		.nav_right {display: none;}
		.nav_right_img {display: none;}
		.hide_mobile {display: none;}

		#RO_logo{margin-top: 2rem;}

		.topnav a.icon {
	    	float: right;
	    	display: block;
			padding: 30px 30px 15px 15px;
			margin: 0px 0px -15px -15px;
      		position: absolute;
      		right: 0;
      		top: 0;
			color: #535252;
	  }
		.topnav a:hover {display:inline-block;}
		.topnav.responsive {position: relative;padding-left: 0px;padding-right: 0px;}
		.topnav.responsive .icon {position: absolute;right: 0;top: 0;}

		#myBtn {right: -46px;}
		.ScrollButton_arrow {font-size: .9rem;}
		.ScrollButton_arrow::before {font-size: 1.5rem; vertical-align: 0%;}

		p {font-size:1.1rem; line-height:1.3rem ;}
		p:last-of-type{margin-bottom: 1.5rem;}
		#myStraplineText {height:8rem;}
		#RO_logo, #RO_quote {margin-top: 1.5rem;}
		.RO_Headline{font-size:2.1rem; line-height:2.1rem; padding-top:2rem;}
		.logo_strap{font-size:2.1rem; line-height:2.1rem;}
		.Strapline {padding: 2rem 0;}
		.RO_Secondary{font-size:1.3em;}
		.cat_strap{font-size: 1.2em;padding-bottom: .5rem;}
		.cat_strap_m{font-size: 1.2em;padding-bottom: .5rem;}
		.RO_Footer_Heading{font-size: 1em; line-height:1rem;}
		.RO_last_P p {margin-bottom: 0;} 
		.RO_Headline_pad {padding-top: 2rem;}
		.R-O_logo {height:1.5rem; padding-right: 6px;}
		.bottom-pad {padding-bottom: 2rem;}
		.p_pad_bottom_heavy {padding-top: 1.4rem; padding-bottom: 2rem;}
		.p_pad {padding:2rem 0;}
		.p_pad_bottom {padding-bottom:2rem;}
		
		.flex_container > div {max-width: 600px; }	/* justify-content: center; */
		.flex_third, .flex_double, .resize  {max-width: 100%}
		/* .flex_third {padding-bottom: 0;} */
		.flex_container, .columns_3 {padding-bottom: 2rem;}
		.flex_container img {padding-bottom:12px;}
		.image-container img{padding-bottom:0px;}
		.last_img {padding-bottom:0px;}
		.last_img img:last-of-type{padding-bottom:0px;}

		.flex_cont_text {display:block; padding-bottom: 0;}

		.f_3_text {width: 100%; padding-bottom: 0.5rem;}
		.f_3_text p{line-height: 1.3rem;}

		.columns_3 {columns: 1; column-width: 100%; padding-bottom: 2rem;}
		#Blank_space {display: none;}
		.R_no_B_pad {padding-bottom: 0;}
	
		.full_width_text {margin-bottom: 2rem;}
		.Portrait_third {width: 100%; padding-bottom:12px;}
		.Potrait_Imgs .mySlides3{padding-bottom:12px;}
	
		.shrink {height: 250px;}

		ul{font-size: 1.1rem; line-height: 1.3rem;}

		.Hero_text_block p{ font-size:2.1rem; line-height:2.1rem; padding-bottom: 2rem; margin:0;}
		.Hero_text_block p:last-of-type { padding-bottom: 0; margin:0;}
		.Htb_pad{padding: 0 0 2rem 0;}
		.Hero_text_links {flex-wrap:wrap; text-align: center;}
		.Hero_block_third {width: 100%;}
		.red_block_third {font-size:1.1rem;width: 100%;}
		.Hero_link_third_right {font-size:1.1rem; width: 100%; line-height: 15px; color:#a3a3a3; margin-top: 35px; text-align: left;}
		.Hero_link_third_left {font-size:1.1rem; text-align: left;}
		.Hero_block_third a, .Hero_link_third_right a, .Hero_link_third_left a,.red_block_third a, .red_block_full a, .footer_p {font-size:1.1rem;}

		#disclaimer {font-size: 1.1rem; padding: 0px 10px 5px 10px;}
		#Footer, #Footer a {font-size: 1.1rem;}
		.foot_unit_L {width: 51%; padding-bottom: 1.5rem;}
		.foot_unit_R {width: 49%; padding-bottom: 1.5rem;}
		.foot_left {width: 50%; padding-bottom: 1rem;}
		.foot_right {width: 100%; padding-bottom: 1rem;}
		.footer_flex {padding-bottom: 1rem;}
		.footer_social_img a {margin:0 22px 5px 0}
		.blank_foot_unit {display: none;}
		.p_margin {margin-left: 20px;margin-right: 20px;}
		.copyright {max-width:50%; line-height: 1rem; padding: 0;}

		.hr_main_pad {padding-bottom: 2rem;}

		.R_no_T_border {border-top: 0px;}
		.R_no_B_border {border-bottom: 0px;}		

	/* Footer boxes order*/
	/* Safari 6.1+ */
		div#careers_footer  {-webkit-order: 1;order: 1;}
		div#media_footer 	{-webkit-order: 2;order: 2;}
		div#phone_footer	{-webkit-order: 3;order: 3;}
		div#social_footer 	{-webkit-order: 4;order: 4;}
		div#address_footer 	{-webkit-order: 5;order: 5;}
		div#Company_footer 	{-webkit-order: 6;order: 6;}
	}

	@media screen and (max-width: 410px) {
		#myStraplineText {height:9rem;}
		.RO_Headline{ font-size:2.4rem; line-height:2.5rem;}
		/* .R-O_logo {height:1.68rem; padding-right: 6px;} */
		.logo_strap{ font-size:2.4rem; line-height:2.5rem;}
		/* .RO_Secondary{ font-size:1.5rem;} */

	.form-section.page-section {
    border-bottom : none !important;
    border-top : none !important;
    box-shadow : none !important;}
	}

/* When the screen is less than 523 pixels wide, fixing Jotform box spacing  */
@media screen and (max-width: 523px) {
	.Jotform_container {margin: -45px -12px 0 -12px;}
}
