BODY {
  margin: 0px;
  letter-spacing: .02rem;
}

BODY, .dialog-off-canvas-main-canvas select, .dialog-off-canvas-main-canvas input, .dialog-off-canvas-main-canvas textarea {
  font-family: 'Sora', sans-serif;
  font-size: 16px;
  line-height: 150%;
  color: #4e4e4e;
}

/* -------------- LINKS -------------- */
.dialog-off-canvas-main-canvas a, .dialog-off-canvas-main-canvas a:visited, .dialog-off-canvas-main-canvas a:active {
  text-decoration: none;
  color: #2c2c70;
}

.dialog-off-canvas-main-canvas a:hover {
  text-decoration: underline;
}

.paragraph-link {
  margin-top: 30px;
  white-space: nowrap;
}

.paragraph-link a {
  padding: 15px 50px;
  border: 1px solid #fca01f;
  border-radius: 25px;
  background-color: #fca01f;
  color: white;
}

.paragraph-link a:visited, .paragraph-link a:active, .paragraph-link a:hover {
  color:white;
  text-decoration: none;
}

.dialog-off-canvas-main-canvas header {
  overflow: hidden;
  /*min-width: 600px;*/
  max-width: 1340px;
  margin: 0px auto 0px auto;
}

.layout-content, div[role=contentinfo] {
  max-width: 1340px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
}

div.view-attachment {
  text-align: center;
}

DIV[role=contentinfo] {
  text-align: center;
  color:firebrick;
}

.title-center {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  /*padding-top: 10px;*/
}

.block-clear {
  clear: both;
  padding-top: 10px;
}

.pad-top {
  padding-top: 10px;
}

#block-vco-branding {
  padding: 10px;
  float: left;
}

#block-vco-languageswitcher {
  float: left;
  margin-right: 15px;
} 



.geolocation-map-container {
  margin-top: 40px;
  margin-bottom: 40px;
}

.links li {
  display: inline;
}
.links li:not(:last-child):after {
  content: ' | ';
}

div.layout-container > footer {
  background: #fca01f;
  padding: 20px;
  /*margin-top: 40px;*/
}
div.layout-container > footer p {
  text-align: center;
  color: #282828;
}

.featured-image {
  margin-bottom: 40px;
}

.featured-image IMG {
  width: 100%;
  height: 400px;
  object-fit: cover; /* Crop image to image element size */
  object-position: 50% 50%; /* Scale image with center as origin */
}

.slick-arrow::before {
  color: #fca01f;
}

.slick-prev::before, .slick-next::before {
  opacity: 1;
}

/*.section-padded {
  margin-left: 30px;
  margin-right: 30px;
}*/

.webform-submission-form FIELDSET {
   /*max-width: 600px;
  min-width: 300px;*/
  width: 600px;
}

/*.form-type-textfield label {
  font-weight: bold;
}*/

a.is-active {
  text-decoration: underline !important;
}

/*.field {
  margin-bottom: 10px;
}*/

.field--type-text-with-summary {
  padding: 0px 15px 0px 15px;
}

.field__label {
  font-weight: bold;
  /*padding-top: 10px;*/
}
/*.field__label:not(first-child) {
  margin-top: 10px;
}*/

.layout--twocol-section { 
  margin-bottom: 20px;
  margin-left: 15px;
  margin-right: 15px;
}

.captcha IMG {
  display: block;
}

@media screen and (min-width: 40em) 
{
  .layout--twocol-section {
    flex-wrap: nowrap;
  }
  .layout__region--first {
    padding-right: 20px;
  }
  .layout__region--second {
    padding-left: 20px;
  }
}

.layout__region--first P {
  text-align: justify;
}

.inline-block {
  display: block;
  float: left;
  margin-right: 10px;
}

.bingo-icon {
  display: block;
  clear: both;
}

/* VIEWS EXPOSED FORMS */
/* --------------------------------------------------------- */
.views-exposed-form {
  margin-bottom: 30px;
  padding-left: 20px;
  /*display: block;
  margin-left: auto;
  margin-right: auto;
  max-width: 1340px;*/
}

.views-exposed-form OPTION { 
  background: #ffffff;
}

.form-submit {
  border: 4px solid #fca01f; 
  border-radius: 36px;
  background: #fca01f; 
  padding: 3px 8px 3px 8px; /* top right bottom left */
  color: #282828; 
}

/* Rounded border for form fields */
.views-exposed-form .select-wrapper, .views-exposed-form .input-wrapper {
  border-radius: 36px;
  display: block;
  overflow: hidden;
  background: #ffffff;
  border: 4px solid #fca01f; 
  padding: 6px 8px 6px 8px;
  float: left;
  margin-right: 10px;
  margin-bottom: 10px;
}
.views-exposed-form .form-select, .views-exposed-form .form-text {
  background: #ffffff;
  height: 26px;
  border: 0px;
  outline: none;
}
/* End rounded borders */

.views-exposed-form .form-text {
  background: white url(../images/magnifier-small.png) right no-repeat;
  padding-right: 40px;
}
/* --------------------------------------------------------- */

.webform-submission-form {
  width: 632px;
  margin-left: auto;
  margin-right: auto;
}

.form-item {
  margin-bottom: 10px;
}

.form-required:after {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin: 0 0.3em;
  content: "";
  vertical-align: super;
  /* Use a background image to prevent screen readers from announcing the text. */
  background-image: url(../images/required.svg);
  background-repeat: no-repeat;
  background-size: 6px 6px;
}

/*.views-element-container {
  max-width: 1340px;
  margin-left: auto;
  margin-right: auto;
}*/

/* Bingo checkbox for exposed form */
.fieldgroup {
  max-width: 100px;
}

/* the slides */
.slick-slide {
  /*margin: 0 20px;*/
  padding-left: 10px;
  padding-right: 10px;
}

/* the parent */
/*.slick-list {
  margin: 0 -20px;
}*/

.slick--optionset--place-gallery img {
  border-radius: 10px;
}

textarea { 
  width: 585px;
}

details, fieldset, .filter-wrapper {
  border-radius: 9px;
  padding-top: 14px;
}

.fieldset-legend {
  font-weight: bold;
}

.webform-element-help {
  background: #fca01f;
  border: 2px solid #fca01f;
}

.webform-element-help:hover {
  background: #fca01f;
  border: 2px solid #fca01f;
}

.form-type-processed-text P {
  margin-block-start: 0em;
}

FORM > .form-type-processed-text {
  width: 630px;
  text-align: justify;
}

.views-exposed-form legend {
  display: none;
}

.places-col, .placetypes-col {
  width: 400px;
  height: 470px;
  margin-left: 20px;
  margin-right: 20px;
  margin-bottom: 30px;
  border: 1px solid white;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}

.places-list-img img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  object-position: 50% 50%;
  border-bottom: 1px solid white;
  border-radius: 0 0 10px 10px;
}

.views-field-fieldset {
  display: none;
  position: absolute;
  padding: 10px;
  top: 57px;
  left: 0px;
  width: 380px;
  height: 400px;
  background-color: rgba(255,255,255,0.9);
  z-index: 500;
}

.views-field-field-description, .field--name-body {
  text-align: justify;
}

.views-field-title, .views-field-name {
  font-weight: bold;
}

.placetypes-col .views-field-title, .placetypes-col .views-field-name {
  background: #fca01f;
  color: white;
  position: relative;
  padding-top: 15px;
  padding-bottom: 15px;
  padding-left: 10px;
}

.places-col .views-field-title, .places-col .views-field-name {
  background: #6ecfbd;
  color: white;
  position: relative;
  padding-top: 15px;
  padding-bottom: 15px;
  padding-left: 10px;
  /*height: 40px;*/
}

.views-field-field-bingo {
  position: absolute;
  top: 76px;
  right: 20px;
  z-index: 100;
}

.jsLink {
  cursor:pointer;
}

.link-read-more {
  position: absolute;
  right: 10px;
  top: 11px;
  display: block;
  cursor:pointer;
}

.margin-bottom {
  margin-bottom: 10px;
}

div.sponsorLogos {
  text-align: center;
}

div.sponsorLogo {
  display: inline-block;
  margin-right: 30px;
}

div.sponsorLogo:last-child {
  margin-right: none;
}

div.sponsorLogo img {
  height: 50px;
  width: auto;
}

/* -------------------------------------------------*/
/* Form checkboxes                                  */
/* -------------------------------------------------*/
.form-type-checkbox {
  white-space: nowrap;
  display: grid;
  grid-template-columns: 1em auto;
  gap: 1em;
  margin-top: 12px;
}
.views-exposed-form .form-type-checkbox label {
  padding-top: 2px;
}
input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  background-color: #fff;
  margin: 0;
  font: inherit;
  color: #fca01f;
  width: 1.7em;
  height: 1.7em;
  border: 3px solid #fca01f;
  border-radius: 8px;
  transform: translateY(-0.075em);
  display: grid;
  place-content: center;
}
input[type="checkbox"]::before {
  content: "";
  width: 0.8em;
  height: 0.8em;
  transform: scale(0);
  transition: 80ms transform ease-in-out;
  box-shadow: inset 1em 1em #fca01f;
  transform-origin: bottom left;
  clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}
input[type="checkbox"]:checked::before {
  transform: scale(1);
}
.form-type-checkbox .description {
  grid-column: 1 / 3;
}

.webform-submission-form input[type="text"],
.webform-submission-form input[type="email"],
.webform-submission-form input[type="url"] {
  width: 583px;
}

/* Fit carousel image to width of screen at a specific height */
.paragraph--type--slick-paragraph img, .paragraph--type--paragraph-with-bg-image img, .paragraph--type--paragraph-with-bg-media img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  object-position: 50% 50%;
  border-radius: 8px;
}

.paragraph--type--paragraph-with-bg-image, .paragraph--type--paragraph-with-bg-media {
	position: relative;
}


.paragraph--type--title-body-link, .paragraph--type--title-body, .paragraph--type--title {
	color: white;
	position: absolute;
	top: 100px;
	text-align: center;
	width: 100%;
	padding-left: 50px;
	padding-right: 50px;
}

.places-row {
  display: inline;
}

.views-view-grid {
  text-align: center;
}

.views-view-grid * {
  text-align: left;
}

.views-view-grid .views-col {
  float: none;
  display: inline-block;
}

#block-header-links {
  float: right;
}

#block-header-links p {
  line-height: 120%;
  padding-right: 15px;
  font-size: 0.95em;
}

#block-header-links .field--name-body {
  text-align: left;
}

#block-header-links a, #block-header-links a:visited, #block-header-links a:active {
  display: inline-block;
  padding: 5px 10px 5px 10px;
  background-color: #e5e5f1;
  border-radius: 10px;
  color: #2c2c70;
  width: 100%;
}

a.box {
  display: inline-block;
  padding: 5px 20px 5px 20px;
  background-color: #e5e5f1;
  border-radius: 10px;
  color: #2c2c70;
}

p.box {
  padding: 5px 5px 5px 5px;
  background-color: #e5e5f1;
  border-radius: 10px;
  color: #2c2c70;
}

.smallText {
  font-size: 0.8em;
}

@media screen and (max-width: 40em)
{
  .paragraph--type--title-body-link, .paragraph--type--title-body {
    top: 20px;
  }

  /*.views-view-grid .views-col {
    float: none;
  }*/
  
  .places-col, .placetypes-col {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 30em)
{
  /* Banner */
  .paragraph--type--slick-paragraph img, .paragraph--type--paragraph-with-bg-image img, .paragraph--type--paragraph-with-bg-media img {
    height: 500px;
  }
}

.paragraph-title {
	font-size: 50px;
	font-weight: bold;
  line-height: normal;
}

/* Autosize image */
div.autosize img {
  max-width: 100%;
  height: auto;
}

/* PAGE SPECIFIC FORMATTING (HACK: Find a better way to do this) */

article[data-history-node-id="95"] div.field--name-body {
  text-align: center;
}




/*.geolocation-map-container {
  margin: 0 auto;
}*/

/*input[type=checkbox]:before { content:""; display:inline-block; width:12px; height:12px; background:red; }
input[type=checkbox]:checked:before { background:green; }*/

/*.form-checkbox {
  -webkit-appearance: none;
  appearance: none;
  background-color: #fff;
  margin: 0;
  font: inherit;
  color: #fca01f; 
  width: 24px;
  height: 24px;
  border: 3px solid #fca01f; 
  border-radius: 5px;
  transform: translateY(6px);
}*/

