/* -- import SCSS before variables (more see some lines down) -- */
/*
*	_mixins.scss
*	some mixins
*/
/* === clamp functions === */
/**
 *
 *	clamp-fontsize
 *
 *	@param $minSize - minimum fontsize on smallest viewport breatpoint in REM
 *	@param $maxSize - maximum fontsize on widest viewport breakpoint in REM
 *
 *	see: https://www.smashingmagazine.com/2022/10/fluid-typography-clamp-sass-functions/
 *	changes: input vars in REM instead of px
 *
 */
/**
 *
 *	clamp-margin
 *
 *	@param $minSize - minimum fontsize on smallest viewport breatpoint in REM
 *	@param $maxSize - maximum fontsize on widest viewport breakpoint in REM
 *
 *	see: https://www.smashingmagazine.com/2022/10/fluid-typography-clamp-sass-functions/
 *	changes: input vars in REM instead of px
 *
 */
/* === buttons === */
/* -- colors -- */
/*
:root {
	--color-primary-1: #1d1d1d;
	--color-primary-1-light: #373737;
	--color-primary-1-dark: #040404;
}
*/
/* -- fonts -- */
/* common weight name mapping
100	Thin (Hairline)
200	Extra Light (Ultra Light)
300	Light
400	Normal (Regular)
500	Medium
600	Semi Bold (Demi Bold)
700	Bold
800	Extra Bold (Ultra Bold)
900	Black (Heavy)
950	Extra Black (Ultra Black)
*/
/* -- breakpoints -- */
/* -- widths -- */
/* -- import SCSS (after variables) -- */
/* ===== reset css ===== */
html {
  padding: 0;
  border: 0;
  /*overflow-y: scroll;*/
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
  scroll-padding: 6rem;
}

* {
  letter-spacing: 0px;
  margin: 0;
  padding: 0;
  border: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  vertical-align: top;
  text-rendering: auto;
  -webkit-text-size-adjust: none;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis-weight: none; /* fix apple problems with variable fonts */
}

body {
  font-weight: inherit;
  font-style: inherit;
  vertical-align: baseline;
  margin: 0;
  padding: 0;
  border: 0;
}

div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, code, del, dfn, em, img, q, dl, dt, dd, ol, ul, li, form, fieldset, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, nav, section {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: inherit;
  font-style: inherit;
  vertical-align: baseline;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section, form {
  display: block;
}

table {
  border-collapse: separate;
  border-spacing: 0;
  vertical-align: middle;
}
table th, table td {
  text-align: left;
  font-weight: normal;
  float: none !important;
  vertical-align: middle;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
}

blockquote, q {
  quotes: "" "";
}

a img {
  border: none;
}

:focus {
  outline: 0;
}

.clearfix:before,
.clearfix:after {
  content: " "; /* 1 */
  display: table; /* 2 */
}

.clearfix:after {
  clear: both;
}

/*
*	plugin: elementor
*/
/* === entrance animations === */
/* -- fadeInUp -- */
@-webkit-keyframes KrfadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 30px, 0);
            transform: translate3d(0, 30px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
@keyframes KrfadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 30px, 0);
            transform: translate3d(0, 30px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
.fadeInUp {
  -webkit-animation-name: KrfadeInUp !important;
          animation-name: KrfadeInUp !important;
}

/* -- fadeInDown -- */
@-webkit-keyframes KrfadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -30px, 0);
            transform: translate3d(0, -30px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
@keyframes KrfadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -30px, 0);
            transform: translate3d(0, -30px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
.fadeInDown {
  -webkit-animation-name: KrfadeInDown !important;
          animation-name: KrfadeInDown !important;
}

/* -- fadeInRight -- */
@-webkit-keyframes KrfadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(30px, 0, 0);
            transform: translate3d(30px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
@keyframes KrfadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(30px, 0, 0);
            transform: translate3d(30px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
.fadeInRight {
  -webkit-animation-name: KrfadeInRight !important;
          animation-name: KrfadeInRight !important;
}

/* -- fadeInLeft -- */
@-webkit-keyframes KrfadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-30px, 0, 0);
            transform: translate3d(-30px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
@keyframes KrfadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-30px, 0, 0);
            transform: translate3d(-30px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
.fadeInLeft {
  -webkit-animation-name: KrfadeInLeft !important;
          animation-name: KrfadeInLeft !important;
}

/* === elementor: boxed container === */
.e-con-boxed {
  padding-left: 0% !important;
  padding-right: 0% !important;
  scroll-margin-top: 4rem;
}
.e-con-boxed .e-con-inner {
  padding-left: 10% !important;
  padding-right: 10% !important;
}
@media screen and (min-width: 1024px) {
  .e-con-boxed {
    padding-left: 7% !important;
    padding-right: 7% !important;
  }
  .e-con-boxed .e-con-inner {
    padding-left: 0% !important;
    padding-right: 0% !important;
  }
}
@media screen and (max-width: 1024px) {
  .e-con-boxed .e-con-inner {
    padding-left: 7% !important;
    padding-right: 7% !important;
  }
}

/* === elementor: images === */
.elementor-widget-image img {
  vertical-align: top !important; /* needed for safari browser */
}

.elementor-image a {
  display: block;
}

/* === elementor: buttons === */
/* -- General -- */
.elementor-menu-cart__wrapper,
.elementor-menu-cart__toggle_wrapper,
.elementor-button-wrapper {
  line-height: 100% !important;
}

/* -- "Information" -- */
.elementor-button-info .elementor-button,
.btn-type-1 .elementor-button {
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button-info .elementor-button .elementor-button-icon,
.elementor-button-info .elementor-button .elementor-button-text,
.btn-type-1 .elementor-button .elementor-button-icon,
.btn-type-1 .elementor-button .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-info .elementor-button .elementor-button-icon svg,
.elementor-button-info .elementor-button .elementor-button-text svg,
.btn-type-1 .elementor-button .elementor-button-icon svg,
.btn-type-1 .elementor-button .elementor-button-text svg {
  fill: #ffffff !important;
}
.elementor-button-info .elementor-button:hover,
.btn-type-1 .elementor-button:hover {
  background-color: #040404 !important;
  border: 1px solid #040404 !important;
}
.elementor-button-info .elementor-button:hover .elementor-button-icon,
.elementor-button-info .elementor-button:hover .elementor-button-text,
.btn-type-1 .elementor-button:hover .elementor-button-icon,
.btn-type-1 .elementor-button:hover .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-info .elementor-button:hover .elementor-button-icon svg,
.elementor-button-info .elementor-button:hover .elementor-button-text svg,
.btn-type-1 .elementor-button:hover .elementor-button-icon svg,
.btn-type-1 .elementor-button:hover .elementor-button-text svg {
  fill: #ffffff !important;
}
.elementor-button-info .elementor-button:focus, .elementor-button-info .elementor-button:active,
.btn-type-1 .elementor-button:focus,
.btn-type-1 .elementor-button:active {
  background-color: #1d1d1d !important;
  border: 1px double #1d1d1d !important;
}
.elementor-button-info .elementor-button:focus .elementor-button-icon,
.elementor-button-info .elementor-button:focus .elementor-button-text, .elementor-button-info .elementor-button:active .elementor-button-icon,
.elementor-button-info .elementor-button:active .elementor-button-text,
.btn-type-1 .elementor-button:focus .elementor-button-icon,
.btn-type-1 .elementor-button:focus .elementor-button-text,
.btn-type-1 .elementor-button:active .elementor-button-icon,
.btn-type-1 .elementor-button:active .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-info .elementor-button:focus .elementor-button-icon svg,
.elementor-button-info .elementor-button:focus .elementor-button-text svg, .elementor-button-info .elementor-button:active .elementor-button-icon svg,
.elementor-button-info .elementor-button:active .elementor-button-text svg,
.btn-type-1 .elementor-button:focus .elementor-button-icon svg,
.btn-type-1 .elementor-button:focus .elementor-button-text svg,
.btn-type-1 .elementor-button:active .elementor-button-icon svg,
.btn-type-1 .elementor-button:active .elementor-button-text svg {
  fill: #ffffff !important;
}

/* -- "Erfolgsmeldung" -- */
.elementor-button-success .elementor-button,
.btn-type-2 .elementor-button {
  background-color: #ffffff !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button-success .elementor-button .elementor-button-icon,
.elementor-button-success .elementor-button .elementor-button-text,
.btn-type-2 .elementor-button .elementor-button-icon,
.btn-type-2 .elementor-button .elementor-button-text {
  color: #1d1d1d !important;
  font-weight: 400 !important;
}
.elementor-button-success .elementor-button .elementor-button-icon svg,
.elementor-button-success .elementor-button .elementor-button-text svg,
.btn-type-2 .elementor-button .elementor-button-icon svg,
.btn-type-2 .elementor-button .elementor-button-text svg {
  fill: #1d1d1d !important;
}
.elementor-button-success .elementor-button:hover,
.btn-type-2 .elementor-button:hover {
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button-success .elementor-button:hover .elementor-button-icon,
.elementor-button-success .elementor-button:hover .elementor-button-text,
.btn-type-2 .elementor-button:hover .elementor-button-icon,
.btn-type-2 .elementor-button:hover .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-success .elementor-button:hover .elementor-button-icon svg,
.elementor-button-success .elementor-button:hover .elementor-button-text svg,
.btn-type-2 .elementor-button:hover .elementor-button-icon svg,
.btn-type-2 .elementor-button:hover .elementor-button-text svg {
  fill: #ffffff !important;
}
.elementor-button-success .elementor-button:focus, .elementor-button-success .elementor-button:active,
.btn-type-2 .elementor-button:focus,
.btn-type-2 .elementor-button:active {
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button-success .elementor-button:focus .elementor-button-icon,
.elementor-button-success .elementor-button:focus .elementor-button-text, .elementor-button-success .elementor-button:active .elementor-button-icon,
.elementor-button-success .elementor-button:active .elementor-button-text,
.btn-type-2 .elementor-button:focus .elementor-button-icon,
.btn-type-2 .elementor-button:focus .elementor-button-text,
.btn-type-2 .elementor-button:active .elementor-button-icon,
.btn-type-2 .elementor-button:active .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-success .elementor-button:focus .elementor-button-icon svg,
.elementor-button-success .elementor-button:focus .elementor-button-text svg, .elementor-button-success .elementor-button:active .elementor-button-icon svg,
.elementor-button-success .elementor-button:active .elementor-button-text svg,
.btn-type-2 .elementor-button:focus .elementor-button-icon svg,
.btn-type-2 .elementor-button:focus .elementor-button-text svg,
.btn-type-2 .elementor-button:active .elementor-button-icon svg,
.btn-type-2 .elementor-button:active .elementor-button-text svg {
  fill: #ffffff !important;
}

/* -- "Warnung" -- */
.elementor-button-warning .elementor-button,
.btn-type-3 .elementor-button {
  background-color: #ffffff !important;
  border: 1px solid #3c3c3b !important;
}
.elementor-button-warning .elementor-button .elementor-button-icon,
.elementor-button-warning .elementor-button .elementor-button-text,
.btn-type-3 .elementor-button .elementor-button-icon,
.btn-type-3 .elementor-button .elementor-button-text {
  color: #3c3c3b !important;
  font-weight: 400 !important;
}
.elementor-button-warning .elementor-button .elementor-button-icon svg,
.elementor-button-warning .elementor-button .elementor-button-text svg,
.btn-type-3 .elementor-button .elementor-button-icon svg,
.btn-type-3 .elementor-button .elementor-button-text svg {
  fill: #3c3c3b !important;
}
.elementor-button-warning .elementor-button:hover,
.btn-type-3 .elementor-button:hover {
  background-color: #3c3c3b !important;
  border: 1px solid #3c3c3b !important;
}
.elementor-button-warning .elementor-button:hover .elementor-button-icon,
.elementor-button-warning .elementor-button:hover .elementor-button-text,
.btn-type-3 .elementor-button:hover .elementor-button-icon,
.btn-type-3 .elementor-button:hover .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-warning .elementor-button:hover .elementor-button-icon svg,
.elementor-button-warning .elementor-button:hover .elementor-button-text svg,
.btn-type-3 .elementor-button:hover .elementor-button-icon svg,
.btn-type-3 .elementor-button:hover .elementor-button-text svg {
  fill: #ffffff !important;
}
.elementor-button-warning .elementor-button:focus, .elementor-button-warning .elementor-button:active,
.btn-type-3 .elementor-button:focus,
.btn-type-3 .elementor-button:active {
  background-color: #3c3c3b !important;
  border: 1px solid #3c3c3b !important;
}
.elementor-button-warning .elementor-button:focus .elementor-button-icon,
.elementor-button-warning .elementor-button:focus .elementor-button-text, .elementor-button-warning .elementor-button:active .elementor-button-icon,
.elementor-button-warning .elementor-button:active .elementor-button-text,
.btn-type-3 .elementor-button:focus .elementor-button-icon,
.btn-type-3 .elementor-button:focus .elementor-button-text,
.btn-type-3 .elementor-button:active .elementor-button-icon,
.btn-type-3 .elementor-button:active .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button-warning .elementor-button:focus .elementor-button-icon svg,
.elementor-button-warning .elementor-button:focus .elementor-button-text svg, .elementor-button-warning .elementor-button:active .elementor-button-icon svg,
.elementor-button-warning .elementor-button:active .elementor-button-text svg,
.btn-type-3 .elementor-button:focus .elementor-button-icon svg,
.btn-type-3 .elementor-button:focus .elementor-button-text svg,
.btn-type-3 .elementor-button:active .elementor-button-icon svg,
.btn-type-3 .elementor-button:active .elementor-button-text svg {
  fill: #ffffff !important;
}

/* -- "Gefahr" -- */
/* === elementor: gallery === */
a.elementor-gallery-item {
  border: 0 !important;
}

.pp-icon i,
.pp-icon svg {
  line-height: 1;
}

/* === elementor: loops === */
.last-element-in-row .elementor-loop-container .e-loop-item .e-flex .elementor-element:last-child {
  margin-top: auto;
}

/* === elementor: popups === */
.dialog-lightbox-message {
  max-width: 1440px !important;
}

.elementor-widget-off-canvas .e-off-canvas__content {
  max-width: 1440px !important;
}

.popop-small .dialog-lightbox-message {
  max-width: 768px !important;
}

/*
*	plugin: forms (incl. woocommerce aso.)
*/
/* === general === */
/* -- disable browser's plus/minus @ number inputs */
/*
input[type=number] {
	-moz-appearance: textfield;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
*/
input,
select,
textarea,
.woocommerce form .form-row .input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  font-family: "Nunito Sans", Arial, Verdana, sans-serif;
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 130%;
  color: #3c3c3b;
  background-color: #ffffff !important;
  padding: 0.55rem 1rem 0.5rem 1rem !important;
  border: 1px solid #3c3c3b !important;
}
input:hover,
select:hover,
textarea:hover,
.woocommerce form .form-row .input-text:hover,
.woocommerce form .form-row select:hover,
.woocommerce form .form-row textarea:hover {
  border: 1px solid #1d1d1d !important;
}
input:focus,
select:focus,
textarea:focus,
.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  border: 1px solid #1d1d1d !important;
}

.ff-message-success {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  border: none !important;
}

.elementor-button[type=submit] {
  background-color: #ffffff !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button[type=submit] .elementor-button-icon,
.elementor-button[type=submit] .elementor-button-text {
  color: #1d1d1d !important;
  font-weight: 400 !important;
}
.elementor-button[type=submit] .elementor-button-icon svg,
.elementor-button[type=submit] .elementor-button-text svg {
  fill: #1d1d1d !important;
}
.elementor-button[type=submit]:hover {
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button[type=submit]:hover .elementor-button-icon,
.elementor-button[type=submit]:hover .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button[type=submit]:hover .elementor-button-icon svg,
.elementor-button[type=submit]:hover .elementor-button-text svg {
  fill: #ffffff !important;
}
.elementor-button[type=submit]:focus, .elementor-button[type=submit]:active {
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
.elementor-button[type=submit]:focus .elementor-button-icon,
.elementor-button[type=submit]:focus .elementor-button-text, .elementor-button[type=submit]:active .elementor-button-icon,
.elementor-button[type=submit]:active .elementor-button-text {
  color: #ffffff !important;
}
.elementor-button[type=submit]:focus .elementor-button-icon svg,
.elementor-button[type=submit]:focus .elementor-button-text svg, .elementor-button[type=submit]:active .elementor-button-icon svg,
.elementor-button[type=submit]:active .elementor-button-text svg {
  fill: #ffffff !important;
}

.elementor-button-align-start .elementor-field-type-submit {
  -webkit-box-pack: end !important;
      -ms-flex-pack: end !important;
          justify-content: flex-end !important;
}

/* === form "secured download" === */
.dl-error {
  font-size: 0.9rem;
  font-weight: 500;
  color: #ffffff;
  background: #1d1d1d;
  padding: 0.25rem 0.75rem;
  margin-top: 0.25rem;
}

/* -- input placeholder -- */
::-webkit-input-placeholder,
:-moz-placeholder,
::-moz-placeholder,
:-ms-input-placeholder { /* Internet Explorer 10+ */
  font-family: "Nunito Sans", Arial, Verdana, sans-serif !important;
  font-weight: 400 !important;
  color: #3c3c3b !important;
}

:focus::-webkit-input-placeholder,
:focus:-moz-placeholder,
:focus::-moz-placeholder,
:focus:-ms-input-placeholder { /* Internet Explorer 10+ */
  color: #3c3c3b !important;
}

/* -- scrollbars -- */
::-webkit-scrollbar {
  width: 12px;
  background: #3c3c3b;
}

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: #1d1d1d;
}

::marker {
  color: #1d1d1d;
}

/* -- general -- */
body {
  background: #ffffff;
  overflow-x: hidden;
}
body img,
body object {
  width: auto;
  max-width: 100%;
  height: auto;
}
body strong {
  font-weight: 500 !important;
}

/* -- paddings / margins -- */
.no-padding-top {
  padding-top: 0 !important;
}

.no-padding-bottom {
  padding-bottom: 0 !important;
}

.no-margin {
  margin: 0 !important;
}
.no-margin .elementor-heading-title {
  margin: 0 !important;
}

.no-margin-top {
  margin-top: 0 !important;
}
.no-margin-top .elementor-heading-title {
  margin-top: 0 !important;
}

.no-margin-bottom {
  margin-bottom: 0 !important;
}
.no-margin-bottom .elementor-heading-title,
.no-margin-bottom h1,
.no-margin-bottom h2,
.no-margin-bottom h3,
.no-margin-bottom h4,
.no-margin-bottom h5,
.no-margin-bottom div,
.no-margin-bottom p {
  margin-bottom: 0 !important;
}

/* -- corner / border effects -- */
.roundcorner-sm-tl {
  overflow: hidden;
  border-radius: 0.5rem;
  border-top-left-radius: 0;
}

.roundcorner-sm-tr {
  overflow: hidden;
  border-radius: 0.5rem;
  border-top-right-radius: 0;
}

.roundcorner-sm-br {
  overflow: hidden;
  border-radius: 0.5rem;
  border-bottom-right-radius: 0;
}

.roundcorner-sm-bl {
  overflow: hidden;
  border-radius: 0.5rem;
  border-bottom-left-radius: 0;
}

.width-fit-content {
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
  /*
  &.tablet {
  	@media screen and (max-width: $breakpoint-1024 ) {

  		width: 100% !important;
  	}
  }
  */
}
@media screen and (max-width: 1024px) {
  .width-fit-content.desktop {
    width: 100% !important;
  }
}

#scroll-top {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  display: none;
  position: fixed;
  bottom: 2.5rem;
  right: 1rem;
  z-index: 999999;
  width: 36px;
  height: 36px;
  text-align: center;
  color: #ffffff;
  background: #3c3c3b;
  border: 0;
  border-radius: 0;
}
#scroll-top i {
  font-size: 1rem;
  line-height: 2.25rem;
  color: #ffffff;
}
#scroll-top:hover {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  background: #1d1d1d;
}
#scroll-top:hover i {
  color: #ffffff;
}

/* -- buttons -- */
button,
.btn,
.button,
.elementor-button {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  display: -webkit-inline-box !important;
  display: -ms-inline-flexbox !important;
  display: inline-flex !important;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.9rem;
  font-weight: 400 !important;
  line-height: 130% !important;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none;
  color: #1d1d1d;
  background-color: #ffffff;
  cursor: pointer;
  padding: 0.55rem 1rem 0.5rem 1rem !important;
  border-radius: 0 !important;
  border: 1px solid #1d1d1d;
}
button a,
button a.elementor-button,
button a .elementor-button-text,
.btn a,
.btn a.elementor-button,
.btn a .elementor-button-text,
.button a,
.button a.elementor-button,
.button a .elementor-button-text,
.elementor-button a,
.elementor-button a.elementor-button,
.elementor-button a .elementor-button-text {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 400;
  line-height: 130% !important;
  letter-spacing: 1px !important;
  text-transform: uppercase;
  text-decoration: none !important;
  color: #1d1d1d !important;
}
button a:hover,
button a.elementor-button:hover,
button a .elementor-button-text:hover,
.btn a:hover,
.btn a.elementor-button:hover,
.btn a .elementor-button-text:hover,
.button a:hover,
.button a.elementor-button:hover,
.button a .elementor-button-text:hover,
.elementor-button a:hover,
.elementor-button a.elementor-button:hover,
.elementor-button a .elementor-button-text:hover {
  text-decoration: none !important;
}
button .elementor-button-icon,
button .elementor-button-text,
.btn .elementor-button-icon,
.btn .elementor-button-text,
.button .elementor-button-icon,
.button .elementor-button-text,
.elementor-button .elementor-button-icon,
.elementor-button .elementor-button-text {
  font-size: 0.9rem;
  color: #1d1d1d !important;
  font-weight: 400 !important;
  line-height: 130% !important;
  letter-spacing: 1px !important;
  text-transform: uppercase;
}
button .elementor-button-icon .e-font-icon-svg,
button .elementor-button-text .e-font-icon-svg,
.btn .elementor-button-icon .e-font-icon-svg,
.btn .elementor-button-text .e-font-icon-svg,
.button .elementor-button-icon .e-font-icon-svg,
.button .elementor-button-text .e-font-icon-svg,
.elementor-button .elementor-button-icon .e-font-icon-svg,
.elementor-button .elementor-button-text .e-font-icon-svg {
  height: 0.9rem;
}
button .elementor-button-icon svg,
button .elementor-button-text svg,
.btn .elementor-button-icon svg,
.btn .elementor-button-text svg,
.button .elementor-button-icon svg,
.button .elementor-button-text svg,
.elementor-button .elementor-button-icon svg,
.elementor-button .elementor-button-text svg {
  fill: #1d1d1d !important;
}
button i,
.btn i,
.button i,
.elementor-button i {
  font-size: 0.9rem;
}
button > i,
.btn > i,
.button > i,
.elementor-button > i {
  margin-right: 0.5rem;
}
button:hover,
.btn:hover,
.button:hover,
.elementor-button:hover {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  color: #ffffff;
  background-color: #1d1d1d !important;
  border: 1px solid #1d1d1d !important;
}
button:hover span,
.btn:hover span,
.button:hover span,
.elementor-button:hover span {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  color: #ffffff;
}

#page-wrapper {
  *zoom: 1;
  position: relative;
  width: 100%;
  background: #ffffff;
  margin: 0 auto !important;
}
#page-wrapper::before, #page-wrapper::after {
  content: "";
  display: table;
}
#page-wrapper::after {
  clear: both;
}

#main-content {
  *zoom: 1;
  position: relative;
  padding-bottom: 5rem;
}
#main-content::before, #main-content::after {
  content: "";
  display: table;
}
#main-content::after {
  clear: both;
}
#main-content ul,
#main-content ol {
  padding-bottom: 0.5rem;
}
#main-content ul li,
#main-content ol li {
  margin: 0 0 5px 1.25rem;
}
#main-content ul {
  list-style-type: square;
}
#main-content .elementor-text-editor,
#main-content p,
#main-content li {
  margin-bottom: 1.25rem;
}
#main-content .text-small,
#main-content .text-small * {
  font-size: 0.9rem;
  line-height: 130%;
  color: #3c3c3b;
}

p a {
  font-size: inherit !important;
}

/* === images === */
.wp-caption {
  background: none;
  border: 0;
  max-width: unset;
  padding: 0;
}
.wp-caption .wp-caption-text {
  font-size: 0.75rem;
  font-weight: 300;
  margin-top: 0.5rem;
}

/* === header === */
header {
  position: sticky;
  top: 0;
  z-index: 9999;
  width: 100%;
  background: #ffffff;
  padding: 1.5rem 0 1rem 0;
}
header a {
  text-decoration: none !important;
}
header #logo a {
  display: block;
}
header #logo a svg {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  width: 100%;
  height: 4rem !important;
}
header #mainnav-wrapper {
  position: relative;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul {
  -webkit-column-gap: 0rem !important;
     -moz-column-gap: 0rem !important;
          column-gap: 0rem !important;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  -webkit-transform: skewX(-27deg);
          transform: skewX(-27deg);
  margin: 0 !important;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > a {
  -webkit-transform: skewX(27deg);
          transform: skewX(27deg);
  font-family: "Nunito Sans", Arial, Verdana, sans-serif;
  font-size: clamp(1.15rem, 0.5vw + 1.05rem, 1.5rem);
  font-weight: 700;
  line-height: 140%;
  color: #3c3c3b;
  padding: 0.35rem 1.25rem 0.3rem 1.25rem;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > a .sub-arrow {
  fill: #3c3c3b;
  padding-left: 0.5rem !important;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li:hover {
  background: #1d1d1d;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li:hover a {
  color: #ffffff;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li.current-menu-item, header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li.current-menu-parent {
  background: #1d1d1d;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li.current-menu-item > a, header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li.current-menu-parent > a {
  color: #ffffff;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > ul li a {
  font-size: 0.9rem;
  font-weight: 300;
  color: #3c3c3b;
  padding: 0.5rem 1rem;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > ul li:hover a {
  color: #1d1d1d;
}
header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > ul li.current-menu-item > a, header #mainnav-wrapper #mainnav .pp-advanced-menu-main-wrapper ul > li > ul li.current-menu-parent > a {
  color: #1d1d1d;
}
header.sticky {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  padding: 0.75rem 0 0.75rem 0;
  -webkit-box-shadow: -10px 0 20px 1px rgba(0, 0, 0, 0.4);
          box-shadow: -10px 0 20px 1px rgba(0, 0, 0, 0.4);
}
header.sticky #logo a svg {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  height: 3rem !important;
}
@media screen and (max-width: 768px) {
  header {
    /*
    .e-con-boxed {
    	.e-con-inner {
    		padding-left: 5% !important;
    		padding-right: 10% !important;
    	}
    }
    */
  }
}

.headbanner .swiper-slide-inner {
  max-width: 1920px;
  padding-left: 7% !important;
  padding-right: 7% !important;
}
.headbanner .swiper-slide-inner .swiper-slide-contents .elementor-slide-heading {
  white-space: nowrap;
}

/* === contact badge right === */
#contact-badge-right {
  position: fixed;
  top: 50%;
  right: 50;
  z-index: 99999;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
/* === mainnav mobile === */
.pp-menu-toggle {
  background: #e7e7e7;
}

.pp-menu-off-canvas {
  width: 80vw !important;
  max-width: 380px !important;
}
.pp-menu-off-canvas.pp-advanced-menu--dropdown.pp-menu-off-canvas-right {
  margin-bottom: 1rem !important;
}
.pp-menu-off-canvas.pp-advanced-menu--dropdown.pp-menu-off-canvas-right .pp-menu-close-wrap {
  left: auto !important;
  right: 2rem !important;
}
.pp-menu-off-canvas .pp-advanced-menu li {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  margin: 0rem 1.5rem 0.35rem 1.5rem !important;
  border-bottom: 1px solid #e7e7e7;
}
.pp-menu-off-canvas .pp-advanced-menu li > a {
  -webkit-column-gap: 1.5rem;
     -moz-column-gap: 1.5rem;
          column-gap: 1.5rem;
  font-size: 1.125rem !important;
  font-weight: 500 !important;
  color: #3c3c3b !important;
  text-decoration: none !important;
  padding: 0.5rem 0.5rem 0.75rem 0.5rem !important;
}
.pp-menu-off-canvas .pp-advanced-menu li > a .sub-arrow {
  font-size: 1rem;
  fill: #3c3c3b !important;
  background: #3c3c3b;
  padding: 0.5rem;
}
.pp-menu-off-canvas .pp-advanced-menu li.current-menu-item > a, .pp-menu-off-canvas .pp-advanced-menu li.current-menu-parent > a {
  color: #1d1d1d;
}
.pp-menu-off-canvas .pp-advanced-menu li > ul {
  padding: 0 0.5rem 0 1rem;
}
.pp-menu-off-canvas .pp-advanced-menu li > ul li {
  margin-bottom: 0 !important;
}
.pp-menu-off-canvas .pp-advanced-menu li > ul li a {
  padding: 0.5rem 0.5rem 0.5rem 0.5rem !important;
}
.pp-menu-off-canvas .pp-advanced-menu li > ul li:hover a {
  background: #ffffff !important;
}
.pp-menu-off-canvas .pp-advanced-menu li > ul li:last-child {
  border-bottom: none !important;
}

/* === headlines === */
.topline .elementor-heading-title {
  font-size: 0.9rem;
  letter-spacing: 0.15rem;
  text-align: center;
  text-transform: uppercase;
  color: #3c3c3b;
  margin-bottom: 2rem !important;
}

h1,
h1.elementor-heading-title {
  position: relative;
  text-shadow: 0 0 1.5rem rgba(0, 0, 0, 0.25);
  margin-top: 0rem;
  margin-bottom: 2.5rem;
}

.elementor-widget-heading:has(h1) + .elementor-widget-heading:has(h2) h2:first-of-type,
.elementor-widget-heading:has(h1) + .elementor-widget-text-editor h2:first-of-type {
  margin-top: 0;
}

h2,
h2.elementor-heading-title {
  position: relative;
  margin-top: 3rem;
  margin-bottom: 1.5rem;
}

h3,
h3.elementor-heading-title {
  margin-top: 2rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  h3,
  h3.elementor-heading-title {
    margin-bottom: 0.75rem;
  }
}

.topline + .elementor-widget-heading:has(h3) h3 {
  margin-top: 0;
}

h4,
h4.elementor-heading-title {
  margin-top: 0rem;
  margin-bottom: 0.5rem;
}

h1 a,
h2 a,
h3 a,
h4 a {
  text-decoration: none !important;
}

/* === links === */
a:not(.btn):not(.button):not(.elementor-button):not(.woocommerce-MyAccount-navigation a):not(.widget_shopping_cart_content a):not(.woocommerce .shop_table a):not(.woocommerce .products a):not(.product_title a) {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  position: relative;
  cursor: pointer;
  -webkit-text-decoration: underline 1px dotted #3c3c3b;
          text-decoration: underline 1px dotted #3c3c3b;
  text-underline-offset: 3px;
}
a:not(.btn):not(.button):not(.elementor-button):not(.woocommerce-MyAccount-navigation a):not(.widget_shopping_cart_content a):not(.woocommerce .shop_table a):not(.woocommerce .products a):not(.product_title a) i.fa {
  vertical-align: baseline;
}
a:not(.btn):not(.button):not(.elementor-button):not(.woocommerce-MyAccount-navigation a):not(.widget_shopping_cart_content a):not(.woocommerce .shop_table a):not(.woocommerce .products a):not(.product_title a):hover {
  -webkit-transition: all 0.25s ease-in-out !important;
  transition: all 0.25s ease-in-out !important;
  -webkit-text-decoration: underline 1px solid #1d1d1d;
          text-decoration: underline 1px solid #1d1d1d;
}
a:not(.btn):not(.button):not(.elementor-button):not(.woocommerce-MyAccount-navigation a):not(.widget_shopping_cart_content a):not(.woocommerce .shop_table a):not(.woocommerce .products a):not(.product_title a).no-style {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  text-decoration: none !important;
}
a:not(.btn):not(.button):not(.elementor-button):not(.woocommerce-MyAccount-navigation a):not(.widget_shopping_cart_content a):not(.woocommerce .shop_table a):not(.woocommerce .products a):not(.product_title a).no-style:hover {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  text-decoration: none !important;
}

.no-style * {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  text-decoration: none !important;
}
.no-style *:hover {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  text-decoration: none !important;
}

.no-wrap {
  white-space: nowrap;
}

/* === individual content === */
.headerslider .pp-image-slider {
  max-height: 100vh;
}

/* === grids === */
.e-con-boxed.grid-66-33 .e-con-inner {
  -webkit-box-pack: justify !important;
      -ms-flex-pack: justify !important;
          justify-content: space-between !important;
  -webkit-column-gap: 4rem !important;
     -moz-column-gap: 4rem !important;
          column-gap: 4rem !important;
  row-gap: 3rem !important;
}
.e-con-boxed.grid-66-33 .e-con-inner .e-child:first-child {
  width: 66%;
  border: 1px solid red;
}
.e-con-boxed.grid-66-33 .e-con-inner .e-child:last-child {
  width: 33%;
  border: 1px solid green;
}

.shop-cat-button-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 5rem 1fr 5rem 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem 5rem;
  justify-items: stretch;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.shop-cat-button-grid a.grid-button {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  overflow: hidden;
  -webkit-transform: skewX(-27deg);
          transform: skewX(-27deg);
  width: 100%;
  height: auto;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(1.15rem, 0.5vw + 1.05rem, 1.5rem);
  line-height: 120%;
  text-align: center;
  font-weight: 700;
  color: #ffffff;
  background: #1d1d1d;
  padding: 1.5rem 3rem;
  text-decoration: none !important;
}
.shop-cat-button-grid a.grid-button span {
  display: inline-block;
  -webkit-transform: skewX(27deg);
          transform: skewX(27deg);
}
.shop-cat-button-grid a.grid-button:hover {
  background: #737373;
}
@media screen and (max-width: 1024px) {
  .shop-cat-button-grid {
    -ms-grid-columns: 1fr 4rem 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem 4rem;
  }
}
@media screen and (max-width: 768px) {
  .shop-cat-button-grid {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    row-gap: 2rem;
  }
}

/* === footer === */
footer#footer-wrapper {
  /*
  .footer-copy {
  	font-size: 0.9rem;
  	line-height: 130%;
  	font-weight: 400;
  	color: $color-white;
  	text-align: center;
  }

  .footer-nav {
  	ul.elementor-nav-menu {
  		li {
  			//margin-bottom: 1rem;

  			a {
  				@include transition-effect-all;

  				font-size: 0.9rem;
  				line-height: 130% !important;
  				font-weight: 400;
  				color: $color-white !important;
  				padding: 0;
  				text-decoration: underline 1px solid transparent;
  				text-underline-offset: 3px;


  				&:hover {
  					@include transition-effect-all;

  					color: $color-primary-1 !important;
  					padding: 0;
  					text-decoration: underline 1px solid $color-white;
  				}
  			}

  			&.hide {
  				display: none !important;
  			}
  		}
  	}
  }
  */
}
footer#footer-wrapper a {
  text-decoration: none;
}