.elementor-kit-5{--e-global-color-primary:#070606;--e-global-color-secondary:#F7F2EE;--e-global-color-text:#1C1D21;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Source Serif Pro";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Source Serif Pro";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Source Serif Pro";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Source Serif Pro";--e-global-typography-accent-font-weight:500;--e-page-transition-entrance-animation:e-page-transition-fade-out;--e-page-transition-animation-duration:1500ms;}.elementor-kit-5 e-page-transition{background-color:var( --e-global-color-text );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1440px;}.e-con{--container-max-width:1440px;}.elementor-widget:not(:last-child){margin-block-end:0px;}.elementor-element{--widgets-spacing:0px 0px;--widgets-spacing-row:0px;--widgets-spacing-column:0px;}{}h1.entry-title{display:var(--page-title-display);}@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: 30px !important;
    line-height: 42px !important;
}
h1 {
    font-size: 38px !important;
	line-height: 48px !important;
}
.hero h1,
.hero h2 {
    font-size: 46px !important;
	line-height: auto !important;
}  
.uber h1,
.uber h2 {
    font-size: 54px !important;
	line-height: auto !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: 46px !important;
	    line-height: 56px !important;
    }
    h1 {
	    font-size: 54px !important;
    	line-height: 64px !important;
    }
    .hero h1,
    .hero h2 {
	    font-size: 82px !important;
    	line-height: 92px !important;
    }  
    .uber h1,
    .uber h2 {
	    font-size: 112px !important;
    	line-height: 148px !important;
    }
}







/*------------------------------------*
  #COLUMNS - To allow you to use 100% widths
*------------------------------------*/

.elementor-section > .elementor-container{
    flex-wrap: wrap !important;
}




/*------------------------------------*
  #PADDING - Removes default padding from columns
*------------------------------------*/

.elementor-element-populated{
    padding: 0 !important;
    margin: 0 !important;
}




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

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

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

@media only screen and (min-width: 1024px) {
    .o-wrapper,
    .inner-wrapper .elementor-widget-wrap{
        padding-left: 10vw !important;
        padding-right: 10vw !important;
    }
    .section{
        padding-top: 128px;
        padding-bottom: 128px;
    }
    .section-small{
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .section-slim{
        padding-top: 128px;
        padding-bottom: 32px;
    }
}

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



/*------------------------------------*
  #FULL-HEIGHT-SECTION
*------------------------------------*/

@media only screen and (min-width: 1024px) and (min-height: 900px) {
    /* setting the height of the section (need to move this to a global control) */
    .full-height .elementor-container,
    .full-height .sixty-forty .sixty-col,
    .full-height .sixty-forty .forty-col{
        height: calc(100vh - 98px) !important;
    }
}




/*------------------------------------*
  #THIRD-HEIGHT-SECTION
*------------------------------------*/

@media only screen and (min-width: 1024px) and (min-height: 900px) {
    /* setting the height of the section (need to move this to a global control) */
    .third-height .elementor-container{
        height: 33vh;
    }
}




/*------------------------------------*
  #HALF-HEIGHT-SECTION
*------------------------------------*/

@media only screen and (min-width: 1024px) and (min-height: 900px) {
    /* setting the height of the section (need to move this to a global control) */
    .half-height .elementor-container{
        height: 50vh;
    }
}




/*------------------------------------*
  #COLUMN-WIDTHS
*------------------------------------*/

.layout-grid .elementor-container{
    justify-content: space-between;
}
.layout-grid .sixty-col{
    height: auto;
    width: 100%;
}
.layout-grid .fifty-col{
    width: 100%;
}
.layout-grid .forty-col{
    width: 100%;
}
.layout-grid .sixty-col .elementor-widget-wrap {
    align-content: center;
    padding-top: 24px !important;
    padding-bottom: 24px !important;
}
.layout-grid .text-col .elementor-widget-wrap {
    padding-top: 24px !important;
    padding-bottom: 24px !important;
}

@media only screen and (min-width: 753px){
    .layout-grid .sixty-col{
        height: auto;
        width: 60%;
    }
    .layout-grid .fifty-col{
        width: 50%;
    }
    .layout-grid .forty-col{
        width: 40%;
    }
    .layout-grid .thirty-col{
        width: 30%;
    }
    .layout-grid .twenty-col{
        width: 20%;
    }
    .layout-grid .text-col .elementor-widget-wrap {
        padding-top: 48px !important;
        padding-bottom: 48px !important;
    }
}
@media only screen and (min-width: 1024px){
    .layout-grid .text-col .elementor-widget-wrap {
        padding-top: 72px !important;
        padding-bottom: 72px !important;
    }
}




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

body .btn-primary .elementor-button{
    font-size: 16px;
    line-height: 26px;
    text-align: center;
    color: #fff;
    background-color: #000;
    border-radius: 100px;
    margin-top: 24px;
    padding: 12px 48px !important;
    }

.btn-primary .elementor-button:hover{
    background: #666;
}




/*------------------------------------*
  #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{
    object-fit: cover;
}

/**
 * Giving the images a default height 
 */
.img-col{
    min-height: 50vh;
}

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




/*------------------------------------*
  #SECTIONS
*------------------------------------*/




/*------------------------------------*
  #BANNER-SECTION
*------------------------------------*/

/**
 * Adding the background gradient
 */
.main-banner{
    background: #282828;
}

/**
 * Left Column
 *
 * Positioning the title
 */
.main-banner .text-col .title{
    margin-top: 20%;
}
/**
 * Setting the left col text colour
 */
.main-banner .text-col .green{
    color: #01D7D5;
}

/**
 * Positioning the button
 */
.main-banner .btn-primary{
    position: absolute;
    bottom: 0;
    z-index: 2;
    width: auto;
}

/**
 * Stlying the button
 */
.main-banner .btn-primary .elementor-button{
    background: #f3f4f8 !important;
    color: #282828;
    padding: 19px 32px 19px 24px !important;
    border-radius: 0;
}
.main-banner .btn-primary .elementor-button:hover{
    background: #ddd !important;
}
.main-banner .btn-primary .elementor-button .elementor-align-icon-left {
    margin-top: 3px;
}

/**
 * Right column
 *
 * Aligning the text in the right-hand cols
 */
.main-banner .elementor-widget-wrap {
    align-content: center;
}

/**
 * Width and height for the right-hand cols
 */
.main-banner .banner-page-link{
    width: 100%;
    height: 50% !important;
}
.banner-page-link .elementor-widget-wrap{
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}
/**
 * Styling the title
 */
.main-banner .banner-page-link .title h2{
    font-weight: 600 !important;
}

/**
 * Styling the sub-title
 */
.main-banner .banner-page-link .sub-title h6{
    text-transform: uppercase;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 14px !important;
    letter-spacing: 1.5px !important;
}

/**
 * Width and height of the divider
 */
.main-banner .page-link-col .divider-col{
    height: 1px;
    width: 100%;
}

/**
 * Styling the buttons
 */
.main-banner .banner-page-link .elementor-button{
    background: transparent !important;
    border: 1px solid #fff;
    border-radius: 0;
    padding: 16px 32px;
    margin-top: 24px;
}
.main-banner .banner-page-link .elementor-button:hover{
    background: #fff !important;
    border: 1px solid #fff;
    color: #282828 !important;
}

@media only screen and (min-width: 753px){
    .main-banner .text-col{
        border-right: 1px solid #fff;
    }
    .main-banner .text-col .elementor-widget-wrap {
        padding-top: 48px !important;
        padding-bottom: 48px !important;
    }
}



/*------------------------------------*
  #PAGE-LINKS
*------------------------------------*/

/**
 * Adding some space between the page-links
 */
.page-links .link-col:not(:last-child){
   margin:  0 0 2px 0;
}

/**
 * Styling the links
 */
.page-links .elementor-button{
    background: #f3f4f8 !important;
    margin-top: 0;
    width: 100%;
    color: #888 !important;
    min-height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px !important;
    line-height: 40px !important;
}


/**
 * Styling the hover states
 */
.page-links .elementor-button:hover{
    color: #000 !important;
    background: #fff !important;
}

@media only screen and (min-width: 753px) {

    /**
     * Forcing the links to sit in a row
     */
    .page-links .elementor-container{
        flex-wrap: nowrap !important;
        justify-content: space-between;
    }
    
    /**
     * Setting the min height the links should have
     */
    .page-links .elementor-button{
        min-height: 360px;
    }
    
    /**
     * Adding some space between the page-links
     */
    .page-links .link-col:not(:last-child){
       margin: 0 2px 0 0;
    }
}





/* SECTIONS */

/* TITLE */

.banner-small .title-centre,
.banner-small .sub-title-centre{
    /* sets the width of the title at mobile */
    width: 100% !important;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

@media only screen and (min-width: 1024px){
    .banner-small .title {
        /* sets the width at desktop */
        width: 888px !important;
    }
    .banner-small .sub-title {
        /* sets the width of the sub-title at desktop */    
        width: 660px !important;
    }
    .banner-small-right .text-col{
        width: 50%;
        margin-left: auto;
    }
}






/* TITLE AND TEXT SECTION */

.title-text > .elementor-container > .elementor-row{
    justify-content: space-around;
}
.title-text .text-col{
    margin-top: 24px;
}

@media only screen and (min-width: 753px) {
    .title-text > .elementor-container > .elementor-row{
        justify-content: space-around;
    }
    .title-text .title-col,
    .title-text .text-col{
        width: 40%;
        margin-top: 0;
    }
}
@media only screen and (min-width: 1024px) {
    .title-text > .elementor-container > .elementor-row{
        justify-content: space-around;
    }
    .title-text{
        padding: 200px 0 !important;
    }
    .title-text .title-col{
        width: 40%;
    }
    .title-text .text-col{
        width: 40%; 
    }
}




/* LARGE TITLE */

.large-title h2{
    font-size: 38px !important;
    line-height: 46px !important;
}
@media only screen and (min-width: 753px) {
    .large-title h2{
        font-size: 48px !important;
        line-height: 56px !important;
    }
}
@media only screen and (min-width: 1024px) {
    .large-title h2{
        font-size: 68px !important;
        line-height: 76px !important;
    }
}




/* LOGOS SECTION */

.client-info .text-col,
.intro-section{
    width: 100%;
    height: 200px;
}
.client-info .text-col .description p{
    width: 50%;
    margin-left: auto;
    margin-right: auto;
    color: #666;
    font-size: 18px !important;
    line-height: 28px !important;
}
.client-info .text-col .client-title p,
.intro-section p{
    font-size: 18px !important;
    line-height: 28px !important;
    margin-bottom: -10px !important;
}
.logos-01{
    height: 400px !important;
}/* End custom CSS */