html, body {
    padding: 0px;
    margin: 0px;
    font-size: 18px;
    height: 100%;
    -webkit-font-smoothing: subpixel-antialiased;
    -webkit-text-size-adjust: 100%;
    font-family:'Trade Gothic LT W01 Light', Arial, 'Helvetica Neue', Helvetica, sans-serif;
}

img {
    display: block;
}

a img {
    border: none;
}

a:link {
    text-decoration: none;
    font-family:'Trade Gothic Next LT W01 Heavy';
    border: none;
    color: inherit;
}

a:visited {
    text-decoration: none;
    border: none;
    color: inherit;
}

a:hover {
    text-decoration: underline;
    border: none;
    color: inherit;
}

a:active {
    text-decoration: underline;
    border: none;
    color: inherit;
}

h1 {
    font-size: 38px;
    font-weight: normal;
    line-height: 50px;
    margin: 0px;
    font-family:'Trade Gothic Next LT W01 Heavy';
}

h3 {
    font-size: 55px;
    font-weight: normal;
    line-height: 70px;
    margin: 0px;
    font-family:'Trade Gothic Next LT W01 Heavy';
}

i, em {
    font-style: normal;
    font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
}

b, strong {
    font-style: normal;
    font-family: "Trade Gothic Next LT W01 Heavy";
}

ul {
    padding: 30px;
    padding-left: 100px;
    list-style-type: square;
    text-align: left;
}

li{
    padding-bottom: 1em;
    line-height: 30px;
}

::-moz-selection {
    /* Highlighted text style */
    color: white;
    background-color: #002BFF;
}

::selection {
    color: white;
    background-color: #002BFF;
}

:focus {
    outline: none;
}

.fill_box{
    position: absolute;
    top: 0px;
    bottom: 0px;
    left: 0px;
    right: 0px;
}

.clear{
    clear: both;
}

.height100{
    height: 100%;
}

.center_this{
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

/* Site structure */
.max_site_width{
    max-width: 1500px;
    margin: auto;
}

.site_width{
    margin-left: 70px;
    margin-right: 70px;
}

.center_button{
    text-align: center;
}

a.ghost_button,
.ghost_button{
    position: relative;
    display: inline-block;
    text-decoration: none;
    font-family:'Trade Gothic Next LT W01 Heavy';
}

a.big_button,
.big_button{
    border: solid white 4px;
    height: 72px;
    line-height: 70px;
    padding-left: 35px;
    padding-right: 35px;
    margin-bottom: 20px;
    margin-right: 15px;
}

a.big_button:hover,
.big_button:hover{
    color: #002BFF;
}

a.black_button{
    border: solid black 4px;
}

a.black_button:hover{
    color: white;
}

a.small_button,
.small_button{
    border: solid #002BFF 4px;
    color: #002BFF;
    height: 50px;
    line-height: 48px;
    padding-left: 15px;
    padding-right: 15px;
    margin-top: 25px;
}

a.small_button:hover,
.small_button:hover{
    color: white;
}

.ghost_button_text{
    position: relative;
}

.font_regular{
    font-family:'Trade Gothic Next LT W01 Rg';
}

.font_bold{
    font-family:'Trade Gothic Next LT W01 Bold';
}

.wipe_effect{
    display: block;
    height: 100%;
    top: 0px;
    right: 0px;
    width: 0%;
    position: absolute;
}

.wipe_effect_trigger:hover .wipe_effect,
.open_sub_menu .wipe_effect{
    left: 0px;
    right: auto;
    width: 100%;
}

.body_paragraph{
    max-width: 855px;
    margin: auto;
    font-size: 24px;
    line-height: 36px;
    padding-bottom: 80px;
    text-align: center;
}

.body_title{
    padding-top: 90px;
    padding-bottom: 10px;
    text-align: center;
}

.body_subtitle{
    font-weight: normal;
    margin: 0px;
    font-family:'Trade Gothic LT W01 Light Obl';
}

.thick_underline{
    position: absolute;
    height: 4px;
    top: auto;
    bottom: 0px;
}

.animate1{
    transition: 100ms ease-in-out;
}

.animate2{
    transition: 250ms ease-in-out;
}

.animate3{
    transition: 200ms ease-in-out;
}

.animate4{
    transition: 600ms ease-in-out;
}

.animate5{
    transition: 2s ease-in-out;
}

.fade_up{
    animation: fade_up 2s;
}

@keyframes fade_up {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.blue_background{
    background-color: #002BFF;
}

.white_background{
    background-color: white;
}

.grey_strip{
    padding-bottom: 30px;
    background-color: #F5F5F5;
}

.dark_blue_background{
    background-color: #022BBF;
}

.dark_blue_strip{
    padding-bottom: 60px;
}

.black_background{
    background-color: black;
}

.full_page{
    height: 100vh;
    position: relative;
}

#form_buttons_strip{
    position: absolute;
    left: 0px; right: 0px; bottom: 0px;
    top: 70px;
}

.form_button{
    height: 100%;
    width: 50%;
    display: inline-block;
    position: relative;
    color: white;
    overflow: hidden;
}

.form_button_background{
    position: absolute;
    top: -1px;
    bottom: -1px;
    left: -1px;
    right: -1px;
    background-size: cover;
}

#cognito_form_cover{
    background-color: #022BBF;
    position: absolute;
    top: 0px; left: 0px; right: 0px;
    height: 170px;
}

#fixed_enquiry_button{
    position: fixed;
    left: 0px;
    top: 28%;
    width: 50px;
    height: 180px;
    background-image: url("../images/fixed_enquiry_button.svg");
    background-repeat: no-repeat;
    background-position: center;
}

/* Column items */
.column_items_container{
    margin-left: -10px;
    margin-right: -10px;
}

.column_item{
    display: inline-block;
    width: 33.3333%;
    vertical-align: top;
}

.column_item_wide{
    display: inline-block;
    width: 50%;
    vertical-align: top;
}

.column_item_narrow{
    display: inline-block;
    width: 16.6666%;
    vertical-align: top;
}

.column_item_inner{
    margin-left: 10px;
    margin-right: 10px;
}

.column_item_inset{
    margin-left: 55px;
    margin-right: 55px;
}

.column_image_container{
    padding-bottom: 60%;
    width: 60%;
    margin: auto;
    position: relative;
}

.column_image{
    background-size: contain;
    background-position: center;
}

.go_circle{
    border-radius: 50%;
}

.column_item_title{
    text-align: center;
    font-size: 24px;
    padding-top: 36px;
    line-height: 36px;
    font-family:'Trade Gothic Next LT W01 Heavy';
}

.column_item_body{
    font-size: 18px;
    line-height: 30px;
    padding-top: 2px;
    text-align: center;
}

/* Animations */
.animation_container{
    position: relative;
    overflow: hidden;
}

.position_animation{
    width: 100%;
    padding-bottom: 62.5%;
    position: absolute;
    bottom: 0px;
}

#home_animation_position{
    padding-bottom: 138.888889%;
}

.animation,
#home_banner_anim{
    position: absolute;
    bottom: 0px;
    height: 100%;
    width: 100%;
}

.animation_spacer{
    padding-bottom: 30%;
}

.overlay_text{
    position: relative;
}

.home_background{
    background-color: #1FA6EA;
}

.air_background{
    background-color: #83CAFF;
}

.sea_background{
    background-color: #07BBD3;
}

.road_background{
    background-color: #8E8EBF;
}

.site_background{
    background-color: #2C9AE5;
}

.network_background{
    background-color: #0F0F38;
    color: white;
}

.health_background{
    background-color: #83CBEA;
}

.sustainability_background{
    background-color: #7878B5;
}

/* Banner */
#banner{
    margin-top: 100px;
    position: relative;
    overflow: hidden;
    background-color: #022BBF;
}

#banner_text_container{
    float: right;
    position: relative;
    width: 31%;
    padding-top: 45px;
    padding-right: 70px;
    padding-bottom: 80px;
    box-sizing: border-box;
    color: white;
}

#banner_text{
    position: relative;
}

#banner_body_text{
    position: relative;
    padding-top: 20px;
    padding-bottom: 35px;
    font-size: 18px;
    line-height: 30px;
}

a.banner_link{
    height: 50px;
    margin-top: 20px;
    line-height: 50px;
    padding-left: 65px;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: left center;
    display: inline-block;
    font-family:'Trade Gothic LT W01 Light', Arial, 'Helvetica Neue', Helvetica, sans-serif;
}

#gradient_container{
    width: 100%;
    height: 1200px;
    position: absolute;
    top: 0px;
    background: url("../images/gradient_box_background.png") no-repeat top;
    background-size: 100% 100%;
}

#shards_container{
    position: absolute;
    width: 960px;
    height: 1200px;
    top: 0px;
    left: -960px;
}

#shard_gradient{
    background-image: url("../images/shard_gradient.png");
}

#shard1{
    background-image: url("../images/shard1.png");
}

#shard2{
    background-image: url("../images/shard2.png");
}

#shard1,
#shard2{
    mix-blend-mode: multiply;
}

#banner_image_container{
    position: absolute;
    width: 70%;
    height: 100%;
}

.banner_container{
    width: 100%;
    padding-bottom: 48.6%;
    position: relative;
    overflow: hidden;
}

.banner_image{
    background-position: center;
    background-size: cover;
    opacity: 0;
}

/* Person */
#people_strip{
    padding-bottom: 60px;
}

.person_spacer{
    margin-top: 40px;
    margin-bottom: 42px;
}

.person_photo{
    height: 0px;
    width: 70%;
    margin: auto;
    padding-bottom: 90%;
    background: center no-repeat white;
    background-size: cover;
}

.person_contact_container{
    text-align: center;
    padding-top: 30px;
}

.person_contact_icon_container{
    display: inline-block;
    position: relative;
    height: 50px;
    width: 50px;
    margin-left: 3px;
    margin-right: 3px;
    background: no-repeat;
    background-size: 100% 100%;
}

.person_contact_linkedin{
    background: url("../images/person_contact_linkedin.svg");
}

.person_contact_linkedin_hover{
    background-image: url("../images/person_contact_linkedin_hover.svg");
    background-size: auto 100%;
    position: absolute;
    top: 0px; bottom: 0px; left: 0px; right: 0px;
}

.person_contact_email{
    background: url("../images/person_contact_email.svg");
}

.person_contact_email_hover{
    background-image: url("../images/person_contact_email_hover.svg");
    background-size: auto 100%;
    position: absolute;
    top: 0px; bottom: 0px; left: 0px; right: 0px;
}

.wipe_effect_trigger .person_contact_linkedin_hover,
.wipe_effect_trigger .person_contact_email_hover{
    background-position: right;
}

.wipe_effect_trigger:hover .person_contact_linkedin_hover,
.wipe_effect_trigger:hover .person_contact_email_hover{
    background-position: left;
}

/* Home "For..." Feature */
#home_for_feature{
    margin-top: 120px;
    color: white;
}

#hf_distributor{
    width: 100%;
    display: flex;
}

#hf_stage{
    overflow: hidden;
    position: relative;
    flex: 1;
    line-height: 30px;
}

#hf_stage p{
    margin: 0px;
    margin-top: 30px;
}

#hf_stage_sizer{
    white-space: nowrap;
    width: 100%;
}

.hf_stage_spacer{
    white-space: normal;
    box-sizing: border-box;
    padding: 70px 0px 100px 70px;
    display: inline-block;
    opacity: 0;
}

#hf_content_container{
    position: absolute;
    top: 70px;
    bottom: 100px;
    left: 70px;
    right: 0px;
}

.hf_content{
    position: absolute;
    top: 0px;
    left: 0px;
    transition: 450ms;
}

.hf_exhibitors_content{
    opacity: 0;
}

#hf_content_container.for_exhibitors_selected .hf_organisers_content{
    opacity: 0;
}

#hf_content_container.for_exhibitors_selected .hf_exhibitors_content{
    opacity: 1;
}

#hf_buttons_container{
    flex: 1;
    position: relative;
}

.hf_big_button{
    position: absolute;
    right: 0px;
    top: 0px;
    height: 50%;
    width: 50vw;
    background-size: cover;
    background-position: center;
}

#for_exhibitors_button {
    top: 50%;
}

.hf_button_tail{
    height: 90px;
    width: 45px;
    position: absolute;
    right: -5px;
    top: 50%;
    transform: translate(0, -50%);
    background: url("../images/hf_button_tail.svg") top right;
    background-size: contain;
}

.hf_button_cover{
    background-image: url("../images/hf_button_cover.jpg");
    background-size: 100% 100%;
    opacity: 0;
    transition: 450ms;
}

#for_exhibitors_button .hf_button_cover{
    opacity: 1;
}

.for_exhibitors_selected #for_exhibitors_button .hf_button_cover{
    opacity: 0;
}

.for_exhibitors_selected #for_organisers_button .hf_button_cover{
    opacity: 1;
}

.hf_button_text{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    cursor: default;
    text-align: center;
}

.mobile_hf_big_button{
    display: none;
    position: relative;
    background-size: cover;
    background-position: center;
    padding-bottom: 30%;
    margin-bottom: 35px;
}

.mobile_hf_button_tail{
    width: 90px;
    height: 45px;
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translate(-50%);
    background: url("../images/mobile_hf_button_tail.svg") bottom center no-repeat;
    background-size: contain;
}

#home_paragraph{
    padding-bottom: 50px;
}

/* Get In Touch */
#contact_tel{
    font-family:'Trade Gothic LT W01 Light', Arial, 'Helvetica Neue', Helvetica, sans-serif;
}

#gmap_canvas{
    height: 100%;
    width: 100%;
    position: absolute;
}

#contact_banner_icons_container{
    position: relative;
    padding-top: 30px;
    font-size: 18px;
}

/* Our services */
#globe_container{
    width: 30%;
    padding-bottom: 30%;
    position: absolute;
    bottom: 0px;
    left: 50%;
    overflow: hidden;
    transform: translate(-50%, -60px);
}

#globe{
    position: absolute;
    top: 0px;
    left: 0px;
    height: 100%;
    width: 100%;
    border-radius: 50%;
}

.terms_conditions{
    margin: 85px auto 85px auto;
    max-width: 900px;
    line-height: 22px;
}

/* Footer */
#footer{
    padding-top: 55px;
    padding-bottom: 60px;
}

#footer_eifl_logo{
    margin-top: 5px;
    width: 100%;
    max-width: 290px;
}

.footer_affiliate_logo{
    float: right;
    clear: both;
    width: 100%;
    max-width: 230px;
}

.footer_spacer{
    height: 20px;
    clear: both;
}

.footer_title{
    display: inline-block;
    position: relative;
    font-size: 20px;
    line-height: 28px;
    font-family: "Trade Gothic Next LT W01 Heavy";
}

.footer_title .thick_underline{
    height: 4px;
    left: 0px;
    right: 0px;
}

.footer_body{
    font-size: 12px;
    line-height: 20px;
}

.footer_body a{
    font-family: inherit;
}