@font-face {
    font-family: 'Ubuntu';
    font-style: normal;
    font-weight: 300;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-Light.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: normal;
    font-weight: 400;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-Regular.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: normal;
    font-weight: 500;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-Medium.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: normal;
    font-weight: 700;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-Bold.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: italic;
    font-weight: 300;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-LightItalic.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: italic;
    font-weight: 400;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-Italic.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: italic;
    font-weight: 500;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-MediumItalic.ttf') format('truetype');
}
@font-face {
    font-family: 'Ubuntu';
    font-style: italic;
    font-weight: 700;
    src: url('https://stage.kreativ.team/fileadmin/fonts/ubuntu/Ubuntu-BoldItalic.ttf') format('truetype');
}
html{
    overflow-x:hidden;
}
body{
    font-family: Ubuntu;
    font-weight: 300 !important;
    overflow-x: hidden;
}
body p, body a, .btn{
    font-size: 18px;
}
.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
    --bs-gutter-x: 2rem;
}
img{
    width: 100%;
    height: auto;
}
.hero{
    position: fixed;
    z-index: -1;
    height: 100vh;
    width: 100%;
    background-position: 10% 60%;
}
#Content > .container:first-child {
    min-height: 86vh;
}
.frame-space-before-extra-small{
    margin-top: -6rem;
}
.frame-space-before-small{
    margin-top: 4rem;
}
.frame-space-before-medium{
    margin-top: 13rem;
}
.frame-space-before-large{
    margin-top: 13rem;
}
.frame-space-after-medium{
    margin-bottom: 7rem;
}
.frame-space-after-large{
    margin-bottom: 10rem;
}
hr{
    border: none;
    background: #48758a;
    height: 2px;
    width: 100%;
    margin: 70px 0;
    opacity: 1;
}
.transform{
    transform: rotate(-2deg);
    -ms-transform: rotate(-2deg);
    -webkit-transform: rotate(-2deg);
    transform-origin: 0 0 0;
}
.frame-space-before-medium hr.transform {
    display: none;
}
/*Font Styling Global*/
blockquote{
    width: 100%;
    margin-bottom: 2rem;
}
blockquote sub {
    font-style: italic;
    bottom: -2rem;
}
h1,h2,h3,h4,h5,h6{
    font-weight: 300;
}
/*Header*/
#header{
    background: radial-gradient(circle at 100% 0,#48758A,#00385c);
    top: 0;
    height: 134px;
    -moz-transition: all 0.8s ease-in-out;
    -webkit-transition: all 0.8s ease-in-out;
    -ms-transition: all 0.8s ease-in-out;
    transition: all 0.8s ease-in-out;
    transform: rotate(-2deg);
    -ms-transform: rotate(-2deg);
    -webkit-transform: rotate(-2deg);
    transform-origin: 0;
    margin-left: -10px;
    width: 105%;
}
#header.small {
    background: radial-gradient(circle at 100% 0,#48758A,#00385c);
    top: 0;
    height: 75px;
    position: fixed;
    transform: rotate(-0deg);
    -ms-transform: rotate(-0deg);
    -webkit-transform: rotate(-0deg);
    transform-origin: 0;
    width: 100%;
    margin-left: 0;
}
.navbar{
    height: 134px;
    transition: all 0.8s ease-in-out;
    padding: 0 20px 0 8px;
}
#header.small .navbar{
    height: 75px;
    transition: all 0.8s ease-in-out;
    padding: 0 10px;
}
#header .logo{
    color: transparent;
    margin: 25px 0 0 15px;
    transition: all 0.4s ease-in-out;
}
.logo::before{
    content: "";
    background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiBpZD0iRWJlbmVfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA0MC44NTYgNDAuODU2IiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCA0MC44NTYgNDAuODU2IiB4bWw6c3BhY2U9InByZXNlcnZlIj48Zz48Y2lyY2xlIGZpbGw9Im5vbmUiIHN0cm9rZT0iI0ZGRkZGRiIgc3Ryb2tlLXdpZHRoPSIwLjYzOCIgY3g9IjIwLjQyOCIgY3k9IjIwLjQyOCIgcj0iMjAuMTA5Ii8+PC9nPjxwb2x5bGluZSBmaWxsPSJub25lIiBzdHJva2U9IiNGRkZGRkYiIHN0cm9rZS13aWR0aD0iMC42MzgiIHBvaW50cz0iMjQuOTA0LDMwLjQxNiAyNC45MDQsMTAuNjY3IDMzLjEyNiwxMC42NjcgMTYuNDU0LDEwLjY2NyA2LjA2MiwyMC43MTkgMTUuOTQ0LDMwLjI3OCAiLz48L3N2Zz4=);
    width: 80px;
    height: 80px;
    display: block;
    transition: all 0.8s ease-in-out;
}
#header.small .logo{
    margin: 0;
    transition: all 0.8s ease-in-out;
}
#header.small .logo:before {
    width: 50px;
    height: 50px;
    transition: all 0.8s ease-in-out;
}
.logo .logo-brand{
    display: none;
    color: white;
}
.sub .logo:hover:before{
    display: none;
}
.sub .logo:hover .logo-brand{
    display: block;
}
.icon-menu {
    position: relative;
    display: inline-block;
    width: 35px;
    height: 25px;
    vertical-align: middle;
    fill: none;
    float: right;
    margin-top: 15px;
    transition: all 0.8s ease-in-out;
}
#header.small .icon-menu{
    margin-top: 0;
    transition: all 0.8s ease-in-out;
}
.icon-menu .line {
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
    height: 3px;
    border-radius: 3px;
    -webkit-transition: all 0.25s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    -moz-transition: all 0.25s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    -o-transition: all 0.25s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    transition: all 0.25s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    -webkit-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1.000);
    -moz-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1.000);
    -o-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1.000);
    transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1.000);
    background-color: #ffffff;
}
.icon-menu .line-1 {
    top: 0;
}
.icon-menu.is-active .line-1 {
    -webkit-transform: translateY(11px) translateX(0) rotate(45deg);
    -moz-transform: translateY(11px) translateX(0) rotate(45deg);
    transform: translateY(11px) translateX(0) rotate(45deg);
}
.icon-menu .line-2 {
    top: 50%;
    margin-top: -1.5px;
}
.icon-menu.is-active .line-2 {
    opacity: 0;
}
.icon-menu .line-3 {
    bottom: 0;
}
.icon-menu.is-active .line-3 {
    -webkit-transform: translateY(-11px) translateX(0) rotate(-45deg);
    -moz-transform: translateY(-11px) translateX(0) rotate(-45deg);
    transform: translateY(-11px) translateX(0) rotate(-45deg);
}
.navbar-toggler{
    transition: all 0.8s ease-in-out;
    border: 0;
}
.small .navbar-toggler{
    padding-right: 0;
}
.navbar-toggler:focus{
    box-shadow: none;
}
.nav{
    position: relative;
    top: 2px;
}
#navbarNavDropdown{
    margin-right: -15px;
    margin-left: -15px;
    transition: all 0.8s ease-in-out;
}
#header.small #navbarNavDropdown{
    transition: all 0.8s ease-in-out;
}
.navbar-collapse.show, .navbar-collapse.collapsing{
    padding-right: 15px;
    padding-left: 15px;
}
.navbar-nav{
    padding-bottom: 20px;
    padding-top: 0;
    background: #48758a;
    margin: 0 -15px;
    line-height: 20px;
    text-align: center;
}
.nav-link{
    padding: 8px;
    color: white;
    text-decoration: none;
    font-size: 1.5em;
    top: 13px;
}
.nav-link.is-active.is-current{
    color: #48758a;
    text-shadow: 2px 2px 5px rgba(255,255,255,0.2);
    background: white;
    padding: 8px;
}
/*Header Ende*/
/*Startseite*/
#c109{
    height: 100vh;
    align-items: center;
    display: flex;
    text-align: center;
}
.ce-textpic{
    text-align: center;
    justify-content: center;
    display: flex;
}
.ce-bodytext{
    position: absolute;
    margin-top: 40vh;
    width: 100%;
}
.ce-textpic .ce-bodytext blockquote p{
    width: 90%;
    margin: auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #FFFFFF;
    text-shadow: 4px 3px 5px #332A2A;
    font-size: 25px;
}
.ce-gallery{
    min-width: 100%;
}
.ce-textpic .ce-gallery figure.image img{
    min-height: 100vh;
    min-width: 100%;
    object-fit: cover;
}
/*Kontaktseite mit Volllbild*/
img.fullimage.kontakt {
    display: block;
    width: 100%;
    height: auto;
    position: relative;
    overflow: hidden;
    max-height: 100vh;
    object-fit: cover;
}
figure.image::after {
    content: "";
    bottom: 0;
    left: 0;
    width: 102%;
    height: 40px;
    background-color: white;
    transform: rotate(-2deg);
    transform-origin: 100% 100%;
    margin-top: -40px;
    display: block;
}
/*Leistungen Slider*/
.browser-mockup.with-tab{
    min-height: 600px;
}
section.zitat.none hr{
    display: none;
}
.slick-prev::before, .slick-next::before {
    color: #48758a;
    z-index: 10;
}
.slick-prev:hover::before, .slick-prev:focus::before, .slick-next:hover::before, .slick-next:focus::before {
    opacity: 1;
}
.slick-prev{
    left: 0;
}
.slick-next{
    right: 0;
}
.frontslider img{
    border-radius: 50%;
}
.slider .imgWrap .header.col-sm-7 {
    margin-top: 50px;
}
.slider blockquote{
    border-left: none;
    background-color: white;
    display: inline;
    padding: 25px 15px 5px 0;
}
.slider h1{
    color: rgb(72,117,138);
    background-image: linear-gradient(45deg,rgb(72,117,138) 0%,rgb(212,212,212) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
    letter-spacing: 2px;
    font-size: 40px;
    line-height: 1.4;
    padding: 40px 8px;
    margin: 0;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    display: inline;
}
.slider img{
    padding: 35px;
}
.nopadding{
    height: 140%;
    width: 100%;
}
.nopadding img{
    display: flex;
    opacity: 0;
}
.nopadding .cycle{
    padding: 0;
    margin: auto;
    position: relative;
    width: 100%;
    transform-style: inherit;
    z-index: -1;
    height: auto;
    margin-bottom: 50px;
}
.cycle::after {
    content: '';
    position: absolute;
    width: 300px;
    height: 300px;
    top: 50%;
    left: 50%;
    display: block;
    background-image: var(--background-url);
    background-size: 110%;
    background-position: center;
    background-repeat: no-repeat;
    transform: translate(-50%, -50%) translateZ(-0.08px);
    z-index: -2;
    border-radius: 50%;
}
.news-related-row .slick-prev::before{
    margin-right: 0;
}
.news-related-row .slick-next::before{
    margin-left: 0;
}
/*Footer*/
footer{
    background: #48758a;
}
footer .nav-link, footer p{
    font-size: 18px;
}
footer a, footer p{
    color: white;
}
footer a.nav-link:hover{
    color: #212529;
}
/*Footer Ende*/
/*Kunden*/
.btn.projekte{
    background: radial-gradient(circle at 100% 0,#48758A,#00385c);
    color: white;
    font-weight: 300;
    transition: all 0.3s ease;
}
#filterButton {
    width: 100%;
    padding: 10px;
    border: 1px solid #cdcd;
    margin: 20px 0;
    color: #606060;
}
.filter-wrapper > button {
    border: 2px solid #48758a;
    color: #48758a;
}
.filter-wrapper > button:hover {
    border: 2px solid #48758a;
    color: white;
    background: #48758a;
}
.filterDiv {
    display: none;
    transition:  all 0.3s ease;
    opacity: 0;
    transform: translateY(20px);
    margin-left: 40px;
    width: 80vw;
}
.filterDiv h1{
    font-style: italic;
    color: #48758a;
    font-weight: 400;
}
.filterDiv.show {
    display: block;
    opacity: 1;
    transform: translateY(0);
    transition: all 0.3s ease;
}
#filterContainer, #filterContainerDesktop{
    box-sizing: border-box;
    button{
        font-weight: 300;
        border: 2px solid white;
        box-sizing: border-box;
    }
    button.active{
        color: white;
        border-radius: 5px;
    }
    button.all:hover{
        border: 2px solid #48758a;
    }
    button.all.active{
        background: #48758a;
    }
    button.Webentwicklung:hover{
        border: 2px solid #925791;
    }
    button.Webentwicklung.active{
        background: linear-gradient(163deg,#44587c 40%, #925791 80%);
        background: -webkit-linear-gradient(163deg,#44587c 40%, #925791 80%);
        background: -moz-linear-gradient(163deg,#44587c 40%, #925791 80%);
    }
    button.Webdesign:hover{
        border: 2px solid #24a1f6;
    }
    button.Webdesign.active{
        background: linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
        background: -webkit-linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
        background: -moz-linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
    }
    button.Werbetechnik:hover{
        border: 2px solid #ff9431;
    }
    button.Werbetechnik.active{
        background: linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
        background: -webkit-linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
        background: -moz-linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
    }
    button.Gestaltung:hover{
        border: 2px solid #9e273a;
    }
    button.Gestaltung.active{
        background: linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
        background: -webkit-linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
        background: -moz-linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
    }
    button.active:hover{
        border-color: white;
    }
}
.news .article .news-img-wrap{
    margin: 0 !important;
    background: none !important;
}
.news .article .news-img-wrap a{
    border: none;
    padding: 14px;
    overflow: hidden;
    display: block;
    transition: border 0.3s ease, box-shadow 0.3s ease;
    border-radius: 50%;
}
.news .article .news-img-wrap:hover a{
    border: 1px solid #ddd;
    box-shadow: 0 0 9px 0 rgba(0,0,0,0.15);
    -webkit-box-shadow: 0 0 9px 0 rgba(0,0,0,0.15);
    -moz-box-shadow: 0 0 9px 0 rgba(0,0,0,0.15);
}
.news .article .news-img-wrap a img {
    width: 100% !important;
    display: block;
}
.news-backlink-wrap a, .news-backlink-wrap a svg, .news-backlink-wrap a span{
    color: #cbcbcb;
    text-decoration: none;
    transition: color 1s ease;
 }
.news-backlink-wrap a:hover svg, .news-backlink-wrap a:hover span{
    color: #9f9f9f;
    transition: color 1s ease;
}
.header-kunden, .news-backlink-wrap{
    text-align: center;
}
#c111 #news-container-17.news-list-view{
    position: relative;
}
#c111 #news-container-17::before{
    content: "";
    position: absolute;
    height: 100%;
    width: 4px;
    background-color: #48758a;
    margin-top: 100px;
    margin-left: 20px;
    top: 0;
    bottom: 0;
}
#c111 #news-container-17 .news-img-wrap::before {
    content: "";
    display: block;
    width: 38px;
    height: 38px;
    background-color: #48758a;
    border-radius: 50%;
    margin-top: 15px;
    margin-bottom: 15px;
    position: relative;
    top: 50%;
    left: -49px;
    border: 5px solid white;
}
#c111 #news-container-17.webentwicklung::before, #c111 #news-container-17.webentwicklung .news-img-wrap::before{
    background: linear-gradient(163deg,#44587c 40%, #925791 80%);
    background: -webkit-linear-gradient(163deg,#44587c 40%, #925791 80%);
    background: -moz-linear-gradient(163deg,#44587c 40%, #925791 80%);
}
#c111 #news-container-17.webdesign::before, #c111 #news-container-17.webdesign .news-img-wrap::before{
    background: linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
    background: -webkit-linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
    background: -moz-linear-gradient(163deg,#24a1f6 20%, #c5de2d 80%);
}
#c111 #news-container-17.werbetechnik::before, #c111 #news-container-17.werbetechnik .news-img-wrap::before{
    background: linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
    background: -webkit-linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
    background: -moz-linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
}
#c111 #news-container-17.gestaltung::before, #c111 #news-container-17.gestaltung .news-img-wrap::before{
    background: linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
    background: -webkit-linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
    background: -moz-linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
}
.news-text-wrap {
    margin-top: 20px;
}
/*Kunden Ende*/
/*Blogbeiträge*/
.news .article {
    margin-bottom: 15px !important;
}
.card{
    padding: 15px;
    border-radius: 3px;
}
.card-img-overlay, .card.article, .card.article .col-4 img, .card.article .col-4 a{
    border-radius: 3px !important;
}
/*Top Beiträge */
.card.top {
    overflow: hidden;
    position: relative;
    transition: box-shadow 0.3s ease-in-out;
    border: 0;
    padding: 0;
}
.card.top p {
    margin-bottom: 0;
}
.news .top:last-child {
    margin-bottom: 20px !important;
}
.card.top:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
}
.card.top .card-img-overlay {
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1rem;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.3) 20%, /* Heller */
        rgba(0, 0, 0, 0.7) 100% /* Heller */
    );
    transition: background 0.3s ease-in-out;
    z-index: 1;
}
.card.top .card-img-overlay .hover-up {
    width: 100%;
    transform: translateY(0);
    transition: transform 0.6s ease-in-out;
    position: relative;
    z-index: 2;
}
.card.top:hover .card-img-overlay .hover-up {
    transform: translateY(-15px);
}
.card.top .card-img-overlay .card-title {
    margin-bottom: 0.5rem;
}
.card.top .card-img-overlay .card-title a {
    color: inherit;
    text-decoration: none;
}
.card.top .card-img-overlay .card-title a:hover {
    text-decoration: none;
}
.card.top .card-img-overlay .card-text {
    height: 41%;
    overflow: hidden;
    position: relative;
    transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    mask-image: linear-gradient(to bottom, black 50%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, black 50%, transparent 100%);
}
.card.top:hover .card-img-overlay .card-text {
    height: 100%;
    text-shadow: none;
    transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    mask-image: linear-gradient(to bottom, black 100%, transparent 1%);
    -webkit-mask-image: linear-gradient(to bottom, black 100%, transparent 1%);
}
.card.top .card-img-overlay .card-footer {
    padding: 0;
    margin: 0;
    position: relative;
    z-index: 3;
    box-shadow: none;
}
.news-list-author::after {
    content: " · ";
    margin: 0 3px;
}
/*Beiträge Normal*/
.card.article {
    position: relative;
    border: none;
    margin-bottom: 1.5rem;
    transition: box-shadow 0.3s ease-in-out;
}
.card.article:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.card.article .col-4 {
    overflow: hidden;
}
.card.article .col-4 img,
.card.article .col-4 a {
    border-radius: 0.5rem;
    display: block;
    width: 100%;
    height: auto;
}
.card.article .card-body {
    padding: 0 1rem;
}
.card.article .card-title {
    margin-top: 0;
    margin-bottom: 0.5rem;
}
.card.article .card-title a,
.card.article .card-title a:hover {
    color: #333333;
    text-decoration: none;
}
.card.article .card-text {
    display: none;
}
.card.article .card-footer {
    background-color: transparent;
    border: none;
    padding: 0 1rem;
}
.card.article .card-footer p,
.card.article .news-list-author,
.card.article .news-list-date {
    color: #48758a;
    font-size: 0.8rem;
}
.card.article .card-body .reading-time {
    color: #48758a;
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
}
/*Detail Blog Blogbeiträge*/
.news-container-42{
    .footer{
        border-top: none !important;
    }
    .footer span {
        padding-right: 0 !important;
        margin-right: 0 !important;
        border-right: none !important;
    }
    .news-img-wrap {
        width: 100% !important;
        float: none !important;

        img{
            width: 100% !important;
            height: 100% !important;
            max-height: 400px;
            object-fit: cover;
        }
    }
    .breadcrumb{
        margin-bottom: 40px;
        a, span {
        text-decoration: none;
        color: #888;
        }
        .breadcrumb-separator{
            margin: 0 5px;
        }
        .breadcrumb-separator:after{
            content: '';
            background-image: url('/fileadmin/kreativteam/noun-right.svg');
            display: block;
            height: 12px;
            width: 16px;
            background-position: center;
            background-size: contain;
            margin-top: 7px;
        }
        .breadcrumb-active-page {
            color: #48758a;
        }
    }
    .news-text-wrap {
        margin-top: 40px;
    }
}
/*Blogbeiträge Ende*/
/*Parallax*/
div.parallax{
    margin: 0;
    padding: 0;
    font-family: Arial, sans-serif;
    color: #333;
    .parallax-wrapper {
        height: 100vh;
        overflow-x: hidden;
        overflow-y: auto;
        perspective: 1px;
    }
    .parallax-group {
        position: relative;
        height: 100vh;
        transform-style: preserve-3d;
        pointer-events: none;
    }
    .parallax-layer {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        background-size: cover;
        background-position: center;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        color: white;
        font-size: 2rem;
        padding: 20px;
        text-shadow: 0 0 10px rgba(0, 0, 0, 0.7);
        filter: sepia(0.5);
    }
    .aussicht-layer {
        transform: translateZ(-2px) scale(3);
        background-image: url('/fileadmin/kreativteam/parallax/aussicht.png');
        opacity: 1;
        z-index: 1;
        pointer-events: none;
    }
    .aussicht-layer h1{
        opacity: 0.6;
        font-family: Ubuntu;
        font-weight: 500;
    }
    .hotspot-layer {
        position: relative;
        transform: translateZ(-0.4px) scale(1.4);
        background-image: none;
        background-color: transparent;
        z-index: 2;
        justify-content: flex-start;
        align-items: flex-start;
        pointer-events: none;
    }
    .hotspot-layer.onTop {
        transform: translateZ(-0.3px) scale(1.3);
        z-index: 10;
        pointer-events: auto;
    }
    .berge-layer {
        transform: translateZ(-0.37px) scale(1.37);
        background-image: url('/fileadmin/kreativteam/parallax/berge.png');
        opacity: 1;
        z-index: 3;
        pointer-events: none;
        filter: sepia(0.5);
    }
    .hotspot {
        position: absolute;
        width: 25px;
        height: 25px;
        border-radius: 50%;
        cursor: pointer;
        display: flex;
        justify-content: center;
        align-items: center;
        z-index: 10;
        opacity: 0;
        transition: opacity 1s;
    }
    .onTop .hotspot{
        opacity: 1;
        transition: opacity 1s;
    }
    .onTop .hotspot:hover{
        animation-play-state: paused;
    }
    .onTop .hotspot-1{
        animation: pulse-1 4s;
        animation-iteration-count: infinite;
    }
    .onTop .hotspot-2{
        animation: pulse-2 4s;
        animation-iteration-count: infinite;
        animation-delay: 2s;
    }
    .hotspot-1 {
        top: 780%;
        right: 35%;
        background: linear-gradient(163deg,#1762d4 20%, #9e273a 80%);
    }
    .hotspot-2 {
        top: 780%;
        right: 15%;
        background: linear-gradient(163deg,#ff9431 20%, #d90e64 80%);
    }
    .onTop .hotspot .tooltip {
        animation: none;
    }
    .tooltip {
        display: none;
        position: absolute;
        top: 10%;
        left: 50%;
        transform: translateX(-50%);
        padding: 15px 10px;
        margin: 10px 0;
        color: #48758a;
        border-radius: 2px;
        transition: opacity 1s, visibility 1s;
        z-index: 9;
        pointer-events: auto;
        font-size: 0.6em;
        min-width: 15vw;
        text-align: left;
        border: 1px solid #48758a;
        background: rgba(255, 255, 255, 0.25);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        overflow: hidden;
    }
    .tooltip h3{
        margin-bottom: 30px;
    }
    .tooltip .card-body::after {
        content: "";
        position: absolute;
        top: 60px;
        left: 0;
        width: 100%;
        height: 1px;
        background: #48758a;
        transform-origin: 0 0;
        transform: rotate(-2deg);
    }
    .onTop .hotspot:hover > .tooltip,
    .onTop .hotspot > .tooltip:hover, .onTop .hotspot:hover > .tooltip:hover {
        display: block;
        visibility: visible;
        animation: none;
        opacity: 1;
        transition: opacity 2s, visibility 2s;
    }
    .content-section {
        position: relative;
        background-color: white;
        padding: 50px 20px;
        z-index: 5;
        min-height: 200px;
        pointer-events: auto;
        cursor: auto;
    }
    .content-text {
        display: none;
    }
    .zeppelin-layer {
        top: 30vh;
        left: 0;
        right: auto;
        bottom: auto;
        width: 200px;
        height: 40px;
        z-index: 100;
        pointer-events: none;
        animation: fly-across 23s linear forwards;
        background-image: url('/fileadmin/kreativteam/parallax/zeppelin.png');
        filter: sepia(0.5);
    }
    .zeppelin-layer:hover{
        animation: none;
    }
}
/*Parallax Ende*/
#toTopButton {
    transition: opacity 0.5s, visibility 0.5s;
    display: block;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    position: fixed;
    bottom: 90px;
    right: 10px;
    z-index: 999;
    border: solid 2px #48758a;
    outline: none;
    background-color: white;
    color: #48758a;
    padding: 15px;
    border-radius: 50%;
}
#toTopButton.show {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
#toTopButton:hover {
    background-color: #48758a; /* Add a dark-grey background on hover */
    color: white;
}
@media(max-width: 430px){
    .card.top .card-img-overlay .card-text {
        height: 2.5rem;
        transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    }
    .card.top:hover .card-img-overlay .card-text {
        height: 5.87rem;
        transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    }
    .card.top .card-footer{
        display: none;
    }
}
@media(max-width: 576px){
    .frame-space-before-extra-small{
        margin-top: 6rem;
    }
    .cycle{
        border-radius: 50%;
        padding: 20px;
    }
    .top-news-img-wrap.img-logo {
        position: fixed;
        z-index: 100;
        width: 2%;
        top: 2%;
        margin-left: 9px;
        img.img-fluid{
            border-radius: 50%;
        }
    }
    .hotspot-1 {
        right: 15%;
    }

    .hotspot-2 {
        right: 85%;
    }
    #toTopButton{
        padding: 10px;
        bottom: 80px;/* Some padding */
    }
}
@media(min-width: 576px){
    .nav{
        top: 0;
    }
    #navbarNavDropdown{
        margin-top: 30px;
    }
    #header.small #navbarNavDropdown{
        margin-top: 0;
    }
    .navbar-nav{
        justify-content: flex-end;
        margin: 0;
        background-color: transparent;
        padding: 0;
    }
    #nav-header{
        position: absolute;
        right: 0;
        width: 100%;
    }
    .nav-item{
        margin-right: 16px;
    }
    .ce-textpic .ce-bodytext blockquote p{
        width: 70%;
        font-size: 35px;
    }
    .cycle{
        border-radius: 50%;
        padding: 40px;
        margin-top: 50px;
        margin-bottom: 70px;
    }
}
@media(min-width: 576px)and (max-width :768px){
    .cycle::after {
        width: 400px;
        height: 400px;
    }
    .nav-link.is-active.is-current {
        margin-top: 8px;
    }
    .top-news-img-wrap.img-logo {
        top: 15px;
        position: fixed;
        z-index: 100;
        width: 2%;
        margin-left: 15px;
        img.img-fluid{
            border-radius: 50%;
        }
    }
}
@media(max-width: 767px){
    .frame-space-before-medium {
        margin-top: 10rem;
    }
    .nav-link{
        padding: 17px;
        text-align: center;
    }
    .nopadding {
        padding-bottom: 30px;
    }
    img.fullimage.kontakt {
        margin-top: 100px;
    }
    .image-grid{
        .slick-list{
            overflow: visible;
        }
        .slick-track {
            margin-left: -56%;
        }
        .slick-slide{
            margin: 0 10px;
        }
        .slick-dots{
            margin-top: -40px;
            bottom: unset;
        }
        .top-news-wrapper.slick-cloned[data-slick-index="-1"] {
            opacity: 0 !important;
        }
        .grid-item span{
            margin: 20px;
            top: -60px;
            position: relative;
            transition: margin 0.6s ease-in-out, opacity 0.6s ease-in-out, text-shadow 0.6s ease-in-out;
            text-shadow: 23px 2px 50px rgba(255,255,255,0.58);
            color: white;
        }
    }
    .news .article .top-news-img-wrap a img{
        object-fit: cover;
    }
    #c111 #news-container-17 .news-img-wrap::before {
        left: -53px;
    }
}
@media(min-width: 768px){
    .frame-space-before-large{
        margin-top: 15rem;
    }
    .frame-space-after-small{
        margin-bottom: 4rem;
    }
    section.zitat:first-of-type .container {
        padding-top: 70px;
    }
    .nopadding .cycle{
        padding: 0;
        margin: 0;
        width: 90%;
    }
    .intro{
        margin-top: 50px;
    }
    .card.article .card-text {
        display: block;
        color: #6c757d;
    }
    .card.article .card-footer {
        padding: 0 0 0 1rem;
    }
    .row-filter{
        margin: 20px 0 20px -15px;
    }
    #c111 #news-container-17 .news-img-wrap::before {
        position: absolute;
        top: 36px;
        left: -37px;
    }
    #c111 #news-container-17 .row{
        margin-bottom: 40px;
    }
    .filterDiv .row.article {
        padding-left: 40px;
    }
    .content {
        letter-spacing: 4px;
        line-height: 36px;
        width: 90%;
        font-size: 23px;
        transform: translateZ(-2px) scale(3);
    }
    .image-grid {
        display: grid;
        grid-template-columns: repeat(7, 1fr);
        grid-template-rows: repeat(6, 75px);
        gap: 15px;
        position: relative;
        color: white;
    }
    .item-0 {
        grid-column: 5 / 8;
        grid-row: 1 / 3;
        z-index: 10;
    }
    .item-2 {
        grid-column: 3 / 5;
        grid-row: 1 / 4;
        z-index: 10;
    }
    .item-3 {
        grid-column: 1 / 4;
        grid-row: 4 / 6;
        z-index: 10;
    }
    .item-1 {
        grid-column: 4 / 6;
        grid-row: 4 / 7;
        z-index: 5;
    }
    .item-4 {
        grid-column: 6 / 8;
        grid-row: 3 / 6;
        z-index: 15;
    }
    .grid-item {
        position: relative;
        border-radius: 3px;
    }
    .grid-item span{
        margin: 20px 0;
        top: -60px;
        position: relative;
        transition: margin 0.6s ease-in-out, opacity 0.6s ease-in-out, text-shadow 0.6s ease-in-out;
        opacity: 0;
        text-shadow: 23px 2px 50px rgba(255,255,255,0.58);
    }
    .grid-item:hover span {
        margin: 20px;
        top: -60px;
        position: relative;
        transition: margin 0.6s ease-in-out, opacity 0.6s ease-in-out, text-shadow 0.6s ease-in-out;
        opacity: 1;
        text-shadow: 23px 2px 50px rgba(255,255,255,0.58);
    }
    .grid-item img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
        transition: box-shadow 0.5s ease-in-out;
    }
    .grid-item:hover img {
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
        -webkit-box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
        -moz-box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
        transition: box-shadow 0.5s ease-in-out;
    }
    .item-0 img, .item-3 img{
        height: 165px;
    }
    .item-1 img, .item-2 img, .item-4 img{
        height: 255px;
    }
    .top-news-img-wrap.img-logo {
        opacity: 0;
        position: absolute;
        z-index: 100;
        width: 70px;
        top: 15px;
        transition: margin 0.6s ease-in-out, opacity 0.6s ease-in-out, text-shadow 0.6s ease-in-out;
        img.img-fluid{
            border-radius: 50%;
            height: auto;
        }
    }
    .grid-item:hover .top-news-img-wrap.img-logo{
        top: 15px;
        margin-left: 15px;
        position: absolute;
        transition: margin 0.6s ease-in-out, opacity 0.6s ease-in-out, text-shadow 0.6s ease-in-out;
        opacity: 1;
        text-shadow: 23px 2px 50px rgba(255,255,255,0.58);
    }
    .zeppelin-layer {
        animation: fly-across 35s linear forwards;
    }
}
@media(min-width: 768px) and (max-width: 992px){
    .card.top .card-img-overlay .card-text {
        height: 2.5rem;
        transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    }
    .card.top:hover .card-img-overlay .card-text {
        height: 5.87rem;
        transition: max-height 0.6s ease-in-out, opacity 0.6s ease-in-out, height 0.6s ease-in-out, mask-image 0.8s;
    }
    .card.top .card-footer{
        display: none;
    }
}
@media(min-width: 992px){
    .frame-space-before-large{
        margin-top: 17rem;
    }
    .logo:before{
        width: 200px;
        height: 200px;
    }
    .sub .logo:before{
        width: 90px;
        height: 90px;
    }
    .cycle{
        padding: 70px;
    }
    .card{
        padding: 30px;
    }
    .card.top .card-img-overlay {
        padding: 2rem;
    }
    figure.image::after {
        height: 80px;
        margin-top: -70px;
    }
    #c111 #news-container-17 .news-img-wrap::before {
        top: 60px;
    }
    #c139 #news-container-17 .image-grid{
        margin: 0 20% 0 -20%;
    }
    .content {
        letter-spacing: 4px;
        line-height: 40px;
        width: 100%;
        font-size: 25px;
        transform: translateZ(-2px) scale(3);
    }
    #c58 {
        width: 50%;
    }
    .image-grid {
        grid-template-columns: repeat(11, 1fr);
        grid-template-rows: repeat(8, 70px);
    }
    .item-0 {
        grid-column: 9 / 12;
        grid-row: 1 / 3;
    }
    .item-2 {
        grid-column: 7 / 9;
        grid-row: 1 / 4;
    }
    .item-3 {
        grid-column: 5 / 8;
        grid-row: 4 / 6;
    }
    .item-1 {
        grid-column: 8 / 10;
        grid-row: 4 / 7;
    }
    .item-4 {
        grid-column: 10 / 12;
        grid-row: 3 / 6;
    }
    .item-0 img, .item-3 img{
        height: 155px;
    }
    .item-1 img, .item-2 img, .item-4 img{
        height: 240px;
    }
    .zeppelin-layer {
        animation: fly-across 48s linear forwards;
    }
}
@media(min-width: 1200px){
    .image-grid {
        grid-template-rows: repeat(7, 90px);
    }
    .item-0 img, .item-3 img{
        height: 195px;
    }
    .item-1 img, .item-2 img, .item-4 img{
        height: 300px;
    }
    .zeppelin-layer {
        animation: fly-across 60s linear forwards;
    }
}
@media(min-width: 1400px){
    .cycle::after {
        width: 400px;
        height: 400px;
    }
    .image-grid {
        grid-template-rows: repeat(7, 100px);
    }
    .item-0 img, .item-3 img{
        height: 215px;
    }
    .item-1 img, .item-2 img, .item-4 img{
        height: 331px;
    }
    .tooltip {
        max-width: 20vw;
    }
}







/*Styling Drag and Drop*/
.drag-container-wrapper{
    width: 111%;
    position: relative;
    margin-left: -20px;
    margin-bottom: 50px;
}
.drag{
    min-height: 300px;
    background: radial-gradient(circle at 100% 0,#48758A,#00385c);
    border-radius: 2px;
    padding: 30px;
    color: white;
    .kontaktform{
        h2{
            margin-bottom: 20px;
        }
    }
    #left, #right{
        display: flex;
    }
    .item{
        cursor: grab;
        padding: 5px;
        margin: 5px;
        border-radius: 5px;
        position: relative;
        min-height: 36px;
        background-color: #ffffff;
        box-shadow: 0 1px 1px #091e4240, 0 0 1px #091e424f;
        color: #172b4d;
        scroll-margin: 8px;
        width: fit-content;
    }
    .item.is-dragging{
        cursor: grabbing;
    }
}
.drag.container, .drag .content-section.container{
    padding-left: 0;
    padding-right: 0;
}





/* Der Container, der die Schräge bekommt */
.custom-section {
    /* Setzt die Schräge auf den gesamten Container */
    transform: skewY(-2deg);
    /* Füllt die gesamte Breite des Viewports */
    width: 100%;
    /* Stellt sicher, dass der Inhalt sichtbar bleibt */
    padding-top: 50px;
    padding-bottom: 50px;
    margin-top: -50px; /* Kompensiert die Schräge, um bündig anzuschließen */
    margin-bottom: -50px; /* Kompensiert die Schräge */
    position: relative;
    /* Optional: Um die ursprüngliche Hintergrundfarbe zu setzen, falls sie nicht vom Elternelement kommt */
    /* background-color: Ihre Ursprüngliche Hintergrundfarbe; */
}

/* Inhalt im schrägen Container muss zurückgeneigt werden */
.custom-section .content-section {
    transform: skewY(2deg);
    padding-top: 50px; /* Fügt inneren vertikalen Abstand hinzu */
    padding-bottom: 50px; /* Fügt inneren vertikalen Abstand hinzu */
    /* Der Inhaltstext soll immer col-12 sein (Bootstrap macht das automatisch,
       wenn keine spezifischere col-Klasse gesetzt ist). */
}

/* Der eigentliche Inhaltstext im Container soll linksbündig sein (nicht zentriert) */
/* Dies wird durch die h2/p Klassen .text-start im HTML gelöst. */

/* Styling für die Leistungs-Items */
.item-list-container {
    /* Sorgt dafür, dass die Items nebeneinander stehen und nur so groß sind, wie der Inhalt */
    display: flex;
    flex-wrap: wrap; /* Erlaubt das Umbrechen auf neue Zeilen */
    gap: 10px; /* Abstand zwischen den Items */
}

.item {
    /* Items nur so groß, dass der Inhalt rein passt */
    display: inline-block;
    padding: 8px 15px; /* Innenabstand für Lesbarkeit */
    margin-bottom: 5px; /* Etwas Abstand nach unten */
    /* Weißer Hintergrund, blaue Schrift */
    background-color: #FFFFFF;
    color: #007BFF;
    border-radius: 5px;
    /* Optional: leichter Schatten oder Border für besseren Kontrast */
    /* border: 1px solid #007BFF; */
    font-size: 0.9rem;
    cursor: grab; /* Hinweis auf die Drag-Funktionalität */
}

/* Styling für die zweite Spalte (Wunschanfrage) */
.request-column {
    /* Stellt sicher, dass die Hintergrundfarbe die gesamte Spalte abdeckt */
    /* Wird primär durch das innere div gelöst, aber hier zur Sicherheit */
    padding-bottom: 0 !important;
}

.request-area {
    /* Weißen Hintergrund, border-radius von 3px */
    background-color: #FFFFFF;
    border-radius: 3px;
    /* Schrift blau */
    color: #007BFF;
    min-height: 200px; /* Platzhalterhöhe für die Dropping-Zone */
    border: 1px dashed #007BFF; /* Visueller Hinweis auf die Dropping-Zone */
    padding: 15px;
}

/* Mobile-Optimierung: Leistungs-Items unterhalb der Überschrift ist bereits durch
   die .col-12 Struktur und die Flexbox-Anordnung .item-list-container gelöst. */
