/* Global CSS Start --------------------- */

html {
    scroll-behavior: smooth; 
}

body {
    margin: 0;
    font-family: 'Inter', san-serif;
}

.wrapper {
    padding: 0 20px;
    max-width: 1230px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 60px;
    padding-bottom: 60px;
}

.core_body {
    padding-top: 90px;
}

h1 {
    font-weight: 700;
    font-size: 56px;
    margin-top: 0;
    line-height: 68px;
    color: #0f1D40;
}

h2 {
    font-weight: 700;
    font-size: 36px;
    line-height: 1.2;
    margin: 10px 0 0 0;
    color: #0f1D40;
}

h3 {
    font-size: 18px;
    font-weight: bold;
    margin-top: 30px;
}

h4 {
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}

p {
    color: #3A4662;
    line-height: 1.75;
    font-weight: 400;
    font-size: 16px;
    margin-top: 0;
}

.subhead {
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}

.button {
    padding: 10px 20px;
    border-radius: 24px;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    text-decoration: none;
}

.white {
    color: white !important;
}

.center-cont {
    text-align: center;
}

.main_padding {
    padding: 100px 0;
}

.body_header_container, .our_news_container {
    background: #F8FAFF;
}

.our_services_container, .contact_us_container, .footer {
    background: #253562;
}

.section_head {
    text-align: center;
    color: #0f1D40;
}

@media only screen and (max-width: 1200px) {
    .main_padding {
        padding: 80px 0;
    }
}

@media only screen and (max-width: 1000px) {
    .wrapper {
        width: calc(100% - 40px);
        padding-top: 20px;
        padding-bottom: 20px; 
    }

    h1 {
        font-size: 40px;
        text-align: center;
        line-height: 1.5;
    }

    .main_padding {
        padding: 60px 0;
    }
}

/* Global CSS End --------------------- */
/* Navigation CSS Start --------------------- */

.navigation {
    height: 90px;
    position: fixed;
    width: 100%;
    background-color:#253562;
    z-index: 1000;
}

.nav_wrapper {
    padding: 0 20px;
   /* max-width: 1230px;*/
    margin-left: auto;
    margin-right: auto;
}

.logo_container { 
    height: 60px;
}

.logo {
    height: 60px;
    width: auto;
    margin-top: auto;
}

.header_links {
    padding: 20px 0;
    margin-left: 40px;
}

.nav_container {
    display: flex;
    justify-content: space-between;
}

.nav_link {
    color:white;
    font-size: 16px;
    padding: 0 16px;
    text-decoration: none;
}

.nav_left_pane {
    display: flex;
    padding: 15px 0;
}

.navbar_toggler {
    display: none;
}

.header_buttons {
    font-size: 16px;
    padding: 30px;
    text-decoration: none;
}

#schedule_appointment {
    margin-left: 24px;
}

@media only screen and (max-width: 1000px) {

    .navbar_toggler {
        display: block;        
        background-color: transparent;
        border: 0;
        cursor: pointer;
        float: right;
        margin-right: -10px;
        margin-top: 21.5px;
        padding: 10px;
        position: relative;
        width: 55px;
        z-index: 20;
    }

    .header_links, .header_buttons {
        display: none;
    }

    .no_scroll { 
        position: fixed;
        overflow: hidden;
    }

    .nav_left_pane {
        display: block;
    }

    .nav_container {
        display: block;
    }

    .menu_icon_line {
        background-color: #fff;
        border-radius: 2px;
        display: block;
        height: 3px;
        margin-bottom: 6px;
        margin-left: auto;
        transform: translateZ(0);
        transition: transform .3s cubic-bezier(.175,.885,.32,1.275),opacity .2s ease-out;
        width: 100%;
    }

    .menu_icon_line_1 {
        width: 99%;
    }

    .menu_icon_line_2 {
        width: 66%;
    }

    .menu_icon_line_3 {
        width: 33%;
    }

    .nav_open .menu_icon_line {
        margin-bottom: 9px;
        width: 100%;
    }

    .nav_open .menu_icon_line_1 {
        transform: translateY(14px) rotate(-135deg);
    }

    .nav_open .menu_icon_line_2 {
        opacity: 0;
    }

    .nav_open .menu_icon_line_3{
        transform: translateY(-10px) rotate(135deg);
    }


    .nav_open {
        overflow: hidden scroll;
        margin: 0px;
        padding: 0px;
        left: 0px;
        right: 0px;
        width: 100vw;
        transition: opacity 0.15s ease-in-out 0s;
        display: block;
        opacity: 1;
        top: 0px;
        height: 100vh;
        pointer-events: all;
        position: absolute !important;
    }

    .nav_open .header_links {
        display: grid;
        top: 80px;
        border: 1px solid #FCFCFC;
        padding: 32px 32px 32px;
        margin-top: 32px;
        margin-bottom: 32px;
        margin-left: 0;
    }

    .nav_link {
        padding: 15px 0;
    }

    .nav_open .header_buttons {
        display: grid;
    }

    .check_in_button, #schedule_appointment {
        margin: auto;
        text-align: center;
        margin-top: 20px;
    }
}

/* Navigation CSS End --------------------- */
/* Header CSS Start --------------------- */

.head_container {
    display: flex;
    justify-content: space-evenly;
}

.head_container .left_pane, .head_container .right_pane  {
    width: 50%;
}

.head_container .left_pane p {
    margin-bottom: 2rem;
}

.head_container .left_pane {
    max-width: 500px;
}

.collage_head {
    max-width: 500px;
}

.head_container .right_pane {
    /*display: flex;*/
    justify-content: center;
}

.head_container .left_pane {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
}

.check_in_button {
    background-color: white;
    color: black;
}

.blue_drop_button {
    background-color: #4E90EB;
    border:none;
    border-radius: .4rem;
    color: white;
}


.green_drop_button {
    background-color: #65E6B9;
    border:none;
    border-radius: .1rem;
    color: white;
}

@media only screen and (max-width: 1200px) {

    .collage_head {
        max-width: 450px;
    }

    .main_padding {
        padding-left: 20px;
        padding-right: 20px;
    }
}

@media only screen and (max-width: 1000px) {

    .head_container .left_pane, .head_container .right_pane  {
        width: 100%;
        text-align: center;
    }

    .collage_head {
        max-width: 320px;
    }

    .head_container .left_pane {
        max-width: 400px;
        margin: auto;
        display: block;
    }

    .main_padding {
        padding-left: 0;
        padding-right: 0;
    }
}

@media only screen and (max-width: 800px) {
    .collage_head {
        max-width: 400px;
    }

    .head_container {
        flex-direction: column-reverse;
    }

    .head_container .left_pane {
        max-width: 600px;
        margin: auto;
        margin-top: 24px;
    }

}

@media only screen and (max-width: 600px) {
    .collage_head {
        max-width: 320px;
    }

    .head_container .left_pane {
        max-width: 400px;
    }
}

/* Header CSS End --------------------- */
/* Who We Are CSS Start --------------------- */

.single_value {
    size: 16px;
    color: black;
    text-align: center;
    padding: 0 32px;
    font-size: 16px;
}

.values_cont {
    display: flex;
    margin-top: 60px;
}

@media only screen and (max-width: 1000px) {
    .single_value {
        padding: 16px;
    }
}

@media only screen and (max-width: 800px) {
    .values_cont {
        display: block;
    }

    .single_value {
        max-width: 500px;
        margin: auto;
    }
}

/* Who We Are CSS End --------------------- */
/* Our Services CSS Start --------------------- */

.services_cont {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 3.2rem;
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 0px;
    margin-top: 72px;
    margin-bottom: 52px;
}

.single_service {
    grid-column: span 4 / auto;
    flex-basis: 100%;
    border-radius: 32px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.05);
    padding: 62px 44px;
}

.single_serviceb {
    grid-column: span 3 / auto;
    flex-basis: 100%;
    border-radius: 32px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.05);
    padding: 62px 44px;
}

.right_pane img {
    width: 100%;
}

.service_icon{
    height: 50px;
    width: 50px; 
}

.single_service {
    grid-column: span 4/ auto;
    padding: 32px;
    text-align: center;
}

@media only screen and (max-width: 1200px) {
    .single_service {
        padding: 20px;
    }

    .services_cont {
        margin-bottom: 20px;
        gap: 1.6rem;
    }
}

@media only screen and (max-width: 1000px) {
    .single_service {
        grid-column: span 6 / auto;
    }
}

@media only screen and (max-width: 800px) {

}

@media only screen and (max-width: 600px) {
    .single_service {
        grid-column: span 12 / auto;
    }
}

/* Our Services CSS End --------------------- */
/* Our Team CSS Start --------------------- */

.team_cont {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 3.2rem; 
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 0px;
    margin-top: 72px;
}

.team_service {
    grid-column: span 3/ auto;
    flex-basis: 100%;
    border-radius: 32px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.05);
    background-repeat: no-repeat;
}

.team_pic {
    width: 100%;
    border-radius: 50px;
}

.colored_border {
    position: absolute;
}

.team_name {
    margin-bottom: 10px;
}

.team_title {
    color: #253562;
}

.team_service p {
    padding-top: 20px;
}

.team_cont .team_service:nth-of-type(4n-3) .colored_border{
    fill: #EF734D;
}

.team_cont .team_service:nth-of-type(4n-2) .colored_border{
    fill: #4E90EB;
}

.team_cont .team_service:nth-of-type(4n-1) .colored_border{
    fill: #65E6B9;
}

.team_cont .team_service:nth-of-type(4n) .colored_border{
    fill: #EAB944;
}

@media only screen and (max-width: 1000px) {
    .team_service {
        grid-column: span 6/ auto;
        padding: 16px;
        text-align: center;
    }

    .team_cont {
        gap: 1.6rem;
        margin-bottom: 20px;
    }
}

@media only screen and (max-width: 600px) {
    .team_service {
        grid-column: span 12/ auto;
        padding: 0px;
        text-align: center;
        margin: auto;
        max-width: 450px;
    }

    .team_cont {
        gap: 3.2rem 0;
    }
}

/* Who We Are CSS End --------------------- */
/* News & Events CSS Start --------------------- */

.news_cont {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 2rem; 
    margin-top: 44px;
}

.news_link {
    text-decoration: none;
}

.news_name {
    color: #0f1D40;
}

.single_news {
    padding: 0 16px;
    grid-column: span 4/ auto;
    flex-basis: 100%;
}

.single_news img {
    border-radius: 32px;
    width: 100%;
}

.news_label {
    font-weight: 600;
    font-size: 14px;
    line-height: 24px;
    padding: 6px 14px;
    border-radius: 8px;
}

.news_name {
    margin-top: 15px;
}

.news_label_case {
    color: #EF734D;
    background: rgba(239, 115, 77, 0.15);
}

.news_label_video {
    color: #4E90EB;
    background: rgba(78, 144, 235, 0.15);
}

.news_label_article {
    color: #EAB944;
    background: rgba(234, 185, 68, 0.15);
}

.news_content {
    margin-top: 20px;
}


@media only screen and (max-width: 1000px) {
    .single_news {
        grid-column: span 6/ auto;
    }
}


@media only screen and (max-width: 600px) {
    .single_news img {
        width: 100%;
    }
    
    .single_news {
        grid-column: span 12/ auto;
        padding: 0;
        max-width: 450px;
        margin: auto;
    }

    .news_cont {
        gap: 3.2rem 0;
    }
}

/* News & Events CSS End --------------------- */
/* Contact Us CSS Start --------------------- */

.contact_single {
    color: white;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.contact_single p, .contact_single a {
    color: rgba(255, 255, 255, 0.8) !important;
    margin: 0;
}

.contact_title {
    color: #60A1FB;
    margin-top: 0;
    margin-bottom: 5px;
}

.contact_cont {
    color: white;
}

.hours_icon {
    margin-right: 20px;
}

.phone_icon {
    margin-right: 20px; 
}

.email_icon {
    margin-right: 20px;
}

.address_icon {
    margin-right: 20px;

}

.contactus_title {
    color: white;
}

.contactus_descriptor {
    color: white;
}

#contact_us {
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.contact_parent {
    padding-top: 60px;
    padding-bottom: 60px;
}

@media only screen and (min-width: 1000px) {
    .contact_cont {
        display: grid;
        grid-template-columns: repeat(12, 1fr);
        gap: 2.5rem 0;
    }

    .contact_single {
        grid-column: span 6/ auto;
        flex-basis: 100%;
        max-width: 400px;
        flex-wrap: inherit;
    }

    .contact_time {
        display: flex;
    }

    .contact_parent {
        display: flex;
        justify-content: space-between;
    }

    .contact_info {
        max-width: 300px;
    }

    .contact_time_indv {
        margin-left: 15px !important;
    }
}


@media only screen and (max-width: 1000px) {
    .contact_left {
        width: 10%;
    }

    .social_containers {
        margin-top: 32px;
        text-align: center;
    }

    .social_containers a {
        text-decoration: none;
    }

    .contact_single {
        margin-top: 32px;
    }

    .contact_right {
        width: 80%;
    }
}

@media only screen and (max-width: 700px) {
    .contact_left {
        width: 20%;
    }
}

/* Contact Us CSS End --------------------- */
/* Footer CSS Start --------------------- */

.footer_links {
    margin-top: 50px;
    text-align: center;
}

.social_containers {
    text-align: center;
    margin-top: 40px;
}

.all_rights {
    color: white;
    text-align: center;
    margin-top: 25px;
}

@media only screen and (max-width: 1000px) {
    .footer_links {
        margin-top: 1rem;
        display: grid;
        grid-template-columns: repeat(12, 1fr);
        text-align: center;
    }

    .footer_links a {
        grid-column: span 6/ auto;
        flex-basis: 100%;
        margin-top: 32px;
        line-height: 20px;
        padding: 0 16px;
        text-decoration: none;
        color: white;
    }
}

@media only screen and (max-width: 1000px) {

    .footer-top {
        padding-top: 32px;
    }

    .all_rights {
        padding: 16px 0;
        text-align: center;
        margin-bottom: 0;
    }
}
/* Footer CSS End --------------------- */
/* Carousel CSS */
:root {
  --slide-count: 6; /* number of slides in the carousel */
  --slide-width: 400px; /* width of a single slide */
  --carousel-edge-pos:
      calc( 0% - ((var(--slide-width) * var(--slide-count)) - 100%) ); /* formula to calulate the offset value */
}

.carousel-section {
  overflow: hidden;
}

.css-carousel {
  display: flex;
  align-items: stretch;
  gap: 3px;

  -webkit-overflow-scrolling: touch;
  animation: scroll 40s linear alternate infinite;
  animation-play-state: running;
}

.css-carousel:hover {
  animation-play-state: paused;
}

.css-carousel img {
  display: inline-block;
  margin: 0;
  padding: 0;
  width: var(--slide-width);
  height: 100%;
}

@keyframes scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(var(--carousel-edge-pos));
  }
}


/* Carousel CSS End */