@charset "UTF-8";
/* -- CSS Document -- */
/* --	# author      Julian Heinicke -- */

/* montserrat-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  src: url('montserrat/montserrat-v26-latin-200.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-200italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 200;
  src: url('montserrat/montserrat-v26-latin-200italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('montserrat/montserrat-v26-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('montserrat/montserrat-v26-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

:root {
  --bs-danger-lighter: #e52d3f;
}
/***** text markierungs farben *****/
::-moz-selection {
  color: var(--bs-light);
  background: var(--bs-danger);
}
::selection {
  color: var(--bs-light);
  background: var(--bs-danger);
}

/* -- browser reset -- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  background-color: #030303 !important;
  
}
body {
  position: relative;
  -ms-overflow-style: none !important;  /* IE and Edge */
  scrollbar-width: none !important;  /* Firefox */
  text-shadow: 8px 8px 8px #03030381 !important;
  font-family: 'Montserrat', sans-serif !important;
}
body::-webkit-scrollbar {
  display: none !important;
}
body.modal-open {
  overflow: hidden !important;
  }

/* -- Helpers-- */
.small {
  font-size: 12px;
}
.lead {
  font-size: 1.4rem;
}
.btn-outline-light {
  font-weight: 200 !important;
}
@media screen and (max-width: 767px) {
  .lead {
    font-size: 1rem;
  }
  .btn-outline-light {
    font-size: 1rem !important;
  }
  .topics-section h2:last-of-type {
    font-size: 1.17rem;
  }
}
.text-danger-lighter {
  color: var(--bs-danger-lighter);
}
.bg-danger-lighter {
  background-color: var(--bs-danger-lighter);
}

.position-sticky {
  position: sticky;
  top: 0;
}
.z-plus {
  z-index: 15;
}
.z-1 {
  position: relative;
  z-index: 1;
}
.z-2 {
  position: relative;
  z-index: 2;
}
.z-3 {
  position: relative;
  z-index: 3;
}
.z-4 {
  position: relative;
  z-index: 4;
}
.z-5 {
  position: relative;
  z-index: 5;
}
.z-6 {
  position: relative;
  z-index: 6;
}
.pt-extra {
  padding-top: 7rem !important;
}
.pb-extra {
  padding-bottom: 7rem !important;
}
.min-vh-75 {
  min-height: 40vh !important;
}
@media screen and (min-width: 768px) {
  .w-md-25 {
    width: 25% !important;
  }
  .w-md-50 {
    width: 50% !important;
  }
  .w-md-75 {
    width: 75% !important;
  }
  .w-md-100 {
    width: 100% !important;
  }
  .pt-md-extra {
    padding-top: 7rem !important;
  }
  .pb-md-extra {
    padding-bottom: 7rem !important;
  }
  .min-vh-75 {
    min-height: 80vh;
  }
}
p.fw-light {
  font-weight: 300 !important;
  line-height: 1.25em !important;
}
.rounded-5 {
  border-radius: 1.25rem;
  overflow: hidden;
}
.container {
  padding: 3rem 0;
}
@media screen and (min-width: 768px) {
  .container {
    padding: 7rem 0;
  }
}
.anim-point-down-slow {
  -webkit-animation: point-down 2s infinite alternate ease-in-out;
  animation: point-down 2s infinite alternate ease-in-out;
}
@-webkit-keyframes point-down {
  0% {
      -webkit-transform: translateY(0)
  }
  100% {
      -webkit-transform: translateY(0.4em)
  }
}
.shadow-light {
  box-shadow: 0 8px 32px 0 rgba(106, 106, 106, 0.184);
  border: 1px solid rgba(138, 20, 32, 0.214);
}
/* -- Menu -- */
.menu {
  height: 0%;
  top: 0;
  left: 0;
  z-index: 10;
  overflow-y: hidden;
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  gap: 0.5em;
}
.menu a, footer a {
  text-decoration: none;
}
.menu-button {
  top: 1rem;
  right: 1rem;
  z-index: 11;
}
@media screen and (min-width: 768px) {
  .menu-button {
      top: 1.5rem;
      right: 1.5rem;
  }
}
#menu-icon {
  width: 2.5rem;
  height: 2.4rem;
  cursor: pointer !important;
}
#menu-icon span {
  height: 0.15rem;
  border-radius: 0rem;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
}
@media screen and (min-width: 768px) {
  #menu-icon {
      width: 3rem;
  }
}
#menu-icon span:nth-child(1) {
  top: 0;
  -webkit-transform-origin: left center;
  -moz-transform-origin: left center;
  -o-transform-origin: left center;
  transform-origin: left center;
}
#menu-icon span:nth-child(2) {
  top: 2rem;
  -webkit-transform-origin: left center;
  -moz-transform-origin: left center;
  -o-transform-origin: left center;
  transform-origin: left center;
}
#menu-icon span:nth-child(3) {
    top: 1rem;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    transform-origin: left center;
}
#menu-icon.menu-button-open span:nth-child(1) {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}
#menu-icon.menu-button-open span:nth-child(2) {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 1.75rem;
}
@media screen and (min-width: 768px) {
  #menu-icon.menu-button-open span:nth-child(2) {
      top: 2.1rem;
  }
}
#menu-icon.menu-button-open span:nth-child(3) {
  width: 0%;
  opacity: 0;
}

/* SVG Flasche line */
.st0 {
  fill:none;
  stroke:var(--bs-danger-lighter);
  stroke-width: 7;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-miterlimit:10;
}
@media screen and (max-width: 979px) {
  .st0 {
    stroke-width: 15;
  }
}
/* -- Links -- */
a {
  text-decoration: none;
  text-shadow: none !important;
}
.link-underline {
  position: relative;
  color: var(--bs-light);
}
.link-underline::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  border-radius: 1px;
  background-color: var(--bs-danger);
  bottom: 0;
  left: 0;
  transform-origin: right;
  transform: scaleX(0);
  transition: transform .3s ease-in-out;
}
.link-underline:hover, .link-underline:active, .link-underline:focus {
  color: var(--bs-danger-lighter) !important;
}
.link-underline:hover::before {
  transform-origin: left;
  transform: scaleX(1);
}
a.back-to-top {
  color: var(--bs-light);
  transition: 0.25s ease-in-out;
}
a.back-to-top:hover, a.back-to-top:focus, a.back-to-top:active {
  -webkit-animation: point-up 2s infinite alternate ease-in-out;
  animation: point-up .6s infinite alternate ease-in-out;
  color: var(--bs-danger-lighter);
  transition: 0.25s ease-in-out;
}
@-webkit-keyframes point-up {
  0% {
      -webkit-transform: translateY(0)
  }
  to {
      -webkit-transform: translateY(-.4em)
  }
}

.language-buttons {
  width: 2.75rem;
  height: 2.75rem;
  font-size: 0.9rem;
}
.language-button-group {
  display: none !important;
  transition: 0.25s ease-in-out !important;
}
.language-button:hover .language-button-group {
  display: flex !important;
  transition: 0.25s ease-in-out !important;
}

.hero {
  background-image: linear-gradient(180deg, rgba(255,255,255,0) 90%, rgba(3,3,3,1) 100%), url('../img/kultwork-12.webp') !important;
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
}

.info-intro {
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: 40% center;
  background-image: url('../img/flaschen-regal.webp');
}
.weinclub {
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: 40% center;
  background-image: url('../img/weinclub.webp');
}
.weinblog {
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: 40% center;
  background-image: url('../img/weinblog.webp');
}

.section-heading {
  font-size: 8vw;
  text-shadow: 8px 8px 8px #03030381 !important;
}
@media screen and (max-width: 767px) {
  .section-heading {
    font-size: calc(1.5rem + 4vw);
  }
  .display-1 {
    font-size: calc(1.5rem + 3vw);
  }
}
@media screen and (max-width: 576px) {
  .section-heading {
    font-size: calc(1.5rem + 2vw);
  }
  .display-1 {
    font-size: calc(1.5rem + 5vw);
  }
}
.topics-wrapper {
  height: 300vh;
  position: relative;
}
.topics-wrapper-top {
  position: absolute;
  top: 0;
  z-index: 2;
}
.topic-wrapper-bottom {
  position: absolute;
  top: 0;
  z-index: 1;
}
.topics-top {
  height: 300vh;
  position: relative;
}
.topics-bottom {
  height: 300vh;
  position: relative;
  scroll-snap-type: y ;
}

.topics-wein {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 100%;
}
.topics-section {
  scroll-snap-align: start;
  overflow: hidden;
  height: 100vh;
  width: 100%;
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
}
.pt-topics {
  padding-top: 35vh;
}

.handel {
  background-image: url('../img/topics/wine-handel.webp');
}
.events {
  background-image: url('../img/topics/wine-events.webp');
}
.consulting {
  background-image: url('../img/topics/wine-consulting.webp');
  background-position: 58% center;
}
@media screen and (max-width: 767px) { 
  .events {
    background-position: 68% center;
  }
}

.experience-bg {
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: 60% center;
  background-image: url('../img/wine-bottle-screw.webp');
}
.experience-list {
  font-size: 2rem;
}

/* -- Logos -- */
/***** flip boxes intro *****/
.flip-box {
 	background-color: transparent;
  text-shadow: none !important;
  display: block;
 	width: 100%;
 	height: 450px;
	-webkit-perspective: 1000px;
	-moz-perspective: 1000px;
 	perspective: 1000px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .flip-box {
    height: 315px;
  }
}
.flip-box-inner {
 	position: relative;
  display: block;
 	width: 100%;
 	height: 100%;
 	transition: transform 0.8s;
	-webkit-transform-style: preserve-3d;
	-moz-transform-style: preserve-3d;
	-ms-transform-style: preserve-3d;
 	transform-style: preserve-3d;
}
.flip-box:hover .flip-box-inner {
 	transform: rotateY(180deg);
}
.flip-box-front, .flip-box-back {
 	position: absolute;
  display: block;
 	width: 100%;
 	height: 100%;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-ms-backface-visibility: hidden;
	backface-visibility: hidden;
}
/* back side */
.flip-box-back {
	transform: rotateY(180deg);
}
@media screen and (max-width: 767px) {
  .flip-box-back p, .flip-box-back a {
    font-size: 0.8125rem;
  }
  .flip-box-back h5 {
    font-size: 1.25rem;
  }
}

#kontakt {
  background-size: contain;
  -moz-background-size: contain;
  -webkit-background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% center;
  background-image: url('../img/weinflasche-black.webp');
}
@media screen and (max-width: 767px) {
  #kontakt {
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
  }
}

.cta-link {
  color: var(--bs-danger-lighter);
  transition: 0.25s ease-in-out;
}
.cta-link:hover, .cta-link:active, .cta-link:focus {
  color: var(--bs-light);
  transition: 0.25s ease-in-out;
}

/* -- Social Icons -- */
.social-icons {
  width: 2rem;
  height: 2rem;
  color: #030303;
  transition: 0.5s ease-in-out;
  background-color: var(--bs-light);
  text-shadow: none !important;
}
.social-icons:hover, .social-icons:focus, .social-icons:active {
  background-color: var(--bs-danger-lighter);
  transition: 0.5s ease-in-out;
  color: var(--bs-dark);
}
 .social-links {
  width: 2rem;
  height: 2rem;
  transition: 0.5s ease-in-out;
}

/* -- Modals -- */
.modal-content {
  background: rgba(138, 20, 32, 0.5);
  box-shadow: 0 8px 32px 0 rgba(106, 106, 106, 0.184);
  backdrop-filter: blur( 10px);
  -webkit-backdrop-filter: blur( 10px);
  border: 1px solid rgba(138, 20, 32, 0.35);
}

/* -- 404 -- */
body.page-404 {
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: 40% center;
  background-image: url('../img/bottle-bottoms.webp');
}
.datenschutz-linktree {
  overflow-x: hidden;
}

.info-div {
  border: 1px solid var(--bs-danger-lighter);
  background-color: #320c10a5;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur( 5px);
  box-shadow: 0 8px 32px 0 rgba(106, 106, 106, 0.184);
}

.blog-div {
  border: 1px solid var(--bs-light);
  background-color: #f7f7f769;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur( 5px);
  box-shadow: 0 8px 32px 0 rgba(106, 106, 106, 0.184);
}