﻿/*
font-family: proxima-nova, sans-serif;
font-family: proxima-nova-condensed, sans-serif;
font-family: proxima-nova-extra-condensed, sans-serif;
font-family: rift, sans-serif;
*/

/*
HEADINGS
BUTTONS
HEADER
BODY
NAVIGATION
PAGE STRUCTURE
FORMS
SEARCH
FOOTER
CONTACT
SOCIAL
RESPONSIVE
ANIMATIONS
*/

html {
    font-size: 16px;
}

body {
    background: #FFF;
    font-family: proxima-nova, sans-serif;
    font-size: 1.15rem;
    color: #4b4743;
}

#header-navigation .navbar-left, .i-am-nav li, .page-title, .sidebar-title,
.subheading, h1.post-title, .carousel-indicators li, .right-side-callout h2,
.profile-name, .section-heading, .event-title, .slide-content h2, .slide-content h3,
.accordion-alt .card-header span, .popular-search-terms li a, .panel-title {
    font-family: rift, sans-serif;
}

    #header-navigation .navbar-left .sub-menu li {
        font-family: proxima-nova, sans-serif;
    }

@media (max-width: 576px) {
    #header-navigation .navbar-left a {
        padding: 10px 0 !important;
        text-align: left;
    }
}

.quote-text {
    font-family: serif;
}

a {
    color: #8a6e4b;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    transition: all .6s ease;
}

    a:hover, a:focus, a:active {
        text-decoration: none;
        outline: none;
        color: #505050;
    }

.learn-more {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    line-height: 1.5em;
    display: block;
}

    .learn-more::after {
        content: '\2192';
        position: relative;
        margin: 0 0 0 5px;
        display: inline-block;
    }

.read-more {
    font-weight: bold;
    font-size: 0.8rem;
}

.highlight-link {
    /*   background: url(../images/bg-highlight-link.svg) 0 50% / contain no-repeat transparent; */
    position: relative;
    display: inline-block;
    padding-left: 1.5em;
    color: #2d2926;
    text-transform: uppercase;
    font-weight: bold;
    font-size: 0.9rem;
    line-height: 1em;
    margin-top: 1.5em;
    margin-bottom: 1.5em;
}

    .highlight-link span {
        display: inline-block;
        z-index: 1;
        position: relative;
    }

    .highlight-link:hover::before {
        width: 110%;
    }

    .highlight-link::before {
        content: '';
        position: absolute;
        left: 0;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        height: 3em;
        width: 3em;
        background: #c4b6a5;
        border-radius: 3em;
        -webkit-transition: all .4s ease-in-out;
        -moz-transition: all .4s ease-in-out;
        transition: all .4s ease-in-out;
    }

    .highlight-link.light::before {
        background: #FFF;
    }

    .highlight-link::after {
        content: '\2192';
        position: relative;
        margin: 0 0 0 5px;
        display: inline-block;
        font-size: 1.5em;
    }

    .highlight-link:hover {
        text-decoration: none;
        color: #FFF;
    }

    .highlight-link.light:hover {
        color: #2d2926;
    }

.no-margin {
    margin: 0 !important;
}

.transparent {
    opacity: 0;
}

.float-right {
    float: right;
}

.float-left {
    float: left;
}

blockquote {
    margin: 0 0 1rem;
    padding: 2rem;
    font-size: 1.5rem;
    color: #888;
}

ul {
    padding: 0;
    margin-bottom: 1em;
}

    ul li {
        list-style: none;
        margin: 0 0 0.25em 0;
        line-height: 1.2em;
    }

        ul li::before {
            content: '+';
            position: relative;
            display: inline-block;
            font-weight: bold;
            color: #8a6e4b;
            margin: 0 0.25em 0 0;
        }

p {
    line-height: 1.6em;
}

.container-fluid {
    width: 100%;
    /*   overflow-x: hidden; */
}

.all-caps, .uppercase {
    text-transform: uppercase;
}

.d-block {
    display: block;
}

.d-inline-block {
    display: inline-block;
}

.d-inline {
    display: inline;
}

.no-gutters {
    padding-left: 0;
    padding-right: 0;
}

img {
    max-width: 100%;
    height: auto;
    margin-bottom: 15px;
}

#header img, #footer img {
    margin-bottom: 0;
}

img.full-width {
    display: block;
    margin: 0 !important;
    width: 100%;
    height: auto;
}

.round-image {
    border-radius: 1000px;
    padding-top: 100%;
    overflow: hidden;
    position: relative;
}

    .round-image img {
        position: absolute;
        left: 50%;
        top: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        width: 100%;
        height: auto;
    }

.padding-bottom {
    padding-bottom: 40px !important;
}

/* accordions */

.accordion {
    width: 100%;
}

.card, .panel {
    border: none;
}

.card-header {
    padding: 0;
    margin-bottom: 0;
    background-color: transparent;
    position: relative;
}

    .card-header span {
        display: block;
        padding: .75rem 2.5rem .75rem 0;
        cursor: pointer;
        color: #696969;
        font-weight: 500;
        line-height: 1.2em;
    }

        .card-header span::after {
            content: '-';
            position: absolute;
            right: 1rem;
            top: 50%;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
            display: block;
            z-index: 1;
            color: #8a6e4b;
            font-weight: bold;
        }

        .card-header span.collapsed::after {
            content: '+';
        }

.card-body {
    padding: 1.25rem 0;
}

.accordion-alt .card, .accordion-alt .panel {
    margin-bottom: 20px;
}

.accordion-alt .card-header span {
    display: block;
    padding: .5em 1em;
    font-size: 1.3rem;
    color: #FFF;
    font-weight: bold;
    background: #2d2926;
    text-transform: uppercase;
}

.accordion-alt .card-body {
    padding: 5%;
    background: #f3f2f2;
}

/* HEADINGS */

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    color: #676767;
    line-height: 1em;
    margin-top: 0;
}

h2, .h2 {
    font-size: 1.5rem;
    font-weight: bold;
}

h3, .h3 {
    font-size: 1.5rem;
    font-weight: bold;
}

h5 {
    text-transform: uppercase;
    font-weight: bold;
}

    h1 a, h2 a, h3 a, h4 a, h5 a, h6 a, .h1 a, .h2 a, .h3 a, .h4 a, .h5 a, .h6 a {
        color: #676767;
    }

        h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover, h5 a:hover, h6 a:hover,
        .h1 a:hover, .h2 a:hover, .h3 a:hover, .h4 a:hover, .h5 a:hover, .h6 a:hover {
            color: #676767;
        }

.section-header-small {
    font-weight: bold;
}

.section-heading {
    color: #8a6e4b;
    font-size: 3.5rem;
    font-weight: normal;
}

.subheading {
    color: #8a6e4b;
    font-weight: bold;
    font-size: 2rem;
    line-height: 1em;
    margin-bottom: 50px;
}

.section-title {
    margin-bottom: 50px;
}

.major-program span {
    font-size: 0.8rem;
    line-height: 1em;
    letter-spacing: 0.15em;
}

    .major-program span:nth-child(2) {
        margin-bottom: 10px;
    }

.spacer {
    height: 60px;
}

.collapse {
    -webkit-transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    transition: all .4s ease-in-out;
}

    .collapse.in {
        display: block !important;
    }

.collapsing {
    /*
  position: relative;
  height: 0;
  overflow: hidden;
  transition: none;
*/
}

/*
.affix {
  top: 0!important;
  position: fixed!important;
}

.affix-top {
}

.affix-bottom {
  position: absolute;
}
*/

/* BUTTONS */

.btn {
    padding: 0.375rem 1.5rem !important;
    font-size: 0.9rem;
    transition: color 0.15s ease-in-out, background-color 0.3s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: 50px;
    -webkit-border-radius: 50px;
    background: #8a6e4b;
    color: #FFF;
    cursor: pointer;
    font-weight: bold;
}

.btn-primary {
    color: #fff;
    background-color: rgba(138,110,75,1);
    border-color: #8a6e4b;
}

    .btn-primary:hover, .btn:hover {
        color: #ffffff;
        background-color: #222 !important;
        border-color: #222;
    }

.btn-secondary {
    color: #696969;
    background-color: rgba(138,110,75,0);
    border-color: #8a6e4b;
}

    .btn-secondary:hover {
        color: #fff;
        background-color: rgba(138,110,75,1);
        border-color: #8a6e4b;
    }

.close-button {
    width: 25px;
    height: 25px;
    position: absolute;
    left: 28px;
    top: 36px;
}

    .close-button::before, .close-button::after {
        content: '';
        background: #8a6e4b;
        height: 3px;
        width: 100%;
        display: block;
        margin: 0 auto 5px;
        opacity: 1;
        -webkit-transition: all .6s ease;
        -moz-transition: all .6s ease;
        -o-transition: all .6s ease;
        transition: all .6s ease;
        top: 0;
        position: absolute;
        left: 0;
    }

    .close-button::before {
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }

    .close-button::after {
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
    }

/* HEADER */

#header {
    background: #FFF;
    box-shadow: 0 0 6px rgba(0,0,0,0.08);
    margin: 0;
    height: 105px;
}

#logo {
    width: 115px;
    margin: 0;
    padding: 0;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}

    #logo a {
        background: #8a6e4b;
        display: block;
        padding: 20px 25px;
        height: 100%;
        width: 100%;
    }

    #logo img {
        max-width: 100%;
        display: block;
        margin: 0 auto;
        max-height: 100%;
        width: auto;
        height: auto;
    }

#logo-mobile {
    width: 175px;
    height: auto;
    margin: 0 auto;
    position: absolute;
    left: 50%;
    -webkit-transform: translate(-50%);
    -ms-transform: translate(-50%);
    transform: translate(-50%);
    padding: 0 15px;
}

/* BODY */

#page-content {
    padding-top: 105px;
}

/* NAVIGATION */

#primary-nav {
    float: left;
}

#secondary-nav {
    display: block;
    position: static;
    padding-right: 50px;
    text-align: right;
}

    #secondary-nav li.top-level-item {
        text-align: center;
        float: none;
    }

    #secondary-nav li ul li {
        text-align: left;
    }

#main-menu-toggle {
    position: absolute;
    left: 30px;
    z-index: 100;
}

.navbar-toggle {
    width: 30px;
    display: block;
    height: 30px;
    padding: 0;
    margin-right: 0;
}

    .navbar-toggle .icon-bar {
        background: #8a6e4b;
        height: 3px;
        width: 100%;
        display: block;
        margin: 0 auto 5px;
        opacity: 1;
        -webkit-transition: all .6s ease;
        -moz-transition: all .6s ease;
        -o-transition: all .6s ease;
        transition: all .6s ease;
        /*

  top: 10px;
  position: absolute;
  left: 0;
*/
    }

    .navbar-toggle:not(.collapsed) .icon-bar {
        top: 25%;
        position: absolute;
        margin-top: 0 !important;
        left: 0;
        -ms-transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

    .navbar-toggle:not(.collapsed) .icon-bar {
        transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
    }

        .navbar-toggle:not(.collapsed) .icon-bar + .icon-bar {
            margin-top: 4px;
            -ms-transform: rotate(-45deg);
            -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
        }

        .navbar-toggle:not(.collapsed) .icon-bar:last-child {
            opacity: 0;
        }

nav li::before, .nav li::before {
    display: none;
}

.navbar-left .dropdown-submenu {
    position: relative;
}

    .navbar-left .dropdown-submenu > .dropdown-menu {
        top: 0;
        left: 100%;
        margin-top: -6px;
    }

#header-navigation {
    padding: 0 50px 0 165px;
}

.dropup, .dropright, .dropdown, .dropleft {
    position: inherit;
}

#header-navigation .navbar-left {
    text-transform: uppercase;
}

    #header-navigation .navbar-left li {
        margin-right: 30px;
        margin-bottom: 0;
        padding: 0 0 0 13.8px;
    }

    #header-navigation .navbar-left .sub-menu li {
        margin-right: inherit;
        padding: 0 3%;
    }

        #header-navigation .navbar-left .sub-menu li a {
            font-weight: normal;
            font-size: 1.1rem;
            color: #8a6e4b;
            padding: 10px 0 !important;
        }

            #header-navigation .navbar-left .sub-menu li a.active,
            #header-navigation .navbar-left .sub-menu li a:hover {
                border-left: #8a6e4b 2px solid;
                border-right: #8a6e4b 2px solid;
            }

    #header-navigation .navbar-left a {
        color: #2d2d2d;
        font-weight: bold;
        font-size: 1.25em;
        padding: 2.5rem 0;
        border-bottom: 3px solid transparent;
        display: block;
    }

        #header-navigation .navbar-left a:hover {
            color: #2d2d2d;
            border-bottom: #8a6e4b 3px solid;
        }

.dropdown-toggle::after {
    display: none;
}

.navbar {
    padding: 0;
    border: none;
    width: auto!important;
}

.navbar-nav.navbar-left .sub-menu {
    width: 100vw;
    background: #f0efef;
    text-align: center;
    position: absolute;
    top: 100%;
    left: 0;
}

.navbar-nav.navbar-left li.has-sub-menu:hover .sub-menu {
    max-height: 100vh;
}

.has-sub-menu .row {
    padding: 30px;
}

.navbar-nav.navbar-left .sub-menu.open {
    padding-top: 40px;
    padding-bottom: 40px;
}

.navbar-nav.navbar-left .sub-menu.show {
    max-height: 100vh;
}

#header-navigation .navbar-left a.dropdown-item {
    padding: 0.5rem 0;
    border-bottom: none;
}

    #header-navigation .navbar-left a.dropdown-item:hover {
        border-bottom: none;
    }

ul.nav-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

    ul.nav-menu li {
    }

.sub-menu {
    padding: 0;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    transition: all .6s ease;
}

.mega-menu .sub-menu {
    max-height: 100%;
    margin-bottom: 35px;
}

/* navbar right  */

.navbar-right li {
    margin: 0 0 0 16px;
    display: inline-block;
    vertical-align: middle;
    position: inherit;
}

    .navbar-right li a {
        padding: 2.5rem 0;
        display: block;
    }

.nav > li > a:hover, .nav > li > a:focus {
    background: none;
}

.navbar-right li .sub-menu li {
    margin-left: 0;
    display: block;
}

.link-search .icon-search {
    max-width: 20px;
    height: auto;
}

.link-search .dropdown-toggle::after,
#dropdown-i-am::after {
    display: none;
}

.icon-i-am {
    width: 17px;
    margin: -2px 5px 0 0;
}

.menu-header {
    color: #8a6e4b;
    font-weight: bold;
    text-transform: uppercase;
    display: block;
}

/* seondary navigation */

.mega-menu {
    max-width: 100%;
    border-radius: 0;
    border: none;
    background: none;
    position: absolute !important;
    right: 0;
    top: 100%;
    margin: 0;
    max-height: 0;
    overflow: hidden;
}

.sub-menu.open {
    max-height: 100vh;
    opacity: 1;
    display: block !important;
}

.mega-menu-content {
    background: #f0efef;
    color: #767676;
    text-align: left;
    position: relative;
    width: 800px;
    padding: 70px 30px 30px 75px;
    max-width: 100vw;
    max-height: 90vh;
    overflow-y: scroll;
    border-radius: 0;
    border: none;
    float: right;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    transition: all .6s ease;
}

    .mega-menu-content .tab-content > .active {
    }

    .mega-menu-content .nav-tabs {
        border-bottom: none;
    }

#secondary-nav li .nav-tabs .nav-item {
    text-align: center;
}

.nav-tabs .nav-link {
    border: none;
    border-bottom: transparent 2px solid;
}

.mega-menu-content .nav-tabs .active .nav-link,
.mega-menu-content .nav-tabs .nav-item.show .nav-link a {
    border: none;
    background: none;
    border-bottom: #8a6e4b 2px solid;
}

.i-am-nav {
    margin-bottom: 50px;
}

    .i-am-nav li {
        display: inline-block;
        text-transform: uppercase;
        /*   margin: 0 25px 0 0; */
    }

        .i-am-nav li a,
        .navbar-expand-lg .navbar-nav .nav-link {
            padding: 0.5rem 0;
            color: #767676;
            font-weight: bold;
        }

            .i-am-nav li a.active {
            }

.navbar-right .sub-menu li a {
    color: #767676;
    font-weight: bold;
    padding: 0.25rem 0;
    display: inline-block;
}

    .navbar-right .sub-menu li a li a {
        display: block;
    }

.nav-tabs > li.active > a, .nav-tabs > li.active > a:hover, .nav-tabs > li.active > a:focus {
    color: inherit;
    background-color: transparent;
    border: none;
    border-bottom-color: transparent;
}

.icon-menu {
    border-left: #8a6e4b 1px solid;
}

    .icon-menu .menu-icon {
        display: block;
        text-align: center;
        margin-bottom: 25px;
        padding: 1rem 0;
        color: #777;
        font-weight: bold;
    }

        .icon-menu .menu-icon img {
            display: block;
            max-width: 35px;
            margin: 0 auto;
            max-height: 32px;
            height: auto;
            width: auto;
        }

#i-am-menu .more-button {
    margin: 30px 0 0 0;
    display: inline-block;
}

#search-menu .icon-menu {
    border-left: none;
}

    #search-menu .icon-menu .menu-icon {
        display: inline-block;
        margin: 0 30px 0 0;
    }

.popular-searches {
    margin: 50px 0 0 0;
}

    .popular-searches .section-header-small {
        margin-bottom: 10px;
        display: block;
    }

.popular-search-terms {
    margin: 0;
    padding: 0;
    list-style: none;
}

    .popular-search-terms li {
        list-style: none;
        text-transform: uppercase;
        display: inline-block;
        width: 28%;
        margin: 0 2% 3px 0;
        padding: 0;
        vertical-align: top;
    }

        .popular-search-terms li a {
            display: block;
            position: relative;
            padding: 0.25rem 0;
        }

            .popular-search-terms li a::before {
                content: '';
                width: 2px;
                background: none;
                position: relative;
                left: -4px;
                height: 1em;
                z-index: 1;
                display: inline-block;
                top: 3px;
            }

            .popular-search-terms li a::after {
                content: '';
                width: 2px;
                background: none;
                position: absolute;
                margin-left: 4px;
                height: 1em;
                z-index: 1;
                display: inline-block;
                top: 6px;
            }

            .popular-search-terms li a:hover::after,
            .popular-search-terms li a:hover::before {
                background: #8a6e4b;
            }

/* footer menus */

#footer-menu-wrap {
    display: inline-block;
    float: none;
    vertical-align: top;
}

#footer-contact-info {
    float: left;
}

#footer .nav-link {
    display: block;
    padding: 0.5rem 1rem;
}

#footer .nav-menu {
    text-transform: uppercase;
}

#footer-menu-one {
    font-weight: bold;
}

#footer #footer-menu-two a,
#footer #footer-menu-three a {
    color: #8a6e4b;
}

    #footer #footer-menu-two a:hover,
    #footer #footer-menu-three a:hover {
        color: #FFF;
    }

.footer-nav a {
    letter-spacing: 0.15em;
}

.sidebar-title {
    color: #8a6e4b;
    text-transform: uppercase;
    font-weight: 500;
    font-size: 2.5rem;
}

.sidebar-nav .nav {
    display: block;
}

.sidebar-nav li {
    display: block;
}

    .sidebar-nav li a {
        font-weight: bold;
        color: #b1b1b1;
        font-size: 1em;
        padding: 1rem 0;
        position: relative;
        display: block;
    }

        .sidebar-nav li a:hover,
        .sidebar-nav li a.active {
            color: #696969;
        }

            .sidebar-nav li a:hover::after,
            .sidebar-nav li a.active::after {
                content: '';
                position: absolute;
                right: -50px;
                top: 0;
                height: 100%;
                width: 3px;
                background: #8a6e4b;
            }

/* BREADSCRUMBS */

.breadcrumbs {
    background: #f8f8f8;
    color: #a9a8a8;
    text-transform: uppercase;
    font-size: 0.8rem;
    letter-spacing: 0.16em;
    padding: 8px 40px 8px 165px;
    z-index: 1;
    position: relative;
}

    .breadcrumbs a {
        color: #a9a8a8;
    }

/* PAGE STRUCTURE  */

#header-right {
    float: right;
    padding-right: 50px;
}

#page-header {
    min-height: 500px;
    position: relative;
    text-align: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-color: #999;
    background-position: 50% 50%;
}

#home-hero {
    margin-top: 60px;
}

#home-section-quote {
    background: #353535;
    padding: 200px 0 80px;
    text-align: center;
    color: #FFF;
    margin: -65px 0 0;
}

.quote-text {
    font-size: 2rem;
    margin-bottom: 50px;
    display: block;
}

.attribution {
    font-size: 0.9rem;
    letter-spacing: 0.2em;
}

#home-section-apply {
    padding: 0 0 80px;
    background: #ebebeb;
}

    #home-section-apply .main-col {
        padding: 6%;
    }

    #home-section-apply .secondary-col,
    #home-section-offer .secondary-col {
        min-height: 500px;
        background-size: cover;
        background-position: 50% 50%;
        background-repeat: no-repeat;
        background-color: #888;
    }

#home-section-offer .section-content {
    margin-top: 60px;
    margin-bottom: 60px;
    box-shadow: 0 0 8px rgba(0,0,0,0.1);
}

#home-section-offer .main-col {
    padding: 6%;
}

#home-section-more {
    padding: 120px 0;
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
    background-color: #888;
}

    #home-section-more .main-col {
        background: #FFF;
        padding: 6%;
        text-align: center;
    }

#home-section-news {
}

    #home-section-news .section-header {
        background: #8a6e4b;
        padding: 6%;
        color: #FFF;
    }

    #home-section-news .news-events-header {
        background: #8a6e4b;
        color: #FFF;
    }

.event-news-datepicker {
    padding: 16px;
}

    .event-news-datepicker .datepicker {
        background: none;
        color: #FFF;
        font-weight: bold;
        text-transform: uppercase;
        border: none;
        padding: .75rem 1rem;
        font-size: 1.5rem;
        line-height: 1em;
        width: 100%;
        box-sizing: border-box;
    }

.event-news-cta {
    padding: 20px;
    line-height: 1em;
}

.news-event-select .selectric-wrapper {
    display: block;
    padding: 5%;
}

.news-event-select .selectric {
    display: block;
}

#home-section-news .main-col .section-heading {
    color: #FFF;
}

#home-section-news .main-col .section-body {
    padding: 6%;
}

.news-events-header {
}

.news-event-feed .event-item {
    margin-bottom: 20px;
}

.news-event-feed .event-title {
    display: block;
    text-transform: uppercase;
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1em;
}

.event-title a {
    color: #2d2926;
}

    .event-title a .event-date {
        color: #8a6e4b;
    }

.news-event-feed .event-excerpt {
    font-size: 1rem;
    display: block;
}

.social-media-title {
    padding: 6% !important;
}

.social-media-photo {
    padding-top: 58.33333%;
    text-align: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-color: #999;
    background-position: 50% 50%;
}

.page-header-tiles {
    position: absolute;
    left: 0;
    bottom: 0;
    background: #FFF;
    padding: 20px;
    font-size: 0.85rem;
    box-shadow: 0 3px 5px rgba(0,0,0,0.05);
    z-index: 100;
    max-width: 80%;
}

.header-tile {
    width: 190px;
    display: inline-block;
    vertical-align: middle;
    text-align: left;
    line-height: 1em;
    margin: 0 20px 0 0;
    border-right: #BBB 1px solid;
    padding-right: 15px;
}

    .header-tile:nth-child(2n) {
        margin-right: 0;
        padding-right: 0;
        border-right: none;
    }

.tile-image-wrapper {
    width: 22%;
    position: relative;
    padding-top: 22%;
    display: inline-block;
    margin-right: 5%;
    vertical-align: middle;
}

.tile-content, .news-tile .tile-content {
    width: 70%;
    display: inline-block;
    vertical-align: middle;
}

.tile-title {
    display: block;
    font-weight: bold;
    line-height: 1em;
}

.tile-text {
    font-size: 0.7rem;
    display: block;
    line-height: 1.2em;
}

.recent-news-tiles {
    position: relative;
    display: block;
    margin-left: -20px;
    margin-right: -20px;
    margin-bottom: 30px;
}

.news-tile {
    border-bottom: #DDD 1px solid;
}

    .news-tile:first-child {
        border-top: #DDD 1px solid;
    }

    .news-tile a {
        display: block;
        width: 100%;
        height: 100%;
        padding: 20px;
        color: #696969;
    }

        .news-tile a:hover {
            text-decoration: none;
            background: #f6f6f6;
        }

    .news-tile .tile-title {
        text-transform: uppercase;
        font-size: 0.8rem;
        letter-spacing: 0.1em;
    }

#page-header-sidebar {
    width: 60px;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    padding: 20px;
    text-align: center;
    background: #FFF;
    box-shadow: 0 3px 6px rgba(0,0,0,0.15);
}

    #page-header-sidebar .social-icons {
        position: absolute;
        bottom: 20px;
        left: 50%;
        -ms-transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        width: 30px;
    }

        #page-header-sidebar .social-icons img {
            max-height: 24px;
            max-width: 22px;
            width: auto;
            height: auto;
        }

        #page-header-sidebar .social-icons a {
            margin: 12px auto 0;
            display: block;
        }

.page-header-content {
    position: absolute;
    max-width: 90%;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    color: #FFF;
}

    .page-header-content.right-align {
        max-width: 100%;
        top: 50%;
        left: auto;
        -ms-transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        right: 100px;
        text-align: left;
    }

.page-title {
    color: #FFF;
    font-size: 6.5rem;
    font-weight: 500;
}

.page-header-text {
    width: 600px;
    max-width: 100%;
    margin: 0 auto;
}

.right-align .page-header-text {
    margin: 0;
}

#page-builder, #news-main {
    padding-top: 50px;
    padding-bottom: 100px;
    max-width: 100%;
}

    #page-builder .row .row {
        margin: 0;
        /*   margin-bottom: 20px; */
    }

#sidebar-primary {
    top: -40px;
    background: #FFF;
    box-shadow: 0 2px 11px rgba(0,0,0,0.07);
    padding: 100px 50px 60px;
    position: relative;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    transition: all .6s ease;
}

    #sidebar-primary.sidebar-news {
        padding: 100px 20px 30px;
        /*
  position: -webkit-sticky;
	position: sticky;
	top: 0;
*/
    }

.news-sidebar-title {
    font-size: 1.25rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 40px;
}

.tab-wrapper {
    margin: 0 0 60px 0;
    border: #8a6e4b 3px solid;
}

    .tab-wrapper .nav-tabs .nav-item {
        display: inline-block;
        width: 20%;
        font-size: 1rem;
        min-height: 4em;
    }

        .tab-wrapper .nav-tabs .nav-item a {
            display: block;
            background: #f1ede9;
            border-right: #8a6e4b 3px solid;
            border-bottom: #8a6e4b 3px solid;
            text-align: center;
            width: 100%;
            height: 100%;
            line-height: 1em;
        }

        .tab-wrapper .nav-tabs .nav-item:last-child a {
            border-right: none;
        }

        .tab-wrapper .nav-tabs .nav-item.active a {
            border-bottom: #FFF 3px solid;
            border-right: #8a6e4b 3px solid;
            background: #FFF;
            color: #8a6e4b;
            font-weight: bold;
        }

        .tab-wrapper .nav-tabs .nav-item:last-child a {
            border-right: none !important;
        }

    .tab-wrapper .tab-pane {
        padding: 25px;
    }

.panel-default > .panel-heading {
    color: inherit;
    background: none;
    border: none;
}

.panel-group .panel {
    margin-bottom: 0;
    border-radius: 4px;
    background: none;
    border: none;
    box-shadow: none;
}

.panel-heading {
    padding: 10px 0;
}

.panel-title {
    font-size: 1.5rem;
    font-weight: bold;
    color: inherit;
}

    .panel-title a {
        display: block;
        position: relative;
    }

        .panel-title a::after {
            content: '-';
            position: absolute;
            right: -1rem;
            top: 1rem;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
            display: block;
            z-index: 1;
            color: #8a6e4b;
            font-weight: normal;
            font-size: 2.5rem;
        }

    .panel-title .collapsed::after {
        content: '+';
    }

.panel-body {
    padding: 15px 0;
}

.icon-title {
    margin-bottom: 40px;
}

    .icon-title img {
        display: inline-block;
        width: 15%;
        margin: 0 4% 0 0;
        vertical-align: middle;
    }

    .icon-title .icon-title-text {
        width: 72%;
        color: #4b4743;
        font-weight: bold;
        font-size: 1.35rem;
        line-height: 1em;
        vertical-align: middle;
        display: inline-block;
    }

/* news */

#news-main {
    float: none;
    display: inline-block;
}

.archive-entry {
    margin-bottom: 20px;
}

.archive-link {
    font-weight: bold;
}

.post-title {
    font-size: 1.75rem;
    font-weight: bold;
    line-height: 1em;
    margin-bottom: 0;
}

h1.post-title {
    font-size: 4rem;
    font-weight: 500;
    line-height: 1em;
    margin-bottom: 0;
}

.post-subtitle {
    margin-bottom: 30px;
    display: block;
}

.featured-image {
    margin-bottom: 40px;
}

.post-date {
    font-weight: bold;
    display: block;
    text-transform: uppercase;
    font-size: 1rem;
    margin-bottom: 30px;
}

.news-item-short .featured-image {
    margin-bottom: 10px;
}

.news-item-short .read-more {
    font-weight: bold;
    text-transform: uppercase;
    font-size: 0.8rem;
}

.news-item-short .post-subtitle {
    margin-bottom: 0px;
}

/* carousels  */

.carousel {
    padding-right: 40px;
}

    .carousel .featured-image img {
        width: 100%;
        height: auto;
    }

.carousel-indicators {
    position: absolute;
    right: 0px;
    bottom: 65px;
    left: auto;
    z-index: 15;
    display: block;
    justify-content: center;
    padding-left: 0;
    margin-right: 0;
    margin-left: 0;
    list-style: none;
    width: 30px;
    text-align: center;
}

    .carousel-indicators li, .carousel-indicators li.active {
        flex: unset;
        margin: 3px auto;
        text-indent: 0;
        background-color: transparent;
        display: block;
        float: none;
        height: auto;
        border: none;
        width: auto;
        font-weight: bold;
        font-size: 1.5rem;
        color: #adadad;
        -webkit-transition: color .6s ease;
        -moz-transition: color .6s ease;
        -o-transition: color .6s ease;
        transition: color .6s ease;
    }

        .carousel-indicators li.active {
            color: #4b4743;
        }

.carousel-next-prev {
    position: absolute;
    top: -35px;
    right: 0;
    font-size: 0.75rem;
}

.carousel-control-prev, .carousel-control-next {
    position: relative;
    top: 1px;
    bottom: auto;
    display: inline-block;
    align-items: center;
    justify-content: right;
    width: auto;
    color: #666;
    text-align: right;
    opacity: 1;
    font-size: 1.25rem;
    margin: 0 0 0 5px;
}

    .carousel-control-prev:hover, .carousel-control-prev:focus, .carousel-control-next:hover, .carousel-control-next:focus {
        color: #000;
    }

/* homepage slider  */

#homepage-rotator .left-col {
    padding-top: 20px;
    max-height: 325px;
    overflow: hidden;
}

#homepage-rotator h2, #homepage-rotator h3 {
    color: #8a6e4b;
    margin-bottom: 0;
    font-weight: normal;
}

#homepage-rotator h2 {
    font-size: 6.5rem;
}

#homepage-rotator h3 {
    font-size: 4rem;
}

#homepage-rotator .carousel-next-prev {
    position: absolute;
    top: auto;
    right: auto;
    font-size: 0.75rem;
    bottom: 105px;
    left: 0;
}

#homepage-rotator .page-header-tiles {
    left: auto;
    right: 58.33333%;
    bottom: 0;
    top: auto;
    box-shadow: 0 0 5px rgba(0,0,0,0.15);
    -webkit-box-shadow: 0 0 5px rgba(0,0,0,0.15);
}

#homepage-rotator .featured-image {
    margin-bottom: 0;
}

.service-icon {
    margin: 0 auto;
    display: block;
    margin-bottom: 20px;
    width: 60px;
    height: auto;
}

.right-side-callout {
    background: #8a6e4b;
    padding: 50px;
    color: #FFF;
    position: relative;
    margin-right: -60px;
    margin-bottom: -50px;
}

    .right-side-callout h2,
    .right-side-callout h3,
    .right-side-callout h4 {
        color: #FFF;
        line-height: 1em;
        margin-bottom: 0.5em;
    }

    .right-side-callout a {
        color: #FFF;
    }

.profiles {
    background: #f0efef;
    padding: 100px 0;
}

.department-profiles {
    position: relative;
    padding-top: 80px;
    margin-bottom: 60px;
}

    .department-profiles::after {
        /*
  content: '';
  background: #ebe7e7;
  position: absolute;
  width: 200vw;
  height: 100%;
  left: -50vw;
  z-index: -1;
  top: 0;
*/
    }

.team-profile {
    text-align: center;
    margin-bottom: 60px;
}

.headshot-holder {
    max-width: 80%;
    margin: 0 auto 20px;
    padding-top: 80%;
}

.profile-name {
    color: #8a6e4b;
}

.profile-email, .profile-phone {
    display: block;
    font-size: 1rem;
    color: #696969;
    line-height: 1em;
    margin-bottom: 0.5rem;
}

.profile-title {
    display: block;
    text-transform: uppercase;
    font-weight: bold;
    font-size: 1rem;
    line-height: 1em;
    margin-bottom: 5px;
    color: #696969;
}

.profile-info {
    padding: 25px;
}

.profile-position {
    text-transform: uppercase;
    letter-spacing: 0.15em;
    display: block;
    margin-bottom: 20px;
    font-weight: bold;
    color: #818181;
    font-size: 0.85rem;
}

.project-inquiries .row {
    background: #323232;
}

.project-inquiries .main-col {
    padding: 8% 6%;
    background: #323232;
    color: #c2c2c2;
}

    .project-inquiries .main-col a {
        color: #dfdfdf;
    }

.project-inquiries .secondary-col-content {
    padding: 10%;
    background: #FFF;
}

    .project-inquiries .secondary-col-content h2 {
        color: #8a6e4b;
        margin-bottom: 1em;
    }

/* FORMS */

form {
    position: relative;
}

.ui-widget.ui-autocomplete {
    z-index: 10000;
}

    .ui-widget.ui-autocomplete li:before {
        display: none;
    }

input::placeholder {
    color: #999;
}

label {
    padding-left: 10px;
    display: inline-block;
    font-weight: bold;
}

span > label {
    margin-right: 10px;
}

.search-form-large label {
    display: inline-block;
}

.form-control, .selectric, input[type="text"], input[type="search"], input[type="tel"], input[type="password"], input[type="phone"], input[type="email"], textarea {
    display: block;
    width: 100%;
    font-size: 1rem;
    line-height: 1.5;
    color: #495057;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    height: auto;
    padding: .75rem 1rem .75rem 1rem;
    border-radius: 0;
    -webkit-border-radius: 0;
}

.selectric-tab-select .selectric {
    border-radius: 0px;
    display: inline-block;
    background: none;
    line-height: 1em;
    color: #FFF;
    border: none;
}

.selectric-wrapper {
    display: block;
}

.search-form-large .selectric-wrapper {
    display: inline-block;
}

.selectric-tab-select .selectric .label {
    display: block;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 0;
    line-height: 1em;
    height: auto;
    font-weight: bold;
    font-size: 1.5rem;
    text-transform: uppercase;
}

.selectric-items li::before {
    display: none;
}

.selectric-tab-select .selectric .button::after {
    display: none;
}

.selectric-tab-select .selectric-items li {
    background: #8a6e4b;
    color: #FFF;
}

    .selectric-tab-select .selectric-items li.highlighted {
        background: #EEE;
        color: #8a6e4b;
    }

#includeResults label {
    display: inline;
    margin-right: 8px;
}

doinline, label.doinline, doinline label {
    display: inline;
    margin-right: 8px;
}

#includeResults input {
    margin-right: 8px;
}

.selectric-tab-select .selectric .button {
    background: url(../images/icon-dropdown.png) 50% 50% /contain no-repeat transparent;
    display: block;
    position: absolute;
    right: 25px;
    top: 50%;
    width: 15px;
    height: 25px;
    text-align: center;
    left: auto;
    margin: 0 0 0 6px;
    border: none;
    text-indent: -9999px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

/* checkboxes */

/* Customize the label (the container) */
.form-check-label {
    display: block;
    position: relative;
    padding-left: 35px;
    margin-bottom: 12px;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    /* Hide the browser's default checkbox */
    .form-check-label input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

/* Create a custom checkbox */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 25px;
    width: 25px;
    background-color: #FFF;
    border: 1px solid #ced4da;
}

/* On mouse-over, add a grey background color */
.form-check-label:hover input ~ .checkmark {
    background-color: #ccc;
}

/* When the checkbox is checked, add a blue background */
.form-check-label input:checked ~ .checkmark {
    background-color: #2196F3;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
.form-check-label input:checked ~ .checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
.form-check-label .checkmark:after {
    left: 9px;
    top: 5px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* radio buttons */

.form-radio-label {
    display: block;
    position: relative;
    padding-left: 35px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 22px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    /* Hide the browser's default radio button */
    .form-radio-label input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

    /* Create a custom radio button */
    .form-radio-label .checkmark {
        position: absolute;
        top: 50%;
        left: 0;
        height: 25px;
        width: 25px;
        background-color: #eee;
        border-radius: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }

    /* On mouse-over, add a grey background color */
    .form-radio-label:hover input ~ .checkmark {
        background-color: #ccc;
    }

    /* When the radio button is checked, add a blue background */
    .form-radio-label input:checked ~ .checkmark {
        background-color: #2196F3;
    }

    /* Create the indicator (the dot/circle - hidden when not checked) */
    .form-radio-label .checkmark:after {
        content: "";
        position: absolute;
        display: none;
    }

    /* Show the indicator (dot/circle) when checked */
    .form-radio-label input:checked ~ .checkmark:after {
        display: block;
    }

    /* Style the indicator (dot/circle) */
    .form-radio-label .checkmark::after {
        top: 50%;
        left: 50%;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: white;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }

.form-submit, form button {
    background: #FFF;
    border: 1px solid #ced4da;
    padding: .5rem 1.25rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 0.85rem;
    cursor: pointer;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    transition: all .6s ease;
}

    .form-submit:hover, input[type="submit"]:hover, form button:hover {
        background: #222;
        border: 1px solid #ced4da;
        color: #FFF;
    }

/* SEARCH  */

#search-form-wrapper {
    margin: 0 0 40px 0;
}

#search-field-header {
    background: none;
    border: none;
}

#search-form-wrapper .section-header-small {
    margin-bottom: 30px;
    display: block;
}

.search-field {
    background: none;
    border: none;
    font-weight: bold;
    font-size: 1.5rem;
    border-bottom: #DDD 1px solid;
    padding: 0.35rem;
}

.search-form-large {
    display: block;
    text-align: left;
    width: 100%;
    box-shadow: 0 0 5px rgba(0,0,0,0.1);
    padding: 25px;
    margin: 0 auto 50px;
}

    .search-form-large .search-field {
        display: inline-block;
        width: 40%;
    }

    .search-form-large::before {
        content: '';
        position: relative;
        display: inline-block;
        width: 25px;
        height: 25px;
        margin: 0 10px 4px 0;
        vertical-align: middle;
        background: url(../images/icon-search.png) 50% 50% / contain no-repeat transparent;
    }

#search-menu .search-submit {
    position: absolute;
    text-align: left;
    text-indent: -9999px;
    background: url(../images/icon-search-alt.png) 50% 50% / contain no-repeat transparent;
    border: none;
    left: -30px;
    top: 35%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    padding: 0;
}

.departments-dropdown {
    display: inline-block;
    position: relative;
    margin: 0 0 0 25px;
}

    .departments-dropdown::before {
        content: '';
        position: relative;
        display: inline-block;
        vertical-align: middle;
        width: 25px;
        height: 25px;
        background: url(../images/icon-layout.png) 50% 50% / contain no-repeat transparent;
        margin: 0px 10px 4px 0;
    }

    .departments-dropdown:hover ul.dropdown-menu {
        display: block !important;
    }

.search-submit {
    float: right;
    margin: 8px 0 0;
}

.search-result {
    margin-bottom: 40px;
}

.result-link:hover {
    text-decoration: none;
}

.result-title {
    display: block;
    font-size: 1.2rem;
    font-weight: bold;
    color: #767676;
}

.result-url {
    display: block;
}

/* library search */

#search-tabs .selectric, #search-tabs input[type="text"], #search-tabs input[type="search"], #search-tabs .btn,
#search-tabs-accordion .selectric, #search-tabs-accordion input[type="text"], #search-tabs-accordion input[type="search"], #search-tabs-accordion .btn {
    margin-bottom: 10px;
}

#search-tabs-accordion .panel-title a {
    display: block;
    padding: 1em;
    font-weight: bold;
}

#search-tabs-accordion .panel-heading {
    padding: 0;
}

/* MODALS */
.modal-content {
    color: #4b4743;
    padding: 30px 50px;
}

.modal-header, .modal-footer, .modal-content {
    border: none;
    border-radius: 0;
}

.modal-dialog {
    width: 800px;
    max-width: 94%;
    margin: 15px auto;
}

.close {
    float: none;
    font-size: 60px;
    font-weight: bold;
    line-height: 1;
    color: #8a6e4b;
    text-shadow: 0 1px 0 #ffffff;
    opacity: 1;
    filter: alpha(opacity=100);
    margin: -7px 0 0 -15px;
}

/* FOOTER  */

#footer {
    background: #303030;
    padding: 50px;
    color: #FFF;
}

    #footer a {
        color: #FFF;
    }

        #footer a:hover {
            color: #8a6e4b;
        }

#logo-footer {
    width: 150px;
    height: auto;
    margin: 0 0 40px;
    display: inline-block;
}

.footer-section-header {
    text-transform: uppercase;
    font-weight: bold;
}

/* CONTACT */
#privacy-link, #non-discrimination-link, #ada-link {
    display: block;
}

/* SOCIAL */

.social-icon {
    display: inline-block;
    max-width: 40px;
    height: auto;
    margin: 0 10px 0 0;
}

.social-icons path {
    fill: #8a6e4b;
}

.social-icons a:hover {
    text-decoration: none;
}

#footer .social-icons {
    margin-top: 50px;
    width: 100%;
}

    #footer .social-icons svg {
        width: 40px;
        height: auto;
        margin-right: 20px;
    }

/* INSTAGRAM FEED  */

#instagram-feed a {
    width: 31%;
    margin: 0 2% 2% 0;
    float: left;
    padding-top: 31%;
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
}

.instagram-feed, .instagram-image {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
}

#instafeed img {
    width: 31%;
    margin: 0 2% 2% 0;
    float: left;
}

/* RESPONSIVE */

@media (max-width: 1350px) {
    #header-navigation .navbar-left li {
        margin-right: 25px;
    }

    #header-navigation .navbar-left a {
        font-size: 1em;
    }

    .navbar-right li {
        font-size: 1rem;
        margin: 0 0 0 10px;
    }

    #secondary-nav {
        padding-right: 20px;
        margin-right: 0;
    }

    #header-navigation {
        padding: 0 0 0 140px;
    }
}
/* 1350px */

@media (max-width: 1024px) {
    #logo {
        width: 95px;
    }

    #header-navigation {
        padding: 0 0 0 115px;
    }

    .navbar-right li {
        margin: 0 0 0 7px;
    }
}

@media (max-width: 991px) {
    .navbar-toggle {
        display: block;
    }

    .navbar-collapse.collapse {
        display: none !important;
    }

    .navbar-collapse.in {
        display: block !important;
    }

    #secondary-nav {
        padding-right: 40px;
    }

    #header-navigation {
        padding: 70px 30px 30px 75px;
        top: 0;
        margin-top: 0;
        overflow-y: scroll;
        z-index: 1;
        position: absolute;
        width: 100%;
        height: 100vh !important;
        -webkit-transition: all .6s ease;
        -moz-transition: all .6s ease;
        transition: all .6s ease;
    }

        #header-navigation.collapse {
            max-height: 0;
        }

        #header-navigation.collapse {
            max-height: 100vh;
        }

        #header-navigation.show,
        .navbar-fixed-top .navbar-collapse,
        .navbar-fixed-bottom .navbar-collapse {
            height: 100vh;
            max-height: 100vh;
        }

        #header-navigation .navbar-left li {
            margin-right: 20px;
        }

    .has-sub-menu a.nav-link {
        position: relative;
    }

        .has-sub-menu a.nav-link::after {
            content: '-';
            position: absolute;
            right: 1rem;
            top: 1rem;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
            display: block;
            z-index: 1;
            color: #8a6e4b;
            font-weight: normal;
            font-size: 2.5rem;
            margin-top: 2rem;
        }

        .has-sub-menu a.nav-link::after {
            content: '+';
        }

    .navbar-nav.navbar-left .sub-menu {
        width: 100vw;
        background: #f0efef;
        text-align: left;
        position: relative;
        top: 100%;
        left: auto;
        max-height: 0 !important;
        overflow: hidden;
    }

        .navbar-nav.navbar-left .sub-menu.show {
            max-height: 2000px !important;
        }

    #header-navigation .navbar-left a:hover {
        color: #2d2d2d;
        border-bottom: transparent 3px solid;
    }

    #header-navigation .navbar-left .sub-menu li {
        padding: 0;
    }

    .has-sub-menu .row {
        padding: 0;
        margin: 0 0 30px;
    }

    #header .navbar {
        padding: 30px 0;
    }

    #header-navigation {
        background: #f0efef;
        max-height: 0 !important;
        padding-top: 0;
        padding-bottom: 0;
    }

        #header-navigation.collapse.in {
            max-height: 100vh !important;
            padding: inherit;
            padding: 70px 30px 30px 75px;
        }

        #header-navigation .navbar-left a {
            font-size: 1.4em;
            color: #676767;
        }

    .mega-menu {
        max-height: 0;
        width: 100vw;
        max-width: 100vw;
        height: 100vh;
        top: 0;
        z-index: 1000;
    }

        .mega-menu.open {
            display: block;
            max-height: 100vh;
        }

    .mega-menu-content {
        width: 100%;
        height: 100%;
        max-height: 100vh;
    }

    #secondary-nav {
        position: absolute;
        right: 30px;
        padding-right: 0;
        top: 0;
        text-align: right;
        width: auto;
    }

        #secondary-nav li {
            position: relative;
        }

    .navbar-nav.navbar-left li {
        float: none;
    }

    .navbar-left {
        float: none !important;
    }

    .icon-i-am {
        width: 17px;
        margin: 2px 5px 0 0;
    }

    .breadcrumbs {
        font-size: 0.75rem;
        padding: 8px 40px 8px 30px;
    }

    #page-builder {
        padding-top: 50px;
    }

    #sidebar-primary {
        padding: 70px 30px 30px;
    }

    .sidebar-nav li a:hover::after,
    .sidebar-nav li a.active::after {
        right: -30px;
    }

    .page-title {
        font-size: 3.5rem;
    }

    #footer-contact-info {
        margin-top: 60px;
    }

    .tile-content {
        width: 100%;
    }

    .tile-text, .tile-image-wrapper {
        display: none;
    }

    .header-tile {
        width: 135px;
    }

    .navbar-right li {
        margin: 0 0 0 25px;
    }

    #homepage-rotator .page-header-tiles {
        display: none;
    }

    #home-section-quote {
        padding: 100px 0 80px;
        margin: 60px 0 0;
    }

    .page-header-content.right-align {
        max-width: 86%;
        top: 50%;
        left: 30px;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        right: auto;
        text-align: left;
    }

    .carousel {
        margin: 0 auto;
        width: 100%;
    }

    .featured-image img {
        width: 750px !important;
    }

    #homepage-rotator .slide-content {
        background: #FFF;
        padding-right: 20px;
        position: absolute;
        z-index: 1;
        bottom: 0;
        left: 0;
    }

    #homepage-rotator h3 {
        font-size: 2rem;
    }

    #homepage-rotator h2 {
        font-size: 3rem;
    }

    #homepage-rotator p {
        font-size: 0.8rem;
    }

    .carousel-next-prev {
        display: none;
    }
}
/* 991 */

@media (min-width: 767.98px) {
    /*
  #sidebar-nav {
    display: block;
  }
*/
}
/* 767.98px */

@media (max-width: 768px) {
    #search-menu {
        margin-right: 0;
    }

    #i-am-menu {
        margin-right: 0;
    }

    .page-header-content {
        padding-right: 40px;
    }

    #page-header-sidebar {
        width: 40px;
    }

        #page-header-sidebar .social-icons {
            width: 25px;
        }

    .right-side-callout {
        margin: 40px 0 0;
    }

    #news-main {
        padding-bottom: 0px;
        padding-top: 20px;
    }

    #sidebar-primary.sidebar-news {
        padding-top: 50px;
        margin-bottom: 50px;
    }

    .sidebar-title {
        font-size: 2rem;
        text-align: center;
        margin-bottom: 0;
        cursor: pointer;
        position: relative;
    }

    #sidebar-primary.sidebar-news .sidebar-title {
        margin-bottom: 15px;
    }

    #sidebar-primary {
        top: 0;
    }

    .sidebar-title::before {
        content: '';
        width: 30px;
        height: 2px;
        background: #8a6e4b;
        position: absolute;
        top: -10px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
    }

    #sidebar-primary {
        padding: 30px 30px 20px;
    }

    /*
  #sidebar-nav {
    opacity: 0;
    max-height: 0;
  }

  #sidebar-nav.in {
    opacity: 1;
    max-height: 100%;
  }
*/

    .tile-content {
        width: 100%;
    }

    .tile-text, .tile-image-wrapper {
        display: none;
    }

    .news-tile .tile-text, .news-tile .tile-image-wrapper {
        display: inline-block;
    }

    .header-tile {
        width: 135px;
    }

    .news-tile {
        float: left;
        width: 50%;
        border: none !important;
    }

    #footer-menu-wrap {
        display: block;
    }

    .news-event-select .selectric-wrapper {
        padding: 0;
    }
}
/* 768px */

@media (max-width: 576px) {
    .col-xs-12:nth-child(2n+1) {
        clear: left;
    }

    #header {
        padding: 15px 0;
        height: 70px;
    }

    #logo-mobile {
        width: 160px;
        margin: 0 0 0 10px;
        float: left;
        position: relative;
        left: auto;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
    }

    #header .navbar {
        padding: 0;
    }

    #page-builder {
        padding: 50px 30px;
    }

    #main-menu-toggle {
        right: 30px;
        left: auto;
        top: 0;
    }

    #header-navigation {
        position: absolute;
        top: -15px;
        left: 0;
        width: 100%;
        height: 100vh;
    }

        #header-navigation .navbar-left {
            position: relative;
        }

    .has-sub-menu a.nav-link::after {
        margin-top: 0.5rem;
    }

    #secondary-nav {
        right: 100px;
    }

    .navbar-right li a {
        padding: 1rem 0;
    }

    #page-content {
        padding-top: 70px;
    }

    #breadcrumbs-primary {
        display: none;
    }

    #homepage-rotator .slide-content {
        padding: 5%;
    }

    #home-hero {
        margin-top: 0;
    }

    #home-section-quote {
        padding: 50px;
        margin: 0px 0 0;
    }

    #page-header {
        min-height: 100vh;
        margin-top: -70px;
    }

    .page-header-content.right-align {
        max-width: 85%;
        top: 50%;
        left: 30px;
        right: auto;
    }

    #sidebar-primary, #sidebar-primary.sidebar-news {
        padding: 26px 30px 14px;
        position: fixed;
        top: 100%;
        width: 100%;
        margin-top: -65px;
        min-height: 65px;
        background: #FFF;
        z-index: 100;
        height: 100vh;
        max-height: 100vh;
    }

        #sidebar-primary.open {
            padding-top: 26px;
            top: 0;
            margin-top: 0;
            bottom: 0;
            padding-top: 110px;
            overflow: scroll;
            padding-bottom: 50px;
        }

    .sidebar-title {
        font-size: 1.5rem;
        margin-bottom: 30px;
    }

    .sidebar-nav li {
        text-align: center;
    }

    #header-navigation .navbar-left a {
        padding: 1rem 0;
    }

    .profile-info {
        padding: 5px 0 25px 10px;
    }

    .post-title {
        font-size: 1.25rem;
    }

    .page-header-tiles {
        padding: 5% 3% 0;
        width: 80%;
    }

    .header-tile {
        width: 44%;
        margin-right: 5%;
        padding-right: 5%;
        margin-bottom: 6%;
    }

    #page-header-sidebar .social-icons {
        position: absolute;
        bottom: 100px;
    }

    .news-tile {
        float: none;
        width: 100%;
        border: inherit !important;
    }

    .search-form-large .search-field {
        width: 82%;
    }

    .departments-dropdown {
        display: block;
        position: relative;
        margin: 15px 0 0 0;
    }

    .search-form-large .selectric-wrapper {
        width: 84%;
    }

    .service-icon {
        float: left;
        width: 15%;
        margin: 8px 5% 0 0;
    }

    .service-description {
        float: left;
        width: 80%;
    }
}
/* 576px */

/* ANIMATIONS  */

/*
  animation-name: stretch;
  animation-duration: 1.5s;
  animation-timing-function: ease-out;
  animation-delay: 0s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  animation-fill-mode: none;
  animation-play-state: running;
*/

@keyframes fade-up {
    from {
        opacity: 0;
        -webkit-transform: translateY(50px);
        -ms-transform: translateY(50px);
        transform: translateY(50px);
    }

    to {
        opacity: 1;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
}

.fade-up-hidden {
    opacity: 0;
    -webkit-transform: translateY(50px);
    -ms-transform: translateY(50px);
    transform: translateY(50px);
}

.fade-up {
    animation-name: fade-up;
    animation-duration: 0.5s;
    animation-timing-function: ease;
    -webkit-animation-name: fade-up;
    -webkit-animation-duration: 0.5s;
    -webkit-animation-timing-function: ease;
    /*   animation-delay: 0.25s; */
}

@keyframes fade-left {
    from {
        width: 0;
    }

    to {
        width: 100%;
    }
}

@keyframes fade-out {
    from {
        width: 100%;
    }

    to {
        width: 0;
    }
}

.featured-image {
    overflow: hidden;
}

.carousel .featured-image img {
    max-width: 2000px;
    width: 675px;
    margin-bottom: 0;
    -webkit-transform-origin: center;
    -ms-transform-origin: center;
    transform-origin: center;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    transition: all .6s ease;
}

#featured-news-rotator.carousel .featured-image img {
    width: 100%;
}

.fade-left {
    /*
  transform: translateX(800px);
  transform-origin: right;
*/
    width: 100%;
}

.fade-cover {
    position: relative;
    overflow: hidden;
    width: 0;
    -webkit-transition: width .5s ease-out;
    -moz-transition: width .5s ease-out;
    transition: width .5s ease-out;
}

.fade-out {
    animation-name: fade-out;
    animation-duration: .4s;
    animation-timing-function: ease-out;
    -webkit-animation-name: fade-out;
    -webkit-animation-duration: .4s;
    -webkit-animation-timing-function: ease-out;
    -webkit-transform-origin: right;
    -ms-transform-origin: center;
    transform-origin: center;
    width: 0;
}

.active .fade-left {
    animation-name: fade-left;
    animation-duration: 1.7s;
    animation-timing-function: ease;
    -webkit-animation-name: fade-left;
    -webkit-animation-duration: 1.7s;
    -webkit-animation-timing-function: ease;
    /*   animation-delay: 0.25s; */
    /*   transform: translateX(0); */
    -webkit-transform-origin: right;
    -ms-transform-origin: right;
    transform-origin: right;
    width: 100%;
}

/*
.active .featured-image img {
  transform: scale(1, 1);
  transform-origin: center;
}
*/

@keyframes scale-down {
    from {
        -webkit-transform: scale(1.5);
        -ms-transform: scale(1.5);
        transform: scale(1.5);
    }

    to {
        -webkit-transform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1);
    }
}

.active .scale-down {
    animation-name: scale-down;
    animation-duration: 1s;
    animation-timing-function: ease;
    animation-delay: 2.5s;
    -webkit-animation-name: scale-down;
    -webkit-animation-duration: 1s;
    -webkit-animation-timing-function: ease;
    -webkit-animation-delay: 2.5s;
    -webkit-transform-origin: center;
    -ms-transform-origin: center;
    transform-origin: center;
}

/*Validators*/
input[type="text"].invalid, .invalid {
    background-color: #fbe3e4;
    border: 1px solid red;
}

span.validator {
    color: red;
    font-size: 20pt;
    margin-top: -8px;
    display: inline-block;
}

/* Stuff that Aaron added */

.center-content {
    margin-left: auto;
    margin-right: auto;
}

.no-float {
    float: none;
}

/* ///////////////////////////// BOOTSTRAP 4 STYLES //////////////////////////////// */

@media (min-width: 576px) {
    .text-sm-left {
        text-align: left !important;
    }

    .text-sm-right {
        text-align: right !important;
    }

    .text-sm-center {
        text-align: center !important;
    }
}

@media (min-width: 768px) {
    .text-md-left {
        text-align: left !important;
    }

    .text-md-right {
        text-align: right !important;
    }

    .text-md-center {
        text-align: center !important;
    }
}

@media (min-width: 992px) {
    .text-lg-left {
        text-align: left !important;
    }

    .text-lg-right {
        text-align: right !important;
    }

    .text-lg-center {
        text-align: center !important;
    }
}

@media (min-width: 1200px) {
    .text-xl-left {
        text-align: left !important;
    }

    .text-xl-right {
        text-align: right !important;
    }

    .text-xl-center {
        text-align: center !important;
    }
}