/*------------------------------------------------------------
    Template name    : Technoit - IT Solutions & Business Services Multipurpose Responsive Website Template
    Author           : ZRTHEMES
    Version          : 2.0
    File Description : Main css file of the template
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/

@font-face {
    font-family: Saans-Light;
    src: url(../fonts/Saans-Light-1.woff2);
}

@font-face {
    font-family: Saans;
    src: url(../fonts/Saans-Regular-1.woff2);
}

@font-face {
    font-family: Saans-Semibold;
    src: url(../fonts/Saans-SemiBold-1.woff2);
}

:root {
    --font-default: 'Saans', sans-serif;
    --font-primary: 'Saans-Semibold', sans-serif;
    --font-secondary: 'Saans-Light', sans-serif;
    scroll-behavior: smooth;
    --color-bg: #FA9100;
    --hero-overlay-color: transparent;
    --menu-color: #272727;
    --theme-color: #FA9100;
    --border-color: none;
    --theme-color-dark: #f8f8f8;
    --text-color: #272727;
    --asphalt: #272727;
    --hero-text-color: #272727;
    --text-white-color: #ffffff;
    --text-grey-color: #272727;
    --text-theme-color: #FA9100;
    --light-color: #ffffff;
    --color-default: #3a3a3a;
    --color-primary: #FA9100;
    --color-grey: #272727;
    --color-secondary: #FFD802;
    --color-start: #3a3a3a;
    --color-end: #3a3a3a;
    --hero-card-bg: rgb(228 227 223 / 17%);
    --box-shadow-color: rgb(82 90 101 / 10%);
}


body {
    font-family: var(--font-default);
    color: var(--asphalt);
    background: var(--light-color);
    transition: 0.5s background ease;
}

p::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

p::selection {
    background: var(--theme-color);
    color: #fff;
}

h1::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

h1::selection {
    background: var(--theme-color);
    color: #fff;
}

h2::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

h2::selection {
    background: var(--theme-color);
    color: #fff;
}

h3::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

h3::selection {
    background: var(--theme-color);
    color: #fff;
}

h4::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

h4::selection {
    background: var(--theme-color);
    color: #fff;
}


h5::-moz-selection {
    background: var(--theme-color);
    color: #fff;
}

h5::selection {
    background: var(--theme-color);
    color: #fff;
}
.spanbold{
    font:normal normal normal 17px/25px Saans-Semibold;
}
.spanbold15 {
    font: normal normal normal 15px/24px Saans-Semibold;
}

a {
    text-decoration: none;

    color: var(--asphalt);
    text-align: center;
    letter-spacing: 0.53px;
    opacity: 1;
}

btn:hover {
    color: var(--text-grey-color);
    text-decoration: none
}

.pt0{
    padding-top:0px !important;
}
.pb0 {
    padding-bottom: 0px !important;
}

.mt0 {
    margin-top: 0px;
}

.mb0 {
    margin-bottom: 0px;
}

.pt150 {
    padding-top: 150px;
}

.pb150 {
    padding-bottom: 150px;
}

.pt200 {
    padding-top: 200px;
}

.pb200 {
    padding-bottom: 200px;
}

.pt24 {
    padding-top: 24px;
}

.pb24 {
    padding-bottom: 24px;
}

.mt25 {
    margin-top: 25px !important;
}

.mb25 {
    margin-bottom: 25px !Important;
}

.pt25 {
    padding-top: 25px !important;
}

.pb25 {
    padding-bottom: 25px !Important;
}

.pt30 {
    padding-top: 30px;
}

.pb30 {
    padding-bottom: 30px;
}

.pt60 {
    padding-top: 60px;
}

.pb60 {
    padding-bottom: 60px;
}

.pt75 {
    padding-top: 75px !important;
}

.pb75 {
    padding-bottom: 75px !important;
}

.ptmob7550 {
    padding-top: 75px !important;
}

.pbmob7550 {
    padding-bottom: 75px !important;
}

.ptmob7527 {
    padding-top: 75px !important;
}

.pbmob5027 {
    padding-bottom: 50px !important;
}

.ptmob5027 {
    padding-top: 50px !important;
}

.pbmob7527 {
    padding-bottom: 75px !important;
}

.pb100onlymob {
    padding-bottom: 0px;
}

.pl2515 {
    padding-left: 25px;
}

.pt90 {
    padding-top: 90px;
}

.pb90 {
    padding-bottom: 90px;
}


.pt120 {
    padding-top: 120px;
}

.pt10 {
    padding-top: 10px;
}

.pt15 {
    padding-top: 15px;
}

.pb8 {
    padding-top: 8px;
}

.pb120 {
    padding-bottom: 120px;
}

h1, h2, h4, h5, h6 {
    font-family: var(--font-primary)
}

.contact-form-overlay {
    background-color: white;
    border-left: 1px solid var(--theme-color);
    width: 30vw;
    height: 100vh;
    max-height: 100vh;
    color: var(--asphalt);
    z-index: 100000;
    position: fixed;
    right: 0px;
    top: 0px;
    display: none;
    overflow-x: auto;
}

.menu-form-overlay {
    background: #FA9100 0% 0% no-repeat padding-box;
    border-left: 1px solid var(--theme-color);
    width: 30vw;
    height: 100vh;
    max-height: 100vh;
    color: white;
    z-index: 100000;
    position: fixed;
    right: 0px;
    top: 0px;
    display: none;
    overflow-x: auto;
}




.txtwhite{
    color:white;
}

.menubutton{
    cursor:pointer;
}

.contact-form {
    cursor: pointer;
}

.close-contact-form {
    cursor: pointer;
}
container {
    padding-left: 0px;
}

hr{
    color:var(--theme-color) !important;
    margin:0px;
}

h1 {
    color: var(--asphalt);
    text-align: left;
    font: normal normal 300 80px/96px Saans-Light;
    letter-spacing: 0px;
    opacity: 1;
}

h2 {
    color: var(--asphalt);
    text-align: center;
    font: normal normal 300 56px/67px Saans-Light;
    letter-spacing: 0px;
    opacity: 1;
}

h3 {
    color: var(--asphalt);
    text-align: left;
    font: normal normal 300 38px/48px Saans-Light;
    letter-spacing: 0.57px;
    opacity: 1;
}

h4 {
    color: var(--asphalt);
    text-align: left;
    font: normal normal normal 17px/25px Saans-Semibold;
    letter-spacing: 0.63px;
    color: #272727;
    opacity: 1;
}

h5 {
    color: var(--asphalt);
    text-align: left;
    font: normal normal normal 24px/31px Saans-Light;
    letter-spacing: 0.36px;
    color: #272727;
    opacity: 1;
}


p {
    color: var(--asphalt);
    text-align: left;
    font: normal normal normal 17px/25px Saans;
    letter-spacing: 0.63px;
    margin-bottom:0px !important;
    opacity: 1;
}

li {
    color: var(--asphalt);
    text-align: left;
    font: normal normal normal 17px/25px Saans !important;
    letter-spacing: 0.63px;
    opacity: 1;
}

.ptc30 {
    padding-top: 30px;
}

.ptc120 {
    padding-top: 120px;
}

.imgbg {
    float: right;
    min-height: 580px;
    height: 580px;
    background-image: url(../images/artline/home-3.jpg);
    background-size: 588px;
    background-repeat: no-repeat;
    background-size: cover;
}

.btn-right {
    position: absolute;
    right: 0px;
}
.pbc200 {
    padding-bottom: 200px;
}

.autohyph {
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
}

#lotties-js {
    position: absolute;
    z-index: 0;
    top: 300px;
    right: 0;
    bottom: 0;
}

.only-mobile-c {
    display: none;
}

.hide-on-mobile {
    display:block;
}

@media(max-width: 1200px){
    .contact-form-overlay {
        min-width: 50vw;
    }

    .menu-form-overlay {
        min-width: 50vw;
    }
}

@media (min-width: 768px) {
    .only-mobile-c {
        display: none;
    }

    .hide-on-mobile {
        display: block;
    }
}

    @media (max-width: 767px) {
        #lotties-js {
            position: absolute;
            right: -100px;
        }

        .ptmob7550 {
            padding-top: 50px !important;
        }

        .pbmob7550 {
            padding-bottom: 50px !important;
        }

        .ptmob7527 {
            padding-top: 27px !important;
        }

        .pbmob7527 {
            padding-bottom: 27px !important;
        }


        .ptmob5027 {
            padding-top: 27px !important;
        }

        .pbmob5027 {
            padding-bottom: 27px !important;
        }

        .hide-on-mobile-inline {
            display: none;
        }

        .only-mobile-c {
            display: block;
        }

        .btn-right {
            position: absolute;
            left: 0px;
        }

        .ptc30 {
            padding-top: 25px;
            margin-top: 0px;
        }

        .ptc120 {
            padding-top: 30px;
        }

        .pt200 {
            padding-top: 50px;
        }

        .pb200 {
            padding-bottom: 50px;
        }

        .pb200 {
            padding-bottom: 100px;
        }

        .pb100onlymob {
            padding-bottom:100px;
        }

        .pt120 {
            padding-top: 25px;
        }

        .pbonlymob25 {
            padding-bottom:25px;
        }

        .mtonlymob20 {
            margin-top: 20px;
        }

        .mbonlymob20 {
            margin-top: 20px;
        }

        .pl2515{
            padding-left:15px;
        }


        .pb120 {
            padding-bottom: 100px;
        }

        .imgbg {
            float: right;
            min-height: 400px;
            height: 400px;
            background-image: url(../images/artline/home-3.jpg);
            background-size: 400px;
            background-repeat: no-repeat;
            background-size: cover;
        }

        .contact-form-overlay {
            background-color: white;
            border-left: 1px solid var(--theme-color);
            width: 100vw;
            height: 100vh;
            color: var(--asphalt);
            z-index: 100000;
            position: fixed;
            right: 0px;
            top: 0px;
            display: none;
        }

        .menu-form-overlay {
            background: #FA9100 0% 0% no-repeat padding-box;
            border-left: 1px solid var(--theme-color);
            width: 100vw;
            height: 100vh;
            color: white;
            z-index: 100000;
            position: fixed;
            right: 0px;
            top: 0px;
            display: none;
        }

        /* Schriften für Mobilgeräte*/
        h1 {
            color: var(--asphalt);
            text-align: left;
            font: normal normal 300 50px/60px Saans;
            letter-spacing: 0px;
            opacity: 1;
        }

        h2 {
            color: var(--asphalt);
            text-align: center;
            font: normal normal 300 28px/38px Saans;
            letter-spacing: 0px;
            color: #272727;
            opacity: 1;
            -moz-hyphens: auto;
            -o-hyphens: auto;
            -webkit-hyphens: auto;
            -ms-hyphens: auto;
            hyphens: auto;
        }

        .menu-form-overlay h2 {
            font: normal normal 300 56px / 67px Saans-Light;
        }

        h3 {
            color: var(--asphalt);
            text-align: left;
            font: normal normal 300 28px/38px Saans;
            letter-spacing: 0.42px;
            color: #272727;
            opacity: 1;
            -moz-hyphens: auto;
            -o-hyphens: auto;
            -webkit-hyphens: auto;
            -ms-hyphens: auto;
            hyphens: auto;
        }

        h4 {
            color: var(--asphalt);
            text-align: left;
            font: normal normal 600 17px/25px Saans;
            letter-spacing: 0.63px;
            color: #272727;
            opacity: 1;
            -moz-hyphens: auto;
            -o-hyphens: auto;
            -webkit-hyphens: auto;
            -ms-hyphens: auto;
            hyphens: auto;
        }

        p {
            color: var(--asphalt);
            text-align: left;
            font: normal normal normal 17px/25px Saans;
            letter-spacing: 0.63px;
            color: #272727;
            opacity: 1;
            -moz-hyphens: auto;
            -o-hyphens: auto;
            -webkit-hyphens: auto;
            -ms-hyphens: auto;
            hyphens: auto;
        }


        .hide-on-mobile {
            display: none;
        }
    }

    .wleistungen {
        border-radius: 4px;
        height: 100%;
        width: 100%
    }


    .ziele {
        border-radius: 4px;
        /*height: 100%;*/
        width: 100%
    }

    .col-header-text {
        color: var(--asphalt);
        text-align: left;
        font: normal normal 300 80px/96px Saans;
        letter-spacing: 0px;
        opacity: 1;
    }

    .col-smallheader-text-projdetails {
        color: var(--asphalt);
        text-align: left;
        font: normal normal normal 17px/25px Saans-Semibold;
        letter-spacing: 0.63px;
        opacity: 1;
        padding-bottom: 0px;
        padding-top: 5px;
        padding-left: 0px;
        padding-right: 50px;
        margin-bottom:0px !important;
    }

    .col-header-text-projdetails {
        color: var(--asphalt);
        text-align: left;
        font: normal normal 300 80px/96px Saans-Light;
        letter-spacing: 0px;
        opacity: 1;
        padding-top: 0px;
        padding-left: 0px;
        padding-right: 50px;
    }

    .leistung-lottie {
        width: 100%;
        height: 100%;
        z-index: 100000;
        padding: 0px;
        position: absolute;
        bottom: 0px;
        left: 0px;
    }

.leistung-lottie1 {
    width: 100%;
    height: 100%;
    z-index: 100000;
    padding: 0px;
    position: absolute;
    bottom: 0px;
    left: 0px;
}

.leistung-lottie2 {
    width: 100%;
    height: 100%;
    z-index: 100000;
    padding: 0px;
    position: absolute;
    bottom: 0px;
    left: 0px;
}

    .projekt-lottie {
        width: 100%;
        height: 100%;
        z-index: 100000;
        padding: 0px;
        position: absolute;
        bottom: -50px;
        left: -25px;
    }

    .leistungimgnormal {
        width: 100%;
        height: auto
    }

    .proimgnormal {
        width: 100%;
        height: 100%;
        border-radius: 4px;
        object-fit: cover;
    }

    .proimghover {
        width: 100%;
        height: 100%
    }

    .toggle-container {
        position: relative;
    }

    .theme-btn {
        width: 6em;
        height: 6em;
        padding: 0.5em;
        border-radius: 50%;
        cursor: pointer;
        border: none;
        background-color: transparent;
    }

        .theme-btn img {
            height: 100%;
            width: 100%;
            object-fit: cover;
        }

        .theme-btn.light {
            display: none;
        }

    .dark .theme-btn.dark {
        display: none;
    }

    .dark .theme-btn.light {
        display: block;
    }


    /*--------------------------------------------------------------
# Sections & Section Header
--------------------------------------------------------------*/
    section {
        padding: 0px 0;
        overflow: hidden;
    }

    .section {
        padding: 60px 0;
        overflow: hidden;
        background: var(--light-color);
    }

    .section-grey {
        padding: 90px 0;
        overflow: hidden;
        background: var(--theme-color-dark);
    }

    .sections-bg {
        background-color: var(--theme-color-dark);
    }

    .section-header {
        text-align: center;
        padding-bottom: 20px;
    }

        .section-header h2 {
            font-size: 32px;
            position: relative;
            color: var(--color-primary);
        }

        .section-header p {
            margin-bottom: 0;
            color: #b8651d;
        }

    img {
        transition: 0.3s;
    }


    .fill-btn {
        font-family: var(--font-primary);
        font-weight: 500;
        font-size: 15px;
        letter-spacing: 1px;
        display: inline-block;
        padding: 14px 40px;
        border-radius: 50px;
        border: 0;
        transition: 0.3s;
        color: var(--text-white-color);
        background: linear-gradient(45deg, var(--color-primary), var(--color-secondary));
        box-shadow: 0 0 15px rgba(0, 0, 0, 0.08);
    }

    /*.fill-btn:hover {background: linear-gradient(45deg, var(--color-secondary), var(--color-primary));color: var(--text-white-color);}*/


    /*--------------------------------------------------------------
# Scroll top button
--------------------------------------------------------------*/
    .scroll-top {
        position: fixed;
        visibility: hidden;
        opacity: 0;
        right: 15px;
        bottom: -15px;
        z-index: 99999;
        background: var(--color-primary);
        width: 44px;
        height: 44px;
        border-radius: 50px;
        transition: all 0.4s;
    }

        .scroll-top i {
            font-size: 24px;
            color: #fff;
            line-height: 0;
        }

        .scroll-top:hover {
            background: rgb(16 16 16 / 80%);
            color: #fff;
        }

        .scroll-top.active {
            visibility: visible;
            opacity: 1;
            bottom: 15px;
        }

    /*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
    #preloader {
        position: fixed;
        inset: 0;
        z-index: 999999;
        overflow: hidden;
        background: var(--color-primary);
        transition: all 0.6s ease-out;
    }

        #preloader:before {
            content: "";
            position: fixed;
            top: calc(48% - 3px);
            left: calc(48% - 3px);
            border: 2px solid #fff;
            border-color: var(--light-color) transparent var(--light-color) transparent;
            border-radius: 50%;
            width: 60px;
            height: 60px;
            -webkit-animation: animate-preloader 1.5s linear infinite;
            animation: animate-preloader 1.5s linear infinite;
        }

    @-webkit-keyframes animate-preloader {
        0% {
            transform: rotate(0deg);
        }

        100% {
            transform: rotate(360deg);
        }
    }

    @keyframes animate-preloader {
        0% {
            transform: rotate(0deg);
        }

        100% {
            transform: rotate(360deg);
        }
    }



    /*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
    .topbar {
        background: #00796b;
        height: 40px;
        font-size: 14px;
        transition: all 0.5s;
        color: #fff;
        padding: 0;
    }

        .topbar .contact-info i {
            font-style: normal;
            color: #fff;
            line-height: 0;
        }

            .topbar .contact-info i a,
            .topbar .contact-info i span {
                padding-left: 5px;
                color: #fff;
            }

    @media (max-width: 575px) {

        .topbar .contact-info i a,
        .topbar .contact-info i span {
            font-size: 13px;
        }
    }

    .topbar .contact-info i a {
        line-height: 0;
        transition: 0.3s;
    }


    .topbar .social-links a {
        color: rgba(255, 255, 255, 0.7);
        line-height: 0;
        transition: 0.3s;
        margin-left: 20px;
    }

        .topbar .social-links a:hover {
            /*  color: #fff;
*/
        }

    .header {
        transition: all 0.5s;
        z-index: 997;
        height: 90px;
    }

.sideoverlay-container {
    padding-left: 26px;
    padding-top: 42px;
    padding-right: 30px;
    max-height: 100vh;
}

    .header.sticked {
        position: fixed;
        top: 0;
        right: 0;
        left: 0;
        height: 90px;
    }

    .cflabel {
        color: var(--asphalt);
        text-align: left;
        font: normal normal normal 15px/24px Saans;
        letter-spacing: 0.53px;
        color: #272727;
        opacity: 1;
        padding-bottom: 8px;
    }

    .header .logo img {
        max-height: 40px;
        margin-right: 6px;
    }

    .header .logo h1 span {
        color: var(--color-primary);
    }

    .sticked-header-offset {
        margin-top: 0;
    }

    section {
        background: var(--light-color);
    }

    /*--------------------------------------------------------------
# Desktop Navigation
--------------------------------------------------------------*/
    @media (min-width: 1280px) {
        .navbar {
            padding: 0;
        }

            .navbar ul {
                margin: 0;
                padding: 0;
                display: flex;
                list-style: none;
                align-items: center;
            }

            .navbar li {
                position: relative;
            }

            .navbar > ul > li {
                white-space: nowrap;
                padding: 10px 0 10px 28px;
            }

            .navbar a,
            .navbar a:focus {
                display: flex;
                align-items: center;
                justify-content: space-between;
                font-family: var(--font-secondary);
                font-size: 16px;
                font-weight: 600;
                color: var(--menu-color);
                white-space: nowrap;
                transition: 0.3s;
                position: relative;
            }

        .stikcy-menu .navbar a {
            color: var(--text-color);
        }

        .navbar a i,
        .navbar a:focus i {
            font-size: 12px;
            line-height: 0;
            margin-left: 5px;
        }

        .navbar a:hover:before,
        .navbar li:hover > a:before,
        .navbar .active:before {
            visibility: visible;
            width: 100%;
        }

        .navbar a:hover,
        .navbar .active,
        .navbar .active:focus,
        .navbar li:hover > a {
            /*    color: var(--color-primary);*/
        }

        .navbar .dropdown ul {
            display: block;
            position: absolute;
            left: 28px;
            top: calc(100% + 30px);
            margin: 0;
            padding: 10px 0;
            z-index: 99;
            opacity: 0;
            visibility: hidden;
            background: var(--light-color);
            box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
            transition: 0.3s;
            border-radius: 0px;
        }

            .navbar .dropdown ul li {
                min-width: 200px;
            }

            .navbar .dropdown ul a {
                padding: 10px 20px;
                font-size: 15px;
                font-weight: 400;
                color: var(--text-color);
            }

                .navbar .dropdown ul a i {
                    font-size: 12px;
                }

                .navbar .dropdown ul a:hover,
                .navbar .dropdown ul .active:hover,
                .navbar .dropdown ul li:hover > a {
                    /*color: var(--color-primary);*/
                }

        .navbar .dropdown:hover > ul {
            opacity: 1;
            top: 100%;
            visibility: visible;
        }

        .navbar .dropdown .dropdown ul {
            top: 0;
            left: calc(100% - 30px);
            visibility: hidden;
        }

        .navbar .dropdown .dropdown:hover > ul {
            opacity: 1;
            top: 0;
            left: 100%;
            visibility: visible;
        }
    }

    @media (min-width: 1280px) and (max-width: 1366px) {
        .navbar .dropdown .dropdown ul {
            left: -90%;
        }

        .navbar .dropdown .dropdown:hover > ul {
            left: -100%;
        }
    }

    @media (min-width: 1280px) {

        .mobile-nav-show,
        .mobile-nav-hide {
            display: none;
        }
    }

    /*--------------------------------------------------------------
# Mobile Navigation
--------------------------------------------------------------*/
    @media (max-width: 1279px) {
        .navbar {
            position: fixed;
            top: 0;
            right: -100%;
            width: 100%;
            max-width: 400px;
            bottom: 0;
            transition: 0.3s;
            z-index: 9997;
        }

            .navbar ul {
                position: absolute;
                inset: 0;
                padding: 50px 0 10px 0;
                margin: 0;
                background: var(--color-primary);
                overflow-y: auto;
                transition: 0.3s;
                z-index: 9998;
            }

            .navbar a,
            .navbar a:focus {
                display: flex;
                align-items: center;
                justify-content: space-between;
                padding: 10px 20px;
                font-family: var(--font-primary);
                font-size: 15px;
                color: rgb(255 255 255);
                white-space: nowrap;
                transition: 0.3s;
            }

                .navbar a i,
                .navbar a:focus i {
                    font-size: 12px;
                    line-height: 0;
                    margin-left: 5px;
                }

                .navbar a:hover,
                .navbar .active,
                .navbar .active:focus,
                .navbar li:hover > a {
                    /*    color: #fff;
*/
                }

            .navbar .getstarted,
            .navbar .getstarted:focus {
                background: var(--color-primary);
                padding: 8px 20px;
                border-radius: 4px;
                margin: 15px;
                color: #fff;
            }

                .navbar .getstarted:hover,
                .navbar .getstarted:focus:hover {
                    color: #fff;
                    background: rgba(0, 131, 116, 0.8);
                }

            .navbar .dropdown ul,
            .navbar .dropdown .dropdown ul {
                position: static;
                display: none;
                padding: 10px 0;
                margin: 10px 20px;
                transition: all 0.5s ease-in-out;
                background-color: var(--color-primary);
            }

            .navbar .dropdown > .dropdown-active,
            .navbar .dropdown .dropdown > .dropdown-active {
                display: block;
            }

        .mobile-nav-show {
            color: var(--color-primary);
            font-size: 28px;
            cursor: pointer;
            line-height: 0;
            transition: 0.5s;
            z-index: 9999;
            margin-right: 10px;
        }

        .mobile-nav-hide {
            color: #fff;
            font-size: 32px;
            cursor: pointer;
            line-height: 0;
            transition: 0.5s;
            position: fixed;
            right: 20px;
            top: 20px;
            z-index: 9999;
        }

        .mobile-nav-active {
            overflow: hidden;
        }

            .mobile-nav-active .navbar {
                right: 0;
            }

                .mobile-nav-active .navbar:before {
                    content: "";
                    position: fixed;
                    inset: 0;
                    background: rgb(0 0 0 / 80%);
                    z-index: 9996;
                }
    }

    /*--------------------------------------------------------------
# Featured Section
--------------------------------------------------------------*/

    .left {
        text-align: right;
    }

    .right {
        text-align: left;
    }

    .list-wrap {
        display: flex;
        gap: 20px;
        margin-bottom: 30px;
    }

        .list-wrap p {
            color: var(--text-color);
        }

        .list-wrap:nth-child(3),
        .list-wrap:nth-child(6) {
            margin-bottom: 0;
        }

        .list-wrap .description h4 {
            color: var(--text-color);
        }

    .icon {
        width: 150px;
        text-align: center;
        height: 100px;
        border-radius: 50%;
    }

        .icon svg {
            width: 100%;
        }

    .list-center-wrap {
        display: flex;
        gap: 20px;
        align-items: center;
        justify-content: center;
        vertical-align: middle;
        height: 100%;
    }

    .center-icon {
        width: 100%;
        text-align: center;
    }

        .center-icon img {
            width: 100%;
            border-radius: 20px;
            opacity: 0.9;
        }

    /*--------------------------------------------------------------
# About Us Section
--------------------------------------------------------------*/
    .about h3 {
        font-size: 28px;
        margin-bottom: 20px;
        font-family: var(--font-secondary);
    }

    .about .call-us {
        left: 10%;
        right: 10%;
        bottom: 0;
        background-color: #fff;
        box-shadow: 0px 2px 25px rgba(0, 0, 0, 0.08);
        padding: 20px;
        text-align: center;
    }

        .about .call-us h4 {
            font-size: 24px;
            margin-bottom: 5px;
        }

        .about .call-us p {
            font-size: 28px;
            color: var(--color-primary);
        }

    .about .content ul {
        list-style: none;
        padding: 0;
    }

        .about .content ul li {
            padding: 0 0 10px 30px;
            position: relative;
        }

        .about .content ul i {
            position: absolute;
            font-size: 20px;
            left: 0;
            top: -3px;
            color: var(--color-primary);
        }

    .about .content p:last-child {
        margin-bottom: 0;
    }

    .about .play-btn {
        width: 94px;
        height: 94px;
        background: radial-gradient(var(--color-primary) 50%, rgba(0, 131, 116, 0.4) 52%);
        border-radius: 50%;
        display: block;
        position: absolute;
        left: calc(50% - 47px);
        top: calc(50% - 47px);
        overflow: hidden;
    }

        .about .play-btn:before {
            content: "";
            position: absolute;
            width: 120px;
            height: 120px;
            -webkit-animation-delay: 0s;
            animation-delay: 0s;
            -webkit-animation: pulsate-btn 2s;
            animation: pulsate-btn 2s;
            -webkit-animation-direction: forwards;
            animation-direction: forwards;
            -webkit-animation-iteration-count: infinite;
            animation-iteration-count: infinite;
            -webkit-animation-timing-function: steps;
            animation-timing-function: steps;
            opacity: 1;
            border-radius: 50%;
            border: 5px solid rgba(0, 131, 116, 0.7);
            top: -15%;
            left: -15%;
            background: rgba(198, 16, 0, 0);
        }

        .about .play-btn:after {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translateX(-40%) translateY(-50%);
            width: 0;
            height: 0;
            border-top: 10px solid transparent;
            border-bottom: 10px solid transparent;
            border-left: 15px solid #fff;
            z-index: 100;
            transition: all 400ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
        }

        .about .play-btn:hover:before {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translateX(-40%) translateY(-50%);
            width: 0;
            height: 0;
            border: none;
            border-top: 10px solid transparent;
            border-bottom: 10px solid transparent;
            border-left: 15px solid #fff;
            z-index: 200;
            -webkit-animation: none;
            animation: none;
            border-radius: 0;
        }

        .about .play-btn:hover:after {
            border-left: 15px solid var(--color-primary);
            ;
        }

    @-webkit-keyframes pulsate-btn {
        0% {
            opacity: 1;
        }

        100% {
            opacity: 0;
        }
    }

    @keyframes pulsate-btn {
        0% {
            opacity: 1;
        }

        100% {
            opacity: 0;
        }
    }

    .img-frame {
        position: relative;
        background: #f6f6f6;
        background-size: contain;
        padding: 9%;
    }

    .bar {
        background-color: #f1f1f1;
        padding: 1px;
        border-radius: 15px;
        margin-bottom: 20px;
        font-size: 12px;
        color: var(--light-color);
    }

        .bar::before {
            content: attr(data-skill);
            background-color: var(--color-primary);
            display: inline-block;
            padding: 5px 0 5px 10px;
            border-radius: inherit;
            animation: load 2s 0s;
            -webkit-animation: load 2s 0s;
            -moz-animation: load 2s 0s;
            -o-animation: load 2s 0s;
        }

        .bar.front::before {
            background-color: var(--color-primary);
        }

        .bar.back::before {
            background-color: var(--color-primary);
        }

        .bar.learning::before {
            width: calc(20% - 10px);
        }

        .bar.basic::before {
            width: calc(40% - 10px);
        }

        .bar.intermediate::before {
            width: calc(60% - 10px);
        }

        .bar.advanced::before {
            width: calc(80% - 10px);
        }

        .bar.expert::before {
            width: calc(100% - 10px);
        }

    /*--------------------------------------------------------------
# Clients Section
--------------------------------------------------------------*/
    .clients {
        padding: 10px 0;
    }

        .clients .swiper {
            padding: 10px 0;
        }

        .clients .swiper-slide img {
            transition: 0.3s;
            filter: grayscale(0);
            opacity: 1;
            border-radius: 4px;
        }

        .clients .swiper-pagination {
            margin-top: 0px;
            position: relative;
        }

            .clients .swiper-pagination .swiper-pagination-bullet {
                width: 12px;
                height: 12px;
                background-color: #fff;
                opacity: 1;
                background-color: #ddd;
            }

            .clients .swiper-pagination .swiper-pagination-bullet-active {
                background-color: var(--color-primary);
            }


    /*--------------------------------------------------------------
# Call To Action Section
--------------------------------------------------------------*/
    .call-to-action {
        background: url(../images/hero-bg.png) center left;
        background-size: cover;
        padding: 150px 0px;
        border-radius: 0px;
        overflow: hidden;
        position: relative;
        background-attachment: fixed;
    }

        .call-to-action h3 {
            color: #fff;
            font-size: 28px;
            margin-bottom: 20px;
        }

        .call-to-action p {
            color: #fff;
            margin-bottom: 20px;
        }

        .call-to-action .play-btn {
            width: 94px;
            height: 94px;
            margin-bottom: 20px;
            background: radial-gradient(var(--color-primary) 50%, rgba(0, 131, 116, 0.4) 52%);
            border-radius: 50%;
            display: inline-block;
            position: relative;
            overflow: hidden;
        }

            .call-to-action .play-btn:before {
                content: "";
                position: absolute;
                width: 120px;
                height: 120px;
                -webkit-animation-delay: 0s;
                animation-delay: 0s;
                -webkit-animation: pulsate-btn 2s;
                animation: pulsate-btn 2s;
                -webkit-animation-direction: forwards;
                animation-direction: forwards;
                -webkit-animation-iteration-count: infinite;
                animation-iteration-count: infinite;
                -webkit-animation-timing-function: steps;
                animation-timing-function: steps;
                opacity: 1;
                border-radius: 50%;
                border: 5px solid rgba(0, 131, 116, 0.7);
                top: -15%;
                left: -15%;
                background: rgba(198, 16, 0, 0);
            }

        .call-to-action:before {
            content: "";
            position: absolute;
            left: 0;
            bottom: 0;
            top: 0;
            right: 0;
            width: 100%;
            height: 100%;
            background: #000000;
            z-index: 0;
            opacity: 0.6;
        }

        .call-to-action .play-btn:hover:before {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translateX(-40%) translateY(-50%);
            width: 0;
            height: 0;
            border: none;
            border-top: 10px solid transparent;
            border-bottom: 10px solid transparent;
            border-left: 15px solid #fff;
            z-index: 200;
            -webkit-animation: none;
            animation: none;
            border-radius: 0;
        }

        .call-to-action .play-btn:hover:after {
            border-left: 15px solid var(--color-primary);
        }

        .call-to-action .cta-btn {
            font-family: var(--font-primary);
            font-weight: 500;
            font-size: 16px;
            letter-spacing: 1px;
            display: inline-block;
            padding: 12px 48px;
            border-radius: 50px;
            transition: 0.5s;
            margin: 10px;
            color: #fff;
            background: linear-gradient(45deg, var(--color-primary), var(--color-secondary));
        }

            .call-to-action .cta-btn:hover {
                background: linear-gradient(45deg, var(--color-secondary), var(--color-primary));
            }

    @keyframes pulsate-btn {
        0% {
            opacity: 1;
        }

        100% {
            opacity: 0;
        }
    }




    @media (min-width: 1280px) {
        .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
            /*max-width: 80%;*/
        }
    }



    /*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
    .hero {
        width: 100%;
        position: relative;
        background-size: cover;
        height: 100vh;
        display: flex;
        align-items: center;
        overflow: hidden;
    }

    .hero-sub {
        width: 100%;
        position: relative;
        background-size: cover;
        height: 40vh;
        display: flex;
        align-items: center;
        overflow: hidden;
    }

        .hero-sub::before {
            content: '';
            position: absolute;
            left: 0px;
            right: 0px;
            top: 0px;
            width: 100%;
            height: 100%;
            opacity: 0.6;
            z-index: 0;
            margin-top: 0;
            background: linear-gradient(360deg, var(--hero-overlay-color), var(--hero-overlay-color));
        }

    video {
        object-fit: cover;
        width: 100vw;
        height: 100vh;
        position: relative;
        top: 0;
        left: 0;
    }

    .hero::before {
        content: '';
        position: absolute;
        left: 0px;
        right: 0px;
        top: 0px;
        width: 100%;
        height: 100%;
        opacity: 0.6;
        z-index: 0;
        margin-top: 0;
        background: linear-gradient(360deg, var(--hero-overlay-color), var(--hero-overlay-color));
    }

    .hero .circle {
        color: var(--color-primary);
    }

    @media (min-width: 1365px) {
        .hero {
            background-attachment: fixed;
        }
    }

    .dark-bg {
        padding: 50px 30px;
        border-radius: 8px;
    }

    .social {
        margin-top: 15px;
        margin-bottom: 15px;
        display: flex;
        align-items: center;
        gap: 10px;
    }

        .social a {
            color: var(--text-color);
            transition: 0.3s;
            border-radius: 50%;
            width: 30px;
            height: 30px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

            .social a:hover {
                color: var(--color-primary);
                border-color: var(--color-primary);
            }

        .social i {
            font-size: 14px;
            margin: 0 2px;
            color: var(--color-primary);
        }

    .mr-20 {
        margin-right: 20px !important;
    }

    .hero h2 {
        font-size: 80px;
        margin-bottom: 20px;
        color: var(--hero-text-color);
        letter-spacing: 0.7px;
        font-weight: 600;
    }

    .hero span {
        color: var(--color-primary);
        font-weight: bold;
    }

    .hero p {
        color: var(--text-color);
        font-weight: 400;
        margin-bottom: 30px;
    }

    .btn-get-started {
        color: var(--asphalt);
        text-align: center;
        font: normal normal normal 15px/24px Saans;
        letter-spacing: 0.53px;
        opacity: 1;
        display: inline-block;
        height: 29px;
        vertical-align: middle;
        border-radius: 4px;
        text-align: center;
        padding-left: 15px;
        padding-right: 15px;
        cursor: pointer !important;
        background: var(--theme-color);
        border-color: var(--theme-color);
        border-style: solid;
        border-width: 1px
    }

        .btn-get-started:hover {
            color: var(--asphalt);
            text-align: center;
            font: normal normal normal 15px/24px Saans;
            letter-spacing: 0.53px;
            opacity: 1;
            display: inline-block;
            height: 29px;
            vertical-align: middle;
            border-radius: 4px;
            text-align: center;
            padding-left: 15px;
            padding-right: 15px;
            cursor: pointer !important;
            background: none;
            border-color: var(--theme-color);
            border-style: solid;
            border-width: 1px
        }


    .btn-get-started-2 {
        color: var(--asphalt);
        text-align: center;
        font: normal normal normal 15px/24px Saans;
        letter-spacing: 0.53px;
        opacity: 1;
        display: inline-block;
        height: 29px;
        vertical-align: middle;
        border-radius: 4px;
        text-align: center;
        padding-left: 15px;
        padding-right: 15px;
        cursor: pointer !important;
        background: none;
        border-color: var(--theme-color);
        border-style: solid;
        border-width: 1px
    }

        .btn-get-started-2:hover {
            color: var(--asphalt);
            text-align: center;
            font: normal normal normal 15px/24px Saans;
            letter-spacing: 0.53px;
            opacity: 1;
            display: inline-block;
            height: 29px;
            vertical-align: middle;
            border-radius: 4px;
            text-align: center;
            padding-left: 15px;
            padding-right: 15px;
            cursor: pointer !important;
            background: var(--theme-color);
            border-color: var(--theme-color);
            border-style: solid;
            border-width: 1px
        }




    @font-face {
        font-family: 'icomoon';
        src: url('../images/artline/icons/icomoon.eot?damfq4');
        src: url('../images/artline/icons/icomoon.eot?damfq4#iefix') format('embedded-opentype'), url('../images/artline/icons/icomoon.ttf?damfq4') format('truetype'), url('../images/artline/icons/icomoon.woff?damfq4') format('woff'), url('../images/artline/icons/icomoon.svg?damfq4#icomoon') format('svg');
        font-weight: normal;
        font-style: normal;
        font-display: block;
    }

    [class^="icon-"], [class*=" icon-"] {
        /* use !important to prevent issues with browser extensions that change fonts */
        font-family: 'icomoon' !important;
        speak: never;
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        line-height: 1;
        /* Better Font Rendering =========== */
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }


.icon-burger:before {
    content: "\e905";
}

.icon-logo:before {
    content: "\e906";
}

.icon-Pfeil-links:before {
    content: "\e907";
}

.icon-Pfeil-oben:before {
    content: "\e908";
}

.icon-Pfeil-rechts:before {
    content: "\e909";
}

.icon-Pfeil-schraeg:before {
    content: "\e90a";
     font-size:14px;
}

    .icon-Facebook-Icon:before {
        content: "\e900";
        width: 29px;
        height: 29px;
        background-color: var(--theme-color);
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-Facebook-Icon:hover::before {
        content: "\e900";
        width: 29px;
        height: 29px;
        background-color: white;
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-Instagram-Icon:before {
        content: "\e901";
        width: 29px;
        height: 29px;
        background-color: var(--theme-color);
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-Instagram-Icon:hover::before {
        content: "\e901";
        width: 29px;
        height: 29px;
        background-color: white;
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-LinkedIn-Icon:before {
        content: "\e902";
        width: 29px;
        height: 29px;
        background-color: var(--theme-color);
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-LinkedIn-Icon:hover::before {
        content: "\e902";
        width: 29px;
        height: 29px;
        background-color: white;
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-WhatsApp-Icon:before {
        content: "\e903";
        width: 29px;
        height: 29px;
        background-color: var(--theme-color);
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-WhatsApp-Icon:hover::before {
        content: "\e903";
        width: 29px;
        height: 29px;
        background-color: white;
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-X-Icon:before {
        content: "\e904";
        width: 29px;
        height: 29px;
        background-color: var(--theme-color);
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .icon-X-Icon:hover::before {
        content: "\e904";
        width: 29px;
        height: 29px;
        background-color: white;
        padding: 6px;
        border-radius: 4px;
        border-style: solid;
        border-width: 1px;
        border-color: var(--theme-color);
        cursor: pointer;
    }

    .hover-text-leistungen {
        position: absolute;
        bottom: 30px;
        padding-left: 0px;
        padding-right: 50px;
    }

    .hover-text-projdetails {
        padding-left: 0px;
        padding-right: 50px;
        padding-top: 40%
    }

.hover-text-projdetails-bottom {
    padding-left: 0px;
    padding-right: 50px;
    bottom: 30px;
    position: absolute;
    font: normal normal normal 15px/24px Saans;
}

    .hero .btn-watch-video {
        font-size: 16px;
        transition: 0.5s;
        margin-left: 25px;
        color: #fff;
    }

        .hero .btn-watch-video i {
            color: rgba(255, 255, 255, 0.5);
            font-size: 32px;
            transition: 0.3s;
            line-height: 0;
            margin-right: 8px;
        }

        .hero .btn-watch-video:hover i {
            color: #fff;
        }

    @media (max-width: 991px) {
        .hero {
            background: url(../images/hero-bg.png) center center;
        }

            .hero h2 {
                font-size: 50px;
            }

        .call-to-action {
            background: url(../images/cta-bg.jpg) center left;
            background-size: cover;
            padding: 150px 60px;
            border-radius: 0px;
            overflow: hidden;
        }
    }

    @media (max-width: 767px) {
        .text-left.caption {
            text-align: center;
        }

        .caption .justify-content-start {
            justify-content: center !important;
        }

        .caption .social {
            justify-content: center;
        }

        .icon-boxes .card-two {
            margin-top: var(--bs-gutter-y);
            margin-bottom: 0px;
            padding-left: calc(var(--bs-gutter-x) * .5);
            padding-right: calc(var(--bs-gutter-x) * .5);
        }
        .pl2515 {
            padding-left: 15px;
        }
    }

    @media (min-width: 768px) {
        .icon-boxes .card-two {
            margin-top: -20px;
            margin-bottom: -20px;
        }
    }

    .icon-box {
        padding: 20px 30px;
        position: relative;
        overflow: hidden;
        transition: all 0.3s ease-in-out;
        border-radius: 8px;
        z-index: 1;
        height: 100%;
        width: 100%;
        text-align: center;
        color: var(--text-color);
        box-shadow: -1px 5px 20px 0px var(--box-shadow-color);
    }

        .icon-box .icon img {
            width: 77px;
        }

        .icon-box .title {
            margin-bottom: 15px;
            font-size: 24px;
        }

            .icon-box .title a {
                color: var(--color-primary);
                transition: 0.3s;
            }

        .icon-box .icon {
            margin-bottom: 20px;
            padding-top: 10px;
            display: inline-block;
            transition: all 0.3s ease-in-out;
            font-size: 48px;
            line-height: 1;
            color: var(--color-primary);
        }


    /*--------------------------------------------------------------
# Stats Counter Section
--------------------------------------------------------------*/

    .stats-counter .stats-item .purecounter {
        padding-right: 0;
    }

    .stats-counter .stats-item i {
        font-size: 90px;
        line-height: 0;
        color: var(--color-primary);
        margin-bottom: 30px;
    }

    .stats-counter .stats-item span {
        font-size: 24px;
        display: block;
        color: var(--color-primary);
        line-height: 34px;
        text-align: center;
    }

    .stats-counter .stats-item p {
        margin: 0;
        font-family: var(--font-primary);
        font-size: 14px;
        display: flex;
        flex-direction: column;
        align-items: center;
    }


    /*--------------------------------------------------------------
# Portfolio Section
--------------------------------------------------------------*/
    .portfolio .portfolio-flters {
        margin: 0 auto;
        list-style: none;
        text-align: left;
    }

        .portfolio .portfolio-flters li {
            display: inline-block;
            margin: 0 10px;
            margin-bottom: 20px;
            display: inline-block;
            height: 29px;
            vertical-align: middle;
            border-radius: 4px;
            text-align: center;
            padding-top: 3px;
            padding-left: 15px;
            padding-right: 15px;
            cursor: pointer;
            /*transition: 0.3s;*/
            border-color: var(--theme-color);
            border-style: solid;
            border-width: 1px;
            background: var(--theme-color);
            font: var(--unnamed-font-style-normal) normal var(--unnamed-font-weight-normal) var(--unnamed-font-size-15)/var(--unnamed-line-spacing-22-5) var(--unnamed-font-family-saans);
            letter-spacing: var(--unnamed-character-spacing-0-53);
            color: var(--asphalt);
            text-align: center;
            font: normal normal normal 15px/24px Saans;
            letter-spacing: 0.53px;
            opacity: 1;
        }

            .portfolio .portfolio-flters li:hover,
            .portfolio .portfolio-flters li.filter-active {
                background: none;
                border-color: var(--theme-color);
                border-style: solid;
                border-width: 1px;
            }

            .portfolio .portfolio-flters li:first-child {
                margin-left: 0;
            }

            .portfolio .portfolio-flters li:last-child {
                margin-right: 0;
            }

    @media (max-width: 575px) {
        .portfolio .portfolio-flters li {
            font-size: 14px;
        }
    }

    .portfolio-wrap {
        border-radius: 4px;
        height: 100%;
        overflow: hidden;
        position: relative;
    }

        .portfolio-wrap img {
            position: relative;
            z-index: 1;
        }

        .portfolio-wrap .portfolio-info {
            padding: 25px 20px;
            position: absolute;
            z-index: 2;
            bottom: -1px;
        }

    .portfolio .portfolio-wrap {
        border-radius: 8px;
        height: 100%;
        overflow: hidden;
        position: relative;
    }

        .portfolio .portfolio-wrap img {
            transition: 0.3s;
            position: relative;
            z-index: 1;
        }

        .portfolio .portfolio-wrap .portfolio-info {
            padding: 25px 20px;
            position: absolute;
            z-index: 2;
            bottom: -1px;
            -webkit-backdrop-filter: saturate(180%) blur(5px);
            backdrop-filter: saturate(180%) blur(5px);
            background: var(--color-secondary);
            border-radius: 0 8px 0 0;
        }

            .portfolio .portfolio-wrap .portfolio-info:hover {
                /*  background: #1c042e;
*/
            }

            .portfolio .portfolio-wrap .portfolio-info h4 {
                font-size: 18px;
                margin-bottom: 0;
                color: #fff;
            }

                .portfolio .portfolio-wrap .portfolio-info h4 a {
                    color: var(--light-color);
                    transition: 0.3s;
                }

                    .portfolio .portfolio-wrap .portfolio-info h4 a:hover {
                        /* color: var(--color-primary);*/
                    }

        .portfolio .portfolio-wrap .project-btn a {
            color: var(--light-color);
        }

        .portfolio .portfolio-wrap .portfolio-info p {
            color: #6c757d;
            font-size: 14px;
            margin-bottom: 0;
            padding-right: 50px;
        }

        .portfolio .portfolio-wrap .portfolio-info .portfolio-details {
            margin-bottom: 20px;
        }





    /**************************************
  Contact
 **************************************/
    .contact-section .contact-form-3 form .form-control {
        font-size: 15px;
        width: 100%;
        padding: 10px 20px;
        height: 52px;
        color: #fff;
        border: none;
        border-radius: 8px;
        text-transform: capitalize;
        transition: all 0.4s;
        background: var(--theme-color-dark);
    }

    .contact-section .contact-form-3 form input:focus,
    .contact-section .contact-form-3 form textarea:focus {
        outline: none;
        border: none;
        -webkit-box-shadow: none;
        box-shadow: none;
    }

    .contact-information-box-3 {
        padding: 25px 20px;
        border-radius: 8px;
        margin-bottom: 50px;
    }

        .contact-information-box-3 .single-contact-info-box {
            position: relative;
            z-index: 1;
            padding: 10px 10px;
            display: block;
            border-radius: 3px;
            text-align: left;
            margin-bottom: 10px;
            overflow: hidden;
        }

        .contact-information-box-3 .contact-info {
            position: relative;
            z-index: 1;
        }

            .contact-information-box-3 .contact-info h6 {
                font-size: 18px;
                color: var(--text-color);
                margin-bottom: 7px;
                text-transform: capitalize;
            }

            .contact-information-box-3 .contact-info p {
                color: var(--text-color);
                font-size: 14px;
                font-weight: 500;
                margin: 0;
            }

        .contact-information-box-3 .single-contact-info-box .contact-info-bg-icon {
            color: #f44336;
            opacity: .2;
            position: absolute;
            left: 0;
            right: 0;
            bottom: -25px;
            margin: 0 auto;
            z-index: -1;
            -webkit-transition: 0.5s;
            transition: 0.5s;
        }

            .contact-information-box-3 .single-contact-info-box .contact-info-bg-icon i {
                font-size: 100px;
            }

    .contact-section .contact-form .form-group {
        margin-bottom: 30px;
    }

    .contact-section .contact-form form textarea.form-control {
        height: auto;
        padding-top: 15px;
        line-height: initial;
    }

    .contact-section .form-message {
        margin: 0;
    }


        .contact-section .form-message.success {
            background: #03b103;
            color: #fff;
            padding: 10px 15px;
            border-radius: 3px;
            margin-bottom: 30px;
        }

        .contact-section .form-message.error {
            background: #ff4d15;
            color: #fff;
            padding: 10px 15px;
            border-radius: 3px;
            margin-bottom: 30px;
        }

    .contact-area .form-message.success {
        background: #03b103;
        color: #fff;
        padding: 10px 15px;
        border-radius: 3px;
        display: block;
        margin-bottom: 15px;
    }

    .contact-area .form-message.error {
        background: #ff4d15;
        color: #fff;
        padding: 10px 15px;
        border-radius: 3px;
        display: block;
        margin-bottom: 15px;
    }

    .with-errors {
        color: #dc3545;
    }

    .messages {
        margin-top: 30px;
    }

    .alert-success {
        margin-left: 15px;
    }

    .hidden {
        display: none;
    }




    /*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/


    .footer-section {
        background: url(../images/artline/footer-cewe.png) center left;
        background-size: cover;
        padding: 0px 0;
        border-radius: 0px;
        position: relative;
        background-attachment: fixed;
    }

        .footer-section:before {
            content: "";
            position: absolute;
            left: 0;
            bottom: 0;
            top: 0;
            right: 0;
            width: 100%;
            height: 100%;
            background: #000000;
            z-index: 0;
            opacity: 0.8;
        }

    #footer h2 {
        font-size: 80px;
        margin-bottom: 20px;
        color: var(--hero-text-color);
        /* text-transform: capitalize; */
        letter-spacing: 0.7px;
        font-weight: 600;
    }


    .footer-content {
        position: relative;
        z-index: 2;
    }

        .footer-content .list {
            padding-left: 0;
        }

    .footer-pattern img {
        position: absolute;
        top: 0;
        left: 0;
        height: 330px;
        background-size: cover;
        background-position: 100% 100%;
    }

    .footer-logo {
        margin-bottom: 30px;
    }

        .footer-logo img {
            max-width: 200px;
        }

    .footer-widget ul li,
    .footer-widget ul li a {
        font-size: 14px;
    }

    .footer-text p {
        margin-bottom: 14px;
        font-size: 14px;
        color: var(--text-white-color);
        line-height: 28px;
    }


    .footer-widget-heading h3 {
        color: var(--color-primary);
        font-size: 20px;
        font-weight: 500;
        margin-bottom: 20px;
        position: relative;
    }

    .footer-widget ul li {
        display: inline-block;
        float: left;
        width: 100%;
        margin-bottom: 12px;
    }

        .footer-widget ul li a {
            color: var(--text-white-color);
            text-transform: capitalize;
        }

    .subscribe-form {
        position: relative;
        overflow: hidden;
        border-radius: 50px;
    }

        .subscribe-form input {
            width: 100%;
            padding: 14px 28px;
            background: #e4e4e4;
            border: 1px solid #e4e4e4;
            color: #222222;
            outline: none;
        }

        .subscribe-form button {
            position: absolute;
            right: -3px;
            background: transparent;
            border: 0;
            top: -8px;
        }

            .subscribe-form button i {
                color: var(--color-primary);
                font-size: 3rem;
                transform: rotate(-6deg);
            }

    .footer-menu li {
        display: inline-block;
        margin-left: 20px;
    }

        .footer-menu li a {
            font-size: 14px;
        }




    /* Anpassung Bootstrap Forms */
    .form-text {
        margin-top: 0.25rem;
        font-size: 0.875em;
        color: #6c757d;
    }

    .form-control {
        display: block;
        width: 100%;
        padding: .375rem .75rem;
        font: normal normal normal 17px/25px Saans;
        background-color: #fff;
        background-clip: padding-box;
        border: 1px solid #FA9100;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        border-radius: 4px;
        min-height: 40px;
    }

    @media (prefers-reduced-motion: reduce) {
        .form-control {
            transition: none;
        }
    }

    .form-control[type=file] {
        overflow: hidden;
    }

        .form-control[type=file]:not(:disabled):not([readonly]) {
            cursor: pointer;
        }

    .form-control:focus {
        color: black;
        background-color: #fff;
        border-color: #FA9100;
        outline: 0;
        box-shadow: none;
    }

    .form-control::-webkit-date-and-time-value {
        height: 1.5em;
    }

    .form-control::-moz-placeholder {
        color: #A3A3A3;
        opacity: 1;
    }

    .form-control::placeholder {
        color: #A3A3A3;
        opacity: 1;
    }

    .form-control:disabled {
        background-color: #e9ecef;
        opacity: 1;
    }

    .form-control::-webkit-file-upload-button {
        padding: 0.375rem 0.75rem;
        margin: -0.375rem -0.75rem;
        -webkit-margin-end: 0.75rem;
        margin-inline-end: 0.75rem;
        color: #212529;
        background-color: #e9ecef;
        pointer-events: none;
        border-color: inherit;
        border-style: solid;
        border-width: 0;
        border-inline-end-width: 1px;
        border-radius: 0;
        -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
        transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    }

    .form-control::file-selector-button {
        padding: 0.375rem 0.75rem;
        margin: -0.375rem -0.75rem;
        -webkit-margin-end: 0.75rem;
        margin-inline-end: 0.75rem;
        color: #212529;
        background-color: #e9ecef;
        pointer-events: none;
        border-color: inherit;
        border-style: solid;
        border-width: 0;
        border-inline-end-width: 1px;
        border-radius: 0;
        transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    }

    @media (prefers-reduced-motion: reduce) {
        .form-control::-webkit-file-upload-button {
            -webkit-transition: none;
            transition: none;
        }

        .form-control::file-selector-button {
            transition: none;
        }
    }

    .form-control:hover:not(:disabled):not([readonly])::-webkit-file-upload-button {
        background-color: #dde0e3;
    }

    .form-control:hover:not(:disabled):not([readonly])::file-selector-button {
        background-color: #dde0e3;
    }

    .form-control-plaintext {
        display: block;
        width: 100%;
        padding: 0.375rem 0;
        margin-bottom: 0;
        line-height: 1.5;
        color: #212529;
        background-color: transparent;
        border: solid transparent;
        border-width: 1px 0;
    }

        .form-control-plaintext:focus {
            outline: 0;
        }

        .form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
            padding-right: 0;
            padding-left: 0;
        }

    .form-control-sm {
        min-height: calc(1.5em + 0.5rem + 2px);
        padding: 0.25rem 0.5rem;
        font-size: 0.875rem;
        border-radius: 0.25rem;
    }

        .form-control-sm::-webkit-file-upload-button {
            padding: 0.25rem 0.5rem;
            margin: -0.25rem -0.5rem;
            -webkit-margin-end: 0.5rem;
            margin-inline-end: 0.5rem;
        }

        .form-control-sm::file-selector-button {
            padding: 0.25rem 0.5rem;
            margin: -0.25rem -0.5rem;
            -webkit-margin-end: 0.5rem;
            margin-inline-end: 0.5rem;
        }

    .form-control-lg {
        min-height: calc(1.5em + 1rem + 2px);
        padding: 0.5rem 1rem;
        font-size: 1.25rem;
        border-radius: 0.5rem;
    }

        .form-control-lg::-webkit-file-upload-button {
            padding: 0.5rem 1rem;
            margin: -0.5rem -1rem;
            -webkit-margin-end: 1rem;
            margin-inline-end: 1rem;
        }

        .form-control-lg::file-selector-button {
            padding: 0.5rem 1rem;
            margin: -0.5rem -1rem;
            -webkit-margin-end: 1rem;
            margin-inline-end: 1rem;
        }

    textarea.form-control {
        min-height: calc(1.5em + 0.75rem + 2px);
    }

    textarea.form-control-sm {
        min-height: calc(1.5em + 0.5rem + 2px);
    }

    textarea.form-control-lg {
        min-height: calc(1.5em + 1rem + 2px);
    }

    .form-control-color {
        width: 3rem;
        height: calc(1.5em + 0.75rem + 2px);
        padding: 0.375rem;
    }

        .form-control-color:not(:disabled):not([readonly]) {
            cursor: pointer;
        }

        .form-control-color::-moz-color-swatch {
            border: 0 !important;
            border-radius: 0.375rem;
        }

        .form-control-color::-webkit-color-swatch {
            border-radius: 0.375rem;
        }

        .form-control-color.form-control-sm {
            height: calc(1.5em + 0.5rem + 2px);
        }

        .form-control-color.form-control-lg {
            height: calc(1.5em + 1rem + 2px);
        }


/*
* @subsection RD Google Map
*
* @description Describes style declarations for RD Google Map extension
*
* @author Evgeniy Gusarov
* @link https://ua.linkedin.com/pub/evgeniy-gusarov/8a/a40/54a
* @version 1.0.0
*/
.rd-google-map {
    color: #333;
    background: #27292b;
}

.rd-google-map__model {
    height: 250px;
}

    .rd-google-map__model img {
        max-width: none !important;
    }

@media (min-width: 480px) {
    .rd-google-map__model {
        height: 250px;
    }
}

@media (min-width: 768px) {
    .rd-google-map__model {
        height: 400px;
    }
}

@media (min-width: 1200px) {
    .rd-google-map__model {
        height: 450px;
    }
}

@media (min-width: 1800px) {
    .rd-google-map__model {
        height: 482px;
    }
}

.rd-google-map__locations {
    display: none;
}