.elementor-kit-5{--e-global-color-primary:#112378;--e-global-color-secondary:#F2E9DC;--e-global-color-text:#112378;--e-global-color-accent:#45B69C;--e-global-color-0853b25:#F3F6FE;--e-global-color-dc66a5e:#FFFFFF;--e-global-color-92576c8:#0B1852;--e-global-color-a1d5763:#8F94AF;--e-global-color-7870097:#0044FF;--e-global-typography-primary-font-family:"DM Sans";--e-global-typography-primary-font-weight:500;--e-global-typography-secondary-font-family:"DM Sans";--e-global-typography-secondary-font-weight:700;--e-global-typography-text-font-family:"DM Sans";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"DM Sans";--e-global-typography-accent-font-weight:500;}.elementor-kit-5 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1344px;}.e-con{--container-max-width:1344px;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){margin-block-end:24px;}.elementor-element{--widgets-spacing:24px 24px;--widgets-spacing-row:24px;--widgets-spacing-column:24px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//*------------------------------------*
  #TYPOGRAPHY
*------------------------------------*/


p {
    font-size: 16px !important;
    line-height: 28px !important;
}
h6 {
    font-size: 14px  !important;
    line-height: auto !important;
}
h5 {
	font-size:16px !important;
	line-height: 28px !important;
}
h4 {
	font-size: 20px !important;
	line-height: 32px !important;
}
h3 {
	font-size: 24px !important;
	line-height: 38px !important;
}
h2 {
    font-size: 24px !important;
    line-height: 38px !important;
}
h1 {
    font-size: 28px !important;
	line-height: 38px !important;
}
.hero h1,
.hero h2 {
    font-size: 12vmin !important;
	line-height: 13vmin !important;
}  
.uber h1,
.uber h2 {
    font-size: 18vw !important;
	line-height: 18vw !important;
}    

@media only screen and (min-width: 1024px) {
 
    p {
    	font-size: 16px !important;
    	line-height: 28px !important;
    }
    h6 {
    	font-size: 20px  !important;
    	line-height: 32px !important;
    }
    h5 {
    	font-size:24px !important;
    	line-height: 38px !important;
    }
    h4 {
    	font-size: 30px !important;
    	line-height: 42px !important;
    }
    h3 {
    	font-size: 38px !important;
    	line-height: 48px !important;
    }
    h2 {
	    font-size: 54px !important;
	    line-height: 64px !important;
    }
    h1 {
	    font-size: 54px !important;
    	line-height: 64px !important;
    }
    .uber h1,
    .uber h2{
        font-size: 15vw !important;
        line-height: 15vw !important;
    } 
}
@media only screen and (min-width: 1280px) {
    .hero h1,
    .hero h2 {
	    font-size: 13vmin !important;
    	line-height: 14vmin !important;
    } 
}

@media only screen and (min-width: 1920px) {
    .hero h1,
    .hero h2 {
	    font-size: 14vmin !important;
    	line-height: 15vmin !important;
    } 
    .uber h1,
    .uber h2{
        font-size: 12vw !important;
        line-height: 12vw !important;
    } 
}
@media only screen and (max-height: 768px) {

    .uber h1,
    .uber h2{
        font-size: 20vmin !important;
        line-height: 20vmin !important;
    } 

}



    
/*------------------------------------*
  #SPACING
*------------------------------------*/

.o-wrapper,
.o-wrapper-small,
.inner-wrapper,
.inner-wrapper-small{
    padding-left: 24px !important;
    padding-right: 24px !important;
}
.section{
    padding-top: 64px;
    padding-bottom: 64px;
}
.section-small{
    padding-top: 64px;
    padding-bottom: 64px;
}
.section-slim{
    padding-top: 64px;
    padding-bottom: 32px;
}
.section-large-top{
    padding-top: 96px;
    padding-bottom: 32px;
}

@media only screen and (min-width: 753px) {
    .o-wrapper,
    .o-wrapper-small,
    .inner-wrapper,
    .inner-wrapper-small{
        padding-left: 48px !important;
        padding-right: 48px !important;
    }
    .section{
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .section-small{
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .section-slim{
        padding-top: 64px;
        padding-bottom: 32px;
    }
    .section-large-top{
        padding-top: 96px;
        padding-bottom: 32px;
    }
}

@media only screen and (min-width: 1024px) {
    .o-wrapper,
    .inner-wrapper {
        padding-left: 10vw !important;
        padding-right: 10vw !important;
    }
    .section{
        padding-top: 144px;
        padding-bottom: 144px;
    }
    .section-large{
        padding-top: 244px;
        padding-bottom: 244px;
    }
    .section-slim{
        padding-top: 128px;
        padding-bottom: 48px;
    }
    .section-large-top{
        padding-top: 244px;
        padding-bottom: 48px;
    }
}

@media only screen and (min-width: 1920px){
    .o-wrapper,
    .inner-wrapper{
        padding-left: 14vw !important;
        padding-right: 14vw !important;
    }
}





/*------------------------------------*
  #BUTTON-STYLES
*------------------------------------*/


.btn-primary{
    overflow: hidden !important;
}
/**
 * Setting the font style
 */
.btn-primary:before,
.btn-primary .elementor-button-text{
    font-family: var( --e-global-typography-accent-font-family ), Roboto;
    font-weight: var( --e-global-typography-accent-font-weight );
    font-size: 16px !important;
    line-height: 24px;
    text-align: center;
    color: #fff;
    transition: transform 1.2s cubic-bezier(.19,1,.22,1);
}
/**
 * Styling the background
 */
body .btn-primary .elementor-button{
    background-color: #1DB899;
    border-radius: 100px;
    padding: 14px 24px !important;
}
/**
 * Button background hover state
 */
.btn-primary .elementor-button:hover{
    background: #666;
}
/**
 * Styling the button icon
 */
.btn-primary .elementor-button svg{
    transition: all 0.3s cubic-bezier(.17,.67,.3,1.33);
}
.btn-primary .elementor-button:hover svg{
    transform: translateX(4px);
}
/**
 * Text hover state
 */
.btn-primary:hover .elementor-button-text{
    transform: translate3d(0,-190%,0) skewY(0deg);
}
/**
 * Styling the secondary text
 */
.btn-primary:before{
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    transform: translate3d(0,180%,0) skewY(0deg);
    pointer-events: none;
}
/**
 * Secondary text hover state
 */
.btn-primary:hover:before {
    transform: translateY(12px);
    transition: transform 0.8s cubic-bezier(.19,1,.22,1);
}

body .btn-primary-white .elementor-button{
    background-color: #fff !important;
}
.btn-primary-white .elementor-button:hover{
    background: #666 !important;
}
.btn-primary-white .elementor-button-text{
    color: #1DB899 !important;
}
.btn-primary-white:before{
    color: #fff !important;
}

.btn-simple .elementor-button{
    padding: 8px 0 !important;
    background: transparent !important;
    color: #0044FF;
}

.btn-simple-green .elementor-button{
    color: #45B69C;
}
.btn-simple-green .elementor-button svg path{
    fill: #45B69C;
}
.btn-simple .elementor-button-icon{
    transform: translateX(0);
    transition: all 0.8s cubic-bezier(.19,1,.22,1);
}
.btn-simple:hover .elementor-button-icon{
    transform: translateX(12px);
}




/*------------------------------------*
  #DOWN-ARROW
*------------------------------------*/

.banner-large .down-arrow{
    position: absolute;
    bottom: 24px;
    align-self: center;
    z-index: 4 !important;
}

.text-banner .down-arrow svg{
    width: 24px;
    transition: all 0.3s ease-out;
}

.text-banner .down-arrow:hover svg{
    transform: scale(1.4);
}

@media only screen and (min-width: 1024px) {
   
    .text-banner .down-arrow{
        position: absolute;
        bottom: 24px;
        right: 48px;
    }

}





/*------------------------------------*
  #BACKGROUND-IMAGE
*------------------------------------*/

/**
 * Sizing the image (to maintain it's ratio)
 */
.background-image:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.background-image,
.background-image img{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}
.background-image img,
.uael-post__thumbnail img{
    object-fit: cover;
}




/*------------------------------------*
  #BACKGROUND-IMAGE
*------------------------------------*/

.img-col:has(.background-image) {    
    min-height: 50vh;
}

@media only screen and (min-width: 753px) {
    .img-col:has(.background-image) { 
        min-height: auto;
    }
}




/*------------------------------------*
  #TEXT-IMAGE-SECTION
*------------------------------------*/


@media only screen and (max-width: 767px) {
    
    .text-image .img-col{
        order: 1;
    }
    .text-image .text-col{
        order: 2;
    }
}




/*------------------------------------*
  #MODULE-TABLE
*------------------------------------*/

.table-title{
    padding-top: 48px;
    padding-bottom: 24px;
}
.table-buttons{
    padding-top: 24px;
    padding-bottom: 48px;
}

.module-table {
    padding-bottom: 24px;
    gap: 48px;
}

.module-table .table-header .table-cell{
    background: #F2E9DC !important;
    flex: 1;
}

.module-table .table-cell{
    padding: 16px 8px;
    flex: 1;
    align-self: stretch;
}

.table-cell p{
    height: 100% !important;
    display: flex !important;
    justify-content: center;
    flex-direction: row;
    align-items: center;
}

.table-cell .elementor-icon,
.table-cell .elementor-icon-wrapper svg{
    height: 100% !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.table-cell .elementor-icon-wrapper{
    height: 100% !important;
}

.module-table-container{
    border-radius: 8px;
    overflow: hidden;
}

.module-table-container .table-row:nth-child(odd) .table-cell{
  background: #F1F2F7 !important;
}

.module-table-container .table-row:nth-child(even) .table-cell{
  background: white !important;
}

.module-table-container .pdf-download svg{
    width: 24px !important;
    height: 24px !important;
}

.module-table-container{
    background: #dcdcdc;
    box-shadow: 0rem 0.6rem 1.3rem 0rem rgb(0 0 0 / 15%);
}

    
@media only screen and (max-width: 767px) {

    .module-table{
        overflow-x: scroll !important;
    }

    .module-table-container{
        width: 750px !important;
        display: flex;
        margin: 0 !important;
    }

}




/*------------------------------------*
  #TEXT-BG-IMAGE
*------------------------------------*/

.text-bg-image:after{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    background: linear-gradient(90deg, rgba(17, 35, 120, 0) 0%, #112378 100%);
}
.text-bg-image-white:after{
    background:linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
}
.text-bg-image .img-col{
    z-index: 0;
    mix-blend-mode: soft-light !important;
}
.text-bg-image-white .img-col{
    mix-blend-mode: normal !important;
}
.text-bg-image .img-col img{
    opacity: 0.8;
    filter: grayscale(100%);
    -webkit-filter: grayscale(100%);
}
.text-bg-image-white .img-col img{
    opacity: 0.3;
    filter: none;
    -webkit-filter: none;
}
.text-bg-image .text-col{
    z-index: 2 !important;
}

@media only screen and (min-width: 768px) {
    .text-bg-image:after{
        width: 50%;
    }
    .text-bg-image-white:after{
        background:linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 90%);
    }
    .text-bg-image .img-col{
        width: 50%;
    }
    .text-bg-image .img-col .background-image{
        width: 100% !important;
    }
    .text-bg-image-white .img-col img{
        opacity: 1;
        filter: none;
        -webkit-filter: none;
    }
    .text-bg-image .text-col{
        width: 50% !important;
    }

}




/*------------------------------------*
  #CALL-TO-ACTION-SECTION
*------------------------------------*/

.cta-section .text{
    max-width: 888px !important;
}




/*------------------------------------*
  #PRODUCTS
*------------------------------------*/

/* Removed. Causing extra gap below the CTA for some reason. EDIT - Added back in. */

.products{
    padding-bottom: 72px;
}





/*------------------------------------*
  #PRODUCTS-CAROUSEL
*------------------------------------*/

.products-carousel img{
    background: #fff !important;
}
.products-carousel .elementor-loop-container{
    width: 100% !important;
    padding-bottom: 72px !important;
}
.products-carousel .elementor-swiper-button{
    position: absolute !important;
    top: 100% !important;
    left: calc(50%) !important;
}
.products-carousel .elementor-swiper-button-prev{
    left: calc(50% - 64px) !important;
}
.products-carousel .elementor-swiper-button svg{
    transition: all 0.3s ease-out;
}
.products-carousel .elementor-swiper-button:hover svg{
    transform: scale(1.2);
}


@media only screen and (min-width: 768px) {
    .products-carousel .title{
        max-width: 66% !important;
    }
    
    .products-carousel .elementor-loop-container{
        padding-bottom: 0 !important;
    }
    .products-carousel .elementor-swiper-button{
        position: absolute !important;
        top: -72px !important;
        left: calc(100% - 48px) !important;
    }
    .products-carousel .elementor-swiper-button-prev{
        left: calc(100% - 104px) !important;
    }
}




/*------------------------------------*
  #VIDEO-BANNER
*------------------------------------*/

.video-banner .elementor-background-video-container{
    mix-blend-mode: exclusion !important;
    opacity: 0.3;
}




/*------------------------------------*
  #TEXT-BANNER-LARGE
*------------------------------------*/

.text-banner-large{
    min-height: 600px;
    justify-content: center;
}

.text-banner .sub-title{
    max-width: 700px !important;
}




/*------------------------------------*
  #TEXT-BG-IMAGE
*------------------------------------*/

.text-banner-small{
    padding-top: 24px;
    padding-bottom: 24px;
}
.text-banner-small:after{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    top: 0;
    right: 0;
    background: linear-gradient(-90deg, rgba(17, 35, 120, 0) 0%, #112378 100%);
}
.text-banner-small .img-col{
    z-index: 0;
}
.text-banner-small .img-col img{
    opacity: 0.3;
    filter: saturate(0);
    -webkit-filter: saturate(0);
}
.text-banner-small .text-col{
    z-index: 2 !important;
}
.text-banner-small .down-arrow{
    z-index: 4;
    height: 24px;
    margin-top: 24px;
}
.text-banner-small .down-arrow svg{
    width: 24px;
    height: 24px;
    transition: all 0.3s ease-out;
}
.text-banner-small .down-arrow:hover svg{
    transform: scale(1.4);
}

@media only screen and (min-width: 768px) {
    .text-banner-small{
        padding-top: calc(130px + 72px);
        padding-bottom: 48px;
    }
    .text-banner-small:after{
        width: 50%;
        left: 50%;
    }
    .text-banner-small .text-col{
        width: 80%;
    }
    .text-banner-small .img-col{
        width: 50%;
    }
    .text-banner-small .img-col .background-image{
        width: 100% !important;
        left: 100%;
    }
    .text-banner-small .down-arrow{
        position: absolute;
        bottom: 24px;
        right: 48px;
    }
}

@media only screen and (min-width: 1024px) {
    .text-banner-small{
        padding-top: calc(130px + 72px);
        padding-bottom: 72px;
    }
    .text-banner-small:after{
        width: 50%;
        left: 50%;
    }
    .text-banner-small .text-col h3,
    .text-banner-small .text-col p{
        max-width: 888px;
    }
    .text-banner-small .img-col{
        width: 50%;
    }
    .text-banner-small .img-col .background-image{
        width: 100% !important;
        left: 100%;
    }
}




/*------------------------------------*
  #QUOTATION-FORM
*------------------------------------*/

.quotation-form {
    max-width: 888px !important;
    box-shadow: 0rem 0.6rem 1.3rem 0rem rgb(0 0 0 / 15%);
}
.quotation-form .form{
    margin-top: 24px;
}
.quotation-form .form .elementor-field-label,
.quotation-form .form .elementor-field-textual{
    font-size: 14PX;
}

.quotation-form .form .elementor-button{
    border-radius: 100px;
    background-color: #1DB899;
}
/*
.quotation-form .form .elementor-field-textual{
    padding: 12px !important;
}*/
/*
.elementor-select-wrapper:before{
    background: white;
    padding: 10px;
    right: 6px !important;
}
*/
.quotation-form .text{
    margin-top: 24px;
}

.dialog-close-button{
    border-radius: 100% !important;
    background: red;
    padding: 12px !important;
}

.dialog-close-button{
    transition: all 0.3s ease-out;
}
.dialog-close-button:hover{
    transform: scale(1.2);
}




/*------------------------------------*
  #POST-ARCHIVES
*------------------------------------*/

.elementor-post__thumbnail img{
    height: auto;
    position: absolute;
    top: calc(50% + 1px);
    left: calc(50% + 1px);
    transform: scale(1.01) translate(-50%,-50%);
    transition: opacity 0.45s ease-out, transform .45s cubic-bezier(.17,.67,.3,1.33) !important;
}
.elementor-post__thumbnail:hover img{
    transform: scale(1.1) translate(-46%,-46%) !important;
}

.elementor-loop-container .elementor-widget-container{
    overflow: hidden;
}
.elementor-loop-container img{
    transform: scale(1.01);
    transition: opacity 0.45s ease-out, transform .45s cubic-bezier(.17,.67,.3,1.33) !important;
}
.elementor-loop-container a:hover img{
    transform: scale(1.1) !important;
}



/*------------------------------------*
  #DOWNLOAD-BTN-SECTION
*------------------------------------*/

/*.download-btn-section{
    padding-top: 0
}*//* End custom CSS */