/* ### REACTIVE SIZINGS ### */

:root {
  /* optimized for 1920x1080 (large desktop) */
  /* optimized for 1440x900 (average desktop) */
  /* optimized for 1366x768 (average laptop) */

  --header-height: 100px;
  --footer-height: 62px;
  --wrapper-width: 1240px;
  --section-spacing: 40px;
  --nav-spacing: 10px;
  --text-spacing-large: 20px;
  --menu-hpad: 28px;
  --menu-vpad: 34px;
  --font-size-normal: 18px;
  --font-size-large: 24px;
  --font-size-x-large: 30px;
  --font-size-small: 15px;
  --font-size-x-small: 13px;
}

@media only screen and (max-width: 1365px) {
  /* optimized for 1280x720 (desktop or laptop) */

  :root {
    --header-height: 80px;
    --nav-spacing: 7px;
    --menu-hpad: 22px;
    --menu-vpad: 26px;
  }
}

@media only screen and (max-width: 1279px) {
  /* optimized for 1200x690 (small desktop or laptop) */

  :root {
    --wrapper-width: 1100px;
    --menu-vpad: 27px;
    --font-size-normal: 16px;
    --font-size-large: 22px;
    --font-size-x-large: 26px;
    --font-size-small: 13px;
    --font-size-x-small: 11px;
  }
}

@media only screen and (max-width: 1119px) {
  /* optimized for 1024x768 (small desktop or laptop) */

  :root {
    --wrapper-width: 1000px;
    --font-size-normal: 14px;
    --font-size-large: 20px;
    --font-size-x-large: 23px;
    --font-size-small: 12px;
    --font-size-x-small: 10px;
    --box-5col-width: 25.00%;
  }
}

@media only screen and (max-width: 1023px) {
  /* optimized for 720x1280 (large mobile) */
  /* optimized for 640x360 (small mobile) */

  :root {
    --header-height: 60px;
    --menu-hpad: 12px;
    --menu-vpad: 16px;
    --box-3col-width: 50.00%;
    --box-5col-width: 33.33%;
  }
}

@media only screen and (max-width: 799px) {
  :root {
    --box-4col-width: 40.00%;
  }
}

@media only screen and (max-width: 639px) {}

@media only screen and (max-width: 599px) {
  :root {
    --box-5col-width: 50.00%;
  }
}

@media only screen and (max-width: 579px) {}

@media only screen and (max-width: 539px) {}

@media only screen and (max-width: 479px) {
  /* optimized for 375x667 (average mobile) */
  /* optimized for 360x640 (small mobile) */

  :root {
    --section-spacing: 20px;
    --font-size-normal: 16px;
    --font-size-small: 14px;
    --font-size-x-small: 14px;
    --box-2col-width: 100.00%;
    --box-3col-width: 100.00%;
    --box-4col-width: 50.00%;
  }
}


/* ### PAGE DEFAULTS ### */

html, body, input, textarea, select {
  font-size: var(--font-size-normal);
}

.button-wrapper {
  display: flex;
}

.clear {
  clear: both;
}

.word-wrap p {
  hyphens: auto;
  word-break: break-word;
}

.photo img,
.video img {
  box-shadow: 3px 2px 5px rgba(0, 0, 0, 0.2);
}

.photo img {
  background-color: white;
  border: #ddd solid 1px;
  object-fit: cover;
  padding: 3px;
}

[itemprop="articleBody"]::after {
  clear: both;
  content: " ";
  display: block;
}

@media only screen and (max-width: 799px) {
  img.pull-left,
  img.pull-right {
    display: block;
    float: none;
    margin: 0 auto 20px;
  }
}

p.published {
  color: var(--f4k-grey-dark);
  font-size: var(--font-size-small);
  margin-bottom: var(--text-spacing-large);
}

p.space {
  margin-bottom: var(--text-spacing-large);
}

small {
  font-size: var(--font-size-small);
}


/* ### COOKIE CONSENT ### */

#macc-decline {
  border-color: #999 !important;
  color: #666 !important;
  font-size: 0.8em !important;
}


/* ### ANCHORS ### */

a.anchor {
  display: block;
  position: relative;
  top: calc(0px - var(--header-height) - var(--text-spacing-large));
  visibility: hidden;
}


/* ### SYSTEM MESSAGES ### */

.message-section .content-wrapper {
  margin-bottom: 0;
}

.message-section .alert {
  background-color: #fffdd0;
  box-shadow: 0 0 10px #888770;
  padding: 10px;
  position: relative;
}

.message-section .alert * {
  color: #888770;
  margin: 0;
}

.message-section .alert .alert-heading {
  font-weight: bold;
}


/* ### SPEECH BUBBLES ### */

blockquote {
  background: transparent url(/assets/quote/quote.png) left 4px no-repeat;
  margin: 0;
  padding-left: 30px;
}

blockquote cite {
  font-size: var(--font-size-small);
  font-style: normal;
}

@media only screen and (min-width: 1024px) {
  blockquote cite {
    font-size: 15px !important;
  }
  blockquote cite:before {
    content: ' - ';
  }
}

blockquote p {
  color: var(--f4k-black);
  font-style: oblique;
}

@media only screen and (min-width: 1024px) {
  blockquote p {
    font-size: 18px !important;
    line-height: 1.5em !important;
  }
}

blockquote.bubble cite {
  color: var(--f4k-grey-dark);
}

@media only screen and (min-width: 1024px) {
  blockquote.bubble {
    background-position: 20px 24px;
    padding: 0;
    position: relative;
  }

  blockquote.bubble p {
    background: transparent url(/assets/quote/bubble-left.png) left top no-repeat;
    height: 222px;
    margin: 0;
    padding: 20px 70px 20px 50px;
    position: relative;
    width: 767px;
  }

  blockquote.bubble cite {
    bottom: 20px ;
    display: inline-block;
    position: absolute;
    right: 70px ;
  }

  blockquote.bubble img {
    height: 222px;
    left: 775px;
    position: absolute;
  }

  blockquote.bubble.right {
    background-position: 270px 24px;
  }

  blockquote.bubble.right p {
    background: transparent url(/assets/quote/bubble-right.png) right top no-repeat;
    left: 200px;
    padding: 20px 20px 20px 100px;
  }

  blockquote.bubble.right cite {
    left: unset;
    right: 20px;
  }

  blockquote.bubble.right img {
    left: 0;
  }
}


/* ### SECTION DEFAULTS ### */

section {
  background-position: calc(50% + 150px) bottom;
  background-repeat: no-repeat;
  padding: var(--section-spacing) 0;
}

section.filled {
  padding: 0;
}

section.blue {
  background-color: var(--f4k-blue);
}

section.grey {
  background-color: var(--f4k-grey-light);
}


/* ### FORMULAR DEFAULTS ### */

form .control-group:not(:last-child) {
  margin-bottom: var(--text-spacing-large);
}

form .control-label {
  margin-bottom: 5px;
}

form .check,
form .gdpr {
  align-items: center;
  display: flex;
}

form .check .controls,
form .gdpr .controls {
  order: 1;
}

form .check .control-label,
form .gdpr .control-label {
  margin: 0;
  order: 2;
}

form .gdpr {
  margin-top: calc(2 * var(--text-spacing-large));
}

fieldset .checkboxes {
  display: block;
}

form.space {
  margin-bottom: var(--text-spacing-large);
}


/* ### MAIN CONTENT ### */

main {
  min-height: 100%;
  padding-top: var(--header-height);
  position: relative;
}

main.home .content-wrapper > h2,
main.home .content-wrapper h2.main {
  font-family: var(--font-family-highlight);
  font-size: 2rem;
  margin-bottom: 1em;
  text-align: center;
}


/* ### PAGE HEADER ### */

header {
  background-color: var(--f4k-white);
  height: var(--header-height);
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 99;
}
header::after {
  clear: both;
}

@media only screen and (max-width: 1023px) {
  header {
    background-color: var(--f4k-blue);
  }
}

header > * {
  height: 100%;
}

header .button-wrapper {
  float: right;
}

header .button {
  background-color: var(--f4k-white);
  border: none;
  border-radius: 0;
  color: var(--f4k-blue-dark);
  font-family: var(--font-family-headline);
  font-size: var(--font-size-large);
  height: var(--header-height);
  letter-spacing: 2px;
}

header .button:hover {
  background-color: var(--f4k-white);
  color: var(--f4k-green);
}


/* ### PAGE HEADER / TITLE ### */

#title {
  filter: drop-shadow(calc(var(--header-height) * .02) calc(var(--header-height) * .02) calc(var(--header-height) * .05) #bbb);
  float: left;
  overflow: hidden;
  position: relative;
}

@media only screen and (min-width: 1024px) {
  #title {
    background: linear-gradient(to right, transparent 0%, transparent 10%, var(--f4k-blue) 10%, var(--f4k-blue) 90%, transparent 90%, transparent 100%);
    filter: drop-shadow(calc(var(--header-height) * .02) calc(var(--header-height) * .02) calc(var(--header-height) * .05) #9bc);
  }
}

#title img {
  height: calc(var(--header-height) * .8);
  margin: calc(var(--header-height) * .1);
  width: calc(var(--header-height) * 2.54);
}

#title a {
  display: block;
  height: 100%;
}

#title span {
  bottom: 0;
  color: var(--f4k-white);
  font-family: var(--font-family-highlight);
  opacity: 80%;
  position: absolute;
  right: 11%;
}

@media only screen and (max-width: 1023px) {
  #title img {
    height: calc(var(--header-height) * .7);
    margin: calc(var(--header-height) * .15);
    width: calc(var(--header-height) * 2.4);
  }

  #title span {
    font-size: var(--font-size-small);
  }
}


/* ### PAGE HEADER / MENU ### */

#menu-toggle {
  background-color: var(--f4k-blue);
  display: none;
  width: 60px;
}
#menu-toggle::before {
  color: var(--f4k-white);
}

@media only screen and (min-width: 1120px) {
  #menu > ul > li {
    margin: 0 var(--nav-spacing);
  }
  #menu > ul > li:first-child {
    margin-left: calc(var(--nav-spacing) * 2);
  }
  #menu > ul > li:last-child {
    margin-right: calc(var(--nav-spacing) * 2);
  }

  #menu > ul > li .button {
    padding: var(--menu-vpad) calc(var(--menu-hpad) / 2);
  }

  #menu ul.nav-child {
    background-color: var(--f4k-white);
    display: none;
    filter: drop-shadow(calc(var(--header-height) * .01) calc(var(--header-height) * .02) calc(var(--header-height) * .02) #ccc);
    padding: 0 var(--nav-spacing) var(--nav-spacing);
    position: absolute;
    opacity: 95%;
  }

  #menu ul.nav-child > li a {
    display: inline-block;
    padding: var(--nav-spacing);
    padding-right: 50px;
    width: 100%;
  }

  #menu ul.nav-child .active > a {
    font-weight: bold;
  }

  #menu .open ul.nav-child {
    display: block;
  }
}

@media only screen and (max-width: 1119px) {
  #menu-toggle {
    display: inline-block;
  }

  #menu {
    display: none;
    position: absolute;
    right: 0;
    top: var(--header-height);
    width: 600px;
  }
  #menu.open {
    display: block;
  }

  #menu a {
    height: unset;
    margin: unset;
    padding: unset;
  }

  #menu a.button {
    padding-bottom: var(--nav-spacing);
  }

  #menu > ul {
    background-color: var(--f4k-white);
    filter: drop-shadow(calc(var(--header-height) * .01) calc(var(--header-height) * .02) calc(var(--header-height) * .02) #ccc);
    flex-wrap: wrap;
    max-height: 85vh;
    opacity: 95%;
    overflow: scroll;
    padding: calc(var(--nav-spacing) * 2);
    padding-bottom: 0;
  }

  #menu > ul > li {
    padding-bottom: calc(var(--nav-spacing) * 2);
    width: 250px;
  }

  #menu .current:not(.alias) > a {
    color: var(--f4k-green);
  }

  #menu ul.nav-child {
    display: block;
  }

  #menu ul.nav-child li a {
    display: block;
    padding: var(--nav-spacing);
    padding-left: 27px;
  }
}

@media only screen and (max-width: 599px) {
  #menu {
    width: 300px;
  }

  #menu > ul > li {
    width: 100%;
  }
}


/* ### PAGE HEADER / DONATE BUTTON ### */

@keyframes heartbeat {
  0% { transform: scale(1); }
  20% { transform: scale(1.2); } 
  40% { transform: scale(1.4); }
}

header .button.donate {
  margin: 0;
  padding: var(--menu-vpad) calc(var(--menu-hpad) + var(--nav-spacing));
  text-transform: uppercase;
}
header .button.donate::before {
  animation: heartbeat 5s linear infinite;
  display: inline-block;
  width: 20px;
}
header .button.donate:hover {
  color: red;
}

@media only screen and (max-width: 1023px) {
  header .button.donate {
    border: var(--f4k-white) solid 2px;
    height: calc(var(--header-height) - 6px);
    margin: 3px;
    padding: calc(var(--menu-vpad) - 2px) calc(var(--menu-hpad) + var(--nav-spacing));
  }

  header .button.donate::before {
    display: none;
  }
}


/* ### SUJET ### */

.sujet-section {
  padding: var(--section-spacing) 0;
}

.sujet-section h1 {
  color: var(--f4k-blue);
  font-size: 2.5rem;
  margin: 0;
}

@media only screen and (max-width: 599px) {
  .sujet-section h1 {
    font-size: 1.5rem;
  }
}


/* ### BREADCRUMBS ### */

nav.breadcrumb {
  font-size: var(--font-size-small);
}

nav.breadcrumb li:not(:last-child)::after {
  color: var(--f4k-green);
  content: "\ea1c";
  font-family: var(--font-family-symbols);
  font-size: 80%;
  font-style: normal;
  margin: 0 .8em;
}


/* ### PAGE CONTENT ### */

.content-section h2:not(:first-child),
.content-section .content-block:not(:first-child) {
  margin-top: calc(2 * var(--text-spacing-large));
}

.content-section p,
.content-section li {
  line-height: 1.5rem;
}


/* ### PAGE CONTACT ### */

#contact {
  background: var(--f4k-grey-light) left bottom no-repeat;
  background-size: contain;
  border: var(--f4k-grey-light) solid 5px;
  border-radius: 5px;
  display: inline-block;
  margin-top: var(--text-spacing-large);
  padding: 0 10px 0 100px;
}


/* ### ERROR PAGE ### */

section.error h2 {
  margin-top: 40px;
}

@media only screen and (max-width: 639px) {
  section.error {
    padding-top: 0;
  }

  section.error h2 {
    margin-top: 20px;
  }
}

section.error .button-wrapper {
  display: flex;
}

section.error .button {
  margin: 0 10px 10px 0;
  width: 130px;
  padding: 6px;
}

@media only screen and (max-width: 639px) {
  section.error .button-wrapper {
    flex-flow: wrap;
  }
}

@media only screen and (min-width: 1024px) {
  section.error .content-wrapper {
    background: transparent url(/assets/zoo/error.png) no-repeat right 60px bottom 5px;
    min-height: 375px;
  }
}


/* ### PAGE FOOTER ### */

footer {
  width: 100%;
}

#footer-top {
  background-image: linear-gradient(var(--f4k-grey) 0%, var(--f4k-white) 40px);
  padding: var(--section-spacing) 0;
}

#footer-top h2 {
  border-bottom: var(--f4k-grey) solid 1px;
  font-size: var(--font-size-x-large);
  margin-bottom: var(--box-spacing);
  padding-bottom: var(--box-spacing);
}

@media only screen and (max-width: 1279px) {
  #footer-top h2 {
    margin-bottom: calc(var(--box-spacing) * .66);
    padding-bottom: calc(var(--box-spacing) * .66);
  }
}

#footer-bottom {
  background-color: var(--f4k-blue-dark);
  padding: 20px 0;
}

#footer-bottom::after {
  clear: both;
}

#footer-bottom a,
#footer-bottom p {
  color: var(--f4k-white);
  margin: 0;
}

#footer-bottom nav a {
  font-weight: bold;
  padding: var(--nav-spacing);
}

#footer-bottom nav a:hover {
  color: var(--f4k-green-light);
}

@media only screen and (min-width: 580px) {
  #footer-bottom nav {
    float: right;
  }

  #footer-bottom nav li:not(:first-child)::before {
    background-color: var(--f4k-white);
    content: "";
    display: inline-block;
    height: var(--font-size-normal);
    margin: 0 var(--nav-spacing);
    opacity: 65%;
    position: relative;
    top: 2px;
    width: 1px;
  }

  #footer-bottom nav li:last-child a {
    padding-right: 0;
  }
}

@media only screen and (max-width: 579px) {
  #footer-bottom .content-wrapper {
    padding:0;
  }

  #footer-bottom nav ul {
    justify-content: center;
  }

  #footer-bottom nav li {
    margin-top: var(--nav-spacing);
    text-align: center;
  }
}


/* ### PAGE FOOTER / BOXES ### */

.box.footer {
  width: var(--box-3col-width);
}

@media only screen and (max-width: 1023px) {
  .box.footer.donate { order: 1 }
  .box.footer.follow { order: 2 }
  .box.footer.contact { order: 3 }
  .box.footer.newsletter { order: 4 }
  .box.footer.office-hours { order: 5 }
  .box.footer.navigation { order: 6 }
}

@media only screen and (max-width: 479px) {
  .box.footer.donate { order: 1 }
  .box.footer.follow { order: 2 }
  .box.footer.newsletter { order: 3 }
  .box.footer.navigation { order: 4 }
  .box.footer.contact { order: 5 }
  .box.footer.office-hours { order: 6 }
}


/* ### PAGE FOOTER / BOXES / DONATE BOX ### */

.box.footer.donate .button-wrapper {
  margin-top: 28px;
}

.box.footer.donate .seal {
  bottom: 12px;
  left: 190px;
  position: absolute;
}

.box.footer.donate .seal img {
  margin: 40px 30px 10px;
  opacity: 70%;
  transition-duration: var(--trans-hover-time);
  transition-property: margin, opacity, transform, width;
  transition-timing-function: var(--trans-hover-fnc);
  width: 120px;
}

.box.footer.donate .seal:hover img {
  margin: 0;
  opacity: 100%;
  transform: rotate(-2deg);
  width: 180px;
}

@media only screen and (max-width: 1279px) {
  .box.footer.donate .seal {
    bottom: 0;
    left: 160px;
   }

  .box.footer.donate .seal img {
    width: 100px;
  }

  .box.footer.donate .seal:hover img {
    width: 150px;
  }
}


/* ### PAGE FOOTER / BOXES / FOLLOW US ### */

.box.footer.follow li {
  margin-right: var(--text-spacing-large);
}

.box.footer.follow form {
  margin-top: 20px;
}

.box.footer.follow form input[type=text] {
  width: 200px;
}

.box.footer.follow form button[type=submit] {
  height: 68px;
  font-size: var(--font-size-normal);
  left: 210px;
  position: absolute;
  top: 0;
}


/* ### PAGE FOOTER / BOXES / NAVIGATION ### */

.box.footer.navigation li {
  margin-bottom: 10px;
}


/* ### PAGE FOOTER / BOXES / CONTACT ### */

p.icon-mail {
  margin-top: var(--text-spacing-large);
}

@media only screen and (max-width: 479px) {
  p.icon-mail {
    margin-top: 30px;
  }
}


/* ### PAGE FOOTER / BOXES / NEWSLETTER ### */

div.newsletter form {
  padding: 5px 115px 0 0;
  position: relative;
}

div.newsletter button {
  font-size: 0 !important;
  height: 90px;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  right: 15px;
  top: 5px;
  width: 90px;
}
div.newsletter button::before {
  background-image: url(/assets/icons/contact-white.png);
  background-position: 0 -64px;
  content: '';
  display: inline-block;
  height: 64px;
  padding: 0;
  width: 64px;
}

div.newsletter input {
  margin: 0 0 10px;
  width: 100%;
}

div.newsletter p {
  font-size: var(--font-size-x-small);
}

@media only screen and (max-width: 1279px) {
  div.newsletter form {
    padding-right: 95px;
  }

  div.newsletter button {
    height: 70px; width: 70px;
  }
}

[itemprop="articleBody"] div.newsletter {
  max-width: 400px;
}


/* ### PAGE FOOTER / BOXES / OFFICE HOURS ### */

.box.footer.office-hours td {
  padding-top: 8px;
}

.box.footer.office-hours td:first-child {
  padding-right: 30px;
}

.box.footer.office-hours td:last-child {
  text-align: right;
}


/* ### PAGE FOOTER / BOXES / PARTNERS ### */

.box.footer.partners {
  order: 99;
  width: 100%;
}

.box.footer.partners ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0 auto;
  max-width: 800px;
}

.box.footer.partners li {
  display: inline-block;
  margin: 10px;
}

@media only screen and (min-width: 480px) {
  .box.footer.partners {
    padding-top: 40px;
    padding-bottom: 0;
  }

  .box.footer.partners h2 {
    display: none;
  }

  .box.footer.partners ul {
    justify-content: center;
  }
}


/* ### PAGE FOOTER / LEGAL NOTE ### */

@media only screen and (min-width: 580px) {
  #legal {
    display: inline-block;
  }
}

@media only screen and (max-width: 579px) {
  #legal {
    margin-bottom: 10px;
    text-align: center;
  }
}


/* ### CAROUSEL ### */

.f4k-carousel {
  position: relative;
}

.f4k-carousel-text h2 {
  margin: 20px 0 10px;
}

@media only screen and (min-width: 480px) {
  .f4k-carousel-text h2 {
    font-family: var(--font-family-highlight);
    font-size: var(--font-size-x-large);
  }
}

.f4k-carousel-text p:last-child {
  margin-bottom: 0;
}

.f4k-carousel-progress {
  background-color: white;
  height: 7px;
  left: 0;
  opacity: 40%;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.f4k-carousel-nav {
  border-radius: 50%;
  display: inline-block;
  height: 40px;
  padding: 0;
  position: absolute;
  text-align: center;
  top: 50%;
  width: 40px;
  z-index: 1;
}
.f4k-carousel-nav::before {
  font-size: 20px;
}

.f4k-carousel-nav-next {
  right: 0;
  transform: translate(100%, -50%);
}

.f4k-carousel-nav-prev {
  left: 0;
  transform: translate(-100%, -50%);
}

.f4k-carousel-pagination {
  list-style: none;
  margin: 0 auto;
}

.f4k-carousel-pagination li {
  display: inline-block;
}

.f4k-carousel-pagination li:not(:last-child) {
  margin-right: 10px;
}

.f4k-carousel-pagination li button {
  background-color: rgba(128, 128, 128, .3);
  border: var(--f4k-white) solid 2px;
  border-radius: 50%;
  cursor: pointer;
  display: inline-block;
  height: 16px;
  overflow: hidden;
  padding: 0;
  text-indent: -1000px;
  width: 16px;
}

.f4k-carousel-pagination li.slick-active button,
.f4k-carousel-pagination li:hover button {
  background-color: var(--f4k-blue);
}


/* ### HOME / TEASER SECTION ### */

.teaser-section {
  height: calc(100vh - var(--header-height));
  /*height: calc(var(--vh) * 100 - var(--header-height));*/
}

.teaser-section .f4k-carousel,
.teaser-section .slick-list,
.teaser-section .slick-track,
.teaser-section .slick-slide {
  height: 100%;
  margin: 0;
  width: 100%;
}

.teaser-section .f4k-carousel {
  overflow: hidden;
}

.teaser-section .f4k-carousel-item {
  height: 100%;
}

.teaser-section .f4k-carousel-image {
  height: 100%;
  width: 100%;
}

.teaser-section .f4k-carousel-image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

@media only screen and (min-width: 1024px) {
  .teaser-section .content-wrapper {
    height: 100%;
  }

  .teaser-section .f4k-carousel-image {
    position: absolute;
  }

  .teaser-section .f4k-carousel-text {
    bottom: 15%;
    height: 250px;
    opacity: 95%;
    position: absolute;
    width: 800px;
  }

  .teaser-section .f4k-carousel-text p {
    text-align: justify;
  }

  .teaser-section .f4k-carousel-text .button {
    right: 14%;
    position: absolute;
    transform: translate(-50%, 0);
  }
}

@media only screen and (min-width: 1120px) and (max-width: 1279px) {
  .teaser-section .f4k-carousel-text {
    height: 220px;
    width: 675px;
  }
}

@media only screen and (min-width: 1024px) and (max-width: 1119px) {
  .teaser-section .f4k-carousel-text {
    height: 200px;
    width: 600px;
  }

  .teaser-section .f4k-carousel-text h2 {
    margin: 16px 0 8px;
  }
}

@media only screen and (max-width: 1023px) {
  .teaser-section .content-wrapper {
    padding-bottom: var(--box-spacing);
  }
}

@media only screen and (max-width: 1023px) and (orientation: portrait) {
  .teaser-section {
    border-bottom: var(--f4k-grey) solid 3px;
    box-sizing: content-box;
  }

  .teaser-section .f4k-carousel-item,
  .teaser-section .f4k-carousel-item > div {
    display: flex;
  }

  .teaser-section .f4k-carousel-item {
    flex-flow: column;
  }

  .teaser-section .f4k-carousel-image {
    flex: 1 1 auto;
  }

  .teaser-section .content-wrapper {
    flex: 0 1 auto;
  }
}

@media only screen and (max-width: 1023px) and (orientation: landscape) {
  .teaser-section .content-wrapper {
    background-color: rgba(255, 255, 255, 0.8);
    bottom: 0;
    left: 0;
    position: absolute;
    width: 75%;
  }
}

.teaser-section .f4k-carousel-pagination {
  bottom: 25px;
  margin: 0;
  position: absolute;
  right: 40px;
}

.teaser-section .f4k-carousel-pagination li:not(:last-child) {
  margin-right: 16px;
}


/* ### HOME / FEATURED SECTION ### */

.featured-section .box {
  width: var(--box-3col-width);
}

@media only screen and (min-width: 480px) {
  .featured-section .box {
    border-right: var(--f4k-grey) solid 1px;
  }
}

@media only screen and (max-width: 479px) {
  .featured-section .box {
    border-bottom: var(--f4k-grey) solid 3px;
  }
}

@media only screen and (min-width: 1024px) {
  .featured-section .box:nth-child(3) {
    border-right-style: none;
  }

  .featured-section .box:nth-child(n+4) {
    display: none;
  }
}

@media only screen and (max-width: 1023px) {
  .featured-section .box:nth-child(2) {
    border-bottom-style: none;
    border-right-style: none;
  }

  .featured-section .box:nth-child(n+3) {
    display: none;
  }
}

.featured-section .box h2 {
  margin: 40px 0 15px;
}

.featured-section .box-campaign img,
.featured-section .box-event img,
.featured-section .box-job img {
  float: left;
  width: 130px;
}

.featured-section .box-campaign .info,
.featured-section .box-event .info,
.featured-section .box-job .info {
  margin-left: 148px;
}

.featured-section .box-campaign .info .buttons,
.featured-section .box-job .info .buttons {
  margin-top: 20px;
}

.featured-section .box-event .info .head {
  font-size: var(--font-size-small);
  margin-bottom: 5px;
}

.featured-section .box-event .info .date,
.featured-section .box-event .info .location {
  font-weight: bold;
}

.featured-section .box-event .info .date {
  margin-bottom: 20px;
}

.featured-section .box-event .info .link {
  font-size: var(--font-size-small);
}

.featured-section .box-video img {
  max-width: 100%;
}

@media only screen and (max-width: 1279px) {
  .featured-section .box-campaign img,
  .featured-section .box-event img,
  .featured-section .box-job img {
    width: 105px;
  }

  .featured-section .box-campaign .info,
  .featured-section .box-event .info,
  .featured-section .box-job .info {
    margin-left: 120px;
  }
}

.box .tagline {
  left: 0;
  margin: var(--box-spacing);
  position: absolute;
  top: 0;
}

.box .tagline .tag {
  background: var(--f4k-green);
  color: white;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 2px;
  line-height: 1rem;
  padding: 2px 5px;
  text-shadow: #8a8 1px 0 10px;
}
.box .tagline.small .tag {
  font-size: 12px;
}

.box .tagline .date {
  color: var(--f4k-grey-dark);
  font-size: 13px;
  margin-left: 5px;
}


/* ### HOME / DONATION SECTION ### */

@media only screen and (min-width: 1024px) {
  .f4k-donation .box {
    border-right: var(--f4k-grey) solid 1px;
  }

  .f4k-donation .box-wrapper {
    margin-top: var(--box-spacing);
  }

  .f4k-donation .box:nth-child(3) {
    border-right-style: none;
  }

  .donation-section {
    background-image: url(/assets/zoo/donate.png);
    background-position: calc(50% + 350px) bottom;
  }

  .f4k-donation .donation-section {
    background-image: url(/assets/zoo/donate2.png);
  }
}

.donation-section ul {
  display: flex;
  list-style: none;
  margin: 0;
}

.donation-section form {
  margin-top: 60px;
}

.donation-section div.input {
  margin: 20px 0 60px;
}

.donation-section input[type=number] {
  margin-right: 20px;
  width: 210px;
}

.donation-section select {
  width: 150px;
}

.donation-section label {
  cursor: pointer;
  display: inline-block;
  margin-right: 40px;
  vertical-align: middle;
}
.donation-section li:last-child label {
  margin-right: 0;
}

.donation-section .amount {
  font-size: 40px;
  margin-left: 10px;
}

.donation-section .seal {
  bottom: -35px;
  left: 480px;
  position: absolute;
}

@media only screen and (max-width: 1279px) {
  .donation-section {
    background-position: right 20px bottom;
  }

  .donation-section .seal {
    left: 380px;
  }
}

@media only screen and (max-width: 579px) {
  .donation-section form {
    margin-top: 0;
  }

  .donation-section div.input {
    margin-bottom: 20px;
  }

  .donation-section input[type="number"] {
    width: 140px;
  }

  .donation-section label {
    margin-right: 20px;
  }

  .donation-section p:last-child {
    width: 65%;
  }

  .donation-section .amount {
    font-size: 28px;
  }

  .donation-section .seal {
    bottom: -28px;
    left: unset;
    right: 10px;
  }

  .donation-section .seal img {
    width: 120px;
  }
}


/* ### HOME / VALUES SECTION ### */

.values-section .box {
  text-align: center; 
  width: 240px; 
}

.values-section .box p {
  margin-top: 10px;
}

.values-section .box .circle-wrapper {
  height: 200px;
}

.values-section .box:nth-child(5n+2) .circle-wrapper::before {
  transform: rotate(15deg);
}
.values-section .box:nth-child(5n+3) .circle-wrapper::before {
  transform: rotate(30deg);
}
.values-section .box:nth-child(5n+4) .circle-wrapper::before {
  transform: rotate(45deg);
}
.values-section .box:nth-child(5n+5) .circle-wrapper::before {
  transform: rotate(60deg);
}

.values-section .click-wrapper:hover {
  background-color: var(--f4k-grey-light);
}

@media only screen and (max-width: 1279px) {
  .values-section .box-wrapper {
    margin: 0 auto;
    max-width: 800px;
  }
}

@media only screen and (max-width: 539px) {
  .circle-wrapper::before {
    display: none;
  }

  .values-section .box {
    padding: calc(var(--box-spacing) / 2);
    width: 50%;
  }

  .values-section .box .circle-wrapper {
    height: unset;
  }

  .circle-wrapper img {
    filter: drop-shadow(2px 2px 4px #aaa);
    height: unset;
    left: 0;
    position: relative;
    top: 0;
    width: calc(100% - 2 * var(--box-spacing));
  }

  .circle-wrapper h3 {
    position: absolute;
    width: 100%;
  }
}

@media only screen and (max-width: 479px) {
  .values-section {
    border-top: var(--f4k-grey) solid 3px;
    padding-bottom: 0;
  }
}


/* ### HOME / PILLARS SECTION ### */

.pillars-section .box {
  width: var(--box-2col-width);
}

.pillars-section .image-wrapper {
  position: relative;
}

.pillars-section .image-wrapper img {
  width: 100%;
}

@media only screen and (min-width: 1024px) {
  .pillars-section {
    padding-bottom: 0;
  }

  .pillars-section .text-wrapper {
    background-color: rgba(255, 255, 255, .9);
    border-radius: 5px;
    bottom: 25px;
    left: 20px;
    padding: 10px;
    position: absolute;
    width: 70%;
  }

  .pillars-section .button {
    float: right;
  }
}

@media only screen and (min-width: 480px) {
  .pillars-section .image-wrapper img {
    filter: drop-shadow(2px 2px 4px #aaa);
  }
}


/* ### HOME / SUPPORT SECTION ### */

.support-section .box {
  text-align: center;
  width: var(--box-4col-width);
}

.support-section .box h3 a {
  color: var(--f4k-blue);
}

.support-section .box img {
  background-color: white;
  border-radius: 125px;
  filter: drop-shadow(2px 2px 4px #ccc);
  width: 50%;
}

.support-section .box p {
  margin: 0;
}

.support-section .click-wrapper:hover {
  background-color: var(--f4k-white);
}

@media only screen and (min-width: 1024px) {
  .support-section {
    background-image: url(/assets/zoo/support.png);
    background-position: calc(50% - 415px) bottom;
    min-height: 510px;
  }

  .support-section ul {
    margin-left: 170px;
  }

  .support-section .box p {
    font-size: var(--font-size-small);
  }
}

@media only screen and (min-width: 1119px) {
  .support-section ul {
    margin-left: 200px;
  }
}

@media only screen and (min-width: 1280px) {
  .support-section {
    background-position: calc(50% - 525px) bottom;
  }
}

@media only screen and (max-width: 799px) {
  .support-section .box p {
    margin: 0 auto;
    max-width: 200px;
  }
}


/* ### HOME / TEAM SECTION ### */

.team-section img {
  width: 100%;
}

.team-section p.buttons {
  margin-top: 20px;
  text-align: center;
}


/* ### PAGES / SHOP2HELP ### */

.f4k-shop2help form {
  margin: var(--section-spacing) 0;
  text-align: center;
}


/* ### PAGES / PARTNERS ### */

.content-section ul.partners {
  list-style: none;
  margin: 0;
}

.content-section ul.partners li {
  margin-top: var(--text-spacing-large);
  position: relative;
}

@media only screen and (min-width: 480px) {
  .content-section ul.partners h3,
  .content-section ul.partners p {
    font-family: var(--font-family-text);
    margin-left: 175px;
  }

  .content-section ul.partners .logo {
    display: inline-block;
    left: 0;
    height: 100%;
    max-width: 33%;
    padding: 5px 0;
    position: absolute;
    text-align: center;
    top: 0;
    width: 140px;
  }

  .content-section ul.partners .logo img {
    max-height: 100%;
    max-width: 100%;
  }
}

@media only screen and (max-width: 479px) {
  .content-section ul.partners h3 {
    display: none;
  }

  .content-section ul.partners .logo {
    display: block;
    width: 100%;
  }

  .content-section ul.partners .logo img {
    max-height: 45px;
    max-width: 50%;
  }
}


/* ### PAGES / PRESS CLIPPINGS ### */

.content-section ul.clippings div.clip {
  margin-top: 50px;
  max-height: 400px;
  overflow: hidden;
}

.content-section ul.clippings div.clip img {
  width: 100%;
}

.content-section ul.clippings div.tagline .date {
  white-space: nowrap;
}

@media only screen and (max-width: 1023px) {
  .content-section ul.clippings div.tagline .date {
    display: block;
    margin-left: 0;
  }
}


/* ### PAGES / TEAM ### */

.content-section .team .box {
  font-size: var(--font-size-small);
  text-align: center;
}

.content-section .team h3 {
  margin: var(--text-spacing-large) 0 0;
}

.content-section .team.animals h3 {
  margin-top: 0;
}


@media only screen and (max-width: 479px) {
  .content-section .team h3 {
    font-size: var(--font-size-small);
  }
}

.content-section .team img {
  filter: drop-shadow(2px 2px 4px #aaa);
  max-width: 200px;
  width: 100%;
}


/* ### PAGES / INSTITUTIONS ### */

.content-section ul.institutions {
  margin-top: 20px;
}

.content-section ul.institutions img {
  max-width: 100%;
}

.content-section ul.institutions small {
  color: var(--f4k-grey-dark);
}


/* ### PAGES / GALLERY ### */

.content-section .gallery {
  margin-top: 10px;
}

.content-section .gallery .box {
  font-size: var(--font-size-small);
  width: var(--box-5col-width);
}

.content-section .gallery a {
  display: flex;
  position: relative;
}

.content-section .gallery img {
  width: 100%;
}

.content-section .gallery div.overlays {
  display: none;
}

.content-section .gallery div.overlays .duration {
  background-color: #222;
  border-radius: 3px;
  bottom: 0;
  color: #fff;
  font-size: var(--font-size-x-small);
  font-weight: bold;
  margin: 5px;
  padding: 0 5px;
  position: absolute;
  right: 0;
}


/* ### PAGES / SHOP ### */

.f4k-shop .category {
  margin-top: 10px;
}

.f4k-shop .box {
  font-size: var(--font-size-small);
}

.f4k-shop .cart span {
  font-weight: bold;
}

.f4k-shop .cart.fixed {
  background-color: white;
  border-bottom: var(--f4k-grey) solid 1px;
  left: 50%;
  margin: 0;
  max-width: 100%;
  padding: 0 var(--box-spacing);
  position: fixed;
  top: var(--header-height);
  transform: translate(-50%, 0);
  width: var(--wrapper-width);
  z-index: 1;
}

.f4k-shop #cartTotal {
  display: inline-block;
  padding: var(--text-spacing-large);
  padding-left: 0;
}

.f4k-shop #cartTotal,
.f4k-shop #cartTotal * {
  color: var(--f4k-green);
}

.f4k-shop #cartCheckout {
  display: none;
}

.f4k-shop .controls input.add.soldout {
  background-color: var(--f4k-orange);
  border-color: var(--f4k-orange);
}
.f4k-shop .controls input.add.soldout:hover {
  background-color: var(--f4k-orange-light);
  border-color: var(--f4k-orange-light);
}

.f4k-shop .controls .quantity {
  background-color: var(--f4k-green-light);
  border-color: var(--f4k-green-dark);
  display: none;
  width: 70px;
}

.f4k-shop .controls span {
  display: inline-block;
  margin-top: 8px;
}

@media only screen and (min-width: 1280px) {
  .f4k-shop .controls span {
    margin-top: 14px;
  }
}

.f4k-shop table.grid td.image {
  width: 50px;
}
.f4k-shop table.grid td.image img {
  vertical-align: middle;
  width: 100%;
}

.f4k-shop table.grid td.code,
.f4k-shop table.grid td.quantity {
  width: 100px;
}

.f4k-shop table.grid td.price {
  width: 120px;
}
@media only screen and (max-width: 1023px) {
  .f4k-shop table.grid td.price {
    width: 100px;
  }
}

.f4k-shop table.grid td.price s {
  color: red;
  font-size: var(--font-size-small);
}

.f4k-shop table.grid tfoot td {
  padding-bottom: 0;
}
.f4k-shop table.grid tfoot td.small {
  font-size: var(--font-size-small);
}
.f4k-shop table.grid tfoot td.sum {
  font-weight: bold;
}

.f4k-shop-progress ul {
  margin-bottom: calc(2 * var(--text-spacing-large));
}

.f4k-shop-progress li {
  margin-right: 20px;
}

.f4k-shop-progress li a,
.f4k-shop-progress li:before {
  color: var(--f4k-grey);
}
.f4k-shop-progress li.icon-circle-right a,
.f4k-shop-progress li.icon-circle-right:before {
  color: var(--f4k-blue);
}
.f4k-shop-progress li.icon-circle-checked a,
.f4k-shop-progress li.icon-circle-checked:before {
  color: var(--f4k-green);
}


/* ### PAGES / TIMELINE ### */

.f4k-timeline .element {
  height: 75px;
}

.f4k-timeline .element .time {
  background-image: linear-gradient(var(--f4k-green-light), var(--f4k-green-light));
  background-size: 4px 100%;
  background-position: center 0;
  background-repeat: no-repeat;
  padding: 0;
}
.f4k-timeline .element:first-child .time {
  background-image: linear-gradient(var(--f4k-white), var(--f4k-green-light));
}
.f4k-timeline .element:last-child .time {
  background-image: linear-gradient(var(--f4k-green-light), var(--f4k-white));
}

.f4k-timeline .element .time > div {
  align-items: center;
  background-color: var(--f4k-white);
  border: var(--f4k-green) solid 4px;
  border-radius: 50%;
  color: var(--f4k-green);
  display: flex;
  font-family: var(--font-family-highlight);
  font-size: 1.1em;
  height: 55px;
  justify-content: center;
  width: 55px;
}

.f4k-timeline .element .info {
  color: var(--f4k-grey-dark);
  padding: 10px 0 10px 20px;
}


/* ### PRINT OVERRIDES ### */

@media only print {
  header,
  nav.breadcrumb,
  #footer-top,
  #footer-bottom nav {
    display: none;
  }

  main,
  .sujet-section {
    padding-top: 0;
  }

  .teaser-section,
  .featured-section,
  .donation-section,
  .circle-wrapper::before,
  .button {
    display: none;
  }

  #contact {
    -webkit-print-color-adjust: exact !important;
    color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  * {
    color: black !important;
  }

  #legal,
  p.published {
    color: gray !important;
  }
}
