@font-face {
    font-family: 'MinionProRegular';
    src: url('../fonts/MinionPro-Regular/MinionProRegular.eot');
    src: url('../fonts/MinionPro-Regular/MinionProRegular.eot') format('embedded-opentype'),
         url('../fonts/MinionPro-Regular/MinionProRegular.woff2') format('woff2'),
         url('../fonts/MinionPro-Regular/MinionProRegular.woff') format('woff'),
         url('../fonts/MinionPro-Regular/MinionProRegular.ttf') format('truetype'),
         url('../fonts/MinionPro-Regular/MinionProRegular.svg#MinionProRegular') format('svg');
}

@font-face {
    font-family: 'SourceSansProBlack';
    src: url('../fonts/SourceSansPro-Black/SourceSansProBlack.eot');
    src: url('../fonts/SourceSansPro-Black/SourceSansProBlack.eot') format('embedded-opentype'),
         url('../fonts/SourceSansPro-Black/SourceSansProBlack.woff2') format('woff2'),
         url('../fonts/SourceSansPro-Black/SourceSansProBlack.woff') format('woff'),
         url('../fonts/SourceSansPro-Black/SourceSansProBlack.ttf') format('truetype'),
         url('../fonts/SourceSansPro-Black/SourceSansProBlack.svg#SourceSansProBlack') format('svg');
}

@font-face {
    font-family: 'SourceSansProLight';
    src: url('../fonts/SourceSansPro-Light/SourceSansProLight.eot');
    src: url('../fonts/SourceSansPro-Light/SourceSansProLight.eot') format('embedded-opentype'),
         url('../fonts/SourceSansPro-Light/SourceSansProLight.woff2') format('woff2'),
         url('../fonts/SourceSansPro-Light/SourceSansProLight.woff') format('woff'),
         url('../fonts/SourceSansPro-Light/SourceSansProLight.ttf') format('truetype'),
         url('../fonts/SourceSansPro-Light/SourceSansProLight.svg#SourceSansProLight') format('svg');
}

@font-face {
    font-family: 'SourceSansProRegular';
    src: url('../fonts/SourceSansPro-Regular/SourceSansProRegular.eot');
    src: url('../fonts/SourceSansPro-Regular/SourceSansProRegular.eot') format('embedded-opentype'),
         url('../fonts/SourceSansPro-Regular/SourceSansProRegular.woff2') format('woff2'),
         url('../fonts/SourceSansPro-Regular/SourceSansProRegular.woff') format('woff'),
         url('../fonts/SourceSansPro-Regular/SourceSansProRegular.ttf') format('truetype'),
         url('../fonts/SourceSansPro-Regular/SourceSansProRegular.svg#SourceSansProRegular') format('svg');
}


body {
    font-size: 0.938vw; /* 18px */
    line-height: 1.042vw; /* 20px */
    font-family: 'SourceSansProRegular';
    color: #000000;
    /* display: flex;
    flex-direction: column;
    height: 100vh; */
}

a {
    text-decoration: none;
    /* color: #000000; */
}

main {
    padding-top: 124px;
}

h1 {
    text-align: center;
    color: #fff;
    font-size: 76.8px;
    line-height: 115.2px;
    font-family: 'SourceSansProBlack';
    margin: 0;
}

h2 {
    text-align: center;
    /* color: #fff; */
    font-size: 57.6px;
    line-height: 76.8px;
    font-family: 'SourceSansProBlack';
    margin: 0;
}

h3 {
    text-align: center;
    /* color: #fff; */
    font-size: 38.4px;
    line-height: 48px;
    font-family: 'SourceSansProBlack';
    margin: 0;
}

h4 {
    /* text-align: center; */
    /* color: #fff; */
    font-size: 36.48px;
    line-height: 38.4px;
    font-family: 'SourceSansProBlack';
    margin: 0;
}

h6 {
    text-align: center;
    /* color: #fff; */
    font-size: 28.8px;
    line-height: 38.4px;
    font-family: 'SourceSansProBlack';
    margin: 0;
}

p,
ul li {
    font-size: 22px;
    line-height: 30.01px;
    font-family: 'SourceSansProRegular';
    color: #000000;
}

.primary-text-color {
    color: #0e72ba;
}

.primary-button {
    background: linear-gradient(90deg, #0c82c7 0%, #00aae3 90%);
    padding: 10px 20px;
    font-size: 20px;
    line-height: 25px;
    color: #FFFFFF;
    display: inline-block;
    font-family: 'SourceSansProBlack';
    border-radius: 10px;
    cursor: pointer;
    background-size: 200% 100%;
    background-position-x: 0;
    transition: background-position-x .45s ease;
}

.primary-button:hover {
    /* text-decoration: underline; */
    background-color: #0c82c7;
    background-position-x: -100%;
    color: #0c82c7;
    background-image: linear-gradient(to left, #fff 50%, transparent 50%);
}

.buttons {
    display: flex;
    justify-content: center;
    gap: 10px;
    align-items: center;
}

.buttons.text-left {
    justify-content: start;
}

.buttons.text-right {
    justify-content: end;
}

.wave:before {
    /* content: ""; */
    background-image: url('../Icons/Website_lay3-1.png');
    background-repeat: repeat-x;
    /* background-repeat: no-repeat; */
    width: 100%;
    position: absolute;
    /* left: 0;
    right: 0; */
    top: -30px;
    height: 32px;
}

.wave:after {
    /* content: ""; */
    background-image: url('../Icons/Website_lay3-bottom1.png');
    background-repeat: repeat-x;
    width: 100%;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -32px;
    height: 32px;
}

.text-left {
    text-align: left;
}

/* header */

.header {
    padding: 10px 0;
    position: fixed;
    background-color: #FFFFFF;
    left: 0;
    right: 0;
    z-index: 10;
}

header .row {
    align-items: center;
    justify-content: space-between;
}

header .navbar-menu ul {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    list-style-type: none;
    justify-content: space-between;
    padding: 0;
}

header .navbar-menu ul li.menu-item-has-children span {
    display: flex;
}

header .navbar-menu ul li.menu-item-has-children span {
    content: "";
    background-image: url('../Icons/down-arrow.svg');
    background-repeat: no-repeat;
    width: 15px;
    height: 8px;
    transform: rotate(0deg);
    transition: transform .5s;
}

header .navbar-menu ul li.menu-item-has-children.open-menu span {
    transform: rotate(180deg);
}

header .navbar-menu ul li {
    font-size: 20px; /* 1.042vw */
    line-height: 30px; /* 1.563vw */
    position: relative;
}

header .navbar-menu ul li a {
    text-decoration: none;
    color: #000000;
    display: flex;
    align-items: center;
    gap: 8px;
}

header .navbar-menu ul li:hover > a,
header .navbar-menu ul li.current_page_item > a,
header .navbar-menu ul li.current_page_ancestor > a {
    background: linear-gradient(90deg, #0c82c7 0%, #00aae3 90%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}

header .navbar-menu ul .sub-menu {
    display: none;
    position: absolute;
    left: 0;
    top: 144%;
    background-color: #fff;
    min-width: 215px;
    z-index: 9;
    padding: 5px;
    box-shadow: -1px 2px 12px -3px rgba(0,0,0,0.75);
}

/* header ul > li:hover .sub-menu {
    display: block;
} */

.contact-details p {
    text-align: right;
}

.contact-details p a {
    background: linear-gradient(90deg, #0c82c7 0%, #00aae3 90%);
    color: #FFFFFF;
    padding: 5px 15px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 25px; /* 1.302vw */
    line-height: 30px; /* 1.563vw */
    font-family: 'SourceSansProBlack';
    border-radius: 12px;
}

.contact-details p a::before {
    content: "";
    background-image: url('../Icons/phone-icon.svg');
    background-repeat: no-repeat;
    width: 30px;
    height: 30px;
}

.mobile-menu {
    display: none;
}

/* footer */

footer {
    background-color: #24418e;
    padding-top: 90px;
    padding-bottom: 90px;
    color: #FFFFFF;
    margin-top: auto;
}

footer a {
    text-decoration: none;
    color: #FFFFFF;
}

footer ul {
    list-style-type: none;
    padding-left: 0;
    margin: 0;
}

footer li {
    padding: 5px 0;
}

footer li:hover a {
    color: #FFFFFF;
}

footer .social-icons {
    display: inline-flex;
    gap: 20px;
    padding-left: 20px;
}

footer .social-icons li {
    background-color: #FFFFFF;
    width: 40px;
    height: 40px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 0;
    padding: 0 !important;
}

footer .social-icons li a {
    padding: 0 !important;
}

footer .social-icons li svg {
    width: 40px !important;
    height: 40px !important;
    fill: #24418e !important;
}

footer .footer_logo {
    display: inline-block;
}

footer .footer_logo figure {
    margin: 0 !important;
}

footer .footer_logo img {
    width: 150px;
}

footer .footer-description {
    padding-top: 30px;
    display: flex;
    flex-direction: column;
    gap: 30px;
}

footer .footer-description p {
    margin: 0;
}

footer p {
    color: #FFFFFF;
}

.mail-phone {
    position: fixed;
    z-index: 9;
    bottom: 20px;
    right: 20px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.mail-phone .mail,
.mail-phone .phone {
    background: linear-gradient(90deg, #0c82c7 0%, #00aae3 90%);
    width: 5vw;
    height: 5vw;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mail-phone .mail img,
.mail-phone .phone img {
    width: 3vw;
}

/* hero_element */

.hero_element {
    background-repeat: no-repeat;
    background-size: cover;
    height: calc(100vh - 124px);
    position: relative;
    /* z-index: 2; */
}

.hero_element > .bg-overlay {
    height: 100%;
}

.hero_element > .bg-overlay:after {
    content: "";
    /* background-image: url('../Icons/overly.png'); */
    /* background-size: cover; */
    background-color: rgb(0 0 0 / 22%);
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
}

.hero_element .hero-element-outer:before,
.hero_element .hero-element-outer:after {
    content: "";
    background-repeat: no-repeat;
    position: absolute;
}

.hero_element .hero-element-outer:before {
    top: -10px;
    left: 60px;
    width: 173px;
    height: 152px;
    z-index: 9;
}

.hero_element .hero-element-outer:after {
    bottom: 83px;
    right: 20%;
    width: 42px;
    height: 59px;
}

.hero_element .bg-overlay > .container {
    display: flex;
    height: 100%;
    justify-content: center;
    padding: 50px 0;
    position: relative;
    z-index: 1;
}

.hero_element .hero-element-text {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-evenly;
    align-items: center;
    gap: 30px;
}

.hero_element .hero-element-text .heading {
    display: flex;
    height: 100%;
    align-items: end;
    justify-content: center;
}

.scroll-down-icon {
    width: 50px;
    height: 50px;
    cursor: pointer;
}

/* offer_layout */

.offer_layout {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom;
    padding: 300px 0 350px;
    min-height: 20%;
    margin-top: -250px;
    position: relative;
    --mask:
    radial-gradient(447.21px at 50% 600px,#000 99%,#0000 101%) calc(50% - 400px) 0/800px 51% repeat-x,
    radial-gradient(447.21px at 50% -400px,#0000 99%,#000 101%) 50% 200px/800px calc(51% - 200px) repeat-x,
    radial-gradient(447.21px at 50% calc(100% - 600px),#000 99%,#0000 101%) calc(50% - 400px) 100%/800px 51% repeat-x,
    radial-gradient(447.21px at 50% calc(100% + 400px),#0000 99%,#000 101%) 50% calc(100% - 200px)/800px calc(51% - 200px) repeat-x;
    -webkit-mask: var(--mask);
    mask: var(--mask);
}
.no-background{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom;
    padding: 150px 0 150px;
    min-height: 20%;
    margin-top: -250px;
    position: relative;
    mask: unset!important;
    -webkit-mask: unset!important;
}

.offer_layout .offer-text {
    text-align: center;
}

.offer_layout .offer-text .heading {
    padding-bottom: 50px;
    color: #0065b7;
}

.offer_layout .offer-text .offer_grid .heading {
    padding: 0;
}

.offer_layout .offer-text .subheading {
    color: #0065b7;
}

.offer_layout .offer-text .offer_grid .image {
    padding-bottom: 20px;
}

.offer_layout .offer-text .offer_grid .image img {
    width: 100%;
    object-fit: contain;
}

.offer_layout .offer-text .button-text {
    padding-top: 30px;
}

.offer_layout .offer-layout-inner {
    justify-content: space-between;
}

/* advice_layout */

.advice_layout {
    margin-top: -320px;
}

.advice_layout > .container {
    position: relative;
    display: flex;
    justify-content: center;
}

.advice_layout .heading {
    display: inline-block;
    color: #fff;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background: linear-gradient(360deg, hsla(0, 0%, 0%, 1) 0%, hsla(1, 76%, 50%, 1) 24%);;
    display: flex;
    justify-content: center;
    align-items: center;
    transform: rotate(-9deg);
    padding-bottom: 26px;
    margin-left: 5px;
}

.advice_layout .heading h5 {
    font-family: 'SourceSansProBlack';
    font-size: 22px;
}

.advice_layout .advice-image {
    display: inline-block;
    position: absolute;
    bottom: -16px;
    left: auto;
}

.advice_layout  .advice-image img {
    width: 200px;
}

.heading_with_text_and_button,
.two_column_layout_text_and_image,
.services,
.kontakt,
.news_layout {
    padding-top: 100px;
    padding-bottom: 100px;
}

.two_column_layout_text_and_image + .two_column_layout_text_and_image {
    padding-top: 0;
}

/* heading_with_text_and_button */

.heading_with_text_and_button .description {
    padding-top: 30px;
    padding-bottom: 30px;
}

.heading_with_text_and_button {
    /* min-height: 13%; */
    display: flex;
}

.heading_with_text_and_button > .container {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.wave-up,
.wave-bottom {
    width: 100%;
}

/* two_column_layout_text_and_image */

.two_column_layout_text_and_image .row {
    justify-content: space-between;
}

.two_column_layout_text_and_image img {
    width: 100%;
}

.two_column_layout_text_and_image .description {
    padding-top: 30px;
}

.description ul li {
    padding: 5px 0;
}

/* .two_column_layout_text_and_image .left-image:before {
    content: "";
    background-repeat: no-repeat;
} */

/* services */

.services,
.heading_with_text_and_button {
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 1;
    position: relative;
    padding-top: 30px;
    padding-bottom: 30px;
}

.services .row {
    justify-content: center;
}

.services .service_items_outer {
    padding-bottom: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.services .service-heading-description,
.services .service-heading-description > h3 {
    padding-bottom: 30px;
}

/* kontakt */

.kontakt {
    background: linear-gradient(1800deg, #0c82c7 0%, #00aae3 90%);
    margin-top: -250px;
    padding-top: 320px;
}

.kontakt h2 {
    padding-bottom: 60px;
}

.kontakt .map iframe {
    width: 100%;
    height: 350px;
}

.kontakt .logo-image-outer img.logo-image {
    width: 150px;
    border-radius: 50%;
    padding-right: 15px;
}

.kontakt .row {
    justify-content: space-between;
    margin-left: -25px;
    margin-right: -25px;
}

.kontakt .row .col-12 {
    padding-left: 25px;
    padding-right: 25px;
}

.kontakt p {
    color: #FFFFFF;
}

.kontakt .form_description {
    padding-top: 30px;
}

.kontakt .form_description label {
    display: block;
}

.kontakt .form_description .form-control {
    border-radius: 0;
}

.form_description .primary-button {
    border: 0;
    border-radius: 10px;
}

/* news_layout */

.news_layout .post-list {
    width: 85%;
    margin: 0 auto;
    /* position: relative; */
}

.news_layout .post-image {
    display: flex;
    align-items: center;
    justify-content: center;
}

.news_layout .post-heading-text {
    position: absolute;
    width: 25%;
    top: 40%;
    color: #fff;
    left: 35%;
}

.news_layout .post-heading-text a,
.news_layout .post-heading-text p {
    color: #FFFFFF;
    text-align: center;
}

.news_layout .post-list .news-slider img {
    width: 100%;
    margin-left: 85px;
}

.news_layout .swiper-button-prev {
    background: linear-gradient(to right, #4a00e0, #00aaff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}

.news_layout .swiper-button-next {
    background: linear-gradient(to right, #00aaff, #4a00e0);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}

.news_layout .post-heading-text > a {
    padding-bottom: 15px;
    display: block;
}

.news_layout .post-list .button-prev,
.news_layout .post-list .button-next {
    position: absolute;
    top: 50%;
    cursor: pointer;
    z-index: 9;
    height: 50px;
}

.news_layout > .container {
    position: relative;
}

.news_layout .post-list .button-prev {
    left: 30px;
}

.news_layout .post-list .button-next {
    right: 30px;
}


/* column_layout */

.column_layout {
    padding-top: 100px;
    padding-bottom: 100px;
}

.column_layout .column-image {
    padding-bottom: 33px;
}

.column_layout .column-text .buttons {
    padding-top: 11px;
}

.column_layout .column_items {
    padding-top: 30px;
}

.column_layout .column_items_outer {
    padding-bottom: 20px;
    padding-top: 20px;
}

/* table_section */

.table_section {
    padding-top: 100px;
    padding-bottom: 100px;
}

.table_section h2 {
    padding-bottom: 20px;
}

.table_section h3 {
    text-align: left;
    padding-bottom: 10px;
}

.table_section h3 span {
    color: #2112e0;
}

.table_section h3 span.text-green {
    color: #03bd03;
}

table {
    width: 100%;
}

table.cm_table {
    border-spacing: 0px;
    width: 100%;
    margin: 10px 0;
    text-align: left;
    table-layout: fixed;
    border: 1px solid;
    width: 100%;
}

table.cm_table td {
    border-right: 1px solid;
    border-bottom: 1px solid;
}

table.without-border {
    border: none;
}

table.without-border  td {
    border: none;
}

table td {
    padding: 5px;
    border-bottom: 1px solid #6b6b6b;
}

form p {
    text-align: left;
}

form .form-control {
    padding: 11px 12px;
    border-radius: 0;
    border: 1px solid rgba(107,107,107,0.45);
}

form .form-control:focus {
    box-shadow: 0 0 6px rgba(107,107,107,0.4);
    border: 1px solid #6B6B6B;
}

form .submit-button .col-6:last-child p {
    text-align: right;
}

form .submit-button .primary-button {
    border: none;
}

form .submit-button .wpcf7-spinner {
    display: none;
}

form p label {
    width: 100%;
}

form .wpcf7-submit {
    border: 0;
}

.accordion_items {
    padding: 50px 0;
}

.accordion-flush .accordion-item .accordion-header .accordion-button {
    font-size: 25px;
    line-height: 30px;
}

.accordion-flush .accordion-item .accordion-header .accordion-button:focus {
    box-shadow: none;
    background-color: transparent;
}

.image_gallery {
    padding-top: 50px;
    padding-bottom: 50px;
}

.image_gallery img {
    margin-bottom: 0.5em;
}

.image_gallery .image_gallery_items {
    display: inline-block;
}

.image_gallery .example-image-link {
    display: inline-block;
}

.image_gallery .image_gallery_items img {
    width: 100%;
    height: auto;
}

.image_gallery .image_gallery_items_outer {
    position: relative;
}

.image_gallery .image_gallery_items_outer .heading {
    padding: .5em;
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    background: rgba(0, 0, 0, .6);
    box-shadow: inset 0 0 0 .1em rgba(0, 0, 0, .1);
    transition: opacity .4s ease-in;
    right: 0;
    bottom: 12px;
    left: 0;
    color: #FFFFFF;
}

.image_gallery .image_gallery_items_outer:hover .heading  {
    opacity: 1;
}

.image_gallery .container > .heading  {
    padding-bottom: 20px;
}