@charset "utf-8";
/*
Theme Name: Nonotuck Theme
Author URI: https://vibrantbrands.com/
Description: A custom theme by Vibrant Brands
Version: 1.0
Text Domain: nonotuck
*/

/**
* Owl Carousel v2.3.4
* Copyright 2013-2018 David Deutsch
* Licensed under: SEE LICENSE IN https://github.com/OwlCarousel2/OwlCarousel2/blob/master/LICENSE
*/
.owl-carousel,
.owl-carousel .owl-item {
    -webkit-tap-highlight-color: transparent;
    position: relative;
}
.owl-carousel {
    display: none;
    width: 100%;
    z-index: 1;
}
.owl-carousel .owl-stage {
    position: relative;
    -ms-touch-action: pan-Y;
    touch-action: manipulation;
    -moz-backface-visibility: hidden;
}
.owl-carousel .owl-stage:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
}
.owl-carousel .owl-stage-outer {
    position: relative;
    overflow: hidden;
    -webkit-transform: translate3d(0, 0, 0);
}
.owl-carousel .owl-item,
.owl-carousel .owl-wrapper {
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
}
.owl-carousel .owl-item {
    min-height: 1px;
    float: left;
    -webkit-backface-visibility: hidden;
    -webkit-touch-callout: none;
}
.owl-carousel .owl-item img {
    display: block;
    width: 100%;
}
.owl-carousel .owl-dots.disabled,
.owl-carousel .owl-nav.disabled {
    display: none;
}
.no-js .owl-carousel,
.owl-carousel.owl-loaded {
    display: block;
}
.owl-carousel .owl-dot,
.owl-carousel .owl-nav .owl-next,
.owl-carousel .owl-nav .owl-prev {
    cursor: pointer;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.owl-carousel .owl-nav button.owl-next,
.owl-carousel .owl-nav button.owl-prev,
.owl-carousel button.owl-dot {
    background: 0 0;
    color: inherit;
    border: none;
    padding: 0 !important;
    font: inherit;
}
.owl-carousel.owl-loading {
    opacity: 0;
    display: block;
}
.owl-carousel.owl-hidden {
    opacity: 0;
}
.owl-carousel.owl-refresh .owl-item {
    visibility: hidden;
}
.owl-carousel.owl-drag .owl-item {
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.owl-carousel.owl-grab {
    cursor: move;
    cursor: grab;
}
.owl-carousel.owl-rtl {
    direction: rtl;
}
.owl-carousel.owl-rtl .owl-item {
    float: right;
}
.owl-carousel .animated {
    animation-duration: 1s;
    animation-fill-mode: both;
}
.owl-carousel .owl-animated-in {
    z-index: 0;
}
.owl-carousel .owl-animated-out {
    z-index: 1;
}
.owl-carousel .fadeOut {
    animation-name: fadeOut;
}
@keyframes fadeOut {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
.owl-height {
    transition: height 0.5s ease-in-out;
}
.owl-carousel .owl-item .owl-lazy {
    opacity: 0;
    transition: opacity 0.4s ease;
}
.owl-carousel .owl-item .owl-lazy:not([src]),
.owl-carousel .owl-item .owl-lazy[src^=""] {
    max-height: 0;
}
.owl-carousel .owl-item img.owl-lazy {
    transform-style: preserve-3d;
}
.owl-carousel .owl-video-wrapper {
    position: relative;
    height: 100%;
    background: #000;
}
.owl-carousel .owl-video-play-icon {
    position: absolute;
    height: 80px;
    width: 80px;
    left: 50%;
    top: 50%;
    margin-left: -40px;
    margin-top: -40px;
    cursor: pointer;
    z-index: 1;
    -webkit-backface-visibility: hidden;
    transition: transform 0.1s ease;
}
.owl-carousel .owl-video-play-icon:hover {
    -ms-transform: scale(1.3, 1.3);
    transform: scale(1.3, 1.3);
}
.owl-carousel .owl-video-playing .owl-video-play-icon,
.owl-carousel .owl-video-playing .owl-video-tn {
    display: none;
}
.owl-carousel .owl-video-tn {
    opacity: 0;
    height: 100%;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    transition: opacity 0.4s ease;
}
.owl-carousel .owl-video-frame {
    position: relative;
    z-index: 1;
    height: 100%;
    width: 100%;
}

/**
* Owl Carousel v2.3.4
* Copyright 2013-2018 David Deutsch
* Licensed under: SEE LICENSE IN https://github.com/OwlCarousel2/OwlCarousel2/blob/master/LICENSE
*/
.owl-theme .owl-dots,
.owl-theme .owl-nav {
    text-align: center;
    -webkit-tap-highlight-color: transparent;
}
.owl-theme .owl-nav {
    margin-top: 10px;
}
.owl-theme .owl-nav [class*="owl-"] {
    color: #fff;
    font-size: 14px;
    margin: 5px;
    padding: 4px 7px;
    background: #d6d6d6;
    display: inline-block;
    cursor: pointer;
    border-radius: 3px;
}
.owl-theme .owl-nav [class*="owl-"]:hover {
    background: #869791;
    color: #fff;
    text-decoration: none;
}
.owl-theme .owl-nav .disabled {
    opacity: 0.5;
    cursor: default;
}
.owl-theme .owl-nav.disabled + .owl-dots {
    margin-top: 10px;
}
.owl-theme .owl-dots .owl-dot {
    display: inline-block;
    zoom: 1;
}
.owl-theme .owl-dots .owl-dot span {
    width: 10px;
    height: 10px;
    margin: 5px 7px;
    background: #d6d6d6;
    display: block;
    -webkit-backface-visibility: visible;
    transition: opacity 0.2s ease;
    border-radius: 30px;
}
.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
    background: #869791;
}

/*! Lity - v2.4.1 - 2020-04-26
* http://sorgalla.com/lity/
* Copyright (c) 2015-2020 Jan Sorgalla; Licensed MIT */
.lity {
    z-index: 9990;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    white-space: nowrap;
    background: #0b0b0b;
    background: rgba(0, 0, 0, 0.9);
    outline: none !important;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
}
.lity.lity-opened {
    opacity: 1;
}
.lity.lity-closed {
    opacity: 0;
}
.lity * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.lity-wrap {
    z-index: 9990;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-align: center;
    outline: none !important;
}
.lity-wrap:before {
    content: "";
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    margin-right: -0.25em;
}
.lity-loader {
    z-index: 9991;
    color: #fff;
    position: absolute;
    top: 50%;
    margin-top: -0.8em;
    width: 100%;
    text-align: center;
    font-size: 14px;
    font-family: Arial, Helvetica, sans-serif;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
}
.lity-loading .lity-loader {
    opacity: 1;
}
.lity-container {
    z-index: 9992;
    position: relative;
    text-align: left;
    vertical-align: middle;
    display: inline-block;
    white-space: normal;
    max-width: 100%;
    max-height: 100%;
    outline: none !important;
}
.lity-content {
    z-index: 9993;
    width: 100%;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    -o-transition: -o-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease, -o-transform 0.3s ease;
}
.lity-loading .lity-content,
.lity-closed .lity-content {
    -webkit-transform: scale(0.8);
    -ms-transform: scale(0.8);
    -o-transform: scale(0.8);
    transform: scale(0.8);
}
.lity-content:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}
.lity-close {
    z-index: 9994;
    width: 35px;
    height: 35px;
    position: fixed;
    right: 0;
    top: 0;
    -webkit-appearance: none;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
    padding: 0;
    color: #fff;
    font-style: normal;
    font-size: 35px;
    font-family: Arial, Baskerville, monospace;
    line-height: 35px;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
    border: 0;
    background: none;
    outline: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}
.lity-close::-moz-focus-inner {
    border: 0;
    padding: 0;
}
.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited {
    text-decoration: none;
    text-align: center;
    padding: 0;
    color: #fff;
    font-style: normal;
    font-size: 35px;
    font-family: Arial, Baskerville, monospace;
    line-height: 35px;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
    border: 0;
    background: none;
    outline: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}
.lity-close:active {
    top: 1px;
}
.lity-image img {
    max-width: 100%;
    display: block;
    line-height: 0;
    border: 0;
}
.lity-iframe .lity-container,
.lity-youtube .lity-container,
.lity-vimeo .lity-container,
.lity-facebookvideo .lity-container,
.lity-googlemaps .lity-container {
    width: 100%;
    max-width: 964px;
}
.lity-iframe-container {
    width: 100%;
    height: 0;
    padding-top: 56.25%;
    overflow: auto;
    pointer-events: auto;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-overflow-scrolling: touch;
}
.lity-iframe-container iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #000;
}
.lity-hide {
    display: none;
}

/* Reset */
* {
    box-sizing: border-box;
}
html,
body,
div,
span,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
code,
em,
img,
strong,
sub,
sup,
var,
b,
u,
i,
center,
ol,
ul,
li,
fieldset,
form,
label,
legend,
article,
aside,
canvas,
figure,
figcaption,
footer,
header,
nav,
section,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    font-family: "Roboto Condensed", sans-serif;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}
body {
    line-height: 1;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Khand", sans-serif;
    font-weight: bold;
}
a,
a:focus,
a:hover {
    text-decoration: none;
}

/* Skip to Main Content */
/* ------------------------------------------------------------ */

.main_content {
    height: 0;
    overflow: hidden;
    display: block;
    font-size: 0;
    text-transform: uppercase;
    line-height: 0;
    background: #193f84;
    color: #fff;
    font-weight: bold;
    letter-spacing: 1px;
}
.main_content:focus {
    font-size: 14px;
    line-height: 16px;
    height: 36px;
    padding: 10px 15px;
}
.main_content:focus + header {
    top: 36px;
}

/* Globals */
/* ------------------------------------------------------------ */

main#content.no_hero {
    padding: 90px 0 0 0;
}
.wrapper {
    max-width: 1380px;
    padding: 0 30px;
    margin: 0 auto;
    width: 100%;
}
.wp-block-buttons {
    margin: 20px 0;
}
.wp-block-button__link {
    color: #fff !important;
    background-color: #9d0d40;
    border: 3px solid #9d0d40;
    font-size: 20px;
    line-height: normal;
    display: inline-block;
    padding: 6px 24px;
    transition: 175ms ease-in-out;
    border-radius: 0;
    height: auto;
}
.wp-block-button__link:hover {
    color: #193f84 !important;
    background: transparent;
}

/* Header Nav */
/* ------------------------------------------------------------ */

header {
    z-index: 1000;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: rgba(25, 63, 132, 0.8);
    box-shadow: 3px 4px 15px -4px rgba(0, 0, 0, 0.5);
}
.header_inner {
    display: flex;
    justify-content: space-between;
    gap: 50px;
}
#logo {
    display: block;
    background-repeat: no-repeat;
    background-position: center left;
    background-image: url("img/nonotuck-logo-white.png");
    background-size: contain;
    flex: 0 0 140px;
}
#logo h1 {
    position: absolute;
    user-select: none;
    text-indent: -9999px;
}
#mnavbutton {
    display: none;
}

header nav {
    display: flex;
    justify-content: center;
    gap: 10px;
    padding: 18px 0;
}
header nav .nav_item_holder {
    position: relative;
    align-content: center;
}
header nav .nav_item_holder:after {
    content: "";
    height: 2px;
    width: 100%;
    position: absolute;
    bottom: -6px;
    left: 0;
    display: block;
    background: #c92760;
    opacity: 0;
    transition: ease 300ms all;
}
header nav .nav_item_holder:focus:after,
header nav .nav_item_holder:hover:after {
    opacity: 1;
    bottom: 0px;
}
header nav .nav_item_holder > a {
    color: white;
    padding: 4px;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    display: block;
    line-height: 28px;
    transition: ease all 150ms;
}
header nav .nav_item_holder > a:hover {
    color: #fff;
}

/* Subnav */
/* ------------------------------------------------------------ */

header nav .nav_item_holder.menu-item-has-children {
    display: flex;
}
header nav .nav_item_holder.menu-item-has-children > a {
    padding-right: 0;
}
.subnav_more {
    width: 20px;
    position: relative;
    cursor: pointer;
}
.subnav_more:after {
    content: "\f0d7";
    font-family: "Font Awesome 6 Pro";
    font-weight: 900;
    color: #fff;
    font-size: 13px;
    line-height: 36px;
    text-align: center;
    width: 100%;
    display: block;
    transition: ease all 150ms;
}
.subnav_more:hover:after {
    color: #7ac2ea;
}
.sub_nav {
    display: none;
    top: 100%;
    position: absolute;
    left: -4px;
    background-color: #9d0d40;
    text-align: left;
    min-width: 270px;
    padding: 0;
    z-index: 10;
}

header nav .nav_item_holder:focus-within .sub_nav,
header nav .nav_item_holder .subnav_more:focus + .sub_nav,
header nav .nav_item_holder:hover > .sub_nav {
    display: block;
}
.sub_nav a {
    display: block;
    color: #fff;
    padding: 8px 8px;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    transition: 175ms ease-in-out;
}
.sub_nav a:hover {
    color: #9d0d40;
    background: #fff;
}

/* Homepage */
/* ------------------------------------------------------------ */

.home_slider_wrapper {
    position: relative;
}
#home_hero_slider .item {
    height: 82vh;
    position: relative;
}
#home_hero_slider .item .slide_bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: block;
    background-size: cover;
    background-position: center;
    z-index: 1;
    border-radius: 0 0 0 100px;
}
#home_hero_slider .item h2 {
    position: absolute;
    top: 15%;
    left: 5%;
    font-size: 150px;
    color: #fff;
    font-weight: bold;
    z-index: 2;
    text-transform: uppercase;
    text-shadow: 0 0 25px #000;
}
.home_hero_controls {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translate(0-50%);
    display: flex;
    justify-content: space-between;
    z-index: 5;
}
.home_hero_controls > div {
    height: 69px;
    width: 41px;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    font-size: 24px;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: ease all 200ms;
    user-select: none;
}
.home_hero_controls > div:hover {
    cursor: pointer;
    background: rgba(0, 0, 0, 0.9);
}

.home_hero_content {
    background-image: url("img/home_hero_bg.webp");
    background-size: cover;
}

/* Homepage Parallax Description Blue Block */
/* ------------------------------------------------------------ */
#description {
    top: calc(85vh - 90px);
    width: 100%;
    height: auto;
    z-index: 10;
    position: absolute;
}
.description_row {
    display: flex;
    border-radius: 0 20px 0 20px;
    overflow: hidden;
    box-shadow: -5.7px -1.8px 8px 1px rgba(0, 0, 0, 0.39);
}
#description-column-1 {
    background-color: rgba(7, 32, 77, 0.85);
    font-size: 18px;
    padding: 3rem;
    line-height: 1.6em;
    color: #fff;
    flex: 1 1 auto;
}
#description-column-2 {
    background-color: rgba(255, 255, 255, 0.93);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: flex;
    flex: 1 0 30%;
}

/* Homepage 3-up Services CTAs */
/* ------------------------------------------------------------ */
#services {
    position: relative;
    background-color: #193f84;
    background-image: url("img/home_hero_bg.webp");
    background-size: cover;
    padding-top: 270px;
    padding-bottom: 60px;
    margin-top: -100px;
}
.services_grid {
    display: grid;
    gap: 7%;
    grid-template-columns: repeat(3, 1fr);
    margin: 30px 0;
}
.services_grid_item {
    text-align: center;
}
.services_grid_item img {
    height: auto;
    width: 120px;
}
.services_grid_item h2 {
    color: #fff;
    font-size: 30px;
    margin: 0 0 20px 0;
}
.services_grid_item p {
    color: #fff;
    font-size: 18px;
    line-height: 1.4em;
    margin: 0 0 30px 0;
}
.home_button {
    font-size: 17px;
    line-height: normal;
    display: inline-block;
    padding: 8px 30px;
    border-bottom-left-radius: 10px;
    border-top-right-radius: 10px;
    transition: 175ms ease-in-out;
    color: white;
    background-color: #9d0d40;
    border: 2px solid #9d0d40;
    box-shadow: -1.9px -0.6px 8px 1px rgba(40, 53, 101, 0.55);
}
.home_button:hover {
    background-color: transparent;
}

/* Homepage Complex Grid */
/* ------------------------------------------------------------ */
#homepage-grid {
    grid-template-columns: repeat(13, 1fr);
    grid-template-rows: repeat(3, 290px);
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    -ms-grid-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    -ms-grid-rows: 290px 290px 290px;
    margin: 5px;
    display: grid;
}
.grid-item {
    background-color: #ddd;
}
.grid-item-text-container {
    display: flex;
    display: -ms-flex;
    align-items: center;
    -ms-align-items: center;
    justify-content: center;
    justify-items: center;
    width: 100%;
    height: 100%;
    padding-top: 25px;
    padding-bottom: 25px;
    padding-left: 20px;
    padding-right: 20px;
}
.grid-bg-full {
    width: 100%;
    height: 100%;
}
.grid-item-block {
    max-width: 75%;
}
#grid-item-1 {
    grid-row: 1/3;
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;

    grid-column: 1/4;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
}
#grid-item-2 {
    grid-row: 1/2;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;

    grid-column: 4/9;
    -ms-grid-column: 4;
    -ms-grid-column-span: 5;
}
#grid-item-3 {
    grid-row: 1/2;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;

    grid-column: 9/14;
    -ms-grid-column: 9;
    -ms-grid-column-span: 5;
    z-index: 100;
}
#grid-item-4 {
    grid-row: 2;
    -ms-grid-row: 2/3;
    -ms-grid-row-span: 1;

    grid-column: 4/11;
    -ms-grid-column: 4;
    -ms-grid-column-span: 7;
}
#grid-item-5 {
    grid-row: 2/4;
    -ms-grid-row: 2;
    -ms-grid-row-span: 2;

    grid-column: 11/14;
    -ms-grid-column: 11;
    -ms-grid-column-span: 3;
}
#grid-item-6 {
    grid-row: 3/4;
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;

    grid-column: 1/7;
    -ms-grid-column: 1;
    -ms-grid-column-span: 6;
}
#grid-item-7 {
    grid-row: 3/4;
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;

    grid-column: 7/11;
    -ms-grid-column: 7;
    -ms-grid-column-span: 4;
}
.grid-youtube,
.popup-link {
    position: relative;
    cursor: pointer;
    display: block;
}
.grid-youtube:hover::after,
.popup-link:hover::after {
    background-color: #9f234d;
    color: white;
}
.grid-youtube::after,
.popup-link::after {
    content: "\f04b";
    font-family: "Font Awesome 6 Pro";
    font-size: 21px;
    position: absolute;
    bottom: 15px;
    right: 20px;
    height: 50px;
    width: 47px;
    background-color: white;
    border-radius: 50%;
    transition: 175ms ease-in-out;
    font-weight: 900;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    padding-left: 3px;
    color: #07204d;
}
.popup-link {
    width: 440px;
    height: 230px;
    display: block;
}
.popup-link img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    border-radius: 5px;
}

.griditem1 {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}
.griditem2 {
    background-color: rgb(159, 35, 77);
    position: relative;
    z-index: 100;
}
.griditem2:before {
    content: "";
    display: block;
    height: 30px;
    width: 30px;
    background-color: rgb(159, 35, 77);
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
    z-index: 5;
}
.griditem2:after {
    content: "";
    display: block;
    height: 20px;
    width: 20px;
    position: absolute;
    top: 50%;
    left: 0px;
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
    z-index: -1;
    border-left: 10px solid #fff;
    border-bottom: 10px solid #fff;
    border-right: 10px solid transparent;
    border-top: 10px solid transparent;
    box-sizing: content-box;
}
.griditem3 {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}
.griditem4 {
    background-color: rgb(246, 249, 254);
}
.griditem5 {
    background-color: rgb(7, 32, 77);
    z-index: 100;
    position: relative;
}
.griditem5:before {
    content: "";
    display: block;
    height: 30px;
    width: 30px;
    background-color: rgb(7, 32, 77);
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
}
.griditem5:after {
    content: "";
    display: block;
    height: 20px;
    width: 20px;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
    z-index: -1;
    border-left: 10px solid #fff;
    border-top: 10px solid #fff;
    border-bottom: 10px solid transparent;
    border-right: 10px solid transparent;
    box-sizing: content-box;
}
.griditem6 {
    background-color: rgb(25, 63, 132);
    z-index: 100;
    position: relative;
}
.griditem6:before {
    content: "";
    display: block;
    height: 30px;
    width: 30px;
    background-color: rgb(25, 63, 132);
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translate(50%, -50%) rotate(45deg);
    transform: translate(50%, -50%) rotate(45deg);
}
.griditem6:after {
    content: "";
    display: block;
    height: 20px;
    width: 20px;
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translate(50%, -50%) rotate(45deg);
    transform: translate(50%, -50%) rotate(45deg);
    z-index: -1;
    border-right: 10px solid #fff;
    border-top: 10px solid #fff;
    border-bottom: 10px solid transparent;
    border-left: 10px solid transparent;
    box-sizing: content-box;
}
.griditem7 {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}
.griditem4 h2 {
    color: #082252;
    font-size: 48px;
    margin: 10px 0;
    font-weight: normal;
}
.griditem4 h2 strong {
    font-weight: bold;
    font-family: "Khand", sans-serif;
}
.griditem4 h2 i {
    color: #8fa7cd;
}
.griditem4 p {
    color: #082252;
    line-height: 1.5em;
}
.griditem2 h3,
.griditem5 h3,
.griditem6 h3 {
    font-size: 28px;
    color: #fff;
    margin: 10px 0;
}
.griditem2 p,
.griditem5 p,
.griditem6 p {
    margin: 0;
    color: #fff;
    line-height: 1.5em;
}

/* Homepage News Block */
/* ------------------------------------------------------------ */
#home_news {
    background-color: #07204d;
    padding: 50px 0 80px 0;
    border-radius: 0 0 100px 0;
    color: #fff;
    margin: 0 0 5px 0;
}
#home_news h2 {
    font-size: 48px;
    margin: 0 0 10px 0;
    font-weight: normal;
}
#home_news h2 i {
    color: #8fa7cd;
}
#home_news h2 strong {
    font-weight: bold;
    font-family: "Khand", sans-serif;
}
#news_grid_home {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 35px;
    margin: 50px 0 0 0;
}
.news_item {
    color: white;
}
.news_information h3 {
    font-size: 28px;
    line-height: 1.2;
    margin: 15px 0;
}
.news_item .news_image {
    min-width: 180px;
    min-height: 180px;
    background-size: cover;
    background-repeat: no-repeat;
    border-bottom-right-radius: 30px;
    margin-bottom: 15px;
    box-shadow: -1.9px -0.6px 5.5px 0.5px rgb(0 0 0 / 32%);
}

.news_url {
    font-size: 22px;
    text-decoration: none;
    color: white;
}
.news_url i {
    color: #8fa7cd;
}

/* Homepage Careers Block */
/* ------------------------------------------------------------ */
#homepage_carousel_gallery {
    margin: 0 0 5px 0;
}
#homepage_carousel_gallery .item {
    height: 19vw;
    background-size: cover;
    background-position: center;
    max-height: 280px;
}

/* Homepage Careers Block */
/* ------------------------------------------------------------ */
#home_careers {
    position: relative;
}
.bg-shadow {
    display: none;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.32);
    z-index: 2;
}
.bg-image {
    top: 0;
    left: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    z-index: 1;
}
.home_careers_content {
    position: relative;
    z-index: 3;
    display: flex;
    padding: 100px 0;
}
.home_careers_content_blue {
    background-color: rgba(7, 32, 77, 0.89);
    padding: 40px;
    color: #fff;
    flex: 0 1 50%;
}
.home_careers_content_blue h2 {
    font-size: 48px;
    margin: 0 0 10px 0;
    font-weight: normal;
}
.home_careers_content_blue h2 i {
    color: #8fa7cd;
}
.home_careers_content_blue h2 strong {
    font-weight: bold;
    font-family: "Khand", sans-serif;
}
.home_careers_content_blue p {
    margin: 0 0 20px 0;
    color: #fff;
    line-height: 1.5em;
}

/* Locations Post Type */
/* ------------------------------------------------------------ */
#locations_list {
    background: #ebebeb;
    padding: 60px 0;
}
.staff_list {
    padding: 0 30px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.staff_accordion h2 {
    border-bottom: 1px solid #2b4e8e;
    padding: 5px 0 10px 0;
    cursor: pointer;
    color: #2b4e8e;
    font-size: 1.75rem;
    position: relative;
    font-weight: 400;
}
.staff_accordion h2:after {
    content: "\f107";
    font-family: "Font Awesome 6 Pro";
    font-weight: 900;
    position: absolute;
    top: 50%;
    right: 15px;
    font-size: 24px;
    color: #c5285d;
    -webkit-transform: translate(0, -50%) rotate(0deg);
    transform: translate(0, -50%) rotate(0deg);
    -webkit-transform-origin: center;
    transform-origin: center;
}
.staff_accordion h2.active:after {
    -webkit-transform: translate(0, -50%) rotate(180deg);
    transform: translate(0, -50%) rotate(180deg);
}
.staff_accordion_body {
    display: none;
    padding: 10px 0;
    color: #2b4e8e;
    line-height: 1.5em;
    font-size: 16px;
}
.staff_accordion_body a {
    color: #c5285d;
}
.staff_accordion_body p {
    margin: 10px 0;
}
.staff_accordion_body.active {
    display: block;
}

/* Contact Us Page */
/* ------------------------------------------------------------ */
.locations_grid {
    padding: 20px 0;
    display: grid;
    gap: 25px;
    grid-template-columns: repeat(3, 1fr);
}
.location_grid_item {
    border: 2px solid #9f234d;
    padding: 15px;
    border-radius: 3px;
}
.location_grid_item :last-child {
    margin-bottom: 0 !important;
}
.thepage h3.location_header {
    color: #9f234d;
}

/* News Blog Page (home.php) */
#bloglist {
    padding: 50px 0;
    background-color: #e8e8e8;
}
.news_articles {
}
.news_article {
    margin: 0 0 60px 0;
    padding: 0 0 0 25%;
    position: relative;
    min-height: 250px;
    display: flex;
}
.news_article_text {
    padding: 0 0 0 50px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
}
.news_article_image {
    width: 25%;
    height: 100%;
    max-height: 250px;
    background-color: #ddd;
    border-radius: 0 0 40px 0;
    position: absolute;
    top: 0;
    left: 0;
    background-size: cover;
    background-position: center;
}
.news_article_image.no_image {
    background-color: #fff;
    background-size: contain;
    background-repeat: no-repeat;
}
.news_article_text span {
    color: #354561;
    font-size: 15px;
}
.thepage .news_article_text h2 {
    color: #193f84;
    font-size: 28px;
    margin: 12px 0 14px 0;
    font-weight: 600;
}

/* Footer */
/* ------------------------------------------------------------ */

footer {
    padding: 55px 0;
}
.footer_columns {
    display: grid;
    gap: 50px;
    grid-template-columns: 1fr 1fr;
}
a.footer_logo {
    display: block;
    height: 60px;
    margin: 0 0 40px 0;
    background-repeat: no-repeat;
    background-position: center left;
    background-image: url("img/nonotuck-logo-dark.png");
    background-size: contain;
}
.footer_badges {
    display: flex;
    position: relative;
    left: -23px;
}
.footer_badge {
    height: 140px;
    background-size: contain;
    background-position: center top;
    background-repeat: no-repeat;
    flex: 0 0 120px;
}
.footer_column.navs {
    display: flex;
    justify-content: flex-end;
    gap: 30px;
}
nav.footer_nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px 50px;
    align-self: flex-start;
}
nav.footer_nav a {
    color: #193f84;
    text-decoration: none;
    font-size: 20px;
    transition: 175ms ease-in-out;
}

nav#social {
    display: grid;
    grid-template-columns: 1fr;
    margin: 0 0 0 40px;
    align-self: flex-start;
    position: relative;
    top: -10px;
}
nav#social a {
    color: #193f84;
    font-size: 24px;
    padding: 10px;
    text-align: center;
}

/* Newsletter Signup (prefooter) Section */
/* ------------------------------------------------------------ */

#newsletter_signup {
    background-color: #193f84;
}
.newsletter_inner {
    display: flex;
}
.newsletter_image {
    flex: 0 0 50%;
    background-size: cover;
    background-position: center;
}
.newsletter_form {
    flex: 0 0 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    min-height: 400px;
    padding: 0 40px;
    flex-wrap: wrap;
}
.newsletter_form h2 {
    font-size: 50px;
    font-weight: bold;
    flex: 1 0 100%;
}
.newsletter_form h2 i {
    margin: 0 10px 0 0;
}
.newsletter_wrap {
    flex: 0 0 300px;
}
.newsletter_form form label {
    margin: 20px 0 6px 0;
    display: block;
    font-size: 20px;
    font-weight: bold;
    color: #fff !important;
    position: relative;
}
.newsletter_form form label:before {
    content: "\2217";
    position: absolute;
    top: -4px;
    left: -12px;
    color: #f5463b;
}
.ctct-form-embed.form_0 .ctct-form-defaults {
    background-color: transparent !important;
    padding: 0 !important;
}
div.ctct-form-embed form.ctct-form-custom div.ctct-form-field {
    margin: 0 0 15px 0 !important;
}
.newsletter_form form input {
    width: 100%;
    height: 46px;
    padding: 10px 15px;
    border: 1px solid #b0b6bb;
    background-color: #fff;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
    border-radius: 3px;
    font-size: 14px;
    line-height: 1.5;
    font-family: "Roboto Condensed", sans-serif;
    color: #323232;
    display: inline-block;
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    -o-appearance: none;
    appearance: none;
}
.newsletter_form form [type="submit"] {
    display: block;
    width: 100%;
    margin-bottom: 0;
    text-align: center;
    cursor: pointer;
    font-size: 18px;
    font-weight: bold;
    padding: 16px;
    line-height: 1;
    background-image: none;
    box-shadow: none;
    border-radius: 3px;
    text-transform: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -o-user-select: none;
    user-select: none;
    -webkit-transition: all 0.1s ease-in-out;
    -moz-transition: all 0.1s ease-in-out;
    -ms-transition: all 0.1s ease-in-out;
    -o-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
    background-color: #c5285d;
    border: 1px solid #c5285d;
    color: #ffffff;
}
#gdpr_text {
    display: none;
}

/* Internal */
/* ------------------------------------------------------------ */
#internal_hero {
    border-radius: 0 0 0 80px;
    position: relative;
    height: 50vh;
    max-height: 570px;
    overflow: hidden;
}
#internal_hero h1 {
    font-size: 92px;
    line-height: 70px;
    position: absolute;
    color: #fff;
    bottom: 0;
    right: 15px;
    z-index: 100;
    text-align: right;
    text-shadow: 1px 1px 3px black;
    text-transform: uppercase;
}
.internal_hero_image {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    background-size: cover;
    background-position: center;
    background-image: url("img/interior_header_default.webp");
}

.thepage {
    padding: 50px 30px;
}
.thepage strong {
    font-weight: bold;
}
.thepage hr {
    margin: 40px 0;
    border: none;
    border-bottom: 1px solid #ddd;
}
.thepage :first-child {
    margin-top: 0px !important;
}
.thepage h1,
.thepage h2 {
    color: #9d0d40;
    font-size: calc(1.375rem + 1.5vw);
    margin: 70px 0 15px 0;
    font-weight: 500;
    line-height: 1.2;
}
.thepage h2 a,
.thepage h2 {
    font-family: "Khand", sans-serif;
    text-decoration: none;
    border-bottom: 1px solid #ddd;
    padding: 0 0 5px 0;
    font-size: calc(1.175rem + 1.5vw);
}
.thepage h3 a,
.thepage h3 {
    font-family: "Khand", sans-serif;
    text-decoration: none;
    color: #183e84;
    font-size: calc(1.05rem + 0.9vw);
    margin: 50px 0 10px 0;
    font-weight: 500;
    line-height: 1.2;
}
.thepage h4 a,
.thepage h4 {
    font-family: "Khand", sans-serif;
    text-decoration: none;
    color: #9d0d40;
    font-size: calc(1.4rem + 0.1vw);
    margin: 33px 0 8px 0;
    font-weight: 500;
    line-height: 1.2;
}
.thepage li {
    margin: 0 0 10px 0;
}
.thepage li :last-child {
    margin-bottom: 0;
}
.thepage p a,
.thepage li a {
    /* color: #C5285D; */
    color: #9d0d40;
}
.thepage li,
.thepage p {
    line-height: 1.6;
    font-weight: 400;
    color: #212529;
    margin-bottom: 20px;
    font-size: 1.15em;
}
.thepage ul,
.thepage ol {
    padding-left: 2rem;
}
.wp-block-embed__wrapper {
    margin: 30px 0 50px 0;
}
.thepage iframe {
    max-width: 100%;
}

/* Aside Sidebar */
.flex_sidebar {
    display: flex;
    gap: 40px;
}
.flex_sidebar section {
    flex: 1 1 auto;
}
aside#sidebar {
    flex: 0 0 30%;
    padding: 50px 30px 0 0;
}
aside#sidebar nav {
    border-left: 1px solid #eee;
    padding: 0 0 30px 30px;
}
.nav_header {
    color: #193f84;
    font-size: 30px;
    margin: 0 0 15px 0;
    font-weight: 500;
    line-height: 1.2;
}
aside#sidebar nav a {
    color: #9d0d40;
    transition: 175ms ease-in-out;
    display: block;
    margin: 21px 0;
    font-size: 20px;
    position: relative;
}
aside#sidebar nav a.current_page {
    font-weight: bold;
}
aside#sidebar nav a.current_page:before {
    content: "-";
    position: absolute;
    top: 50%;
    left: -18px;
    color: #9d0e41;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    font-size: 22px;
}
aside#sidebar nav a:hover {
    text-decoration: underline;
}

/* Blog Sidebar Nav */
.postdate_sidebar {
    color: #143269;
    font-size: 14px;
    font-weight: bold;
    margin: 5px 0 0 0;
}
.newpost {
    display: inline-block;
    padding: 2px 5px;
    background: #17336a;
    color: #fff;
    border-radius: 3px;
    font-weight: normal;
    font-size: 13px;
    text-transform: uppercase;
    margin: 0 0 0 3px;
}
.post_date {
    color: #143269;
    font-size: 15px;
    font-weight: bold;
    margin: 0 0 45px 0;
    display: block;
}
.thepage h1.blog_post_title {
    margin-bottom: 0px;
    color: #183e84;
}

/* Staff Directory Page */
/* ------------------------------------------------------------ */
#staff_dir {
    background: #ebebeb;
    padding: 60px 0;
}
.staff_dir_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
.staff_dir_grid_item {
    border: 1px solid #ddd;
    border-radius: 4px;
    display: block;
    padding: 25px;
    transition: ease all 300ms;
    background: #f1f1f1;
}
.staff_dir_grid_item:hover {
    border-color: #193f84;
    background: #fff;
}
.staff_dir_body h3 {
    color: #c5285d;
    font-size: 30px;
    font-weight: bold;
    margin: 0 0 8px 0;
}
.staff_dir_body p {
    color: #000;
    line-height: 1.4em;
    font-size: 15px;
}

/* Jobs Listings */
/* ------------------------------------------------------------ */
.RSS_filter {
    display: flex;
    width: 100%;
    gap: 10px;
}
.RSS_filter select {
    flex: 0 1 100px;
    width: auto;
    max-width: 300px;
    padding: 12px;
    border-radius: 0;
    border: 2px solid #193f84;
    color: #193f84;
    font-size: 18px;
    font-weight: bold;
    line-height: 1em;
}
.RSS_filter select:hover {
    cursor: pointer;
}
.RSS_filter .reset {
    border: 2px solid #eee;
    line-height: 1em;
    color: #646464;
    font-size: 18px;
    padding: 12px;
    font-weight: bold;
    flex: 0 1 auto;
    background: #eee;
    transition: ease all 400ms;
}
.RSS_filter .reset:hover {
    cursor: pointer;
    color: #555;
    border: 2px solid #888;
}
#job_listings {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
#job_listings .job_posting {
    background-color: white;
    border: 2px solid #9f234d;
    padding: 20px;
    transform: translate(0, 0);
    position: relative;
    transition: all 250ms ease-out;
}
#job_listings .job_posting:focus,
#job_listings .job_posting:hover {
    transform: translate(0, -10px);
}
.thepage #job_listings .job_posting h3 {
    color: #9d0d40;
    margin: 0 0 15px 0;
}
.thepage #job_listings .job_posting p {
    margin: 0;
}
.no_jobs_message {
    margin: 30px 0;
    background: #eee;
    padding: 40px;
    text-align: center;
    display: none;
}
.thepage .no_jobs_message h2 {
    color: #555;
    font-size: 24px;
    margin: 0;
}

/* PAGINATION */
#pagination {
    width: 100%;
    margin: 50px 0;
    text-align: center;
    display: flex;
    justify-content: center;
}
.pagi_inner {
    border-radius: 4px;
    display: flex;
    overflow: hidden;
}
#pagination a.prev,
#pagination a.next {
    line-height: 2em;
}
section.centered #pagination a,
section#page #pagination a {
    text-decoration: none;
}
#pagination a,
#pagination span {
    padding: 10px;
    line-height: 2em;
    border: 1px solid transparent;
    font-size: 22px;
    font-weight: 700;
    margin: 0 3px;
    display: block;
    transition: all ease 200ms;
    border-radius: 4px;
}
#pagination a {
    color: #07204d;
}
#pagination a:hover {
    background: rgba(157, 13, 64, 0.09);
}
#pagination span.current {
    border: 1px solid #07204d;
}

/* Media Queries */
/* ------------------------------------------------------------ */
/* ------------------------------------------------------------ */

@media (max-width: 1280px) {
    /* Header Nav */
    header nav {
        gap: 8px;
    }
    header nav .nav_item_holder > a {
        font-size: 16px;
    }
    .sub_nav a {
        font-size: 16px;
    }
}
@media (max-width: 1200px) {
    /* Home Hero */
    #home_hero_slider .item {
        height: 65vw;
        min-height: 350px;
    }
    #home_hero_slider .item h2 {
        top: initial;
        bottom: 8vw;
        left: 50%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
        font-size: 12vw;
    }

    /* Home Description Block */
    #description-column-2 {
        display: none;
    }
    #description {
        top: calc(65vw - 90px);
    }
}
@media (max-width: 1160px) {
    /* Header Nav */
    header nav {
        overflow-y: scroll;
        padding: 0 0 25px 0;
        position: fixed;
        left: 0;
        top: 0;
        bottom: 0;
        background-color: #07204d;
        left: 0;
        -webkit-transform: translate3d(-100%, 0, 0);
        transform: translate3d(-100%, 0, 0);
        -webkit-transition-property: -webkit-transform;
        transition-property: -webkit-transform;
        -o-transition-property: transform;
        transition-property: transform;
        transition-property: transform, -webkit-transform;
        -webkit-transition-duration: 0.3s;
        -o-transition-duration: 0.3s;
        transition-duration: 0.3s;
        -webkit-transition-timing-function: ease;
        -o-transition-timing-function: ease;
        transition-timing-function: ease;
        width: 400px;
        max-width: 80%;
        max-width: calc(100% - 105px);
        gap: 0;
        flex-direction: column;
        justify-content: flex-start;
    }
    header nav.active {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    header nav .nav_item_holder {
        flex-wrap: wrap;
    }
    header nav .nav_item_holder::after {
        display: none;
    }
    .subnav_more {
        display: none;
    }
    header nav .nav_item_holder > a {
        flex: 1 1 auto;
        font-size: 26px;
        background-color: #193f84;
        padding: 10px;
        border-top: 25px solid #07204d;
        border-bottom: 2px solid #07204d;
    }
    .sub_nav a:focus,
    header nav .nav_item_holder > a:focus,
    header nav .nav_item_holder > a:hover {
        color: #9d0d40;
        background: #fff;
        outline: none;
    }
    .sub_nav {
        flex: 1 0 100%;
        display: block;
        position: relative;
        top: initial;
        left: 0;
        width: 100%;
        background-color: #193f84;
        min-width: 0px;
        padding: 0;
        left: 0px;
    }
    .sub_nav a {
        padding: 13px 10px;
    }

    /* Mobile Nav Toggle */
    #mnavbutton {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        color: #fff;
        align-self: center;
        padding: 11px 20px 11px 20px;
        font-size: 24px;
        order: 2;
        transition-duration: 0.5s;
        background: #5270a9;
    }
    .menu {
        background-color: transparent;
        border: none;
        cursor: pointer;
        display: flex;
        padding: 0;
    }
    .line {
        pointer-events: none;
        fill: none;
        stroke: #ffffff;
        stroke-width: 6;
        transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1), stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
    }
    .line1 {
        stroke-dasharray: 60 207;
        stroke-width: 6;
    }
    .line2 {
        stroke-dasharray: 60 60;
        stroke-width: 6;
    }
    .line3 {
        stroke-dasharray: 60 207;
        stroke-width: 6;
    }
    .opened .line1 {
        stroke-dasharray: 90 207;
        stroke-dashoffset: -134;
        stroke-width: 6;
    }
    .opened .line2 {
        stroke-dasharray: 1 60;
        stroke-dashoffset: -30;
        stroke-width: 6;
    }
    .opened .line3 {
        stroke-dasharray: 90 207;
        stroke-dashoffset: -134;
        stroke-width: 6;
    }

    /* Footer */
    .footer_columns {
        display: grid;
        gap: 50px;
        grid-template-columns: 1fr;
    }
    .footer_column.navs {
        flex-direction: column;
        align-content: center;
    }
    nav.footer_nav {
        align-self: center;
    }
    nav#social {
        display: flex;
        margin: 0;
        align-self: center;
        top: 0;
        gap: 10px;
    }
    nav#social a {
        font-size: 26px;
        padding: 15px;
    }
    .footer_badges {
        left: 0;
        justify-content: center;
        gap: 15px;
        flex-wrap: wrap;
    }
    .footer_badge {
        flex: 0 1 100px;
    }
    a.footer_logo {
        background-position: center;
    }

    /* Staff Directory Page */
    .staff_dir_grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Contact Us Page */
    .locations_grid {
        gap: 25px;
        grid-template-columns: repeat(2, 1fr);
    }

    /* Staff Listings Locations Pages */
    .staff_list {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Blog */
    .news_article_image {
        width: 25%;
        height: auto;
        padding: 25% 0 0 0;
    }
}
@media (max-width: 1000px) {
    /* Job Listings Page */
    #job_listings {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Interior Page Templates */
    .page_stacked_bg {
        padding: 30% 0 0 0;
        flex: 0 0 30%;
        align-self: flex-start;
    }
    .flex_sidebar {
        flex-wrap: wrap;
    }
    .flex_sidebar section {
        flex: 1 0 100%;
    }
    .flex_sidebar aside#sidebar {
        flex: 1 0 100%;
        padding: 50px 0 0 0;
        margin: 40px 0 0 0;
        border-top: 1px solid #ddd;
    }
    aside#sidebar nav {
        border: none;
    }
}
@media (max-width: 992px) {
    /* Home Hero */
    #home_hero_slider .item .slide_bg {
        border-radius: 0;
    }

    /* Home Description Block */
    .description_row {
        border-radius: 0;
        box-shadow: none;
    }
    #description {
        position: relative;
        top: 0;
        transform: translateY(0) !important;
        background-color: #07204d;
    }
    #description .wrapper {
        padding: 0;
    }

    /* Home 3-CTA */
    #services {
        padding: 50px 0;
        margin: 0;
    }
    .services_grid {
        margin: 0;
        gap: 7vw;
        grid-template-columns: repeat(1, 1fr);
    }
    .services_grid_item {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .services_grid_item p {
        max-width: 560px;
    }
    .services_grid_item img {
        width: 20vw;
        max-width: 120px;
    }
    .services_grid_item h2 {
        font-size: 26px;
        margin: 0 0 10px 0;
    }

    /* Home News */
    #news_grid_home {
        grid-template-columns: repeat(2, 1fr);
        gap: 40px;
    }
    .news_item .news_image {
        max-height: 260px;
        height: 29vw;
    }

    /* Home Gird */
    #homepage-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, 340px);
        margin: 5px 0;
    }
    #grid-item-4 {
        grid-row-start: 1;
        grid-row-end: 1;
        grid-column-start: 1;
        grid-column-end: 3;
    }
    #grid-item-4 i {
        display: none;
    }
    #grid-item-1 {
        grid-row-start: 2;
        grid-row-end: 2;
        grid-column-start: 1;
        grid-column-end: 2;
    }

    #grid-item-2 {
        grid-row-start: 2;
        grid-row-end: 2;
        grid-column-start: 2;
        grid-column-end: 3;
    }

    #grid-item-5 {
        grid-row-start: 3;
        grid-row-end: 3;
        grid-column-start: 1;
        grid-column-end: 2;
    }
    .griditem5:before {
        top: 50%;
        left: initial;
        right: 0;
        -webkit-transform: translate(50%, -50%) rotate(45deg);
        transform: translate(50%, -50%) rotate(45deg);
    }
    .griditem5:after {
        top: 50%;
        left: initial;
        right: 0;
        -webkit-transform: translate(50%, -50%) rotate(45deg);
        transform: translate(50%, -50%) rotate(45deg);
        border-left: 10px solid transparent;
        border-top: 10px solid #fff;
        border-bottom: 10px solid transparent;
        border-right: 10px solid #fff;
    }

    #grid-item-3 {
        grid-row-start: 3;
        grid-row-end: 3;
        grid-column-start: 2;
        grid-column-end: 3;
    }

    #grid-item-7 {
        grid-row-start: 4;
        grid-row-end: 4;
        grid-column-start: 1;
        grid-column-end: 2;
    }

    #grid-item-6 {
        grid-row-start: 4;
        grid-row-end: 4;
        grid-column-start: 2;
        grid-column-end: 3;
    }
    .griditem6:before {
        top: 50%;
        right: initial;
        left: 0;
        -webkit-transform: translate(-50%, -50%) rotate(45deg);
        transform: translate(-50%, -50%) rotate(45deg);
    }
    .griditem6:after {
        top: 50%;
        right: initial;
        left: 0;
        -webkit-transform: translate(-50%, -50%) rotate(45deg);
        transform: translate(-50%, -50%) rotate(45deg);
        border-right: 10px solid transparent;
        border-top: 10px solid transparent;
        border-bottom: 10px solid #fff;
        border-left: 10px solid #fff;
    }

    /* Interior Page Templates */
    #internal_hero {
        height: 360px;
    }
    #internal_hero h1 {
        font-size: 58px;
    }

    /* Internal Newsletter Signup */
    #newsletter_signup .wrapper {
        padding: 0;
    }
    .newsletter_inner {
        flex-wrap: wrap;
    }
    .newsletter_image {
        flex: 1 0 100%;
        height: 35vw;
        max-height: 320px;
    }
    .newsletter_form {
        flex: 1 0 100%;
        min-height: 0;
        padding: 50px 25px;
    }
    .newsletter_form h2 {
        font-size: 38px;
    }
}
@media (max-width: 900px) {
    /* Homepage Careers Block */
    .home_careers_content_blue {
        flex: 0 1 70%;
    }

    /* Staff Directory Page */
    .staff_dir_grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Interior Page Templates */
    .page_list_holder.blocks {
        grid-template-columns: repeat(1, 1fr);
        gap: 15px;
    }
    .page_block {
        padding: 46vw 0 0 0;
        min-height: 250px;
    }
}
@media (max-width: 800px) {
    /* Home Grid */
    .griditem2 p.mobile-hide,
    .griditem5 p.mobile-hide,
    .griditem6 p.mobile-hide {
        display: none;
    }
    .griditem2 h3,
    .griditem5 h3,
    .griditem6 h3 {
        font-size: 25px;
        margin: 3px 0;
    }

    /* Home News */
    #news_grid_home {
        gap: 60px 40px;
    }
    .news_information h3 {
        font-size: 24px;
    }

    /* Home Carousel Images */
    #homepage_carousel_gallery .item {
        height: 23vw;
    }

    /* Contact Us Page */
    .locations_grid {
        padding: 0px 0;
        display: grid;
        gap: 15px;
        grid-template-columns: repeat(1, 1fr);
    }

    /* Staff Listings Locations Pages */
    .staff_list {
        grid-template-columns: repeat(1, 1fr);
        gap: 15px;
    }

    /* Job Postings List */
    .thepage #job_listings .job_posting h3 {
        font-size: 24px;
    }
    #job_listings {
        grid-template-columns: repeat(1, 1fr);
        gap: 20px;
    }
    .RSS_filter {
        flex-wrap: wrap;
        justify-content: flex-end;
    }
    .RSS_filter select {
        flex: 1 0 100%;
        max-width: 100%;
    }

    /* Blog */
    .news_article_image {
        width: 25%;
        height: auto;
        padding: 25% 0 0 0;
        position: relative;
    }
    .news_article {
        flex-wrap: wrap;
        padding: 0;
    }
    .news_article_text {
        padding: 20px 0 0 0;
        flex: 1 0 100%;
    }
}
@media (max-width: 700px) {
    /* Homepage Description */
    #description p {
        font-size: 19px;
        line-height: 1.6em;
        text-align: center;
    }
    #description-column-1 {
        padding: 2rem;
    }

    /* Homepage Grid */
    .griditem4 h2 {
        font-size: 38px;
    }
    .grid-item-block {
        max-width: 100%;
    }

    /* Homepage News */
    #home_news h2 {
        font-size: 38px;
    }

    /* Homepage Careers Block */
    .home_careers_content_blue h2 {
        font-size: 38px;
    }
    #home_careers .wrapper {
        padding: 0;
    }
    .home_careers_content_blue {
        flex: 0 1 100%;
        padding: 25px;
    }
    .home_careers_content {
        padding: 200px 0 0 0;
    }

    /* Interior Page Templates */
    #internal_hero {
        border-radius: 0;
    }
    #internal_hero {
        height: 360px;
    }
    #internal_hero h1 {
        font-size: 40px;
        line-height: 1.1em;
    }
    .no_hero .thepage {
        padding: 20px;
    }
    .thepage {
        padding: 40px 20px;
    }
    .page_stacked {
        flex-wrap: wrap;
    }
    .thepage .page_stacked_content {
        padding: 20px 0 40px 0;
    }
    .thepage .page_stacked_content h2 {
        font-size: 30px;
    }
    .page_stacked_bg {
        padding: 40% 0 0 0;
        flex: 0 0 40%;
        min-height: 50vw;
        min-width: 50vw;
    }

    /* Staff Listings Locations Pages */
    .staff_list {
        padding: 0 20px;
    }
}
@media (max-width: 600px) {
    /* Globals */
    .wrapper {
        padding: 0 15px;
    }
    #homepage-grid {
        grid-template-rows: repeat(4, 200px);
    }
    .grid-item-text-container {
        padding: 1.5rem;
    }
    .griditem2 h3,
    .griditem5 h3,
    .griditem6 h3 {
        font-size: 24px;
        margin: 3px 0;
    }
    .griditem2 p,
    .griditem5 p,
    .griditem6 p {
        line-height: 1.2em;
        font-size: 14px;
    }

    /* Home Carousel Images */
    #homepage_carousel_gallery .item {
        height: 45vw;
    }

    /* Homepage News */
    #news_grid_home {
        grid-template-columns: repeat(1, 1fr);
    }
    #home_news {
        border-radius: 0 0 30px 0;
    }

    /* Staff Directory Page */
    .staff_dir_grid {
        grid-template-columns: repeat(1, 1fr);
        gap: 15px;
    }
    #staff_dir {
        padding: 30px 0;
    }

    /* Staff Listings Locations Pages */
    #locations_list {
        padding: 30px 0;
    }

    /* Blog */
    #bloglist {
        padding: 30px 0;
    }
    .news_article_image {
        min-width: 50%;
        padding: 50% 0 0 0;
    }
}
@media (max-width: 500px) {
    /* Interior Page Templates */
    #internal_hero {
        height: 270px;
    }
    .thepage li,
    .thepage p {
        font-size: 17px;
        line-height: 1.8;
    }
}
