﻿@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

:root {
    --ff-primary: "Montserrat", sans-serif;
    --ff-secondary: "Montserrat", sans-serif;
    --ff-heading: var(--ff-primary);
    --ff-body: var(--ff-secondary);
    --fw-regular: 400;
    --fw-semi-bold: 600;
    --fw-bold: 700;
    --fs-300: 0.875rem;
    --fs-400: 1rem;
    --fs-500: 1.25rem;
    --fs-550: 1.5rem;
    --fs-600: 2rem;
    --fs-700: 2.5rem;
    --fs-800: 3rem;
    --fs-primary-heading: var(--fs-700);
    --fs-secondary-heading: var(--fs-600);
    --fs-sub-heading: var(--fs-550);
    --fs-nav: var(--fs-500);
    --fs-body: var(--fs-400);
    --fs-button: var(--fs-300);
}

/* Large - Screens */
@media (min-width: 768px) {
    :root {
        --fs-primary-heading: var(--fs-800);
        --fs-secondary-heading: var(--fs-700);
        --fs-sub-heading: var(--fs-550);
        --fs-nav: var(--fs-500);
        --fs-body: var(--fs-400);
        --fs-button: var(--fs-300);
    }
}

/***********************************************
    SERVICE SECTION
***********************************************/

@media (min-width: 768px) {
    .html-center {
        padding-top: 30px !important;
    }
}

/***********************************************
    SLIDESHOW
***********************************************/
    .element-type-slideshow .btn {
        height: 50px;
        line-height: 50px;
        font-weight: 400;
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 50px;
        font-size: 20px !important;
        border: 1px solid;
        border-radius: 0px;
        transition: all .3s ease-in-out;
        letter-spacing: 0px;
    }

    @media (min-width: 768px) {

        .slideshow-overlayvert-top {
            top: 10%;
        }

        .slideshow-overlay-left {
            left: 13%;
        }

        .sb-slide-txt {
            display: block;
        }

        .overlay-content {
            max-width: 710px !important;
        }

        .element-type-slideshow .btn {
            max-width: 250px;
        }
    }


/***********************************************
    GENERAL
***********************************************/
    @media (min-width: 1400px) {
        .container {
            width: 1400px;
        }
    }

    .page-content .container,
    .page-content .container-fluid {
        background-color: transparent;
    }

    .btn {
        border-radius: 0px;
    }

/***********************************************
    BANNER
***********************************************/

    .banner-container {
        padding: 8px 0px;
        max-width: 100%;
    }

    a.banner-link {
        font-size: var(--fs-body);
        text-shadow: none;
    }

    .banner-links-bar {
        padding: 0px 15px;
        max-width: 100%;
    }

    .banner-links-bar-wrapper .social-media-links,
    .banner-links-bar-wrapper .address-link,
    .banner-links-bar-wrapper .phonenumber-link {
        padding: 8px 0px;
    }

    /* Social Media links */
    .media-icon,
    .media-icon-small {
        box-shadow: none !important;
    }

/***********************************************
    NAVBAR
***********************************************/
.navbar-fixed-shadow {
    box-shadow: none;
}

    .navbar {
        transition: all .2s ease-in-out;
        border-bottom: 2px solid;
    }

    a.navbar-brand > img {
        max-width: 300px !important;
    }

    .navbar-brand > img {
        padding: 15px 0px;
    }

    @media (max-width: 767.98px) {
        .navbar-header a.navbar-brand img {
            max-width: 255px !important;
        }
    }

    @media (min-width: 768px) {
        .navbar .container.wide-navbar {
            width: 100%;
        }

        .navbar .container {
            padding-right: 15px;
        }
    }

    @media (min-width: 768px) {
        .navbar-nav,
        a.navbar-brand:has(.fa-home) {
            margin-block-start: 1.3em;
            margin-block-end: 1.3em;
            margin-inline-start: 0px;
            margin-inline-end: 0px;
            padding-inline-start: 40px;
            padding-right: 15px;
        }

        .navbar-collapse {
            padding-left: 0px;
            padding-right: 0px;
        }
    }



/***********************************************
    TYPOGRAPHY
***********************************************/
    html {
        font-size: 16px;
    }

    body {
        font-family: var(--ff-body);
        font-size: var(--fs-body);
        line-height: 1.5;
    }

    h1, h2, h3,
    h4, h5, h6 {
        font-family: var(--ff-heading) !important;
        margin-top: 8px;
        margin-bottom: 8px;
        line-height: 1.2;
        text-wrap: balance;
        font-weight: 400 !important;
        text-transform: uppercase;
    }

    h1 {
        font-size: var(--fs-primary-heading) !important;
    }

    h2, h3, h4 {
        font-size: var(--fs-secondary-heading) !important;
        line-height: 1.2;
    }

    h5, h6 {
        font-size: var(--fs-secondary-heading) !important;
        line-height: 1.2;
    }

    a {
        text-decoration: none;
        font-size: var(--fs-body);
    }

        a:focus, a:hover {
            color: inherit;
        }

    input {
        cursor: text !important;
    }

    .sub-heading {
        font-size: var(--fs-sub-heading);
        font-weight: var(--fw-regular);
        line-height: 1.2;
    }

    .element-heading {
        padding-top: 0px;
        padding-bottom: 8px;
    }

    .form-control {
        font-size: 16px;
    }

    .page-content .container,
    .page-content .container-fluid {
        background-color: transparent;
    }


/***********************************************
    FORMS
***********************************************/
    .form-submit .btn {
        display: flex;
        width: 100%;
        height: 50px;
        align-items: center;
        justify-content: center;
        font-size: 18px;
        transition: all .3s ease-in-out;
    }

    @media (min-width: 768px) {
        .form-submit .btn {
            width: max-content;
        }
    }

/***********************************************
    FOOTER
***********************************************/
    .footer-links-heading {
        font-size: var(--fs-body);
    }


/*****************************************************************************
    Unique to theme - can remove below
*****************************************************************************/
/***********************************************
    HERO SECTION
***********************************************/
.hero-section {
    position: relative;
    min-height: 650px;
    background-position: center;
    border-image: linear-gradient(90deg, rgba(0, 0, 0, .7) 100%, rgba(255, 255, 255, 0) 100%) fill 1;
}

    .hero-section .container {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }

.btn-hero {
    font-weight: 700;
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    font-size: 20px;
    border: 1px solid;
    border-radius: 0px;
    transition: all .3s ease-in-out;
}

.hero-button .quicklinkbuttons-vertical {
    padding: 0px 15px 15px 15px;
}

.hero-button .element-heading-quicklinkbuttons {
    padding: 0px;
}

.hero-button .quicklinkbutton {
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    font-size: 20px !important;
    border: 1px solid;
    border-radius: 0px;
    transition: all .3s ease-in-out;
    letter-spacing: 0px;
}

    .hero-button .quicklinkbutton .quicklinkbutton-label {
        letter-spacing: 0px;
    }

@media (min-width: 768px) {
    .hero-section .container {
        position: relative;
        left: 0;
        top: 0;
        transform: none;
        padding-top: 60px;
    }

    .hero-button .quicklinkbutton {
        max-width: 250px;
    }
}

@media (max-width: 767.98px) {

    .hero-section .container {
        width: 100%;
    }
}

@media (min-width: 768px) {

    .btn-hero {
        max-width: 200px;
    }

    .hero-section {
        border-image: none;
    }
}


/***********************************************
    CustomHTML
***********************************************/

.about-row {
    background-position: center;
    text-align: center;
}

.row-bg-dark {
    padding: 40px 0px;
}

@media (min-width: 768px) {
    .service-row, .appointment-row, .about-row, .location-row {
        margin: 50px 0px;
    }
    .html-center {
        padding-top: 60px !important;
    }
}


/***********************************************
    Slideshow
***********************************************/
.sb-slide-txt {
    display: none;
}

.element-type-slideshow .btn {
    height: 50px;
    line-height: 50px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    font-size: 20px !important;
    border: 1px solid;
    border-radius: 0px;
    transition: all .3s ease-in-out;
    letter-spacing: 0px;
}

.carousel-control {
    -ms-border-radius: 0px;
    border-radius: 0px;
}

@media (min-width: 768px) {

    .slideshow-overlayvert-top.slideshow-overlayvert-top {
        top: 10%;
    }

    .slideshow-overlay-left.slideshow-overlay-left {
        left: 13%;
    }

    .sb-slide-txt {
        display: block;
    }

    .overlay-content.overlay-content {
        max-width: 710px !important;
    }

    .element-type-slideshow .btn {
        max-width: 250px;
    }

    .carousel-control .glyphicon-chevron-left, .carousel-control .icon-prev {
        margin-left: -14px;
    }

    .carousel-control .glyphicon-chevron-right, .carousel-control .icon-next {
        margin-right: -14px;
    }
}
/***********************************************
    Custom Quicklinks
***********************************************/
.about-row .cus-qlbtn .quicklinkbutton {
    margin-inline: auto;
}

.cus-ql-bttns a.btn.quicklinksbutton {
    height: 50px;
    line-height: 50px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    font-size: 20px !important;
    border: 1px solid;
    border-radius: 0px;
    transition: all .3s ease-in-out;
    letter-spacing: 0px;
    min-width: 300px;
}

.cus-ql-bttns .quicklinkbuttons-horizontal {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 0px 20px;
}

    .cus-ql-bttns .quicklinkbuttons-horizontal .quicklinkbutton-wrapper {
        width: 100%;
    }


.cus-ql-bttns .element-heading-quicklinkbuttons {
    display: none;
}

.cus-ql-bttns .quicklinkbutton, 
.cus-qlbtn .quicklinkbutton {
    height: 50px;
    line-height: 50px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    font-size: 20px !important;
    border: 1px solid;
    border-radius: 0px;
    transition: all .3s ease-in-out;
    letter-spacing: 0px;
}

.cus-qlbtn .quicklinkbuttons-vertical {
    padding-top: 0px;
    padding-botto: 0px;
}

@media (min-width: 768px) {
    .cus-ql-bttns .quicklinkbuttons-horizontal {
        flex-direction: row;
    }

    .cus-ql-bttns a.btn.quicklinkbutton {
        max-width: 250px;
    }

    .cus-ql-bttns .quicklinkbuttons-horizontal .quicklinkbutton-wrapper {
        width: max-content;
    }
    .cus-ql-bttns a.btn.quicklinkbutton {
        max-width: none;
        width: 300px;
    }

    .cus-qlbtn .quicklinkbutton {
        max-width: 250px;
    }
}

/*************************************************
Location Section
*************************************************/
@media (min-width: 768px) {
    .location-row .html-center {
        padding-left: 50px;
        padding-right: 50px;
    }
}


/*************************************************
Body style section
*************************************************/
@media (min-width: 768px) {
    .body-style-title.body-style-title {
        padding-top: 50px;
        padding-bottom: 50px;
    }
}