/*!   
 * Template Name: College Green - Bootstrap 5 Template for Education
 * Version: 1.0
 * Author: Xiaoying Riley
 * Copyright: 3rd Wave Media Ltd.
 * Website: http://themes.3rdwavemedia.com/
 * X: @3rdwave_themes
 * Best Buddy Dog Training - Custom CSS
 * Author: Shawn Hines
 * Copyright: 2026 Best Buddy Dog Training
 * Website https://www.bestbuddydogtraining.com
* theme main blue color choices: 2f7fc1,  3c709b
text colors:

*/html,
body {
    height: 100%;
}
body {
    font-size: 14px;
}
html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "open sans", arial, sans-serif;
    font-weight: 300;
}
.h1 {
    font-size: 26px;
}
.h2 {
    font-size: 22px;
}
.h3 {
    font-size: 18px;
}
.h4 {
    font-size: 16px;
}
.h5 {
    font-size: 14px;
}

p {
    color: #494949;
    line-height: 1.7;
    font-size: 1rem
    
}
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: #2C5F8A;
  color: #fff;
  padding: 10px 20px;
  z-index: 9999;
  font-weight: bold;
  text-decoration: none;
  transition: top 0.2s;
}
.skip-link:focus {
  top: 0;
}

a {
    color: #2f7fc1;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
    color: #365d7e;
}
a:focus {
    text-decoration: none;
}
a.theme-link {
    text-decoration: none;
    color: #2f7fc1;
    -webkit-transition: color .15s ease, text-decoration-color .15s ease;
    -moz-transition: color .15s ease, text-decoration-color .15s ease;
    transition: color .15s ease, text-decoration-color .15s ease;
    cursor: pointer;
}
a.theme-link:hover {
    color: #303030;
    text-decoration: none
}
a.silent-link{
color: #2f7fc1;
font-weight: 600;
-webkit-transition: all 0.4s ease-in-out;
-moz-transition: all 0.4s ease-in-out;
-ms-transition: all 0.4s ease-in-out;
-o-transition: all 0.4s ease-in-out;
text-decoration: none;
}
a.silent-link:hover{
color: #2f7fc1;
font-weight: 600;
-webkit-transition: all 0.4s ease-in-out;
-moz-transition: all 0.4s ease-in-out;
-ms-transition: all 0.4s ease-in-out;
-o-transition: all 0.4s ease-in-out;
text-decoration: none;
}
a.silent-link:active{
color: #2f7fc1;
font-weight: 600;
-webkit-transition: all 0.4s ease-in-out;
-moz-transition: all 0.4s ease-in-out;
-ms-transition: all 0.4s ease-in-out;
-o-transition: all 0.4s ease-in-out;
text-decoration: none;
}

#site-logo {
    max-height: 40px;
    /* padding-bottom: 24px; */
}

.blog-header {
    color: #2f7fc1;
    margin-top: 0;
    margin-bottom: 15px;
    font-style: normal;
    font-size: 28px;
}
.jobs-wrapper .custom-quote {
    border-left: 4px solid #2f7fc1;
    padding-left: 15px;
    padding-top: 10px;
    padding-bottom: 10px;
}
.jobs-wrapper .page-content .custom-quote p {
    font-size: 14px;
    color: #7c7c7c;
    line-height: 1.5;
}
.jobs-wrapper .page-content .custom-quote .svg-inline--fa {
    color: #2f7fc1;
    margin-right: 10px;
}
.jobs-wrapper .page-content .custom-quote .people {
    margin-top: 10px;
    margin-bottom: 0;
    font-size: 11px;
    color: #494949;
    font-style: normal;
}

.block-quote {
    height:auto; 
    margin-top:30px; 
    margin-bottom:30px; 
    padding:20px; 
    border-left:6px solid #2f7fc1; 
    background-color:#f9f9f9;
}
.btn,
a.btn {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    border-radius: 0;
    box-shadow: none;
    text-decoration: none;
}
/* [A11Y FIX] Restored visible focus indicators for keyboard navigation (WCAG 2.4.7) */
.btn:focus,
a.btn:focus {
    box-shadow: 0 0 0 0.2rem rgba(47, 127, 193, 0.5);
    outline: 2px solid #2f7fc1;
    outline-offset: 2px;
}
.btn .svg-inline--fa,
a.btn .svg-inline--fa {
    color: #fff;
    margin-right: 5px;
}
.btn .svg-inline--fa.fa-search,
a.btn .svg-inline--fa.fa-search {
    margin-right: 0;
}
.btn:hover,
a.btn:hover {
    text-decoration: none;
}
.btn-theme {
    background: #2f7fc1;
    border: 1px solid #2f7fc1;
    color: #fff;
}
.btn-theme:hover {
    background: #84aac9;
    border: 1px solid #84aac9;
    color: #fff;
}
a.btn-cta,
.btn-cta {
    background: #2f7fc1;
    color: #fff;
    padding: 10px 20px;
    font-size: 18px;
    line-height: 1.33;
    border-radius: 0;
    border: 1px solid #2f7fc1;
    font-family: "open sans", arial, sans-serif;
}
a.btn-cta:hover,
.btn-cta:hover {
    color: #fff;
    background: #2f506c;
    border: 1px solid #2f506c;
}
a.btn-cta .svg-inline--fa,
.btn-cta .svg-inline--fa {
    margin-right: 10px;
    font-size: 20px;
    color: #fff;
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #2f7fc1;
    --bs-btn-border-color: #2f7fc1;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #2f7fc1;
    --bs-btn-hover-border-color: #2f7fc1;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #2f7fc1;
    --bs-btn-active-border-color: #2f7fc1;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #2f7fc1;
    --bs-btn-disabled-border-color: #2f7fc1;
}

.btn-outline-theme {
    --bs-btn-color: #2f7fc1;
    --bs-btn-border-color: #2f7fc1;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #2f7fc1;
    --bs-btn-hover-border-color: #2f7fc1;
    --bs-btn-focus-shadow-rgb: 60, 112, 155;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #2f7fc1;
    --bs-btn-active-border-color: #2f7fc1;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #2f7fc1;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #2f7fc1;
    --bs-gradient: none;
}

.cta-bar {
    min-height:60px;
    background-color:#2f7fc1;
    color:#f9f9f9;    
} 

.form-control {
    border-radius: 0;
    border-color: #e3e3e3;
}
.form-control::-webkit-input-placeholder {
    color: #a6a6a6;
}
.form-control:-moz-placeholder {
    color: #a6a6a6;
}
.form-control::-moz-placeholder {
    color: #a6a6a6;
}
.form-control:-ms-input-placeholder {
    color: #a6a6a6;
}
/* [A11Y FIX] Added visible focus ring for form controls (WCAG 2.4.7) */
.form-control:focus {
    border-color: #2f7fc1;
    box-shadow: 0 0 0 0.2rem rgba(47, 127, 193, 0.25);
}
.form-select {
    border-radius: 0;
    border-color: #e3e3e3;
}
.form-check-input:checked {
    background-color: #2f7fc1;
    border-color: #2f7fc1;
}
blockquote p {
    line-height: 2;
}
.RedDamask {
    background-color: #e27240;
}
.RedDamask:hover {
    background-color: #df622a;
}
.FireBush {
    background-color: #e28d40;
}
.FireBush:hover {
    background-color: #df802a;
}
.OliveDrab {
    background-color: #60a823;
}
.OliveDrab:hover {
    background-color: #54931f;
}
.Mojo {
    background-color: #c94139;
}
.Mojo:hover {
    background-color: #b73932;
}
.text-highlight {
    color: #27435a;
}
.highlight-border {
    border-color: #2f7fc1;
}
.read-more {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    display: block;
}
.read-more .svg-inline--fa {
    position: relative;
    top: 1px;
    margin-left: 5px;
}
.carousel-fade .item {
    -webkit-opacity: 0;
    -moz-opacity: 0;
    opacity: 0;
    -webkit-transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    -ms-transition: opacity 0.3s;
    -o-transition: opacity 0.3s;
}
.carousel-fade .item.active {
    -webkit-opacity: 1;
    -moz-opacity: 1;
    opacity: 1;
}
#back-to-top {
    background: #84aac9;
    color: #fff;
    text-align: center;
    display: inline-block;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 2px;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}
#back-to-top:hover {
    background: #2f7fc1;
}
#back-to-top svg {
    margin-top: 5px;
}
.row-end {
    margin-right: 0;
    padding-right: 0;
}
ul.custom-list-style li {
    list-style: none;
    margin-bottom: 16px !important;
}
.date-label {
    background: #f5f5f5;
    display: inline-block;
    width: 40px;
    height: 50px;
    text-align: center;
    font-size: 13px;
}
.date-label .month {
    background: #2f7fc1;
    color: #fff;
    display: block;
    font-size: 13px;
    text-transform: uppercase;
}
.date-label .date-number {
    clear: left;
    display: block;
    padding-top: 2px;
    font-size: 15px;
    font-family: "open sans", arial, sans-serif;
    font-weight: 600;
}
.pagination-container {
    margin-top: 30px;
}
.page-link {
    color: #2f7fc1;
}
.page-item.active .page-link {
    background: #2f7fc1;
    border-color: #2f7fc1;
}
.page-item:first-child .page-link {
    border-radius: 0;
}
.page-item:last-child .page-link {
    border-radius: 0;
}
.nav-tabs {
    border-bottom: none;
    position: relative;
    margin-bottom: -1px;
}
.tab-content {
    border: 1px solid #e3e3e3;
    padding: 15px;
    margin-bottom: 20px;
}
.nav .nav-item .nav-link {
    border-radius: 0;
}
.nav-tabs .nav-link {
    border: 1px solid #e3e3e3;
    border-bottom: none;
    text-decoration: none;
}
.nav-tabs .nav-link:hover {
    background: none;
}
.nav-tabs .nav-link.active {
    border-top: 2px solid #2f7fc1;
}
.nav-tabs .nav-link.active:hover {
    border-bottom: none;
}
.nav-tabs > li > a {
    border: 1px solid #e3e3e3;
    border-bottom: none;
    background: #f5f5f5;
    padding: 5px 15px;
    margin-right: 0;
    border-radius: 0;
    color: #494949;
    -webkit-transition: all 0s;
    -moz-transition: all 0s;
    -ms-transition: all 0s;
    -o-transition: all 0s;
}
.nav-tabs > li {
    margin-right: 2px;
}
.table-striped > tbody > tr:nth-child(odd) > td,
.table-striped > tbody > tr:nth-child(odd) > th {
    background: #f5f8fb;
}
.table > thead > tr > th,
.table > tbody > tr > th,
.table > tfoot > tr > th,
.table > thead > tr > td,
.table > tbody > tr > td,
.table > tfoot > tr > td {
    border-top: 1px solid #ebebeb;
}
.table > thead > tr > th {
    border-bottom: 2px solid #a7c2d9;
    color: #365d7e;
}
.table-hover > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > th {
    background: #f5f8fb;
}
.table-boxed,
.table-bordered {
    border: 1px solid #ebebeb;
}
.table.table-boxed > thead > tr > th {
    border-bottom: none;
    background: #2f7fc1;
    color: #fff;
}
.faq-wrapper .accordion-item {
    border-radius: 0;
    margin-bottom: 20px;
    border: 1px solid #e3e3e3;
}
.faq-wrapper .accordion-item .accordion-header {
    background: none;
    border: none;
    border-radius: 0;
}
.faq-wrapper .accordion-item .accordion-header .accordion-button {
    color: #2f7fc1;
    background: white;
    border: none;
    box-shadow: none;
}
.faq-wrapper .accordion-item .card-body {
    font-size: 13px;
}
.card {
    border-radius: 0;
}
.card .card-header {
    border-radius: 0;
}
.card .card-header .card-title {
    margin-bottom: 0;
}
.card .card-header h3.card-title {
    font-weight: 500;
    margin-bottom: 0;
    font-size: 18px;
}
.card .card-header .badge {
    font-size: 11px;
    padding: 5px 10px;
}
.card .card-footer {
    border-radius: 0;
}
.card .card-footer ul {
    margin-bottom: 0;
}
.card .card-footer ul.list-inline li {
    margin-bottom: 0;
}
/* [A11Y FIX] Improved color contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.card .card-footer small {
    color: #595959;
}
.no-margins {
    margin: 0;
}
.no-margin-left {
    margin-left: 0;
}
.no-margin-right {
    margin-right: 0;
}
.no-margin-top {
    margin-top: 0;
}
.no-margin-bottom {
    margin-bottom: 0;
}
.label {
    border-radius: 0;
}
.label.label-theme {
    background: #2f7fc1;
}
.label .svg-inline--fa {
    margin-right: 4px;
}
.label.label-icon-only .svg-inline--fa {
    margin-right: 0;
}
.badge {
    border-radius: 0;
}
.badge.badge-theme {
    background: #2f7fc1;
}
.badge.badge-default {
    background: #999;
}
.badge.badge-primary {
    background: #428bca;
}
.badge.badge-success {
    background: #5cb85c;
}
.badge.badge-info {
    background: #5bc0de;
}
.badge.badge-info {
    background: #5bc0de;
}
.badge.badge-warning {
    background: #f0ad4e;
    color: #fff;
}
.badge.badge-danger {
    background: #d9534f;
}
.promo-badge {
    font-size: 20px;
    display: table;
}
.promo-badge a {
    color: #fff;
    display: table-cell;
    width: 135px;
    height: 135px;
    text-align: center;
    vertical-align: middle;
    border-radius: 50%;
    border: 5px solid #fff;
    box-shadow: 0px 0px 1px 1px rgba(0, 0, 0, 0.1);
}
.promo-badge .percentage {
    font-size: 32px;
    font-weight: 500;
    color: #fff;
    position: relative;
    font-family: "open sans", arial, sans-serif;
}
.promo-badge .percentage .off {
    font-size: 11px;
    position: absolute;
    top: 15px;
    right: -15px;
}
.promo-badge .desc {
    font-size: 12px;
}
.progress-bar-theme {
    background: #2f7fc1;
}
.gallery-album .item {
    margin-bottom: 15px;
}
.gallery-album .item a {
    border: 1px solid #e3e3e3;
    padding: 4px;
    display: inline-block;
}
.gallery-album .item a:hover {
    box-shadow: 0px 0px 5px 0px #e3e3e3;
}
.blueimp-gallery > .slides > .slide > .slide-content,
.blueimp-gallery > .prev,
.blueimp-gallery > .next,
.blueimp-gallery > .close,
.blueimp-gallery > .play-pause {
    color: #fff !important;
}
#cboxLoadedContent,
#cboxContent {
    background: none;
}
.box {
    background: #f5f5f5;
    padding: 30px;
}
.box.box-border {
    border-left: 5px solid #2f7fc1;
}
.box.box-dark {
    background: #494949;
    color: #fff;
}
.box.box-theme {
    background: #2f7fc1;
    color: #fff;
}
.box .date-label {
    background: #fff;
}
.social-icons {
    list-style: none;
    padding-top: 10px;
    margin-bottom: 0;
}
.social-icons li {
    float: left;
}
.social-icons li:last-child {
    margin-right: 0;
}
.social-icons a {
    display: inline-block;
    background: #95b6d1;
    width: 32px;
    height: 32px;
    text-align: center;
    padding-top: 2px;
    border-radius: 50%;
    font-size: 18px;
    margin-right: 10px;
    float: left;
}
.social-icons a:hover {
    background: #2f7fc1;
}
.social-icons a .svg-inline--fa {
    color: #fff;
}
.social-icons a .svg-inline--fa:before {
    font-size: 18px;
    text-align: center;
    padding: 0;
}
.header .top-bar {
    background: #2f506c;
}
.header .top-bar .search-form {
    padding: 10px 0;
}
.header .top-bar .search-form .form-group {
    display: inline-block;
    margin-bottom: 0;
    vertical-align: middle;
}
.header .top-bar .search-form .form-control {
    font-size: 13px;
}
.header .top-bar .search-form .btn {
    font-size: 13px;
}
.header .social-icons li.row-end {
    margin-right: 0;
}
.header .social-icons a {
    background: rgba(0, 0, 0, 0.2);
}
.header .social-icons a:hover {
    background: #2f7fc1;
}
.header .social-icons a:hover .svg-inline--fa {
    color: #fff;
}
.header .social-icons a .svg-inline--fa {
    color: rgba(255, 255, 255, 0.6);
}
.header .social-icons a .svg-inline--fa:before {
    font-size: 18px;
    text-align: center;
    padding: 0;
}
.header .header-main {
    padding-top: 30px;
    padding-bottom: 30px;
}
.header h1.logo {
    margin-top: 0;
    margin-bottom: 0;
}
.header h1.logo img {
    max-height: 40px;
}
.h1-image {
  background: url('https://www.bestbuddydogtraining.com/assets/images/bbdt-header-logo-lt-blue.png') no-repeat;
  background-size: contain;
  width: 400px; /* match your image's aspect ratio */
  height: 66px;
  text-indent: -9999px;
}
.header .menu-top {
    list-style: none;
    margin: 0;
    padding: 0;
    text-align: right;
    float: right;
}
.header .menu-top li {
    list-style: none;
    float: left;
    font-size: 13px;
    font-family: "open sans", arial, sans-serif;
}
.header .menu-top li:last-child a {
    padding-right: 0;
}
.header .menu-top li.divider a {
    border-right: 1px solid #c9c9c9;
}
.header .menu-top li a {
    display: inline-block;
    color: #7c7c7c;
    padding: 0px 10px;
}
.header .menu-top li a:hover {
    color: #2f7fc1;
}
.header .contact {
    font-family: "open sans", arial, sans-serif;
    font-weight: 300;
    margin-top: 15px;
}
.header .contact p {
    float: left;
    margin-bottom: 0;
}
.header .contact p.phone {
    margin-right: 0px;
}
.header .contact p a {
    color: #494949;
}
.header .contact .svg-inline--fa {
    color: #2f7fc1;
    margin-right: 8px;
    font-size: 16px;
    vertical-align: middle;
}
.header .contact .svg-inline--fa.fa-phone {
    font-size: 20px;
    top: 2px;
}
.header .search-form {
    border: 0;
    box-shadow: none;
}
.header .search-form .form-control {
    width: 260px;
    background: #f5f5f5;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}
.header .search-form .form-control:focus {
    background: #fff;
    border-color: #2f7fc1;
}
.mobile-search-form {
    border: 0;
}
.mobile-search-form .form-control {
    background: #f5f5f5;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}
.mobile-search-form .form-control:focus {
    background: #fff;
    border-color: #2f7fc1;
}
.main-nav-wrapper {
    background: #2f7fc1;
    margin-bottom: 30px;
    min-height: 50px;
}
.main-nav {
    padding: 0;
}
.main-nav .navbar-toggler {
    position: relative;
    margin-bottom: 15px;
    top: 9px;
    padding: 9px 10px;
    background-image: none;
    border: 1px solid transparent;
}
/* [A11Y FIX] Restored visible focus indicator for navbar toggler (WCAG 2.4.7) */
.main-nav .navbar-toggler:focus {
    box-shadow: 0 0 0 0.2rem rgba(47, 127, 193, 0.5);
    outline: 2px solid #2f7fc1;
    outline-offset: 2px;
}
.main-nav button {
    background: #27435a;
    color: #fff !important;
    border-radius: 0;
}
/* [A11Y FIX] Restored visible focus indicator for nav buttons (WCAG 2.4.7) */
.main-nav button:focus {
    outline: 2px solid #2f7fc1;
    outline-offset: 2px;
}
.main-nav button .icon-bar {
    background-color: #fff;
    display: block;
    width: 22px;
    height: 2px;
    border-radius: 1px;
}
.main-nav button .icon-bar + .icon-bar {
    margin-top: 4px;
}
.main-nav .navbar-toggler-label {
    margin-right: auto;
    margin-left: 10px;
    font-weight: 600;
    color: white;
    font-size: 16px;
    letter-spacing: 1px;
}
.main-nav .navbar-collapse {
    padding: 0;
}
.main-nav .nav .nav-item {
    font-weight: 600;
    text-transform: uppercase;
    font-family: "open sans", arial, sans-serif;
    z-index: 100;
    position: relative;
}
.main-nav .nav .nav-item.dropdown {
    z-index: 101;
}
.main-nav .nav .nav-item .nav-link.show {
    background: #2f506c;
}
.main-nav .nav .nav-item .nav-link.show:hover {
    background: #2f506c;
}
.main-nav .nav .nav-item .nav-link {
    color: #dce7f0;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    padding: 15px;
    background: #2f7fc1;
    text-decoration: none;
}
.main-nav .nav .nav-item .nav-link:hover {
    background: #2f7fc1;
    color: #fff;
}
.main-nav .nav .nav-item .nav-link.active {
    background: #2f506c;
    color: #fff;
}
.main-nav .nav .nav-item .nav-link.active:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-bottom: 8px solid #fff;
    position: absolute;
    left: 50%;
    margin-left: -8px;
    bottom: -1px;
}
.main-nav .nav .nav-item .nav-link.active.dropdown-toggle:before {
    display: none;
}
.main-nav .nav .nav-item .dropdown-toggle:after {
    display: none;
}
.main-nav .nav .nav-item.open a {
    background: #2f506c;
    color: #fff;
}
.main-nav .nav .nav-item .dropdown-menu {
    border-radius: 0;
    margin: 0;
    border: none;
    padding: 0;
    min-width: 220px;
}
.main-nav .nav .nav-item .dropdown-menu a {
    border-bottom: 1px solid #3e6a8f;
    padding: 8px 20px;
    text-transform: none;
    font-size: 14px;
    background: #2f506c;
    color: #fff;
    text-decoration: none;
}
.main-nav .nav .nav-item .dropdown-menu a:hover {
    background: #3e6a8f;
    color: #fff;
    padding-left: 24px;
}
/* ----------------------------------------
   Multi-level dropdown (submenu)
----------------------------------------- */

.main-nav .nav .nav-item .dropdown-submenu {
    position: relative;
}

/* keep your right-arrow icon aligned */
.main-nav .nav .nav-item .dropdown-submenu .svg-inline--fa {
    position: absolute;
    right: 15px;
    top: 10px;
}

/* Desktop: position submenu to the right and hide by default */
@media (min-width: 992px) {
    .main-nav .nav .nav-item .dropdown-submenu > .dropdown-menu {
        position: absolute;
        top: 0;
        left: 100%;
        margin-top: 0;
        margin-left: -1px;
        display: none;
    }

    /* Hover opens submenu on desktop */
    .main-nav .nav .nav-item .dropdown-submenu:hover > .dropdown-menu {
        display: block;
    }
}

/* If JS toggles .show (mobile tap, etc), force it visible */
.main-nav .nav .nav-item .dropdown-submenu > .dropdown-menu.show {
    display: block;
}

.footer {
    background: #494949;
    color: rgba(255, 255, 255, 0.7);
    bottom: 0;
}
.footer p {
    color: rgba(255, 255, 255, 0.7);
}
.footer ul {
    padding-left: 0;
}
.footer li {
    list-style: none;
}
.footer h3 {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 24px;
    color: white;
}
.footer .footer-content {
    /* padding: 30px 30px 30px 24px; */
    margin: 0
}
/* [A11Y FIX] Improved footer text contrast on dark background (WCAG 1.4.3) */
.footer .footer-content .footer-col {
    color: #d4d4d4;
}
.footer .footer-content .footer-col .footer-col-inner {
    padding: 0 15px;
}
.footer .footer-content .footer-col .svg-inline--fa {
    margin-right: 10px;
    display: inline-block;
    color: #767676;
}
.footer .footer-content .footer-col .svg-inline--fa.fa-phone {
    font-size: 16px;
}
.footer .footer-content .footer-col li {
    margin-bottom: 10px;
}
.footer .footer-content .footer-col a {
    color: rgba(255, 255, 255, 0.8);
}
.footer .footer-content .footer-col a:hover {
    color: #95b6d1;
}
/* [A11Y FIX] Improved footer address contrast on dark background (WCAG 1.4.3) */
.footer .footer-content .adr {
    margin-bottom: 30px;
    color: #d4d4d4;
}
.footer .footer-content .adr .svg-inline--fa {
    font-size: 16px;
    margin-top: 5px;
}
.footer .footer-content .subscribe-form {
    padding: 0;
}
.footer .footer-content .subscribe-form .form-group {
    display: inline-block;
    margin-bottom: 0;
    vertical-align: middle;
}
.footer .footer-content .subscribe-form .form-control {
    width: 320px;
    background: #f5f5f5;
    border: none;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}
.footer .footer-content .subscribe-form .form-control:focus {
    background: #fff;
}
.footer .bottom-bar {
    background: #303030;
    padding: 5px 0;
    margin: 0;
    color: rgba(255, 255, 255, 0.7);
}
.footer .bottom-bar .copyright {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.7);
    line-height: 3;
}
.footer .bottom-bar .copyright a:hover {
    color: #84aac9;
}
.footer .bottom-bar .social {
    margin: 0;
}
.footer .bottom-bar .social li {
    float: right;
    margin-left: 10px;
    text-align: center;
    font-size: 18px;
    line-height: 2;
}
.footer .bottom-bar .social li a {
    color: #a9a9a9;
    padding: 0 5px;
}
.footer .bottom-bar .social li a:hover {
    color: #2f7fc1;
}
.page-wrapper .page-heading {
    margin-bottom: 30px;
    border-bottom: 1px solid #e3e3e3;
}
.page-wrapper .page-heading h1.heading-title {
    margin-top: 0;
    display: inline-block;
    font-size: 28px;
}
.page-wrapper .breadcrumbs ul {
    margin: 0;
}
.page-wrapper .breadcrumbs ul li {
    color: #2f7fc1;
    font-size: 13px;
    float: left;
    list-style: none;
    display: inline-block;
    margin-bottom: 0;
}
/* [A11Y FIX] Improved breadcrumb link contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.page-wrapper .breadcrumbs ul li a {
    display: inline-block;
    padding: 0 5px;
    color: #595959;
}
.page-wrapper .breadcrumbs ul li a:hover {
    color: #365d7e;
}
/* [A11Y FIX] Improved breadcrumb label contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.page-wrapper .breadcrumbs ul li.breadcrumbs-label {
    padding-right: 0;
    color: #595959;
}
.page-wrapper .breadcrumbs ul li.current {
    max-width: 250px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
/* [A11Y FIX] Improved breadcrumb icon contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.page-wrapper .breadcrumbs ul li .svg-inline--fa {
    margin-right: 5px;
    color: #595959;
}
.page-wrapper ul li {
    margin-bottom: 5px;
}
.page-wrapper ul li .svg-inline--fa {
    margin-right: 5px;
    color: #2f7fc1;
}
.page-wrapper ul li.list-group-item {
    margin-bottom: -1px;
}
.page-wrapper ul.nav li {
    margin-bottom: 0;
}
.page-wrapper ul.social-icons li .svg-inline--fa {
    margin-right: 0;
    color: #fff;
}
.page-wrapper ol li {
    margin-bottom: 5px;
}
.page-wrapper dl dd {
    margin-bottom: 5px;
}
.page-wrapper .page-content h1 {
    font-size: 26px;
    font-weight: normal;
}
.page-wrapper .page-content h2 {
    font-size: 24px;
    font-weight: normal;
}
.page-wrapper .page-content h3 {
    font-size: 20px;
    font-weight: normal;
}
.page-wrapper .page-content h4 {
    font-size: 18px;
    font-weight: normal;
}
.page-wrapper .page-content h5 {
    font-size: 16px;
    font-weight: normal;
}
.page-wrapper .page-content h6 {
    font-size: 14px;
    font-weight: normal;
}
.page-wrapper .page-content .title {
    margin-top: 0;
    margin-bottom: 15px;
    font-weight: 300;
}
.page-wrapper .page-content .page-row {
    margin-bottom: 30px;
}
.page-wrapper .page-content .page-row:last-child {
    margin-bottom: 0;
}
.page-wrapper .page-content .custom-quote {
    border-left: 4px solid #a7c2d9;
    padding-left: 15px;
    padding-top: 10px;
    padding-bottom: 10px;
}
.page-wrapper .page-content .custom-quote p {
    font-size: 14px;
    color: #7c7c7c;
    line-height: 1.5;
}
.page-wrapper .page-content .custom-quote .svg-inline--fa {
    color: #2f7fc1;
    margin-right: 10px;
}
.page-wrapper .page-content .custom-quote .people {
    margin-top: 10px;
    margin-bottom: 0;
    font-size: 11px;
    color: #494949;
    font-style: normal;
}
.page-wrapper .page-content .custom-quote .people .name {
    color: #2f7fc1;
}
.page-wrapper .page-content .has-divider {
    border-bottom: 1px dotted #e3e3e3;
    padding-bottom: 15px;
}
.page-wrapper .page-content .has-divider-solid {
    border-bottom: 1px solid #e3e3e3;
}
.page-wrapper .page-content .row-divider {
    border-bottom: 1px dotted #e3e3e3;
    padding: 10px 0;
}
.page-wrapper .page-content .even-row {
    background: #f5f5f5;
}
.page-wrapper .page-content .read-more.btn {
    margin-bottom: 15px;
    display: inline-block;
}
.page-wrapper .page-content .card-title {
    font-size: 16px;
    font-weight: 300;
    margin-bottom: 0;
}
.page-wrapper .page-content .video-iframe {
    max-width: 100%;
}
.page-wrapper .page-content .album-cover {
    border: 1px solid #e3e3e3;
    margin-bottom: 30px;
}
.page-wrapper .page-content .album-cover img {
    width: 100%;
}
.page-wrapper .page-content .album-cover:hover {
    box-shadow: 0px 0px 5px 0px #e3e3e3;
}
.page-wrapper .page-content .album-cover > a:hover {
    position: relative;
}
.page-wrapper .page-content .album-cover > a:hover img {
    display: block;
    -webkit-opacity: 0.9;
    -moz-opacity: 0.9;
    opacity: 0.9;
}
.page-wrapper .page-content .album-cover .desc {
    padding: 15px;
    position: relative;
}
.page-wrapper .page-content .album-cover .desc:before {
    content: "";
    display: block;
    display: block;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 10px solid #fff;
    position: absolute;
    top: -10px;
}
.page-wrapper .page-sidebar h3.title {
    margin-top: 0;
    margin-bottom: 15px;
    font-size: 20px;
}
.page-wrapper .page-sidebar .widget {
    margin-bottom: 30px;
    padding: 30px 15px;
    padding-top: 0;
}
.page-wrapper .page-sidebar .widget.has-divider {
    border-bottom: 1px dotted #e3e3e3;
}
.page-wrapper .page-sidebar .widget h3 {
    margin-bottom: 20px;
}
.page-wrapper .page-sidebar .widget .iframe {
    height: auto;
    min-height: 200px;
    max-width: 100%;
}
.page-wrapper .page-sidebar .widget .svg-inline--fa {
    margin-right: 5px;
    color: #2f7fc1;
}
.page-wrapper .page-sidebar .widget .svg-inline--fa.fa-phone {
    font-size: 16px;
}
.page-wrapper .page-sidebar .widget .btn .svg-inline--fa {
    color: #fff;
}
.page-wrapper .page-sidebar .widget .nav li a {
    padding: 5px 15px;
    color: #494949;
    margin-bottom: 10px;
    border-left: 5px solid transparent;
}
.page-wrapper .page-sidebar .widget .nav li a:hover {
    background: none;
    color: #2f7fc1;
}
.page-wrapper .page-sidebar .widget .nav li.active a {
    background: none;
    color: #2f7fc1;
    font-weight: bold;
    border-left: 5px solid #2f7fc1;
}
.page-wrapper .page-sidebar ul {
    padding-left: 0;
}
.page-wrapper .page-sidebar .news-item {
    margin-bottom: 15px;
}
.page-wrapper .page-sidebar .news-item:last-child {
    margin-bottom: 0;
}
.page-wrapper .page-sidebar .news-item img {
    width: 40px;
    height: 40px;
}
.page-wrapper .page-sidebar .news-item .title {
    font-size: 14px;
    margin-top: 0;
}
.page-wrapper .page-sidebar .testimonials-carousel {
    position: relative;
}
.page-wrapper .page-sidebar .testimonials-carousel .svg-inline--fa {
    color: #2f7fc1;
    margin-right: 5px;
    font-size: 18px;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel .item {
    min-height: 300px;
}
.page-wrapper .page-sidebar .testimonials-carousel .quote {
    padding-left: 15px;
    border-left: 4px solid #f5f5f5;
}
.page-wrapper .page-sidebar .testimonials-carousel .source {
    position: relative;
    min-height: 80px;
}
.page-wrapper .page-sidebar .testimonials-carousel .people {
    margin-top: 30px;
    margin-left: 19px;
}
.page-wrapper .page-sidebar .testimonials-carousel .people .name {
    color: #2f7fc1;
}
/* [A11Y FIX] Improved color contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.page-wrapper .page-sidebar .testimonials-carousel .people .title {
    color: #595959;
}
.page-wrapper .page-sidebar .testimonials-carousel .profile {
    position: absolute;
    right: 0;
    top: 0;
    width: 80px;
    height: 80px;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls {
    margin-top: 20px;
    text-align: right;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls a {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    display: inline-block;
    width: 20px;
    height: 20px;
    background: #e2e2e2;
    text-align: center;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls a .svg-inline--fa {
    color: #fff;
    text-align: center;
    margin-right: 0;
    font-size: 20px;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls a.next .svg-inline--fa {
    margin-left: 2px;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls a.prev .svg-inline--fa {
    margin-right: 2px;
}
.page-wrapper .page-sidebar .testimonials-carousel .carousel-controls a:hover {
    background: #2f7fc1;
}
.home-page h1.section-heading {
    font-size: 26px;
    font-weight: 300;
    line-height: 2;
    margin-top: 0;
    margin-bottom: 15px;
    color: #2f506c;
}

.home-page h2.section-heading {
    font-size: 22px;
    font-weight: 300;
    line-height: 1.5;
    margin-top: 0;
    margin-bottom: 15px;
    color: #2f506c;
}

.home-page h1.section-heading .line {
    border-top: 2px solid #2f7fc1;
    display: inline-block;
    padding: 0 30px;
    padding-top: 5px;
}

.home-page h2.section-heading .line {
    border-top: 2px solid #2f7fc1;
    display: inline-block;
    padding: 0 30px;
    padding-top: 16px;
}

.home-page section {
    background: #ffffff;
    overflow: hidden;
    margin-bottom: 30px;
}
.home-page .section-content {
    padding: 30px;
    padding-top: 0;
}
.home-page .promo {
    margin-bottom: 30px;
    margin-top: 30px;
}
.home-page .promo h1.section-heading {
    font-size: 24px;
    color: #fff;
}
.home-page .promo h2.section-heading {
    font-size: 20px;
    color: #fff;
}
.home-page .promo p {
    color: rgba(255, 255, 255, 0.7);
}
.home-page .promo .btn-cta {
    font-size: 20px;
    font-family: "Open Sans", arial, sans-serif;
}
.home-page .promo .btn-cta:hover {
    background: #2f506c;
    border-color: #2f506c;
}
.home-page .news {
    position: relative;
}
.home-page .news h2.title {
    font-size: 20px;
    font-weight: 300;
    margin-top: 0;
}
.home-page .news h2.title a {
    color: #365d7e;
    text-decoration: none;
}
.home-page .news h2.title a:hover {
    color: #27435a;
    text-decoration: underline;
}
.home-page .news .news-item {
    padding-left: 115px;
    position: relative;
    margin-bottom: 20px;
}
.home-page .news .thumb {
    position: absolute;
    left: 0;
    top: 0;
}
.home-page .news .carousel-controls {
    position: absolute;
    right: 15px;
    top: 15px;
}
.home-page .news .carousel-controls a {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    display: inline-block;
    width: 24px;
    height: 24px;
    background: #c9c9c9;
    text-align: center;
    padding-top: 3px;
}
.home-page .news .carousel-controls a .svg-inline--fa {
    color: #fff;
    text-align: center;
    margin-right: 0;
    font-size: 18px;
}
.home-page .news .carousel-controls a:hover {
    background: #2f7fc1;
}
.home-page .events .section-content {
    min-height: 520px;
}
.home-page .events .event-item {
    position: relative;
    padding-left: 55px;
    border-bottom: 1px solid #e3e3e3;
    padding-bottom: 10px;
    margin-bottom: 15px;
}
.home-page .events .event-item .date-label {
    background: #fff;
    position: absolute;
    left: 0;
}
.home-page .events .event-item h2.title {
    margin-bottom: 10px;
    font-size: 16px;
    font-weight: 400;
}
.home-page .events .event-item p {
    margin-bottom: 5px;
}
.home-page .events .event-item .svg-inline--fa {
    margin-right: 5px;
    font-size: 14px;
    min-width: 16px;
    color: #666;
}
.home-page .events .event-item .svg-inline--fa.fa-map-marker {
    font-size: 18px;
}
.home-page .events .read-more {
    margin-top: 15px;
}
.home-page .events .details p {
    color: #666;
}
.home-page .course-finder .course-finder-form {
    margin-bottom: 15px;
}
.home-page .course-finder .keywords input {
    width: 200px;
    margin-right: 5px;
}
.home-page .video {
    position: relative;
}
.home-page .video .carousel-controls {
    position: absolute;
    right: 15px;
    top: 15px;
}
.home-page .video .carousel-controls a {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    display: inline-block;
    width: 24px;
    height: 24px;
    background: #c9c9c9;
    text-align: center;
    padding-top: 3px;
}
.home-page .video .carousel-controls a .svg-inline--fa {
    color: #fff;
    text-align: center;
    margin-right: 0;
    font-size: 18px;
}
.home-page .video .carousel-controls a:hover {
    background: #2f7fc1;
}
.home-page .video .video-iframe {
    max-width: 100%;
    width: 100%;
    height: 287px;
    margin-bottom: 5px;
}
.home-page .links .svg-inline--fa {
    margin-right: 5px;
}
.home-page .testimonials {
    position: relative;
}
.home-page .testimonials .svg-inline--fa {
    color: #2f7fc1;
    margin-right: 5px;
    font-size: 18px;
}
.home-page .testimonials .carousel .item {
    min-height: 298px;
}
.home-page .testimonials .quote {
    padding-left: 15px;
    border-left: 4px solid #e6e6e6;
}
.home-page .testimonials .source {
    position: relative;
    padding-top: 30px;
}
.home-page .testimonials .people {
    margin-top: 10px;
}
.home-page .testimonials .people .name {
    color: #2f7fc1;
}
/* [A11Y FIX] Improved color contrast to meet 4.5:1 ratio (WCAG 1.4.3) */
.home-page .testimonials .people .title {
    color: #595959;
}
.home-page .testimonials .profile {
    position: absolute;
    right: 5px;
    bottom: 0;
    width: 60px;
    height: 60px;
}
.home-page .testimonials .carousel-controls {
    position: absolute;
    right: 15px;
    top: 15px;
}
.home-page .testimonials .carousel-controls a {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    display: inline-block;
    width: 24px;
    height: 24px;
    background: #c9c9c9;
    text-align: center;
    padding-top: 3px;
}
.home-page .testimonials .carousel-controls a .svg-inline--fa {
    color: #fff;
    text-align: center;
    margin-right: 0;
    font-size: 18px;
}
.home-page .testimonials .carousel-controls a:hover {
    background: #2f7fc1;
}
.home-page .awards {
    background: #fff;
}
.home-page .awards .logos {
    margin: 0;
    padding: 0;
}
.home-page .awards .logos li {
    list-style: none;
    margin-right: 0;
    text-align: center;
}
.home-page .awards .logos li img {
    -webkit-opacity: 0.6;
    -moz-opacity: 0.6;
    opacity: 0.6;
    max-width: 100px;
    margin: 0 auto;
}
.home-page .awards .logos li img:hover {
    -webkit-opacity: 1;
    -moz-opacity: 1;
    opacity: 1;
}
.home-page .awards .carousel-indicators {
    position: static;
}
.home-page .awards .carousel-indicators [data-bs-target] {
    height: 12px;
    width: 12px;
    margin-left: 4px;
    margin-right: 4px;
    background-color: #494949;
}
.promo-carousel .carousel-control-prev,
.promo-carousel .carousel-control-next {
    width: 8%;
}
.promo-carousel .carousel-indicators [data-bs-target] {
    height: 4px;
    margin-left: 4px;
    margin-right: 4px;
    width: 24px;
}
.promo-carousel .carousel-control-prev-icon,
.promo-carousel .carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.9);
    padding: 5px;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background-size: 50%;
}
.promo-carousel .carousel-item {
    height: 440px;
}
.promo-carousel .carousel-item.slide-1 {
    background: #212121 url("../images/slides/Slide_2_DSC_1189.webp") no-repeat 50% 50%;
    background-size: cover;
}
.promo-carousel .carousel-item.slide-2 {
    background: #212121 url("../images/slides/Slide_3_DSC_0833.webp") no-repeat 50% 50%;
    background-size: cover;
}
.promo-carousel .carousel-item.slide-3 {
    background: #212121 url("../images/slides/Slide_4_DSC_1135.webp") no-repeat 50% 50%;
    background-size: cover;
}
.promo-carousel .carousel-item.slide-4 {
    background: #212121 url("../images/slides/Slide_5_DSC_0724.webp") no-repeat 50% 50%;
    background-size: cover;
}
.promo-carousel .carousel-item .carousel-caption {
    position: absolute;
    left: 30px;
    bottom: 30px;
    color: #fff;
    display: inline-block;
    font-family: "open sans", arial, sans-serif;
    font-weight: 300;
}
.promo-carousel .carousel-item .carousel-caption .main {
    display: inline-block;
    background: #2f7fc1;
    margin-bottom: 5px;
    padding: 10px 15px;
    font-size: 22px;
}
.promo-carousel .carousel-item .carousel-caption .secondary {
    display: inline-block;
    background: rgba(0, 0, 0, 0.8);
    padding: 5px 15px;
    color: #fff;
    font-size: 18px;
}

.about-carousel .carousel-item.slide-1 {
    background: #212121 url("../assets/images/slides/About_header_Philosophy_DSC_2059_large.jpg") no-repeat 50% 50%;
    background-size: cover;
}

.courses-wrapper .tab-content {
    font-size: 13px;
}
.courses-wrapper .tab-content .item {
    margin-top: 15px;
}
.courses-wrapper .tab-content img {
    margin-bottom: 10px;
}
.courses-wrapper .course-finder {
    margin-bottom: 30px;
}
.courses-wrapper .course-finder .keywords input {
    width: 260px;
}
.courses-wrapper .course-list-header {
    margin-bottom: 15px;
    font-size: 13px;
}
.courses-wrapper .course-list-header .sort {
    padding-top: 5px;
}
.courses-wrapper .course-list-header .sort-options {
    font-size: 13px;
}
.courses-wrapper .course-item .col-meta {
    color: #7c7c7c;
}
.events-wrapper .events-item .date-label {
    background: #f5f5f5;
}
.events-wrapper .events-item .details .time {
    margin-right: 10px;
}
.events-wrapper .events-item .details .svg-inline--fa {
    margin-right: 5px;
}
.contact-form .required {
    color: #e14b39;
    display: inline-block;
    font-weight: normal;
    padding-left: 2px;
}
.contact-form label {
    font-weight: 700;
}
.contact-form .form-control {
    font-size: 14px;
}
.gmap-wrapper {
    border: 1px solid #e3e3e3;
    position: relative;
    padding-bottom: 30%;
    height: 0;
    overflow: hidden;
}
.gmap-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
@media (max-width: 767.98px) {
    .wrapper {
        min-height: inherit;
        margin-bottom: 0;
    }
    .wrapper:after {
        content: none;
    }
    .footer {
        height: auto;
    }
    .header .header-main {
        padding-top: 20px;
        padding-bottom: 20px;
    }
    .main-nav .navbar-collapse {
        border-top: 0;
        box-shadow: 0;
    }
    .navbar-nav {
        margin-top: 0;
    }
    .header .search-form {
        text-align: center;
    }
    .header .search-form .form-group {
        display: inline-block;
    }
    .header .search-form .form-control {
        width: 210px;
    }
    .promo-carousel .carousel-item {
        height: 320px;
    }
    .home-page .news .thumb {
        width: 60px;
        height: 60px;
    }
    .home-page .news .news-item {
        padding-left: 75px;
    }
    .home-page .course-finder .keywords {
        margin-top: 10px;
    }
    .home-page .course-finder .keywords input {
        width: auto;
    }
    .home-page .video .video-iframe {
        height: auto;
    }
    .home-page .testimonials .carousel .item {
        min-height: inherit;
    }
    .home-page .events .section-content {
        min-height: inherit;
    }
    .home-page .awards .carousel-control {
        top: 50px;
    }
    .footer .footer-content .subscribe-form .form-control {
        width: 140px;
    }
    .footer #tweet .tweets-list-container {
        max-width: 100%;
    }
    .footer .bottom-bar .social li {
        float: left;
    }
    .footer-col-inner {
        margin-bottom: 30px;
    }
    .footer #tweet {
        min-height: inherit;
    }
    .footer .footer-content .footer-col .fa-twitter {
        text-align: center;
        margin-bottom: 10px;
    }
    .page-wrapper .page-heading h1.heading-title {
        float: none;
        text-align: center;
        display: block;
    }
    .page-wrapper .breadcrumbs {
        text-align: center;
        display: block;
    }
    .page-wrapper .breadcrumbs ul {
        padding-top: 0;
        padding-left: 0;
        margin: 0 auto;
    }
    .page-wrapper .breadcrumbs ul li {
        float: none;
        display: inline-block;
    }
    .page-wrapper .breadcrumbs ul li.current {
        max-width: inherit;
        overflow: visible;
    }
}
@media (max-width: 991.98px) {
    .main-nav .nav .nav-item .dropdown-submenu > .dropdown-menu {
        position: static;
        left: auto;
        margin-left: 0;
    }
    .main-nav .nav .nav-item .dropdown-submenu .dropdown-menu a {
        padding-left: 30px;
    }
    .main-nav .nav .nav-item .dropdown-submenu .dropdown-menu a:hover {
        padding-left: 34px;
    }
    .main-nav .nav .nav-item .dropdown-submenu .dropdown-menu .dropdown-submenu .dropdown-menu a {
        padding-left: 45px;
    }
    .main-nav .nav .nav-item .dropdown-submenu .dropdown-menu .dropdown-submenu .dropdown-menu a:hover {
        padding-left: 49px;
    }
    .main-nav .nav .nav-item .nav-link.active:before {
        display: none;
    }
}
@media (min-width: 768px) {
    .wrapper {
        min-height: inherit;
        margin-bottom: 0;
    }
    .wrapper:after {
        content: none;
    }
    .header .top-bar .search-form {
        text-align: right;
    }
    .footer {
        height: auto;
    }
    .footer .bottom-bar .social li {
        float: left;
    }
    .footer-col-inner {
        margin-bottom: 15px;
    }
    .home-page .testimonials .carousel .item {
        min-height: inherit;
    }
    .home-page .events .section-content {
        min-height: inherit;
    }
    .footer #tweet {
        min-height: inherit;
    }
    .page-wrapper .album-cover {
        min-height: 360px;
    }
}
@media (min-width: 992px) {
    .home-page .promo .btn-cta {
        margin-top: 30px;
    }
    .footer .bottom-bar .social li {
        float: right;
    }
    .footer #tweet {
        min-height: 100px;
    }
    .page-wrapper .album-cover {
        min-height: 360px;
    }
    html,
    body {
        height: 100%;
    }
    .wrapper {
        min-height: 100%;
        margin-bottom: -344px;
    }
    .wrapper:after {
        content: "";
        display: block;
        height: 344px;
    }
    .footer {
        height: 344px;
    }
}
body {
    overflow-x: hidden;
}
.config-trigger {
    position: absolute;
    left: -36px;
    width: 36px;
    height: 36px;
    background: #222;
    color: #fff;
    text-align: center;
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 4px;
    -webkit-border-top-left-radius: 4px;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 4px;
    -moz-border-radius-topleft: 4px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 4px;
    border-top-left-radius: 4px;
    text-decoration: none;
}
.config-trigger:hover {
    background: #000;
    text-decoration: none;
}
.config-trigger:hover .svg-inline--fa {
    color: #fff;
}
.config-trigger .svg-inline--fa {
    font-size: 20px;
    margin-top: 7px;
    display: block;
    color: rgba(255, 255, 255, 0.8);
}
.config-panel {
    position: fixed;
    top: 100px;
    z-index: 1000;
    width: 180px;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}
.config-panel.config-panel-open {
    right: 0;
}
.config-panel.config-panel-hide {
    right: -180px;
}
.config-panel .panel-inner {
    position: relative;
    background: #222;
    color: #fff;
    padding: 15px;
    padding-bottom: 0;
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 4px;
    -webkit-border-top-left-radius: 4px;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 4px;
    -moz-border-radius-topleft: 4px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 4px;
    border-top-left-radius: 4px;
}
.config-panel .panel-title {
    font-weight: 600;
    margin-bottom: 15px;
    font-size: 14px;
    text-transform: uppercase;
}
.config-panel label {
    color: #fff;
}
.config-panel #color-options {
    margin-bottom: 0px;
}
.config-panel #color-options li a {
    display: block;
    width: 25px;
    height: 25px;
    border: 2px solid transparent;
    margin-bottom: 10px;
}
.config-panel #color-options li a:hover {
    -webkit-opacity: 0.9;
    -moz-opacity: 0.9;
    opacity: 0.9;
    border: 2px solid rgba(255, 255, 255, 0.8);
}
.config-panel #color-options li.active a {
    border: 2px solid #fff;
}
.config-panel #color-options li.theme-1 a {
    background: #2f7fc1;
}
.config-panel #color-options li.theme-2 a {
    background-color: #57a89a;
}
.config-panel #color-options li.theme-3 a {
    background-color: #6f7a9f;
}
.config-panel #color-options li.theme-4 a {
    background-color: #a85770;
}
.config-panel .close {
    position: absolute;
    right: 5px;
    top: 5px;
    color: #fff;
}
.config-panel .close .svg-inline--fa {
    color: #fff;
    font-size: 18px;
}
/* ============================================================
   NAV — User dropdown, avatar, login item
   Extracted from _nav.php (lines 198–297)
   ============================================================ */

/*
 * On desktop: absolutely position the user/login item so it is
 * removed from the normal flex flow. The other nav items render
 * identically whether logged in or out.
 */
@media (min-width: 992px) {
    .main-nav {
        position: relative;
    }
    .main-nav .nav .nav-user-dropdown,
    .main-nav .nav .nav-login-item {
        position: absolute;
        right: 0;
        top: 0;
        bottom: 0;
        z-index: 102;
        display: flex;
        align-items: center;
    }
}

/* ── Avatar & user link styling ── */
.nav-user-dropdown .nav-link {
    gap: 4px;
    background: transparent !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    display: flex !important;
    align-items: center;
}
.nav-login-item .nav-link {
    background: transparent !important;
}
.nav-user-dropdown .nav-link.dropdown-toggle::after {
    display: none; /* hide default Bootstrap caret, we use our own angle-down icon */
}
.nav-avatar-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    vertical-align: middle;
}
.nav-avatar-wrap img {
    width: 24px;
    height: 24px;
    object-fit: cover;
    border-radius: 50%;
}
.nav-avatar-initial {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #3C709B;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    line-height: 1;
}
.nav-online-dot {
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 7px;
    height: 7px;
    background: #2ecc40;
    border: 1.5px solid #fff;
    border-radius: 50%;
    z-index: 2;
}
.nav-user-name {
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 14px;
}
.nav-user-dropdown .dropdown-item i {
    width: 18px;
    text-align: center;
}

/* ── Mobile: return to normal flow ── */
@media (max-width: 991.98px) {
    .nav-user-dropdown,
    .nav-login-item {
        position: static !important;
    }
    .nav-user-name { max-width: none; }
}


/* ============================================================
   NAV — Nested dropdown (Locations submenu)
   Extracted from _nav.php (lines 299–346)
   ============================================================ */

/* Position submenu to the right of its parent item */
.dropdown-menu .dropend .submenu {
    display: none;
    position: absolute;
    top: 0;
    left: 100%;
    margin-top: -0.5rem;
    margin-left: 0.125rem;
    min-width: 10rem;
    padding: var(--bs-dropdown-padding-y) 0;
    background-color: var(--bs-dropdown-bg, #fff);
    border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
    border-radius: var(--bs-dropdown-border-radius);
    box-shadow: var(--bs-dropdown-box-shadow);
    z-index: 1000;
}

/* Show state */
.dropdown-menu .dropend .submenu.show {
    display: block;
}

/* Right-pointing caret for submenu toggle */
.dropdown-menu .dropend > .submenu-toggle::after {
    content: "";
    display: inline-block;
    margin-left: auto;
    margin-top: 0.45em;
    border-top: 0.3em solid transparent;
    border-bottom: 0.3em solid transparent;
    border-left: 0.3em solid currentColor;
    border-right: 0;
}

/* Responsive: stack submenu below parent on mobile */
@media (max-width: 991.98px) {
    .dropdown-menu .dropend .submenu {
        position: static !important;
        display: none;
        margin-left: 1rem;
        border: none;
        box-shadow: none;
        background: transparent;
    }
    .dropdown-menu .dropend .submenu.show {
        display: block;
    }
}