@font-face {
    font-family: 'AvenirNextLTPro-Regular';
    src: url('../fonts/avenirnextltpro-regular.eot');
    /* IE 9 Compatibility Mode */
    src: url('../fonts/avenirnextltpro-regular.eot?#iefix') format('embedded-opentype'),
        /* IE < 9 */
        url('../fonts/avenirnextltpro-regular.woff2') format('woff2'),
        /* Super Modern Browsers */
        url('../fonts/avenirnextltpro-regular.woff') format('woff'),
        /* Firefox >= 3.6, any other modern browser */
        url('../fonts/avenirnextltpro-regular.ttf') format('truetype'),
        /* Safari, Android, iOS */
        url('../fonts/avenirnextltpro-regular.svg#avenirnextltpro-regular') format('svg');
    /* Chrome < 4, Legacy iOS */
}

@font-face {
    font-family: 'AvenirNextLTPro-Bold';
    src: url('../fonts/avenirnextltpro-bold.eot');
    /* IE 9 Compatibility Mode */
    src: url('../fonts/avenirnextltpro-bold.eot?#iefix') format('embedded-opentype'),
        /* IE < 9 */
        url('../fonts/avenirnextltpro-bold.woff2') format('woff2'),
        /* Super Modern Browsers */
        url('../fonts/avenirnextltpro-bold.woff') format('woff'),
        /* Firefox >= 3.6, any other modern browser */
        url('../fonts/avenirnextltpro-bold.ttf') format('truetype'),
        /* Safari, Android, iOS */
        url('../fonts/avenirnextltpro-bold.svg#avenirnextltpro-bold') format('svg');
    /* Chrome < 4, Legacy iOS */
}


@font-face {
    font-family: 'AvenirNextLTPro-Light';
    src: url('../fonts/avenirnextltpro-light.eot');
    /* IE 9 Compatibility Mode */
    src: url('../fonts/avenirnextltpro-light.eot?#iefix') format('embedded-opentype'),
        /* IE < 9 */
        url('../fonts/avenirnextltpro-light.woff2') format('woff2'),
        /* Super Modern Browsers */
        url('../fonts/avenirnextltpro-light.woff') format('woff'),
        /* Firefox >= 3.6, any other modern browser */
        url('../fonts/avenirnextltpro-light.ttf') format('truetype'),
        /* Safari, Android, iOS */
        url('../fonts/avenirnextltpro-light.svg#avenirnextltpro-light') format('svg');
    /* Chrome < 4, Legacy iOS */
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'AvenirNextLTPro-Regular', Roboto, sans-serif;
    font-weight: 400;
}

ul {
    list-style: none;
}

a {
    text-decoration: none;
}

button {
    border: none;
    outline: none;
    cursor: pointer;
}

/* HEADER */

.header .container {
    max-width: 1146px;
    margin: 15px auto 25px;
    display: flex;
    justify-content: space-between;
}

.header .container div {
    display: flex;
    align-items: center;
}

.logo img {
    width: 190px;
}

.catalog-btn,
.catalog-btn_mobile {
    padding-top: 11px;
    text-align: center;
    width: 150px;
    height: 40px;
    background: linear-gradient(#FF3923 0%, #FF582C 100%);
    color: #fff;
    text-transform: uppercase;
    font-size: 18px;
    border-radius: 40px;
}

.social {
    margin-left: 30px;
}

.inst {
    background: url(img/inst.svg) no-repeat center/contain;
    width: 34px;
    height: 34px;
    margin-left: 20px;
}

.fb {
    background: url(img/fb.svg) no-repeat center/contain;
    width: 34px;
    height: 34px;
    margin-left: 10px;
}

.burger {
    display: none;
}

/* HERO */

.hero div h1,
.footer-title {
    font-family: 'AvenirNextLTPro-Bold';
    background: rgb(0, 23, 30, 0.69);
    font-size: 64px;
    padding: 50px 0;
    color: #fff;
    text-align: center;
    text-transform: uppercase;
}

.hero div h1 span:nth-child(2) {
    color: #2CBCC6;
    margin-left: 20px;
}

.hero-wrapper {
    background: url(img/hero_bg.png) no-repeat center/cover;
    height: 75vh;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: end;
}

.catalog-btn_mobile {
    display: none;
}

.hero .title {
    position: relative;
}

.arrow-orange,
.arrow-blue {
    top: -20px;
    left: 50%;
    transform: translate(-50%);
}

.arrow-orange {
    background:
        url(img/arrow.svg) no-repeat center center/ 15px auto,
        linear-gradient(#FF3923 0%, #FF582C 100%);
    width: 50px;
    height: 50px;
    border-radius: 100%;
    position: absolute;
}

.descr {
    background: #01303D;
    padding: 70px 0;
}

.hero p {
    color: #fff;
    font-size: 40;
    text-align: center;
    margin: 0 auto;
    max-width: 1170;
    font-weight: 300;
}

/* CLIENTS */

.container {
    max-width: 1170px;
    margin: 0 auto;
}

.clients-container {
    margin: 0 auto;
    position: relative;
    padding: 90px 0;
}

.clients-container .arrow-orange {
    top: -20px;
    left: 50%;
    transform: translate(-50%);
}

h2 {
    margin-bottom: 45px;
    text-align: center;
    font-size: 40px;
    text-transform: uppercase;
    color: #014657;
}

.clients-container ul,
.features-container ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.clients-container ul li,
.features-container ul li {
    display: flex;
    width: 196px;
    flex-direction: column;
    align-items: center;
}

.clients-container ul div,
.features-container ul div {
    width: 164px;
    height: 121px;
    margin-left: -41px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: bottom;
}

.clients-container ul li:nth-child(1) div {
    background-image: url(img/clients/villas.svg);
}

.clients-container ul li:nth-child(2) div {
    background-image: url(img/clients/apart.svg);
}

.clients-container ul li:nth-child(3) div {
    background-image: url(img/clients/hotels.svg);
}

.clients-container ul li:nth-child(4) div {
    background-image: url(img/clients/restorants.svg);
}


.clients-container ul h3 {
    text-align: center;
    margin-top: 20px;
    color: #FF3D24;
}

.clients-container ul p {
    text-align: center;
    width: 165px;
    margin-top: 12px;
    color: #182B45;
}

/* CATEGORIES */

.arrow-blue {
    background:
        url(img/arrow.svg) no-repeat center center/ 15px auto,
        linear-gradient(#009AA4 0%, #00A0AC 100%);
    width: 50px;
    height: 50px;
    border-radius: 100%;
    position: absolute;
}

.categories {
    background: #CBDBDF;
}

.categories-container {
    margin: 0 auto;
    padding: 66px 0 100px;
    position: relative;
}

.categories-container ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: 20px 16px;
    margin: 70px auto 0;
}

.categories-container ul li img {
    width: 100%;
}

.categories-container ul li {
    background: #fff;
    padding: 14px 15px 0;
    width: fit-content;
}

.categories-container ul li a {
    display: block;
    font-size: 18px;
    color: #009AA4;
    text-align: center;
    margin-top: 40px;
    padding-bottom: 33px;
}


/* FEATURES */

.features-container {
    padding: 66px 0 100px;
    position: relative;
}

.features-container ul {
    margin-top: 80px;
}

.features-container ul p {
    color: #182B45;
    width: 200px;
    text-align: center;
    margin-top: 20px;
}

.features-container ul li:nth-child(1) div {
    background-image: url(img/features/1.svg);
}

.features-container ul li:nth-child(2) div {
    background-image: url(img/features/2.svg);
}

.features-container ul li:nth-child(3) div {
    background-image: url(img/features/3.svg);
}

.features-container ul li:nth-child(4) div {
    background-image: url(img/features/4.svg);
}

/* FOOTER */

.footer {
    background:
        linear-gradient(rgba(0, 23, 30, 0.2), rgba(0, 23, 30, 0.2)),
        url(img/footer_bg.png) no-repeat center/cover;
    height: 900px;
    position: relative;
    color: #fff;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.footer-title {
    background: none;
    padding-top: 196px;
}

.footer button {
    font-size: 18px;
    text-transform: uppercase;
    margin: 0 auto;
    display: block;
    width: 320px;
    height: 60px;
    border-radius: 40px;
    color: #fff;
    background: linear-gradient(#FF3923 0%, #FF582C 100%);
}

.footer-wrapper .container {
    display: grid;
    grid-template-columns: 1fr 1.1fr 2fr;
    width: fit-content;
}

.footer-wrapper {
    padding: 73px 0;
    margin-top: auto;
    background: rgb(0, 23, 30, 0.69);

}

h4 {
    font-size: 24px;
    margin-bottom: 26px;
}

.footer-wrapper .container>div:nth-of-type(1) ul li,
.footer-wrapper_mobile .container>div:nth-of-type(1) ul li {
    margin-bottom: 16px;
}

.footer-wrapper .container>div:nth-of-type(1) ul li a,
.footer-wrapper_mobile .container>div:nth-of-type(1) ul li a {
    color: #fff;
}

.footer .social {
    display: flex;
    align-items: center;
}

.footer-wrapper .social div {
    width: 119px;
}

.footer .inst {
    display: block;
    width: 34px;
    height: 34px;
    background: url(img/inst_blue.svg) no-repeat;
}

.footer .fb {
    display: block;
    width: 34px;
    height: 34px;
    background: url(img/fb_blue.svg) no-repeat;
}

.footer-wrapper .container>div:nth-of-type(3) .logo img {
    width: 180px;
}

.footer .container>div:nth-of-type(3) {
    display: flex;
    flex-direction: column;
    align-items: end;
    gap: 45px;
}

.tel {
    color: #fff;
    font-size: 32px;
}

.mail {
    color: #fff;
    background: url(img/mail.svg) no-repeat center left;
    padding-left: 30px;
    margin-top: 15px;
    display: block;
}

.address {
    background: url(img/place.svg) no-repeat top left;
    padding-left: 30px;
    margin-top: 15px;
    width: 250px;
}

.footer-wrapper_mobile,
.banner-footer {
    display: none;
}




@media (max-width: 1170px) {
    .header .container {
        padding: 0 20px;
    }

    .hero div h1,
    .footer-title {
        font-size: 48px;
    }

    .hero p,
    .container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .tel {
        display: block;
        width: 277px;
    }
}

@media (max-width:768px) {

    .header .container .social div {
        display: none;
    }

    .descr p {
        font-size: 32px;
    }

    .footer-wrapper .container {
        grid-template-columns: 1fr;
        width: 100%;
        gap: 25px;
    }

    .footer .container>div:nth-of-type(3) {
        align-items: start;
    }

    .footer-wrapper {
        display: none;
    }

    .footer {
        background: none;
        height: auto;
    }

    .footer-title {
        padding: 0;
        margin-bottom: 70px;
    }

    .banner-footer {
        padding: 93px 20px 64px;
        display: block;
        background:
            linear-gradient(rgba(0, 23, 30, 0.2), rgba(0, 23, 30, 0.2)),
            url(img/footer_bg.png) no-repeat center/cover;
    }

    .footer-wrapper_mobile {
        display: block;
        background: #01303D;
        padding: 40px 0;
    }

    .footer-wrapper_mobile .container {
        display: flex;
        flex-direction: column;
        gap: 30px;
    }

    .footer>.arrow-orange,
    .footer>.footer-title,
    .footer>button {
        display: none;
    }

    .clients-container ul,
    .features-container ul {
        gap: 30px;
        margin: 0 auto;
        max-width: 441px;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }

    .footer .logo {
        display: none;
    }

    .footer .social {
        margin: 0;
    }
}

@media (max-width: 575px) {

    .burger {
        display: block;
        background: url(img/menu.svg) no-repeat center/contain;
        width: 30px;
        height: 30px;
        margin-left: 20px;
    }

    .hero-wrapper {
        background: url(img/hero-mob_bg.png) no-repeat center/cover;
    }

    .hero-wrapper .arrow-orange {
        display: none;
    }

    .hero div h1,
    .footer-title {
        padding-bottom: 20px;
    }

    .btn_mobile {
        background: rgb(0, 23, 30, 0.69);
        width: 100%;
        padding-bottom: 43px;
    }

    .catalog-btn_mobile {
        display: block;
        margin: 0 auto;
    }

    .categories-container {
        padding: 44px 0;
    }

    .categories-container ul {
        margin: 44px auto 0;
        padding: 0 20px;
    }

    .logo img {
        width: 116px;
    }

    .hero-wrapper {
        height: 90vh;
    }

    h2 {
        font-size: 28px;
    }

    .descr {
        padding: 38px 0;
    }

    .descr p {
        font-size: 20px;
    }

    .clients-container {
        padding: 45px 0 69px;
    }

    .catalog-btn {
        display: none;
    }

    .categories-container ul {
        width: fit-content;
        grid-template-columns: repeat(1, 1fr);
    }

    .clients-container ul,
    .features-container ul {
        flex-direction: column;
    }

    .hero div h1 span:first-child {
        width: 235px;
    }

    .hero div h1,
    .footer-title {
        display: flex;
        font-size: 32px;
        flex-direction: column;
        align-items: center;
    }

    .footer-title {
        margin: 0 auto 70px;
        width: 235px;
    }

    h4 {
        margin-bottom: 20px;
    }

    .social div {
        font-size: 14px;
    }
}