@charset "utf-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;700&display=swap');

.otgs-development-site-front-end {
    display: none;
    background-color: #000 !important;
}

.desktop-video { display:block; }
.mobile-video { display:none; }

html, body {
    margin:0;
    padding:0;
    color:#06273a;
    background:#cbcbcb;
}

main {
    position:relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;
    flex-wrap: wrap;
    margin:0 auto;
    width:100%;
    max-width:1920px;
    font-family:'Montserrat', Arial, 'sans-serif';
    color:#06273a;
    /*overflow-x: hidden;*/
}

.row {
    margin-left:0;
    margin-right:0;
}

h1 {
    margin:0 0 24px 0;
    font-size:2.063rem;
    font-weight:700;
    line-height:135%;
}

h2 {
    margin:0 0 24px 0;
    font-size:1.813rem;
    font-weight:700;
    line-height:130%;
}

.home h1,
.home h2 {
    margin:0 0 55px 0;
    font-size:2.063rem;
    font-weight:700;
    line-height:135%;
}

h3 {
    margin:0 0 15px 0;
    font-size:1.813rem;
    line-height:130%;
    font-weight:700;
}
h4 {
    margin:0 0 0.625rem 0;
    font-size:1.375rem;
    line-height:130%;
    font-weight:700;
}
h5 {
    margin:0 0 1.875rem 0;
    font-size:1.125rem;
    line-height:130%;
    font-weight:700;
}

p, ul {
    margin:0 0 1.875rem 0;
    font-size:1rem;
    font-weight:500;
    line-height:175%;
}

.privacy-policy ol ol,
.politique-de-confidentialite ol ol { list-style-type: lower-alpha; }

a {
    color:#06273a;
}

p a,
label a,
.about-intro ul a { 
    text-decoration: underline; 
}

p a:hover,
label a:hover { 
    color:#106FAF; 
}

.nav-box h3 {
	font-size: 1.125rem;
}

.carrot {
    display: block;
    font-size:2.75rem;
    font-weight:500;
}

.btn.focus, .btn:focus {
    outline: 0;
    box-shadow: none !important;
    -webkit-transition: none !important;
    -moz-transition: none !important;
    -o-transition: none !important;
    transition: none !important;
}

.btn-blue  {
    margin:30px auto;
    padding:18px 30px;
    min-width:202px;
    font-size:1rem;
    font-weight:400;
    color:#ffffff;
    border:1px solid #ffffff;
    border-radius:0;
    background-color:#06273a;
}
.btn-clear {
    margin:30px auto;
    padding:18px 30px;
    min-width:202px;
    font-size:1rem;
    font-weight:400;
    color:#06273a;
    border:1px solid #06273a;
    border-radius:0;
    background-color:transparent;
}
.btn-clear-white {
    margin:30px auto;
    padding:18px 30px;
    min-width:202px;
    font-size:1rem;
    font-weight:400;
    color:#ffffff;
    border:1px solid #ffffff;
    border-radius:0;
    background-color:transparent;
}
.btn-white {
    margin:30px auto;
    padding:18px 30px;
    min-width:202px;
    font-size:1rem;
    font-weight:400;
    color:#06273a !important;
    border:1px solid #06273a;
    border-radius:0;
    background-color:#ffffff;
}
#home-news .btn-white {
    margin:30px 20px;
    min-width: 240px;
}

.btn-blue:hover  {
    color:#06273a;
    background-color:#ffffff;
    border:1px solid #ffffff;
}
.btn-clear:hover {
    color:#ffffff;
    background-color:#06273a;
    border:1px solid #06273a;
}
.btn-clear-white:hover {
    color:#06273a;
    background-color:#ffffff;
    border:1px solid #ffffff;
}
.btn-white:hover {
    color:#ffffff !important;
    background-color:#06273a;
    border:1px solid #06273a;
}


#nav-col {
    position:relative;
    display:flex;
    flex-direction:column;
    margin:0;
    padding:0;
    min-width:106px !important;
    width:106px !important;
    max-width:106px !important;
    float: left;
    color:#fff;
    background:#06273a;
    /*overflow-x: hidden;*/
    z-index: 9999;
}

#nav-controls {
    position:fixed;
    top:0;
    margin:0;
    z-index:10000;
}

.btn-menu {
	display:none;
    visibility: hidden;
    margin:24px 0 0 33px;
    padding:4px 10px;
    min-width:70px;
    color:#fff;
    font-size:1rem;
    font-weight:700;
    border:1px solid #fff;
    background:#06273a;
    cursor:pointer;
}

.btn-menu:hover { color:#30c8ff; border-color:#30c8ff; }

#nav-logo-mobile {
    display:none;
}

.lang-search {
    display:flex;
    padding:14px 0 0 4px;
    text-align:right;
}

#jfn-main-menu {
    position:relative; /* was fixed */
    margin:0;
    padding-top:0;
    height: 100%;
    width: 180px;
    z-index: 1;
    top: 0;
    left: 0;
    background-color: #06273a;
    /*overflow-x: hidden;*/
    transition: 1s;
}
.nav-hover {
    position: fixed;
    top: 70px; 
    padding:0;
	height:50%;
    z-index:10000;
}

.nav-tab {
    visibility: visible;
    position: fixed;
    margin:0 0 0 90px;
    top:45%;
    width:7px;
    height:68px;
    border-left:1px #30c8ff solid;
    border-right:1px #30c8ff solid;
    opacity: 0;
    z-index:10000;
}

ul.nav {
    /*position:fixed;
    top:16.5%;*/
}

.nav {
    margin:0;
    padding:0 16px 0 0;
    width:180px;
}
.nav li {
    text-align:right;
}
.nav-item, .nav-item-mobile {
    opacity: 1;
    transition: 1s;
}

.nav-item-mobile {
    display:none;
}

a.nav-link {
    padding:6px 10px;
    font-size:0.813rem;
    color:#fff;
    font-weight:700;
    line-height:20px;
	text-decoration: none;
}
a.nav-link:hover {
    color:#30c8ff;
	text-decoration: none;
}

.lang-search a.nav-link {
    padding:8px 16px;
}

#nav-logo {
    position:fixed;
    bottom:0;
    margin:0 auto 40px 24px;
    width:60px;
    z-index:10000;
}
#bandp-logo {
    width:60px;
    height:300px;
}

#cover-menu {
    position:absolute;
    top:0;
    left:-260px;
    width:260px;
    height:100%;
    background:#cbcbcb;
    z-index: 10;
}

.nav-item .btn-twitter {
    margin:4px 0 0 0;
    background:#06273a;
    color:#fff;
    line-height:0;
}
.nav-item .btn-twitter:hover,
.nav-item .btn-twitter:focus {
    background:#06273a;
    color:#30c8ff;
}

.nav-item .btn-linkedin {
    margin:4px 12px 0 18px;
    padding:2px;
    line-height:0;
    background:#fff;
    color:#06273a;
}
.nav-item .btn-linkedin:hover,
.nav-item .btn-linkedin:focus {
    background:#30c8ff;
    color:#06273a;
}

#content-col {
    margin:0;
    padding:0;
    width:calc(100% - 106px) !important;
    max-width:1814px;
    float: left;
    background:#fff;
}

#content-padding {
    position:relative;
    padding:104px 104px 0 104px;
}

.col {
    padding:0;
}

.carrot-down {
    font-size:2.75rem;
    font-weight:500;
    line-height:0;
    transform:rotate(90deg);
}

#home-intro {
    padding:0;
}

#home-about,
#home-people,
#home-testimonials,
#home-expertise,
#home-diversity,
#home-news,
#home-events {
    margin:100px;
}

#home-subscribe {
    margin:100px 0 0 0;
}
#home-accolades {
    margin:0;
}

#home-about .column-ip {
    margin-right:7px;
    width:calc(50% - 7px);
    padding:5% 6% 5% 8%;
    background:#edf0f1;
}

#home-about .column-play-cta { /*position:relative;*/
    margin-left:7px;
    width:calc(50% - 7px);
	background:#06273a url("../images/home-about-bg.jpg") 60px center no-repeat;
	background-size: 45%;
	display: flex;
	align-items: center;
}

#home-about .column-play-cta a:hover { text-decoration: none; }

/*#home-about-play-cta {
	display: flex;
	flex-direction: column;
	align-items: stretch;	
    justify-content: center;
}*/

#home-about-play-cta p { 
	/*position:absolute; 
	right:25%; 
	top:130px;
	padding-top:100px;*/
    margin:0 10% 0 30%;
    /*width:60%;*/
    /*max-width:310px;*/
    font-size:1.875rem;
    line-height:165%;
    font-weight:700;
    color:#fff;
    /*cursor: pointer;*/
    /*background:url("../images/home-about-play-btn.png") top center no-repeat;*/
}
#home-about-play-cta:hover {
    /*background:url("../images/home-about-play-btn-hover.png") top center no-repeat;*/
}


#home-people h2,
#home-people p,
#home-expertise h2,
#home-expertise p,
#home-news h2,
#home-news p,
#home-events h2,
#home-events p,
#home-accolades h2,
#home-accolades p {
    margin:0 auto 50px auto;
    max-width:560px;
    text-align:center;
}

#home-accolades h2,
#home-accolades p  {
    color:#ffffff;
}


#home-testimonials {
    padding:95px;
    background:#06273a;
    color:#fff;
}
#home-testimonials .quote {
    margin:0 auto;
    padding:140px 100px 0 100px;
    width:100%;
    max-width:990px;
    font-size:2.5rem;
    font-weight:400;
    text-align:center;
    background:url("../images/testimonial-quote.png") top center no-repeat;
}
#home-testimonials .quote p { 
    font-size:2.5rem; 
    font-weight:400; 
    line-height:150%;
}
#home-testimonials .source {
    margin:30px auto;
    font-size:1.125rem;
    font-weight:700;
    color:#30c8ff;
}

#home-testimonials .row,
#home-testimonials h2,
#home-testimonials p {
    background:#06273a;
    color:#fff;
}


#home-diversity .home-diversity-col01 {
    margin-right:7px;
    width:calc(40% - 7px);
    /*background:#edf0f1 url("../images/diversity-img.jpg") center no-repeat;*/
    background-size:cover;
}
#home-diversity .home-diversity-col02 {
    margin-left:7px;
    width:calc(60% - 7px);
    background:#edf0f1;
    padding:7% 7% 6% 8%;
}
#home-diversity .home-diversity-col01 img {
    display:none;
}


#home-subscribe {
    padding:55px 10% 55px 8%;
    width:100%;
    background:#30c8ff;
}
#home-subscribe .home-subscribe-col01 {
    padding:0 4% 0 0;
    width:30%;
    border-right:1px #06273a solid;
}
#home-subscribe .home-subscribe-col02 {
    padding:0 0 0 5%;
    width:70%;
}

#home-subscribe .home-subscribe-col01 h2 {
    margin:0;
}
#home-subscribe input[type=email] {
    display:inline;
    margin-right:50px;
    padding:20px 45px;
    width:50%;
    font-size:1.125rem;
    color:#06273a;
    font-weight:500;
    background:#fff;
    border:0;
    border-radius:50px;
}
#home-subscribe .home-subscribe-col02 div {
    display:inline;
}
#home-subscribe .home-subscribe-col02 p {
    font-size:0.688rem;
    line-height:160% !important;
}


#home-accolades {
    padding:110px;
    background:#06273a url("../images/home-accolades-bg.jpg") center center no-repeat;
    background-size:cover;
}


.modal-xl {
    margin:0;
    width:100vw !important;
    height:100vh !important;
    max-width:100vw; /* 1214px */
    max-height:100vh; /* 1214px */
    background:rgba(6,39,58,0.8);
    background-size:contain; /* 100% 100% */
    border:none;
    align-items:center;
    justify-content:center;
}
.modal-dialog-centered {
    /* margin:0 auto;*/
}
.modal-content {
    position:relative;
    margin:0 20px;
    padding:0;
    width:100%;
    max-width:500px;
    height:360px;
    background-color:transparent;
    border:0;
    /*max-width:1400px !important;
    max-height:875px !important;
    min-height:720px !important;*/
}
.close-modal, .close-modal:hover {
    position:absolute;
    top:15%;
    right:5%;
    width:74px;
    height:74px;
	color:#fff;
    cursor: pointer;
    z-index: 9999;
}

.close-modal-X {
    font-size:2.5rem;
    font-weight:700;
}

.modal-body {
    display:flex; /*width:100%; height:100%;*/
    align-items:center;
    justify-content:center;
}
#global-search  {
    width:100%;
	max-width:570px;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
  -webkit-appearance:none;
}

/*#home-slide-search*/ .bandp-search {
    padding:25px 45px;
    width:80%;
	/*max-width:570px;*/
    font-size:1.125rem;
    color:#000;
    text-align:center;
    font-weight:500;
    opacity:0.85;
    border:0;
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
    background-color:rgba(255,255,255,0.85) !important;
}
#global-search .bandp-search {
    padding:25px 45px;
    width:80%;
	/*max-width:385px;*/
    font-size:1.125rem;
    color:#000;
    text-align:center;
    font-weight:500;
    opacity:0.85;
    border:0;
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
    background-color:rgba(255,255,255,0.85) !important;
}

button#clear-search, 
button#clear-global-search {
    display: none;
}

/*#home-slide-search*/ .filters-submit, 
/*#home-slide-search*/ .filters-reset, 
#global-search .filters-submit, 
#global-search .filters-reset
{
    margin:0;
    padding:24px 10px;
    color:#06273a;
    background-color:rgba(255,255,255,0.7) !important;
    border:0;
	border-radius:0;
}
.filters-submit:hover, 
.filters-reset:hover {
    background:#eee;
}
/*
#home-slide-search .filters-reset { visibility:hidden; }
#home-slide-search .bandp-search:focus .filters-reset { visibility:visible; }
*/

#home-slide-search .filters-submit, 
#global-search .filters-submit, 
#global-search-mobile .filters-submit  {
	border-top-right-radius: 50px !important;
    border-bottom-right-radius: 50px !important;
}

#global-search .input-group {
	display:flex;
	justify-content:center;
}

#global-search-mobile .bandp-search {
    padding:15px 25px;
    width:100%;
	max-width:285px;
    font-size:1.125rem;
    color:#000;
    text-align:center;
    font-weight:500;
    opacity:0.85;
    border:0;
    border-top-left-radius: 50px !important;
    border-bottom-left-radius: 50px !important;
    background-color:rgba(255,255,255,0.85) !important;
}

#global-search-mobile .filters-submit, 
#global-search-mobile .filters-reset
{
    margin:0;
    padding:14px 10px;
    color:#06273a;
    background-color:rgba(255,255,255,0.7) !important;
    border:0;
	border-radius:0;
}

.filters-reset { display: none; }



footer {
    padding:105px 106px 0 106px !important;
    font-family:"Helvetica Neue", Helvetica, Arial, "sans-serif";
    background:#edf0f1;
}
footer .footer-row {
    padding:0 54px 45px 54px;
}
footer .footer-branding {
    display:flex;
    width: 100%;
    justify-content:space-between;
}

footer .row div {
    letter-spacing:1.8px;
    font-weight:500 !important;
}

footer a:hover {
    color:#000 !important;
}

footer .footer-logo {
    display:inline;
    margin-left:-54px;
    padding-right:50px;
}

footer .footer-cities {
    display:flex;
    justify-content:flex-start;
    flex-grow: 1;
    align-items:center;
}
footer .footer-cities div {
    text-align:center;
}
footer .footer-cities .menu-bar {
    width:50px;
}

footer .footer-menu {
    width:100%;
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
}
footer .footer-menu-spacer {
    display:none;
}
footer .footer-menu-item {
    display:inline;
}

footer .footer-fine-print {
    width:100%;
    max-width:1100px;
    display:flex;
    justify-content:space-between;
}

footer .footer-socials {
    display:relative;
    right:0;
}

footer .btn-twitter,
footer .btn-linkedin {
    background:#edf0f1;
    color:#06273a;
}

footer .btn-twitter:hover,
footer .btn-linkedin:hover,
footer .btn-twitter:focus,
footer .btn-linkedin:focus {
    background:#edf0f1;
    color:#000;
}

footer .btn-linkedin {
    padding-left:34px !important;
}

footer .footer-copyright,
footer .footer-copyright a {
    display:inline;
    font-size:0.813rem;
    font-weight:500 !important;
}
footer .footer-copyright a:hover {
    color:#000;
}


.desktop-only {
    display:block;
}
.mobile-only {
    display:none;
}
.subscribe-only {
    display:none;
}

#share-btn a {
    font-size: 0.75rem;
    /*color: #9a9a9a;*/
    background-color: transparent !important;
    width: 24px;
    height: 24px;
    position: absolute;
    right: 37px;
    top: 0;
}

#share-btn a:before {    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 24px;
    cursor: pointer;
    width: 24px;
    background: url(../images/share-icon.svg) center center no-repeat;
    background-size: 20px 20px;
}
#share-btn a .at4-visually-hidden {
	color: #000 !important; /* Fix for accessability error */
}
#share-btn a .at-icon-wrapper,
#share-btn a .at-label {
	color: #000 !important; /* Fix for accessability error */
    display: none;
}

.jfn-tooltip {
    font-size: 1rem;
}