@charset "UTF-8";
/* Reset
-------------------------------------------------- */
*,
*:before,
*:after {
  margin: 0;
  padding: 0;
  border: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  outline: none;
}

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

/* Pix
-------------------------------------------------- */
img {
  display: block;
  max-width: 100%;
}

/* Audio
-------------------------------------------------- */
audio {
  width: 100%;
  max-width: 100%;
}

@font-face {
  font-family: "INVISION";
  src: url("../wf/invision-bold_italic.woff2") format("woff2"), url("../wf/invision-bold_italic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
}
@font-face {
  font-family: "INVISION";
  src: url("../wf/invision-bold.woff2") format("woff2"), url("../wf/invision-bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "INVISION";
  src: url("../wf/invision-regular.woff2") format("woff2"), url("../wf/invision-regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
body {
  background: lightgrey;
}

/* Font formats for UI elements
-------------------------------------------------- */
.footer, .footer form input, button,
.button, .menu--secondary ul li a, label,
.label, .menu--primary a,
section header time,
article header time,
article header div a,
.readmore,
.reading,
#main .breadcrumbs a,
#main .breadcrumbs p,
#main .breadcrumbs h6 {
  text-align: center;
  font-family: "INVISION";
  font-size: 0.75rem;
  text-transform: uppercase;
  font-weight: 900;
}

.radio-button-label span, .menu--primary a, .menu--footer a {
  font-size: 1.2rem;
  text-align: left;
}

.heroine h1, #headtxt h1 {
  position: relative;
  z-index: 2;
}
.heroine h1:before, #headtxt h1:before, .heroine h1:after, #headtxt h1:after {
  opacity: 0.8;
  position: absolute;
  content: "";
  margin: auto;
  left: 0;
  right: 0;
  z-index: -1;
  height: 1.6rem;
  max-width: calc(100% - 2rem);
}
.heroine h1:before, #headtxt h1:before {
  top: 0.25rem;
  transform: rotate(-2.5deg) skew(-20deg);
  background: linear-gradient(90deg, rgba(236, 59, 87, 0.8) 0%, rgba(236, 59, 87, 0.8) 100%);
}
.heroine h1:after, #headtxt h1:after {
  top: 0.5rem;
  transform: translate(0.5rem, 0) rotate(-2.5deg) skew(-20deg);
  background: linear-gradient(90deg, rgba(224, 105, 39, 0.8) 0%, rgba(224, 105, 39, 0.8) 100%);
}

/* Font formats for form inputs
-------------------------------------------------- */
textarea,
input[type=search],
input[type=tel],
input[type=text],
input[type=email] {
  text-align: left;
  font-family: "INVISION";
  font-size: 1rem;
}

h1,
h2,
h3,
h4 {
  font-weight: bold;
  margin-bottom: 0.5em;
  letter-spacing: 0.05em;
  hyphens: auto;
  word-wrap: break-word;
  font-family: "INVISION";
}
h1 a,
h2 a,
h3 a,
h4 a {
  color: inherit;
  border: 0 !important;
}

h1 {
  letter-spacing: -1px;
  text-transform: uppercase;
  font-size: 1.8rem;
  line-height: 1.8rem;
}

h2 {
  font-size: 1.4rem;
  line-height: 1.4rem;
}

h3 {
  font-size: 1.2rem;
  line-height: 1.2rem;
}

h4 {
  font-size: 1rem;
  line-height: 1rem;
}

#headtxt h1 {
  text-align: center;
}

.page-title {
  text-align: center;
  margin: 0;
}

strong {
  font-weight: bold;
}

.text p,
.text ul,
.text ol {
  text-align: justify;
  font-size: 1rem;
  line-height: 1.25rem;
  padding-bottom: 1rem;
}
.text p strong,
.text ul strong,
.text ol strong {
  font-weight: bold;
}
.text p a,
.text ul a,
.text ol a {
  border-bottom: 2px solid rgba(224, 105, 39, 0.5);
}
.text p a:hover,
.text ul a:hover,
.text ol a:hover {
  border-bottom: 2px solid #e06927;
}
.text p a.anchor,
.text ul a.anchor,
.text ol a.anchor {
  display: block;
  position: relative;
  top: -10rem;
  visibility: hidden;
}
p {
  hyphens: auto;
}

.heroine p:first-of-type, .text blockquote, .text blockquote p {
  color: black;
  background: transparent;
  text-transform: lowercase;
  letter-spacing: -1px;
  font-size: 2.25rem;
  line-height: 100%;
  text-align: center;
  hyphens: none;
}

/* Links
-------------------------------------------------- */
a {
  color: #000;
  text-decoration: none;
  transition: color 0.3s, background 0.3s, border 0.3s;
}
a:hover {
  color: #e06927;
}

/* Site
-------------------------------------------------- */
html {
  font-family: "INVISION", Helvetica Neue LT Std, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif;
  font-weight: 100;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  position: relative;
  min-height: 100%;
  font-size: 16px;
}
@media screen and (max-width: 68em) {
  html {
    font-size: 12px;
  }
}

body {
  font-size: 100%;
  line-height: 1rem;
  color: #000;
}

form,
nav,
p,
figure,
ul,
ol,
img {
  margin: 0 auto;
}

/* Selections
-------------------------------------------------- */
::-moz-selection {
  color: white;
  background: #000;
}

::selection {
  color: white;
  background: #000;
}

/* Visually hidden [vh]
-------------------------------------------------- */
.vh {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.centered {
  text-align: center !important;
}

/* Header
-------------------------------------------------- */
.header {
  z-index: 50;
  width: 100%;
  top: 0;
  left: 0;
  padding: 2rem 1rem 0 1rem;
}

#headtxt {
  position: relative;
  padding-bottom: 2rem;
}
#headtxt h1 {
  transition: color 0.3s cubic-bezier(0.17, 0.67, 0.83, 0.67);
  line-height: 3rem;
  margin: 0 auto;
  text-transform: lowercase;
  font-weight: 900;
  letter-spacing: -1px;
  font-size: 2.25rem;
  max-width: calc(100vw - 2rem);
}
#headtxt h1:before, #headtxt h1:after {
  height: 1.8rem;
  width: 60rem;
  max-width: calc(100vw - 2rem);
}
#headtxt h1:before {
  top: 0.75rem;
  transform: rotate(-1.75deg) skew(-20deg);
  background: linear-gradient(90deg, rgba(236, 59, 87, 0.8) 0%, rgba(236, 59, 87, 0.8) 100%);
}
#headtxt h1:after {
  top: 1.3157894737rem;
  transform: translate(0.5rem, 0) rotate(-1.75deg) skew(-20deg);
}
@media screen and (max-width: 68em) {
  #headtxt h1 {
    font-size: 1.2rem;
    word-wrap: break-word;
  }
  #headtxt h1:before, #headtxt h1:after {
    height: 0.96rem;
  }
}
#headtxt h1.secondary-subtitle:before, #headtxt h1.secondary-subtitle:after {
  width: 20rem;
}
#headtxt a {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

@media screen and (min-width: 69em) and (orientation: landscape) {
  #menu-toggle {
    display: none;
  }
}
/* @extend font style for navigation styled items
-------------------------------------------------- */
.menu--primary a:hover .svg-button,
section header time:hover .svg-button,
article header time:hover .svg-button,
article header div a:hover .svg-button,
.readmore:hover .svg-button,
.reading:hover .svg-button,
#main .breadcrumbs a:hover .svg-button,
#main .breadcrumbs p:hover .svg-button,
#main .breadcrumbs h6:hover .svg-button {
  fill: #e06927;
}

.breadcrumbs {
  max-width: calc(100vw - 2rem);
  width: 100%;
  background: black;
  text-align: center;
  padding-top: 0.75rem;
}
.breadcrumbs * {
  color: white;
}
.breadcrumbs a:not(:first-of-type):before,
.breadcrumbs p:before {
  content: " ▸ ";
}
@media screen and (max-width: 68em) {
  .breadcrumbs {
    text-align: center;
  }
}
.breadcrumbs p,
.breadcrumbs h6 {
  font-weight: normal;
  display: inline;
}

/* Header accesibility links
-------------------------------------------------- */
#headskip {
  position: absolute;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  justify-content: space-between;
}
#headskip a {
  font-size: 1rem;
  padding: 0.5rem;
  letter-spacing: 0.05em;
}

/* <NAV> wrapper + styles for all HEADER MENUS
-------------------------------------------------- */
.menu ul {
  list-style: none;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .menu--primary {
    width: 60rem;
    max-width: calc(100vw - 2rem);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 1rem;
  }
}
.menu--primary a {
  transition: box-shadow 0.3s ease-out;
  box-shadow: 3px 3px 0 0 grey;
  background: black;
  color: white;
  line-height: 2.25rem;
  display: block;
  padding: 0.25rem 0.5rem;
}
.menu--primary > li {
  min-width: calc(24% - 0.75rem);
}
.menu--primary > li + li {
  margin-left: 1rem;
}
.menu--primary > li:nth-of-type(4n) {
  break-after: always;
}
.menu--primary > li.hassubmenu {
  position: relative;
  margin: 0 0.5rem 1rem;
}
.menu--primary > li:focus .menu--primary__submenu, .menu--primary > li:hover .menu--primary__submenu {
  visibility: visible;
  opacity: 1;
  will-change: visibility, opacity, transform;
}
.menu--primary .active > a,
.menu--primary a:focus,
.menu--primary a:hover {
  background: black;
  color: #e06927;
  box-shadow: 3px 3px 0 0 #e06927;
}
.menu--primary__submenu li {
  margin-top: 0.5rem;
}
.menu--primary__submenu li + li {
  margin-left: 0 !important;
}
.menu--primary__submenu a {
  font-size: 0.75rem;
  padding: 0 0.5rem;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .menu--primary__submenu {
    min-width: 100%;
    z-index: 5000;
    position: absolute;
    opacity: 0;
    visibility: hidden;
    transform-origin: top;
    transition: 0.3s ease-out;
  }
}
.menu--secondary {
  z-index: 9999;
  position: absolute;
  top: 2rem;
  right: 2rem;
}
.menu--secondary ul {
  display: flex;
}
.menu--secondary ul li + li {
  margin-left: 1rem;
}
.menu--secondary ul li:not(.active) {
  filter: grayscale(100%);
}
.menu--footer {
  flex-wrap: wrap;
}
@media screen and (max-width: 68em) {
  .menu--footer a {
    width: 100%;
    text-align: center;
  }
  .menu--footer a + a {
    margin-top: 1rem;
  }
}

@media screen and (min-width: 69em) and (orientation: landscape) {
  #navbarlabel {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }
}
#menu-toggle {
  position: absolute;
  top: -9999px;
  left: -9999px;
}

@media screen and (max-width: 68em) {
  .mobile-hide,
.secondary-navigation {
    display: none;
  }

  #menu-toggle:checked ~ #primary-navigation {
    transform: translateX(0) !important;
    opacity: 1;
  }

  #menu-toggle:checked ~ #navbarlabel {
    color: #e06927;
  }

  #navbarlabel {
    transition: 0.3s ease-out;
    z-index: 5000;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2.75rem;
    line-height: 2.75rem;
    text-align: center;
    background: #e06927 url("../images/mobile.min.svg") no-repeat center center;
    cursor: pointer;
    user-select: none;
    font-size: 1rem;
  }

  #primary-navigation {
    background: url("../images/pattern5.jpg") fixed white;
    max-width: 100vw !important;
    z-index: 4999;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow-y: scroll;
    padding: 3.75rem 1rem 1rem 1rem;
    margin: 0;
    transform: translate(-100vw);
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
  }
  #primary-navigation ul {
    width: 100%;
    display: block;
    padding-bottom: 1rem;
    list-style-type: none;
  }
  #primary-navigation li {
    max-width: 100%;
    hyphens: auto;
    margin: 0;
    display: block;
  }
  #primary-navigation a {
    display: block;
    padding: 0;
    padding-top: 5px;
    transition: all 0.4s ease-in-out;
  }
  #primary-navigation a:hover {
    transition: all 0.4s ease-in-out;
    text-decoration: none;
    color: black;
  }
  #primary-navigation a:active {
    transition: all 0.4s ease-in-out;
    text-decoration: none;
    color: #e06927;
  }
  #primary-navigation a:focus {
    transition: all 0.4s ease-in-out;
    text-decoration: none;
    color: black;
  }
}
@media screen and (max-width: 68em) {
  .menu--primary {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .menu--primary li a {
    text-align: center;
  }
}
.widget {
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  text-align: center;
}

.main {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: space-between;
  padding: 1rem;
}
.main .text {
  position: relative;
  padding: 1rem;
  flex: 1 1 auto;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .main .text {
    width: 40%;
    width: 33%;
    transition: transform 0.3s ease-out, box-shadow 0.3s ease-out, background 0.3s ease-out;
  }
  .main .text img {
    filter: brightness(80%);
    overflow: hidden;
  }
  .main .text:hover {
    background: #fff;
  }
  .main .text:hover img {
    filter: brightness(100%);
  }
}
.main .text header {
  padding-top: 1rem;
}
.main .text h2 {
  text-align: center;
  text-transform: uppercase;
  letter-spacing: -1px;
}
.main .text h2:before, .main .text h2:after {
  width: 75%;
  right: 0;
}
.main .absolute-link {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.nextprev,
.blognav > div {
  flex-direction: row;
  justify-content: space-between;
}

.downloads ul {
  list-style: none;
}

.feed-footer {
  width: 100%;
}

/*
 :::  Forms
-------------------------------------------------- */
input,
label,
button,
fieldset,
textarea {
  display: inline-block;
}

input,
button,
.button,
textarea {
  transition: 0.3s ease-out;
  padding: 0.25rem;
}

button,
.button,
textarea {
  appearance: none;
}

input[type=radio] {
  appearance: radio;
}

input[type=checkbox] {
  appearance: checkbox;
}

label,
.label {
  font-family: "INVISION";
}

textarea {
  overflow: auto;
  resize: none;
  height: 25vh;
}

.options label {
  padding: 0 !important;
}

button,
.button, .menu--secondary ul li a {
  background: rgba(236, 59, 87, 0.8);
  border: 1px solid #ec3b57;
  box-shadow: 3px 3px 0 0 rgba(236, 59, 87, 0.5);
  color: rgba(0, 0, 0, 0.75);
  display: inline-block;
  padding: 0 1rem;
  margin: 0 auto;
  margin-top: 1rem;
}
button:focus,
.button:focus, .menu--secondary ul li a:focus, button:active,
.button:active, .menu--secondary ul li a:active, button:hover,
.button:hover, .menu--secondary ul li a:hover {
  color: white;
  cursor: pointer;
  background: rgba(236, 59, 87, 0.5);
}

.button-wrapper {
  display: flex;
  margin-top: 1rem;
}
.button-wrapper .button {
  min-width: 50%;
}
.button + .button {
  margin-left: 1rem;
}
.button .svg-button {
  width: 1rem;
  margin-bottom: 0.25rem;
  fill: rgba(224, 105, 39, 0.5);
}
.button--huge, .nextprev .button {
  padding: 1rem 1.5rem;
  font-size: 1.5rem;
  text-transform: lowercase;
}
@media screen and (max-width: 68em) {
  .button--huge, .nextprev .button {
    padding: 0.5rem 0.75rem;
    font-size: 1.25rem;
  }
}
.button--reset {
  box-shadow: 3px 3px 0 0 rgba(238, 95, 100, 0.5);
}
.button--reset:hover, .button--reset:focus {
  border-color: #ee5f64;
  background: #ee5f64;
}
.button--ok {
  box-shadow: 3px 3px 0 0 rgba(133, 191, 49, 0.5);
}
.button--ok:hover, .button--ok:focus {
  border-color: #85bf31;
  background: #85bf31;
}

.readmore {
  min-width: 50%;
}

textarea,
input[type=search],
input[type=tel],
input[type=text],
input[type=email] {
  border: 1px solid;
  box-shadow: 5px 5px 0 0 rgba(224, 105, 39, 0.2);
  color: black;
  border-color: rgba(224, 105, 39, 0.5);
  background: rgba(255, 255, 255, 0.5);
}
textarea:required,
input[type=search]:required,
input[type=tel]:required,
input[type=text]:required,
input[type=email]:required {
  border-right: 5px solid #ee5f64;
}
textarea:required:valid,
input[type=search]:required:valid,
input[type=tel]:required:valid,
input[type=text]:required:valid,
input[type=email]:required:valid {
  border-right-color: #85bf31;
  background: rgba(128, 128, 128, 0.5);
}
textarea:focus:invalid,
input[type=search]:focus:invalid,
input[type=tel]:focus:invalid,
input[type=text]:focus:invalid,
input[type=email]:focus:invalid {
  background: rgba(238, 95, 100, 0.5);
}
textarea:focus:valid,
input[type=search]:focus:valid,
input[type=tel]:focus:valid,
input[type=text]:focus:valid,
input[type=email]:focus:valid {
  background: rgba(133, 191, 49, 0.5);
}
textarea:focus, textarea:hover,
input[type=search]:focus,
input[type=search]:hover,
input[type=tel]:focus,
input[type=tel]:hover,
input[type=text]:focus,
input[type=text]:hover,
input[type=email]:focus,
input[type=email]:hover {
  color: white;
  border-color: #e06927;
  background: #e06927;
  border-right-width: 1px;
}

/*
 :::  Forms
-------------------------------------------------- */
.form {
  padding: 1rem;
  text-align: center;
}
.form .full,
.form textarea {
  width: 100%;
}
.form .full h4 {
  margin-bottom: 0;
  text-align: left;
}
.form .label a {
  border-bottom: 2px solid #e06927;
}
.form select {
  max-width: 100%;
}

.contact button,
.contact input[type=text],
.contact input[type=email],
.contact input[type=tel],
.contact label,
.contact textarea {
  margin-top: 1rem;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .contact button,
.contact input[type=text],
.contact input[type=email],
.contact input[type=tel],
.contact label,
.contact textarea {
    width: 80%;
  }
}
@media screen and (max-width: 68em) {
  .contact button,
.contact input[type=text],
.contact input[type=email],
.contact input[type=tel],
.contact label,
.contact textarea {
    width: 100%;
  }
}

@media screen and (max-width: 68em) {
  .form-register button,
.form-register label,
.form-register fieldset {
    width: 100%;
  }
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .form-register button,
.form-register label,
.form-register fieldset {
    width: 49%;
  }
}
.form-register .label,
.form-register label {
  padding: 1rem;
}
.form-register input[type=text],
.form-register input[type=tel],
.form-register input[type=email] {
  width: 100%;
}
.form-register label[for=anmerkungen] {
  width: 100%;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .form-register .label > .options {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .form-register .label > .options label {
    width: 20%;
  }
}

.uniform-sucess, .uniform-errors {
  position: fixed !important;
  top: 50vh;
  width: 10rem;
  left: calc(50vw - 5rem);
  padding: 1rem !important;
  z-index: 1000;
  max-width: 100vw;
  max-height: 100vh;
  box-shadow: 5px 5px 0 0 rgba(224, 105, 39, 0.2);
}
.uniform-sucess {
  background: #ec3b57;
}
.uniform-errors {
  background: #e06927;
}

/*
 :::  Search
-------------------------------------------------- */
.search {
  display: block;
  width: 50%;
  min-width: 20em;
  max-width: 100vw;
}
.search input {
  width: 100%;
  display: block;
}

/*
 :::  Results
-------------------------------------------------- */
/*
 :::  Results' heading
-------------------------------------------------- */
.result mark {
  background: inherit;
  color: inherit;
}

/* Uniform
-------------------------------------------------- */
.uniform__potty {
  position: absolute;
  top: -9999px;
  left: -9999px;
}

.kidsgroup label {
  font-size: 0.75rem;
}
.kidsgroup__kid {
  display: flex;
}
.kidsgroup__kid__set {
  display: flex;
  flex-wrap: wrap;
}
.kidsgroup__kid__set__label {
  width: 100%;
}

.radio-button:checked + .radio-button-label {
  background: #85bf31;
  background: #e06927;
  box-shadow: 3px 3px 0 0 rgba(224, 105, 39, 0.5);
}

.form--section {
  background: rgba(255, 255, 255, 0.5);
  padding: 1rem;
  margin-top: 1rem;
  box-shadow: 3px 3px 0 0 rgba(128, 128, 128, 0.5);
  border: 1px solid rgba(128, 128, 128, 0.5);
}

.fieldset-flex {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .fieldset--buttons--many .radio-button-label {
    max-width: 15%;
  }
  .fieldset--buttons--four .radio-button-label {
    max-width: 19%;
  }
}

.radio-button-label {
  color: white;
  min-width: 10rem;
  max-width: 25%;
  min-height: 5rem;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  border: none;
  flex-grow: 0;
  background: grey;
  box-shadow: 3px 3px 0 0 rgba(128, 128, 128, 0.5);
}
.radio-button-label + .radio-button {
  margin-left: 1rem;
}
.radio-button-label span {
  display: block;
  width: 100%;
  font-weight: 100;
}
.radio-button-label span:first-of-type {
  text-transform: none;
  font-weight: bold;
  hyphens: auto;
}
.radio-button-label span + span {
  border-top: 2px solid white;
  padding-top: 1rem;
  margin-top: 1rem;
}

#helper_form {
  align-items: center;
}

.helper_services {
  text-align: right;
  margin-right: 2rem;
}

.helper_services + select.service-motivation {
  max-height: 1.5rem;
  align-items: center;
}

.helper_comment {
  width: 100%;
}

.custom_solifond {
  max-width: 50%;
}

.security-check {
  border: 2px solid #b229a1;
  color: #b229a1;
}

.security-check label {
  width: auto;
}

.security-check input {
  border: 1px solid #b229a1;
}

@media only screen and (max-width: 69em) {
  .helper_services {
    text-align: left;
  }
}
.transportation-button-labels {
  max-width: 24%;
}

.options_kid {
  margin: 0 auto;
}
.options_kid select {
  width: 100%;
}

@media only screen and (max-width: 69em) {
  .options_kid select {
    font-size: 0.75rem;
  }
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .form-register .label-languages {
    display: flex;
    width: 100%;
  }

  .sign-language-flexbox label {
    width: 32%;
  }
}
/* Project meta
-------------------------------------------------- */
.meta {
  margin-bottom: 1.5em;
}
.meta li {
  float: left;
  list-style: none;
  margin-right: 2em;
  color: #e06927;
}
.meta li b {
  font-weight: 400;
  color: #000;
  padding-right: 0.25em;
}

/* Project teaser
-------------------------------------------------- */
.teaser {
  list-style: none;
}
.teaser li {
  margin-bottom: 1.5em;
  list-style: none;
}

@media screen and (min-width: 50em) {
  .teaser li {
    float: left;
    width: 30%;
    margin-left: 5%;
  }

  .teaser li:first-child {
    margin-left: 0;
  }
}
/* Next/Prev nav
-------------------------------------------------- */
.nextprev {
  padding: 1rem;
}
.nextprev .button {
  border: 0;
  width: calc(50% - 1rem);
}

/* main Formats
-------------------------------------------------- */
#main {
  z-index: 10;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.8);
  border: 0;
  width: 60rem;
  max-width: calc(100vw - 2rem);
}

.content {
  padding: 2rem;
}
.content p:last-of-type {
  padding-bottom: 0;
}

.page-header,
.text header h1 {
  background: black;
  color: white;
  padding: 1rem;
  font-size: 4rem;
  line-height: 4rem;
  font-style: italic;
}

.text {
  margin-top: 2rem;
}
.text ul,
.text ol {
  padding-left: 1rem;
}
.text .banner img {
  width: 225px !important;
  border: none;
}
.text .video {
  display: inline-block;
  border: 1px solid rgba(224, 105, 39, 0.5);
}
.text .video {
  width: 100%;
  max-width: calc(100vw - 2rem) !important;
  height: 40rem !important;
}
.text .video iframe {
  width: 100%;
  height: 100%;
}
.text figure {
  display: inline-block;
  height: 30rem;
}
.text figure:not(.video) {
  overflow: hidden;
}
.text figure img {
  object-fit: cover;
}
.text .gallery {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
}
.text .gallery img {
  flex-shrink: 2;
  border: none;
  width: 30rem !important;
}

/* article Formats
-------------------------------------------------- */
article.text {
  padding-bottom: 2rem;
}
article.text header h2 {
  overflow: hidden;
  text-overflow: ellipsis;
}
article.text header div {
  margin: 0 auto;
  text-align: center;
}

/* All of the above
-------------------------------------------------- */
@media screen and (max-width: 68em) {
  .widget h1,
.widget h2,
.widget h3,
.text h1,
.text h2,
.text h3 {
    word-wrap: break-word;
  }
  .widget h3,
.text h3 {
    text-align: center;
  }
}
.widget h1:before, .widget h1:after,
.text h1:before,
.text h1:after {
  width: 75%;
  height: 1.35rem;
}
.widget h2:before, .widget h2:after,
.text h2:before,
.text h2:after {
  width: 50%;
  height: 0.84rem;
}
.widget header,
.text header {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: 0 auto;
}
.widget header h2,
.text header h2 {
  margin-top: 1rem;
  margin-bottom: 1rem;
}
.widget header div a svg,
.text header div a svg {
  height: 1rem;
  width: 1rem;
  display: inline-block;
}
.widget header div a:hover .svg-tag, .widget header div a:active .svg-tag, .widget header div a:focus .svg-tag,
.text header div a:hover .svg-tag,
.text header div a:active .svg-tag,
.text header div a:focus .svg-tag {
  fill: #e06927;
  stroke: #e06927;
}

/* FAQ Templates
-------------------------------------------------- */
/* Footer
-------------------------------------------------- */
.footer {
  left: 0;
  bottom: 0;
  min-height: 25vw;
  width: 100%;
}

.footer {
  margin: 2rem 0;
}
.footer .widget {
  width: 60rem;
  max-width: calc(100vw - 2rem);
  background: black;
}
.footer p {
  margin-bottom: 0.5rem;
}
.footer a:focus, .footer a:hover {
  color: #ec3b57;
}
.footer p,
.footer a {
  color: white;
}
.footer svg {
  fill: white;
  box-shadow: 3px 3px 0 0 rgba(255, 255, 255, 0.2);
  margin-bottom: 3px;
}
.footer svg:focus, .footer svg:hover {
  fill: #ec3b57;
}
.footer nav {
  display: flex;
  justify-content: center;
  margin: 1rem;
}
.footer nav a {
  margin-right: 0.3rem;
  margin-left: 0.3rem;
}
.footer form {
  margin-top: 0.5rem;
  margin-bottom: 0.7rem;
}
.footer form input[type=search] {
  border-color: white;
  background: rgba(255, 255, 255, 0.5);
  box-shadow: 4px 4px 0 0 rgba(255, 255, 255, 0.2);
  opacity: 1;
}
.footer form input[type=search]::-webkit-input-placeholder {
  color: rgba(224, 105, 39, 0.5);
  opacity: 1;
}
.footer form input[type=search]:-ms-input-placeholder {
  color: rgba(224, 105, 39, 0.5);
  opacity: 1;
}
.footer form input[type=search]:-moz-placeholder {
  color: rgba(224, 105, 39, 0.5);
  opacity: 1;
}
.footer form input[type=search]::-moz-placeholder {
  color: rgba(224, 105, 39, 0.5);
  opacity: 1;
}
.footer form input[type=search]:focus, .footer form input[type=search]:hover {
  color: white;
  border-color: white;
  background: #ec3b57;
}
.footer form input[type=search]:focus::-webkit-input-placeholder, .footer form input[type=search]:hover::-webkit-input-placeholder {
  color: white;
  opacity: 1;
}
.footer form input[type=search]:focus:-ms-input-placeholder, .footer form input[type=search]:hover:-ms-input-placeholder {
  color: white;
  opacity: 1;
}
.footer form input[type=search]:focus:-moz-placeholder, .footer form input[type=search]:hover:-moz-placeholder {
  color: white;
  opacity: 1;
}
.footer form input[type=search]:focus::-moz-placeholder, .footer form input[type=search]:hover::-moz-placeholder {
  color: white;
  opacity: 1;
}

/* Gallery
-------------------------------------------------- */
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
#overlay {
  z-index: 100;
}

#overlay,
#overlay #zoom {
  display: none;
}

#zoom {
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.activated {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.9);
  animation: fadein 1s;
}
.activated #zoom {
  transition: opacity 1s ease-in-out;
  height: 60vh;
  transition: 0.3s ease-out !important;
  transition: opacity 1s ease-in-out;
}
.activated button {
  position: fixed;
}
.activated button.close {
  top: 0;
  right: 0;
}
.activated button.prev, .activated button.next {
  top: 50%;
}
.activated button.prev {
  left: 0;
}
.activated button.next {
  right: 0;
}
.activated .gallery-text-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.activated .gallery-text-wrapper:first-of-type {
  height: 15vh;
}
.activated .gallery-text-wrapper:last-of-type {
  height: 25vh;
}
.activated .gallery-title,
.activated .gallery-caption {
  background: rgba(255, 255, 255, 0.9);
  padding: 1rem;
}

.activated,
.activated #zoom {
  display: block !important;
}

.fadeout {
  opacity: 0;
}

.noscroll {
  overflow: hidden;
}

/* Icons
-------------------------------------------------- */
#main .img-dgs {
  display: inline;
  width: auto !important;
  height: 2.5rem !important;
  border: none !important;
  margin-bottom: -1rem;
}

svg {
  transition: fill 0.3s ease-out;
  display: inline-block;
  vertical-align: middle;
}

.headlogo {
  display: block;
  margin: 0 auto;
  width: 70rem;
  max-width: calc(100vw - 2rem);
  fill: rgba(224, 105, 39, 0.5);
}

#headtxt:hover .headlogo {
  fill: rgba(236, 59, 87, 0.5);
}

.blognav svg {
  margin-right: 0.3rem;
  margin-left: 0.3rem;
  box-shadow: 3px 3px 0 0 rgba(224, 105, 39, 0.2);
}

.svg-social {
  width: 2rem;
}
.svg-social:hover, .svg-social:active, .svg-social:focus {
  fill: #e06927;
}
.svg-supporter {
  box-shadow: none !important;
}

.utmost-importances svg {
  max-height: 4rem;
  margin: 2rem;
}

.heroine {
  text-align: center;
  margin: 1rem;
  background-size: cover;
  background-repeat: no-repeat;
}
.heroine h1:before, .heroine h1:after {
  max-width: 55%;
}
.heroine img {
  background-color: transparent;
}
.heroine .video {
  width: 100%;
  max-width: 100%;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .heroine .video {
    height: 30rem !important;
  }
}
@media screen and (max-width: 68em) {
  .heroine .video {
    height: auto;
  }
}
.heroine .video iframe {
  width: 100%;
  height: 100%;
}
.heroine .video + h1 {
  margin-top: 2rem;
}
.heroine p {
  line-height: 2.25rem;
}
@media screen and (min-width: 69em) and (orientation: landscape) {
  .heroine p:first-of-type {
    padding: 1rem 4rem;
  }
}
.heroine p + h1 {
  margin-top: 2rem;
}

.tag {
  display: block;
  padding: 0.1rem 0.5rem;
  background: black;
  color: white;
}
.tag + .tag {
  margin-top: 0.5rem;
}
.tag:before {
  content: "#";
}
.tag__invision2019 {
  background: #e06927;
}
.tag:last-of-type {
  margin-bottom: 1rem;
}

.blog .text a.button,
.widget .text a.button {
  display: block;
  border: none;
}

/*# sourceMappingURL=style.min.css.map */
