/*
Theme Name: Cates
Template: generatepress
Author: WPSiteHelper
Author URI: https://www.wpsitehelper.com
Description: This is a child theme of the GeneratePress framework, customized for Cates Control Systems by WPSiteHelper.
Tags: two-columns,three-columns,one-column,right-sidebar,left-sidebar,footer-widgets,blog,e-commerce,flexible-header,full-width-template,buddypress,custom-header,custom-background,custom-menu,custom-colors,sticky-post,threaded-comments,translation-ready,rtl-language-support,featured-images,theme-options
Version: 3.0.2.1613457590
Updated: 2025-06-22 00:37:50
*/

/*
 * 1. ROOT SELECTORS
 * 2. THEME
 * -Typography
 * -Colors
 * -Header
 * -Navigation
 * -Footer
 * -Overrides
 * 3. CUSTOM CLASSES
 * -Pages
 * -Layouts
 * -Components
 * 4. UTILITIES
*/


/* 
 * 1. ROOT SELECTORS
 * _______________________________ */
:root {
	/*--light-gray: #ededed;
	--cates-blue: #0084C7;
	--light-blue:  #008fd2;
	--dark-blue: #006187;
	--button-hover: #1a90cd;
	--button-active: #0077b3; */
	--white: #ffffff;
	--black: #000;
	--round-borders: 8px;
	--button-padding-med: 8px 24px;
	--button-padding-lg: 16px 32px;
	--base-font-size: 20px;

	--btn-box-shadow: 0 12px 22px -10px rgba(0, 0, 0, 0.6);
	--btn-box-shadow-hover: 0 6px 8px -2px rgba(0, 0, 0, 0.6);
}

/* -------------------
 * Selector defaults
 * ------------------- */
.content-area :not(.gb-block-image) > img {
	/*max-width: 100%;*/
	/*height: auto;*/
	object-fit: cover;
	display: inline-block;
	margin-block: 1rem;
}



/* 
 * 2. THEME
 * Typography, Colors, Header, 
 * Navigation, Footer, Overrides
 * _______________________________ */

/* ___Main Header___ */
/* header background gradient */
.site-header,
#sticky-navigation,
#mobile-header .inside-navigation {
	/* background-image: linear-gradient(180deg, rgba(204, 204, 204, 0.1) 20%, rgba(204, 204, 204, 1) 100%); */
	/* background-image: linear-gradient(180deg, rgba(255, 255, 255, 1) 20%, rgba(204, 204, 204, 1) 100%); */
	background-image: linear-gradient(180deg, var(--white) 20%, var(--neutral-light) 100%);
	max-width: unset;
}
#sticky-navigation {
    padding-inline: var(--section-padding-x);
}
#sticky-navigation .main-nav {
    margin: 0;
}
#mobile-header .inside-navigation {
    padding-inline: var(--section-padding-x);
}
.mobile-header-navigation .site-logo.mobile-header-logo {
    margin: 0;
}
#mobile-header.main-navigation.has-branding .menu-toggle {
    padding: 0;
}
.main-header-container {
	border-bottom: 5px solid;
	position: sticky;
	top: 0;
	z-index: 9;
	overflow: visible !important;
}
.gb-button-main-banner-button {
	font-style: oblique;
	max-width: 33vw;
}
@media all and (max-width:768px) {
	.gb-button-main-banner-button {
		max-width: 90vw;
	}
}
.gb-button-main-banner-button:hover {
	cursor: pointer;
}


/* ___Main menu___ */
#menu-main-menu {
	display: flex;
	width: 100%;
	justify-content: flex-start;
}
.main-navigation ul {
	list-style: none;
	margin: 0;
	padding-left: 0;
}
/*.main-navigation li {
float: none;
position: unset;
display: flex;
flex-grow: 1;
}*/
.main-navigation a, .menu-toggle {
	font-family: Helvetica;
	font-weight: 700;
	/*font-size: 18px;*/
}
.main-navigation li a {
	font-style: oblique;
	color: var(--cates-blue);
}
.main-navigation ul.main-nav li:hover > a,
.main-navigation ul.main-nav li:focus > a,
.main-navigation ul.main-nav li.sfHover > a,
.main-navigation .menu-bar-item:hover > a,
.main-navigation ul.main-nav li[class*="current-menu-"] > a {
	text-decoration: underline;
}
.main-navigation ul.main-nav li[class*="current-menu-"] > a {
	color: var(--white);
}
.main-navigation ul.main-nav li a,
.menu-toggle,
.main-navigation .mobile-bar-items a {
	padding-left: 30px;
	line-height: 40px;
}
.main-header-container .gb-inside-container .gb-grid-wrapper > .gb-grid-column:nth-child(2) {
	display: flex;
	align-items: end;
	justify-content: flex-end;
}
.main-header-container .gb-inside-container .gb-grid-wrapper .gb-grid-column .main-menu-container-col {
	height: auto;
	width: 100%;
}
@media (min-width: 768px) and (max-width: 1024px){
	.main-menu-container-col .main-navigation #menu-main-menu li a {
		/*font-size: .75rem;*/
		line-height: 2;
	}
}


/*  Main header contact nav */
.main-header-container .phone-link a::before,
.main-header-container .email-link a:before {
	content: ' ';
	width: 16px;
	height: 16px;
	margin-right: 10px;
	display: inline-block;
	background-size: contain;
	background-position: center bottom;
	background-repeat: no-repeat;
}
.main-header-container .phone-link a::before {
	background-image: url(/wp-content/uploads/2021/02/Call-icon-blue.png);
}
.main-header-container .email-link a::before {
	background-image: url(/wp-content/uploads/2021/02/email-icon-blue.png);
}


/* Main Nav on mobile */
#mobile-menu .menu {
	background-color: #f4f4f4;
}
#mobile-menu .menu .sub-menu {
	padding-left: 0.5em;
}


/* ___Mobile header___ */
#mobile-header,
.slideout-navigation.main-navigation {
	background: linear-gradient(180deg, var(--action) 0%, var(--action-dark) 100%);
	max-width: 100vw;
}
#generate-slideout-menu .widget-title {
	color: var(--white);
	font-style: oblique;
}
.slideout-navigation,
.slideout-navigation a {
	color: var(--white);
	margin: auto;
}

/* Sticky Navigation re-ordering */
#sticky-navigation .inside-navigation {
	order: 1;
	flex-direction: row;
}
#sticky-navigation .main-nav {
	order: 2;
}
#sticky-navigation .gb-grid-column.gb-grid-column-3f4ede29 {
	order: 3;
	margin-left: auto;
}


/* ___ Secondary Nav (GP Elements > GB) ___ */
/* Top bar nav menu */
.secondary-navigation {
	background-color: var(--base);
}
#secondary-navigation {
	padding-inline: var(--section-padding-x);
}
#secondary-navigation .inside-navigation {
	padding: 0px;
}


/* ___ Sub-page nav menu ___ */
/* ex. Engineer It */
.container__secondary-navigation .container__breadcrumbs span, 
.container__secondary-navigation .container__breadcrumbs a, 
.container__secondary-navigation .secondary-navigation ul.secondary-nav li a {
	/*font-size: 1rem;
	font-size: var(--text-s, 1rem);
	color: rgba(255,255,255,0.8);*/
	color: var(--neutral-ultra-light);
	line-height: 1.2;
}
.container__secondary-navigation .container__breadcrumbs a:hover {
	text-decoration: underline;
	color: var(--white);
}

.container__secondary-navigation .secondary-nav {
  list-style: none;
  margin: 0;
  padding-left: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}
.container__secondary-navigation .secondary-nav li {
  display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
  /*flex: 0 1 20%;*/
}
.container__secondary-navigation .secondary-nav li a {
	padding-inline: 20px;
}
@media all and (max-width: 1050px) {
	.container__secondary-navigation .secondary-nav li {
		flex: 1;
	}
}
@media all and (max-width: 600px) {
	.container__secondary-navigation .secondary-nav {
    flex-direction: column;
		padding-left: 20px;
		align-items: flex-start;
	}
	.container__secondary-navigation .secondary-nav li {
		display: list-item;
		width: 100%;
	}
	.container__secondary-navigation .secondary-nav li a {
		height: 2.5em !important;
		justify-content: flex-start !important;
		padding: 0 20px;
	}

}

.container__secondary-navigation .secondary-nav li:hover a, 
.container__secondary-navigation .secondary-nav li.current-menu-item a{
	/* background-color: rgba(0,0,0,0.1);
	background-color: hsl(200deg 100% 36%); */
	background-color: var(--action-hover);
	color: var(--white)!important;
}
.container__secondary-navigation .secondary-nav li a {
	display: flex;
	flex: 1;
  text-align: center;
	justify-content: center;
	align-items: center;
	/*height: 60px; height: 3.5em;*/
	padding-block: var(--space-xs, .5rem);
}


/* ___ Sidebars ___ */
.inside-right-sidebar > .gb-container > .gb-inside-container {
    padding-block: var(--section-space-m);
    padding-inline: var(--section-padding-x);
}
/* hide breadcrumb on blog index */
.blog .site-content #right-sidebar .container__back-to-posts {
    display: none;
}
.inside-right-sidebar .sidebar-blog-recent-posts a, 
.inside-right-sidebar .blog-sidebar__tag-cloud-container .sidebar-blog-tag-cloud a.tag-cloud-link {
	font-size: var(--text-m) !important;
}
/* sidebar text color */
.blog .site-content #right-sidebar h3, .single-post .site-content #right-sidebar h3 {
	font-size: var(--h5);
	color: var(--neutral-trans-50);
}
.blog .site-content #right-sidebar .gb-container .gb-inside-container a, .blog .site-content #right-sidebar .gb-container .gb-inside-container p, 
.single-post .site-content #right-sidebar .gb-container .gb-inside-container a, .single-post .site-content #right-sidebar .gb-container .gb-inside-container p {
}




/* ******************************* 
 * Main-Navigation & Mega Menu Styles - 
 * WPSiteHelper - August 2022  
 * ********************************** */

/* contact info meta element */
.inside-header .inside-navigation .site-header-contact-details * {
	font-size: var(--text-m, 1.5rem);
	font-weight: 500;
}
.site-header-contact-details {
    margin-left: auto;
}
.inside-header .site-header-contact-details .gb-container .gb-headline:last-child {
	margin-right: 20px;
}
/* match above right-spacing */
#site-navigation .inside-navigation .main-nav > ul > li:last-child a {
	padding-right: 20px;
}

/* hide contact info 
 * when nav is top-stuck */
.inside-header .main-navigation.is_stuck .inside-navigation .main-menu-container-col {
	display: none;
}

/* no dropdown arrows, desktop */
@media all and (min-width: 1053px) {
    .menu-item-has-children .dropdown-menu-toggle {
        display: none;
    }
}

.inside-header {
	display: flex;
	flex-direction: row;
	align-items: stretch;
}
.inside-header .main-navigation {
	
}
.inside-header .main-navigation .inside-navigation {
	display: flex;
	height: 100%;
	flex-direction: column;
}
.inside-header .inside-navigation .main-nav {
	margin-top: auto;
}

@media (max-width: 1109px) {
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb {
		display: none;
	}
	
	nav .main-nav ul.menu li.mega-menu ul .sub-menu {
		box-shadow: 0 0 0;
		display: block;
		height: auto;
		left: 0;
		opacity: 1;
		pointer-events: auto;
    position: static;
		transform: scale(1);
    visibility: visible;
    width: calc( 100% - 3rem );
	}
}




@media (min-width: 1110px) {
	nav .main-nav a {
		/*font-size: 1rem;*/
		font-style: normal;
	}
	
	nav .main-nav ul.menu li.mega-menu > a {
		text-transform: uppercase;
	}
	
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
	
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li {
		grid-column-start: 2;
		grid-column-end: 3;
	}
	
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb {
		align-items: center;
		background-color: var(--action);
		color: var(--white);
		grid-column-start: 1;
		grid-column-end: 2;
		grid-row-start: 1;
		grid-row-end: 5;
		padding: 1.5rem;
		width: calc(100% - 3rem);
	}
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb:hover a {
		text-decoration: none;
	}
	
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb a, nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb h4 {
		color: var(--neutral-ultra-light)!important;
	}
	
	nav .main-nav ul.menu li.mega-menu > ul.sub-menu > li.mega-menu-blurb button {
		border-radius: .5rem;
		display: block;
		/*font-size: 1rem;*/
		margin-top: 1rem;
		text-transform: uppercase;
	}
	
	li.mega-menu ul.sub-menu li.mega-menu-parent {
    padding: 1.5rem 1.5rem 0;
}
	li.mega-menu ul.sub-menu li.mega-menu-parent:last-child {
		padding-bottom: 1.5rem;
	}
	
	nav .main-nav ul.menu li.mega-menu ul .sub-menu {
		box-shadow: 0 0 0;
		display: block;
		height: auto;
		left: 0;
		opacity: 1;
		pointer-events: auto;
    position: static;
		transform: scale(1);
    visibility: visible;
    width: calc( 100% - 3rem );
	}

	
	nav .main-nav ul.menu li.mega-menu ul.sub-menu a {
		font-weight: 400;
		padding: 0.3rem 0;
	}
	nav .main-nav ul.menu li.mega-menu ul.sub-menu a:hover {
		background-color: transparent;
		color: var(--action-hover);
		text-decoration: underline;
	}
	
	nav .main-nav ul.menu li.mega-menu ul.sub-menu li.mega-menu-parent > a {
		/*font-size: 1.05rem;*/
		font-weight: 700;
		text-transform: uppercase;
		width: calc(100% - 3rem);
		line-height: 1.5;
		margin-bottom: .5em;
	}
		nav .main-nav ul.menu li.mega-menu ul.sub-menu li.mega-menu-parent > a:hover {
		color: var(--action-hover);
		text-decoration: underline;
	}


	nav .main-nav ul.menu li.mega-menu ul.sub-menu li.menu-item-has-children .dropdown-menu-toggle {
  	display: none;
	}
}
/* hide Services menu sub-menus on mobile */
.main-navigation.toggled .menu-item-has-children.menu-item-18147 .sub-menu .sub-menu, 
.main-navigation.toggled .menu-services .sub-menu .dropdown-menu-toggle {
	display: none;
}
.main-navigation .main-nav .menu-item-has-children > a {
	padding-right: 30px !important;
}


/* ___Footer___ */
.footer-widgets .widget-title {
	color: var(--action);
	font-style: normal;
}
#footer-widgets ul {
	padding-left: 0px;
}
.footer-widgets li.menu-item a {
	text-decoration: underline;
}
.footer-widgets a:hover {
	color: var(--neutral);
}
.site-footer h6 {
	margin-bottom: 5px;
	color: var(--action);
	text-transform: uppercase;
}
footer.site-info {
	display: none;
}
@media all and (max-width: 1024px) {
	.footer-widget-1,
	.footer-widget-2,
	.footer-widget-3,
	.footer-widget-4,
	.footer-widget-5 {
		width: 100%;
		text-align: center;
	}
}


/* space out images in logo column */
.footer-image-margin-bottom img {
	margin-bottom: 40px;
}
.footer-image-grayscale {
  -webkit-filter: grayscale(1);
	        filter: grayscale(1);
	 opacity: 0.5;
}

@media all and (min-width: 1024px) {
	.gb-container-footer-style-1 > .gb-container {
		display: flex !important;
		justify-content: space-between !important;
	}
	.gb-container-footer-style-1 > .gb-container > .gb-container {
		width: unset;
	}
}

@media all and (max-width:1024px) {
	.site-footer .footer-widgets .ccs-logo {
		width: min(100%,256px);
	}
  .site-footer .footer-widgets .forty-years-badge, 
	.site-footer .footer-widgets .csia-certified {
    width: 200px;
  }
}

/* no indent or li marks on nav */
.menu.cates-footer-navigation {
    list-style: none;
    padding: 0;
}

/* Footer Style 1 -------------- */
.gb-container-footer-style-1 .widget-title {
	font-size: var(--h5);
	font-weight: 700;
}
.gb-container-footer-style-1 .widget-sub-title {
	font-size: var(--h6);
	text-transform: uppercase;
}

@media (max-width: 1024px) {
	.footer-locations-columns-wrapper {
		columnn-width: 30rem;
	}
}


/* __Overrides___ */
/* site-wide page header image container fix */
.gb-container-main-hero-container {
	width: 100%;
	inline-size: 100%;
	background-size: clamp(400px,100%,1300px) auto;
	aspect-ratio: unset;
	/*background-color: var(--neutral);*/
	background-color: var(--primary);
	min-height: unset;
	min-block-size: unset;
}
@media (min-width: 400px) {
	.gb-container-main-hero-container {
		background-position: center 61%;
		background-size: cover;
		background-repeat: no-repeat;
	}
}
@media (min-width: 1058px) {
	body:not(.home) .gb-container-main-hero-container {
		background-size: clamp( 400px,cover,var(--content-width,1300px) ) auto;
    aspect-ratio: 4 / 1.25;
	}
}
@media (min-width: 1300px) {
	.gb-container-main-hero-container {
		background-size: clamp(400px,100%,2100px) auto;
		max-height: 656px;
		aspect-ratio: unset;
		/* 2100/656 is 4/1.25 ratio */
	}
}

/* GB Global Styles Mods 
 * ------------------------------- */
.gb-button-main-banner-button, 
.gb-button.gb-button-style-1, 
.gb-button.gb-button-style-2 {
	line-height: 1.2;
}


/* Override ACSS */
#masthead {
	padding-block: var(--space-xs, .5rem);
}
/* full width pages: 
 * sections default inline padding */
.full-width-content .site.grid-container .site-content .content-area .entry-content > .gb-container:not(.gb-container-main-hero-container), 
.archive .site.grid-container {
    padding-inline: var(--section-padding-x);
}
/*@media (max-width:1340px) and (min-width:768px) {
    .site.grid-container {
        padding-inline: var(--section-padding-x);
    }
}*/
.one-container:not(.full-width-content) .container.grid-container .site-content {
	width: 100%;
	max-width: var(--content-width);
	margin-inline: auto;
	padding-inline: 0;
}
/* remove acss default section spacing, 
 * UNLESS there will be many sections
 * with background colors/images
 * that require padding,
 * OR section is direct child of body. */
:not(body) > section:not(.alignfull) {
	padding-inline: 0;
}
/* Override GP */

/* Use ACSS default main content padding 
 * since GP customizer does not accept
 * variables */
.separate-containers .inside-article, .separate-containers .comments-area, .separate-containers .page-header, .separate-containers .paging-navigation, .one-container .site-content, .inside-page-header {
	padding-block: var(--section-space-m);
	padding-inline: var(--section-padding-x);
}

/* add block padding to non-full width 
 * sections with background colors */
.gb-container-default-body, 
.gb-container-outer--bg-dark:not(.container__secondary-navigation) > .gb-container, 
.gb-container-outer--bg-light > .gb-container {
	padding-block: var(--space-m);
}

/* Gap between blog post 
 * main column and right sidebar */
/*body.right-sidebar .site-content {
	column-gap: var(--content-gap);
	row-gap: var(--section-space-m);
}*/

.entry-content .gb-container:last-of-type p:last-of-type:last-child {
    margin-block-end: 0;
}




/* *******************************************
 * 3. CUSTOM CLASSES
 * Pages, Layouts, Components
 * *******************************************/

/* ___Home, banner video___ */
.background-video {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	max-width: 100vw;
}
.video-container {
	position: relative;
	overflow: hidden;
}
.background-video-content {
	position: relative;
	z-index: 1;
}
video[poster] {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

/* swap headline-only background overlay to full section on HOME */
.home .gb-container-main-headline-container {
    background: none;
}

.home .gb-container-main-hero-container::before {
    content: '';
    display: block;
    position: absolute;
    inset: 0;
    width: 100%;
    background: var(--neutral-trans-20);
    z-index: 1;
}

/* vertically center vid on large display */
@media all and (min-width: 1500px) {
	.home .background-video {
		top: -30%;
		aspect-ratio: 16 / 9;
	}
}
/* stretch vid on large width displays */
@media all and (min-width: 1280px) {
	.home .background-video {
		width: 100%;
	}
}
/* smaller displays */
@media all and (max-width: 1180px) {
	.home .background-video {
		aspect-ratio: 16 / 9;
		max-width: unset;
		height: 100%;
		width: auto;
	}
}

.home .gb-container-main-hero-container {
	min-height: 25vh;
}


/* ABOUT US PAGE
 ************************************ */

@media (max-width: 767px){
	/* Center the 40 year image */
	.forty-year-cert-image figure {
		display: block;
		width: 100%;
		text-align: center;
	}
}
/* Key Company Milestones */
ul.company-milestones {
	list-style-type: none;
	padding-left: 0px;
}
ul.company-milestones li {
	display: grid;
	grid-template-columns: 1fr 7fr;
	margin: 16px 0;
}
ul.company-milestones li:not(:has(span)) {
	display: block;
	margin-left: 12.5%;
}
ul.company-milestones li.second-line {
	/*text-indent: 78px;*/
	margin-left: auto;
	width: 87.5%;
	display: block;
	margin-top: -16px;
}
.text-light-blue {
	font-weight: 700;
	padding-right: 20px;
	color: var(--action-dark);
}
@media all and (max-width: 768px){
	ul.company-milestones {
		list-style-type: none;
		position: relative;
		/*left: 3rem;
		padding-right: 1.5rem;*/
	}
	/*ul.company-milestones li {
	text-indent: -4rem;
	padding: 5px;
}*/
	ul.company-milestones li.second-line {
		text-indent: 0rem;
	}
	.text-light-blue {
		padding-right: 0px;
	}
}


/* Company Culture */
ul.company-culture {
	list-style-type: none;
}
ul.company-culture li {
	position: relative;
	/*text-indent: -11rem;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 11rem;
	padding-right: 11rem;*/
	/*font-size: 23px;*/
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 2fr 6fr;
	grid-template-columns: 2fr 6fr;
	margin: 1em 0;
}
ul.company-culture .text-black {
	font-weight: 700;
	min-width: 150px;
	display: inline-block;
	text-align: right;
	color: var(--white);
	padding-right: 20px;
	text-shadow: 1px 1px 4px var(--black);
	text-transform: uppercase;
}
@media all and (max-width: 768px){
	ul.company-culture li {
		text-indent: 0;
		padding-left: 0;
		padding-right: 0;
		display: list-item;
	}
	ul.company-culture .text-black {
		min-width: auto;
		display: block;
		/*text-align: center;*/
		text-align: left;
		background: linear-gradient(135deg,var(--dark-blue) 30%,rgba(0,0,0,0.1) 50%,var(--light-blue) 80%);
		padding-left: 0.5em;
		margin-left: -0.5em;
		margin-bottom: 8px;
	}

}


/* ___ Blog Index ___ */
@media all and (min-width:768px) {
  .single-post.single-format-standard .site-content .site-main {
    
  }
}
article .post-author-meta a, 
article .post-author-meta .gb-icon , 
article .post-date-meta, 
article .post-terms-meta a, 
article .post-terms-meta .gb-icon {
	
}
.single-post .dynamic-featured-image/*, .single-post .content-area article*/ {
	box-shadow: var(--btn-box-shadow);
	box-shadow: var(--box-shadow-l);
}
@media (min-width: 768px) {
	.inside-right-sidebar {
    position: sticky;
    top: 9rem;
	}
}

/* ___ Blog styling update 2023.Q4 ___ */
.single-post .blog-post-header-container h1 {
	font-size: var(--h2);
}
.single-post .site-main article h2 {
	color: var(--action);
	text-align: center;
	text-wrap: balance;
}
.wp-block-pullquote {
	padding-block: var(--space-xs, 1em);
}
blockquote, 
.wp-block-pullquote blockquote {
	font-size: var(--text-l);
	font-style: italic;
	text-align: center;
	color: var(--action);
	padding: var(--space-s, 2em);
}
.single-post .site-main article h3 {
    font-weight: 600;
    font-size: var(--h4);
}
.single-post .site-main article li::marker {
    color: var(--action);
    font-weight: 900;
}
.single-post .site-main article a, 
.single-post .site-main article a:visited {
    color: var(--action);
    font-style: italic;
    font-weight: 600;
}
.single-post .site-main .single-post__post-meta-text-container a, 
.single-post .site-main .single-post__post-meta-text-container a:visited {
	font-weight: 400;
	font-style: normal;
}
.ccs-post-category-icon {
	max-height: 11rem;
	aspect-ratio: 1 / 1;
	margin: 0;
}
/* __Single-post Tables__ */
.single-post .site-main table * {
    border: 0 !important;
}
.single-post .site-main table thead th {
	color: var(--secondary);
	font-size: var(--h4);
}
.single-post .site-main table tbody tr:nth-child(even) {
    background-color: var(--primary-light-trans-10);
}
.single-post .site-main table tbody tr td {
    font-size: var(--text-s);
}

.container__post-meta .post-meta__author-name, .container__post-meta .post-meta__post-date, .container__post-meta .post-meta__tags {
    line-height: 1;
}

/* background color blog index and posts */
body.blog, 
body.blog.one-container #page, body.single-post, 
body.single-post.one-container #page {
	background-color: var(--primary);
}
body.blog .site-main article {
	background-color: var(--white);
}

@media (min-width: 768px) {
    .blog .site.grid-container {
        padding-inline: var(--section-padding-x);
        max-width: 100%;
    }
}

.one-container.blog .post:not(:last-child):not(.is-loop-template-item) {
	padding-bottom: 0;
}

@media (max-width: 767px) {
	.blog .site-content, 
	.single-post .site-content {
    padding-block: 0 !important;
	}
}
@media (max-width: 767px) {
	.blog .content-area article.post:not(:last-child):not(.is-loop-template-item) {
			margin-bottom: 0;
			padding-bottom: 0;
	}
	article .gb-inside-container {
	}
}

/* ___ Blog: Single ___ */
.single-post :where(h3, h4, h5) {
	font-weight: 500;
}


/* -- Pre-Footer CTA bar -- */
.gb-container-col-2-cta {
    background-color: var(--action);
}
.gb-container-col-2-cta.light-version {
	background-color: var(--neutral-ultra-light);
}
.gb-container-col-2-cta.light-version .gb-headline.gb-headline-text {
	color: var(--neutral)!important;
}

.gb-container-col-2-cta > .gb-inside-container, 
.gb-container-col-2-cta > .gb-container, 
.gb-container-col-2-cta > .gb-grid-wrapper {
	padding-block: var(--section-space-l);
	max-inline-size: var(--content-width);
	max-inline-size: clamp(100px, 100%, var(--content-width) *.75);
	margin-inline: auto;
}

.gb-container-col-2-cta .gb-grid-wrapper {
	display: grid;
	grid-template-columns: var(--grid-auto-2);
	gap: var(--grid-gap);
	row-gap: calc(2 * var(--grid-gap));
}

.gb-container-col-2-cta .gb-grid-wrapper > .gb-grid-column {
	width: clamp(100px, 100%, 70ch);
	margin-inline: auto;
	text-wrap: balance;
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container {
	display: flex;
	flex-direction: column;
	height: 100%;
	align-items: center;
}

.gb-container-col-2-cta h2 {
	margin-block-end: var(--space-l);
	text-wrap: balance;
}

.gb-container-col-2-cta .wp-block-image {
	margin-inline: auto;
}

.gb-container-col-2-cta .wp-block-image:not(.training-cta__image) img {
	height: 6rem !important;
	width: auto !important;
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .gb-headline, 
.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-heading {
	margin-block-start: var(--space-s);
	margin-block-end: var(--space-s);
	font-size: var(--h3);
	color: var(--neutral-ultra-light);
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container p, 
.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container p {
	font-size: var(--text-xxl);
	color: var(--neutral-ultra-light);
	margin-block-end: var(--space-s);
	text-align: center;
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons, 
.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons {
	justify-content: center;
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons a, 
.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons .wp-block-button a {
	font-weight: var(--btn-weight);
	padding-inline: var(--btn-pad-x);
	padding-block: var(--btn-pad-y);
	border-radius: var(--btn-radius);
	border-width: var(--btn-border-size, 2px);
	border-style: solid;
	border-color: var(--action);
	background-color: var(--neutral-ultra-light);
	color: var(--action);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	text-transform: var(--btn-text-transform);	box-shadow: var(--btn-box-shadow);
}

.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons a:hover, 
.gb-container-col-2-cta .gb-grid-wrapper .gb-grid-column > .gb-container .wp-block-buttons .wp-block-button a:hover {
	border-color: rgba(0, 0, 0, 0.1);
	background-color: var(--action-hover);
	color: var(--neutral-ultra-light);
	box-shadow: var(--btn-box-shadow-hover);
}
@media only screen and (max-width: 767px) {
	.force-center
	{
		justify-items:center!important;
	}
}



/* INDUSTRY EXPERIENCE PAGE
------------------------------------ */
.ccs-industry-experience__expertise-list {
	column-count: 3;
	list-style: none;
	text-align: center;
	padding-inline: 0;
	margin-inline: 0;
}
@media (max-width: 767px) {
	.ccs-industry-experience__expertise-list {
		column-count: 2;
		list-style: initial;
		text-align: initial;
		padding-inline: initial;
		margin-inline: initial;
	}
}
.ccs-industry-experience__image-text-columns-grid {
    display: grid;
    grid-template-columns: var(--grid-auto-2);
    gap: var(--grid-gap);
    margin: 0;
}
.ccs-industry-experience__image-text-columns-grid > .gb-grid-column {
    width: 100%;
    padding: 0;
}
.ccs-industry-experience__image-text-columns-grid img {
    border-radius: var(--btn-border-radius);
    aspect-ratio: 5 / 3;
}
.ccs-industry-experience__image-text-columns-grid > .gb-grid-column:nth-of-type(2) > .gb-container > .gb-inside-container {
    display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
    -webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
    -webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.gb-grid-wrapper-featured-stats {
    gap: var(--grid-gap);
    display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
    margin-block-end: var(--space-m);
}
.gb-grid-wrapper-featured-stats > .gb-grid-column {
    min-width: 200px;
    max-width: calc(calc(100% - calc(var(--grid-gap)*4) ) / 5);
}
@media (max-width:1023px) {
    .gb-grid-wrapper-featured-stats > .gb-grid-column {
        max-width: calc(calc(100% - calc(var(--grid-gap)*1) ) / 2);
    }
}
@media (max-width:767px) {
    .gb-grid-wrapper-featured-stats > .gb-grid-column {
        max-width: unset;
    }
}
.gb-container-featured-stats-button > .gb-inside-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	place-content: center;
}



/* ENGINEER IT PAGE
************************************ */
  .cates-system-integration img {
      transform: translateX(5%);
  }



/* FABRICATE IT PAGE
************************************ */
.container-column-children-larger-text li,
.container-column-children-larger-text p {
  font-size: 16px !important;
}

@media (max-width: 767px){
	.gb-grid-wrapper.column-reverse-mobile {
		flex-direction: column-reverse !important;
	}
}

@media (min-width: 1200px) {
	.gb-container-f81b7a0c {
		background-position: center center;
	}
}


@media (max-width: 767px ){
	.gb-container.gb-container-d7404bbd {
		min-height: 250px !important;
		background-size: contain !important;
	}
	.gb-container-a1ac92a8 {
		min-height: 200px !important;
	}
	.gb-grid-column.gb-grid-column-b845f459,
	.gb-grid-column.gb-grid-column-c6acf367 {
		width: 50% !important;
	}

}

/* ___ Install It page ___ */
.gb-container.gb-container-child-image--fill-height figure, .gb-container.gb-container-child-image--fill-height img {
	height: 100%;
}


/* TransferMinder Page */

/* Overlaid Grid & Image *
 * Added by Jake W 10/29 */

.overlay-grid-image--wrapper .gb-inside-container {
    position: relative;
}

.overlay-grid-image--wrapper .gb-inside-container figure {
    bottom: 20px;
    position: absolute;
}

ul.transferminder-list {
    color: #008f44;
}

@media(max-width: 767px) {
    .overlay-grid-image--wrapper .gb-inside-container figure {
        position: initial;
    }
}

/* TransferMinder page
 * Comparison Table
 * Added by Jake W 10/31 */

/* Typography */
#footable_18263 {
	font-size: var(--text-m, 1.6rem);
}

#footable_18263 thead {
	font-size: var(--text-m, 1.55rem);
}

/* Cost Range */
p.transferminder-table-accent {
	color: var(--action);
	font-weight: bold;
}

/* Tick Icons */
#footable_18263 .wp-image-18264 {
	height: 24px;
	width: 24px;
}

/* Clock icons */
#footable_18263 .wp-image-18265 {
	display: inline;
	margin-right: 2px;
}
#footable_18263 .wp-image-18265:last-child {
	margin-right: 0;
}

/* Careers Page */
#current-openings p a {
	text-decoration: underline;
}

.careers-perks-item a {
	text-decoration: underline;
}


/**
 *  Engineer It page
 **/
.page-id-16354 .site-content .gb-container:not(.gb-container-main-hero-container) a:not(.gb-button, .gb-button a) {
	color: inherit;
	text-decoration: none;
	background-image: -webkit-gradient(linear, left top, left bottom, from var(--action-dark), to var(--action-dark));
	background-image: linear-gradient(to bottom, var(--base) 0%, var(--base) 100%);
	background-repeat: no-repeat;
	background-size: 100% 0%;
	background-position: 0% 111%;
	-webkit-transition: background-size .25s ease-in;
	transition: background-size .25s ease-in;
	padding: 2px 2px 0 0;
	border-bottom: 2px solid var(--action);
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
.page-id-16354 .site-content .gb-container:not(.gb-container-main-hero-container) a:not(.gb-button, .gb-button a):hover {
	background-size: 100% 88%;
	cursor: pointer;
	border-bottom: 2px solid var(--accent);
}



/* ___ Store pages ___ */
@media all and (max-width: 600px) {
	body.woocommerce .site-content {
		padding: 40px;
	}
}


/* ___ Products ___ */
.page-id-2642 .content-area img {
	object-fit: contain;
}
@media all and (min-width: 600px) {
	.container-has-inline-children .gb-inside-container {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

/* ___ Spacing before training dates calendar ___ */
body.single-product.woocommerce.woocommerce-page form.cart {
    margin-top: 2em;
}


/* ___ Contact Us Page ___ */

/* Map Boxes */
@media all and (max-width: 1024px) {
	.address-column {
		max-width: 450px;
		margin: 10px auto;
	}
}
@media all and (min-width: 1024px) and (max-width: 1076px){
	.address-column .gb-inside-container > .gb-container {
		min-height: 415px;
	}

}


/* OEM CONTROL PANELS PAGE
************************************ */
.plus-symbol-list {
	margin: auto;
}
.plus-symbol-list li {
	padding-left: 5px;
}
.plus-symbol-list li::marker {
	content: '+';
	font-weight: 300;
	color: var(--neutral);
}
.plus-symbol-list + hr {
	margin: 15px;
}


/* PLC-5 PAGE
************************************ */
.spinny-number {
	font-weight: bold;
	margin: auto;
	line-height: 1.2;
}
.spinny-number:after {
	content: '';
}
.spinny-number span::after {
	content: '+';
	position: absolute;
}

/* PROGRAMMING PAGE
************************************ */
.partner-logos-slider .slick-list {
	min-height: auto;
}
.partner-logos-slider .slick-next.slick-arrow,
.partner-logos-slider .slick-prev.slick-arrow {
	background: transparent;
	font-size: 0px;
}
.partner-logos-slider .slick-next.slick-arrow{
	right: 0px;
}
.partner-logos-slider .slick-prev.slick-arrow {
	left: 0px;
}
.three-col-list-container {
	text-align: center;
}
.three-col-list {
	text-align: left;
	width: 80%;
	margin: auto;
	max-width: 270px;
}
@media (min-width: 768px){
	.three-col-list {
		columns: 2;
		max-width: 80%;
		padding-left: 15%;
	}
}
@media (min-width: 1199px){
	.three-col-list {
		columns: 3;
	}
}


/* ___ Learn More CTA Styles ___ */
span.mega-menu--cta {
	align-items: center;
    display: flex;
    justify-content: flex-start;
    margin-top: 1rem;
}
span.mega-menu--cta::after {
    content:  '';
    height:  10px;
    width:  20px;
    display: inline-block;
    margin-left: 0.5rem;
    background-image: url('/wp-content/uploads/2022/10/cates_com-right-arrow-white.png');
}


/* ___ Customer Portal ___ */
.fst_client_portal .fs_tk_header {
	box-sizing: border-box;
	/* fix oversized table header row */
}
li.woocommerce-MyAccount-navigation-link.woocommerce-MyAccount-navigation-link--bookings {
	display: none;
	/* hide "Bookings" on My Account page */
}


/* Style 1 */
.cts-50-50-image-text-container p:last-child {
	padding-block-end: 0;
}
.cts-50-50-image-text-container {
	--grid-gap: var(--section-padding-x);
	gap: var(--grid-gap, 1.5rem);
	display: grid !important;
	grid-template-columns:
		repeat(auto-fit, minmax( min(38rem, 100vw - var(--grid-gap)), 1fr ));
	inline-size: 100%;
	/*margin: 0;
	padding: 0;*/
	grid-template-columns: var(--grid-auto-2);
}
.cts-50-50-image-text-container > .gb-grid-column, 
.cts-50-50-image-text-container > .gb-container {
	width: unset;
	display: inline-grid;
	/*margin: 0;
	padding: 0;*/
}
.cts-50-50-image-text-container > .gb-grid-column > .gb-container, 
.cts-50-50-image-text-container > .gb-container {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
@media (min-width: 61rem) {
	.cts-50-50-image-text-container > .gb-grid-column > .gb-container, 
	.cts-50-50-image-text-container > .gb-container {
		min-height: 35rem;
	}
}
.cts-50-50-image-text-container > .gb-grid-column > .gb-container > .gb-inside-container > figure > img, 
.cts-50-50-image-text-container > .gb-container > figure > img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	margin-block: 0;
}
.cts-50-50-image-text-container + .cts-50-50-image-text-container {
	margin-top: var(--grid-gap, 1.5rem);
}
@media (max-width: 767px) {
	.cts-50-50-image-text-container > .gb-grid-column, 
	.cts-50-50-image-text-container > .gb-container {
		width: 100%;
		padding-inline: 0;
	}
	.cts-50-50-image-text-container > .gb-grid-column:first-of-type, 
	.cts-50-50-image-text-container > .gb-container:first-of-type {
		padding: var(--section-padding-x);
	}
	/*.cts-50-50-image-text-container {
		grid-template-columns: repeat(auto-fit, minmax( min(22rem, 100vw - var(--grid-gap)), 1fr ));
	}*/
}

/* when inside a parent section with colored background */
.cts-50-50-image-text-container:not(.reverse) > .gb-grid-column:first-of-type, 
.cts-50-50-image-text-container:not(.reverse) > .gb-container:first-of-type {
	padding-inline-start: var(--section-padding-x);
}
.cts-50-50-image-text-container.reverse > .gb-grid-column:first-of-type, 
.cts-50-50-image-text-container.reverse > .gb-container:first-of-type {
	padding-inline-end: var(--section-padding-x);
}

/* when no parent section exists and no column gap wanted */
.cts-50-50-image-text-container.no-gap {
	column-gap: 0;
}
.cts-50-50-image-text-container.no-gap > .gb-grid-column:first-of-type, 
.cts-50-50-image-text-container.no-gap > .gb-container:first-of-type {
	padding: var(--section-padding-x);
}

/* reverse columns */
@media (min-width: 61rem) {
	.cts-50-50-image-text-container.reverse > .gb-grid-column:nth-of-type(1), 
	.cts-50-50-image-text-container.reverse > .gb-container:nth-of-type(1) {
		order: 2;
	}
	.cts-50-50-image-text-container.reverse > .gb-grid-column:nth-of-type(2), 
	.cts-50-50-image-text-container.reverse > .gb-container:nth-of-type(2) {
		order: 1;
	}
}

/* Style 2 */
.cts-wrap--title-50-50 {
    background-color: var(--secondary);
    padding-block-end: var(--section-space-m);
}
.cts-wrap--title-50-50 h2 {
    padding: var(--space-xs);
    margin-bottom: 0px;
		margin-block-end: var(--section-space-xs);
    color: var(--white);
    background-color: var(--action);
    text-align: center;
}

.cts-wrap--title-50-50 .cts-50-50-image-text-container {
	padding-inline: var(--section-padding-x);
}



/* ___Testimonials Carousel in Footer___ */
.testimonial-container .gb-inside-container {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.testimonial-container {
	background: var(--white);
	max-width: 900px;
	margin: auto;
	display: flex;
	align-items: center;
	justify-content: center;
}
.full-testimonial {
	font-size: inherit;
	font-weight: 400;
	max-width: 90%;
	margin-left: auto;
	margin-right: auto;
	padding-bottom: 15px;
}
.testimonial-source {
	text-align: center;
	font-weight: 700;
	/*font-size: 22px;*/
}
.testimonial-source:before {
	content: "—";
}
.slick-prev::before,
.slick-next::before {
	font-family: 'Font Awesome 5 Free';
	color: var(--action) !important;
	font-size: 2.5rem;
}
.slick-prev::before {
	content: '\f053';
	position: absolute;
	top: 0;
	right: 25px;
}
.slick-next::before {
	content: '\f054';
	position: absolute;
	top: 0;
	left: 25px;
}
@media all and (max-width:768px) {
	.full-testimonial {
		font-size: 1.2rem;
	}
}
@media all and (min-width: 768px){
	.slick-list {
		min-height: 350px;
	}
}
@media all and (max-width: 1024px){

	.slick-prev::before {
		right: 5px;
	}
	.slick-next::before {
		left: 5px;
	}
}
/* slider dots */
.gb-container-testimonial-section .has-dots-inside .slick-dotted .slick-dots li button:before {
    color: var(--neutral-ultra-light);
    opacity: 1;
}
.gb-container-testimonial-section .has-dots-inside .slick-dotted .slick-dots li.slick-active button:before {
    color: var(--action);
}

/* ___Fluent Forms Styling___
 * incl File-upload and Submit buttons */
.fluentform .ff-btn, 
.fluentform button[type="submit"].ff-btn {
    font-size: var(--text-m);
}
/* alert success */
.fluentform .ff-message-success {
    border-left: 8px solid green;
    color: #155724;
    background-color: #d4edda;
}
/* alert warning */
.fluentform .text-danger {
    border-left: 8px solid red;
    color: #721c24;
    background-color: #f8d7da;
}

/* ___Buttons: Style 1 (white w/ border)___
 * uses: 
 *  file-upload button
 *  blog 'Read More' button
 *  in dark background sections
 */
.gb-button-wrapper .gb-button.button__cates-dark-blue, 
.container__blog-index-loop-item .dynamic-entry-excerpt .read-more-container a, 
.ff_form_modal .button-style-1, 
.gb-button.button-style-1, 
.fluentform .ff_file_upload_holder .ff_upload_btn.ff-btn {
    background-color: var(--neutral-ultra-light, #fff);
    border: 1px solid var(--action);
    color: var(--action);
    border-radius: var(--btn-radius);
	  padding: var(--btn-pad-y) var(--btn-pad-x);
}
.gb-button-wrapper .gb-button.button__cates-dark-blue:hover, 
.container__blog-index-loop-item .dynamic-entry-excerpt .read-more-container a:hover, 
.ff_form_modal .button-style-1:hover, 
.gb-button.button-style-1:hover, 
.fluentform .ff_file_upload_holder .ff_upload_btn.ff-btn:hover {
    background-color: var(--action-hover);
    border-color: var(--action-hover);
    color: var(--neutral-ultra-light, #fff);
}

/* ___Buttons: Style 2 (dark w/ white border)___
 * uses: 
 *  form submission button
 *  light backgrounds
 *  
 */
form.frm-fluent-form button[type="submit"].ff-btn.ff-btn-submit {
	background-color: var(--action);
	padding: var(--btn-pad-y) var(--btn-pad-x);
	border: 1px solid var(--action);
	border-radius: var(--btn-radius);
	color: var(--neutral-ultra-light, #fff);
}
form.frm-fluent-form button[type="submit"].ff-btn.ff-btn-submit:hover {
	background-color: var(--action-hover);
	padding: var(--btn-pad-y) var(--btn-pad-x);
	border: 1px solid var(--action-hover);
	color: var(--neutral-ultra-light, #fff);
}

/* ___Stylistic Modals___ */
.stylistic-modal {
	max-height: 80vh;
	max-height: 80dvh;
}
.iziModal .iziModal-header {
	background-color: var(--action) !important;
}

/* icons after headline text */
.gb-headline.reverse-icon span.gb-icon {
    order: 2;
	  margin-left: auto;
	  padding-right: 0;
}

.section__contact-us__icon--white figure, 
.section__contact-us__icon--white img {
	height: 119px;
	max-height: 119px !important;
	width: auto !important;
}





/* *******************************
 * 4. UTILITY CLASSES
 * ******************************* */

/* ___Alerts___ */
.alert {
    position: relative;
	  padding: var(--button-padding-med);
	  margin: 1rem;
	  border: 1px solid transparent;
    border-left: 8px solid;
}
.alert.alert-warning {
    color: #856404;
    background-color: #fff3cd;
    border-color: #f0ad4e;
}
.alert.alert-success, 
.woocommerce-notice.woocommerce-notice--success {
    position: relative;
    padding: var(--button-padding-med);
    margin: 1rem;
    color: #3c763d;
    background-color: #dff0d8;
    border-left: 8px solid #3c763d;
}

div[name="g-recaptcha-response"] {
    max-width: 100%;
}
.hide-this {
    display: none;
}
ul.list-no-bullets {
	list-style: none;
}
ul.list-spaced-items li {
	margin-bottom: var(--space-xs, .25em);
}

[class^="aspect-ratio-"], 
[class*=" aspect-ratio-"] {
	object-fit: cover;
}
.aspect-ratio-16-9 { aspect-ratio: 16 / 9; }
.aspect-ratio-9-16 { aspect-ratio: 9 / 16; }
.aspect-ratio-4-3 { aspect-ratio: 4 / 3; }
.aspect-ratio-1-1 { aspect-ratio: 1 / 1; }


.text-oblique,
.text-oblique p,
.text-oblique a {
font-style: italic !important;
}
ul {
	/*margin: auto auto auto 0.5em;*/
	/*margin-bottom: 1.5em;*/
	padding-inline-start: 20px;
	margin-inline: 0.5em 0;
	margin-block: 0 1.5em;
}
ul.menu.cates-footer-navigation {
	margin-left: 0;
}
.d-flex {
	display: flex !important;
}
/* Generate blocks buttons*/
.gb-button {
	background: var(--light-blue);
}
.black-border {
	border: 2px solid #000;
}
.m-bottom-none {
	margin-bottom: 0 !important;
}

a.link--underline, .link--underline a {
	text-decoration: underline;
}
a:visited:not(.button, .gb-button, button, .container__breadcrumbs a) {
	color: var(--action);
}
a.button:hover, a.gb-button:hover, .gb-button a:hover, .ff-btn:hover {
    text-decoration: none;
}
/* visible links on color backgrounds */
.gb-container-outer--bg-light a:not(.gb-button), 
.gb-container-outer--bg-light a:not(.gb-button):visited, .cts-wrap--title-50-50 a:not(.gb-button), 
.gb-container-outer--bg-light a:not(.gb-button):visited, .cts-wrap--title-50-50 a:not(.gb-button):visited {
	text-decoration: underline;
	/*background-color: var(--action-light-trans-20);*/
}
.gb-container-outer--bg-light a:hover, .cts-wrap--title-50-50 a:hover {
    /*background-color: var(--action-ultra-light);*/
    color: var(--action);
}
/* dark backgrounds */
.content-area .gb-container-outer--bg-dark a, 
.content-area .gb-container-outer--bg-dark a:visited {
    color: var(--base-ultra-light);
}
.content-area .gb-container-outer--bg-dark a:hover {
	color: white;
}

.margin-bottom-none, 
ul:last-child {
    margin-bottom: 0;
}
.gb-container.container-left-aligned, 
.gb-container.inner-container-left-aligned .gb-inside-container {
    margin-right: auto;
    margin-left: 0;
}
.gb-container.container-right-aligned, 
.gb-container.inner-container-right-aligned .gb-inside-container {
    margin-left: auto;
    margin-right: 0;
}
.gb-container.container-fit-contents {
    width: fit-content;
}

.break--before-column {
	-webkit-column-break-before: column;
	-moz-column-break-before: column;
	break-before: column;
}

.column-count-2 {
	-webkit-column-count: 2;
	-moz-column-count: 2;
	column-count: 2;
}

/* Next 2 classes make cards clickable, 
 * YET ACCESSIBLE FOR SCREEN-READERS,  
 * when applied to the link and its parent */
.position-relative:has(.make-parent-clickable) {
	position: relative;
}
a.make-parent-clickable::before, 
.make-parent-clickable a::before {
	content: '';
    position: absolute;
    inset: 0;
    z-index: 100;
}



















/* TWO COLUMN IMAGE/TEXT LIST
 ************************************ */
  .gb-container-two-column-image-text-container-left,
  .gb-inside-container {
    height: 100%;
  }


  /* Utility class to swap sides  */
  .gb-grid-wrapper-two-column-image-text-grid.row-reverse {
      flex-direction: row-reverse;
  }

  /* Flip the classroom image  */
  .scale-x-neg-1 {
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
  }

  /* Bottom-align buttons inside GB container (exclude mobile) */
@media all and (min-width: 768px) {
  .gb-container-last-child-button .gb-inside-container {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	height: 100%;
  }
  .gb-container-last-child-button .gb-button-wrapper:last-of-type {
	margin-top: auto;
  }
}



