/*
Theme Name: Tealstone
Description: Unicon Child Theme
Author: Insight Designs
Author URI: https://insightdesigns.com
Template: unicon
Version: 1.1
*/

/*

/*
+++++++++++++++++++++
COLORS
+++++++++++++++++++++


Dark Blue			#224c66
Tealstone Blue		#4698ca
Bright Blue			#4698ca
Brightest Blue		#1795e2
Link Blue			#005B94
Light Gray			#f1f2f2
Footer Blue			#253746
Copy Blue			#042a3a
Dark Gray			#717481
Neon Green			#c4db21

*/



/*#############################################  
#############################################  FONTS
#############################################*/  

  @import url("https://use.typekit.net/qah1wby.css");



/*###############################################
SITEWIDE STYLES
###############################################*/

body :is(p, ul, li, h1, h2, h3, h4, h5, h6, a) {
  font-family: "avenir-lt-pro", sans-serif!important;
  font-weight: 400;
}

body {
	& .wpb_row,
	.wpb_content_element,
	ul.wpb_thumbnails-fluid > li,
	.last_toggle_el_margin,
	.wpb_button {
	    margin-bottom: 0px;
	}
}

body {
	& .vc_section.vc_section-has-fill,
	.vc_section.vc_section-has-fill+.vc_row-full-width+.vc_section,
	.vc_section.vc_section-has-fill+.vc_section{
		padding-top: 0;
	}
}

body h2 {
	font-weight: 200;
	margin-bottom: 7px;
}

body h3{
	font-weight: 500;
	margin-bottom: 7px;
}

body :is(h4, h5, h6){
	font-weight: 600;
	margin-bottom: 7px;
}

body blockquote{
	color: #8B8787;
	font-size: 24px;
}

body :is(h1 a, h2 a, h3 a, h4 a, h5 a, h6 a){
	color: #0066B2;
}

body #content .wpb_text_column a{
	font-weight: 600;
}

body{
	& a.button,
	input[type=submit],
	button,
	.minti_button,
	a.button.full,
	#navigation ul li.nav-button a,
	.vc_do_btn a.vc_general {
		font-family: "avenir-lt-pro", sans-serif!important;
	    position: relative;
	    display: block;
	    margin: 0;
	    padding: 10px 20px!important;
	    font-weight: 700!important;
	    font-size: 15px!important;
	    letter-spacing: 2px!important;
	    border: 1px #fff solid!important;
	    border-radius: 0!important;
	    text-transform: uppercase!important;
	    outline: 0;
	    overflow: hidden;
	    z-index: 1;
	    cursor: pointer;
	    transition: 0.3s ease-in;
	    -o-transition: 0.3s ease-in;
	    -ms-transition: 0.3s ease-in;
	    -moz-transition: 0.3s ease-in;
	    -webkit-transition: 0.3s ease-in;
	    width: max-content;
	    background:#224c66 !important;
	    color: #fff!important;
  
			&:hover{
			    color:#ffffff!important;
				}
				
			&:before{
				content: "";
				position: absolute;
				background: #4698ca;
				bottom: 0;
				left: 0;
				right: 0;
				top: 100%;
				z-index: -1;
				-webkit-transition: top 0.3s ease-in;
			}
			
			&:hover:before {
				top: 0;
			}
			
			&:after{
				content: "»";
				position: absolute;
				right: -12px;
				top: 10px;
				opacity: 0;
				transition: 0.3s ease-in;
			}
			
			&:hover:after{
				right: 7px;
				top: 9px;
				opacity: 1;
			}
	}
	


	& .vc_separator .vc_sep_line{
		border-color: #4698ca!important;
		border-width: 1px!important
	}
	
	& .medium-blue-font p{
		color: #4698ca!important;
		font-size: 36px!important;
		font-weight: 900!important;
	}
	
	& .big-blue-font p{
		color: #4698ca!important;
		font-size: 42px!important;
		font-weight: 900!important;
	}
	
	& .biggest-blue-font p{
	    color: #4698ca!important;
	    font-size: 160px!important;
	    font-weight: 900!important;
	    line-height: .8em;
	}


	& .big-gray-font p{
		color: #717481!important;
		font-size: 42px!important;
		font-weight: 900!important;
	}

	
	& .wpb_row .wpb_row .wpb_content_element {
	    margin-bottom: 0;
	}
	
	& .vc_pagination-color-grey.vc_pagination-style-outline .vc_pagination-trigger {
	    border-color: #224c66;
	    border-width: 2px;
	}
	
	& .vc_pagination-color-grey.vc_pagination-style-outline .vc_active .vc_pagination-trigger{
		background-color: #4698CB;
	}
	
	& .vc_row.wpb_row.display-inline-flex-row .button {
	    display: inline-flex;
	    margin-right: 5px;
	}
}

body .vc_do_btn a.vc_general:before{
	content: "";
	position: absolute;
	background: #224c66;
	bottom: 0;
	left: 0;
	right: 0;
	top: 100%;
	z-index: -1;
	-webkit-transition: top 0.3s ease-in;
}

body .vc_do_btn a.vc_general:hover:before {
	top: 0;
}
			
body .vc_do_btn a.vc_general:after{
	content: "»";
	position: absolute;
	right: -12px;
	top: 10px;
	opacity: 0;
	transition: 0.3s ease-in;
}
			
body .vc_do_btn a.vc_general:hover:after{
	right: 7px;
	top: 9px;
	opacity: 1;
}

body .secondary-btn.vc_do_btn a.vc_general {
    border: 1px solid #4698ca!important;
    background: #ffffff!important;
    color: #4698ca!important;
    padding-top: 10px!important;
    padding-bottom: 9px!important;
    margin: 0 5px;
}

body .secondary-btn.vc_do_btn a.vc_general:hover{
	color: #ffffff!important;
}


/*###############################################
HEADER STYLES
###############################################*/

body {
	& #logo img {
	    height: 55px;
	    width: auto;
	}
	
	& header#header {
	    box-shadow: none;
	}
		
	
	& header#header #navigation > ul > li > a {
	    border-left: 2px solid #d1d1d1;
	    font-family: "avenir-lt-pro"!important;
	    transition: .1s all ease-in-out;
	    padding: 2px 0px 2px 20px;
	    margin-left: 20px;
	    margin-right: 0px;
	    padding-bottom: 4px;
	    font-weight: 600;
	    text-transform: uppercase;
	    color: #005b94;
	    font-size: 15px;
		
			&:hover {
				  color:#1795e2;
			}
	
			&:after{
			    content: "»";
			    position: relative;
			    right: -12px;
			    top: -1px;
			    opacity: 0;
			    transition: 0.3s ease-in;
   			}
			
			&:hover:after{
				right: -5px;
				top: -1px;
				opacity: 1;
			}
	}
	
	& header#header #navigation > ul > li:first-child > a{
				border-left: none;
			}


	
	& #navigation ul li.nav-button a{
		margin-left: 15px;
		margin-top: -10px;
	}
	

	/* === Header logo and nav inline === */
	& .header-inner {
	  display: flex;
	  flex-wrap: nowrap;
	  align-items: center;
	  justify-content: space-between;
	}
	
	/* === Logo sizing === */
	& .logo img {
	  max-width: 230px;
	  height: auto;
	}
	
	/* === Nav item styling === */
	& #navigation > ul > li > a {
	  border-left: 1px solid #d1d1d1;
	  padding-left: 3px;
	  padding-right: 4px;
	  display: inline-block;
	}
	
}


/* === Force remove left border and any pseudo-elements from first nav item === */
/* #navigation > ul > li:first-child > a,
#navigation > ul > li:first-child > a::before,
#navigation > ul > li:first-child > a::after,
header#header #navigation > ul > li:first-child > a,
header#header #navigation > ul > li:first-child > a::before,
header#header #navigation > ul > li:first-child > a::after {
  border-left: none !important;
  background: transparent !important;
  box-shadow: none !important;
  content: '' !important;
  margin-left: 0 !important;
  padding-left: 3px !important;
  display: inline-block !important;
}
 */



/*###############################################
HOME STYLES
###############################################*/
body {
	& .five-row-plus .vc_col-sm-4.wpb_column, .five-row-plus .vc_col-sm-3.wpb_column {
	    width: 27.6%;
	    margin: 0 auto;
	}
	& .five-row-plus p {
	    line-height: 1.25em;
	    font-size: 17px;
	}
	
	& .row-no-margin{
		margin: 0!important;
	}
	
	& .blue-bg-box .wpb_column{
	    background: #224c66;
	    padding: 40px 70px!important;
	    min-height: 195px;
   	}
   	
   	& .blue-bg-box .vc_col-sm-4.wpb_column {
	    width: calc(33.33333333% - 1px);
	    margin: .5px;
	}

	& .vc_tta.vc_tta-o-no-fill.vc_tta-tabs-position-top .vc_tta-panel-body {
	    padding: 0px;
	}

}

.divider1 {
  clear: both;
  border-bottom: 1px solid #efefef70;
  width: 50%;
}

.faux-h2 p{
    font-size:20px;
    font-weight:500;
}

.row-values img{
    width:100px;
    height:auto;
}

.blue-block-text{
    background:#224a65;
    color:#ffffff;
    padding:8px 12px;
    border-bottom:5px solid #4698cb;
}

body .vc_general.vc_cta3.vc_cta3-color-classic.vc_cta3-style-flat {
    border: none;
}


/*###############################################
TESTIMONIALS BOX STYLES
###############################################*/
body {
	& .testimonials-box .col.span_12 .vc_col-sm-8 {
	    background: #f1f2f2;
		padding: 12px 30px 20px;
		margin-top: 0px;
	}
	
	& .testimonials-box .col.span_12 .vc_col-sm-8 .testimonial-slide{
	    text-align: left;
	    font-weight: 700;
	    font-size: 20px;		
	
		& span {
			font-size: 16px;
			font-weight: 500;
			color: #000000;
		}
	}
	
	
	
	& .owl-theme .owl-dots .owl-dot span{
		border-color: #224c66;
	}
	
	& .owl-theme .owl-dots .owl-dot.active span{
		background-color: #4698CB;
	}
	
	& .testimonials-box .col.span_12 .vc_col-sm-8 .quote-marker img{
		width: 120px;
		height: auto;
	}
	
	& .testimonials-box .col.span_12 .vc_col-sm-8 .quote-marker.vc_col-sm-3 {
	    position: relative;
	    z-index: 999999999;
	    top: -12px;
	    left: 50px;
	}
	
	& .testimonials-box .owl-theme .owl-controls{
		position: relative;
		left: -18%;
	}
}



/*###############################################
FOOTER STYLES
###############################################*/


body #footer .widget .menu a{
	opacity: 1;
    transition: .3s all ease-in-out;
    padding-bottom: 3px;
}

body #footer .widget .menu a:hover{
	opacity: .6;
}

body #footer {
    padding: 30px 0 40px 0;
 }

body #footer .widget h3 {
    font-family: 'Urbanist',Arial,Helvetica,sans-serif;
    font-size: 20px;
}

body #footer .widget ul li {
    border-bottom: 1px solid #42637e;
    position: relative;
    padding: 5px 5px 5px 0;
}

body footer .gallery dt.gallery-icon.landscape img {
    opacity: .6;
    max-height: 125px;
    width: auto;
}


body footer #gallery-1 .gallery-item {
    padding: 2px;
	margin-top: 10px;
    text-align: center;
}

body footer #gallery-1 {
	margin: auto;
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	grid-template-rows: repeat(3, auto);
	align-items: center;
	gap: 5px 15px;
}

body footer #gallery-1 .gallery-item {
    padding: 2px;
	margin-top: 10px;
    text-align: center;
}

/* Row 1: 4 columns - items 1-4 */
body footer #gallery-1 .gallery-item:nth-child(1) {
	grid-column: 1 / span 3;
	grid-row: 1;
}
body footer #gallery-1 .gallery-item:nth-child(2) {
	grid-column: 4 / span 3;
	grid-row: 1;
}
body footer #gallery-1 .gallery-item:nth-child(3) {
	grid-column: 7 / span 3;
	grid-row: 1;
}
body footer #gallery-1 .gallery-item:nth-child(4) {
	grid-column: 10 / span 3;
	grid-row: 1;
}

/* Row 2: 4 columns - items 5-8 */
body footer #gallery-1 .gallery-item:nth-child(5) {
	grid-column: 1 / span 3;
	grid-row: 2;
}
body footer #gallery-1 .gallery-item:nth-child(6) {
	grid-column: 4 / span 3;
	grid-row: 2;
}
body footer #gallery-1 .gallery-item:nth-child(7) {
	grid-column: 7 / span 3;
	grid-row: 2;
}
body footer #gallery-1 .gallery-item:nth-child(8) {
	grid-column: 10 / span 3;
	grid-row: 2;
}

/* Row 3: 3 columns - items 9-11 */
body footer #gallery-1 .gallery-item:nth-child(9) {
	grid-column: 4 / span 3;
	grid-row: 3;
}
body footer #gallery-1 .gallery-item:nth-child(10) {
	grid-column: 7 / span 3;
	grid-row: 3;
}
/*
body footer #gallery-1 .gallery-item:nth-child(11) {
	grid-column: 8 / span 3;
	grid-row: 3;
}
*/

body footer #gallery-1 br{
	display: none;
}

body footer div#gallery-1 {
    margin-top: -12px;
} 

body footer #gallery-1 img {
	border: 2px solid #cfcfcf;
}

body footer #gallery-1 .gallery-caption {
	margin-left: 0;
}

body .widget_contact address span {
    line-height: 1.4;
}

body .widget_contact address span i {
    margin: 3px 0 0px 0;
}

body .container .eight.columns:first-child {
    width: 27%;
}

body .container .eight.columns:last-child {
    width: 65%;
}

#footer .widget {
    margin-bottom: 0px!important; 
    margin-top: 30px;
}

#copyright .copyright-text {
    font-size: 16px;
}

/*###############################################
TITLE FONT & BREADCRUMB STYLES
###############################################*/

body #fullimagecenter {
	min-height: 360px;
    position: relative;

    & #fullimagecenter-overlay {
	    background: linear-gradient(135deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 50%);
        min-height: 360px;
    }
    
    & .header-vertical-center {
        top: 50%;
        position: absolute;
        width: 100%;
    }

    & .img-title-header {
        width: 100%;
        align-items: center;
        transform: translateY(-50%);
        text-align: left;

        & .outline-font{
            text-shadow: none;
        }
        
        & svg.outline-font {
            width: auto!important;
            height: 55px!important;
        }

        & p.header-white-font {
            color: #ffffff;
            font-size:50px;
            text-transform: uppercase;
            font-weight: 900 !important;
            line-height: 1;
            padding-bottom: 5px;
            margin-bottom: 2px;
        }

        & p.blue-bg-text {
            color: #ffffff;
            background-color: #4698ca;
            width: max-content;
            padding: 5px 10px;
            margin-bottom: 2px;
            font-size: 22px;
            text-transform: uppercase;
            line-height: 1em;
        }
	
    }
	
}

body {
	
	& #fulltitle #title {
		display: none;
	}
	
	& #breadcrumbs {
	    text-align: left;
	    text-transform: uppercase;
	    font-weight: 600 !important;
	    color: #717481;
	    font-family: 'avenir-lt-pro';
	    background: #f1f2f2;
	    padding: 7px 0;
	    margin-top: 0px;
	}
	
	& #breadcrumbs a{
		color: #005B94;
		font-weight: 600!important;
	}
	
	& div#fulltitle.titlebar {
	    padding: 8px 0px;
	    border-bottom: none;
	    background: #f1f2f2;
	}
	
}



/*###############################################
GIVING BACK SECTION
###############################################*/


/* Optional divider if you use it elsewhere */
body .divider1 {
  clear: both;
  border-bottom: 1px solid #efefef70;
  width: 50%;
}

/* Row container */
body .highlight-stats-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* keeps boxes centered if wrapping */
  overflow: visible;       /* allow hover lift without clipping */
}

/* Individual stat box */
body .highlight-box {
  width: calc(33.33% - 30px);
  margin: 0 15px;
  background-color: #3498db;   /* your brand blue */
  color: #fff;                 /* base text color for everything inside */
  border-radius: 8px;
  text-align: center;
  display: inline-block;
  vertical-align: top;
  padding: 40px 20px;          /* top/bottom, left/right */
  box-sizing: border-box;
  min-height: 200px;           /* same height for all boxes */
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

body .highlight-box:hover {
  transform: translateY(-5px); /* subtle lift */
  box-shadow: 0 8px 20px rgba(0,0,0,0.2);
}

/* Stack boxes on mobile */
@media (max-width: 768px) {
body .highlight-box {
    width: 90%;
    margin: 15px 5%;
    min-height: auto; /* let them grow naturally if needed */
  }
}

/* Big number styling */
body .stat-number {
  color: #fff;            /* FORCE white text so theme color doesn't override */
  font-size: 64px;
  font-weight: bold;
  line-height: 1.1;
}

/* Label text below number */
body .stat-label {
  color: #fff;            /* ensure label stays white too */
  font-size: 16px;
  line-height: 1.4;
  display: block;
  margin-top: 10px;
  font-weight: 300;
  letter-spacing: 1px;
}



/*###############################################
Gravity Forms STYLES
###############################################*/


/*********************/
/* RESPONSIVE STYLES */
/*********************/

@media screen and (max-width:1200px) {

}

@media screen and (max-width: 1000px) {

}

@media screen and (max-width: 960px) {

}

@media screen and (max-width: 959px) {

}

@media screen and (min-width:1px) and (max-width: 767px) {
	body {
		& .logo img {
		    height: 65px;
		    width: auto;
		}
	
		&.vc_responsive .page-section .standard-section .span_12 {
		    max-width: 100vw;
		}
	
		& .wpb_column.vc_column_container.vc_col-sm-1\/5 {
		    padding-left: 20px;
		    padding-right: 20px;
		}
		
		& .container{
			width: 100vw;
		
				& .one.column,
				.one.columns,
				.two.columns,
				.three.columns,
				.four.columns,
				.five.columns,
				.six.columns,
				.seven.columns,
				.eight.columns,
				.nine.columns,
				.ten.columns,
				.eleven.columns,
				.twelve.columns,
				.thirteen.columns,
				.fourteen.columns,
				.fifteen.columns,
				.sixteen.columns,
				.one-third.column,
				one-third.columns,
				.two-thirds.column,
				.two-thirds.columns {
					    width: 90vw;
					    margin: auto 5vw;
				}   
		}
		
		& .testimonials-box .owl-theme .owl-controls{
			position: relative;
			left: -0%;
		}
		
		& .biggest-blue-font p,
		.safety-rating h4{
			text-align: center;
		}
		
		& footer .container .eight.columns{
			width: 90vw!important;
		}
		
		& .intro-text .single_image img.attachment-full {
		    width: 70%;
		    height: auto;
		    text-align: center;
		}
		
		& .testimonials-box .col.span_12 .vc_col-sm-8 .quote-marker.vc_col-sm-3 {
		    left: 0px;
		}
		
		& .blue-bg-box .vc_col-sm-4.wpb_column {
		    width: calc(100% - 1px);
		    margin: 1px;
		}
		
		& .mobile-htag-center h2{
			text-align: center;
		}
		
		& .mobile-htag-center .vc_sep_pos_align_left {
		    margin-left: auto;
		    margin-right: auto;
		}
		
		& .secondary-btn.vc_do_btn a.vc_general {
		    display: flex;
		    flex-wrap: wrap;
		    width: 97%;
		}
		
		& a.button, input[type=submit], button, .minti_button, a.button.full, #navigation ul li.nav-button a, .vc_do_btn a.vc_general {
		    width: auto;
		    white-space: break-spaces;
		}
		
		& .five-row-plus .vc_col-sm-4.wpb_column, .five-row-plus .vc_col-sm-3.wpb_column {
		    width: 98%;
		    margin: 0 auto;
		}

	}
}













