/* Global styles */
::placeholder { color: darkgray; opacity: 1; }
::-ms-input-placeholder { color: darkgray; opacity: 1; }
::-webkit-input-placeholder { color: darkgray; opacity: 1; }
* { -webkit-overflow-scrolling: touch; }
div.icons, div.popover { display: none !important; }
.radius { border-radius: 0.313rem; }

a:not([href]) { color: inherit; cursor: inherit; text-decoration: inherit; }
h1, h2, h4, h3, h5, h6 { color: #852628; }
h1, h2, h4 { font-weight: bold; }
h3, h5, h6 { font-weight: normal; }
h2, h3 { line-height: calc(26 / 20); }
h4, h5 { line-height: calc(22 / 18); }
h1 { line-height: calc(32 / 25); margin: 0 auto 1rem; }
h2 { margin: 0.625rem auto; text-transform: capitalize; }
h3 { margin: 0.625rem auto 0; }
h4 { margin: 0.5rem auto 0; }
iframe { border: 0 solid #554832; display: block; margin: 1rem auto; max-width: 100%; }
.text-red { color: #852628; }
/* End global styles */

/* Masthead */
.masthead, .masthead-content { position: relative; }
.masthead { padding: 1.25rem 0; }
.masthead-content { font-size: 0; padding: 0 .625rem; }
.masthead-content > * { display: inline-block; font-size: 1rem; position: relative; vertical-align: bottom; }

.masthead-content > *:nth-child(2) { width: calc(100% - 200px - 274px); }
.masthead-content > *:nth-child(3) { text-align: right; width: 12.5rem; }

.logo { margin-right: 2.75rem; width: 14.375rem; }
.logo p { margin: 0; }
/* End masthead */

/* Navigation */
/* .mainmenu .menu a:hover { background: #722122; color: #fefefe; } */
.mainmenu { text-transform: capitalize; }
.mainmenu a { color: #852628; }
.mainmenu a:focus, .mainmenu a:hover { color: #0a0a0a; text-decoration: underline; }
.mainmenu .menu .active>a, .mainmenu .menu > li.is-active > a, .mainmenu .menu > li a:focus,
  .mainmenu .menu > li a:hover { background: inherit; color: #0a0a0a; }
.mainmenu .menu > li a:focus, .mainmenu .menu > li a:hover, .dropdown.menu>li.is-active>a { text-decoration: underline; }
.mainmenu .is-dropdown-submenu { background: #852628; border: 0; color: #fefefe; }
.mainmenu .is-dropdown-submenu a { color: #fefefe; line-height: 1.2; }
.mainmenu .is-dropdown-submenu .active>a, .mainmenu .is-dropdown-submenu > li a:focus,
  .mainmenu .is-dropdown-submenu > li a:hover { background: #0a0a0a; color: #fefefe; text-decoration: none; }
  .mainmenu .submenu a:focus, .mainmenu .submenu a:hover, .mainmenu .submenu .is-active>a { background: #0a0a0a; }
/* dropdown arrows */
/* .dropdown.menu>li.is-dropdown-submenu-parent>a::after { border-color: #fff transparent transparent; } */
.dropdown.menu>li.is-dropdown-submenu-parent>a::after { border-color: #852628 transparent transparent; }
.dropdown.menu>li.is-dropdown-submenu-parent.is-active>a::after { border-color: #0a0a0a transparent transparent; }
.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after { border-color: transparent transparent transparent #fff; }

.topmenu { font-size: 0.875rem; }
.topmenu a { display: inline-block; line-height: 1; margin: 0 0.3125rem; padding-bottom: 0.7rem; vertical-align: bottom; }
.topmenu img { height: 2.375rem; width: auto; }

.pushy-menu-btn { display: none; font-size: 3.375rem; line-height: 1; position: absolute; right: 3%; top: 50%; transform: translateY(-50%); }
.pushy, .pushy > .pushy-main-submenu .pushy-submenu { background: #852628; font-weight: normal; }
.pushy li > a { color: #fefefe; }
.pushy li > a:hover { background-color: #0a0a0a; }
.pushy-active { overflow: hidden; }

/* Unset the webkit-perspective property if we use a fixed position header */
.pushy-container { -webkit-perspective: unset; }

a.up-button { background-color: #852628; bottom: 1rem; border-radius: 1.875rem; color: #fefefe; display: block; font-family: 'Font Awesome 5 Free';
  font-size: 2rem; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; font-variant: normal; font-weight: 900; left: 0.5rem;
  line-height: 1; padding: 0.8125rem 0.8125rem; position: fixed; text-decoration: none; text-rendering: auto; z-index: 2; }
a.up-button:focus, a.up-button:hover { background-color: #722122; }
a.up-button::before, a.up-button:before { content: '\f062'; }
/* End navigation */

/* Slideshow */
/* End slideshow */

/* Copyarea */
.copyarea, .homeblockarea { margin-bottom: 32px; margin-top: 32px; }
.copyarea.home { font-size: 1.5625rem; text-align: center; }
.copyarea.home p { line-height: calc(30 / 25); }
.copyarea ol, .copyarea ul:not(.breadcrumbs) { margin: 1.5rem 0 1.5rem 0; padding-left: 1.875rem; }
.copyarea ol li, .copyarea ul:not(.breadcrumbs) li { line-height: calc(23 / 16); margin: 0 auto 0.625rem; }
.breadcrumbs li { font-size: 0.875rem; line-height: calc(18 / 14); text-transform: capitalize; }
/* Reset left/right margins back to auto for component content that may contain its own rows and columns */
.row.reset { margin-left: auto; margin-right: auto; }

dl dt.result-title:first-child { margin: 0 auto 0.3125rem; }
dl dt.result-title:not(:first-child) { margin: 1rem auto 0.3125rem; }

.photoblock { background-position: center; background-repeat: no-repeat; background-size: contain; display: inline-block;
  font-size: 0; height: 200px; margin: 10px 0; width: 100%; }
.photoblock a { display: block; height: 100%; }

.imageset { margin: 0 auto 36px; }
/* End copyarea */

/* Footer */
footer { background: #852628; color: #fefefe; margin-top: calc(32px + 64px); padding: 3.4375rem 0; position: relative; text-align: center; }
footer::before { background-size: cover; background-image: url('../images/bg-footer-top.png'); background-position: center top;
  background-repeat: no-repeat; content: ''; display: block; height: 2.25rem; left: 0; position: absolute; right: 0; top: -2.1875rem; }
footer a, footer a:focus, footer a:hover { color: #fefefe; }

footer .moduletable { margin: 0 0 50px; }
.dev-copyright { font-size: 0.813rem; }

img.footer-logo { max-width: 45%; }
/* End footer */

/* Locations map styles */
.gmaps-wrapper { position: relative; }
.noscroll { pointer-events: none; }
.gmaps-wrapper, .location-map { border: 0.063rem solid #333; box-shadow: 0 0 0.188rem 0 rgba(51,51,51,0.5); }
.gmaps-wrapper .details * { color: #fff; }
.gmaps-wrapper .details a { color: #ccd699; text-decoration: underline; }
.gmaps-wrapper .details a:focus, .gmaps-wrapper .details a:hover { text-decoration: none; }
.gmaps-wrapper .details { background: rgba(0,0,0,0.8); bottom: 0; cursor: default; left: 0;
  padding: 0.625rem; pointer-events: unset; position: absolute; right: 0; top: 0; z-index: 1000; }
/* End locations map styles */

/* Custom CSS */
blockquote { border-left: 0.1875rem solid #333; margin: 1rem 0; padding: 0.9375rem 1rem; }
blockquote, blockquote p { color: inherit; }
blockquote > p:last-child, blockquote [class*="button"]:last-of-type { margin-bottom: 0; }
input[readonly] { background-color: inherit; }
select { background-position: right center; }
span.br { display: initial; }

.recap-container { position: relative; }
.recap-container > div { display: none; }
.grecaptcha-badge { margin: 0 0 1rem; }
.required::before, .required:before { color: #c71c24; content: '*'; display: inline-block; vertical-align: top; }
.pagination-list { margin-left: 0; }
.pagination .has-tip { cursor: pointer; }
.pagination li:last-child, .pagination li:first-child, .pagination li.nav-start,
  .pagination li.nav-prev, .pagination li.nav-next, .pagination li.nav-end { display: inline-block; }

.imageset img { display: block; margin: 0 auto; }

/* End custom CSS */

/* Media queries */
/* Small and up */
@media screen and (min-width: 0em) {}

/* Small only */
@media only screen and (max-width: 39.9375em) {
  a.logo { padding-top: 10%; }
  .logo img { width: 90%; }
  .nav-wrapper { padding: 0; }

  footer .columns { margin-bottom: 1rem; }
  footer .text-right { text-align: left; }
}

/* Medium and up */
@media only screen and (min-width: 40em) {
  .masthead-content { padding: 0 .9375rem; }
}

/* Medium only */
@media screen and (min-width: 40em) and (max-width: 63.9375em) {}

/* Medium and lower */
@media only screen and (max-width: 54.938em) {
  .mainmenu, .topmenu { display: none; }
  .pushy-menu-btn { display: block; }
}

@media only screen and (max-width: 63.9375em) {

}

/* Large and up */
@media only screen and (min-width: 64em) {

}

/* Large only */
@media screen and (min-width: 64em) and (max-width: 74.9375em) {}

/* Xlarge and up */
@media only screen and (min-width: 75em) {

}

@media only screen and (max-width: 75em) {
  footer { padding-left: 3%; padding-right: 3%; }
}

/* Xxlarge and up */
@media only screen and (min-width: 90em) {}
