/*********************************************
* General
*********************************************/
body {
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

a,
a:hover {
  color: #404040;
}

.one-word-per-line {
  word-spacing: 100vw;
}

/*********************************************
* Icons
*********************************************/
.mat-icon-big {
  font-size: 36px !important;
}

.mat-icon-align {
  display: inline-flex;
  vertical-align: middle;
}

/*********************************************
* Navbar
*********************************************/
.navbar a,
.navbar a:hover {
  color: #fff !important;
}

.navbar-light .navbar-toggler {
  background-color: #fff !important;
}

.largenav {
  padding: 0px;
}

.navbar-light .navbar-nav .nav-link.active {
  background: none;
  font-weight: bold;
  text-decoration: underline;
}

.nav-link:hover {
  color: #bfbfbf !important;
}

.nav-button-same-size {
  width: 200px !important;
}

.nav-buttons {
  padding: 0;
}

.nav-buttons .btn.active {
  text-decoration: underline !important;
}

button {
  vertical-align: text-top !important; 
}

#navbar-jumbo.container {
  padding: 0;
}

@media (min-width: 768px) {
  .navbar-extended {
    min-height: 120px;
  }
  .fake-center {
    padding-left: 10vh;
  }
}

/*********************************************
* Colors
*********************************************/
header.masterhead {
  background-color: #ffff43;
}

.text-contrast {
  color: #bfbfbf;
}

.bg-grey-dark {
  background-color: #404040 !important;
}

.bg-grey-middle {
  background-color: #dbdbdb !important;
}

.bg-white {
  background-color: #fff;
}

/*********************************************
* header
*********************************************/
header.masterhead {
  position: relative;
  background-size: cover;
  padding-top: 8rem;
  padding-bottom: 5rem;
}

header.masterhead .overlay {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  opacity: 0.3;
}

header.masterhead .headertext {
  color: #000;
}

@media (min-width: 768px) {
  header.masterhead {
    padding-top: 3rem;
    padding-bottom: 2rem;
  }
  header.masterhead h1 {
    font-size: 3rem;
  }
}

/*********************************************
* Table
*********************************************/

.tablepress thead th {
  background-color: #404040 !important;
  color: #fff;
}

/*********************************************
* Main
*********************************************/
.main {
  min-height: 70vh;
}

.main .infoboxes .card,
.main .part .card {
  border: none;
}

.main .infoboxes .card .card-header,
.main .part .card .card-header {
  background: none;
}

/*********************************************
* Infobox
*********************************************/

/*********************************************
* Footer
*********************************************/
footer.footer {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

footer.footer a,
footer.footer a:hover {
  color: white;
}

/*********************************************
* WP Core 
*********************************************/
.alignnone {
  margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
  display: block;
  margin: 5px auto 5px auto;
}

.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}

.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}

a img.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}

a img.alignnone {
  margin: 5px 20px 20px 0;
}

a img.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}

a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption {
  background: #fff;
  border: 1px solid #f0f0f0;
  max-width: 96%; /* Image does not overflow the content area */
  padding: 5px 3px 10px;
  text-align: center;
}

.wp-caption.alignnone {
  margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
  margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
  margin: 5px 0 20px 20px;
}

.wp-caption img {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 98.5%;
  padding: 0;
  width: auto;
}

.wp-caption p.wp-caption-text {
  font-size: 11px;
  line-height: 17px;
  margin: 0;
  padding: 0 4px 5px;
}

/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
  background-color: #eee;
  clip: auto !important;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 1em;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/*********************************************
* Fonts
*********************************************/
/* quicksand-300 - latin */
@font-face {
  font-family: "Quicksand";
  font-style: normal;
  font-weight: 300;
  src: url("fonts/quicksand-v7-latin-300.eot"); /* IE9 Compat Modes */
  src: local("Quicksand Light"), local("Quicksand-Light"),
    url("fonts/quicksand-v7-latin-300.eot?#iefix") format("embedded-opentype"),
    /* IE6-IE8 */ url("fonts/quicksand-v7-latin-300.woff2") format("woff2"),
    /* Super Modern Browsers */ url("fonts/quicksand-v7-latin-300.woff")
      format("woff"),
    /* Modern Browsers */ url("fonts/quicksand-v7-latin-300.ttf")
      format("truetype"),
    /* Safari, Android, iOS */ url("fonts/quicksand-v7-latin-300.svg#Quicksand")
      format("svg");
  /* Legacy iOS */
}
/* quicksand-regular - latin */
@font-face {
  font-family: "Quicksand";
  font-style: normal;
  font-weight: 400;
  src: url("fonts/quicksand-v7-latin-regular.eot");
  /* IE9 Compat Modes */
  src: local("Quicksand Regular"), local("Quicksand-Regular"),
    url("fonts/quicksand-v7-latin-regular.eot?#iefix")
      format("embedded-opentype"),
    /* IE6-IE8 */ url("fonts/quicksand-v7-latin-regular.woff2") format("woff2"),
    /* Super Modern Browsers */ url("fonts/quicksand-v7-latin-regular.woff")
      format("woff"),
    /* Modern Browsers */ url("fonts/quicksand-v7-latin-regular.ttf")
      format("truetype"),
    /* Safari, Android, iOS */
      url("fonts/quicksand-v7-latin-regular.svg#Quicksand") format("svg"); /* Legacy iOS */
}
/* quicksand-500 - latin */
@font-face {
  font-family: "Quicksand";
  font-style: normal;
  font-weight: 500;
  src: url("fonts/quicksand-v7-latin-500.eot"); /* IE9 Compat Modes */
  src: local("Quicksand Medium"), local("Quicksand-Medium"),
    url("fonts/quicksand-v7-latin-500.eot?#iefix") format("embedded-opentype"),
    /* IE6-IE8 */ url("fonts/quicksand-v7-latin-500.woff2") format("woff2"),
    /* Super Modern Browsers */ url("fonts/quicksand-v7-latin-500.woff")
      format("woff"),
    /* Modern Browsers */ url("fonts/quicksand-v7-latin-500.ttf")
      format("truetype"),
    /* Safari, Android, iOS */ url("fonts/quicksand-v7-latin-500.svg#Quicksand")
      format("svg");
  /* Legacy iOS */
}
/* quicksand-700 - latin */
@font-face {
  font-family: "Quicksand";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/quicksand-v7-latin-700.eot"); /* IE9 Compat Modes */
  src: local("Quicksand Bold"), local("Quicksand-Bold"),
    url("fonts/quicksand-v7-latin-700.eot?#iefix") format("embedded-opentype"),
    /* IE6-IE8 */ url("fonts/quicksand-v7-latin-700.woff2") format("woff2"),
    /* Super Modern Browsers */ url("fonts/quicksand-v7-latin-700.woff")
      format("woff"),
    /* Modern Browsers */ url("fonts/quicksand-v7-latin-700.ttf")
      format("truetype"),
    /* Safari, Android, iOS */ url("fonts/quicksand-v7-latin-700.svg#Quicksand")
      format("svg");
  /* Legacy iOS */
}

.display-5 {
  font-size: 3.0rem;
  font-weight: 300;
  line-height: 1.2;
}

.display-6 {
  font-size: 2.5rem;
  font-weight: 300;
  line-height: 1.2;
}

.display-7 {
  font-size: 2.0rem;
  font-weight: 300;
  line-height: 1.2;
}


/*********************************************
* google maps
*********************************************/
.ce-google-maps {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 100%; /* 1x1 */
}

.ce-google-maps > * {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
.ce-google-maps .gmap-opt-in-wrap {
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-color: grey;
}

@media screen and (min-width:481px) {
  .ce-google-maps {
      padding-bottom: 66.6666%; /* 3x2*/
  }
  .ce-google-maps .gmap-opt-in-wrap {
  }
}

@media screen and (min-width:769px) {
  .ce-google-maps {
      padding-bottom: 56.25%; /* 16x9*/
  }
  .ce-google-maps .gmap-opt-in-wrap {
  }
}

@media screen and (min-width:1280px) {
  .ce-google-maps {
      padding-bottom: 42.8571%; /* 21x9*/
  }
  .ce-google-maps .gmap-opt-in-wrap {
  }
}

.ce-google-maps .gmap-opt-in-button-wrap {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255,255,255,0.3);
}

.ce-google-maps .gmap-opt-in-button {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  cursor: pointer;
  width: 80%;
  max-width: 20em;
  color: rgb(20%,20%,20%);
  background-color: rgba(255,255,255,0.9);
  padding: 0.5em;
  border-radius: 0.5em;
}

.ce-google-maps .gmap-opt-in-button div:first-child {
  text-align: center;
  font-weight: 700;
  text-transform: uppercase;
}

.ce-google-maps .gmap-opt-in-button div:last-child {
  font-size: 80%;
  line-height: 1.3;
}