
/* Theme Variables */
:root {
    /* Typography */
    --font-family-body: rig-sans, "Open Sans", Helvetica, Arial, sans-serif;
    --font-family-heading: rig-sans, "Open Sans", Helvetica, Arial, sans-serif;
    
    --font-size-h1: 56px;
    --font-size-h2: 40px;
    --font-size-h3: 32px;
    --font-size-h4: 26px;
    --font-size-h5: 18px;
    --font-size-h6: 16px;
    --font-size-paragraph: 17px;
    
    /* Colors */
    --primary-color: #004785;
    --secondary-color: #00794c;
    --tertiary-color: #55616d;
    --accent-color: #ccab00;
    --dark-color: #000000;
    --light-color: #ffffff;
    --input-border-colour:#c9c9c9;
    
    /* Border Radius & Padding */
    --btn-border-radius: 7px;
    --input-border-radius: 5px;
    --input-padding: 10px 28px;

    /* Primary Button */
    --primary-btn-bg: #004785;
    --primary-btn-color: #ffffff;
    --primary-btn-border-color: #004785;
    
    /* Primary Button Hover */
    --primary-btn-bg-hover: #0c3a5a;
    --primary-btn-color-hover: #ffffff;
    --primary-btn-border-color-hover: #004785;
    
    /* Secondary Button */
    --secondary-btn-bg: #00794c;
    --secondary-btn-color: #ffffff;
    --secondary-btn-border-color: #00794c;
    
    /* Secondary Button Hover */
    --secondary-btn-bg-hover: #004785;
    --secondary-btn-color-hover: #ffffff;
    --secondary-btn-border-color-hover: #004785;
 
    /* Button One */
    --button-one-bg: #00794c;
    --button-one-color: #ffffff;
    --button-one-border-color: #00794c;

    /* Button One Hover */
    --button-one-bg-hover: #004785;
    --button-one-color-hover: #ffffff;
    --button-one-border-color-hover: #004785;

    /* Button Two */
    --button-two-bg: #007DA3;
    --button-two-color: #ffffff;
    --button-two-border-color: #007DA3;

    /* Button Two Hover */
    --button-two-bg-hover: #55616D;
    --button-two-color-hover: #ffffff;
    --button-two-border-color-hover: #55616D;

    /* Button Three */
    --button-three-bg: #004785;
    --button-three-color: #ffffff;
    --button-three-border-color: #fff;

    /* Button Three Hover */
    --button-three-bg-hover: #0c3a5a;
    --button-three-color-hover: #ffffff;
    --button-three-border-color-hover: #fff;

    /* Button Four */
    /* --button-four-bg: #ffffff; */
    --button-four-color: #00799E;
    /* --button-four-border-color: #ffffff; */

    /* Button Four Hover */
    /* --button-four-bg-hover: #ffffff; */
    --button-four-color-hover: #55616D;
    /* --button-four-border-color-hover: #ffffff; */
    
    /* Layout Settings */
    --card-columns: 33.333%;
    --filter-columns: 25%;
}
/* Global Typography */
/*** Global Theme ***/
body {
  background:#fff;
  color: var(--dark-color);
  line-height:1.5;
  font-family:var(--font-family-body);
  font-weight:500;
  font-size:var(--font-size-paragraph);
}
/** Typography **/
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
  font-family:var(--font-family-heading);
  font-weight:600;
  letter-spacing:normal;
}
.h1, h1 {
    font-size: var(--font-size-h1);
}
.h2, h2 {
    font-size: var(--font-size-h2);
}
.h3, h3 {
    font-size: var(--font-size-h3);
}
.h4, h4, .hero-banner .block-image-text p {
    font-size: var(--font-size-h4);
}
.h5, h5 {
    font-size: var(--font-size-h5);
}
.h6, h6 {
    font-size: var(--font-size-h6);
}
.hero-banner h1, .hero-banner p {
    text-shadow: 0 1px 10px rgb(0 0 0 / 50%);
}
/* Responsive Typography */
@media (max-width: 768px) {
    .h1, h1 {
        font-size: calc(var(--font-size-h1) * 0.8);
    }
    .h2, h2 {
        font-size: calc(var(--font-size-h2) * 0.8);
    }
    .h3, h3 {
        font-size: calc(var(--font-size-h3) * 0.8);
    }
    .h4, h4, .hero-banner .block-image-text p {
        font-size: calc(var(--font-size-h4) * 0.8);
    }
    .h5, h5 {
        font-size: calc(var(--font-size-h5) * 0.8);
    }
    .h6, h6 {
        font-size: calc(var(--font-size-h6) * 0.8);
    }
}

@media (max-width: 576px) {
    .h1, h1 {
        font-size: calc(var(--font-size-h1) * 0.6);
    }
    .h2, h2 {
        font-size: calc(var(--font-size-h2) * 0.6);
    }
    .h3, h3 {
        font-size: calc(var(--font-size-h3) * 0.6);
    }
    .h4, h4, .hero-banner .block-image-text p {
        font-size: calc(var(--font-size-h4) * 0.6);
    }
    .h5, h5 {
        font-size: calc(var(--font-size-h5) * 0.6);
    }
    .h6, h6 {
        font-size: calc(var(--font-size-h6) * 0.6);
    }
}
/* .hero-h1 h1 {
  font-size:56px;
}
.hero-h2 h2 {
  font-size:46px;
} */
.hero-text .block-image-text {
    margin-right: calc(.5 * var(--bs-gutter-x));
    margin-left: calc(.5 * var(--bs-gutter-x));
}
a,
a:visited,
a:active,
a:focus {
    color: var(--primary-color);
    font-weight: 500;
}
a:hover {
    color: var(--primary-color);
    font-weight: 500;
}
/** Navigation **/
.nav-item {
  margin:0px;
  margin-top: auto !important;
  margin-bottom: auto !important;
}
.nav-link,
.nav-link:active,
.nav-link:visited,
.nav-link:focus {
 color: var(--dark-color) !important;
 font-size: 16px;
 font-weight: 600;
 padding: 8px 20px !important;
}
.nav-link:hover {
  font-weight: 600;
}
/* Logos */
.navbar-brand-logo {
    width: 100%;
    max-width: 155px;
}
.footer-brand-logo {
    width: 100%;
    max-width: 155px;
}
@media (max-width: 576px) { 
    .navbar-brand-logo {
        max-width: 115px;
    }
}
@media (max-width: 576px) { 
    .footer-brand-logo {
        max-width: 155px;
    }
}
/* ==== UTILITY / HELPERS ================= */
/* horizontal scroll fix */
.hero-no-gutter .page-row-container .col-md-12,
.no-gutters .page-row-container .col-md-12 {
    padding-left: 0;
    padding-right: 0;
}
.hero-no-gutter .page-row-container .block-image,
.no-gutters .page-row-container .block-image {
    margin-left: 0;
    margin-right: 0;
}
.bg-color-f6f6f6 {
    background-color: #f6f6f6;
}
.img-border-radius .block-image img,
.img-border-radius .block-image-cover {
    border-radius: 0.875rem;
}
/*** Buttons ***/
.btn, button, a.button, a.btn {
    font-weight: 600 !important;
    font-family: inherit;
    text-transform: inherit;
    line-height: 1.5;
    padding: var(--input-padding);
    -webkit-transition: background .25s linear;
    -moz-transition: background .25s linear;
    -o-transition: background .25s linear;
    transition: background .25s linear;
    border-radius: var(--btn-border-radius) !important;
    font-size: 15px;
    text-transform:inherit;
}
.btn-primary  {
  background:var(--primary-btn-bg);
  color:var(--primary-btn-color);
  border:1px solid var(--primary-btn-border-color);
}
.btn-primary:hover,
.btn-primary:first-child:active,
.btn-primary:focus-visible {
  background:var(--primary-btn-bg-hover);
  color:var(--primary-btn-color-hover);
  border:1px solid var(--primary-btn-border-color-hover);
}
.btn-primary:visited,
.btn-primary:active,
.btn-primary:focus {
  background:var(--primary-btn-bg);
  color:var(--primary-btn-color);
  border:1px solid var(--primary-btn-border-color);
}
.btn-success {
  background:var(--secondary-btn-bg);
  color:var(--secondary-btn-color);
  border:1px solid var(--secondary-btn-border-color);
}
.btn-success:hover {
  background:var(--secondary-btn-bg-hover);
  color:var(--secondary-btn-color-hover);
  border:1px solid var(--secondary-btn-border-color-hover);
}
.btn-success:visited,
.btn-success:active,
.btn-success:focus {
  background:var(--secondary-btn-bg);
  color:var(--secondary-btn-color);
  border:1px solid var(--secondary-btn-border-color);
}
.btn-info {
  background:var(--primary-btn-bg);
  color:var(--primary-btn-color);
  border:1px solid var(--primary-btn-border-color);
}
.btn-info:hover,
.btn-info:visited,
.btn-info:active,
.btn-info:focus{
  background:var(--primary-btn-bg-hover);
  color:var(--primary-btn-color);
  border:1px solid var(--primary-btn-border-color-hover);
}
/* Candidate setting buttons */
.label {
    background: var(--secondary-btn-bg);
    color: var(--secondary-btn-color);
    border: 1px solid var(--secondary-btn-bg);
    padding: 4px 12px;
    font-size: 13px !important;
    margin-bottom: 4px;
    display: inline-block;
    border-radius: var(--btn-border-radius);
}
/* custom buttons */
a.button.button1 {
  background:var(--button-one-bg);
  color:var(--button-one-color);
  border:1px solid var(--button-one-border-color);
}
a.button.button1:hover {
  background:var(--button-one-bg-hover);
  color:var(--button-one-color-hover);
  border:1px solid var(--button-one-border-color-hover);
}
a.button.button2 {
  background:var(--button-two-bg);
  color:var(--button-two-color);
  border:1px solid var(--button-two-border-color);
}
a.button.button2:hover {
  background:var(--button-two-bg-hover);
  color:var(--button-two-color-hover);
  border:1px solid var(--button-two-border-color-hover);
}
a.button.button3 {
  background:var(--button-three-bg);
  color:var(--button-three-color);
  border:2px solid var(--button-three-border-color);
}
a.button.button3:hover {
  background:var(--button-three-bg-hover);
  color:var(--button-three-color-hover);
  border:2px solid var(--button-three-border-color-hover);
}
a.button.button4 {
  background:var(--button-four-bg);
  color:var(--button-four-color);
  /* border:1px solid var(--button-four-border-color); */
  font-size: 18px;
    padding: 3px 25px 0px 2px;
}
a.button.button4:hover {
  color:var(--button-four-color-hover);
}
a.button.button4:after {
    content: '';
    background: url(https://fgcu.edu/_resources/images/marine-right.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    display: inline-block;
    position: absolute;
    height: 22px;
    width: 14px;
    margin-bottom: -2px;
    margin-left: 6px;
}
a.button.button4:hover:after {
    background: url(https://fgcu.edu/_resources/images/slate-right.png);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    display: inline-block;
    position: absolute;
    height: 22px;
    width: 14px;
    margin-bottom: -2px;
    margin-left: 6px;
}
/* Input group fix */
.input-group input, .input-group-btn button {
    height: auto !important;
    padding: var(--input-padding) !important;
}
/* Bootstrap Card */
.card {
    border: 1px solid var(--card-border-colour);
    border-radius: var(--border-radius);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
    margin-bottom: 6px;
    background: var(--card-background-colour);
    padding:var(--card-padding);
}
/* Search Bar */
.job-search-control .near-me-control {
    margin-left: 0;
}
.job-search-control .input-group-btn {
    margin-left: 15px !important;
}
@media (max-width: 576px) {
  .job-search-control .form-control,
  .job-search-control .input-group-btn,
  .job-search-control .input-group-btn .btn,
  .job-search-control .btn,
  .job-search-control .col-2 {
    width: 100%;
  }
  .job-search-control .input-group-btn {
    margin: 5px 0 !important;
  }
}
.call-to-action .form-control {
    border-radius: var(--border-radius);
}
/** Job Search page **/
/* Job Search table */
.job-search-filter-header {
    font-size: 20px !important;
}
/* Job Search cards */
@media (min-width: 992px) {
  .job-search-results-card-col {
    flex: 0 0 var(--card-columns);
    max-width: var(--card-columns);
  }
}
@media (min-width: 768px) {
.job-search-results-dropdown-filter-col {
    flex: 0 0 var(--filter-columns);
    max-width: var(--filter-columns);
  }
}
.job-search-results-card {
    border: 1px solid #ececec;
    border-radius: var(--border-radius);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
    margin-bottom: 6px;
}
.job-search-results-card-title a {
    color: #000000;
    font-size: 22px;
}
.job-search-results-footer {
    background: var(--card-background-colour);
    border-top: 0px;
}
.job-search-results-footer a {
    background: var(--card-background-colour);
    color: var(--primary-color);
}
.card {
    background: var(--card-background-colour);
}
/** Job Search page filters / inputs */
.block-job-search-results .job-search-results .job-search-filter-groups {
    width: 100%;
}
.job-search-control input {
    border-radius: var(--input-border-radius) !important;
    border: 1px solid var(--input-border-colour);
}
.job-search-dropdown-filters select {
    padding: 10px 10px;
    margin-bottom: 6px;
    border-radius: var(--input-border-radius);
    border: 1px solid var(--input-border-colour);
    appearance: none; 
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 100%; 
    color:var(--dark-color);
    background-color:var(--light-color);
}
.badge {
    background-color: var(--primary-color) !important;
    border-radius: var(--border-radius);
    color: var(--light-color);
}
.page-item.active .page-link {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--light-color);
}
.page-link {
    color: var(--primary-color);
}
@media only screen and (max-width: 576px) {
	.pagination li:not(:first-child):not(:last-child) {
		display: none;
	}
}

/** Job Advert **/
/* Side panels */
.side-panel {
    box-shadow: 0 5px 9px 0 rgb(0 0 0 / 10%);
    padding: 40px 25px;
    margin-bottom: 20px;
    border-radius: 6px;
}
.side-panel .job-title {
    font-size: 22px !important;
    font-weight: 500 !important;
    margin-bottom: 10px !important;
}
.side-panel .job-field {
    color: #484848;
    font-size: 14px;
    font-weight: 600;
}
.side-panel h3 {
    font-size: 24px;
}
.side-panel .job-summary {
    margin-top: 2px;
    padding-top: 2px;
}
/* Jobs list content block card style */
.job-list-cards .jobs-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-left: -15px;
    margin-top: -15px;
    align-items: stretch;
}
.job-list-cards .job {
    background: #ffffff;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    padding: 30px;
    width: calc(33.333% - 30px);
    margin-left: 15px;
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    margin-bottom: 0px !important;
}
@media (max-width: 768px) {
    .job-list-cards .job {
        width: calc(50% - 30px);
    }
}
@media (max-width: 480px) {
    .job-list-cards .job {
        width: calc(100% - 30px);
    }
}
.job-list-cards .job .job-title {
    margin-bottom: 10px;
    color: #202e49  !important;
}
.job-list-cards .job-summary {
  padding-top: 12px;
  color: #444444 !important;
}
/* Jobs list content block table style */
.job {
    background: #ffffff;
    padding: 16px;
    padding-bottom: 0px;
    border-radius: 5px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
}
.job .job-title {
    margin-bottom: 10px;
    color: #202e49  !important;
}
.job-summary {
  padding-top: 12px;
  color: #444444 !important;
}
.block-jobs .job {
    margin-bottom: 16px;
}
/* Employee Referral Link */

/** CTAs **/
/** CTA select dropdowns **/
.selectize-control.multi .selectize-input>div {
	background-color: var(--primary-color);
	color: var(--light-color);
    border-radius: var(--border-radius);
}
.selectize-dropdown-content .option.active {
	background-color: var(--primary-color);
}
.selectize-input {
    border-radius: var(--border-radius);
}
.cta-left-align .block-call-to-action form {
  margin: 0 auto 0 0;
}
.cta-right-align .block-call-to-action form {
  margin: 0 0 0 auto;
}
/* Carousel */
.carousel-caption {
    position: relative;
    right: 0 !important;
    bottom: 1.25rem;
    left: 0 !important;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    color: #fff;
    text-align: center;
    padding-left: 40px;
    padding-right: 40px;
}
.carousel-control-prev-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000000'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}
.carousel-control-next-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000000'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}      
.carousel-control-prev-icon, .carousel-control-next-icon {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    background-repeat: no-repeat;
    background-position: 50%;
    background-size: 60% 60%;
    border-radius: 2rem;
    background-color: #FFF;
    padding: 2rem;
}
.carousel-item-caption-header {
    text-shadow: none !important;
    color: var(--dark-color) !important;
}
.carousel-item-caption-detail * {
    text-shadow: none !important;
    color: var(--dark-color) !important;
}
@media (min-width: 768px) {
	.carousel-control-prev, .carousel-control-next {
		width: 3%;
	}
}
/** Video **/
/*** video fixes ***/
@media (min-width: 576px) {
	.col-md-12 .clinch-video-player.video-js {
		height: 292px;
	}
	.col-md-8 .clinch-video-player.video-js {
		height: 292px;
	}
	.col-md-6 .clinch-video-player.video-js {
		height: 292px;
	}
	.col-md-4 .clinch-video-player.video-js {
		height: 292px;
	}
}
@media (min-width: 768px) {
	.col-md-12 .clinch-video-player.video-js {
		height: 392px;
	}
	.col-md-8 .clinch-video-player.video-js {
		height: 258px;
	}
	.col-md-6 .clinch-video-player.video-js {
		height: 190px;
	}
	.col-md-4 .clinch-video-player.video-js {
		height: 122px;
	}
}
@media (min-width: 992px) {
	.col-md-12 .clinch-video-player.video-js {
		height: 526px;
	}
	.col-md-8 .clinch-video-player.video-js {
		height: 348px;
	}
	.col-md-6 .clinch-video-player.video-js {
		height: 256px;
	}
	.col-md-4 .clinch-video-player.video-js {
		height: 166px;
	}
}
@media (min-width: 1200px) {
	.col-md-12 .clinch-video-player.video-js {
		height: 628px;
	}
	.col-md-8 .clinch-video-player.video-js {
		height: 414px;
	}
	.col-md-6 .clinch-video-player.video-js {
		height: 310px;
	}
	.col-md-4 .clinch-video-player.video-js {
		height: 200px;
	}
}
@media (min-width: 1400px) {
	.col-md-12 .clinch-video-player.video-js {
		height: 730px;
	}
	.col-md-8 .clinch-video-player.video-js {
		height: 482px;
	}
	.col-md-6 .clinch-video-player.video-js {
		height: 358px;
	}
	.col-md-4 .clinch-video-player.video-js {
		height: 234px;
	}
}
.vjs-youtube .vjs-poster {
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
.video-player-wrapper .vjs-poster img {
    object-fit: contain;
    height: inherit;
    width: 100%;
}
/** Teams **/
/*** Team Member Quote ***/
.team-member-bio {
    text-align: left !important;
}
.team-member-image {
    margin-bottom: 10px;
}
.team-member-bio .name {
    font-size: 17px;
    font-weight: 600;
}
.team-member-bio .title {

}
.team-member-bio .bio {

}
.team-member-bio .social-links i {
    margin-right: 8px !important;
}
/** Blogs **/
.posts-cards .posts-cards-cols {
    display: flex;
    flex-wrap: wrap;
    gap: inherit;
}
.posts-card {
  flex: 0 calc(33.33% - 2rem);
  margin: 1rem;
}
.posts-cards .posts-card {
   border-radius: 10px;
}
.posts-cards .posts-card-body {
    height: auto;
    padding: 20px 0px;
    background: rgba(236 236 236 / 0%);
}
.card {
    background: rgba(236 236 236 / 0%);
}

.card.process-card {
    background-color: #ffffff;
}
.posts-cards .posts-card .card-title {
    font-size: 18px;
    font-weight: 600;
}
.posts-cards .posts-card-link {
    color: #202e49 !important;
    font-weight: 600;
    font-size: 16px;
    margin-top: 10px;
    text-decoration: underline;
}
.badge.post-tag {
    background: #202e49 !important;
    padding: 6px 10px;
    font-weight: 600;
    text-transform: uppercase;
}
.posts-card-body .post-tags {
    display: none;
}
.posts-cards .posts-card-footer {
    padding: 10px 30px;
    background: none;
}
.posts-card-image {
    transition: transform 0.3s ease;
    border-radius: 8px;
}
@media only screen and (max-width: 768px) {
    .posts-cards .posts-cards-cols {
        flex-direction: column;
    }
}
/** FAQs Accordion **/
.accordion-item:first-of-type {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}
.accordion-item:last-of-type {
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
}
.accordion-item {
	color: #333333;
	background-color: #ffffff;
	border: 1px solid #333;
}
.accordion-item h2 {
    margin-bottom: 0;
}
.accordion-button:not(.collapsed) {
    color: #fff !important;
    background-color: var(--secondary-color);
    box-shadow: unset;
}
.accordion-item:first-of-type .accordion-button {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}
.accordion-button:focus {
	z-index: 3;
	border-color: transparent;
	outline: 0;
	box-shadow: unset;
}
.accordion-button {
	font-size: 16px;
	padding: 20px;
}
.accordion-body {
	padding: 20px;
    /* border-left: 4px solid var(--primary-color); */
    background: #FAFBFD;
    padding-left: 70px;
    padding-top: 30px;
    border-bottom-right-radius: 5px;
}
/* ==== FAQ CUSTOM STYLING ============ */
.faq-set .accordion-item {
    border-radius: 0px 10px 10px 0px !important;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
    border: none;
}
.faq-set .accordion-button {
    border-left: 8px solid var(--secondary-color);
    border-radius: 0px 8px 0px 0px !important;
}
/** Footer **/
footer {
  background:#004785;
  box-shadow: rgba(0, 0, 0, 0.1) 0px -4px 12px;
}
footer * {
  color:#fff;
}
footer a[href] {
    color: #fff;
}
.social a {
    font-size: 16px;
}
/** Candidate consent **/
.consent-modal .image-wrapper {
   width: 100%;
   text-align: left;
}
.consent-reject {
  
}
.consent-agree {
  
}

/* Candidate Settings */
.candidate-settings-panel {
    background-color: #f9f9f9;
    padding: 30px 42px;
}
.candidate-settings {
    background: #f0f0f0;
    margin: 10px 0px;
    padding: 50px;
}
.candidate-settings-panel i {
  color:var(--dark-color);
}
.candidate-settings-panel h3 {
    font-size: 22px;
}
/* Alignment & Spacing */
/* Vertical Alignment add my-auto to ROW */
.my-auto .col-md-6, .my-auto .col-md-8, .my-auto .col-md-4 {
    margin-top: auto !important;
    margin-bottom: auto !important;
}
/* adds padding to the bottom of every col */
@media (max-width: 768px) {
  .row>.col-md-2, .row>.col-md-3, .row>.col-md-4, .row>.col-md-6, .row>.col-md-8 {
    padding-bottom: 1.5rem !important;
  }
}
/* treat col-md-2 as col-md-4 on tablets and smaller desktops */
@media (min-width: 768px) and (max-width: 991px) {
  .col-md-2 {
    flex: 0 0 auto;
    width: 33.333333%; 
  }
}
/* text left alignment sits within container on fullwidth page */
@media (min-width: 576px) {
 .hero-banner .block-image-text * {
   width: 540px;
   margin-right:auto;
   margin-left:auto;
  }
}
@media (min-width: 768px) {
  .hero-banner .block-image-text * {
    width: 720px;
    margin-right:auto;
    margin-left:auto;
  }
}
@media (min-width: 992px) {
 .hero-banner .block-image-text * {
   width: 960px;
   margin-right:auto;
   margin-left:auto;
  }
}
@media (min-width: 1200px) {
 .hero-banner .block-image-text * {
   width: 1140px;
   margin-right:auto;
   margin-left:auto;
  }
}
@media (min-width: 1400px) {
  .hero-banner .block-image-text * {
    width: 1320px;
    margin-right:auto;
    margin-left:auto;
  }
}

/* AI Chat bot */
.chatbot-launcher {
background-color: var(--primary-color);
}
.chatbot-chat-window .chatbot-header {
color: #ffffff;
background-color: var(--primary-color);
}
.chatbot-message-content.sent .chatbot-message-text {
color: #ffffff;
background-color: var(--primary-color);
}
.chatbot-message-avatar .fa-circle {
color: var(--primary-color);
}
.chatbot-message-content.sent a[href] {
color: #ffffff;
}
turbo-frame.message-turbo-frame {
    .job-message {
        border: 1px solid var(--chatbot-message-shadow);
        border-radius: 15px;
        box-shadow: 0 2px 5px var(--chatbot-message-shadow);
        padding: 17px 20px;
    }
  .job-interested-btn {
    
  }
}

/* Spacing */

/** Mobile styles **/

/** Career Site CSS **/
.search-form-container h1 {
  padding-bottom:10px;
}
.search-form-container {
    position: relative;
    top: -100px;
    background: #f6f6f6;
    margin: 0 auto -85px;
    padding: 40px 60px 40px !important;
    border-radius: 10px;
    -webkit-box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}
.category-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    position: relative;
    background-image: url('https://d2nc0na9w8r5aj.cloudfront.net/public/uploads/b93e050e6c50adf7ff80f8b4125f6d23/images/files/5a2af693c03d50b401467de0abe45b91/medium/empty-uni-classroom.jpg?1726771650');
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 300px;
    padding: 20px;
    border-radius: 0.75rem;
    z-index: 1;
}
.category-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgb(0 58 99 / 65%);
    border-radius: 0.75rem;
    z-index: -1;
    transition: all .25s ease-in-out;
}
.category-card:hover::before {
    background-color: rgb(0 58 99 / 85%);
    transition: all .25s ease-in-out;
}
.category-card h3 {
    color: #fff;
    font-size: 2rem;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.category-squares-wrapper .col-md-3 {
  display: flex;
}

.category-squares-wrapper .category-card {
  width: 100%;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.category-squares-wrapper .block-html,
.category-squares-wrapper .page-block {
  height: 100%;
}

.category-squares-wrapper .page-block {
  display: flex;
  flex-direction: column;
}

.category-squares-wrapper .page-block p:last-child {
  margin-top: auto;
}

@media (min-width: 768px) and (max-width: 1400px)  {
.category-squares-wrapper .col-md-3 {
    width: 50%;
    max-width: 100%;
    padding-bottom: 1.5rem !important;
}
}
.benefit-card {
    background: #004785;
    padding: 22px;
    height: 100%;
    border-radius: 8px;
}
.benefit-card * {
    color: #fff;
    text-align: center;
}
.benefit-card img {
    width: 100%;
    height: auto;
    max-width: 90px !important;
}
/* ==== CUSTOM JOB CARDS - DESCRIPTIONS ON RIGHT ============ */
/* job search page card title link */
@media (min-width: 768px) {
    .job-search-results-card-col {
        flex: 0 0 100%;
        max-width: 100%;
        padding: 0;
    }
  }
.block-job-search-results .job-search-results .job-search-results-card {
    flex: 1;
}
.job-search-results .card {
    display: block;
    margin: 0px 15px 0px 15px;
}
.card-title.job-search-results-card-title {
    position: relative;
    display: inline-block;
    width: 70%;
}
.card-title .job-search-results-card-title a {
    font-size: 1.5rem;
    font-weight: 600;
    color: #000;
}
.card-title .job-search-results-card-title a:hover {
    font-size: 1.5rem;
    font-weight: 600;
    color: #173966;
    text-decoration:underline;
}
.card-title .job-search-results-card-title a:active {
    font-size: 1.5rem;
    font-weight: 600;
    color: #2C60B0;
    text-decoration:underline;
}

.block-job-search-results .job-search-results .job-search-results-card {
    padding: 0;
}
.card-body.job-search-results-card-body {
  padding-right: 0;
}
.card-text.job-search-results-summary {
    width: 75%
}
.job-component-details .job-component-list ul {
    margin-left: 0.5rem;
}
.check-check .job-component-details {
    float: right !important;
    display: flex;
    flex-direction: column;
    background-color: #F8F8F8;
  	width: 210px !important;
/*     margin-top: -73px; */
    margin-top: -17px;
    margin-bottom: 0;
    margin-left: 10px;
    border-radius: 0px 5px 5px 0px;
    border-left: 1px solid #EAEAEA;
  	border-top: 1px solid #EAEAEA;
    line-height: 2em;
    font-weight: 400 !important;
    padding: 60px 12px 70px 12px;
}
/* viewport larger than 768px */
@media (min-width: 768px) {
  /* keep asterisk(*) job card text inline and justified without wrapping under icon  */
  .job-component-icon-and-text i.fa-asterisk {
      max-width: 25%;
  }
  .job-component-icon-and-text span {
      display: inline-block;
      position: relative;
      vertical-align: top;
      max-width: 75%;
  }
}
/* viewport width less than 1200px */
@media (max-width: 1200px) {
  .job-search-results-container .page-row-container {
    width: 75%;
    max-width: 75%;
  }
  .check-check .job-component-details {
    float: right !important;
    position: absolute;
    bottom: 0;
    top: 0;
    display: inline-flex;
    flex-direction: column;
    background-color: #f8f8f8;
    width: auto;
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 18px;
    border-radius: 0px 5px 5px 0px;
    border-left: 1px solid #EAEAEA;
    border-top: 1px solid #EAEAEA;
    line-height: 2em;
    font-weight: 400 !important;
    padding: 40px 12px 25px 12px;
  }
  .check-check .card-text.job-search-results-summary {
    width: 70%;
  }
}
/* viewport width less than 992px */
@media (max-width: 992px) {
  .job-search-results-container .page-row-container {
    width: 90%;
    max-width: 90%;
  }
  /* FILTER JOBS BUTTON - WHEN SIDE FILTERS ARE HIDDEN */
  .job-search-results a.job-search-collapse {
    display: flex;
    font-size: 1.1rem !important;
    color: #fff;
    font-weight: 400;
    letter-spacing: 0.5px;
    background-color: #777;
    padding: 0.2rem 0.5rem;
    border-radius: 8px;
    margin: 0 0 0.5rem 0;
    width: 100%;
    justify-content: center;
  }
}
/* viewport width less than 768px */
@media (max-width: 768px) {
  .check-check .card-body.job-search-results-card-body {
    padding: 1rem;
  }
  .check-check .job-component-details  {
    float: none !important;
    position: relative;
    display: block;
    background-color: #F8F8F8;
    margin-top: 0;
    margin-bottom: 0.5rem;
    margin-left: -5px;
    border-radius: 0;
    border: none;
    border-top: 1px solid #EAEAEA;
    border-bottom: 1px solid #EAEAEA;
    padding: 0.5rem 0;
    width: 100% !important;
  }
  .check-check .card-title.job-search-results-card-title {
    width: 100%;
    line-height: 1.1;
  }
  .check-check .job-component-details .job-component-list li {
    line-height: 1.4;
    margin-bottom: 0.2rem;
  }
  .check-check .card-text.job-search-results-summary {
    width: 100%;
  }
}
.card-footer.job-search-results-footer a {
    font-weight: 700;
    color: #000;
}
.card-footer.job-search-results-footer a:hover {
    color: #173966;
    text-decoration:underline;
}
.card-footer.job-search-results-footer a:focus{
    color: #2C60B0;
    text-decoration:underline;
}