@font-face {
    font-family: FrutigerPro;
    font-weight: 300;
    src: url("../fonts/Frutiger/FrutigerLTProLight.otf") format("opentype");
}
@font-face {
    font-family: FrutigerPro;
    font-weight: 300;
    font-style: italic;

    src: url("../fonts/Frutiger/FrutigerLTProLightItalic.otf") format("opentype");
}

@font-face {
    font-family: FrutigerPro;
    font-weight: 400;
    src: url("../fonts/Frutiger/FrutigerLTProRoman.otf") format("opentype");
}

@font-face {
    font-family: FrutigerPro;
    font-weight: 700;
    src: url("../fonts/Frutiger/FrutigerLTProBold.otf") format("opentype");
}

@font-face {
    font-family: FrutigerPro;
    font-weight: 700;
    font-style: italic;
    src: url("../fonts/Frutiger/FrutigerLTProBoldItalic.otf") format("opentype");
}




/* ==========================================================================
CUSTOM CSS
========================================================================== */

:root{scroll-behavior:auto}

#pre-loader {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999999;
}

#status {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

body {
    font-family: "FrutigerPro", Helvetica, sans-serif !important;
    font-size: 14px;
    padding-top: 70px;
    color: #515356;
}

section, footer {
    padding-top: 6rem;
    padding-bottom: 6rem;
}

.full-size-background {
    background: url(../img/static-header-img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='../img/static-header-img.jpg', sizingMethod='scale');
    -ms-filter: "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='../img/static-header-img.jpg', sizingMethod='scale')";
}

.venue-image {
    background: url(../img/venue-img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='../img/venue-img.jpg', sizingMethod='scale');
    -ms-filter: "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='../img/venue-img.jpg', sizingMethod='scale')";
}

/* ==========================================================================
COLOURS
========================================================================== */

.bg-black {
    background-color: #000000 !important;
}

.bg-blue {
    background-color: #004070;
}

.bg-white {
    background-color: #ffffff;
}

.bg-light-gray {
    background-color: #F6F6F6;
}

.bg-light-blue {
    background-color: #EAF6FE;
}


.bg-feature {
    background-color: #da6702;
}

.text-white {
    color: #ffffff;
}

.text-light-blue {
    color: #BEDDE3
}

.text-blue {
    color: #004070;
}



a, a:hover {
    color: #004070

}

#agenda a:hover, #register a:hover {
    color: #da6702;

}

footer a {
    color: #004070 !important;
}

/* ==========================================================================
BUTTONS
========================================================================== */

.btn {
    padding: .7em 3.2em;
    border-radius: 0;
    height: auto;
    font-size: 14px;
    max-width: fit-content;
}

.btn-orange {
    border: 1px solid #da6702;
    background-color: #da6702;
    color: #fff;
    transition: all .2s ease;
}

.btn-orange:hover {
    background-color: #fff;
    color: #da6702;
}

.btn-blue {
    border: 1px solid #0099CC;
    background-color: #0099CC;
    color: #fff;
    transition: all .2s ease;
}

.btn-blue:hover {
    background-color: #fff;
    color: #0099CC;
}


.btn-text-only, .btn-text-only:hover, .btn-text-only:focus {
    background: none;
    color: inherit;
    border: none;
    padding: 0;
    cursor: pointer;
    outline: none;
    font-weight: 800;
    font-size: 1rem;
}

/* ==========================================================================
FONT STYLES
========================================================================== */

h1 {
    font-size: 1.6rem;
}

h1, h2, h3 {
    font-weight: 700
}

header h2 {
    font-weight: 400 !important;
    font-size: 1.3rem
}

h2.section-header {
    font-size: 1.6rem;
    position: relative;
}

h2.section-header::before {
    display: block;
    content: '';
    background: #da6702;
    height: 100%;
    width: 6px;
    position: absolute;
    left: -16px;
    top: -6px;
}

/* ==========================================================================
NAV
========================================================================== */


 nav {
    box-shadow: 0 4px 15px 0 rgba(0,0,0,.2);

}

.navbar-light .navbar-nav .nav-link {
    color: #515356;
    font-size: 1rem;
}


.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover {
    color: #004070;
}

.navbar-brand img {
    width: 140px;
    height: auto;
}

/* ==========================================================================
HEADER
========================================================================== */

header {
    position: relative;
    overflow: hidden;
    padding-top: 6rem;
    padding-bottom: 6rem;
}

header iframe {
    width: 100vw;
    height: 56.25vw;
    min-height: 100vh;
    min-width: 177.77vh;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* ==========================================================================
WELCOME
========================================================================== */

.welcome-image {
    width: 98%;
    height: auto;
    max-width: 500px;
}

/* ==========================================================================
AGENDA
========================================================================== */


#agenda {
    background-image: url('../img/graphics/hive-graphic-tr-v2.svg'), url('../img/graphics/hive-graphic-bl-v2.svg');
    background-size: 70%;
    background-repeat: no-repeat;
    background-position: top -100px right -5%, bottom -100px left -5%;
}

.table tbody tr td, .table tbody tr th {
    border-top: 1px solid #fff;
    padding: 1rem;
    font-size: 1.2rem;
}
.table tbody tr:last-child td, .table tbody tr:last-child th {
    border-bottom: 1px solid #fff;
}

.table tbody tr td {
    font-weight: 300;
    color: #fff;
}


.table tbody tr th {
    color: #BEDDE3;
    width: 120px;
}



/* ==========================================================================
SPEAKERS
========================================================================== */

/* ==========================================================================
BOARDROOM SESSIONS
========================================================================== */


.breakout-card {
    padding-bottom: 4rem;
    position: relative;
    height: 100%;
}

.breakout-card {
    padding-bottom: 4rem;
    position: relative;
    border-bottom: 12px solid #da6702
}
.breakout-card a, .breakout-card a:hover {
    color: #da6702;
    text-decoration: none !important;
}

.breakoutcard-header {
    font-size: .8rem;
}


.breakoutcard-footer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

.breakout-row .breakout-container:nth-child(odd) .breakout-card {
    border-bottom: 12px solid #0099CC
}

.breakout-row .breakout-container:nth-child(odd) a, .breakout-row .breakout-container:nth-child(odd) a:hover {
    color: #0099CC
}

/* ==========================================================================
FORM
========================================================================== */



#register {
    background-image: url('../img/graphics/hive-graphic-tr.svg?v=1.4'), url('../img/graphics/hive-graphic-bl.svg?v=1.4');
    background-size: 70%;
    background-repeat: no-repeat;
    background-position: top -100px right -5%, bottom -100px left -5%;
}

.btn-check:active+.btn-secondary, .btn-check:checked+.btn-secondary, .btn-secondary.active, .btn-secondary:active, .show>.btn-secondary.dropdown-toggle {
    color: #fff;
    background-color: #E8AF6B;
    border-color: #E8AF6B;
}

#register label {
    font-size: 1rem;
}

.form-control, .form-select {
    border-radius: 0;
    padding: .675rem .75rem;

}

.form-check-input[type=checkbox] {
    border-radius: 0;
}


.form-control::placeholder, .form-select::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #e2e2e2;
    opacity: 1; /* Firefox */
}

.form-control:-ms-input-placeholder,  .form-select:-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: #e2e2e2;
}

.form-control::-ms-input-placeholder,  .form-select::-ms-input-placeholder { /* Microsoft Edge */
    color: #dedede;
}

.boardroom-sessions option:disabled {
    color: #d9d9d9 !important;
}


/* ==========================================================================
OTHER
========================================================================== */

.accordion-button:not(.collapsed) {
    color: #000;
    background-color: #e6e4e5;
}

.accordion-button:focus {
    border-color: #000;
}

.contact-module {
    width: 100%;
}

/* ==========================================================================
MAP
========================================================================== */

.map-container {
    position: relative;
    color: #222;
    background-attachment: scroll;
    background-image: url(../img/map-image.jpg);
    background-position: center center;
    background-repeat: none;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    min-height: 500px;
}

#map {
    position:absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 0; /* Set z-index to 0 as it will be on a layer below the contact form */
}

/* ==========================================================================
FOOTER
========================================================================== */

.foot-logo {
    width:100%;
    height: auto;
    max-width: 200px;
}


/* ==========================================================================
ANIMATED HAMBURGER MENU
========================================================================== */

.hamburger {
    padding: 15px 15px 5px 15px;
    display: inline-block;
    cursor: pointer;
    transition-property: opacity, filter;
    transition-duration: 0.15s;
    transition-timing-function: linear;
    font: inherit;
    color: inherit;
    text-transform: none;
    background-color: transparent;
    border: 0;
    margin: 0;
    overflow: visible;
}

.hamburger:focus {
    outline: none;
}

.hamburger:hover {
    opacity: 0.7;
}

.hamburger.is-active:hover {
    opacity: 0.7;
}

.hamburger.is-active .hamburger-inner, .hamburger.is-active .hamburger-inner::before, .hamburger.is-active .hamburger-inner::after {
    background-color: #004070;
}

.hamburger-box {
    width: 40px;
    height: 24px;
    display: inline-block;
    position: relative;
}

.hamburger-inner {
    display: block;
    top: 50%;
    margin-top: -2px;
}

.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
    width: 40px;
    height: 3px;
    background-color: #004070;
    border-radius: 0px;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease;
}

.hamburger-inner::before, .hamburger-inner::after {
    content: "";
    display: block;
}

.hamburger-inner::before {
    top: -10px;
}

.hamburger-inner::after {
    bottom: -10px;
}

.hamburger--squeeze .hamburger-inner {
    transition-duration: 0.075s;
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger--squeeze .hamburger-inner::before {
    transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}

.hamburger--squeeze .hamburger-inner::after {
    transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger--squeeze.is-active .hamburger-inner {
    transform: rotate(45deg);
    transition-delay: 0.12s;
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.hamburger--squeeze.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}

.hamburger--squeeze.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}



/* ==========================================================================
MODALS
========================================================================== */

.modal {
    backdrop-filter: blur(6px);
}

.modal-backdrop {
    background-color: #004070;
 }

 .modal-header, .modal-footer, .modal-content {
    border-radius: 0px;
 }

 .modal-head-wrap {
    max-width: 600px;
 }

 .modal-header {
    background-size: cover;
    background-position: center;
 }

.blue-theme .modal-footer {
    border-bottom: 12px solid #0099CC;
}

.orange-theme .modal-footer {
    border-bottom: 12px solid #da6702;
}

.custom-modal-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 100px;
    font-size: 1.2rem;
    line-height: 0;
    border: 2px solid #fff;
    color: #fff;
}

.blue-theme .custom-modal-close  {
    background:  #0099CC;
}

.orange-theme .custom-modal-close  {
    background: #da6702;
}


.modal-speaker-img {
    width: 100%;
    height: auto;
    max-width: 120px;
    border-radius: 50%;
}

.blue-theme .modal-speaker-img  {
    border: 1px solid  #0099CC;
}

.orange-theme .modal-speaker-img {
    border: 1px solid #da6702;
}

.close-wrap {
    width: 40px;
    height: 40px;
    text-align: center;
}
