/*! normalize.css v3.0.2 | MIT License | git.io/normalize */

/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */

html {
    font-family: sans-serif; /* 1 */
    -ms-text-size-adjust: 100%; /* 2 */
    -webkit-text-size-adjust: 100%; /* 2 */
}

/**
 * Remove default margin.
 */

body {
    margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */

/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
summary {
    display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */

audio,
canvas,
progress,
video {
    display: inline-block; /* 1 */
    vertical-align: baseline; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */

audio:not([controls]) {
    display: none;
    height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */

[hidden],
template {
    display: none;
}

/* Links
   ========================================================================== */

/**
 * Remove the gray background color from active links in IE 10.
 */

a {
    background-color: transparent;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */

a:active,
a:hover {
    outline: 0;
}

/* Text-level semantics
   ========================================================================== */

/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */

abbr[title] {
    border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */

b,
strong {
    font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */

dfn {
    font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */

h1 {
    font-size: 4.8rem;
    margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */

mark {
    background: #ff0;
    color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */

small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sup {
    top: -0.5em;
}

sub {
    bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove border when inside `a` element in IE 8/9/10.
 */

img {
    border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */

svg:not(:root) {
    overflow: hidden;
}

/* Grouping content
   ========================================================================== */

/**
 * Address margin not present in IE 8/9 and Safari.
 */

figure {
    margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */

hr {
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
}

/**
 * Contain overflow in all browsers.
 */

pre {
    overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */

code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

/* Forms
   ========================================================================== */

/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */

/**
 * 1. Correct color not being inherited.
 *        Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */

button,
input,
optgroup,
select,
textarea {
    color: inherit; /* 1 */
    font: inherit; /* 2 */
    margin: 0; /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */

button {
    border: 0;
    overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */

button,
select {
    text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *        and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *        `input` and others.
 */

button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button; /* 2 */
    cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */

button[disabled],
html input[disabled] {
    cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */

input {
    line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */

input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *        (include `-moz` to future-proof).
 */

input[type="search"] {
    -webkit-appearance: textfield; /* 1 */
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box; /* 2 */
    box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */

fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */

legend {
    border: 0; /* 1 */
    padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */

textarea {
    overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */

optgroup {
    font-weight: bold;
}

/* Tables
   ========================================================================== */

/**
 * Remove most spacing between table cells.
 */

table {
    border-collapse: collapse;
    border-spacing: 0;
}

td,
th {
    padding: 0;
}@font-face {
  font-family: 'willow-tree';
  src:
    url('../fonts/willow-tree.ttf?rcfslc') format('truetype'),
    url('../fonts/willow-tree.woff?rcfslc') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

.icon {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'willow-tree' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-person:before {
  content: "\e918";
}
.icon-menu:before {
  content: "\e917";
}
.icon-arrow_right:before {
  content: "\e908";
}
.icon-arrow_left:before {
  content: "\e909";
}
.icon-arrow_up:before {
  content: "\e910";
}
.icon-arrow_down:before {
  content: "\e911";
}
.icon-minus:before {
  content: "\e906";
}
.icon-plus:before {
  content: "\e907";
}
.icon-arrow-drop-down:before {
  content: "\e901";
}
.icon-file-pdf:before {
  content: "\e900";
}
.icon-circle:before {
  content: "\f111";
}
.icon-logo-img .path1:before {
  content: "\e800";
  color: rgb(207, 227, 226);
}
.icon-logo-img .path2:before {
  content: "\e801";
  margin-left: -1em;
  color: rgb(1, 57, 65);
}
.icon-logo-tag .path1:before {
  content: "\e912";
  color: rgb(94, 137, 135);
}
.icon-logo-tag .path2:before {
  content: "\e913";
  margin-left: -7.853515625em;
  color: rgb(1, 58, 67);
}
.icon-logo-tag .path3:before {
  content: "\e914";
  margin-left: -7.853515625em;
  color: rgb(218, 177, 112);
}
.icon-logo-tag .path4:before {
  content: "\e915";
  margin-left: -7.853515625em;
  color: rgb(86, 69, 69);
}
.icon-logo-leaves:before {
  content: "\e916";
}
.icon-audio:before {
  content: "\e90f";
}
.icon-times:before {
  content: "\e90e";
}
.icon-previous:before {
  content: "\e902";
}
.icon-next:before {
  content: "\e903";
}
.icon-down:before {
  content: "\e904";
}
.icon-up:before {
  content: "\e905";
}
.icon-mail:before {
  content: "\e90a";
}
.icon-instagram:before {
  content: "\e90b";
}
.icon-twitter:before {
  content: "\e90c";
}
.icon-facebook:before {
  content: "\e90d";
}
/* define page element custom scrollbar style */
::-webkit-scrollbar { /* the entire scrollbar */
    width: 1.2rem;
    height: 1.12rem;
}

::-webkit-scrollbar-thumb { /* the draggable scroll handle */
    border-radius: 1.2rem;
    background-clip: padding-box;
    background-color: hsla(222, 4%, 56%, 1);
    border: 0.2rem solid transparent;
    /* border-radius = ::-webkit-scrollbar width */
    min-height: 4rem;
}

::-webkit-scrollbar-track { /* the track of the scrollbar */
    background-color: transparent;
}

body {
    scrollbar-width: thin;
    /* tells the user agent to use thinner scrollbars, when applicable */
    scrollbar-color: hsla(222, 4%, 56%, 1) transparent;
    scrollbar-face-color: hsla(222, 4%, 56%, 1);
    scrollbar-track-color: transparent;
}

html,
body {
    background-color: hsla(0, 0%, 100%, 1);
	font-family: 'Montserrat', Helvetica, Arial, Lucida, sans-serif;
	height: 100%;
	line-height: 3rem;
}

html {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-size: 62.5%;
}

*,
::before,
::after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
}

body {
	color: hsla(188, 97%, 13%, 1);
	font-size: 2rem;
	-webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.hidden {
	display: none !important;
	height: 0;
	width: 0;
}

.selectable {
	-webkit-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
    user-select: text;
}

a {
	text-decoration: none;
}

p {
	margin-top: 0;
}

h1,
h2,
h3,
h4,
button.info {
    font-family: 'Lora', Georgia, 'Times New Roman', serif;
}

h1 {
    line-height: 1.2em;
    margin-top: 0;
}

h2 {
    font-size: 4.2rem;
    line-height: 4.7rem;
}

h3 {
    font-size: 2rem;
    line-height: 2.5rem;
    margin-top: 0;
}

.flex-align-items-center > h3 {
    text-align: center;
}

li:not(.nav-item) {
	margin-bottom: 1rem;
}

pre,
blockquote,
figure,
table,
p,
ul,
ol {
	margin-bottom: 3rem;
}

pre:last-child,
blockquote:last-child,
figure:last-child,
table:last-child,
p:last-child,
ul:last-child,
ol:last-child {
	margin-bottom: 0;
}

ul {
    margin-top: 0;
}

hr {
	border-width: 0;
	border-top: 0.1rem solid hsla(120, 2%, 10%, 1);
	height: 0;
    margin-top: 0;
	width: 100%;
}

form.column .input-label {
    margin-bottom: 0.125rem !important;
}

form label.error {
    color: 	hsla(0, 100%, 50%, 1);
    font-size: 1.5rem;
    margin-top: -3rem;
}

#map {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

#map iframe {
    border: 1px solid;
    height: 100%;
    width: 100%;
}

img {
    border-radius: 1rem;
    max-width: 100%;
	/* -webkit-touch-callout: inherit; */
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-o-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.img-wrapper {
    overflow: hidden;
    width: 25rem;
    height: 25rem;
}

    .img-wrapper > img {
        transition: transform .3s;
        max-width: none;
    }

        .img-wrapper > img:hover {
            transform: scale(1.1);
        }

.round {
    border-radius: 50%;
}

.relative {
    position: relative;
}

.absolute {
    position: absolute;
}

.avoid-clicks {
	pointer-events: none;
}

.bold {
	font-weight: bold;
}

.italic {
	font-style: italic;
}

.normal {
	font-style: normal;
	font-weight: normal;
}

.center {
	text-align: center;
}

.uppercase {
	text-transform: uppercase !important;
}

.sup {
	font-size: .75rem;
	vertical-align: 24%;
}

.no-margin {
    margin: 0 !important;
}

.no-pad {
    padding: 0 !important;
}

.no-pad-top {
    padding-top: 0 !important;
}

.no-pad-right {
    padding-right: 0 !important;
}

.no-pad-bottom {
    padding-top: 0 !important;
}

.no-pad-left {
    padding-left: 0 !important;
}

.overflow-hidden {
    overflow: hidden;
}

.full-height {
    height: 100%;
}

.full-width {
    width: 100%;
}

.vp-width {
    width: calc(100vw - 1.2rem);
}

input,
select,
textarea,
button {
	font-family: 'Montserrat', Helvetica, Arial, Lucida, sans-serif;
	font-size: 1.65rem;
}

input,
select,
textarea {
    border: 1px solid;
	border-radius: 0.6rem;
	color: hsla(188, 97%, 13%, 1);
    padding: 0.5rem 1rem;
}

textarea {
    line-height: 1.5em;
    max-width: 100%;
    min-height: 20rem;
    min-width: 100%;
}

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: hsla(0, 0%, 80%, 1);
  opacity: 1; /* Firefox */
}

::-ms-input-placeholder { /* Microsoft Edge */
  color: hsla(0, 0%, 80%, 1);
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
  color: hsla(0, 0%, 80%, 1);
}

.select-wrapper {
    /* background-color: #FFF; */
    display: inline-block;
    position: relative;
}

    .select-wrapper::before {
        pointer-events: none;
        position: absolute;
        right: 1rem;
        top: 50%;
        transform: translateY(-50%);
    }

select {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background-color: transparent;
    cursor: pointer;
    line-height: normal;
    position: relative;
    width: 100%;
}

input[type=checkbox] {
    transform: scale(1.5);
}

button {
    border-radius: 0.6rem;
	padding: 0.75rem 2rem;
	-webkit-transition: all .2s ease-in-out;
	transition: all .2s ease-in-out;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
}

button.info {
    align-items: center;
    background: none;
    display: flex;
    font-size: 2rem;
    font-weight: 700;
    padding: 0;
}

button.info > .icon {
    margin-right: 1rem;
}

button.info > :not(.icon) {
    text-align: left;
}

button.submit {
    background-color: hsla(188, 97%, 13%, 1);
    color: hsla(0, 0%, 100%, 1);
}

button.submit:hover {
    background-color: hsla(188, 45%, 13%, 1);
}

button.info-slide {
    background-color: hsla(0, 0%, 100%, 1);
    color: hsla(188, 97%, 13%, 1);
    font-size: 2.4rem;
    font-weight: 600;
}

button.info-slide:hover {
    background-color: hsla(188, 97%, 13%, 1);
    color: hsla(0, 0%, 100%, 1);
}

button.submit:disabled {
    background-color: hsla(14, 3%, 76%, 1);
    cursor: not-allowed;
}

.flex-container-wrapper {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    overflow: hidden;
    width: 100%;
}

.flex-container-wrapper:not(:last-child) {
    margin-bottom: 1rem;
}

.flex-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
}

.flex-container.row {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
}

.flex-container.row-reverse {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.row.spacing-small > :not(:last-child) {
    margin-right: 1rem !important;
}

.row-reverse.spacing-small > :not(:last-child) {
    margin-left: 1rem !important;
}

.flex-container.two-col-max > :not(.flex-basis-auto) {
    -ms-flex-preferred-size: 34%;
    flex-basis: 34%;
}

.flex-container.three-col-max > :not(.flex-basis-auto) {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
}

.flex-container.four-col-max > :not(.flex-basis-auto) {
    -ms-flex-preferred-size: 20%;
        flex-basis: 20%;
}

.flex-container.five-col-max > :not(.flex-basis-auto) {
    -ms-flex-preferred-size: 16.7%;
    flex-basis: 16.7%;
}

.flex-container.ratio-one-to {
    flex-wrap: wrap;
}

.flex-container.ratio-one-to > :not(:last-child) {
    margin-bottom: 3rem;
}

.flex-container.ratio-one-to > :not(.bg) {
    min-width: 100%;
}

.flex-container.ratio-one-to > :first-child {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 0px;
    flex: 1 1 0;
}

.flex-container.ratio-one-to.one > :last-child {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 0px;
    flex: 1 1 0;
}

.flex-container.column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.flex-container.column-reverse {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
}

.flex-container.column.no-child-margins > * {
    margin-bottom: 0 !important;
}

.flex-container.column:not(#page-sections) > :not(h1):not(h2):not(.bg):not(.expando-heading):not(:last-child) {
    margin-bottom: 3rem;
}

.flex-container-wrapper > .flex-container:not(.flex-no-wrap) {
    margin: -0.625rem -0.3125rem;
    padding: 0;
}

.flex-container-wrapper > .flex-container:not(.flex-no-wrap).pad {
    /* padding = half the margin-bottom of '.flex-container:not(.page-container).column > ...:not(:last-child)' */
    padding: 0.625rem;
}

.flex-container-wrapper > .flex-container:not(.flex-no-wrap) > * {
    /* margin = same as container's margin (positive) */
    margin: 0.625rem 0.3125rem;
}

.flex-container-wrapper > .flex-container.contact-card-container {
    margin: -1.5rem -0.3125rem;
}

.flex-container-wrapper > .flex-container.contact-card-container:not(.flex-no-wrap) > * {
    /* margin = same as container's margin (positive) */
    margin: 1.5rem 0.3125rem;
}

:not(.flex-container-wrapper) > .flex-container.row.no-child-margins > * {
    margin-right: 0 !important;
}

:not(.flex-container-wrapper) > .flex-container.row-reverse.no-child-margins > * {
    margin-left: 0 !important;
}

:not(.flex-container-wrapper) > .flex-container.row.child-margins-quarter > :not(:last-child) {
    margin-right: 0.25rem !important;
}

:not(.flex-container-wrapper) > .flex-container.row-reverse.child-margins-quarter > :not(:last-child) {
    margin-left: 0.25rem !important;
}

:not(.flex-container-wrapper) > .flex-container.row.child-margins-half > :not(:last-child) {
    margin-right: 0.5rem !important;
}

:not(.flex-container-wrapper) > .flex-container.row-reverse.child-margins-half > :not(:last-child) {
    margin-left: 0.5rem !important;
}

:not(.flex-container-wrapper) > .flex-container.row.child-margins-full > :not(:last-child) {
    margin-right: 1rem !important;
}

:not(.flex-container-wrapper) > .flex-container.row-reverse.child-margins-full > :not(:last-child) {
    margin-left: 1rem !important;
}

.flex-wrap {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.flex-no-wrap {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.flex-no-grow,
.flex-no-grow-children > * {
    flex-grow: 0 !important;
}

.flex-no-shrink,
.flex-no-shrink-children > * {
    flex-shrink: 0 !important;
}

.flex-grow,
.flex-grow-children > * {
    flex-grow: 1 !important;
}

.flex-grow-double {
    flex-grow: 2 !important;
}

.flex-shrink,
.flex-shrink-children > * {
    flex-shrink: 1 !important;
}

.flex-align-items-start {
    align-items: flex-start !important;
}

.flex-align-items-end {
    align-items: flex-end !important;
}

.flex-align-items-center {
    align-items: center !important;
}

.flex-align-items-stretch {
    align-items: stretch !important;
}

.flex-align-items-baseline {
    align-items: baseline !important;
}

.flex-align-self-start {
    align-self: flex-start !important;
}

.flex-align-self-end {
    align-self: flex-end !important;
}

.flex-align-self-center {
    align-self: center !important;
}

.flex-align-self-stretch {
    align-self: stretch !important;
}

.flex-align-self-baseline {
    align-self: baseline !important;
}

.flex-justify-start {
    justify-content: flex-start;
}

.flex-justify-end {
    justify-content: flex-end;
}

.flex-justify-center {
    justify-content: center;
}

.flex-justify-between {
    justify-content: space-between;
}

.flex-justify-around {
    justify-content: space-around;
}

.flex-basis-auto {
    flex-basis: auto !important;
}

.section {
	height: auto;
    min-height: calc(100vh - 7rem + 1px); /* viewport height - nav container height */
	min-width: 32.0rem;
    overflow: hidden;
	padding: 3rem;
    position: relative;
}

    .section:first-child {
        margin-top: 7rem; /* nav container height */
    }

.section-content:not(#home-content) {
    min-height: 60rem;
}

    .section-content > :first-child.right ~ :last-child {
        padding-right: 5%;
    }

    .section-content > :first-child.left ~ :nth-child(2) {
        padding-left: 5%;
    }

    .section-content > .body > button {
        align-self: flex-start; /* to prevent full-width button in IE */
    }

    .section-content > .body.flex-align-items-center > button {
        align-self: center; /* to prevent full-width button in IE */
    }

.bg {
	position: absolute;
}

    .bg.circle {
        border-radius: 50%;
        height: calc((200vh - 7rem) * 0.7); /* default size */
        width: calc((200vh - 7rem) * 0.7); /* default size */
    }

        .bg.circle.small {
            height: calc((200vh - 7rem) * 0.25);
            width: calc((200vh - 7rem) * 0.25);
        }

        .bg.circle.medium {
            height: calc((200vh - 7rem) * 0.5);
            width: calc((200vh - 7rem) * 0.5);
        }

        .bg.circle.large {
            height: calc((200vh - 7rem) * 0.7);
            width: calc((200vh - 7rem) * 0.7);
        }

        .bg.circle.green {
            background-color: hsla(189, 30%, 73%, 1);
        }

        .bg.circle.light-green {
            background-color: hsla(177, 26%, 85%, 1);
        }

        .bg.circle.orange {
            background-color: hsla(37, 61%, 80%, 1);
        }

        .bg.circle.blue {
            background-color: hsla(206, 30%, 79%, 0.6);
        }

        .bg.circle.top.small {
            top: calc((((200vh - 7rem) * 0.25) / 2) * -1);
        }

        .bg.circle.top.medium {
            top: calc((((200vh - 7rem) * 0.5) / 2) * -1);
        }

        .bg.circle.top.large {
            top: calc((((200vh - 7rem) * 0.7) / 2) * -1);
        }

        .bg.circle.bottom.small {
            bottom: calc((((100vh - 7rem) * 0.25) / 2) * -1);
        }

        .bg.circle.bottom.medium {
            bottom: calc((((100vh - 7rem) * 0.5) / 2) * -1);
        }

        .bg.circle.bottom.large {
            bottom: calc((((100vh - 7rem) * 0.7) / 2) * -1);
        }

        .bg.circle.left {
            left: 0;
        }

        .bg.circle.right {
            right: 0;
        }

    .bg.icon-logo-leaves {
        font-size: 20vh; /* default size */
    }

        .bg.icon-logo-leaves.small {
            font-size: 20vh;
        }

        .bg.icon-logo-leaves.medium {
            font-size: 40vh;
        }

        .bg.icon-logo-leaves.large {
            font-size: 60vh;
        }

        .bg.icon-logo-leaves.green {
            color: hsla(189, 30%, 73%, 1);
        }

        .bg.icon-logo-leaves.light-green {
            color: hsla(177, 26%, 85%, 1);
        }

        .bg.icon-logo-leaves.orange {
            color: hsla(37, 61%, 80%, 1);
        }

        .bg.icon-logo-leaves.blue {
            color: hsla(206, 30%, 79%, 0.6);
        }

        .bg.icon-logo-leaves.top {
            top: 1rem;
        }

        .bg.icon-logo-leaves.bottom {
            bottom: 1rem;
        }

        .bg.icon-logo-leaves.left {
            left: 1rem;
        }

        .bg.icon-logo-leaves.right {
            right: 1rem;
        }

    .bg.box {
        border-radius: 1rem;
        height: calc(100vh - 40%);
        left: 0;
        max-height: 55rem;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
    }

        .bg.box.blue {
            background-color: hsla(206, 30%, 79%, 0.6);
        }

        .bg.box.green {
            background-color: hsla(174, 48%, 60%, 0.4);
        }

        .bg.box.orange {
            background-color: hsla(14, 77%, 75%, 0.4);
        }

        .bg.box.left {
            left: 5rem;
            right: 20%;
        }

        .bg.box.right {
            left: 20%;
            right: 5rem;
        }

li > .icon :not(span[class^='path']) {
	font-family: 'Montserrat', Helvetica, Arial, Lucida, sans-serif;
}

li > .icon {
    display: flex;
}

    li > .icon::before {
        margin-right: 0.75rem;
    }

    li > .icon::before,
    li > .icon > * {
        line-height: 1.8em;
    }

.body,
.feature {
    z-index: 1;
}

.feature {
    display: none;
}

#home,
#welcome,
#faq {
    background-color: hsla(37, 16%, 90%, 1);
}

#resources {
    background-color: hsla(174, 48%, 60%, 1);
}

#services,
#contact {
	background-color: hsla(201, 37%, 97%, 1);
;
}

#staff,
#forms {
    background-color: hsla(177, 26%, 85%, 1);
}

#page-sections > :last-child {
	min-height: calc(100vh - 13rem); /* viewport height, minus nav container and footer heights */
}

.staff-card {
    max-width: calc(25rem + 6rem);
    padding: 3rem;
}

#nav-container {
	background-color:  hsla(0, 0%, 100%, 1);
    padding: 0 2rem;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 2;
    height: 7rem;
}

#nav-bar {
    position: relative;
}

#site-logo {
    font-size: 4rem;
    margin-right: 0.5rem;
}

#site-name {
    font-size: 2.5rem;
}

#footer {
	background-color: hsla(188, 97%, 13%, 1);
	color: hsla(0, 0%, 100%, 1);
    font-size: 1.8rem;
	height: 6rem;
    padding: 0 3rem;
	width: 100%;
}

    #footer > p {
        text-align: center;
    }

.slideshow {
    height: 50%;
    position: relative;
    width: calc(100vw - 1.2rem);
}

.holder {
    height: 100%;
    position: relative;
    width: calc(100vw - 1.2rem);
}

.slide {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    color: hsla(0, 0%, 100%, 1);
    height: 100%;
    opacity: 0;
    overflow: hidden;
    padding: 0 3.5rem;
    pointer-events: none;
    position: absolute;
    transition: opacity 1s;
    width: calc(100vw - 1.2rem);
    z-index: 1;
}

.slide-content {
    flex-grow: 0;
    margin-top: 100%;
    opacity: 0;
    padding: 2rem;
}

.slide-content > * {
    text-align: center;
}

.slide-content > h3 {
    font-size: 1.5rem;
    line-height: 1.75rem;
    margin-bottom: 1rem !important;
}

.slide-content > p {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.75rem;
}

    .slide-content > p > .link {
        font-weight: 600;
    }

.slide.active {
    opacity: 1;
    pointer-events: auto;
}

.slide-gradient,
.slide-bg-image {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transition: all 1s;
}

.slide-bg-image {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.slide.active ~ .slide-bg-image { /* default background image for newly-added slides */
    background-image: url(../media/slide-02.jpg);
}

.slide.active ~ .slide-gradient { /* default background image gradient for newly-added slides */
    background: -moz-linear-gradient(top,  hsla(267,12%,40%,1) 0%, hsla(348,62%,45%,0) 100%);
    background: -webkit-linear-gradient(top,  hsla(267,12%,40%,1) 0%,hsla(348,62%,45%,0) 100%);
    background: linear-gradient(to bottom,  hsla(267,12%,40%,1) 0%,hsla(348,62%,45%,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#655a72', endColorstr='#00ba2c48',GradientType=0 );

}

[data-slide='1'].active ~ .slide-bg-image {
    background-image: url(../media/slide-04.jpg);
}

[data-slide='1'].active ~ .slide-gradient {
    background: -moz-linear-gradient(top,  hsla(199,67%,12%,1) 0%, hsla(0,0%,84%,0) 100%);
    background: -webkit-linear-gradient(top,  hsla(199,67%,12%,1) 0%,hsla(0,0%,84%,0) 100%);
    background: linear-gradient(to bottom,  hsla(199,67%,12%,1) 0%,hsla(0,0%,84%,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0a2633', endColorstr='#00d6d6d6',GradientType=0 );

}

[data-slide='2'].active ~ .slide-bg-image {
    background-image: url(../media/slide-06.jpg);
}

[data-slide='2'].active ~ .slide-gradient {
    background: -moz-linear-gradient(top,  hsla(120,23%,11%,1) 0%, hsla(45,56%,49%,0) 100%);
    background: -webkit-linear-gradient(top,  hsla(120,23%,11%,1) 0%,hsla(45,56%,49%,0) 100%);
    background: linear-gradient(to bottom,  hsla(120,23%,11%,1) 0%,hsla(45,56%,49%,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#162316', endColorstr='#00c19e36',GradientType=0 );

}

[data-slide='3'].active ~ .slide-bg-image {
    background-image: url(../media/slide-09.jpg);
}

[data-slide='3'].active ~ .slide-gradient {
    background: -moz-linear-gradient(top,  hsla(28,23%,24%,1) 0%, hsla(39,45%,56%,0) 100%);
    background: -webkit-linear-gradient(top,  hsla(28,23%,24%,1) 0%,hsla(39,45%,56%,0) 100%);
    background: linear-gradient(to bottom,  hsla(28,23%,24%,1) 0%,hsla(39,45%,56%,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4c3d30', endColorstr='#00c19e5d',GradientType=0 );

}

[data-slide='4'].active ~ .slide-bg-image {
    background-image: url(../media/slide-07.jpg);
}

[data-slide='4'].active ~ .slide-gradient {
    background: -moz-linear-gradient(top,  hsla(101,43%,16%,1) 0%, hsla(71,18%,36%,0) 100%);
    background: -webkit-linear-gradient(top,  hsla(101,43%,16%,1) 0%,hsla(71,18%,36%,0) 100%);
    background: linear-gradient(to bottom,  hsla(101,43%,16%,1) 0%,hsla(71,18%,36%,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#223a17', endColorstr='#00676d4b',GradientType=0 );

}

.steps {
    bottom: 1rem;
    left: 50%;
    overflow: hidden;
    position: absolute;
    transform: translateX(-50%);
    z-index: 1;
}

.step {
    color: hsla(0, 0%, 87%, 0.4);
    cursor: pointer;
    font-size: 0.75rem;
}

.step:not(:last-child) {
    margin-right: 2rem;
}

.step.active {
    color: hsla(0, 0%, 100%, 1);
    cursor: default;
}

a.carousel-nav {
    font-size: 2.5rem;
    font-weight: 700;
    position: absolute;
    text-decoration: none;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1;
}

a.page-nav {
    font-size: 5rem;
    font-weight: 700;
}

#home-content > .column > :not(:last-child) {
    margin-bottom: 1.5rem !important;
}

.prev {
    left: 2rem;
}

.next {
    right: 2rem;
}

.up {
    top: 2rem;
}

.down {
    bottom: 2rem;
}

.contact-card > p {
    line-height: 2.4rem;
    margin-bottom: 1rem;
}

.expando-item {
    border-bottom: 1px solid hsla(188, 97%, 13%, 0.3);
    padding-bottom: 1.5rem;
}

.expando-item > :not(:last-child) {
    margin-bottom: 1rem;
}

.expando-heading {
    cursor: pointer;
}

.expando-heading > * {
    line-height: 1.8em;
}

.expando-heading:not(.column) > :not(:last-child) {
    margin-right: 2rem;
}

.expando-heading-text,
.expando-heading-icon {
    font-weight: 600;
}

@-webkit-keyframes clockwise-ninety {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
    }
}

@keyframes clockwise-ninety {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
    }
}

@-webkit-keyframes counter-clockwise-ninety {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
    }
}

@keyframes counter-clockwise-ninety {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
    }
}

.expando-heading-icon.rotate-cw {
    -webkit-animation: clockwise-ninety 0.5s;
    animation: clockwise-ninety 0.5s;
}

.expando-heading-icon.rotate-ccw {
    -webkit-animation: counter-clockwise-ninety 0.5s;
    animation: counter-clockwise-ninety 0.5s;
}

.expando-content {
    display: none;
    font-size: 2rem;
}

.rotating-service {
    background-color: hsla(206, 30%, 79%, 0.6);
    padding: 2rem;
    border-radius: 1rem;
}

#navigation li > span,
.nav-item-menu > div,
.info,
#return,
a {
	color: hsla(188, 97%, 13%, 0.74);
	cursor: pointer;
	-webkit-transition: all .2s ease-in-out;
	transition: all .2s ease-in-out;
}

#navigation li > span:hover,
.nav-item-menu > div:hover,
.info:hover,
#return:hover,
a:hover {
	color: hsla(188, 45%, 13%, 1);
}

.link {
    text-decoration: underline;
}

.email {
    word-break: break-word;
}

.inverse {
	color: hsla(0, 0%, 100%, 1);
}

.inverse:hover {
	color: hsla(37, 61%, 80%, 1);
}

#error-page {
	height: 100%;
}

#error-message-container {
	height: 100%;
	text-transform: uppercase;
	width: 100%;
}

#error-message-text-wrapper {
    margin-bottom: 3.5vw !important;
}

#error-message-text {
	font-size: 3.5vw;
    font-weight: 100;
	letter-spacing: -0.075rem;
	line-height: 3.5vw;
    text-align: center;
}

#error-message-link-wrapper {
    text-align: center;
}

#return {
	font-size: 2rem;
    font-weight: 500;
	letter-spacing: 0.6em;
}

#navigation {
    background-color: hsla(0, 0%, 100%, 1);
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
    display: none;
	list-style-type: none;
	margin: 0;
	padding: 0 1rem;
    position: absolute;
    right: -1.5rem;
    top: 5.5rem;
    width: fit-content;
	z-index: 2;
}

    #navigation li {
        font-size: 1.8rem;
        font-weight: 600;
        text-transform: capitalize;
    }

        #navigation li.active > span > a {
            border-bottom: 1px dashed;
            color: hsla(188, 45%, 13%, 1);
        }

        #navigation li.has-menu {
            position: relative;
        }

        #navigation li.has-menu > .nav-item-menu {
            background-color: hsla(0, 0%, 100%, 1);
            border-radius: 1rem;
            display: none;
            padding: 1rem 2rem;
            position: absolute;
        }

        #navigation li.has-menu > .nav-item-menu > div {
            font-size: 1.5rem;
            margin-bottom: 1rem !important;
            white-space: nowrap;
        }

/* The Modal (background) */
.modal,
.menu-modal {
    background-color: hsl(0, 0%, 0%); /* Fallback color */
    background-color: hsla(0, 0%, 0%, 0.2); /* Black w/ opacity */
    display: none; /* Hidden by default */
    height: 100%; /* Full height */
    left: 0;
    overflow: auto; /* Enable scroll if needed */
    position: fixed; /* Stay in place */
    top: 0;
    width: 100%; /* Full width */
    z-index: 3; /* Sit on top */
}

.menu-modal {
    top: 7rem;
    z-index: 2;
}

/* Modal Content */
.modal-content {
    /* -webkit-animation-name: animatetop;
    -webkit-animation-duration: 0.4s;
    animation-name: animatetop;
    animation-duration: 0.4s; */
    background-color: hsla(0, 0%, 100%, 1);
    border-radius: 1rem;
    box-shadow: 0 4px 8px 0 hsla(0, 0%, 0%, 0.2),0 6px 20px 0 hsla(0, 0%, 0%, 0.2);
    display: flex;
    left: 50%;
    max-height: 80vh;
    opacity: 0;
    padding: 0;
    position: fixed;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90vw;
    z-index: 4;
}

.modal-content.wide {
    max-width: 108rem;
    width: 85vw;
}

.message {
    align-items: center;
    background-color: white;
    border-radius: 2rem;
    box-shadow: 0 4px 8px 0 hsla(0, 0%, 0%, 0.2),0 6px 20px 0 hsla(0, 0%, 0%, 0.2);
    display: none;
    left: 50%;
    padding: 3rem;
    position: fixed;
    text-align: center;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 80vw;
    z-index: 2;
}

/* Add Animation */
/* @-webkit-keyframes animatetop {
    from {top:-300px; opacity:0}
    to {top:0; opacity:1}
}

@keyframes animatetop {
    from {top:-300px; opacity:0}
    to {top:0; opacity:1}
} */

/* The Close Button */
.close {
    color: hsla(188, 97%, 13%, 1);
    font-size: 3rem;
	-webkit-transition: all .2s ease-in-out;
	transition: all .2s ease-in-out;
}

.close:hover,
.close:focus {
    color: hsla(188, 97%, 13%, 0.5);
    cursor: pointer;
}

.modal-header,
.modal-body,
.modal-footer {
    padding: 2rem 1.5rem;
}

.modal-footer.no-button > button {
    display: none;
}

.modal-header {
    border-bottom: 1px solid hsla(188, 97%, 13%, 1);
}

.modal-body {
    overflow-y: auto;
}

.modal-body img {
    margin-bottom: 0 !important;
    max-width: 15rem;
}

.modal-footer {
    border-top: 1px solid hsla(188, 97%, 13%, 1);
}

@media only screen
    and (min-width: 768px) {

    h3 {
        font-size: 2.5rem;
        line-height: 3rem;
        margin-top: 1em;
    }

    #nav-container,
    #footer {
        padding: 0 3rem;
    }

    #site-logo {
        font-size: 8.5rem;
        margin-right: 2rem;
        transform: translateY(2rem);
    }

        #error-message-text-wrapper #site-logo {
            transform: none;
        }

    #site-name {
        font-size: 5rem;
    }

    .slideshow {
        height: 70%;
        min-height: 35rem;
    }

    .slide {
        padding: 3rem 15rem;
    }

    .slide-content > h3 {
        font-size: 3.5rem;
        line-height: 4rem;
        margin-bottom: 3rem !important;
    }

    .slide-content > p {
        font-size: 2.8rem;
        line-height: 3.2rem;
    }

    a.carousel-nav {
        font-size: 5rem;
    }

    a.page-nav {
        margin-top: auto;
        margin-bottom: 2rem;
    }

    #home-content > .column > :not(:last-child) {
        margin-bottom: 3rem !important;
    }

    .modal-content {
        width: 55rem;
    }

    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 2rem 4rem;
    }

    .message {
        width: 40rem;
    }

    .bg.circle.bottom.small {
        bottom: calc((((200vh - 7rem) * 0.25) / 2) * -1);
    }

    .bg.circle.bottom.medium {
        bottom: calc((((200vh - 7rem) * 0.5) / 2) * -1);
    }

    .bg.circle.bottom.large {
        bottom: calc((((200vh - 7rem) * 0.7) / 2) * -1);
    }

    #map {
        height: 35rem;
    }
}

@media only screen
    and (min-width: 1024px) {

    #site-name {
        font-size: 4rem;
    }

    #navigation {
        background-color: transparent;
        border-radius: 0;
        display: flex;
        list-style-type: none;
        margin: 0;
        padding: 0;
        position: static;
        right: auto;
        top: auto;
        width: auto;
        z-index: 2;
    }

        #navigation li:not(:first-of-type) {
            margin-left: 2rem;
        }

    #menu-mobile {
        display: none;
    }

    .section {
        padding: 3rem 10rem;
    }

    .feature {
        display: flex;
    }

    .flex-container-wrapper > .contact-card-container {
        margin: -1.5rem -3.5rem !important;
    }

    .flex-container.ratio-one-to.one > :not(.bg) {
        -ms-flex-preferred-size: 34%;
        flex-basis: 34%;
        margin-bottom: 0;
        min-width: calc(50% - 3.5rem);
    }

    .flex-container-wrapper > .flex-container.ratio-one-to.one.contact-card-container > .contact-card {
        margin: 1.5rem 3.5rem ;
        min-width: calc(50% - 7rem);
    }

    :not(.flex-container-wrapper) > .flex-container.row > :not(.nav-item):not(.step):not(.bg):not(.expando-heading-text):not(:last-child) {
        margin-right: 7rem;
    }

    :not(.flex-container-wrapper) > .flex-container.row-reverse > :not(.nav-item):not(.bg):not(:last-child) {
        margin-left: 7rem;
    }
}

@media only screen
    and (min-width: 1200px) {

    #nav-container,
    #footer {
        padding: 0 10rem;
    }

    #site-logo {
        font-size: 10rem;
    }

    #site-name {
        font-size: 5rem;
    }
}

/* any touch device */
@media (hover:none), (hover:on-demand) { /* STYLES GO HERE */ }

/* iPad 1, 2, Mini and Air in portrait */
@media only screen
    and (min-device-width: 768px)
    and (max-device-width: 1024px)
    and (orientation: portrait)
    and (-webkit-min-device-pixel-ratio: 1) { /* STYLES GO HERE */ }

/* iPhone X in portrait */
@media only screen
	and (min-device-width : 375px)
	and (max-device-width : 812px)
	and (-webkit-device-pixel-ratio : 3)
	and (orientation : portrait) {

    #error-message-text {
        font-size: unset;
        line-height: unset;
    }
}

/* iPhone 6, 7, & 8 in portrait */
@media only screen
	and (min-device-width : 375px)
	and (max-device-width : 667px)
	and (orientation : portrait) {

    #error-message-text {
        font-size: unset;
        line-height: unset;
    }

	#return {
		padding: 2rem 1rem 0 1rem;
	}
}

/* iPhone SE, 5 & 5S */
@media screen and (device-aspect-ratio: 40/71) {

    #error-message-text {
        font-size: unset;
        line-height: unset;
    }

	#return {
		padding: 2rem 1rem 0 1rem;
	}
}