/*
    Template:       airi
    Theme Name:     Airi Child
    Theme URI:      http://themeforest.net/user/LA-Studio/portfolio?ref=LA-Studio
    Author:         LA Studio
    Author URI:     http://themeforest.net/user/LA-Studio?ref=LA-Studio
    Description:    Clean, Minimal WooCommerce Theme
    Version:        1.0
    Tags:           one-column, two-columns, three-columns, four-columns, left-sidebar, right-sidebar, custom-background, custom-colors, custom-header, custom-menu, featured-image-header, featured-images, flexible-header, full-width-template, post-formats, sticky-post, theme-options, translation-ready
    License: 		GNU General Public License
	License URI: 	licence/GPL.txt
    Text Domain:    airi-child
    Domain Path:    /languages/
*/

@font-face {
    font-family: 'Roboto Condensed';
    src: url('./fonts/RobotoCondensed-Light.woff2') format('woff2'),
        url('./fonts/RobotoCondensed-Light.woff') format('woff'),
        url('./fonts/RobotoCondensed-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto Condensed';
    src: url('./fonts/RobotoCondensed-Bold.woff2') format('woff2'),
        url('./fonts/RobotoCondensed-Bold.woff') format('woff'),
        url('./fonts/RobotoCondensed-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto Condensed';
    src: url('./fonts/RobotoCondensed-Regular.woff2') format('woff2'),
        url('./fonts/RobotoCondensed-Regular.woff') format('woff'),
        url('./fonts/RobotoCondensed-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

body, h1, h2, h3, h4, h5, h6, p {
    font-family: 'Roboto Condensed', sans-serif;
}

h1, h2 {
    font-size: 42px;
    text-transform: uppercase;
    color: #2a5135;
    font-weight: 300;
}

h3 {
    color: #9badab;
    text-transform: uppercase;
    font-weight: 300;
    font-size: 22px;
    line-height: 1.7;
}

.thin-text {
    font-weight: 300;
}

.light-text, .light-text h1, .light-text h2, .light-text h3, .light-text h4, .light-text h5, .light-text h6 {
    color: #fff;
}

.green-text {
    color: #b4bd10;
}

.page-content a {
    color: #9badab;
}

.strassen a {
    color: #2a5135;
    text-decoration: underline;
}

p {
    margin: 0 0 25px;
}

.page-content li {
margin-bottom:15px;
}

@media (max-width: 767px) {
    h1, h2 {
      font-size: 30px;
    }
}

/* Text Elements */

.body.airi-body {
    background: linear-gradient(90deg, rgba(232, 232, 232, 1) 0%, rgba(255, 255, 255, 1) 50%, rgba(232, 232, 232, 1) 100%);
}

.spacer {
    margin: 50px 0px;
}

.icon img {
    width: 50px;
    height: 50px;
}

.strassen {
    background: rgb(168,177,163);
    background: linear-gradient(180deg, rgba(168,177,163,1) 0%, rgba(208,212,205,1) 51%, rgba(230,232,229,1) 100%);
    color:#2a5135;
    padding: 35px 35px 15px;
    margin-bottom: 35px;
}

.strassen img {
    display: block;
    margin-bottom: 15px;
}

@media (max-width: 1200px) {
    .container {
        margin-left: 0;
        margin-right: 0;
    }
}

/* End Text Elements */

/* STICKY SIDE BOX */

.fixed-container {
    position: fixed;
    top: 200px;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
    z-index: 3;
}

@media (max-width: 991px) {
    .fixed-container{
        top: 70px;
    }
}

.box {
    position: relative; /* Für den z-index */
    width: 50px;
    height: 50px;
    background-color: #2a5135;
    text-align: center;
    line-height: 50px;
    cursor: pointer;
    transition: width 0.3s ease-in-out;
    overflow: hidden;
    white-space: nowrap;
    padding-left: 10px;
    border-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.7), #2a5135) 1 100%;
    border-style: solid;
    box-shadow: 2px 2px 4px #000;
    border-width: 0 5px 0 0;
}

.box img {
    width: 25px;
    height: 25px;
    position: relative;
    right: 5px;
}

@media (hover: hover) {
.box:hover {
    width: 150px;
    z-index: 10;
    display: flex;
    align-items: center;
}
}

@media (hover: none) {
    .box.active {
    width: 150px;
    z-index: 10;
    display: flex;
    align-items: center;
    }
}

.box.mail:hover::after {
    content: "E-Mail";
}

.box.chat:hover::after {
    content: "Anrufen";
}

.box.like:hover::after {
    content: "Ansprechpartner";
}

.box.sos:hover::after {
    content: "Notfallnummern";
}

.hidden-link {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2; 
}

@media (hover: none) {
  .box.active .hidden-link {
    display: block;
  }
}

/* END STICKY SIDE BOX */

/* Header */

.header-v6 #masthead_aside .mega-menu > li > a, .header-v7 #header_aside .mega-menu > li > a, .site-main-nav .main-menu > li > a {
    font-size: 20px;
}

.header-right {
    float: left;
}

.site-main-nav .main-menu > li > a:after {
    content: "";
    clip-path: polygon(50% 50%, 0% 100%, 100% 100%);
    background: #2a5135;
    height: 25px;
    right: 15px;
    left: auto;
    width: 0;
    position: absolute;
    transition: width .25s ease-out;
    bottom: -22px;
}

.site-main-nav .main-menu > li.active > a:after {
    left: calc(50% - 20px);
    right: auto;
    width: 40px;
}

.site-main-nav .main-menu > li > a {
    color:#2a5135;
    font-weight: 300;
}

.site-main-nav .main-menu > li.active > a, .site-main-nav .main-menu > li:hover > a {
    color:#2a5135;
    font-weight: 600;
}


/* End Header */

/* Cards */

.card-wrap {
    width: 100%;
    filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
}

.card {
    background-color: #9badab;
    padding: 25px;
    clip-path: polygon(0 0, calc(100% - 50px) 0%, 100% calc(0% + 50px), 100% 80%, 100% 100%, 0 100%, 0% 100%, 0% 20%);
    height: 100%;
}



.img-card img, .bestand-card img {
    clip-path: polygon(0 0, calc(100% - 50px) 0%, 100% calc(0% + 50px), 100% 80%, 100% 100%, 0 100%, 0% 100%, 0% 20%);
}

.bestand-card, .img-card {
    position: relative;
}

 .bestand-card .ort, .bestand-card .overlay {
    position: absolute;
}

.bestand-card .overlay, .img-card .overlay {
    bottom: 0;
    width: 100%;
    height: 50%;
    background: rgb(42, 81, 53);
    background: linear-gradient(0deg, rgba(42, 81, 53, 1) 0%, rgba(42, 81, 53, 0.8603816526610644) 50%, rgba(42, 81, 53, 0) 100%);
    mix-blend-mode: multiply;
}

.bestand-card .ort {
    bottom: 25px;
    left: 25px;
    color: #fff;
    margin: 0;
    font-weight: 300;
}
  
  .card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px;
    justify-items: center;
    margin-top: -100px;
  }

  .card-grid2 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 35px;
    justify-items: center;
  }
  
  @media (max-width: 767px) {
    .card-grid, .card-grid2 {
      grid-template-columns: repeat(2, 1fr);
      gap: 25px;
    }
    .strassen {
        margin-top: 50px;
    }
    .img-card img, .bestand-card img {
    clip-path: polygon(0 0, calc(100% - 30px) 0%, 100% calc(0% + 30px), 100% 80%, 100% 100%, 0 100%, 0% 100%, 0% 20%);
    }
    .bestand-card .ort {
    bottom: 15px;
    left: 15px;
    }
  }

  @media (max-width: 500px) {
    .card-grid2 {
      grid-template-columns: repeat(1, 1fr);
    }
  }

  /* End Cards */

  /* Contact */

  .wpcf7-form-control-wrap {
    margin-bottom: 0px;
}
.wps-form {
    width: 100%;
    margin: 0 auto;
}
.wps-form .wps-form-row {
    display: flex;
    flex-direction: column;
    width: 100%;
}
.wps-form .wps-form-row  {
    width: 100%;
}
.wps-form .wps-form-column {
    flex: 1;
    width: 100%;
}

.wpcf7 .wpcf7-submit:disabled {
    background-color: #9badab;
    cursor: not-allowed;
}

input[type="submit"] {
    background-color: #2a5135;
    color: #fff;
}

  @media (max-width: 1000px) {
  .wps-form-img {
    display: none;
    }
    }

    @media only screen and ( min-width: 48em ) { 
        .wps-form .wps-form-row {
            flex-direction: row;
        }
    }

  /* End Contact */

  /* Hero Section */

  .hero-image .overlay {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 40%;
    background: rgb(42, 81, 53, 0.6);
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0% 100%);
}

.hero-image .overlay-brown {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 40%;
    background: rgb(188, 149, 91, 0.6);
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0% 100%);
}

.hero-image .overlay-grau {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 40%;
    background: rgb(155, 173, 171, 0.6);
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0% 100%);
}

.hero-image .overlay-yellowgreen {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 40%;
    background: rgb(180, 189, 16, 0.6);
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0% 100%);
}

.overlay-center {
    display: flex;
    justify-content: center;
    height: 100%;
    align-items: center;
}

.overlay-center p {
    font-size: 15vw;
    color:rgba(255, 255, 255, 0.8);
}

.overlay img, .overlay-brown img, .overlay-grau img, .overlay-yellowgreen img {
    height: 30%;
    position: absolute;
    top: calc(50% - 26px);
    right: 5%;
}

.divider {
    width: 100%;
    background: #cfd3cc;
    clip-path: polygon(0px 0px, 100% 0px, 100% calc(100% - 110px), 0px 100%);
    padding: 35px 0 100px 0;
    height:200px;
}

.divider-green {
    width: 100%;
    background: #2a5135;
    clip-path: polygon(0px 0px, 100% 0px, 100% calc(100% - 110px), 0px 100%);
    display: flex;
    align-items: center;
    padding: 35px 0 100px 0;
}

.divider-brown {
    width: 100%;
    background: #f1e9dd;
    clip-path: polygon(0px 0px, 100% 0px, 100% calc(100% - 110px), 0px 100%);
    display: flex;
    align-items: center;
    padding: 35px 0 100px 0;
}

.divider-grau {
    width: 100%;
    background: #eceeee;
    clip-path: polygon(0px 0px, 100% 0px, 100% calc(100% - 110px), 0px 100%);
    display: flex;
    align-items: center;
    padding: 35px 0 100px 0;
}

.divider-yellowgreen {
    width: 100%;
    background: #dbdd98;
    clip-path: polygon(0px 0px, 100% 0px, 100% calc(100% - 110px), 0px 100%);
    display: flex;
    align-items: center;
    padding: 35px 0 100px 0;
}

@media (max-width: 767px) {
    .divider {
    padding: 15px 0 50px 0;
    }
    .overlay img, .overlay-brown img, .overlay-grau img, .overlay-yellowgreen img {
        top: calc(50%);
    }
    .divider {
    height:auto;
    min-height: 160px;
}
}

/* End Hero Section */

/* Footer */

.site-footer {
    font-size: 16px;
    line-height: 1.84;
    font-weight: 300;
    letter-spacing: 0.5px;
}

.footer-top {
    margin-top: -1px;
    padding-top: 15px;
    padding-bottom: 15px;
}

.bv-footer-white {
    position: relative;
    bottom: 0;
    width: 100%;
    height: 200px;
}

.bv-footer {
    position: relative;
    bottom: 0;
    width: 100%;
    height: 200px;
    background: rgb(42, 81, 53);
    clip-path: polygon(0 70%, 100% 45%, 100% 100%, 0% 100%);
}

@media (max-width: 767px) {
    .site-footer .widget {
      margin-bottom: 2em;
    }
    .site-footer #block-5 img {
        float: left;
    }
  }

/* End Footer */