/*
	Theme Name: CloveRock Design
	Theme URI: https://www.cloverockdesign.ie
	Description: CloveRock Design WordPress Theme
	Version: 1.0
	Author: CloveRock Design (@cloverockdesign)
	Author URI: https://www.cloverockdesign.ie

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/

/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
/* html element 62.5% font-size for REM use */
html {
	font-size:62.5%;
}
body {
	font: 400 16px/1.4 'Rubik', sans-serif;
	color: #1C1C1C;
	padding:0px;
}
/* clear */
.clear:before,
.clear:after {
    content:' ';
    display:table;
}

.clear:after {
    clear:both;
}
.clear {
    *zoom:1;
}
img {
	max-width:100%;
	vertical-align:bottom;
}
a {
	color: #EA095F;
	text-decoration: none !important;
	transition: all 400ms ease-in-out 0s;
}
a:focus {
	outline:0;
}
a:hover,
a:active {
	outline:0;
}
input:focus {
	outline:0;
	border:1px solid #04A4CC;
}

.mega-indicator {
	position: absolute !important;
	left: 50% !important;
	margin-left: -10px;
	bottom: -14px;
}
/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/

/* wrapper */
.wrapper {
	max-width:1280px;
	width:95%;
	margin:0 auto;
	position:relative;
}
.quick-link-bar {
  background: #4059ad;
  padding: 20px;
  color: #fff;
}
.quick-link-bar a {
  color: #fff;
}
.quick-link-wrap {
	margin: 0 auto;
	width: 95%;
	max-width: 1380px;
	font-size: 80%;
}
.quick-link-wrap strong {
   margin-right:10px;
}
/* header */
.head-wrap {
	height: 120px;
	background: #fff;
	z-index: 9999;
	position: relative;
}
.header {
   width:95%;
	 max-width:1380px;
	 margin:0 auto;
	 height:120px;
	 position:relative;
}
/* logo */
.logo-img {
	max-width: 100px;
	position: absolute;
	top: 11px;
	left: 0px;
	width: 100%;
}
.logo-img {

}
.school-title {
	display: block;
	position: absolute;
	left: 120px;
	font-size: 20px;
	font-weight: 700;
	line-height: 21px;
	max-width: 200px;
	color: #4059ad;
	top: 39px;
}
.header-tel {
	top: -49px;
	position: absolute;
	height: auto;
	font-size: 15px;
	padding: 0px;
	margin-top: 0;
	right: 0px;
	font-weight: 700;
	padding: 10px 15px;
	font-weight: 700;
	color: #fff;
	/* background: #fff; */
	border-radius: 99px;
}
.header-tel i {
  color: #74BEFF;
  margin: 0 5px 0 0;
}
/* nav */
.nav {
	position: absolute;
	right: 0;
	top:0px;
}
.header .shiftnav-toggle-button {
	display: none;
	padding: 10px 0px;
	background: #fff;
	color: #EA095F;
	font-size: 40px;
	position: absolute;
	right: 0px;
	top: 25px;
}
.header .shiftnav-toggle-button:hover {
	display: inline-block;
	padding: 10px 0px;
	background: #fff;
	color: #121212;
}
.shiftnav.shiftnav-shiftnav-main {
	border-left: 2px solid #030764;
}
.sub-menu.sub-menu-1 {
	padding-left: 0px !important;
}
.shiftnav.shiftnav-shiftnav-main ul.shiftnav-menu ul.sub-menu li.menu-item > .shiftnav-target {
	color: #ffffff;
	font-size: 14px !important;
	font-weight: 400;
}
.shiftnav ul.shiftnav-menu li.menu-item > .shiftnav-target, .shiftnav ul.shiftnav-menu li.shiftnav-retract > .shiftnav-target {
	padding: 22px 25px !important;
}
.sub-menu.sub-menu-2 li.menu-item > .shiftnav-target {
	padding: 10px 25px !important;
}
.shiftnav ul.shiftnav-menu li.menu-item {
	border-top: 1px solid rgba(255,255,255,0.1) !important;
}
.shiftnav ul.shiftnav-menu .sub-menu.sub-menu-2 li.menu-item {
   border:0 none !important;
}
.shiftnav-inner #menu-item-119272 {
    border:0 none !important;
}
.shiftnav .shiftnav-panel-close {
	padding: 24px 25px 25px 25px !important;
	z-index: 9999 !important;
}
.shiftnav::after {
  display:none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-ms-box-shadow: none !important;
	-o-box-shadow: none !important;
	box-shadow: none !important;
}

@media only screen and (max-width:1100px) {
.nav {
    display:none;
}
.header .shiftnav-toggle-button {
	display: block;
}
}
.est-date {
	font-size: 20px;
	display: block;
	position: absolute;
	top: 55px;
	left: 235px;
	font-weight: 700;
	color: #EA095F;
}
main {
	max-width: 800px;
	margin: 0 auto;
	padding: 50px 0px;
	width: 95%;
}
main.row-main {
   max-width:100%;
	 margin:0 auto;
	 padding:0px;
}
.content-main {
	padding: 50px 0;
}
.content-section {
	max-width: 800px;
	margin: 0 auto;
}
/* sidebar */
.sidebar {
   padding:50px 0px;
	 background:#aaa;
	 color:#fff;
	 text-align:center;
}
/* footer */
.footwrap {
	background: #4059AD;
}
.footer {
   max-width:1380px;
	 margin:0 auto;
	 width:95%;
	 padding:60px 0px;
	 color:#fff;
	 text-align:center;
	 overflow:hidden;
}

.footcol span {
  display: block;
}
.footcol span i {
    color:#74BEFF;
		margin:0 10px 0 0;
}
.footcol.footright ul {
  list-style: none;
  padding: 0px;
  margin: 0px;
}
.footcol.footright li img {
  display: inline-block;
  background: #fff;
  padding: 2px 15px;
  border-radius: 99px;
  width: 140px;
  margin: 0px 10px 0px 0px;
  vertical-align: top;
}
.footcol.footright li i {
	background: ;
	font-size: 30px;
	margin: 0 0 0 15px;
}
.footcol.footright ul li:first-child {
	margin: 0px 0 34px 0px;
}
.footer a {
   color:#fff;
}
.footer a:hover {
   color:#74BEFF;
}
.footer h5 {
	font-size: 26px;
	margin: 0px 0 20px 0;
	padding: 0;
	line-height: 26px;
}
.foot-logo {
	width: 220px;
	margin: 0px;
}
.footcol {
	text-align: left;
	font-size: 12px;
	line-height: 20px;
	width: auto;
	margin-right:40px;
	text-align: left;
	float: left;
}
.footcol.footright {
	float: right;
	text-align: right;
	margin-right: 0px;
	font-size: 12px;
	line-height: 20px;
}
.foot-strap {
  text-align: center;
  padding: 30px 2.5%;
  font-size: 12px;
  background: #000;
  color: #fff;
}
.foot-strap a {
  color: #fff;
}

.footcol audio {
	border-radius: 99px;
	max-width: 230px;
	border: 3px solid #74BEFF;
	margin-top: 10px;
}
.social-links { 
margin:0px auto 20px auto;
text-align:center;
}
.social-links a {
color: #EA095F;
font-size: 36px;
margin: 0px 5px;
}
.crd-link {
    display:block;
}

.sponsors-bar {
    padding:60px 0px;
}
.sponsors-title {
	 margin:0 auto 30px auto;
	 color:#0f3e10;
	 display:block;
	 text-align:center;
}
.sponsors-title span {
   display:inline-title;
}
.sponsors-wrap {
    width:90%;
		margin:0 auto;
		max-width:1380px;
}
.sponsor-logo {
padding:0px 5px;
}
.sponsor-logo img {
border:2px solid #f2f2f2;
}
.logo-inner {
    display:none;
}
.logo-inner.slick-initialized {
   display:block;
}

.head-wrap, .logo, .header, .est-date, .logo-img, nav {
	transition: all 400ms ease-in-out 0s !important;
}


#mega-menu-wrap-header-menu #mega-menu-header-menu > li.mega-menu-item > a.mega-menu-link {
	transition: all 400ms ease-in-out 0s !important;
}


#mega-menu-header-menu li.mega-align-bottom-left:last-child a {
	background: #EA095F !important;
	height: 40px !important;
	line-height: 40px !important;
	width: 160px !important;
	text-align: center !important;
	padding: 0px !important;
	color: #fff !important;
	border-radius: 99px !important;
	margin: 0 0 0 20px !important;
	font-weight: 700 !important;
}
#mega-menu-header-menu li.mega-align-bottom-left:last-child a:hover {
	background: #74BEFF !important;
}
#mega-menu-header-menu li.mega-align-bottom-left:last-child {
    margin:0 !important;
}
#post-404 {
    text-align:center;
}
@media only screen and (max-width:1180px) {
.logo-col {
    display:none;
}
}
@media only screen and (max-width:900px) {
.foot-logo {
	width: 220px;
	margin: 0px auto;
}
.footcol {
	width: 100%;
	margin:0 auto 20px auto;
	max-width:300px;
	text-align:center;
	float:none;
}
.footcol.footright {
	width: 100%;
	margin:0 auto 0px auto;
	max-width:300px;
	text-align:center;
	float:none;
}
}
.tribe-common--breakpoint-full.tribe-events .tribe-events-c-top-bar__datepicker-desktop, .tribe-events-c-top-bar__datepicker-mobile {
	font-size: 16px !important;
}
/*------------------------------------*\
    DOWNLOADS
\*------------------------------------*/
.page-downloads {
    margin-top: 50px;
    background: #fff;
    padding: 20px;
    border-radius: 10px;
    border: 2px solid #74BEFF;
}
.page-downloads ul {
  list-style: none;
  padding: 0px;
  margin: 0px;
}
.page-downloads ul li {
  border-bottom: 1px solid #e8e8e8;
  padding: 0;
  position: relative;
}
.page-downloads ul li:last-child {
    border-bottom:0 none;
}
.page-downloads ul li a {
    display:block;
		font-weight:700;
		padding: 15px 45px 15px 15px;
}
.page-downloads ul li i {
  color: #74BEFF;
  position: absolute;
  right: 15px;
  top: 18px;
}
.page-downloads ul li a:hover {
    background:#EA095F;
    color: #fff;
    border-radius: 5px;
}
/*------------------------------------*\
    HOME
\*------------------------------------*/
.intro-bar {
	padding: 80px 0px;
	text-align: center;
	max-width: 650px;
	width: 95%;
	margin: 0 auto;
}
h1 {
	font-size: 34px;
	line-height: 36px;
}

.clr {
  clear: both;
}
.home-text h1 {
	margin: 0px 0px 30px 0px;
	text-align: left !important;
	color:#fff;
}
.intro-bar h1 {
	margin: 0 0 30px 0;
	color: #4059ad;
}
.home-main {
    position:relative;
		max-width:100%;
		width:100%;
		padding:0;
}
.home-section {
    display:table;
		height:500px;
		margin:0 auto;
		z-index:99;
		position:relative;
}
.home-text {
	width: 50%;
	display: table-cell;
	vertical-align: middle;
	padding: 100px 10%;
	font-size: 16px;
	text-align: justify;
	line-height: 26px;
	background: #4059ad;
	color: #fff;
}
.home-image {
	width: 50%;
	display: table-cell;
	vertical-align: middle;
	padding: 100px 2.5% 100px 2.5%;
	font-size: 18px;
	text-align: justify;
	line-height: 26px;
	background: #f2f2f2;
	text-align: center;
	background-size: cover !important;
	background-position: center center !important;
}
.home-calendar h2 {
	font-size: 36px;
	max-width: 250px;
	margin: 0 auto 20px auto;
	line-height: 30px;
	color: #EA095F;
}
.cal-title {
  margin: 0px 0px 10px 0px;
}
.cal-date {
  font-size: 85%;
}


/*------------------------------------*\
    SPLASH
\*------------------------------------*/
.home-splash .slides {
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
margin:0px;
padding:0px;
}
.home-splash.loading .slides {
display:none;
}
.home-splash .slides li {
height: 100%;
background-size: cover !important;
background-position: center center !important;
}
.home-splash .slides li div{
height: 100%;
background-position: center center;
background-size: cover !important;
}
.splash {
	position: relative;
	background: #4059ad;
}
.home-splash.flexslider {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
.splash-grid {
	display: grid;
	height: 100%;
	grid-template-columns: 1fr;
	z-index: 999;
	position: ;
}
.splash-wrap {
	display: table;
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	height: calc(50vh + 110px);
	min-height: 400px;
	position: relative;
	z-index: 999;
	background: rgb(0, 6, 136, 0.1);
}
.announcement-bar {
  text-align: center;
  padding: 20px 2.5%;
  background: rgba(234,9,95,1);
  color: #fff;
  z-index: 1019;
  width: 100%;
}
.announcement-bar .ann_button {
  background: #fff;
  display: inline-block;
  padding: 2px 15px;
  border-radius: 99px;
  margin: 0 0 0 10px;
  font-size: 100%;
  font-weight: 700;
}
.splash-text {
	width: 100%;
	display: table-cell;
	vertical-align: middle;
	position: relative;
	z-index: 99;
	padding: 0px 5%;
	background: rgba(0,0,0,0.2);
	background: linear-gradient(90deg, rgba(0,0,0,0.70) 0%, rgba(0,0,0,0.20) 30%, rgba(255,255,255,0) 50%, rgba(255,255,255,0) 75%);
}
h1.splash-title {
	margin: 0px 0px 20px 0px !important;
	font-size: 75px;
	line-height: 63px;
}
.splash-intro {
	font-size: 140%;
}
.splash-text-wrap {
	background: transparent;
	width: auto;
	float: none;
	text-align: left;
	color: #fff;
	border-left: 15px solid #ea095f;
	padding: 0 0 0 30px;
	margin: 0 auto;
	max-width: 1380px;
}
.page-splash.no-image {
  height: auto;
  min-height: 0;
  background: #EA095F;
}
.page-splash.no-image .splash-inner {
  min-width: ;
  height: auto;
  padding: 0px;
}
.page-splash.no-image .title-bar {
  position: relative;
  text-align: ;
  top: auto;
  padding: 30px 0px;
}
.page-splash.no-image .title-inner {
	background: rgba(255,255,255,1);
}


/*------------------------------------*\
    BUTTONS
\*------------------------------------*/
.link_button {
	width: 100%;
	max-width: 230px;
	height: 50px;
	display: block;
	line-height: 50px;
	font-weight:700;
	text-align: center;
	color: #fff;
	background: #74BEFF;
	border-radius: 99px;
	margin: 30px auto 0 auto;
	font-size: 16px;
}
.link_button:hover {
	background: #FFF;
	color: #4059ad;
}
.home-buttons .link_button {
	display: inline-block;
	margin-top: 20px;
	width: calc(50% - 8px);
	margin:20px 16px 0px 0px;
	min-width:170px;
}
.home-buttons .link_button + .link_button {
  margin: 20px 0 0 0;
  background: #EA095F;
}
.home-buttons .link_button + .link_button:hover {
	background: #FFF;
	color: #4059ad;
}

.intro-bar .link_button {
	background: #ea095f;
}
.intro-bar .link_button:hover {
	background: #74beff;
	color:#fff;
}
/*------------------------------------*\
	NEWS
\*------------------------------------*/

.front-news {
list-style:none;
width:100%;
margin:0 auto;
padding:0px;
clear:both;
}
.news-wrap {
}
.news-wrap .slick-slide {
	margin: 0 15px;
	text-align: center;
	background: #fff;
	padding: 0 0 30px 0;
	border-radius: 20px;
	overflow: hidden;
	border-bottom: 2px solid rgba(0,0,0,0.1);
}
.news-wrap .slick-list {
      margin: 0 -15px;
}
.news-wrap .slick-slide img {
    width:100%;
}
.news-wrap h4 {
	padding: 0px;
	text-align: center;
	margin: 0px 0px 30px 0px;
	text-transform: inherit;
	font-size: 30px;
	line-height: 28px;
	color:#4059ad;
}
.news-wrap .slick-prev {
	height: 50px;
	position: absolute;
	top: 50%;
	left:-80px;
	width: 50px;
	text-align: center;
	line-height: 50px;
	margin-top:-25px;
	background: #74beff;
	font-size: 15px;
	color: #fff;
	padding: 0px;
	border: 0 none;
	border-radius: 149px;
	transition: all 400ms ease-in-out 0s;
}
.news-wrap .slick-next {
	height: 50px;
	position: absolute;
	top: 50%;
	right: -80px;
	width: 50px;
	text-align: center;
	line-height: 50px;
	margin-top: -25px;
	background: #74beff;
	font-size: 15px;
	color: #fff;
	padding: 0px;
	border: 0 none;
	border-radius: 149px;
	transition: all 400ms ease-in-out 0s;
}
.news-wrap .slick-prev:hover, .news-wrap .slick-next:hover {
background:#4059AD;
}

.news-date {
	margin: 25px 0px 0px 0px;
	display: block;
}
.news-bar {
   background:#f2f2f2;
	 padding:80px 0px;
}
.news-wrap .slick-slide img {
	border-radius: 10px;
}

h3.news-title-loop {
	margin: 3px 0px 0px 0px;
	line-height: 22px;
	color: #4059AD;
	padding: 0px 2.5%;
}
.news-date {
  color: #74BEFF;
	padding: 0px 2.5%;
}
.news-date a {
  color: #74BEFF;
}
.form-bar + .news-bar, .google-maps + .news-bar {
	border: 0 none !important;
}

.news-wrap {
	padding: 0px 80px !important;
	position: relative;
	width: 95%;
	margin: 0 auto;
	max-width: 1380px;
}
/*------------------------------------*\
    LOOP
\*------------------------------------*/
.title-inner .news-date {
  color: #fff !important;
  padding: 0;
}
.title-inner .news-date a {
  color: #fff !important;
}
.category-main {
	max-width: 100%;
	background: #f2f2f2;
	padding: 50px 0px;
	width: 100%;
}
.category-main section {
	max-width:1380px;
	margin:0 auto;
	width: 95%;
}
.news-loop {
 list-style:none;
 padding:0;
 margin:0;
 overflow:hidden
}
.news-loop li {
text-align:center;
 background:#fff
}
.news-loop li img {
 width:100%
}
div.pagination {
 clear:both;
 text-align:center;
 padding:10px 0
}
.pagination span {
	padding: 10px 15px;
	display: inline-block;
	margin: 0 2px;
	color: #fff;
	background: #74BEFF;
}
.pagination a {
	padding: 10px 15px;
	display: inline-block;
	margin: 0 2px;
	color: #fff;
	background: #EA095F;
}
.pagination a:hover {
 background:#4059AD;
 color:#fff
}
.news-loop li img {
   border-radius:10px;
}

.post-splash img {
	width: 900px;
	max-width: 900px;
	margin: 0px -50px 30px -50px;
	border-radius:10px;
}

.feat-image-wrap {
	background-size: cover !important;
	background-position: center center !important;
}
.wp-block-image img {
	margin: 20px 0px;
	border-radius: 10px;
}
.wp-block-gallery {
	margin: 20px 0px !important;
}
.wp-block-gallery .wp-block-image img {
	margin: 0px;
}
 .news-loop  {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 30px;
	margin-bottom:40px;
}
.news-loop li {
	/* margin: 0 15px; */
	text-align: center;
	background: #fff;
	padding: 0 0 30px 0;
	border-radius: 20px;
	overflow: hidden;
	border-bottom: 2px solid rgba(0,0,0,0.1);
}
@media only screen and (max-width:1199px) {
 .news-loop  {
  grid-template-columns: repeat(3, 1fr);
}
}
@media only screen and (max-width:960px) {
 .news-loop  {
  grid-template-columns: repeat(2, 1fr);
}
}
@media only screen and (max-width:550px) {
 .news-loop  {
  grid-template-columns: 1fr;
}
}


/*------------------------------------*\
    CALENDAR
\*------------------------------------*/

.upcoming-cal {
 list-style:none;
 padding:0;
 margin:0;

}
.upcoming-cal .upcoming-single {
 border-bottom:2px solid #cdf0ff;
 padding:8px 0
}
.cal-date {
	font: 400 16px/20px 'Rubik',sans-serif;
	color: #74beff;
	display: block;
}
h4.cal-title {
 font:700 18px/22px 'Rubik',sans-serif;
 color:#fff;
 padding:0;
 margin:0;
 white-space:nowrap;
 overflow:hidden;
 text-overflow:ellipsis
}

.cal-link {
  width:100%;
	max-width: 230px;
	height: 50px;
	border-radius: 99px;
	font-weight: 700;
	text-align: center;
	line-height: 50px;
	background: #ea095f;
	font-size: 16px;
	color: #fff;
	text-transform: inherit;
	padding: 0px;
	display: block;
	margin: 30px auto 0 auto;
}

.cal-link:hover {
     background:#74BEFF;
		 color:#fff;
}
.upcoming-wrap {
	padding: 80px;
	float: none;
	position: relative;
	margin: 0 auto;
	width:95%;
	max-width:1380px;
	align-content: center;
}
.upcoming-wrap .slick-list {
	margin: 0 -15px;
}
.upcoming-wrap h2 {
	font: 702 30px/28px 'Rubik',sans-serif;
	padding: 0;
	text-align: inherit;
	margin: 0;
	color:#4059ad;
	text-transform: inherit;
	text-align: center;
	width: 100%;
	display: block;
	padding: 0px 2.5%;
	margin: 0 auto 30px auto;
}
.upcoming-cal {
	text-align: center;
  padding:0px;
}
.upcoming-cal .slick-prev {
	height: 50px;
	position: absolute;
	top: 50%;
	left:-80px;
	width: 50px;
	text-align: center;
	line-height: 50px;
	margin-top:-25px;
	background: #74beff;
	font-size: 15px;
	color: #fff;
	padding: 0px;
	border: 0 none;
	border-radius: 149px;
	transition: all 400ms ease-in-out 0s;
}
.upcoming-cal .slick-next {
	height: 50px;
	position: absolute;
	top: 50%;
	right: -80px;
	width: 50px;
	text-align: center;
	line-height: 50px;
	margin-top: -25px;
	background: #74beff;
	font-size: 15px;
	color: #fff;
	padding: 0px;
	border: 0 none;
	border-radius: 149px;
	transition: all 400ms ease-in-out 0s;
}
.upcoming-cal .slick-prev:hover, .upcoming-cal .slick-next:hover {
background:#4059AD;
}

.upcoming-cal .upcoming-single {
	padding: 0 20px;
	border: 0 none;
	margin: 0px 10px;
	background: #4059ad;
	height: 140px;
	display: grid !important;
	align-content: center;
	border-radius: 20px;
}

.tribe-events-list .type-tribe_events {
 border-bottom:2px solid #cdf0ff !important;
 margin:0;
 padding:2.25em 0
}
.tribe-events-list .tribe-events-list-event-title {
 font:400 24px/22px 'Rubik',sans-serif !important;
 color:#0d1f50 !important;
 padding:0 !important;
 margin:0 !important
}
.tribe-events-loop .tribe-events-event-meta {
 font-size:16px !important;
 font-weight:400 !important;
 line-height:1 !important;
 text-transform:uppercase !important;
 color:#58c0ee !important
}
.tribe-events-list .tribe-events-venue-details {
 margin:0
}
.tribe-events-list .time-details,
.tribe-events-list .tribe-events-venue-details {
 display:block !important;
 line-height:1 !important;
 margin:0 !important
}
.tribe-events-loop .tribe-events-event-meta {
 background:0 0 !important;
 border:0 none !important;
 margin-top:10px !important;
 padding:0 !important
}
.tribe-events-list .tribe-events-venue-details {
 border:0 none !important;
 margin-top:0 !important;
 padding:0 !important
}
.cal-date {
	font: 400 16px/20px 'Rubik',sans-serif;
	color: #fff;
	display: block;
}
@media only screen and (max-width:980px) {
.splash-grid {
	grid-template-columns: 1fr;
	display: block;
}
.splash-wrap {
	height: 400px;
	min-height: 400px;
}
h1.splash-title {
	margin: 0px 0px 15px 0px !important;
	font-size: 55px;
	line-height: 53px;
}
}
@media only screen and (max-width:480px) {
h1.splash-title {
	margin: 0px 0px 15px 0px !important;
	font-size: 40px;
	line-height: 40px;
}
.splash-text-wrap {
	border-left: 10px solid #ea095f;
	padding: 0 0 0 20px;
}
.splash-intro {
	font-size: 120%;
}
}
@media only screen and (max-width:400px) {
h1.splash-title {
	margin: 0px 0px 15px 0px !important;
	font-size: 34px;
	line-height: 33px;
}
}
/*------------------------------------*\
    PAGE ROWS
\*------------------------------------*/
.single .form-bar {
	background: #f2f2f2 !important;
}
.text-row h2, .full-row-wrap h2, .intro-row-wrap h2, .row-wrap h2, h3.form-title {
	font-size: 32px;
	line-height: 32px;
	margin: 0px 0px 30px 0px;
}
.row-wrap {
	padding: 0px;
}
.row-section .row-wrap:nth-child(2n+2) {
	background: #f2f2f2;
}
.intro-row {
	padding: 70px;
}
.intro-row-wrap {
	max-width: 700px;
	margin: 0 auto;
	text-align: center;
	font-size: 120%;
	width:95%;
}
.page-row-wrap {
	width: 100%;
	margin: 0 auto;
}
.page-row {
  position: relative;
  display: table;
  height: 600px;
	width:100%;
}
.text-row {
	padding: 50px 10%;
	display: table-cell;
	vertical-align: middle;
}
.page-row.text-right .text-row {
	padding: 50px 5%;
}
.image-row {
  display: table-cell;
  width: 50%;
  height: 500px;
  background-size: cover !important;
  background-position: center center !important;
}
.intro-row-wrap h1 {
	margin: 0 0 30px 0;
	font-size: 50px;
	line-height: 50px;
}
.page-row.text-left {
  padding: 0 50% 0 0;
}
.page-row.text-left .image-row {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 50%;
  height: 100%;
}
.row-section .page-row-bg:nth-child(2n+2) {
	background: #f2f2f2;
}
.row-button {
	display: block;
	width: 100%;
	max-width: 240px;
	text-align: center;
	font-size: 16px;
	line-height: 56px;
	margin: 30px 0 0 0;
	border:2px solid #1dc0ea;
	background: #1dc0ea;
	color: #fff;
	border-radius: 99px;
}
.row-button:hover {
  color:#3f334d;
	border:2px solid #1dc0ea;
  background:transparent;
}
.row-button.blue-row-button {
  margin: 30px auto 0px auto;
  border: 2px solid #fff;
}
.row-button.blue-row-button:hover {
  background: #fff;
  color: ;
  color: #000;
}
.button-holder .row-button {
  display: inline-block !important;
  margin-right: 10px;
	margin-top:10px;
}

.row-section .page-row-bg:nth-child(2n+2) .row-button {
	background: #1dc0ea;
	border:1px solid #1dc0ea;
	color: #fff;
}
.row-section .page-row-bg:nth-child(2n+2) .row-button:hover {
	background: transparent;
	color: #3f334d;
}
.intro-row-wrap .row-button {
	margin: 30px auto 0px auto !important;
}
.full-row {
  padding: 100px 2.5%;
}
.full-row-wrap {
  max-width: 800px;
  margin: 0 auto;
}
.text-wrap h3 {
	color: #000;
	font-size: 26px;
	line-height: 30px;
	font-weight: 300;
}
.text-wrap ul {
  list-style: none;
  padding: 0px;
  border-top: 1px dotted #13839f;
  margin: 20px 0px;
}
.text-wrap ul li {
  border-bottom: 1px dotted #13839f;
  padding: 15px 20px;
}
.row-section .light {
	background: #fff;
}
.row-section .medium {
	background: #f2f2f2;
	color: #484848;
}
.row-section .dark {
	background: #eb4e1f;
	color:#fff;
}
.row-section .medium .row-button {
	background: #009fdd;
	color:#fff;
}
.row-section .medium .row-button:hover {
	background: #fff;
	color:#009fdd;
}
.row-section .dark .row-button {
	background: #fff;
	color:#be3b14;
}
.row-section .dark .row-button:hover {
	background: #be3b14;
	color:#fff;
}
.page-row.text-left .image-row {
	border-right: 0px !important;
}
.blue-bar-wrap h3 i {
	display: block;
	font-size: 60px;
	margin: 0 auto 20px auto;
}
.question-intro {
	text-align: center;
	margin: 0px auto 50px auto;
}
.row-wrap.center-text .full-row-wrap {
  text-align: center;
}
.row-wrap.center-text .full-row-wrap .row-button {
  margin: 30px auto 0px auto;
}
.row-wrap.blue-bar {
  background: #1dc0ea;
  padding: 80px 0px;
}
.blue-bar-wrap {
  width: 95%;
  margin: 0 auto;
  max-width: 600px;
  text-align: center;
  font-size: 110%;
  color: #fff;
  text-transform: ;
  line-height: 130%;
}
.blue-bar-wrap h3 {
	font-size: 32px;
	line-height: 32px;
	margin: 0 0 20px 0;
	padding: 0;
	color: #fff;
}
.text-wrap p:last-child {
	margin: ;
	margin-bottom: 0px;
}
.text-wrap h4 {
	font-size: 28px;
	margin: 0 0 20px 0;
	font-weight: 700;
	text-transform: uppercase;
}
.tablepress tfoot th, .tablepress thead th {
	background-color: #1dc0ea !important;
	color: #fff !important;
}

/*------------------------------------*\
    LISTS
\*------------------------------------*/

.front-services {
  background: #fff;
  padding: 70px 0px;
}
.front-services-wrap {
  text-align: center;
	margin: 0px auto 0 auto;
	max-width: 1410px;
	width: calc(95% + 30px);
	position:relative;
}
.front-services-wrap h3 {
	padding: 0px;
	text-align: left;
	margin: 0px 0px 20px 15px;
	text-transform: none;
	font: 400 40px/50px 'Rubik', sans-serif;
	color: #2a1718;
}
.front-services-wrap .slick-prev {
height:50px;
position:absolute;
top:-70px;
right:75px;
width:50px;
text-align:center;
line-height:48px;
background:transparent;
border:1px solid #7A8B99;
font-size:15px;
color:#7A8B99;
border-radius:99px;
padding:0px;
}
.front-services-wrap .slick-next {
height:50px;
position:absolute;
top:-70px;
right:15px;
width:50px;
text-align:center;
line-height:48px;
background:transparent;
border:1px solid #7A8B99;
font-size:15px;
color:#7A8B99;
border-radius:99px;
padding:0px;
}
.front-service-title {
   font: 400 45px/40px 'Rubik', sans-serif;
	 padding: 0px;
	 margin: 0px 0px 30px 0px;
}
.service-intro {
	font-size: 120%;
	font-weight: 700;
}
.front-links {
  list-style: none;
  padding: 0px;
  margin: 0px 0px -20px 0px;
}
.front-links li {

  padding:0px 15px;

}
.front-links li a {
	display: table;
	height: 120px;
	width: 100%;
	padding: 0px 10px;
   background:#7A8B99;
	color: #fff;

	font-size: 20px;
	line-height: 22px;
}
.front-links li a:hover {
	background: #f2f2f2;
	color: #484848;
}
.front-links li a span {
   display:table-cell;
	 width:100%;
	 height:100%;
	 text-align:center;
	 vertical-align:middle;
}
/*------------------------------------*\
    LISTS
\*------------------------------------*/
.list-row {
	padding: 50px 0px;
}
.list-wrap {
  width: 1380px;
  margin: 0 auto;
  max-width: 95%;
  text-align: center;
}
.row-list {
  list-style: none;
  padding: 0px;
  margin: 0px;
  border-bottom: 1px solid #ddd;
}
.row-list li {
  padding: 10px;
  border-top: 1px solid #ddd;
}
.single-list-wrap {
  margin: 0 auto;
  max-width: 460px;
}
.list-grid {
  float: left;
}
.double-list-wrap {
  max-width: 920px;
  margin: 0 auto;
  overflow: hidden;
}
.double-list-wrap .list-grid {
  width: calc(50% - 15px);
  float: left;
  margin: 0px 30px 0px 0px;
}
.double-list-wrap .list-grid:last-child {
  margin: 0px;
}
.triple-list-wrap {
  max-width: 1380px;
  margin: 0 auto;
  overflow: hidden;
}
.triple-list-wrap .list-grid {
  width: calc(33.3% - 20px);
  float: left;
  margin: 0px 30px 0px 0px;
}
.triple-list-wrap .list-grid:last-child {
  margin: 0px;
}

/*------------------------------------*\
    VIDEO
\*------------------------------------*/

.video-row {
  padding: 50px 0px;
  text-align: center;
}
.video-wrap {
  width: 95%;
  max-width: 940px;
  margin: 0 auto;
}
.video-text {
  margin-top: 30px;
}
.embed-container { 
    position: relative;
		padding-bottom: 56.25%; 
		height: 0; 
		overflow: hidden; 
		max-width: 100%; 
} 
.embed-container iframe, .embed-container object, .embed-container embed { 
    position: absolute;
		top: 0; 
		left: 0; 
		width: 100%; 
		height: 100%; 
}


/*------------------------------------*\
    STAFF
\*------------------------------------*/

.staff-wrap {
  width: 95%;
  margin: 0 auto;
  max-width: 1380px;
  border-top: 2px solid #74BEFF;
  padding: 50px 0px;
  overflow: hidden;
}
.staff-list {
  list-style: none;
  padding: 0px;
  margin: 0px;
}
.staff-details {
  padding: 20px 0px;
  text-align: center;
}
.staff-details span {
  display: block;
}
.staff-name {
  font-weight: 700;
}
.staff-job-title {
	color: #74BEFF;
}
.staff-list li {
  float: left;
  width: calc(25% - 22.5px);
  margin: 0 30px 0 0;
}
.staff-list li:nth-child(4n + 4) {
  margin-right: 0px;
}
.staff-list img {
	border-radius: 20px;
	height: auto;
}

@media only screen and (max-width:767px) {
.staff-list li {
  float: left;
  width: calc(50% - 15px);
  margin: 0 30px 0 0;
}
.staff-list li:nth-child(2n + 2) {
  margin-right: 0px;
}
}
/*------------------------------------*\
    ACCORDION
\*------------------------------------*/

.accordion, .accordion * {
 -webkit-box-sizing:border-box; 
 -moz-box-sizing:border-box; 
 box-sizing:border-box;
}
.accordion {
	overflow: hidden;
	border-radius: 0px;
	max-width: 1000px;
	margin: 0 auto;
}
.accordion-section-title {
	width: 100%;
	padding: 25px 40px;
	display: inline-block;
	transition: all linear 0.15s;
	text-decoration: none;
	background: transparent;
	/* text-decoration: none; */
	color: #3f334d;
	border: 1px solid #1dc0ea;
	border-radius: 10px;
	margin: 0px 0px 20px;
	text-align: center;
	position: relative;
}

.accordion-section-title.active, .accordion-section-title:hover {
	background: #1dc0ea;
	text-decoration: none;
	color: #fff;
}
 
.accordion-section:last-child .accordion-section-title {
 border-bottom-color:white;
 padding-bottom:2px;
}
.accordion-section-content {
	padding: 25px;
	display: none;
	text-align: justify;
	position: relative;
	padding: 30px;
	border: 1px dashed #1dc0ea;
	margin: 0 0 20px 0;
	border-radius: 10px;
	background: #fff;
}
.bc-intro {
    text-align:center;
}
.accordion-section-title::before {
	content: "\f055";
	font-family: "Font Awesome 5 Pro";
	position: absolute;
	right: 20px;
}
.accordion-section-title.active::before {
	content: "\f056";
}
.page-layout .row-block:nth-child(2n+2)  .accordion-section-content {
	background: #fff;
}
.answer-text, .answer-example {
    display:none;
}
.question-text, .example-text {
	border: 1px solid #1dc0ea;
	border-radius: 10px;
	padding: 50px 30px;
	position: relative;
	text-align: center;
}
.show-button, .show-example {
  display: block;
  width: 100%;
  max-width: 240px;
  text-align: center;
  font-size: 16px;
  line-height: 58px;
  margin: -30px auto 0px auto;
  border: 1px solid #1dc0ea;
  background: #fff;
  color: #3f334d;
  border-radius: 99px;
  position: relative;
}
.row-section .row-wrap:nth-child(2n+2) .show-button, .row-section .row-wrap:nth-child(2n+2) .show-example {
	background: #f2f2f2;
}
.show-button:before {
   content:"View Answer";
}
.show-button.hide:before {
   content:"Hide Answer";
}
.show-example:before {
   content:"View Example";
}
.show-example.hide:before {
   content:"Hide Example";
}
.show-button:hover, .show-example:hover, .row-section .row-wrap:nth-child(2n+2) .show-button:hover, .row-section .row-wrap:nth-child(2n+2) .show-example:hover {
	background: #1dc0ea;
	color: #fff;
	cursor: pointer;
}
.question-text:before {
	font-family:"Font Awesome 6 Pro";
  content: "\3f";
  background: #1dc0ea;
  border-radius: 99px;
  width: 60px;
  height: 60px;
  display: block;
  text-align: center;
  color: #fff;
  line-height: 60px;
  font-size: 32px;
  position: absolute;
  text-align: ;
  top: -30px;
  left: 50%;
  margin-left: -30px;
}
.example-text:before {
	font-family:"Font Awesome 6 Pro";
  content: "\f129";
  background: #1dc0ea;
  border-radius: 99px;
  width: 60px;
  height: 60px;
  display: block;
  text-align: center;
  color: #fff;
  line-height: 60px;
  font-size: 32px;
  position: absolute;
  text-align: ;
  top: -30px;
  left: 50%;
  margin-left: -30px;
}
.answer-text, .answer-example {
  position: relative;
  padding: 30px;
  border: 1px dashed #1dc0ea;
  margin: 30px 0 0 0;
  border-radius: 10px;
}

.bc-intro {
	display: block;
	margin: 0 0 30px 0;
}
/*------------------------------------*\
    LISTS
\*------------------------------------*/

.front-services {
  background: #fff;
  padding: 50px 0px;
}
.front-services-wrap {
  text-align: center;
	margin: 0px auto 0 auto;
	max-width: 1410px;
	width: calc(95% + 30px);
	position:relative;
}
.front-services-wrap h3 {
	padding: 0px;
	text-align: left;
	margin: 0px 0px 32px 15px;
	text-transform: none;
	font: 400 40px/40px 'Rubik', sans-serif;
	color: #2a1718;
}

.front-services-wrap .slick-prev {
height:60px;
position:absolute;
top:-80px;
right:75px;
width:50px;
text-align:center;
line-height:60px;
background:#2a1718;
font-size:15px;
color:#fff;
padding:0px;
border:0 none;
}
.front-services-wrap .slick-next {
height:60px;
position:absolute;
top:-80px;
right:15px;
width:50px;
text-align:center;
line-height:60px;
background:#2a1718;
font-size:15px;
color:#fff;
padding:0px;
border:0 none;
}
.front-service-title {
   font: 400 45px/40px 'Rubik', sans-serif;
	 padding: 0px;
	 margin: 0px 0px 30px 0px;
}
.service-intro {
	font-size: 120%;
	font-weight: 700;
}
.front-links {
  list-style: none;
  padding: 0px;
  margin: 0px 0px -20px 0px;
}
.front-links li {

  padding:0px 15px;

}
.front-links li a {
   display:table;
	 height:250px;
	 width:100%;
	 padding:0px 10px;
	   background: #bf1e2e;
	 color:#fff;
}
.front-links li a:hover {
   background:#2a1718;
	 color:#fff;
}
.front-links li a span {
   display:table-cell;
	 width:100%;
	 height:100%;
	 text-align:center;
	 vertical-align:middle;
}

/*------------------------------------*\
    PAGE SPLASH
\*------------------------------------*/
.page-splash {
	display: block;
	width: 100%;
	height: calc(20vh + 110px);
	min-height: 400px;
	position: relative;
	overflow: hidden;
	background: #4059ad;
}
.page-splash-blue {
    height:auto;
		padding:60px 2.5% 60px 2.5%;
		background:#2a56a5;
	margin-top:124px;
}
.title-bar {
	position: absolute;
	display: grid;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, rgba(0,0,0,0.70) 0%, rgba(0,0,0,0.20) 50%, rgba(255,255,255,0) 75%, rgba(255,255,255,0) 100%);
	color: #fff;
	text-align: center;
	margin: 0 auto;
	align-content: center;
}
.title-bar.no-image {
   background:0 none;
}
.title-bar-single{ 
	 color:#fff;
	 display:table;
	 width:100%;
	 height:auto;
	 color:#fff;
	 background:#f7cfda;
}
.title-bar .news-date {
  margin: 0px !important;
}
.title-bar h1 {
	margin: 0px;
	font-weight: 700 !important;
	font-size: 40px;
	line-height: 45px;
}
.title-inner {
	background: transparent;
	display: block;
	padding: 0px !important;
	margin: 0 auto;
	max-width: 100%;
}
.title-wrap {
	display: block;
	width: 100%;
	/* padding: 40px 0px !important; */
	height: auto;
	vertical-align: middle;
	text-align: left;
	max-width: 800px;
	margin: 0 auto;
	background: transparent;
	width: 95%;
	float: none;
	text-align: left;
	color: #fff;
	border-left: 10px solid #ea095f;
	padding: 20px 0 20px 30px;
}
.splash-inner {
	height: calc(20vh + 110px);
	width: 100%;
	display: block;
	background-position: center center !important;
	background-size: cover !important;
	min-height: 400px;
}
.page-splash-blue .splash-inner {
	height: auto;
}
.splash-overlay {
   position:absolute;
	 top:0px;
	 left:0px;
	 width:100%;
	 height:auto;
	 opacity:0.75;
}

.page-splash-blue .title-wrap {
	padding: 0px;
}
.page-splash-blue .title-bar {
	position: relative;
}
a.scroll-link i {
	position: absolute;
	bottom: 20px;
	font-size: 36px;
	color: #fff;
	left: 50%;
	margin-left: -18px;
}
.scroll-anchor {
	position: absolute;
	bottom:0px;
	left: 0px;
	width: 100%;
	height: 0px;
}


@media only screen and (max-width:480px) {
.page-splash {
	height: 300px;
	min-height: 300px;
}
.splash-inner {
	height: 300px;
	min-height: 300px;
}
.splash-wrap {
	height: calc(20vh + 110px);
	min-height: 300px;
}
.title-wrap {
	padding: 20px 0 20px 20px;
}
.title-bar {
	background: linear-gradient(90deg, rgba(0,0,0,0.70) 0%, rgba(0,0,0,0.20) 75%, rgba(255,255,255,0) 95%, rgba(255,255,255,0) 100%);
}
}

@media only screen and (max-width:340px) {
.page-splash {
	height: 200px;
	min-height: 200px;
}
.splash-inner {
	height: 200px;
	min-height: 200px;
}
.splash-wrap {
	height: calc(20vh + 110px);
	min-height: 300px;
}
.title-wrap {
	padding: 20px 0 20px 20px;
}
.title-bar h1 {
	margin: 0px;
	font-weight: 700 !important;
	font-size: 30px;
	line-height: 35px;
}
.title-bar {
	background: linear-gradient(90deg, rgba(0,0,0,0.70) 0%, rgba(0,0,0,0.20) 75%, rgba(255,255,255,0) 95%, rgba(255,255,255,0) 100%);
}
}

/*------------------------------------*\
    FORM
\*------------------------------------*/

.contact-main {
  max-width: 100%;
  width: 100%;
  padding: 0;
  /*! display: grid; */
  /*! grid-template-columns: 1fr 1fr; */
}
.contact-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  content-align: center;
  align-content: center;
  height: 100%;
}
.contact-content {
  display: grid;
  align-content: center;
  padding: 0px 5%;
}
.contact-content h2 {
  font-size: 32px;
  line-height: 32px;
  margin: 0 0 20px 0;
}
.form-bar {
	padding: 50px 0px;
	background: #4059AD;
	color: #fff;
}
.form-wrap {
  max-width: 800px;
  margin: 0 auto;
  width: 90%;
}
.form-title {
  padding: 0px;
  margin: 0px 0px 30px 0px;
  text-align: center;
}
.form-desc {
  display: block;
  text-align: center;
  margin: 0px 0px 30px 0px;
}
.page-form {
  background: #c5d3d5;
  padding: 50px 0px;
  text-align: center;
}
.page-form-wrap {
  margin: 0 auto;
  max-width: 800px;
  width: 95%;
}
.form-wrap-title {
  font-size: 36px;
  line-height: 36px;
  margin: 0px 0px 30px 0px;
  padding: 0px;
}
.form-wrap-intro {
  max-width: 600px;
  margin: 0 auto 30px auto;
  display: block;
}
.gform_wrapper.gravity-theme input[type="color"], .gform_wrapper.gravity-theme input[type="date"], .gform_wrapper.gravity-theme input[type="datetime-local"], .gform_wrapper.gravity-theme input[type="datetime"], .gform_wrapper.gravity-theme input[type="email"], .gform_wrapper.gravity-theme input[type="month"], .gform_wrapper.gravity-theme input[type="number"], .gform_wrapper.gravity-theme input[type="password"], .gform_wrapper.gravity-theme input[type="search"], .gform_wrapper.gravity-theme input[type="tel"], .gform_wrapper.gravity-theme input[type="text"], .gform_wrapper.gravity-theme input[type="time"], .gform_wrapper.gravity-theme input[type="url"], .gform_wrapper.gravity-theme input[type="week"], .gform_wrapper.gravity-theme select, .gform_wrapper.gravity-theme textarea {
	padding: 15px !important;
	border: 1px solid #ccc !important;
	border-radius: 5px;
}
.gform_button.button {
	display: block;
	width: 100%;
	max-width: 230px;
	text-align: center;
	font-size: 16px;
	line-height: 50px;
	margin: 10px auto 0px auto;
	border: 0 none;
	background: #74BEFF;
	color: #fff;
	border-radius: 99px;
	transition: all 400ms ease-in-out 0s;
	font-weight: 700;
}
.gform_button.button:hover {
  color:#fff;
  background:#EA095F !important
}
.gform_validation_errors h2 {
	text-align: center;
}
.gform_wrapper .gfield_required {
	color:#74BEFF !important;
}
.follow-icons h3 {
  font-size: 28px;
  line-height: 28px;
  margin: 20px 0px 30px 0px;
  color: #4059ad;
}
.follow-icons a {
  font-size: 26px;
  margin: 0px 15px 0px 0px;
  color: #74beff;
}
.follow-icons a:hover {
  color: #ea095f;
}
/*------------------------------------*\
    SLICK
\*------------------------------------*/

.slick-prev.slick-arrow {
}
.slick-next.slick-arrow {
}  .slick-slider
{
position: relative;
display: block;
box-sizing: border-box;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-touch-callout: none;
-khtml-user-select: none;
-ms-touch-action: pan-y;
touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}
.slick-list
{
position: relative;
display: block;
overflow: hidden;
margin: 0;
padding: 0 !important;
}
.slick-list:focus
{
outline: none;
}
.slick-list.dragging
{
cursor: pointer;
cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list
{
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
-o-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
}
.slick-track
{
position: relative;
top: 0;
left: 0;
display: block;
margin-left: auto;
margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
display: table;
content: '';
}
.slick-track:after
{
clear: both;
}
.slick-loading .slick-track
{
visibility: hidden;
}
.slick-slide
{
display: none;
float: left;
height: 100%;
min-height: 1px;
}
[dir='rtl'] .slick-slide
{
float: right;
}
.slick-slide img
{
display: block;
}
.slick-slide.slick-loading img
{
display: none;
}
.slick-slide.dragging img
{
pointer-events: none;
}
.slick-initialized .slick-slide
{
display: block;
}
.slick-loading .slick-slide
{
visibility: hidden;
}
.slick-vertical .slick-slide
{
display: block;
height: auto;
border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
display: none;
}

/*------------------------------------*\
    HOME BOXES
\*------------------------------------*/
.home-boxes {
	width: 95%;
	margin: 30px auto;
	max-width: 1270px;
	padding: 0px 50px;
	position: relative;
}
.home-box-image {
	height: 200px;
	background-size: cover !important;
	background-position: center center !important;
}

.home-box-content {
  background: #1c5895;
  padding: 20px;
  color: #fff;
	text-align:center;
}
.home-box-content h3 {
  margin: 0px 0px 10px 0px;
	color:#63b0f0;
}
.home-box-content p {
  margin: 0;
  padding: 0;
}

.home-boxes .cat-prev.slick-arrow {
	position: absolute;
	left: 0px;
	top: calc(50% - 10px);
	background: transparent;
	border: 0 none;
	font-size: 20px;
	z-index:99;
	color:#1c5895;
}
.home-boxes .cat-next.slick-arrow {
	position: absolute;
	right: 0px;
	top: calc(50% - 10px);
	background: transparent;
	border: 0 none;
	font-size: 20px;
	z-index:99;
	color:#1c5895;
}

  /* the slides */
.home-boxes  .slick-slide {
      margin: 0 15px;
  }

  /* the parent */
.home-boxes .slick-list {
      margin: 0 -15px;
  }

@media only screen and (max-width:550px) {
.home-boxes {
	padding: 0px 40px;
}
.home-boxes .cat-next.slick-arrow {
	width: 40px;
}
.home-boxes .cat-prev.slick-arrow {
	width: 40px;
}
}

/*------------------------------------*\
    MAILCHIMP
\*------------------------------------*/
.nl-bar {
	background: #000;
	padding: 40px 0px;
	text-align: center;
	clear: both;
	margin: 0px 0px 0px 0px;
}
.nl-wrap {
   max-width:500px;
	 width:95%;
	 margin:0 auto;
}
.nl-title {
	padding:0px;
	display:block;
	margin:0px 0px 20px 0px;
	text-align:center;
	color:#fff;
}
.sub-button {
	width: 160px;
	height: 60px;
	background: #1dc0ea;
	border: 0 none;
	color: #fff;
	border-radius: 99px;
	margin-left: 10px;
	line-height: 56px;
	border: 2px solid #1dc0ea;
	transition: all 400ms ease-in-out 0s;
	vertical-align: top;
}
.sub-button:hover {
   background: transparent;
   color:#000;
}
.sub-input {
  width: calc(100% - 170px);
  height: 60px;
  padding: 0px 15px;
  border: 0 none;
	vertical-align:top;
}

/*------------------------------------*\
    MISC
\*------------------------------------*/

::selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-webkit-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-moz-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
	margin:5px 20px 20px 0;
}
.aligncenter,
div.aligncenter {
	display:block;
	margin:5px auto 5px auto;
}
.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
a img.alignnone {
	margin:5px 20px 20px 0;
}
a img.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.aligncenter {
	display:block;
	margin-left:auto;
	margin-right:auto;
}
.wp-caption {
	background:#FFF;
	border:1px solid #F0F0F0;
	max-width:96%;
	padding:5px 3px 10px;
	text-align:center;
}
.wp-caption.alignnone {
	margin:5px 20px 20px 0;
}
.wp-caption.alignleft {
	margin:5px 20px 20px 0;
}
.wp-caption.alignright {
	margin:5px 0 20px 20px;
}
.wp-caption img {
	border:0 none;
	height:auto;
	margin:0;
	max-width:98.5%;
	padding:0;
	width:auto;
}
.wp-caption .wp-caption-text,
.gallery-caption {
	font-size:11px;
	line-height:17px;
	margin:0;
	padding:0 4px 5px;
}
.sticky {

}
.bypostauthor {

}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {
		background:transparent !important;
		color:#000 !important;
		box-shadow:none !important;
		text-shadow:none !important;
	}
	a,
	a:visited {
		text-decoration:underline;
	}
	a[href]:after {
		content:" (" attr(href) ")";
	}
	abbr[title]:after {
		content:" (" attr(title) ")";
	}
	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content:"";
	}
	pre,blockquote {
		border:1px solid #999;
		page-break-inside:avoid;
	}
	thead {
		display:table-header-group;
	}
	tr,img {
		page-break-inside:avoid;
	}
	img {
		max-width:100% !important;
	}
	@page {
		margin:0.5cm;
	}
	p,
	h2,
	h3 {
		orphans:3;
		widows:3;
	}
	h2,
	h3 {
		page-break-after:avoid;
	}
}
/*------------------------------------*\
    TRIBE
\*------------------------------------*/
.tribe-common--breakpoint-medium.tribe-events .tribe-events-l-container {
	position: relative;
	max-width: 800px !important;
	padding-left: 0px;
	padding-right: 0px;
	width: 95%;
}
.tribe-events-before-html {
  margin: 0px 0px 40px 0px !important;
  position: relative;
}
.tribe-events-before-html:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 110vw;
  background: #EA095F;
  height: 100%;
  margin-left: -55vw;
}

body.shiftnav-open::before {
	content: "";
	background: rgba(0,0,0,0.9);
	z-index: 99999;
	position: fixed !important;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	/* z-index: ; */
}

.tribe-events .tribe-events-calendar-list__event-datetime-wrapper, .tribe-events .tribe-events-calendar-list__event-title {
	margin: 0 !important;
}
.tribe-events .tribe-events-calendar-list__event-datetime {
	color: #74BEFF !important;
}
.tribe-events-l-container {
	padding-bottom: 50px !important;
}

.tribe-common .tribe-common-h5, .tribe-common .tribe-common-h6 {
	font-family: Rubik !important;
}
.tribe-common .tribe-common-h7, .tribe-common .tribe-common-h8 {
	font-family: Rubik !important;
}



.quick-bar {
  background: #f5f6f7;
  padding: 30px 0px;
}
.quick-wrap {
	width: 95%;
	max-width: 1380px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 200px calc(100% - 200px);
}
.link-scroll-wrap a {
	background: #ea095f;
	border-radius: 99px;
	display: inline-block;
	width: ;
	text-align: center;
	padding: 15px 5px;
	margin: 0px 5px;
	color: #fff;
}
.link-scroll-wrap {
  padding: 0px 40px;
  position: relative;
}
.link-prev.slick-arrow {
  position: absolute;
  left: 0;
  top: 0;
  width: 30px;
  height: 50px;
  background: transparent;
  border: 0 none;
}
.link-scroll-wrap {
  padding: 0px 40px;
  position: relative;
}
.link-next.slick-arrow {
  position: absolute;
  right: 0;
  top: 0;
  width: 30px;
  height: 50px;
  background: transparent;
  border: 0 none;
}
.quick-title h3 {
	font-size: 26px;
	line-height: 50px;
	margin: 0;
	padding: 0;
	color: #4059ad;
}

/*------------------------------------*\
    DOWNLOADS
\*------------------------------------*/
.downloads-section {
  padding-top: 40px;
  margin-top: 70px;
  position: relative;
}
.downloads-section:before {
  position: absolute;
  content: "";
  width: 100%;
  left: 0px;
  top: 0px;
  border-top: 1px dashed #ea095f;
}
.downloads-title {
	color: #4059ad;
	text-align: center;
	margin: 0 0 30px 0;
	font-size: 20px;
	line-height: 30px;
}
.download-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 20px;
	margin:0 0 30px 0;
}
.download-list a {
	height: 80px;
	background: #f2f2f2;
	border-radius: 10px;
	padding: 10px20px;
	text-align: center;
	align-content: center;
	display: grid;
	/* font-weight: bold; */
	color: #4059ad;
}
.download-list a:nth-child(odd):last-of-type {
  grid-column: 1 / -1;
}
.download-list a:hover {
	background: #EA095F;
	color: #fff;
}
.content-section h2:first-child {
	margin-top: 0px;
}

/* Blocks 
--------------------------------------------- */
.wp-block-button__link.wp-element-button {
	background: #4059ad;
	font-weight: 700;
	font-size: 100%;
	margin-top: 10px;
	  color:#fff;
}
.wp-block-button__link.wp-element-button:hover {
	background: #74beff;
   color:#fff;
}
.wp-block-media-text {
	min-height: 450px;
	color:#fff;
	background:#4059AD;
} 
.wp-block-heading {
	color: #4059ad;
}
.wp-block-media-text .wp-block-heading {
	color: #fff;
}
.wp-block-media-text a {
    color:#fff;
} 
.alignfull {
	margin: 0px calc(50% - 50vw);
	max-width: 100vw;
	width: 100vw;
}
.alignwide {
	margin: 50px -290px;
	max-width: 1380px;
	width: 1380px;
}
* + .alignfull {
	margin-top: 50px;
}
.alignfull + * {
	margin-top: 50px;
}
.alignfull + .alignfull {
    margin-top:0;
		margin-bottom:0;
}
.wp-block-columns.alignfull {
	padding-top: 80px;
	padding-bottom: 80px;
}
@media (max-width: 1440px) {
.alignwide {
	margin: 50px calc(50% - 45vw);
	max-width: 90vw;
	width: 90vw;
}

}
@media (max-width: 920px) {
	.alignwide {
		margin: 40px auto;
		max-width: 800px;
		width: 100%
	}
}

.wp-block-image:first-child img {
	margin: ;
	margin-top: 0px;
}
/*------------------------------------*\
    MOBILE
\*------------------------------------*/


@media only screen and (max-width:1280px) {
.home-text {
	padding: 2.5vw;
	font-size: 16px;
	text-align: justify;
	line-height: 24px;
}
}


@media only screen and (max-width:1000px) {
.home-text {
	width: 100%;
	float: none;
	padding: 40px 2.5%;
}
.upcoming-wrap {
	padding: 40px 80px;
	display: block;
}
.home-calendar {
  width: 100%;
  float: none;
	margin-top:30px;
  background: #74BEFF;
}
.home-section {
	display: block;
	height: auto;
	margin: 0 auto;
	z-index: 99;
	position: relative;
	padding-top: 300px;
}
.home-image {
	width: 100%;
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	position: absolute;
	height: 300px;
}
}


@media only screen and (max-width:920px) {
h1 {
	font-size: 28px;
	line-height: 30px;
}
.text-row h2, .full-row-wrap h2, .intro-row-wrap h2, .row-wrap h2, h3.form-title {
	font-size: 28px;
	line-height: 30px;
	margin: 0px 0px 30px 0px;
}
.news-wrap h4 {
	font-size: 28px;
	line-height: 36px;
}
}
@media only screen and (max-width:840px) {
.quick-wrap {
	width: 95%;
	max-width: 1380px;
	margin: 0 auto;
	display: block;
	grid-template-columns: 100%;
}
.quick-title h3 {
	font-size: 26px;
	line-height: 26px;
	margin: 0;
	padding: 0;
	color: #4059ad;
	text-align: center;
	margin: 0 0 20px 0;
}
}
@media only screen and (max-width:767px) {
.download-list {
  grid-template-columns: 1fr;
	grid-gap:20px;
}
.contact-section {
  display: grid;
  grid-template-columns: 1fr;
  content-align: center;
  align-content: center;
  height: 100%;
}
.contact-content {
  display: grid;
  align-content: center;
  padding: 50px 2.5%;
}
.news-bar {
	background: #f2f2f2;
	padding: 50px 0px;
}
.footer {
	padding: 50px 0px;
}
.form-wrap {
	width: 95%;
}
.contact-content h2 {
	font-size: 28px;
	line-height: 28px;
	margin: 0 0 20px 0;
}
.follow-icons h3 {
	font-size: 24px;
	line-height: 24px;
	margin: 20px 0px 30px 0px;
	color: #4059ad;
}
}


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




.news-wrap h4 {
	margin: 0px 0px 31px 0px;
	font-size: 27px;
	line-height: 27px;
	max-width: 150px;
}

.splash-text-wrap {
	padding: 0px 5%;
}
.news-wrap .slick-prev {
	height: 50px;
	top: -70px;
	right: 60px;
	width: 50px;
	line-height: 50px;
}
.news-wrap .slick-next {
	height: 50px;
	top: -70px;
	right: 0px;
	width: 50px;
	line-height: 50px;
}
}

.google-maps {
    position:relative;
		width:100%;
		height:400px;
}
.google-maps iframe {
    position:absolute;
		top:0;
		left:0;
		width:100%;
		height:100%;
}
.map-anchor {
     position:absolute;
		 top:-80px;
		 width:100%;
		 height:1px;
		 opacity:0;
	   display:block;
}
.map-button {
  margin: 10px auto !important;
  display: block;
  width: 100% !important;
  max-width: 190px !important;
}
.map-button a {
  border: ;
  background: #74BEFF !important;
}
.map-button a:hover {
  background: #FF8427 !important;
}
.calendar-download {
    position:relative;
		width:95%;
		max-width:800px;
		margin:0 auto;
}
.calendar-link {
	position: absolute;
	top: -130px;
	font-size: 14px;
	line-height: 22px;

	font-weight: 700;
	border: 0;
	cursor: pointer;
	display: inline-block;
	height: auto;

	background-color: #EA095F;
	border: 1px solid #EA095F;
	border-radius: 5px;
	text-align: center;
	transition: var(--tec-transition);
	color: #fff;
	padding: 11px 20px;
	width: 100%;
	max-width: 200px;
}

@media only screen and (max-width:767px) {
.calendar-link {
	top: -70px;
	width: 100%;
	max-width: 100%;
}
.calendar-download {
	position: relative;
	width: 95%;
	max-width: 800px;
	margin: 0 auto;
	height: 20px;
}
.header {
	height: 100px;
}

.head-wrap {
	height: 100px;
}
.logo-img {
	max-width: 80px;
	top: 12px;
}

.school-title {
	display: block;
	position: absolute;
	left: 92px;
	font-size: 17px;
	font-weight: 700;
	line-height: 18px;
	max-width: 140px;
	color: #4059ad;
	top: 31px;
}
.header .shiftnav-toggle-button {
	top: 14px;
}
}
@media only screen and (max-width:767px) {
.splash-text {
	background: linear-gradient(90deg, rgba(0,0,0,0.70) 0%, rgba(0,0,0,0.20) 50%, rgba(255,255,255,0) 75%, rgba(255,255,255,0) 95%);
}
.quick-link-wrap {
	display: none;
}
.quick-link-bar {
	background: #4059ad;
	padding: 20px;
	color: #fff;
	height: 50px;
}
.header-tel {
	top: -46px;
	width: 100%;
	text-align: center;
}
.upcoming-wrap {
	padding: 40px 50px;
}
.news-wrap {
	padding: 0px 50px !important;
}
.upcoming-cal .slick-prev, .news-wrap .slick-prev {
	height: 30px;
	top: 50%;
	left: -50px;
	width: 30px;
	line-height: 30px;
	margin-top: -15px;
	font-size: 12px;
}
.upcoming-cal .slick-next, .news-wrap .slick-next {
	height: 30px;
	top: 50%;
	right: -50px;
	width: 30px;
	line-height: 30px;
	margin-top: -15px;
	font-size: 12px;
}
}
