/*************************************************************************
                            GENERAL SETTINGS
*************************************************************************/
*{ margin: 0; padding: 0; list-style: none; text-decoration: none; }
@font-face { font-family: "Cairo"; src: url("../fonts/Cairo-Regular.ttf"); }
::-webkit-scrollbar {
    width: 0px;
  }
  
body { font-family: Cairo; background: #191919!important; }
.body-scroll { height: calc(100vh - 100px); overflow: hidden; }
img { width: 100%; }
a{ outline: none; cursor: pointer; }
.d-none { display: none; }
/* MOBILE GENERICS */
#app { min-height: 100vh; }
#gg-screen { background: rgba(0, 0, 0, 0.85)!important; }
.gg-element img { border-radius: 0!important; }
.back-to-top-arrow { width: 200px; text-align: center; margin-bottom: 20px; }
.back-to-top-arrow img { width: 30px; }
.back-to-top-arrow a, .back-to-top-arrow p  { color: #fff; font-size: 16px!important; text-align: center!important; }
.home-footer { margin-top: 50px; display: flex; justify-content: center; }
.galler-left-side-top-title, .title { color: #FF6637; font-size: 28px; }
.subtitle { color: rgba(255, 255, 255, .5); font-size: 20px; line-height: 10px; }
.my-4 { margin-top: 40px; margin-bottom: 40px; }
.color-orange { color: #FF6637; }
.home-menu { display: none; }
.loading { z-index: 999999999; position: fixed; background: #0B0A0C; top: 0; left: 0; bottom: 0; right: 0; display: flex; justify-content: center; align-items: center; }
.prev, .next { display: inline-block; width: 45px; position: relative; }
.gallery-arrow { display: none; }
.gallery-arrow-mobile { display: flex; justify-content: space-between; margin: 30px 0; }
.filter-desktop { display: none; }
.gallery-left-side-top { margin: 10px auto; }
.gg-bt { background: transparent!important; font-size: 55px!important; color: #fff!important; border: 0!important; }
.gg-bt:hover { border: 0!important; }
iframe { width: 1198px!important; height: 674px; }

/*************************************************************************
                            MENU MOBILE
*************************************************************************/
.mobile-bottom-nav { position:fixed; bottom:0; left:0; right:0; z-index:1000; transform: translateZ(0); display:flex; background: #000; justify-content: space-between; padding: 24px 5px 10px; }
.mobile-bottom-nav__item { width: 85px; color: rgba(255, 255, 255, .3); cursor: pointer; text-align: center; }
.mobile-bottom-nav__item--active { color:#FF6637; }
.mobile-bottom-nav__item-content { display:flex; flex-direction:column; font-size: 14px; }
.mobile-bottom-nav__item-icon img { height: 28px; }
.mobile-bottom-nav:before { content: ''; position: absolute; bottom: 80px; left: 0; width: 100%; height: 35px; background: #191919; border-radius: 0 0 50px 50px; z-index: 9999; }
.mobile-bottom-nav:after { content: ''; position: absolute; bottom: 85px; left: 0; width: 100%; height: 30px; background: #000; }
.content-containers { color: #fff; padding: 20px; }
.content-containers p { font-size: 15px; }
.content-containers [class="container-*"] { margin-bottom: 20px; }

/* HOME PAGE */
.home-projects-list-item { position: relative; overflow: hidden; margin: 5px auto 0; cursor: pointer; height: auto; }
.home-projects-list-item-content { background: rgba(0, 0, 0, .5); color: #fff; display: none; justify-content: center; align-items: center; position: absolute; width: 100%; height: 100%; top: 0; right: 0; }
.home-projects-list-item:hover .home-projects-list-item-content { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; }
.home-filter { width: 200px; margin: 10px auto 30px; cursor: pointer; }
.home-filter-modal { text-transform: uppercase; background: #404040; position: fixed; top: 0px; left: 0; width: 300px; transition: all .5s; z-index: 9999; padding: 20px 0; border-radius: 20px;  }
.home-filter-modal input[type="checkbox"] { display: none;}
.home-filter-modal li { padding: 10px 0; }
.home-filter-modal label { display: flex; justify-content: center; cursor: pointer; align-items: center; }
.home-filter-modal label .span{ width: 116px; transition: all .5s; font-size: 16px; }
.home-filter-modal label .span div { width: 140px; margin: auto; }
.home-filter-modal label:hover > .span, .filter-actived{ color: #FF6637; }
.filter-image{ width: 30px; }
.home-filter-modal-close { display: block; width: 25px; margin: 0 auto 50px; cursor: pointer; }
/* ABOUT PAGE */
.logo-mark { width: 150px; margin: 0 auto 20px; padding-top: 10px; }

/* SERVICE PAGE */
.service-icon { width: 160px; margin: 50px auto; }
.service-title { color: #FF6637; font-size: 20px; text-align: center; }
.slick-arrow { display: none!important; }
.service-arrow { width: 0px; }

/* CONTACT PAGE */
.contact-video{ border-radius: 7px;}
.contact-info { margin: 30px auto; font-size: 23px; }
.contact-info a{ color: #fff; }
.contact-social ul{ display: flex; max-width: 300px; justify-content: space-between; align-items: center; list-style: none; }
.contact-social ul li{ width: 40px; }
.form-group { margin: 0px auto 20px; }
.form-control { width: 100%; padding: 15px; box-sizing: border-box; color: #fff; text-align: center; font-size: 20px; border-radius: 10px; outline: none; border: 1px solid #fff; background: transparent; }
.form-btn { display: flex; align-items: center;border: none; background: transparent; font-size: 25px; color: #fff; display: flex; justify-content: space-around; text-decoration: none; width: 200px; margin: 20px auto; }
.title-web { display: none; }
.close-modal-web { cursor: pointer; width: 35px; }
.modal-gallery-close { display: flex; justify-content: center; }

.gallery-header { display: flex; align-items: center; justify-content: space-between; width: 100%; margin: 20px 0; }

@media screen and (min-width: 1200px){
    /** GENERAL **/
    .loading .loading-img { width: 600px; }
    .slick-slide { height: auto!important; }
    .modal-web { background: rgba(45, 31, 31, .99); position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 9999; min-height: 100vh; height: auto; overflow-x: hidden; overflow-y: auto; }
    .slick-controls { display: flex; justify-content: space-between; width: 100%; z-index: 99999; padding: 0 50px; box-sizing: border-box; }
    .title-web{ display: flex; justify-content: space-between; margin: 35px 50px 0px }
    .title-web h2{ color:#FF6637; font-size: 1.3em; }
    .slide-web > div{ padding: 0 50px; }
    .content-containers p { text-align: justify; }
    .footer-mobile-only { display: none;}
    /** HOME **/
    .home-projects-list { display: flex; flex-wrap: wrap; width: calc(100% - 30px); justify-content: flex-start; margin: auto; }
    .home-projects-list-item { height: 300px; display: flex; }
    .item { position: absolute; text-align: center; font-size: 1em; line-height: 1.5em; box-sizing: border-box; }
    .home-projects-list-item-highlight { height: 601px!important }
    .home-menu { display: flex; justify-content: flex-end; width: 100%; margin: 0 auto 10px; }
    .home-menu ul{ width: 300px; display: flex; justify-content: space-between; padding: 10px 50px; }
    .home-menu ul li{ cursor: pointer; color: rgba(255, 255, 255, .3); padding: 0 5px; }
    .home-menu ul li:hover{ transition: all .5s; color: #FF6637; }
    .home-filter { display: none; }
    .filter-desktop { position: fixed; top: -14px; left: -8px; height: 100vh; z-index: 9; display: flex; align-items: center; }
    .filter-desktop-close { left: 3px; top: 0; }
    .filter-desktop a{ color: #fff; display: inline-block; transform: rotate(270deg); position: relative; text-align: center; }
    .filter-desktop a:before, .filter-desktop a:after{ content: ''; display: inline-block; width: 20px; height: 1px; background: #fff; position: absolute; }
    .filter-desktop a:before { top: 13px; left: -30px; }
    .filter-desktop a:after { top: 14px; right: -30px; }
    .w-100 { max-width: 450px; left: 35px; }
    .home-filter-modal label .span { width: 0; overflow: hidden; }
    .home-filter-modal-close { display: none; }
    .home-filter-modal label:hover > .span, .filter-actived{ padding-left: 20px!important; width: 140px!important; }
    .home-filter-modal { top: 300px; left: 35px; }
    .container-home { position: relative; }
    .logo-home { display: block; position: absolute; top: 0px; width: 150px; left: 30px; z-index: 9999;}
    svg path { transition: all .5s; cursor: pointer; }
    svg:hover path { fill: rgba(255, 255, 255, 1)!important; }
    /** ABOUT **/
    
    .container-about { display: flex; align-items: center; justify-content: center; margin: 50px; flex-wrap: wrap; }
    .about-image { width: 450px; margin-right: 20px; }
    .about-content { max-width: 400px; margin-right: 20px; text-align: center; padding-top: 120px; }
    .about-image-container{ display: flex; }
    .about-image img { width: 100%; }
    .logo-mark { display: none; }
    /** SERVICES **/
    .container-service { max-width: 1200px; margin: 100px auto; }
    .service-content { max-width: 450px; margin: 10px auto; text-align: center; }
    .service-display-flex { display: flex; justify-content: center; align-items: center; position: relative; }
    .service-arrow-container { display: none; }
    .service-arrow { width: 70px; }
    .service-arrow-right { position: relative; right: 20px; }
    .prev, .next { width: 80px; }

    /** CONTACTS **/
    .container-contact { min-height: 100%; display: flex; justify-content: space-evenly; margin-top: 100px; }
    .container-contact > div { width: 35%; max-width: 550px }
    .container-contact .contact-form { width: 50%; max-width: 700px; }
    .modal-web-footer { text-align: center; color: rgba(255, 255, 255, .4); font-size: 17px; }
    /* GALLERY */


    .gallery-detail { padding: 50px;  }
    .gallery-header { display: flex; align-items: center; justify-content: space-between; width: 100%; }
    .gallery-media-video { text-align: center; }
    .gallery-center { display: flex; align-items: center; justify-content: space-between; max-width: 1000px; margin: 20px auto; }
    .gallery-left-side-bottom { padding-right: 50px; width: 700px; }
    .gallery-left-side-top { display: flex; align-items: center; }
    .galler-left-side-top-title { color: #FF6637; margin-right: 50px; }
    .gallery-left-side { max-width: 1000px; }
    .gallery-right-side { border-left: 1px solid #fff; margin-left: 126px; width: 200px; padding-left: 30px; }
    .media-fluid { max-width: 100%; }
    #gg-screen .gg-image img { width: auto!important; max-width: auto!important; height: auto!important; max-height: auto!important;}
    .modal-gallery-close { display: none; }
    .gallery-arrow-mobile { display: none;}
    .gallery-arrow { display: block; width: 50px;}

}

@media screen and (max-width: 1024px){
    .content-containers { text-align: center; }
    .contact-social ul{ margin: 50px auto; text-align: center; }
    .slick-controls, .modal-web-footer { display: none; }
    .service-content { max-width: 568px; margin: 10px auto; text-align: center; }
    .container-contact, .container-about, .container-home { padding: 0 10px; }
    .container-contact, .container-home { padding-bottom: 100px; }
    .service-arrow-desktop { display: none; }
    .service-arrow-container { display: flex; justify-content: space-between; max-width: 86%; margin: 50px auto 0;  }
    .about-image { display: none; }
    
    .home-filter-modal label .span div { width: 200px; text-align: left; }
    .filter-image { margin-right: 20px; }
    .prev { left: -10px; }
    .next { right: 33px; }
    .gg-box { grid-template-columns: repeat(auto-fit,minmax(200px,1fr))!important; grid-auto-rows: 200px!important; }
    .gg-close { right: calc(50% - 17px)!important; }
    iframe { width: 100%!important; height: 374px; }
    .gg-element img {
        border-radius: 0px!important;
    }
    .home-filter-modal { width: 100%; padding: 20px 0; height: calc(100vh - 130px); }
    .gallery-right-side span{ display: block!important; padding-top: 10px; }
    .gallery-slideshow{ height: auto!important; }
    .slick-track { overflow: hidden!important; }

}

@media screen and (max-height: 1024px) {
    .slick-track { height: 770px; }
}
@media screen and (min-width: 1400px) { 
    .slick-controls, .modal-web-footer { position: absolute; bottom: 25px; }
    .modal-web-footer { width: 100%; text-align: center; } 
    .modal-web-footer-aux { position: relative; bottom: 0; }
}
@media screen and (min-width: 1600px) { 
    .content-containers p { font-size: 18px; }
 
    .about-image { width: /* calc(50% - 100px) */450px; margin-right: 50px; }
    .about-content { max-width: 600px; margin-left: 20px; text-align: center; }
    .gallery-center {  max-width: 1600px; }
}

@media screen and (min-height: 900px) { 
    .container-contact { margin-top: 200px!important; }
    .container-about { margin-top: 50px!important; }
    .container-service { margin-top: 130px!important; }
}