/*
Theme Name: neoven filia
Description: Special Child Theme for genisuisse.org
Author: Dominic Hostettler
Author URI: www.dominic-hostettler.ch
Template: neoven
*/



/* ---------------------------- */
/* Variables */
/* ---------------------------- */


/* FONTS */

/* Paragraph */

@font-face {
  font-family: Light Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ROBOTO-LIGHT.TTF);}

@font-face {
  font-family: Regular Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ROBOTO-LIGHT.TTF);}

@font-face {
  font-family: Medium Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ROBOTO-REGULAR.TTF);}

@font-face {
  font-family: Bold Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ROBOTO-MEDIUM.TTF);}

@font-face {
  font-family: Title Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ALWYNMEDIUM.TTF);}

@font-face {
  font-family: Light Title Font;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ALWYN.TTF);}
  
@font-face {
  font-family: Arial;
  src: url(/wp-content/themes/neoven-filia/assets/fonts/ARIALMT.TTF);}



:root {

--dark-font: #242422;
--bright-font: #868686;
--very-bright-font: #a2a2a2;


/* COLORS */

/* C1*/

--c1-150: #75130f;
--c1-130: #92221d;
--c1-120: #92221d;
--c1-110: #962420;

--c1-100: #9a2823;
--c1-099: #aa302a;
--c1-090: #aa302a;
--c1-080: #c13a32;
--c1-070: #c6514b;

--c1-007: #aa302a;
--c1-002: #aa302a;

/* C2*/

--c2-100: #9a2823;
--c2-099: #aa302a;
--c2-090: #aa302a;
--c2-080: #c13a32;
--c2-070: #c6514b;

--c2-007: #aa302a;
--c2-002: #aa302a;

/* C0 */

--c0-100: #000;
--c0-095: #0f0f0f;
--c0-090: #1e1e1e;
--c0-085: #2f2f2f;
--c0-080: #3c3c3c;
--c0-075: #484848;
--c0-070: #606060;
--c0-050: #a6a6a6;
--c0-040: #bbbbbb;
--c0-030: #d8d8d8;
--c0-020: #dddddd;
--c0-010: #f2f2f2;
--c0-007: #f7f7f7;
--c0-002: #f9f9f9;
--c0-001: #fbfbfb;
--c0-000: #ffffff;
--c0-t002: rgba(0, 0, 0, .02);
--c0-t004: rgba(0, 0, 0, .05);
--c0-t006: rgba(0, 0, 0, .07);
--c0-t008: rgba(0, 0, 0, .09);
--c0-t010: rgba(0, 0, 0, .1);
--c0-t020: rgba(0, 0, 0, .2);
--c0-t050: rgba(0, 0, 0, .5);



/* OBJECTS */

/* Corners */
--corner-small: 0px;
--corner-medium: 0px;

/* Tags */
--tag-padding-small: .3em .5em .4em .9em;
--tag-padding-medium: .5em 1em .6em 1em;
--tag-padding-big: .8em 1em .9em;

--tag-edges: polygon( 10px 0%, 0% 0%, calc(100%) 0%, 100% 0px, 100% calc(100% - 0px), calc(100% - 0px) 100%, 10px 100%, 0 calc(50%) );

/* Shadows */
--shadow-small: rgba(0, 0, 0, 0.15) 0px 0px 5px 0px;
--shadow-medium: rgba(0, 0, 0, 0.15) 0px 0px 12px 0px;

/* Movements */
--transition-slow: .5s cubic-bezier(.5,0,0.1,1);
--transition-normal: .4s cubic-bezier(.5,0,0.1,1);
--transition-fast: .2s ease-in-out;
}



/* BODY */

body {
  font-size: 17px;
  background-color: var(--c0-007);
}

body p a {
  transition: .1s ease;
  font-family: Medium Font, sans-serif;
  text-decoration: underline;
  text-underline-offset: 3px;
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1.2;
  font-family: Title Font, sans-serif;
}

p, .page-content ul li, .post-content ul li, .page-content ol li, .post-content ol li {
  margin: 0 0 1em 0;
}

/* M - XL */
@media (min-width: 600px) {
  .site-title {
    font-family: Bold Font;
    font-size: 45px;
  }
}

::selection {
  background-color: var(--c1-080);
  color: #fff;
}

.has-medium-font-size {
  font-size: 20px !important;
}

.has-large-font-size {
  font-size: 30px !important;
}

.has-small-font-size {
  font-size: 15px !important;
}


button, .button, .button-1, .submit, .wp-block-button__link, .wp-block-button__link:active, .wp-block-button__link:focus, .wp-block-button__link:hover, .wp-block-button__link:visited, input[type="submit"] {
  cursor: pointer;
  border: none;
  display: inline-block;
  font-family: Light Title Font, sans-serif;
  border-radius: var(--corner-small);
  padding: 0 .7em .1em;
  color: #fff;
  background-color: var(--c2-100);
  line-height: inherit;
}

.button a, .button-1 a, button a {
  color: #fff;
  text-decoration: unset !important;
}

button:hover, .button:hover, .submit:hover, .wp-block-button__link:hover, button a:hover, input[type="submit"]:hover {
  color: #fff;
  background-color: var(--c2-080);
}

.button-next a {
  padding: .25em .6em .25em .9em !important;
}

.button-next a::after {
  font-family: 'dashicons';
  content: "\f345";
  line-height: 0;
  position: relative;
  top: 3px;
  right: -1px;
  transition: var(--transition-normal);
}

.button-next a:hover::after{
  right: -5px;
}

.button-prev a {
  padding: .25em .9em .25em .6em !important;
}

.button-prev a::before {
  font-family: 'dashicons';
  content: "\f341";
  line-height: 0;
  position: relative;
  top: 3px;
  left: -1px;
  transition: var(--transition-normal);
}

.button-prev a:hover::before{
  left: -5px;
}

.button-big {
  font-size: 1.2em;
}


/* Icon Link */

a kbd {
  font-family: inherit;
}

a kbd::before {
  font-family: 'dashicons';
  content: "\f345";
  line-height: 0;
  position: relative;
  transition: var(--transition-normal);
  top: .18em;
  margin-left: -.2em;
}

.o kbd::before {
  content: "\f316";
}

.button-download kbd::before {
  content: "\f316";
}

.button-book kbd::before {
  content: "\f330";
}

.button-map kbd::before {
  content: "\f231";
}



/* SVG ELEMENT */

svg {
  max-width: 100%;
  height: auto;
}

a:hover .st4, a:hover .stm4 {
  fill: var(--c2-080) !important;
}



/* BLOCK CLASSES */

.box {
  padding: 30px;
}

.small-box {
  padding: 20px;
}

.dark-grey {
  background-color: var(--c0-t008);
}

.c1-100 {
  background-color: var(--c1-100);
}

.negative * {
  color: #fff;
}

.negative a {
  text-decoration: underline;
}

.negative .button {
  color: #fff;
  background-color: #d3ff2930;
}

.negative .button:hover {
  background-color: #d3ff2745;
}

code {
  color: var(--dark-font);
  font-family: Light Font;
}


/* 0 - S */
@media (max-width: 599px) {

.wp-block-column.infinite-left {
  margin: -300px -5vw 30px -5vw !important;
  padding: 300px 5vw 0 5vw;
}
}

/* M */
@media (min-width: 600px) and (max-width: 781px) {

.wp-block-column.infinite-left {
  margin: -300px -10vw 30px -10vw !important;
  padding: 300px 10vw 0 10vw;
}
}

/* L - XL */
@media (min-width: 782px) {

.infinite-left {
  margin: -300px 0 -100px -1000px !important;
  padding: 300px 0 100px 1000px;
  box-sizing: content-box;
}
}



/* BLOCK EDITOR ELEMENTS */

/* Block Quote */

blockquote {
  margin-left: 0;
  margin-right: 0;
}

.wp-block-quote p {
  color: var(--c1-100);
  font-size: 23px;
  margin-bottom: 8px;
  margin-left: 20px;
  font-style: italic;
}

.wp-block-quote p::before, .wp-block-quote p::after {
  content: "„";
  font-family: 'Arial';
  font-size: 60px;
  line-height: 0;
  position: relative;
  opacity: .3;
  top: -0.25em;
}

.wp-block-quote p:before {
  margin-left: -20px;
}

.wp-block-quote p::after {
  margin-left: 5px;
}

.wp-block-quote cite {
  font-style: inherit;
  color: var(--c1-070);
  display: inline-flex;
  margin-left: 10px;
}

.wp-block-quote cite:before {
  content: "~";
  margin: 0 5px 0 -5px;
}

/* Separator */

.wp-block-separator {
  margin: 30px 0;
  color: var(--c1-120);
  border-top-width: 2px;
  border-bottom-width: 1px;
}

/* Button */

.wp-block-buttons {
  margin-top: 15px;
}

/* Columns */

.wp-block-columns {
  gap: 30px;
}

/* Groups */

.wp-block-group__inner-container > * {
  margin-top: 0;
}



/* TEMPLATES */

/* Image Left Template */

.image-left-template .post-title {
  font-size: 26px;
}

/* Logged In status */

#wpadminbar {
  position: fixed;
}


/* HEADER */

/* XL */
@media (min-width: 1100px) {
  #header {
    margin-bottom: -45px;
  }
}


#header-bar {
  box-shadow: none;
  background-color: transparent;
  height: unset;
}

/* LOGO */

#logo {
  max-width: 210px;
  margin-top: 15px;
  width: 70%;
}

#logo-bar {
  background-color: var(--c0-t004);
}

/* 0 - L */
@media (max-width: 1099px) {
  #header-bar {
    background-color: var(--c0-t004);
    border-bottom: solid 3px var(--c1-120);
  }
}

/* XL */
@media (min-width: 1100px) {
  #logo-bar {
    height: 65px;
  }
}


/* SECOND MENU */

#second-menu .menu-points-box {
  margin-top: -8px;
}

#second-menu li a {
  opacity: 1;
  color: rgba(255, 255, 255, 0.7);
  background-color: var(--c2-100);
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-family: Medium Font, sans-serif;
  padding: 10px 10px 7px;
  z-index: 100;
}

/* 0 - S */
@media (max-width: 599px) {
  #second-menu li a {
    font-size: 12px;
  }
}

#second-menu li a:hover, #second-menu li a:focus {
  color: rgba(255, 255, 255, 0.9);
  background-color: var(--c2-080);
}


/* PRIMARY MENU */

#primary-menu a {
  font-family: Light Title Font, sans-serif;
}

/* XL */
@media (min-width: 1100px) {
  #primary-menu .menu-item a {
    color: #fff;
  }

  #primary-menu li.current-menu-item > a, #primary-menu li.current_page_parent > a, #primary-menu li.current-menu-item.menu-item-has-children::after, #primary-menu li.current_page_parent.menu-item-has-children::after, #primary-menu ul.menu-points > li:hover > a, #primary-menu ul.sub-menu > li:hover > a {
    color: #fff;
  }

  #primary-menu li {
    background-color: unset;
    height: 45px;
  }

  #primary-menu-bar {
    background-color: var(--c1-120);
  }

  .home #primary-menu-bar {
    background-color: var(--c0-t050);
  }
}


/* Underlined Version */

/* First Level */

/* XL */
@media (min-width: 1100px) {
  #primary-menu ul.menu-points > li > a {
    padding: .7em .2em .2em;
    line-height: 1em;
    margin: auto 15px;
}
}

#primary-menu ul.menu-points > li.menu-item-has-children:not(.hide-2nd-level) > a {
  padding-right: 1em;
}

/* Second Level */

/* XL */
@media (min-width: 1100px) {

#primary-menu .sub-menu {
  padding: .6em;
  background: #fff;
}

#primary-menu ul.sub-menu > li > a {
  padding: .5em 3px;
  line-height: 1.2;
}

#primary-menu ul li:hover > ul, #primary-menu ul li:focus > ul, #primary-menu .focus > ul {
  width: 250px;
}
}

/* 0 - L */
@media (max-width: 1099px) {
  #primary-menu ul.menu-points > li > a {
    padding: inherit;
    overflow: hidden;
  }
}

/* All Levels */

#primary-menu ul.menu-points > li > a, #primary-menu ul.sub-menu > li a {
  border-bottom: 1px solid transparent;
  font-size: 18px;
}

#primary-menu li.current-menu-item > a, #primary-menu li.current_page_ancestor > a, #primary-menu ul.menu-points > li > a:hover, #primary-menu ul.sub-menu > li > a:hover {
  border-bottom-color: #fff !important;
}


/* Hide 2nd Level */

#primary-menu .hide-2nd-level .sub-menu, #primary-menu .hide-2nd-level > a:after, #primary-menu .hide-2nd-level span.mobile-toggle {
  display: none !important;
}

#primary-menu li.current_page_parent.hide-2nd-level.menu-item-has-children > a {
  border-bottom-color: transparent !important;
}

/* Mobile Menu */

/* 0 - L */
@media (max-width: 1099px) {
  #primary-menu li a, .menu-points > .menu-item-has-children > span.mobile-toggle {
    line-height: 40px;
    height: 40px;
  }

  #primary-menu ul.menu-points {
    padding: 30px 20px 30px !important;
    max-height: unset;
  }

  #primary-menu .menu-points-box {
    min-width: 0px;
    width: 0vw;
    overflow: hidden;
    position: absolute;
    right: 0;
    top: 0;
    transition: var(--transition-normal);
  }

  #primary-menu .menu-points-box.toggled-on, #primary-menu .menu-points {
    width: 350px;
    max-width: 100% !important;
  }

  .menu-points > .menu-item-has-children > span.mobile-toggle {
    padding: 0px 15px;
  }

  .menu-points > .menu-item-has-children > span.mobile-toggle::after {
    top: 15px;
  }

  #primary-menu ul.sub-menu > li > a {
    margin-left: 20px;
  }

  #primary-menu ul.sub-menu > li > ul > li > a {
    margin-left: 40px;
  }

  #primary-menu li.current_page_ancestor > a {
    border-bottom-color: transparent !important;
  }

  #primary-menu li.current-menu-item > a, #primary-menu li.current_page_parent > a, #primary-menu li.current-menu-item.menu-item-has-children::after, #primary-menu li.current_page_parent.menu-item-has-children::after, #primary-menu ul.menu-points > li:hover > a, #primary-menu ul.sub-menu > li:hover > a {
    text-decoration: underline;
    text-underline-offset: .4em;
  }
}

/* Fancy Burger Animation */

/* 0 - L */
@media (max-width: 1099px) {

  #primary-menu a.burger {
    margin-top: 0;
    top: -10px;
    left: -10px;
  }

  #primary-menu a.burger .line {
    transition: 0.2s;
    transform-origin: center;
    transform: rotate(0deg);
  }

  #primary-menu a.burger.toggled-on .line:nth-child(1){
    transform: rotate(135deg);
    top: 100%;
  }

  #primary-menu a.burger.toggled-on .line:nth-child(2){
    transform: rotate(45deg);
  }

  #primary-menu a.burger.toggled-on .line:nth-child(3){
    transform: rotate(135deg);
    top: -100%;
    opacity: 0;
  }
}


/* PAGE HEADER */

.header-area {
  width: 100% !important;
  max-width: unset !important;
}

.thumbnail-container {
  margin-top: -30px;
}

.page-thumbnail.wp-post-image {
  max-height: 200px;
  object-fit: cover;
  margin-bottom: -70px;
}

.title-container {
  position: relative;
  max-width: 1080px;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 40px;
  margin-bottom: 20px;
}

.post-title a.title, .page-title a.title {
  pointer-events: none;
}

.page-title {
  width: auto;
  display: inline-block;
  position: relative;
  margin-top: 60px;
}

/* Title Animation */

.title-container h1 a {
  animation: 
    typewriter 1.2s ease 0s 1 normal both;
  white-space: nowrap;
  overflow: hidden;
  display: inline-block;
  padding-right: 3px;
  width: 100%;
}

@keyframes typewriter {
  0% { 
    width: 0;
    border-right: 3px solid;
  }

  50% { 
    width: 100%;
    border-right: 3px solid;
  }

  80% { 
    border-right: none;
  }

  83% { 
    border-right: 3px solid;
  }

  99% { 
    border-right: 3px solid;
  }

  100% { 
    border-right: none;
  }
}



/* 0 - S */
@media (max-width: 599px) {

.title-container {
  width: 90%;
}

.page-thumbnail.wp-post-image {
  max-height: 150px;
  min-height: 150px
}
}



/* FOOTER */

footer {
  background-color: var(--c1-120);
}

footer img.some-icon {
  width: 30px;
  margin-top: 10px;
}

footer #footer-menu li a, .footer-bar .footer-area * {
  color: var(--dark-font);
  letter-spacing: .02em;
}

.footer-bar {
  padding: 0;
}

footer .footer-logo {
  max-width: 210px;
}

#footer-menu-bar {
  background-color: var(--c0-040);
}

.designer-page-link {
  opacity: .7;
}



/* POST PAGE & BLOG PAGE */

.post-meta a {
  pointer-events: all;
}

.post-meta * {
  font-size: 14px;
}

.post-meta span {
  display: inline-block;
  color: var(--bright-font);
  background: var(--c0-t004);
  padding: .2em .5em;
  margin-bottom: 0.5em;
}

.overlay:hover {
  background-color: transparent;
}

.overlay:hover ~ .listing-item-box .button {
  background-color: var(--c2-080);
}

.cpt-name {
  color: var(--bright-font);
  font-family: Light Font, sans-serif;
}

.single-buch .cpt-name, .book .cpt-name {
  float: left;
}

.single-buch .entry-date::before, .book .entry-date::before {
  content: "|";
  margin: 0 5px;
}

.teaser-text {
  margin-bottom: .5em;
}

.entry-date {
  font-size: 17px;
}

.blog .listing-item {
  margin-bottom: 60px;
}

.blog .listing-item img {
  transition: var(--transition-normal);
}

.blog .listing-item:not(.listing-item.animated-book):hover img {
  transform: scale(105%);
  transition: var(--transition-fast);
}

.related-posts {
  padding: 20px;
  background-color: var(--c0-t004);
}

.related-posts h5 {
  color: var(--dark-font);
  font-family: Light Title Font, sans-serif;
  margin: 0 0 1em 0;
}

.related-posts .post-title-linked, .related-posts p {
  margin-bottom: .3em;
}

.related-posts .listing-item {
  margin: 30px 0 10px 0;
}

.related-posts .post-meta span {
	padding: 0;
	background-color: transparent;
	margin: -3px 0 3px;
	display: block;
}

.post-content-content-excerpt {
  font-size: 14px;
  display: -webkit-box;
  -webkit-line-clamp: 2; /* Maximale Zeilenanzahl */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.more a:before {
  content: "";
  display: block;
  float: left;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  border: solid var(--c1-120);
  border-width: 0 2px 2px 0;
  width: 8px;
  height: 8px;
  margin: 8px 6px 0 0;
} 

.side-image-blog .listing-item.event .post-thumbnail {
  overflow: hidden;
}

.event-day-big {
  margin-top: -10px;
  margin-bottom: 5px;
  background-color: var(--c0-020);
  line-height: 1 !important;
  border-radius: var(--corner-small);
  display: inline-block;
  padding: .5em .7em;
}

.event-date {
  display: flex;
  gap: 6px;
  margin: 0 0 15px;
}

.year {
  display: inline;
}

.listing-item .place {
	font-size: 16px;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}


/* POST PAGE */

h1.post-title {
  font-size: 32px;
}

#post {
  padding-top: 90px;
}

#post .post-thumbnail img {
  max-height: 400px;
  max-width: 100%;
  margin-bottom: 15px;
}

.single-buch #post .post-thumbnail img {
  max-width: 70%;
}

/* 0 - M */
@media (max-width: 781px) {

  .post-content {
    width: 100%;
  }

  #main-area {
    margin-left: auto;
    margin-right: auto;
    width: 80%;
  }

  #backButton {
    margin: 0 0 40px 10%;
  }

  .related-posts {
    padding: 30px 10% 60px;
  }

  #post #sidebar {
    margin-bottom: 0;
  }
}

/* Go Back Button */

/* L - XL */
@media (min-width: 782px) {

  .goback.button-prev.desktop {
    display: block;
    z-index: 50;
    position: fixed;
    height: 0;
  }
  
  .goback.button-prev.desktop a {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }
  
  .goback.button-prev.mobile {
    display: none;
  }
}
  
/* 0 - M */
@media (max-width: 781px) {
  
  .goback.button-prev.desktop {
    display: none;
  }
  
  .goback.button-prev.mobile {
    margin-top: 30px;
    display: inline-block;
  }
}

/* Tables */

.post-content-container table {
  width: 100%;
  border-spacing: 0;
}

.post-content-container table td, .post-content-container table th {
  padding: 8px 10px;
}

.post-content-container table tr:nth-child(odd) {
  background-color: var(--c0-t006);
}

.post-content-container table td, .post-content-container table th {
  word-break: keep-all;
  hyphens: initial;
  min-width: 120px;
  vertical-align: top;
}



/* CUSTOM ELEMENTS */

.full-width.box {
  padding: 45px 0 60px;
}

.big-padding {
  padding: 6vw 0;
}

/* check-list */

.check-list li::before {
  content: "\f147";
  font-family: 'dashicons';
  color: var(--c1-100);
  font-size: 1.6em;
  position: absolute;
  margin: -4px 0 0 -25px;
}

.check-list li::marker {
  content: "";
}

li::marker {
  color: var(--c1-100);
}

.page-content ul li {
  list-style: square;
}



/* wrap-reverse */

/* 0 - M */
@media (max-width: 781px) {

  .wp-block-columns.wrap-reverse {
    flex-wrap: wrap-reverse !important;
    display: flex !important;
  }
}



/* Full Width Picture */

.full-width-picture, .full-width-picture > img {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
}

.full-width-picture img {
  max-height: 70vh;
  width: 100%;
  object-fit: cover;
}



/* Counter Area */

.is-layout-flex.counter-area {
  display: flex;
}

.counter-area *, .counter-area.wp-block-columns  .wp-block-column {
  text-align: center;
  margin: 0;
  flex-basis: calc(50% - 30px) !important;
}

.counter-area h2 {
  font-size: clamp(30px, 28px + 1vw, 41px);
}

.counter-area p {
  opacity: .6;
  font-family: Light Font;
  font-size: .9em;
}

.counter-area img {
  width: 60px;
}


/* M - XL */
@media (min-width: 600px) {
  .counter-area img {
    margin-bottom: 20px;
    width: 100px;
  }
}



/* Full Button */

.full-button .wp-block-button__link, .full-button .wp-block-button {
  width: 100vw;
  height: 150px;
  display: table-cell;
  vertical-align: middle;
  font-size: 22px;
  font-family: Medium Font;
  background-size: cover;
  background-position: center;
  transition: var(--transition-normal);
}

.full-button .wp-block-button__link:hover {
  opacity: .9;
}

.full-button .wp-block-buttons {
  display: block;
}

/* L - XL */
@media (min-width: 782px) {

.full-button .wp-block-column:not(:first-child) {
  margin-left: 15px;
}

.full-button.wp-block-columns {
  gap: 0;
}
}


/* Three Column Blog */


.three-column-blog .blog {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

/* L - XL */
@media (min-width: 782px) {

  .three-column-blog .blog {
    gap: 2%;
  }

  .three-column-blog .listing-item {
    flex-basis: 32%;
    margin-bottom: 2%;
  }
}

/* M */
@media (min-width: 600px) and (max-width: 781px) {

  .three-column-blog .blog {
    gap: 3%;
  }

  .three-column-blog .listing-item {
    flex-basis: 47%;
    margin-bottom: 3%;
  }
}

/* 0 - S */
@media (max-width: 599px) {

  .three-column-blog .listing-item {
    flex-basis: 100%;
    margin-bottom: 20px;
  }
} 



/* Four Column Blog */


.four-column-blog .blog {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

/* L - XL */
@media (min-width: 782px) {

  .four-column-blog .blog  {
    gap: 2%;
  }

  .four-column-blog .listing-item {
    flex-basis: 23.5%;
    margin-bottom: 2%;
  }
}

/* M */
@media (min-width: 600px) and (max-width: 781px) {

  .four-column-blog .blog  {
    gap: 3%;
  }

  .four-column-blog .listing-item {
    flex-basis: 31.333%;
    margin-bottom: 3%;
  }
}

/* 0 - S */
@media (max-width: 599px) {

  .four-column-blog .listing-item {
    flex-basis: 100%;
    margin-bottom: 20px;
  }
} 



/* Side Image Blog */

.side-image-blog .listing-item {
  display: table;
  width: 100%;
}

.side-image-blog .listing-item .post-thumbnail {
  padding: 0 0 20px;
  max-width: 200px;
}

.side-image-blog .listing-item .listing-item-box {
  padding: 0;
  position: relative;
}

/*
.side-image-blog .listing-item .listing-item-box::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 2px;
  background-color: var(--c0-050);
  left: 5px;
  top: 0;
}

/* 0 - S */
@media (max-width: 599px) {

.side-image-blog .listing-item {
  max-width: 400px;
}

.side-image-blog .listing-item .post-thumbnail {
  margin-bottom: 15px;
}
}

/* M - XL */
@media (min-width: 600px) {

.side-image-blog .listing-item .post-thumbnail {
  max-width: 120px;
  float: left;
}

.side-image-blog .listing-item .listing-item-box {
  padding: 0px 0px 0px 20px;
  margin-left: 120px;
}
}

/* Box Blog */

.box-blog .listing-item .listing-item-box {
  background-color: #fff;
  padding: 15px;
}

.box-blog .listing-item .post-thumbnail {
  height: 160px;
  width: 100%;
  overflow: hidden;
}

.box-blog .listing-item .post-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}



/* PLUGINS */

/* Neoven Custom post Slider */

.custom-post-slider .swiper-slide {
  opacity: 0 !important; 
  transition: opacity 2s ease-in-out; 
  display: flex;
  gap: 10%;
}

.custom-post-slider .swiper-slide-active {
  opacity: 1 !important;
}

.custom-post-slider .swiper-slide:not(.swiper-slide-active) * {
  pointer-events: none;
}

.custom-post-slider .listing-item {
  width: 60%;
  align-self: center;
}

.custom-post-slider .more-box {
  width: 40%;
  position: relative;
  margin: -30px 0 0 0;
}

.more-box a {
  display: block;
  transition: var(--transition-normal);
  align-content: center;
  min-height: 230px;
}

/* 0 - S */
@media (max-width: 599px) {
  .more-box a {
    min-height: 30px;
  }

  .more-box a::after {
    display: none;
  }

  .custom-post-slider .more-box {
    margin: auto;
    max-width: 400px;
  }
}  

.more-box a:hover {
  margin: 0 -10px 0 10px;
}

.more-box a::before {
  content: "";
  display: block;
  float: left;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  border: solid var(--c1-120);
  border-width: 0 3px 3px 0;
  width: 20px;
  height: 20px;
  margin: 3px 10px 0 0;
}

.more-box a::after {
	content: "";
	position: absolute;
	opacity: .1;
	z-index: -10;
	transform: rotate(-45deg);
	-webkit-transform: rotate(-45deg);
	border: solid var(--c1-120);
	border-width: 0 40px 40px 0;
	width: 80px;
	height: 80px;
	top: 24%;
	left: 5%;
	transition: var(--transition-slow);
}

.more-box a:hover::after {
  margin: 0 -20px 0 20px;
}

.swiper-pagination {
  bottom: unset !important;
}

.swiper-pagination-bullet-active {
  background: var(--c1-100);
}

/* 0 - S */
@media (max-width: 599px) {

  .custom-post-slider .swiper-slide {
    flex-flow: column;
  }

  .custom-post-slider .listing-item, .custom-post-slider .more-box {
    width: 100%;
  }
}

/* M - XL */
@media (min-width: 600px) {
  
  .custom-post-slider .animated-book .post-thumbnail {
    left: 10%;
  }
  
  .custom-post-slider .side-image-blog .listing-item .post-thumbnail {
    max-width: 170px;
  }
  
  .custom-post-slider .side-image-blog .listing-item .listing-item-box {
    margin-left: 170px;
  }
  }



/* Book Animation */

.animated-book .post-thumbnail {
  width: 120px;
  height: 180px;
  position: relative;
  transform-style: preserve-3d;
  transform: rotateY(-20deg);
  transition: .5s ease;
  margin-bottom: 20px;
}

.animated-book .post-thumbnail::before {
  position: absolute;
  content: ' ';
  left: -80px;
  top: 3px;
  width: 21px;
  height: 173px;
  transform: translateX(184px) rotateY(90deg);
  background: linear-gradient(90deg, #ddd 0%, #ddd 5%, #ddd 10%, #ddd 15%, #ddd 20%, #ddd 25%, #ddd 30%, #ddd 35%, #ddd 40%, #ddd 45%, #ddd 50%, #ddd 55%, #ddd 60%, #ddd 65%, #ddd 70%, #ddd 75%, #ddd 80%, #ddd 85%, #ddd 90%, #ddd 95%, #ddd 100% );
}

.animated-book .post-thumbnail > :first-child {
  position: absolute;
  top: 0;
  left: 0;
  width: 120px;
  height: 180px;
  transform: translateZ(15px);
  background-color: #01060f;
  border-radius: 0 2px 2px 0;
  max-height: unset !important;
  box-shadow: var(--shadow-small);
}

.animated-book .post-thumbnail::after {
  position: absolute;
  top: 0;
  left: -4px;
  content: ' ';
  width: 120px;
  height: 180px;
  transform: translateZ(-15px);
  background-color: #01060f;
  border-radius: 0 2px 2px 0;
}

.animated-book:hover .post-thumbnail, .animated-book:focus .post-thumbnail {
  transform: rotateY(0deg);
}

.animated-book {
  perspective: 600px;
  display: block !important;
}



/* Lightbox */

.custom-lightbox-overlay img {
  animation: .3s 1 grow;
}

@keyframes grow {
  0% {
    opacity: 0;
    transform: scale(20%);
  }

  100% {
    opacity: 1;
    transform: scale(100%);
  }
}


/* GETWID */

.getwid-columns {
  margin-left: -10px;
  margin-right: -10px;
}

.getwid-columns > * {
  box-sizing: border-box;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.getwid-columns > * > div {
  height: 100%;
}

.wp-block-getwid-images-slider {
  cursor: grab;
}

.wp-block-getwid-images-slider:active {
  cursor: grabbing;
}



/* Toggle & Accordeon */

.wp-block-getwid-toggle__header, .wp-block-getwid-accordion__header {
  transition: var(--transition-fast);
  padding: .8em .8em;
  margin: 15px 0 0;
  background-color: var(--c0-t004);
}

.wp-block-getwid-toggle__header-wrapper a, .wp-block-getwid-accordion__header a {
  font-family: Light Title Font;
  font-size: 22px;
}

.wp-block-getwid-toggle__row.is-active .wp-block-getwid-toggle__header, .wp-block-getwid-toggle__header:hover, .ui-accordion-header-active .wp-block-getwid-accordion__header, .wp-block-getwid-accordion__header:hover {
  background-color: var(--c0-t006);
}

.wp-block-getwid-toggle__row.is-active .wp-block-getwid-toggle__header:hover, .ui-accordion-header-active .wp-block-getwid-accordion__header:hover {
  background-color: var(--c0-t008);
}

.wp-block-getwid-toggle__header-wrapper, .wp-block-getwid-toggle__row:first-child .wp-block-getwid-toggle__header-wrapper, .wp-block-getwid-toggle .wp-block-getwid-toggle__header-wrapper, .wp-block-getwid-accordion__header-wrapper, .wp-block-getwid-accordion .wp-block-getwid-accordion__header-wrapper:first-child, .wp-block-getwid-accordion .wp-block-getwid-accordion__header-wrapper, .wp-block-getwid-accordion__content, .wp-block-getwid-toggle__content {
  border: none;
}

.wp-block-getwid-toggle__content {
  padding: 20px 0 0 0;
}

.wp-block-getwid-accordion__content {
  padding: 30px;
}

.wp-block-getwid-toggle__content > .box  {
  margin-top: -20px;
  position: relative;
}

.wp-block-getwid-toggle__icon i.fa-plus::before, .wp-block-getwid-accordion__icon i.fa-plus::before {
  content: "";
  height: 10px;
  width: 10px;
  transform: rotate(45deg);
  transform-origin: 60% 60% 0px;
  transition: var(--transition-normal);
  display: inline-block;
  border-bottom: 3px solid var(--c2-100);
  border-right: 3px solid var(--c2-100);
}

.wp-block-getwid-toggle__header, .wp-block-getwid-accordion__header {
  box-sizing: border-box
}

.wp-block-getwid-toggle__row.is-active .wp-block-getwid-toggle__icon i.fa-plus::before, .ui-accordion-header-active  .wp-block-getwid-accordion__icon i.fa-plus::before {
  transform: rotate(225deg) !important;
}

.wp-block-getwid-toggle__row.is-active .wp-block-getwid-toggle__icon.is-active, .wp-block-getwid-accordion .wp-block-getwid-accordion__header-wrapper.ui-state-active .wp-block-getwid-accordion__icon.is-active {
  display: inline-block !important;
}

.wp-block-getwid-toggle__row.is-active .wp-block-getwid-toggle__icon.is-passive, .wp-block-getwid-accordion .wp-block-getwid-accordion__header-wrapper.ui-state-active .wp-block-getwid-accordion__icon.is-passive {
  display: none !important;
}

.wp-block-getwid-toggle, .wp-block-getwid-accordion {
  margin-bottom: 15px;
}




/* Kunden Slider */

.kunde-slider-bild, .slider-container, .kunden-slider {
  height: 80vh !important;
  height: calc(100vh - 120px) !important;
}

.full-width-template .page-content > .kunden-slider {
  width: 100%;
  max-width: unset;
  position: relative;
  background-color: black;
}

.slider-element {
  opacity: 0;
  z-index: 0;
  position: absolute;
  width: 100%;
  transition: var(--transition-slow);
}

.slider-element.active {
  opacity: 1;
  z-index: 10;
 }

.kunde-slider-bild img {
  height: 100%;
  width: 100%;
  opacity: .35;
  filter: grayscale(40%);
}

.kunde-content {
  position: absolute;
  width: 100%;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.kunde-zitat, .kunde-titel, .kunde-website {
  max-width: 1080px;
  width: 80%;
  margin: auto;
  text-align: center;
}

.kunde-zitat {
  font-family: Light Font;
  font-size: 24px;
  text-shadow: #000 0px 0px 15px;
}

.kunde-zitat:before {
  content: "«";
}

.kunde-zitat:after {
  content: "»";
}

.kunde-zitat:before, .kunde-zitat:after {
  font-size: 29px;
  line-height: 1;
  margin: 0 3px;
}

.kunde-zitat strong {
  color: var(--c1-100) !important;
  font-family: Regular Font;
  font-size: 30px;
  line-height: 0;
}

.kunde-titel {
  font-family: Regular Font;  
  font-size: 20px;
  margin: 20px auto;
}

.logo-container {
  bottom: 150px;
  display: flex;
  margin: 0 auto;
  max-width: 1080px;
  width: 80%;
  position: relative;
  z-index: 20;
}

.kunde-logo {
  background-color: #0006;
  padding: 20px;
  display: flex;
  margin: 0 5px;
  cursor: pointer;
  transition: var(--transition-normal);
  box-sizing: border-box;
}

.kunde-logo:hover, .kunde-logo.active {
  background-color: #ffffff1c;
}

.kunde-logo img {
  object-fit: contain;
} 

.slider-element.active .kunde-content.negative > * {
  animation: fadeInUp 1s ease-in-out;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  30% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}


/* 0 - S */
@media (max-width: 599px) {

.kunde-slider-bild, .slider-container, .kunden-slider {
  height: 800px !important;
}

.logo-container {
  flex-wrap: wrap;
}

.kunde-logo {
  width: 33.33%;
  margin: 0;
  padding: 10px;
}
}


/* Side Image Blog */

.side-image-blog .wp-block-getwid-template-post-title {
  margin-top: 0;
}

.side-image-blog .wp-block-column:first-child {
  max-width: 200px;
  float: left;
}

.side-image-blog .wp-block-column:not(:first-child) {
  margin-left: 0;
}

.side-image-blog .wp-block-getwid-template-post-featured-image {
  outline: 1px solid #00000010;
  outline-offset: -2px;
  margin-bottom: 15px;
  height: auto !important;
}

.side-image-blog .wp-block-getwid-template-post-featured-image img {
  height: auto !important;
}

.side-image-blog .post-thumbnail img {
  max-height: 250px;
}

.side-image-blog .wp-block-button {
  margin: 0 0 15px;
}

.side-image-blog .wp-block-getwid-template-post-content.is-excerpt p {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

/* 0 - S */
@media (max-width: 599px) {

.side-image-blog .wp-block-column:not(:first-child) {
  clear: both;
}
}



/* Contact Form */

input[type="text"]::placeholder, input[type="email"]::placeholder, input[type="tel"]::placeholder, input[type="number"]::placeholder, input[type="password"]::placeholder, input[type="url"]::placeholder, textarea::placeholder {
  color: var(--very-bright-font);
  font-family: Regular Font;
}

select {
  font-size: 16px;
  width: 100%;
  border: none;
  padding: 0 .6em;
  height: 40px;
  background-color: var(--c0-t006);
}

select option {
  background-color: #f0f0f0;
}

.wpcf7-list-item {
  margin: 0 20px 0 0;
}

input[type="checkbox"]:checked + ::before {
    background: var(--c1-100);
}

.wpcf7 .wpcf7-submit:disabled {
    color: #ffffff90;
}

form .list > * {
  width: 100%;
}

form .list {
  display: block;
}

.form-columns {
  display: flex;
  gap: 2%;
  flex-wrap: wrap;
}

input[type="file"] {
  margin: .5em;
}

.wpcf7 form.sent .wpcf7-response-output {
	border: unset;
	background: #46b450;
	margin: 0;
	color: #fff;
}

.wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output {
	border: unset;
	background: #e6b04a;
	margin: 0;
	color: #fff;
}

.wpcf7 form.sent .wpcf7-response-output::before,
.wpcf7 form.invalid .wpcf7-response-output::before, 
.wpcf7 form.unaccepted .wpcf7-response-output::before, 
.wpcf7 form.payment-required .wpcf7-response-output::before {
  font-family: Dashicons;
  position: relative;
  top: 2px;
  margin-right: 5px;
}

.wpcf7 form.invalid .wpcf7-response-output::before, 
.wpcf7 form.unaccepted .wpcf7-response-output::before, 
.wpcf7 form.payment-required .wpcf7-response-output::before {
  content: "\f534";
}

.wpcf7 form.sent .wpcf7-response-output::before {
  content: "\f12a";
}

/* M - XL */
@media (min-width: 600px) {

  .form-columns > * {
    flex-basis: 49%;
  }
}



/* Sitemap */

.neoven-sitemap li {
  list-style: none;
}

.neoven-sitemap li a {
  margin: 0px 0 0.7em 0;
  display: block;
}

.neoven-sitemap > li > a {
  font-family: Bold Font;
}




/* COOKIE BAR */

#cookie-notice {
  min-width: auto;
  right: 0;
  left: unset;
  background-color: var(--c1-130) !important;
  font-family: Light Font, sans-serif;
}

.cookie-notice-container, .cookie-revoke-container {
  padding: 7px 20px;
}

.cn-text-container {
  margin: 0;
}

.cn-close-icon::before, .cn-close-icon::after {
  background-color: #fff;
}

#cn-notice-buttons, #cn-revoke-buttons {
  margin-right: 10px;
  line-height: 1;
}

#cookie-notice a {
  background-color: var(--c1-150);
  color: #fff;
  padding: .4em .6em;
}

#cookie-notice a:hover {
  opacity: .6;
}

#cookie-notice a.cn-more-info {
  background-color: inherit;
}

body.cookies-accepted #cn-accept-cookie::after, body.cookies-refused #cn-refuse-cookie::after, body.cookies-not-set #cn-refuse-cookie::after
{
  background: var(--c1-080);
  position: absolute;
  font-family: dashicons;
  content: "\f15e";
  border-radius: 50%;
  margin: -5px 0 0 3px;
  color: #fff;
}

/* Block Notice */

.cookie-block-notice {
  background: var(--c0-010);
  text-align: center;
  padding: 30px;
}

.cookie-block-notice > * {
  margin: 0 0 .5em 0;
  color: var(--bright-font);
}

.cookie-block-notice > :not(.dashicons) {
  font-family: Light Font;
}

.cookie-block-notice a {
  background-color: var(--c1-070);
  color: #fff;
  padding: .3em .6em .2em;
}

.cookie-block-notice a:hover {
  background-color: var(--c1-090);
}



/* SEARCH AND FILTER */

.search-filter-input-group  {
  display: flex;
  gap: 0px 10px;
  flex-wrap: wrap;
}

.search-filter-input-checkbox input + ::before, .search-filter-input-checkbox__control, .search-filter-input-radio__control {
  display: none !important;
}

.search-filter-input-checkbox__container, .search-filter-input-radio__container {
  display: inline-block !important;
}

.search-filter-input-checkbox__container .search-filter-input-checkbox__label, .search-filter-input-radio__container .search-filter-input-radio__label {
  background-color: var(--c0-020);
  line-height: 1 !important;
  font-family: Light Font, sans-serif;
  padding: var(--tag-padding-medium) !important;
  pointer-events: all !important;
  border-radius: var(--corner-small);
  font-size: clamp(15px, 15px + .2vw, 19px);
}

.search-filter-input-checkbox__container 
.search-filter-input-checkbox__label:hover, 
.search-filter-input-checkbox__container 
.search-filter-input-checkbox__label:checked, 
.search-filter-input-radio__container .search-filter-input-radio__label:hover, 
.search-filter-input-radio__container .search-filter-input-radio__label:checked {
  background-color: var(--c0-030)
}

.search-filter-input-checkbox--is-active .search-filter-input-checkbox__container 
.search-filter-input-checkbox__label, 
.search-filter-input-radio--is-active .search-filter-input-radio__container 
.search-filter-input-radio__label {
  background-color: var(--c1-120);
  color: #fff;
}

.search-filter-input-checkbox__container .search-filter-input-checkbox__label,
.search-filter-input-radio__container .search-filter-input-radio__label {
  padding: 0;
}

.search-filter-query--fade-out {
  opacity: .7;
}


/*

.search-filter-disabled {
  opacity: .5;
}

.searchandfilter {
  display: inline-block;
  width: 100%;
  transition: var(--transition-normal);
}

.searchandfilter h4 {
  clear: both;
  font-size: 18px;
}

.searchandfilter select.sf-input-select {
  border: none;
  color: var(--dark-font) !important;
  line-height: 1;
  font-size: 14px !important;
  font-family: Regular Font;
  padding: var(--tag-padding-small);
  cursor: pointer;
  margin-bottom: 15px;
}

/* Checkbox *//*

.searchandfilter, .searchandfilter ul, .searchandfilter ul li {
  margin: 0;
  padding: 0;
}

.searchandfilter ul li li {
  margin: 0 10px 15px 0;
  padding: 0;
  float: left;
}

.searchandfilter .sf-count {
  color: var(--c0-030);
}

.searchandfilter input[type="checkbox"] + label::before {
  display: none;
}

label.sf-label-checkbox {
  color: var(--very-bright-font) !important;
  background-color: var(--c0-001);
  cursor: pointer;
  line-height: 1;
  font-size: 14px !important;
  font-family: Regular Font;
  padding: var(--tag-padding-medium) !important;
  clip-path: var(--tag-edges);
  pointer-events: all !important;
}

label.sf-label-checkbox:hover {
  color: var(--c2-100) !important;
  background-color: #fff;
}

.searchandfilter input[type="checkbox"]:checked + .sf-label-checkbox {
  background-color: var(--c2-099) !important;
  color: #fff !important;
}

.sf-input-select {
  background-color: #fff;
}

/* Serach bar *//*

.sf-field-search {
  width: calc(100% - 40px);
  max-width: 300px;
  float: left;
  clear: both;
}

.sf-field-search label {
  width: 100%;
}

.sf-field-search input {
  border: solid 1px var(--c0-020);
  height: 40px;
  font-size: 18px;
  padding: 9px !important;
  width: 100%;
  font-family: Regular Font;
  background-color: #fff;
  color: var(--dark-font);
}

.sf-field-submit {
  float: left;
  left: -1px;
  position: relative;
}

.sf-field-submit input {
  font-family: Dashicons;
  height: 40px;
  width: 40px;
  color: var(--c1-100);
  background-color: var(--c0-007);
  border: solid 1px var(--c0-020);
  border-left-color: transparent;
  padding: 0;
}

.sf-field-submit input:hover {
  color: var(--c1-100);
  background-color: var(--c0-010);
}
