/*
	Tigerlily Training - Public Website main stylesheet
    
    Author: CFRONT (SABN)
    Created: 08/08/2016

*/

:root {
    --tlt-purple: #512683;
    --tlt-green: #479667;
}

@font-face {
    font-family: 'jenna_sueregular';
    src: url('/Fonts/jennasue_webfont/Webfont/jennasue-webfont.eot');
    src: url('/Fonts/jennasue_webfont/Webfont/jennasue-webfont.eot?#iefix') format('embedded-opentype'), url('/Fonts/jennasue_webfont/Webfont/jennasue-webfont.woff') format('woff'), url('/Fonts/jennasue_webfont/Webfont/jennasue-webfont.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

html, body {
    background: none;
    padding: 0;
    min-height: 100%;
    height: 100%;
    margin: 0;
}

html {
    overflow-y: scroll;
    font-size: 17px;
}

html.hide_scroll {
    overflow-y: hidden;
}

html.hide_scroll .site-msg-tab-container {
    display:none!important;
}

body {
    -webkit-animation: fadein 2s;
    -moz-animation: fadein 2s;
    -ms-animation: fadein 2s;
    -o-animation: fadein 2s;
    animation: fadein 2s;
    margin: 0;
    padding: 0;
    font-family: lato, sans-serif;
    min-height: 100%;
    height: 100%;
    color: #222222;
    background: #ededed;
    font-size: 17px;
}

h1, h2, h3, h4, h5 {
    font-family: sofia-pro, sans-serif;
    font-weight: 500;
}

h1 {font-size: 2.5rem;}
.venues-page h1 {
    margin:24px 0;
    color: #512683;
    font-size: 36px;
    font-weight: 600;
    font-family: sofia-pro, sans-serif;
}

h2 {font-size: 2.2rem;}
.venues-page h2 {font-size:1.4rem;}

h3 {font-size: 1.6rem;}
.site-msg-tab h3 {margin: 0.5rem;}
.site-msg-tab p {
    margin: 0.5rem;
}
h4 {font-size: 1.4rem;line-height: 2rem;}
h5 {font-size: 1.1rem;}

h1 span.normal, h2 span.normal, h4 span.normal {font-weight:500;}
h1 span.normal {font-size:1.2rem;}

.holidays-banner {background:#34b78f;text-align:center;position:relative;}
.row .holidays-banner .inner {max-width:1200px;}
.row .holidays-banner .inner > div {background:rgb(0 143 58 / 80%);border-radius:5px;padding:10px;position:relative;z-index:10;}
.row .holidays-banner h3 {font-size:24px;margin: 10px;}
.holidays-banner h3,.holidays-banner p {color:#FFFFFF;position:relative;z-index:10;}
.holidays-banner a {color:#FFFFFF;text-decoration:underline;}
.holidays-banner .berries {position:absolute;left:0;top:0;width:20%;max-width:250px;}
.holidays-banner .branch {position:absolute;right:0;top:0;width:20%;max-width:250px;}
.holidays-banner .berries img,.holidays-banner .branch img {display:block;width:100%;}
.holidays-banner::after {content:"";display:block;background-image:url(/images/snowflakes.svg);background-size:cover;position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;}

.venue-title-intro {
    color:#512683;
    font-style:italic;
}

.site-msg-tab-container {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 100005;
}
.site-msg-tab strong {
    display: inline-block;
    margin-right: 0.5rem;
}
.site-msg-tab {
    width: 100%;
    background: #f7da0b;
    color: #512683;
    padding: 5px;
    transition: 0.5s;
    margin: 0;
    text-align: center;
    box-sizing: border-box;
}

.site-msg-tab.smt-2 {
    background: #ff8d00;
}

.site-msg-tab:hover {
    cursor: pointer;
    background: #512683;
    color: #FFFFFF;
}

.site-msg-tab > div {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.site-msg-tab .close {
    position: absolute;
    top: 12px;
    right: 12px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: rgba(0,0,0,0.1);
}

.site-msg-tab .close svg {
    display: block;
    width: 16px;
    height: 16px;
}

.site-msg-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    background: rgba(0,0,0,0.6);
    align-items: center;
    justify-content: center;
    display: none;
    z-index: 10001;
}

.site-msg {
    background: #FFFFFF;
    color: #512683;
    width: 60%;
    min-width: 340px;
    position: relative;
    border-radius: 12px;
    padding: 40px;
    box-sizing: border-box;
}

.site-msg-close {
    display: block;
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 4px;
    border-radius: 50%;
    transition: 0.5s;
    color: #512683;
    border: 1px solid #512683;
}

.site-msg-close:hover {
    background: #512683;
    color: #FFFFFF;
    cursor: pointer;
}

.review-banner {
    padding: 1rem 0;
    background: #dcddf2;
}

.site-msg-close svg {
    display: block;
    width: 16px;
    height: 16px;
    pointer-events: none;
}

.ooo-msg-container {
    display:none;
    position:fixed;
    top:100px;
    width:100%;
    left:0;
    align-items:center;
    justify-content:center;
    z-index: 100002;
}

.ooo-msg {
    width:90%;
    max-width: 600px;
    background: #dcddf2;
    border-radius: 12px;
    padding: 24px;
    display: flex;  
    position:relative;
}

.close-ooo {
    position:absolute;
    top:12px;
    right:12px;
    cursor:pointer;
}

.close-ooo svg {
    display:block;
    width:24px;
    height:24px;
    fill:#512683;
    pointer-events:none;
}

.close-ooo:hover svg {
    color:#34b78f;
}

.ooo-image {
    padding: 0 24px 0 0;
}

.ooo-image svg {
    display:block;
    width:100px;
    height:100px;
}

.ooo-text,
.ooo-text h3 {
    color:#512683;
}

.ooo-text h3 {
    margin: 0 0 16px 0;
}

ol {
    counter-reset: item
}

ol li {
    display: block
}

ol li:before {
    content: counters(item, ".") " ";
    counter-increment: item
}

ol ul li:before {
    content: "\2022";
    margin-right: 0.5rem;
}

strong {
    font-family: sofia-pro, sans-serif;
    font-weight: 500;
}

#wrapper {
    background: #FFFFFF;
    margin: 0 auto
}

.no-scrollbar::-webkit-scrollbar {
    display: none;
}

.no-scrollbar {
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
}

.row li {
    margin: 5px 0;
}

a {
    color:#34b78f;
    transition: all ease 0.5s;
    text-decoration: underline;
}

.site-msg-tab a {
    color:#512683;
    text-decoration:underline;
}

.site-msg-tab a:hover {
    color:#FFFFFF;
    text-decoration:underline;
}

.event-type span a {
    color:#512683;
    text-decoration:none;
}

a:hover {
    color:#512683;
    text-decoration: underline;
}

.young-minds {
    background-color: #FFCE00;
    background-image: url('https://tigerlilytraining.co.uk/media/1558/young-minds-bg.png');
    background-repeat: no-repeat;
    background-size: cover;
}

.young-minds,
.young-minds strong,
.young-minds a {
    color: #FF620E;
}

.young-minds a {
    text-decoration: none;
    color: #FF620E;
}

.young-minds a:hover,
.young-minds a:hover strong {
    text-decoration: none;
    color: #512683;
    color: var(--tlt-purple);
    transition: 0.7s;
}

.young-minds > div {
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 2rem;
}

.young-minds > div:nth-of-type(1) {
}

.young-minds > div:nth-of-type(2) {
    text-align: center;
    color: #FF620E;
    font-size: 1.5rem;
}

.young-minds > div:nth-of-type(2) p {
    line-height: 1.75rem;
}

.young-minds > div:nth-of-type(3) {
    background: #FFFFFF;
}

.young-minds img {
    display: block;
    width: 90%;
    max-width: 400px;
}

span.link-button,
.row_center a.link-button,
a.link-button,
a.link-button:visited {
    border: none;
    padding: 6px 20px 8px 20px;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 20px auto 10px auto;
    font-weight: 500;
    background: #512683;
    color: #FFFFFF;
    transition: all ease 0.7s;
    outline: none;
    border-radius: 25px;
    cursor: pointer;
    text-decoration:none;
    display:inline-block;
}

span.link-button.purple,
a.link-button.purple {
    background: #512683;
}

span.link-button.green, 
a.link-button.green {
    background: #34b78f;
}

.row_center a.link-button:hover,
a.link-button:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    text-decoration: none;
}

a.link-button.purple:hover {
    background:#479667;
}

.row.rf_reviews {
    margin: 0 auto;
    padding: 2rem 0;
    display: block;
}

.row_center a {
    display: inline-block;
    color: #512683;
    text-decoration: underline;
    font-weight: 500;
    line-height: 30px;
    padding-bottom: 2px;
}

.row_center a:hover {
    color: #34b78f;
    text-decoration: underline;
}

.row_center a.more_info {
    color: #34b78f;
}

.row_center a.more_info:hover {
    color: #512683;
    border-color: #512683;
    transition: all ease 0.7s;
}

#headerOuter {
    position: sticky;
    top: 0;
    left: 0;
    z-index: 1006;
    width: 100%;
    box-sizing: border-box;
    min-height: 58px;
    -webkit-box-shadow: 0 0 0 1px rgba(50,50,93,.05), 0 7px 14px 0 rgba(50,50,93,.1), 0 3px 6px 0 rgba(0,0,0,.07);
    box-shadow: 0 0 0 1px rgba(50,50,93,.05), 0 7px 14px 0 rgba(50,50,93,.1), 0 3px 6px 0 rgba(0,0,0,.07);
    background: #FFF;
}

body.popup-active::-webkit-scrollbar {
    display: none;
}

body.popup-active #headerOuter {
    z-index:1;
}

#headerOuterSpacer {
    display: block;
    height: 170px;
    position: relative;
}

.mobile_top_button {
    display: none;
    background: #FFFFFF;
    width: 100%;
    text-decoration: none;
    text-align: center;
    font-size: 0.9em;
    padding: 5px 0 12px 0;
    color: #4f4f4f;
    border-bottom: 1px solid #dddddd;
}

.mobile_top_button i.material-icons {
    position: relative;
    top: 6px;
    margin-right: 5px;
}

.mobile_top_button:hover {
    transition: background ease 0.7s;
    background: #009949;
    color: #FFFFFF;
}

h1 {
    color: #512683;
    color: var(--tlt-purple);
    font-size: 2.8rem;
    font-weight: 500;
    margin-top: 0;
}

span.h2,
h2 {
    color: #512683;
    color: var(--tlt-purple);
    font-size: 2.2rem;
    font-weight: 600;
    margin-top: 0;
    font-family: sofia-pro, sans-serif;
}

.nowrap {
    white-space: nowrap;
}

#headerOuter.fix {
    background: #FFFFFF;
    transition: all ease 0.5s;
    z-index: 1004;
    background-color: #fff;
    box-shadow: 0px 1px 10px 0px rgba(0,0,0,0.1);
}

#header {
    position: relative;
    display: flex;
    max-width: 1440px;
    margin: 0 auto;
    z-index: 10;
    box-sizing: border-box;
    transition: all ease 0.5s;
    flex-grow: 0;
}

.logo-home-link {
    display: block;
    text-decoration: none;
    width: 100%;
    max-width: 440px;
    padding: 7px 20px;
    box-sizing: border-box;
}

.logo-home-link svg,
.logo-home-link img {
    display: block;
    width: 100%;
}

.logo-home-link:after {
    content: "";
    height: 2px;
    width: calc(100% - 300px);
    background: #512683;
    background: var(--tlt-purple);
    position: absolute;
    right: 0.5rem;
    top: 92px;
}

.nav,
nav {
    font-family: sofia-pro, sans-serif;
}

.logo-home-link svg {
    display: block;
    width: 100%;
    max-width: 340px;
    padding: 12px 0;
}

.logo-nav .nav,
.logo-nav .nav ul {
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    min-height: 51px;
}

.logo-nav .nav > ul {
    list-style-type: none;
    margin: 0 1rem;
    padding: 0;
    width: 100%;
}

.logo-nav .nav > ul li {
    position: relative;
}

.logo-nav .nav ul .subnav {
    position: absolute;
    display: none;
    width: 480px;
    background: #512683;
    background: var(--tlt-purple);
    color: #fff;
    font-size: 0.9rem;
    padding: 1rem 0;
    transition: 0.2s;
    list-style-type: none;
}

.logo-nav .nav ul .subnav.active {
    display: block;
}

.logo-nav .nav > ul a,
.logo-nav .nav > ul span {
    text-decoration: none;
    color: #512683;
    color: var(--tlt-purple);
    padding: 0.7rem 1rem 0.5rem 1rem;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
    white-space: nowrap;
    font-size: 1rem;
    display: flex;
    display: -webkit-flex;
    height: 100%;
    align-items: center;
}

.logo-nav .nav > ul a:hover {
    color:#34b78f;
}

.logo-nav .nav > ul span.has-subnav {
    cursor: pointer;
}

.logo-nav .nav > ul span.has-subnav:hover,
.logo-nav .nav > ul span.has-subnav.active {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFF;
    transition: 0.2s;
}

.menu-nav a {
    padding: 0.5rem 2rem 1rem 2rem;
}

.logo-nav .nav ul.subnav a,
.logo-nav .nav .subnav span {
    color: #FFF;
    padding: 0.125rem 1rem;
    box-sizing: border-box;
    text-align: left;
    white-space: unset;
    font-size: 0.9rem;
    transition: 0.2s;
}

.logo-nav .nav ul.subnav a:hover {
    background: rgba(0,0,0,0.1);
}

nav div.main_menu .col-1-3 ul.subnav li a.unavailable,
.logo-nav .nav .subnav li a.unavailable {
    color: #C1272D;
    cursor: default;
    pointer-events: none;
}

nav div.main_menu .col-1-3 ul.subnav li a.unavailable:hover,
.logo-nav .nav .subnav li a.unavailable:hover {
    background: none;
    cursor: default;
}

.logo-nav .nav .subnav span {
    font-size: 0.9rem;
    font-weight: 600;
    display: block;
}

.logo-nav .nav .subnav .note span {
    font-size: 0.8rem;
    font-weight: 500;
}

.menu-nav li.has-subnav a:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFF;
}

.menu-nav .header-social-links a {
    border-radius: 50px;
    font-size: 13px;
    width: 24px;
    text-align: center;
    height: 22px;
    padding: 2px 1px 0 0;
}

.nav-icon {
    width: 50px;
    margin: 0 auto;
    display: -webkit-flex;
    display: -webkit-box;
    display: -moz-flex;
    display: -moz-box;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 13px 13px 11px 13px;
    justify-content: flex-end;
    flex-wrap: wrap;
    border-radius: 50%;
    transition: 0.7s;
    background: #512683;
    cursor:pointer;
}

.nav-icon-bars {
    background: #FFF;
    width: 26px;
    height: 2px;
    -webkit-transition: all .3s;
    transition: all .3s;
    margin: 3px 0;
}

.main_menu ul.subnav li {
    margin: 0.25rem 0;
    padding: 0.25rem 0;
    transition: 0.5s;
    border-bottom: 1px solid rgba(255,255,255,0);
}

.main_menu ul.subnav li:hover {
    border-bottom: 1px solid rgba(255,255,255,0.2);
}

.main_menu ul.subnav li.group {
    margin-bottom: 0.3rem;
    border-bottom: 1px solid rgba(255,255,255,0.2);
}

nav div.main_menu .col-1-3 ul.subnav li span {
    font-size: 0.9rem;
    font-weight: 600;
}

nav div.main_menu .col-1-3 ul.subnav li.group span {
    font-size: 1rem;
    letter-spacing: 0.25px;
}

nav div.main_menu .col-1-3 ul.subnav li.note span {
    font-weight: 500;
}

nav div.main_menu .col-1-3 ul.subnav .light {
    font-weight: 200;
    color: rgba(255,255,255,0.5);
}

nav div.main_menu .col-1-3 ul.subnav li a {
    font-weight: 400;
    font-size: 0.9rem;
    letter-spacing: 0.25px;
    display: block;
}

.menu-nav .menu_bars {
    background: #FFFFFF;
    width: 24px;
    height: 17px;
    padding: 8px 0;
    transition: all ease 0.7s;
}

.menu-nav .menu_bars span.menu_bar {
    display: block;
    width: 24px;
    height: 3px;
    background: #4f4f4f;
    padding: 0;
    margin: 4px auto;
    position: relative;
}


.main_menu ul,
.sub_menu ul {
    list-style: none;
}

.main_menu ul li {
    margin: 1rem 0;
}


.menu-nav nav .main_menu ul a,
.menu-nav nav .sub_menu ul a {
    text-align: left;
    padding: 10px;
    justify-content: flex-start;
}

.menu-nav nav .main_menu ul a:hover,
.menu-nav nav .sub_menu ul a:hover {
    opacity: 0.5;
    transition: 0.7s;
}

.menu-nav nav .main_menu ul li.contact-us-title a {
    padding: 10px 10px 10px 0;
}

.menu-nav nav .sub_menu ul a .small {
    font-weight: 500;
    font-size: 14px;
}


.menu-nav nav .main_menu ul a .far,
.menu-nav nav .sub_menu ul a .far,
.menu-nav nav .main_menu ul a .fas,
.menu-nav nav .sub_menu ul a .fas {
    margin-left: 5px;
}

.menu-nav nav .main_menu .cat_courses ul a .far,
.menu-nav nav .sub_menu .cat_type ul a .far {
    color: #d5cfbe;
}

.menu-nav nav .main_menu .cat_links ul a .far,
.menu-nav nav .sub_menu .cat_sector ul a .far,
.menu-nav nav .main_menu .cat_links ul a .fas,
.menu-nav nav .sub_menu .cat_sector ul a .fas {
    color: #FFF;
}

.menu-nav nav div span.email,
.main_menu .tel {
    display: block;
    margin-bottom: 10px;
}

.col-1-3 {
    width: 33.333%;
}

.main_menu .col-1-3 {
    width: 33.333%;
    box-sizing: border-box;
    padding: 20px 40px;
    color: #FFF;
}

.main_menu .col-1-3:nth-child(1) {
    background: #270c47;
}

.main_menu .col-1-3:nth-child(2) {
    background: #321358;
}

.main_menu .col-1-3:nth-child(3) {
    background: #401c6c;
}

.main_menu .col-1-3 h3 {
    margin: 1rem 0;
    color: #FFF;
}

.main_menu .col-1-3 h3 a {
    font-size: 1.6rem;
}

.nav-contact {
    font-size: 16px;
}

.nav-box {
    padding: 10px;
    border-radius: 3px;
    background: rgba(255,255,255,0.2);
}

.main_menu .col-1-3:nth-child(1) .nav-box {
    background: rgba(255,255,255,0.2);
}

.main_menu .col-1-3:nth-child(2) .nav-box {
    background: rgba(255,255,255,0.2);
}

.main_menu .col-1-3:nth-child(3) .nav-box {
    background: rgba(0,0,0,0.2);
}

.main_menu .col-1-3 .nav-box:hover {
    cursor: pointer;
    background: rgba(0,0,0,0.4);
    transition: 0.5s;
}

.main_menu .col-1-3:nth-child(1) .nav-box:hover,
.main_menu .col-1-3:nth-child(2) .nav-box:hover {
    background: rgba(255,255,255,0.4);
}

.main_menu .col-1-3:nth-child(3) .nav-box:hover {
    background: rgba(0,0,0,0.4);
}

.opening-hours h4 {
    margin: 1rem 0 0 0;
    color: #FFF;
    font-size: 1.2rem;
}

.nav-social {
    top: 100%;
    padding: 0.5rem;
    box-sizing: border-box;
    display: flex;
}

.main_menu span.tel {
    font-weight: 500;
}

.menu-nav nav div .main_menu span.tel a {
    font-weight: 600;
    font-size: 22px;
    margin: 5px 0 0 0;
    letter-spacing: 2px;
    display: block;
}

.w_icon {
    color: #4f4f4f;
    line-height: 30px;
}

.menu-nav nav div span.email a {
    display: inline;
}

.contact-us-title a h3 {
    color: #4f4f4f;
}

.mm_contact {
    padding: 0px 40px 20px 40px;
    text-align: left;
}

.menu-nav nav div .mm_contact span,
.menu-nav nav div .mm_contact a {
    text-align: left;
    padding: 0;
}

.menu-nav nav div .mm_contact a {
    font-weight: 900;
    color: #d5cfbe;
}


.menu-nav nav div .mm_contact span:hover {
    background: transparent;
    cursor: default;
}

.mm_contact .social {
    display: flex;
    margin-top: 20px;
}

.menu-nav nav div .mm_contact .social a {
    text-decoration: none;
    color: #FFFFFF;
    padding: 4px;
    width: 30px;
    font-weight: normal;
    text-align: center;
}

.hours {
    line-height: 24px;
}

.small_screen_logo {
    display: none;
    text-align: center;
    padding: 10px;
    background: #FFFFFF;
}

.small_screen_logo img {
    display: block;
    margin: 0 auto;
    height: 60px;
}

.small_screen_show {
    display: none;
}

nav div {
    flex-grow: 1;
    text-align: center;
}

nav .main_menu div {
    text-align: left;
}

nav .main_menu,
nav .sub_menu {
    position: absolute;
    box-shadow: 0px 7px 7px rgba(0,0,0,0.15);
    left: 0;
    top: auto;
    z-index: 11;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#6f71d7+0,512683+100 */
    background: #6f71d7; /* Old browsers */
    background: -moz-linear-gradient(left, #6f71d7 0%, #512683 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left, #6f71d7 0%,#512683 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, #6f71d7 0%,#512683 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6f71d7', endColorstr='#512683',GradientType=1 ); /* IE6-9 */
    width: 100%;
    z-index: 11;
    flex-wrap: wrap;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    overflow-x: hidden;
    overflow-y: scroll;
    height: calc(100vh - 148px);
}

nav div > span,
nav div a,
nav div a:visited {
    text-decoration: none;
    color: #512683;
    color: var(--tlt-purple);
    font-weight: 500;
    font-size: 16px;
    display: flex;
    transition: all ease 0.7s;
    box-sizing: border-box;
    position: relative;
    height: 100%;
    align-items: center;
}

.nav-social a {
    border-radius: 50px;
    background: none;
    font-size: 20px;
    width: 37px;
    text-align: center;
    height: 35px;
    padding: 0 0 0 0px;
    margin: 0 1rem 0 0;
}

.nav-social a:hover {
    text-decoration: none;
    background: rgba(0,0,0,0.2);
    transition: all 0.5s;
}

.nav-social a i {
    margin: auto;
}

nav div a:hover {
    text-decoration: underline;
}

nav div .subnav a:hover {
    text-decoration: none;
}


nav div > span, nav div a i {
    margin-left: 0.5rem;
}

nav div.main_menu .col-1-3 a {
    color: #FFF;
}

nav div.ni-phone > span,
nav div.ni-phone a {
    color: #b965be;
}

.ni-phone i {
    margin-right: 5px;
}

.logo-nav {
    width: calc(100% - 160px);
    position: relative;
}

.header-social-links {
    position: absolute;
    left: 0;
    top: 100%;
    background: #512683;
    background: var(--tlt-purple);
    width: 100%;
    padding: 0.5rem;
    box-sizing: border-box;
    display: flex;
    justify-content: space-between;
}

.menu-nav {
    width: 160px;
    display: flex;
    flex-direction: column;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFF;
    align-items: center;
    text-align: center;
    position: relative;
}

.menu-nav a.contact-us {
    font-family: sofia-pro, sans-serif;
}

.menu-nav > div > span {
    display:block;
    font-style: normal;
    letter-spacing: 1px;
    margin:16px 0 8px 0;
}

.main_menu ul li .tel a {
    padding: 0.5rem 0;
    font-size: 2rem;
}

.menu-nav a {
    text-decoration: none;
    color: #FFF;
}

.menu-nav span .fa-bars {
    display: block;
}

.menu-nav span.active .fa-bars {
    display: none;
}

.menu-nav span .fa-times {
    display: none;
}

.menu-nav span.active .fa-times {
    display: block;
}

nav div > span:after,
nav div a:after {
    display: block;
    content: "";
    position: absolute;
    left: 0;
    bottom: 0px;
    height: 2px;
    width: 100%;
    background: #6466b9;
    transition: 0.7s;
    opacity: 0;
}

nav div.main_menu > span:after,
nav div.main_menu a:after {
    height: 1px;
    background: #FFFFFF;
}


nav div .main_menu > span,
nav div .main_menu a {
    text-decoration: none;
    color: #FFFFFF;
    font-weight: 500;
}

nav div.book_course a {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
}

#nav {
    margin: 0;
    float: left;
}

#logoStrap {
    font-family: 'jenna_sueregular', cursive;
    color: #FFFFFF;
    line-height: 1em;
    font-size: 3.25em;
    text-align: center;
    margin-top: 0.1em;
}

nav {
    margin: 0;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    display: none;
}

nav ul {
    width: 100%;
    vertical-align: middle;
    margin-top: 0;
    margin: 0;
    padding: 0;
}

nav > a.mi_menu {
    margin-left: 40px;
}

nav > a,
nav > span {
    height: 90px;
    display: block;
    color: #FFFFFF;
    text-decoration: none;
    transition: all ease 0.7s;
    font-weight: 500;
    position: relative;
    box-sizing: border-box;
}

#sign-in {
    height: 90px;
    position: relative;
    width: 105px;
    box-sizing: border-box;
    display: block;
    background: rgba(0,0,0,0.7);
    color: #FFFFFF;
    text-decoration: none;
    border-left: 6px solid #ededed;
    transition: all ease 0.7s;
    font-weight: 500;
    float: left;
}

#sign-in span {
    font-size: 15px;
    padding: 19px 13px 15px 13px;
    display: block;
    line-height: 18px;
    color: #FFFFFF;
    bottom: -5px;
}

/* Course booker sesarch */

.select-wrapper {
    z-index: 2;
    position: relative;
}

.book_online .select-arrow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0px;
    color: #999999;
    font-family: sofia-pro, sans-serif;
    font-size: 19px;
}

.book_online .select-arrow span,
.book_online .options span {
    color: #212121;
}

.book_online .options span {
    color: #212121;
    padding: 0.3rem;
    font-size: 0.9rem;
    cursor: pointer;
    transition: 0.2s;
}

.book_online .options span:hover {
    background: #512683;
    color: #FFFFFF;
}

.select-arrow svg {
    display: block;
    width: 20px;
}

.book_online .select-arrow {
    border: 2px solid #999999;
    border-radius: 3px;
    padding: 6px 10px;
    color: #212121;
    font-family: sofia-pro, sans-serif;
    font-size: 19px;
    margin: 15px 0 0 0;
    max-width: 100%;
    box-sizing: border-box;
    outline: none;
}

.select-wrapper .options {
    display: none;
    width: 960px;
    border: 2px solid #512683;
    padding: 0;
    background: #FFFFFF;
    flex-wrap: wrap;
    position: absolute;
    top: calc(100% - 3px);
}

.select-wrapper .options.show {
    display: flex;
}

div.optgroup {
    width: calc(33.333% - 2rem);
    margin: 0.6rem;
}

.book_online .optgroup h5 {
    border-bottom: 2px solid #212121;
    font-size: 1rem;
    padding: 0.5rem 0.3rem;
    margin: 0 0 0.5rem 0;
}

#sign-in span i {
    font-size: 19px;
}

#sign-in:hover {
    background: #ededed;
    transition: background ease 0.7s;
    cursor: pointer;
}

#sign-in:hover span {
    color: #212121;
}

#sign-in.popped {
    background: #2a4759;
    color: #FFFFFF;
}

#sign-in.popped span {
    color: #FFFFFF;
}

#sign-in-box {
    position: absolute;
    top: 90px;
    right: 0;
    box-sizing: border-box;
    padding: 20px;
    background: #2a4759;
    width: 50%;
}

nav > span.mi_plus {
    display: none;
    position: relative;
    width: 108px
}

nav > span.mi_plus:hover {
    cursor: pointer;
    background: #34b78f;
}

.mi_plus i {
    font-size: 3.5em;
    padding: 15px 25px 0px 24px;
}

.header_ad {
    position: fixed;
    top: 0;
    right: 0;
    background: #FFFFFF;
}

.ha_feedback,
.ha_learner_stats {
    float: right;
    font-size: 0.9em;
    text-align: center;
}

.ha_feedback {
    display: block;
    padding: 11px 12px;
    background: #285f81;
    color: #FFFFFF;
    position: relative;
    overflow: visible;
    text-decoration: none;
    color: #FFFFFF;
    transition: all ease 0.7s;
}

.ha_feedback:hover {
    background: #34b78f;
    transition: all ease 0.7s;
}

.five_star {
    display: block;
    margin-top: 2px;
    color: #ffe92f;
}

.five_star .material-icons {
    width: 1em;
}

.fb_triangle {
    position: absolute;
    left: 0;
    bottom: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 20px 20px 0 0;
    border-color: #285f81 transparent transparent transparent;
    transition: all ease 0.7s;
}

.ha_feedback:hover .fb_triangle {
    border-color: #34b78f transparent transparent transparent;
    transition: all ease 0.7s;
}

.ha_learner_stats {
    padding: 12px 16px;
    background: #FFFFFF;
    color: #34b78f;
}

#plus_dd {
    display: none;
    position: absolute;
    top: 80px;
    left: 0;
    box-sizing: border-box;
    background: rgba(0,0,0,0.7);
}

#plus_dd a {
    display: block;
    color: #FFFFFF;
    white-space: nowrap;
    text-decoration: none;
    padding: 10px 60px 10px 20px;
}

#plus_dd a:hover {
    background: #;
}

#plus_dd a.mi_pfa:hover {
    background: #34b78f;
}

#plus_dd a.mi_fas:hover {
    background: #512683;
}

#plus_dd a.mi_faw:hover {
    background: #285f81;
}

#plus_dd a.mi_all:hover {
    background: #eec007;
}

#sign-in-box label {
    display: block;
    color: #EDEDED;
    padding: 7px;
    font-size: 1.2em;
    font-weight: 500;
}

#sign-in-box input,
#sign-in-box input[type="text"],
#sign-in-box input[type="password"] {
    background: #ededed !important;
    color: #212121 !important;
    font-weight: 500 !important;
    font-style: normal !important;
    padding: 10px;
    box-sizing: border-box;
    width: 100%;
    border: none;
    font-size: 1.2em;
}

#sign-in-box input[placeholder] {
    color: #acacac !important;
    font-style: italic !important;
    opacity: 1 !important;
}

.sign-in-button {
    width: 50%;
    float: right;
}

.sign-in-help {
    width: 50%;
    float: left;
    padding: 20px 0 0 7px;
    box-sizing: border-box;
}

#sign-in-box button {
    float: right;
    margin-top: 20px;
    border: none;
    font-size: 1.2em;
    padding: 10px 20px;
}

#sign-in-box button:hover {
    transition: all ease 0.7s;
    background: #34b78f;
    color: #FFFFFF;
    cursor: pointer;
}

.sign-in-help a {
    text-decoration: underline;
    color: #ededed;
    font-weight: 500;
    display: block;
    padding: 10px;
    text-align: center;
}

.sign-in-help a:hover {
    color: #FFFFFF;
    background: rgba(255,255,255,0.2);
}

#sign-in span.remember_container {
    display: none;
}

nav {
    font-family: sofia-pro, sans-serif;
}

nav > a.mi_pfa {
    border-left-color: #34b78f;
}

nav > a.mi_fas {
    border-left-color: #512683;
}

nav > a.mi_faw {
    border-left-color: #285f81;
}

nav > a.mi_all {
    border-left-color: #eec007;
}

nav > a.mi_menu {
    border-left-color: #222222;
}

nav .mi_menu div {
    border: none;
    background: #FFFFFF;
}

/* hover effects */

nav > a:hover {
    transition: all ease 0.7s;
}

nav > a.mi_pfa:hover {
    background: #34b78f;
}

nav > a.mi_fas:hover {
    background: #512683;
}

nav > a.mi_faw:hover {
    background: #285f81;
}

nav > a.mi_all:hover {
    background: #eec007;
}

nav div.mi_menu:hover {
    background: #EDEDED;
}

nav > a.mi_venues:hover {
    background: #b3d1ff;
}

nav > a.mi_menu {
    width: 105px;
}

nav > a span {
    font-size: 17px;
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 10px 15px 10px 10px;
    display: block;
    line-height: 1.2em;
}

.menu_bars {
    background: #FFFFFF;
    float: left;
    width: 100px;
    height: 74px;
    padding: 8px 0;
    transition: all ease 0.7s;
}

.menu_bars:hover {
    cursor: pointer;
    background: #34b78f;
    transition: all ease 0.7s;
}

.menu_bars span.menu_bar {
    display: block;
    width: 50px;
    height: 5px;
    background: #222222;
    padding: 0;
    margin: 10px auto;
    position: relative;
}

.menu_bars:hover span.menu_bar {
    background: #FFFFFF;
}

.menu_menu {
    display: block;
    color: #222222;
    font-weight: 500;
    text-align: center;
    position: relative;
    bottom: 5px;
}

.menu_bars:hover span.menu_menu {
    color: #FFFFFF;
}

.mi_bottom-right {
    -ms-transform: rotate(-90deg); /* IE 9 */
    -webkit-transform: rotate(-90deg); /* Safari */
    transform: rotate(-90deg);
    position: relative;
    top: 5px;
}

.in_house_list li {
    margin: 10px 0;
}

.in_house_list .phone {
    font-size: 2em;
    font-weight: 600;
}

#popupNav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    background: #FFFFFF;
    width: 100%;
    height: 100%;
    z-index: 1005;
    box-sizing: border-box;
    overflow: auto;
}

#popupNav a {
    color: #212121;
    text-decoration: none;
}

#popupNav {
    padding: 40px 0 40px 0;
}

#popupNav .fa {
    margin-right: 6px;
    position: relative;
    top: 1px;
}

#popupNav .nav_group {
    width: 50%;
    float: left;
    box-sizing: border-box;
    padding: 20px 80px;
}

#popupNav .nav_group h3 {
    color: #212121;
    padding: 0 20px 0 0;
    font-weight: 600;
    font-size: 30px;
    margin: 10px 0;
    font-family: sofia-pro, sans-serif;
}

#popupNav .nav_group h3 a {
    font-weight: 600;
    padding: 0;
}

.pn_close {
    position: absolute;
    box-sizing: border-box;
    width: 10%;
    text-align: center;
    top: 0px;
    right: 0;
    color: #FFFFFF;
    display: block;
    padding: 20px;
    transition: all ease 0.7s;
    background: #4f4f4f;
    font-family: sofia-pro, sans-serif;
}

.pn_close:hover {
    cursor: pointer;
    background: #512683;
    transition: all ease 0.7s;
}

.pn_nav {
    padding: 0;
    margin: 0;
    list-style-type: none;
}

.pn_nav ul {
    margin: 0;
    padding: 0;
    font-size: 16px;
    list-style-type: none;
}

.pn_nav > li {
    /*border-bottom:1px solid #4f4f4f;*/
}

.pn_nav > li a {
    position: relative;
}

.pn_nav > li a:before {
    content: '';
    position: absolute;
    display: block;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: -5px;
    width: 2px;
    height: 0;
    background: #fff;
    transition: all .4s ease;
}

.pn_nav > li a:hover:before {
    height: 80%;
}

.ng_2 .pn_nav > li a:hover:before {
    height: 0;
}

.ng_2 .pn_nav > li .material-icons {
    position: relative;
    top: 6px;
    margin-right: 5px;
    line-height: 8px;
}

.pn_nav > li a,
.pn_nav > li span {
    display: inline-block;
    padding: 10px 10px 10px 0;
    font-size: 15px;
    box-sizing: border-box;
    font-weight: 500;
    width: 100%;
}

.pn_nav > li.social {
    margin-top: 20px;
}

.ng_2 .pn_nav > li.social a {
    display: inline-block;
    width: auto;
    text-align: center;
    padding: 5px 10px;
    width: 35px;
    border: 1px solid #CCCCCC;
}

#popupNav .pn_nav > li.social a .fa {
    margin: 0;
}

#popupNav .pn_nav > li.social a.google-plus .fa {
    left: -3px;
}

#popupNav .pn_nav > li a:hover {
    background: #34b78f;
    color: #FFFFFF;
    transition: all ease 0.5s;
    padding: 10px
}

#popupNav .ng_2 .pn_nav > li.social a {
    padding: 5px 10px;
}

#popupNav .pn_nav > li a.s_title:hover {
    padding: 10px;
}

#popupNav .ng_2 .pn_nav > li a:hover {
    color: #FFFFFF;
}

#popupNav li.contact-us-title {
    margin: 20px 0 0 0;
}

.pn_nav > li span {
    color: #212121;
}

.ng_2 .pn_nav li a,
.pn_nav ul li a {
    padding: 10px 10px 10px 0px;
    box-sizing: border-box;
    border-bottom: 1px solid #DDDDDD;
}

#popupNav li.contact-us-title a {
    padding: 0px;
}

#popupNav li.contact-us-title a:hover,
#popupNav li.contact-us-title a:hover h3 {
    color: #FFFFFF;
    padding: 0 0 0 10px;
}

.contact_page .row_flex > div {
    color: #4f4f4f;
}

.contact_form input,
.contact_form select,
.contact_form textarea {
    border: none;
    border-bottom: 1px solid rgba(0, 143, 58, 0);
    padding: 10px 12px;
    display: block;
    background: #ffffff;
    font-size: 19px;
    margin: 1rem 0;
    outline: none;
    width: 90%;
    min-width: 320px;
    min-width: 200px;
    box-sizing: border-box;
    letter-spacing: 1px;
    color: #4f4f4f;
    transition: 0.7s;
    font-family: lato, sans-serif;
    border-radius: 5px;
    max-width: 640px;
}

.contact_form input:focus,
.contact_form textarea:focus {
    border-bottom-left-radius:0;
    border-bottom-right-radius:0;
    border-bottom: 1px solid rgba(0, 143, 58, 1);
    background: #ffffff;
}

.contact_form textarea {
    height: 140px;
}

.contact_form label {
    width: 140px;
    padding: 6px;
    font-size: 19px;
}

.contact_page .row_flex > div div {
    padding: 0;
}

.row_flex > div div.form_item {
    margin: 20px 0;
    display: flex;
    align-items: flex-start;
    padding: 0;
}

.contact_form_container h3 {
    margin: 0 0 0.4rem 0;
    max-width: 640px;
    color: #34b78f;
}

.contact_form_container .cf_note {
    margin-bottom:2rem;
}

.pn_nav .s_title {
    font-weight: 500;
    font-size: 17px;
    margin-top: 10px;
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
}

#popupNav .pn_nav li.pni_paediatric a:hover {
    background: #34b78f;
}

#popupNav .pn_nav li.pni_schools a:hover {
    background: #512683;
}

#popupNav .pn_nav li.pni_work a:hover {
    background: #285f81;
}

#popupNav .pn_nav li.pni_all a:hover {
    background: #eec007;
}

#nav .social {
    float: right;
    margin: 0 0 10px 10px;
}

.green-box,
.purple-box {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFF;
    padding: 1rem 2rem;
    margin: 2rem 0;
}

.green-box {
    background: #479667;
    background: var(--tlt-green);
}

.course-syllabus h3,
.green-box h3,
.purple-box h3,
.green-box h4,
.purple-box h4 {
    color: #FFF;
    margin: 1rem 0;
    font-weight: 500;
    width: 100%;
}

.purple-box h3 {
    margin: 0;
}

.course-syllabus ul {
    width: 80%;
}

.course-syllabus ul li {
    margin: 0.25rem 0;
}

.green-box strong {
    color: #fff;
}

.social a {
    color: #FFFFFF;
    margin: 0 20px 0 0;
    display: inline-block;
    padding: 3px 5px 0px 5px;
    width: 20px;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.2);
    transition: all ease 0.7s;
}

#popupNav .ng_2 .pn_nav > li.social a,
#popupNav .ng_2 .pn_nav > li.social a:hover {
    transition: background ease 0.7s;
    color: #FFFFFF;
}

#popupNav .ng_2 .pn_nav > li.social a:hover {
    opacity: 0.8;
    transition: all ease 0.7s;
}

.header-social-links a.twitter,
.header-social-links a.twitter:hover {
    background: #55ACEE !important;
    border-color: #55ACEE !important;
}

.header-social-links a.facebook,
.header-social-links a.facebook:hover {
    background: #3B5998 !important;
    border-color: #3B5998 !important;
}

.social a.linkedin,
.social a.linkedin:hover,
.social a.linked-in,
.social a.linked-in:hover {
    background: #0077B5 !important;
    border-color: #0077B5 !important;
}

.social a.google-plus,
.social a.google-plus:hover {
    background: #DC4E41 !important;
    border-color: #DC4E41 !important;
}


*/ nav {
    clear: both;
}

#hero {
    background-size: cover;
    position: relative;
    background-color: #ededed;
    height: 60vh;
    min-height: 480px;
    overflow: hidden;
    background-position: 50% 0;
    display: flex;
    align-items: center;
}

#hero::after {
    content:"";
    display:block;
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    background: rgb(0,0,0);
    background: -moz-linear-gradient(90deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 100%);
    background: -webkit-linear-gradient(90deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 100%);
    background: linear-gradient(90deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#000000",endColorstr="#000000",GradientType=1);
}

#hero img {
    display: block;
    width: 100%;
}

#hero.refresher h1 {
    max-width:480px;
}

.refreshers h3 {
    font-weight:600;
    color:#512683;
}

.refresher-page.refresher-type-header {
    margin:48px 0 24px 0;
    align-items:center;
}

.refresher-page.refresher-type-header h1 {
    margin:0;
}

.minh400 {
    min-height: 400px;
}


.hero {
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%;
    display: flex;
    align-items: flex-end;
    position: relative;
}

.hero-title {
    font-family: sofia-pro, sans-serif;
    color: #FFF;
    padding: 1rem 2rem;
    width: 100%;
    max-width: 1440px;
    text-align: center;
    font-size: 1.3rem;
    margin: 0 auto;
    position: relative;
    z-index: 6;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.5);
}

.hero-title p {
    line-height: 1.75rem;
}

.hero::after {
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.2);
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2;
}

.hero-title h1 {
    font-size: 2rem;
    font-weight: 600;
    color: #FFF;
}

.hero-links a {
    padding: 6px 20px 8px 20px;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 1rem;
    font-weight: 500;
    letter-spacing: 1px;
    background: #34b78f;
    color: #FFFFFF;
    transition: all ease 0.7s;
    outline: none;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
    border-radius: 25px;
}

.hero-intro {
    width: 40%;
    text-align: center;
    margin: 0 auto 2rem auto;
}

.hero-intro h1 {
    margin: 0 0 0.5rem 0;
}

.hero-intro p {
    margin: 0;
}

.notice-resp {
    display: none;
}

.notice-links {
    background: #3a1763;
    text-align: center;
    padding: 1rem 0;
}

.hero-links a:hover {
    background: #512683;
    background: var(--tlt-purple);
}

.hero_text_outer {
    position: absolute;
    width: 100%;
    bottom: 20%;
}

.hero_text_center {
    max-width: 1125px;
    position: relative;
    margin: 0 auto;
    width: 100%;
}

.hero_text_outer .hero_text_center .hero_text {
    margin: 0;
    position: relative;
    bottom: 0;
    left: 0;
    width: 80%;
    box-sizing: border-box;
}

.hero_text .controls {
    position: absolute;
    bottom: 0px;
    right: 0;
}

.hero_text a {
    color: #FFFFFF;
    line-height: 24px;
    padding: 10px 20px 12px 20px;
    background: #512683;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    text-align: center;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
}

.hero_text a.info_link {
    background: #285f81;
}

.hero_text a.info_link:hover {
    cursor: pointer;
}

.hero_text a .material-icons {
    position: relative;
    top: 5px;
}

.hero_text a:hover {
    text-decoration: none;
    transition: all ease 0.7s;
    background: #34b78f;
}

.hero_ol_link {
    position: fixed;
    left: 0;
    top: 0;
    margin-bottom: -40px;
    display: block;
    box-sizing: border-box;
    color: #FFFFFF;
    border: none;
    text-decoration: none;
    background: #009949;
    font-weight: 600;
    padding: 23px 80px 23px 20px;
    z-index: 10000;
    max-width: 320px;
    font-size: 1em;
}

.hero_ol_link:hover {
    transition: background ease 0.7s;
    background: #512683;
    color: #FFFFFF;
}

.hero_ol_link .fa {
    position: absolute;
    right: 0;
    top: 6px;
    font-size: 2.2em;
    padding: 23px 24px 20px 20px;
}

.hero_logo {
    width: 240px;
    padding-right: 40px;
}

.hero_logo img {
    display: block;
    width: 100%;
}

/*
    eLEarning Demo Ad styles
*/

.hero-msg {
    box-sizing: border-box;
    width: 100%;
    padding: 2rem 20%;
    background: #f7da0b;
    color: #512683;
    color: var(--tlt-purple);
}

.hero-msg strong {
    color: #512683;
    color: var(--tlt-purple);
}

.elearning-demo {
    display: flex;
    position: relative;
    align-items: flex-end;
    width: 100%;
    z-index: 1005;
}

.eld-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.4);
    z-index: 1;
}

.eld-smoke {
    background: url(/images/home-demo-smoke.svg);
    background-size: cover;
    background-position: 50% 0;
    position: relative;
    z-index: 3;
    width: 100%;
    color: #512683;
    color: var(--tlt-purple);
    padding: 4rem 2rem 2rem 2rem;
    text-align: center;
}

.eld-smoke img {
    display: block;
    width: 150px;
    margin: 1rem auto;
}

.eld-smoke h2 {
    color: #479667;
    font-size: 2rem;
    margin: 0.5rem 0;
}

.eld-smoke span {
    font-size: 1.8rem;
}

.eld-close {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    width: 50px;
    height: 50px;
    z-index: 3;
    cursor: pointer;
}

.eld-rocket {
    width: 170px;
    position: absolute;
    bottom: 238px;
    left: 50%;
    margin-left: -85px;
    z-index: 2;
}

.eld-rocket img {
    width: 100%;
    display: block;
}

/*
    EO eLEarning Demo Ad styles
*/
.cb_close {
    display: none;
}

.h_tile {
    float: left;
    width: 50%;
    box-sizing: border-box;
    height: 100%;
}

.h_tile img {
    display: block;
    width: 100%;
}

.ht_full,
.ht_half {
    position: relative;
    overflow: hidden;
    height: 100%;
    background-size: cover;
    background-position: 0 0;
}

.ht_half {
    height: 50%;
}

.ht_full:before,
.ht_half:before {
    content: "";
    display: block;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    background: rgba(0,0,0,0.1);
    background: -webkit-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.5)); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.5)); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.5)); /* For Firefox 3.6 to 15 */
    background: linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.5)); /* Standard syntax */
    transition: all ease 0.5s;
}

.ht_full:hover:before,
.ht_half:hover:before {
    opacity: 0.5;
    transition: all ease 0.5s;
}

.ht_full span,
.ht_half span {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    box-sizing: border-box;
    padding: 40px;
    color: #FFFFFF;
    z-index: 2;
    width: 100%;
}

.h_tile h1,
.h_tile h2 {
    color: #FFFFFF;
    font-size: 30px;
    margin-bottom: 15px;
    padding-left: 40px;
    font-weight: 500;
    font-family: sofia-pro, sans-serif;
    text-shadow: 0 0 5px rgba(0,0,0,0.5);
}

.h_tile h1:after,
.h_tile h2:after {
    content: "";
    display: block;
    margin: 10px 0;
    height: 2px;
    background: #FFFFFF;
    width: 100px;
}

.h_tile p {
    margin-bottom: 20px;
    display: block;
    width: 75%;
    text-shadow: 0 0 5px rgba(0,0,0,0.5);
}

.ht_content {
    width: 100%;
    overflow: hidden;
    box-sizing: border-box;
    padding: 0 0 0 40px;
}

.ht_full:hover .ht_content,
.ht_half:hover .ht_content {
}

.ht_full:hover h1,
.ht_half:hover h1,
.ht_full:hover h2,
.ht_half:hover h2 {
}

.book_now:hover {
    cursor: pointer;
}

#bookRow {
    clear: both;
}

#bookRow a {
    display: block;
    float: left;
    width: 50%;
    box-sizing: border-box;
    text-align: center;
    padding: 20px;
    background: #ededed;
    color: #222222;
    text-decoration: none;
    font-size: 1.3em;
}

#bookRow a.br_online {
    background: #FFFFFF;
    border-bottom: 1px solid #ededed;
}

#bookRow a.br_inhouse {
    background: #C1272D;
    color: #FFFFFF;
    border-bottom: 1px solid #C1272D;
}

#bookRow a.br_online:hover {
    color: #FFFFFF;
    background: #34b78f;
    border-bottom: 1px solid #34b78f;
}

#bookRow a.br_inhouse:hover {
    background: #ffcc01;
    border-bottom: 1px solid #ffcc01;
    transition: all ease 0.7s;
}

#bookBottom {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    padding: 0;
    box-sizing: border-box;
    color: #FFFFFF;
    font-weight: 500;
    z-index: 100;
    font-size: 1.2em;
    text-align: center;
    width: 100%;
}

#bookBottom.legal_active {
    background: #236e47;
}

#bookBottom a {
    box-sizing: border-box;
    padding: 10px 15px 10px 20px;
    display: block;
    text-decoration: none;
    color: #FFFFFF;
    background: #204c67;
    float: left;
    font-weight: 500;
}

#bookBottom .bb_social a {
    padding: 11px 18px 12px 18px;
}

#bookBottom .bb_social a.facebook {
    padding: 11px 21px 12px 21px;
}

#bookBottom a:hover {
    background: #512683;
    transition: all ease 0.7s;
}

#bookBottom a .material-icons {
    position: relative;
    top: 6px;
    margin-left: 5px;
}

#bookBottom .call_us a {
    padding: 0;
    background: transparent;
}

.call_us .material-icons {
    position: relative;
    top: 4px;
}

.reminder {
    float: left;
}

.reminder .material-icons {
    display: block;
    float: left;
    padding: 13px;
    background: #245674;
}

.reminder .material-icons.popped,
.reminder .material-icons:hover {
    background: #2a4759;
    cursor: pointer;
}

.ivcontainer {
    position: absolute;
    left: 50px;
    bottom: 0;
    width: 0;
    height: 0;
    box-sizing: border-box;
    padding: 10px 15px 10px 20px;
    background: #0f2837;
    z-index: 101;
    text-align: left;
    transition: 0.5s ease;
    transition-property: width, height;
}

.ivcontainer.open {
    width: 420px;
    min-height: 375px;
    height: auto;
}

.ivcontainer input {
    width: 100%;
    box-sizing: border-box;
    border: none;
    font-size: 0.8em;
    background: #FFFFFF;
    padding: 8px;
    font-family: lato, sans-serif;
    font-weight: 500;
}

.ivcontainer button {
    width: 100%;
    box-sizing: border-box;
    border: none;
    font-size: 0.8em;
    padding: 8px;
    font-family: lato, sans-serif;
    font-weight: 500;
    background: #2a4759;
    outline: none;
    color: #FFFFFF;
}

.ivcontainer button:hover {
    background: #34b78f;
    transition: all ease 0.7s;
    cursor: pointer;
}

.ivcontainer h3 {
    font-weight: 500;
    margin: 10px 0px;
}

.contact_page .row_flex > div .ef {
    background: #ff9800;
    color: #FFFFFF;
    font-size: 19px;
    padding: 10px;
    display: block;
    letter-spacing: 1px;
}

.contact_page .row_flex > div div.contact_details_container {
    padding: 20px;
    line-height: 30px;
    font-weight: 500;
    position: relative;
}

a.link-button.absolute,
a.link-button.absolute:visited {
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5rem 1rem;
    background: rgba(0,0,0,0.1);
    color: #FFFFFF;
    transition: 0.7s;
    text-decoration: none;
    width: 200px;
    text-align: center;
    margin: 0;
    font-weight: 300;
    font-size: 1rem;
}

a.link-button.absolute:hover {
    background: rgba(0,0,0,0.3);
    text-decoration: none;
}

.contact_page .row_flex > div div.contact_details_container .phone {
    margin-bottom: 30px;
}

.contact_page .row_flex > div div.contact_details_container .phone strong {
    font-size: 30px;
    letter-spacing: 2px;
    margin-left: 10px;
}

h3.thank_you {
    padding: 20px;
    display: block;
    background: #34b78f;
    color: #FFFFFF;
    margin-top: 40px;
    margin-bottom: 0;
}

.row_flex > div div.form_item.fi_captcha {
    margin: 20px 10px;
}


.remind-me-note {
    font-size: 0.8em;
}

.remind-me-form-item {
    display: block;
    margin: 0 0 5px 0;
}

#ui-datepicker-div {
    background: #34B78F;
    padding: 20px;
    z-index: 16000003 !important;
    border-radius: 8px;
}

.ui-datepicker-calendar {
    margin-top: 10px;
    background: rgba(0,0,0,0.1);
    padding: 5px 10px;
}

.ui-datepicker-calendar th {
    color: #FFFFFF;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    font-weight: 500;
    text-align: center;
}

.ui-datepicker-calendar td a {
    text-align: center;
    display: block;
    text-decoration: none;
    color: #FFFFFF;
    padding: 5px;
    background: rgba(255,255,255,0.1);
}

.ui-datepicker-calendar td a:hover {
    background: #7d55c7;
    transition: all ease 0.7s;
}

.ui-datepicker-prev {
    float: left;
}

.ui-datepicker-next {
    float: right;
}

.ui-datepicker-title {
    text-decoration: none;
    color: #FFFFFF;
    padding: 5px;
    margin: 0 5px;
    text-align: center;
}

.ui-datepicker-title select {
    border: none;
    background: #00843D;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
    outline:none;
}

.ui-datepicker-header a {
    text-decoration: none;
    color: #FFFFFF;
    padding: 5px 10px;
    font-size: 0.9em;
    background: rgba(255,255,255,0.1);
}

.ui-datepicker-header a:hover {
    cursor: pointer;
    text-decoration: none;
    background: #008842;
    transition: all ease 0.7s;
}

.error_flag {
    display: none;
    padding: 5px;
    background: #db1c2a;
    color: #FFFFFF;
    font-size: 0.8em;
}

.legal {
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
    font-size: 0.8em;
}

.legal a,
.legal span {
    padding: 15px 10px 14px 10px;
}

.legal span {
    padding-left: 15px;
}

#bookBottom .legal a {
    background: none;
    padding: 15px 10px 14px 10px;
    font-weight: 500;
}

#bookBottom .legal a:hover {
    background: #03391d;
}

#bookBottom:hover {
    z-index: 16000002;
}


.hero_scroll {
    position: absolute;
    bottom: 0;
    right: 0;
    text-decoration: none;
    text-align: center;
}

.hero_scroll img {
    padding-top: 10px;
}

.hero_scroll.hs_venue {
    padding: 10px 20px 12px 20px;
    background: #512683;
    color: #FFFFFF;
    font-size: 1.2em;
}

.hero_scroll.hs_venue .material-icons {
    position: relative;
    top: 6px;
}

.hero_scroll.hs_venue:hover {
    transition: all ease 0.7s;
    cursor: pointer;
    bottom: 0;
    background: #285f81;
}

/*

	Slider styles

*/
.slider_description {
    position: absolute;
    bottom: 20px;
    right: 20px;
    padding: 10px 20px;
    font-weight: 500;
    text-transform: uppercase;
    color: #000;
    border: 2px solid transparent;
    border-radius: 50px;
    cursor: pointer;
    z-index: 100;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.slider_description:hover {
    color: #FFF;
    border-color: #FFF;
}

#slideshow {
    position: relative;
    width: 100%;
    height: 100%;
}

#slideshow .frame {
    width: 100%;
    height: 100%;
    -webkit-perspective: 1000px;
    perspective: 1000px;
    -webkit-perspective-origin: 50% 50%;
    perspective-origin: 50% 50%;
}

#slideshow .frame .slide_element {
    height: 100%;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
}

#slideshow .frame .slide_element > div {
    float: left;
    height: 100%;
}

#slideshow .frame .mSCover img {
    max-width: none;
}

.mightyslider_modern_skin .mSButtons {
    height: 145px !important;
}

.mSCaption {
    text-align: center;
}

.mSCaption h2 {
    font-weight: 500;
    font-size: 1.8em;
    margin-bottom: 20px;
}

.mSCaption a {
    color: #ffffff;
    line-height: 24px;
    padding: 10px 20px 12px 20px;
    background: #512683;
    background: var(--tlt-purple);
    display: inline-block;
    border-radius: 3px;
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    bottom: 0;
    position: absolute;
    text-align: center;
    right: 0;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
}

.mSCaption a .material-icons {
    position: relative;
    top: 6px;
    margin-left: 5px;
}

.mSCaption a:hover {
    background: #34b78f;
    transition: all ease 0.7s;
    cursor: pointer;
}

.mSCaption.infoBlockFull h2 {
    max-width: 60%;
    margin: 0 auto;
}

.mSCaption.infoBlockLeft h2 {
    margin: 0;
    font-weight: 600;
    margin: 0 0 10px 0;
}

.mSCaption.infoBlockLeft span {
    font-size: 19px;
    font-weight: 500;
}

.mSCaption.infoBlockLeft span.normal {
    font-size: unset;
    font-weight: 500;
}

.mSCaption.infoBlockLeft span p {
    margin-top: 0;
    width: 80%;
}

.mSCaption.infoBlockLeft a {
    text-align: center;
}

.mSCaption.infoBlockLeft i.fa {
    text-align: center;
}

.page_down {
    position: absolute;
    bottom: 0;
    left: 50%;
    -ms-transform: translate(0,-50%); /* IE 9 */
    -webkit-transform: translate(0,-50%); /* Safari */
    transform: translate(0,-50%);
    display: block;
    font-size: 3em;
    transition: all ease 0.7s;
    color: #FFFFFF;
}

.page_down:hover {
    -ms-transform: translate(0,-10px); /* IE 9 */
    -webkit-transform: translate(0,-10px); /* Safari */
    transform: translate(0,-10px);
    transition: all ease 0.7s;
    cursor: pointer;
}

/* */
.row {
    clear: both;
    padding: 40px 0;
    background: #FFFFFF;
}

.umb-grid .row {
    padding: 10px 0;
}

.umb-grid .row h2 {
    margin: 10px 0;
}

.row.page_cb {
    padding-bottom: 0;
}

.row.stealth {
    background: unset;
}

.row.close_gaps {
    padding: 0;
    margin: 0;
}

.row.close_gaps h2 {
    margin: 0;
}

.row.save_a_life {
    background: #f7f7f7;
    padding: 40px 80px;
}

.left_sub_nav a:hover {
    cursor: pointer;
}

.row h3 {
    font-weight: 500;
    font-size: 36px;
}

.row h3 button {
    position: absolute;
    right: 5px;
    top: 7px;
}

.row h4 {
    font-weight: 500;
    font-size: 26px;
    margin-top: 0;
}

.row_center.related_courses {
    padding-top: 20px;
    margin-top: 40px;
}

.row_center h1 {
    text-align: center;
    position: relative;
    padding-bottom: 30px;
}

.nohero .review_item p {
    width: 100%;
}


.image_link_grid {
    display: flex;
    flex-wrap: wrap;
}

.image_link_grid a {
    text-decoration: none;
    display: block;
    width: 20%;
    border: none;
    padding: 20px;
    box-sizing: border-box;
}

.image_link_grid a img {
    display: block;
    width: 100%;
}

.book-in-house-form {
    width: 100%;
    box-sizing: border-box;
    border-radius: 20px;
    overflow: hidden;
}

.prf_item label,
.prf_item span {
    line-height: 26px;
    padding: 5px 0;
}

.prf_item .course-details span.light {
    font-weight: 500;
}

.book_course label {
    display: inline-block;
    width: 30%;
    font-weight: 600;
    padding: 5px 0;
}

.competition_form .book-in-house-form .thanks {
    text-align: center;
    padding: 40px;
}

.book-in-house-form span {
    display: block;
    background: #ededed;
    margin: 10px auto;
    width: 100%;
}

.prf_email input,
.prf_longerinput input {
    width: 40%;
    min-width: 190px;
}

.prf_item textarea {
    width: 40%;
    min-width: 190px;
    height: 120px;
}

.prf_item label {
    display: inline-block;
    width: 30%;
    font-weight: 500;
    padding: 5px 0;
    margin-right: 10px;
}

.book-in-house-form .prf_item label {
    font-family: sofia-pro, sans-serif;
}

.prf_item {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 5px 0;
}

.prf_group {
    border-top: 1px solid #FFFFFF;
    padding: 20px;
}

.flex_row.cb_row 

.book-in-house-form-container { 
    border-radius:15px;
    background:#dcddf3;
}

.page_cb .prf_group {
    border-top: rgba(255,255,255,0.1);
    background: none;
}

.course-details {
    font-weight: 900;
    font-size: 20px;
}

.book-in-house-form input,
.book-in-house-form select,
.book-in-house-form textarea {
    font-size: 17px;
    padding: 5px 10px;
    border: 2px solid transparent;
    font-family: sofia-pro, sans-serif;
    background: none;
    width: 60%;
    border-radius: 3px;
    transition: 0.7s;
    outline: none;
    background: #FFFFFF;
}

.book-in-house-form select option {
    background: rgba(0,0,0,0.1);
}

.book-in-house-form input:focus,
.book-in-house-form textarea:focus {
    border-color: #512683;
    border-color: var(--tlt-purple);
}

.contact_form input[type=submit],
.book-in-house-form input[type="submit"] {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    padding: 10px 20px;
    color: #FFFFFF;
    border: none;
    font-size: 19px;
    font-family: sofia-pro, sans-serif;
    width: 100%;
    border-radius: 3px;
}

.contact_form input[type=submit]:hover,
.book-in-house-form input[type="submit"]:hover {
    transition: all ease 0.7s;
    background: #34b78f;
    cursor: pointer;
}

.book-in-house-form textarea {
    height: 200px;
    color: #212121;
}

.book-in-house-form textarea::-webkit-input-placeholder,
.book-in-house-form input::-webkit-input-placeholder {
    color: #CCCCCC;
    font-style: italic;
    font-weight: 500;
}

.book-in-house-form textarea:-moz-placeholder,
.book-in-house-form input:-moz-placeholder { /* Firefox 18- */
    color: #CCCCCC;
    font-style: italic;
    font-weight: 500;
}

.book-in-house-form textarea::-moz-placeholder,
.book-in-house-form input::-moz-placeholder { /* Firefox 19+ */
    color: #CCCCCC;
    font-style: italic;
    font-weight: 500;
}

.book-in-house-form textarea:-ms-input-placeholder,
.book-in-house-form input:-ms-input-placeholder {
    color: #CCCCCC;
    font-style: italic;
    font-weight: 500;
}

.competition_form .book-in-house-form label {
    width: 30%;
    font-size: 20px;
    letter-spacing: 1px;
}

.competition_form .book-in-house-form input,
.competition_form .book-in-house-form select,
.competition_form .book-in-house-form textarea {
    font-size: 20px;
    letter-spacing: 1px;
}

.competition_form .book-in-house-form input[type="submit"] {
    transition: all ease 0.7s;
    background: #34b78f;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.competition_form .book-in-house-form input[type="submit"]:hover {
    width: 100%;
    background: #232323;
    color: #FFFFFF;
}

.competition_form,
.row_80 {
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
    padding: 40px 80px;
}

.booking_row {
    width: 100%;
    background: #285f81;
}

.booking_row .course_selector {
    display: block;
    width: 50%;
    float: left;
    text-align: center;
    color: #FFFFFF;
    box-sizing: border-box;
    padding: 10px;
    background: rgba(0,0,0,0.2);
    font-size: 2em;
}

.booking_row .course_selector:first-of-type {
    background: rgba(0,0,0,0.1);
}

.booking_row .course_selector:hover {
    cursor: pointer;
    background: #34b78f;
    transition: all ease 0.7s;
}

.course_container {
    display: none;
}

.row.course_content {
    position: relative;
    text-align: left;
    background: #34b78f;
    padding: 0;
}

.course_content:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    overflow: hidden;
}

.row.course_notes {
    width: 100%;
    padding: 2rem;
    background: #dcddf2;
    color: #512683;
    color: var(--tlt-purple);
    margin: 2rem 0 0 0;
    box-sizing: border-box;
    font-weight: 500;
    text-align: center;
}

.row_center h2 {
    color: #4f4f4f;
    font-size: 44px;
    font-weight: 600;
    text-align: center;
}


.course_content h2,
.course_content h4 {
    margin: 0 0 10px 0;
    color: #FFFFFF;
}

.course_content h2 {
    text-align: center;
    color: #FFFFFF;
    letter-spacing: 1px;
    margin: 0;
    padding: 30px 0;
    background: #0db55e;
}

.new_row_inner {
    max-width: 1280px;
    margin: 0 auto;
}

.top_row_flex {
    display: flex;
}

.left_sub_nav {
    width: 270px;
}

.flex_col {
    display: flex;
    flex-wrap: wrap;
}

.fc_with_nav {
    width: calc(100% - 270px);
}

.flex_col .col_1_2 {
    width: 50%;
    box-sizing: border-box;
    padding: 0 40px 40px 40px;
}

.tile,
.col_1_2 .tile {
    padding: 20px;
    background: #FFFFFF;
    border: 1px solid transparent;
}

.col_1_2 .tile p {
    width: 80%;
    margin: 0 auto;
}


.col_1_2 .tile .info_popup p {
    margin: 0 0 20px 0;
}


.row_flex {
    display: flex;
}

.row_flex > div {
    width: 30%;
    margin: 10px 0 10px 5%;
    display: flex;
    color: #FFFFFF;
}

.row_flex.comp > div {
    padding: 40px;
    box-sizing: border-box;
    display: block;
    margin: 0;
}

.row_flex.comp div h3 {
    font-size: 44px;
    width: 75%;
    letter-spacing: 2px;
    margin: 0 auto 30px auto;
    position: relative;
}

.row_flex.comp div a {
    display: inline-block;
    text-decoration: none;
    font-size: 20px;
    padding: 10px 0;
    margin: 10px auto;
    border-bottom: 3px solid #FFFFFF;
    box-sizing: border-box;
}

.row_flex.comp div a:hover {
    text-decoration: none;
    border-bottom: 3px solid #34b78f;
    transition: all ease 0.7s;
}

.row_flex > div.col_1_2 {
    width: 50%;
}

.row_flex > div.col_1_2.green_bloc {
    background: #34b78f;
    text-align: center;
    position: relative;
    padding: 80px;
}

.row_flex > div.col_1_2.green_bloc p {
    font-size: 24px;
}

.row_flex > div.col_1_2.green_bloc:after {
    content: "";
    position: absolute;
    top: 30px;
    left: 30px;
    height: calc(100% - 60px);
    width: calc(100% - 60px);
    display: block;
    box-sizing: border-box;
    border: 3px solid #FFFFFF;
}

.row_flex > div.col_1_2.green_bloc h3 {
    font-weight: 900;
}

.row_flex > div.col_1_2.green_bloc h3:after {
    content: "";
    position: relative;
    bottom: -10px;
    height: 4px;
    display: block;
    width: 75%;
    margin: 0 auto;
    background: #FFFFFF;
}

.row_flex > div.col_1_2.comp_courses {
    background-image: url(/media/1091/school-classroom.jpg);
    background-size: cover;
    background-position: 50%;
    position: relative;
    text-align: center;
    color: #FFFFFF;
}

.row_flex > div.col_1_2.comp_courses > * {
    position: relative;
    z-index: 2;
}

.row_flex > div.col_1_2.comp_courses:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.4);
    z-index: 0;
}

.save_a_life .row_flex {
    background: #FFFFFF;
    padding: 0 20px;
}

.save_a_life .row_flex > div {
    color: #212121;
}

.save_a_life .row_flex > div.col_1_2 {
    width: 50%;
    box-sizing: border-box;
    padding: 0;
    display: block;
}

.save_a_life .row_flex > div.col_1_2 img {
    display: inline-block;
    width: 180px;
    margin-top: 20px;
}

.left_sub_nav ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
}

.left_sub_nav ul li {
    margin-bottom: 2px;
}

.left_sub_nav ul li a {
    text-decoration: none;
    padding: 20px;
    border: 1px solid rgba(0,0,0,0.2);
    box-sizing: border-box;
    display: block;
}

.sal_image {
    width: 100%;
}

.sal_image img {
    width: 100%;
    display: block;
    margin: 20px auto;
}

.tile h3,
.save_a_life .col_1_2 h3 {
    display: block;
    padding: 20px;
    background: #512683;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
    box-sizing: border-box;
    margin: 0 0 20px 0;
    font-weight: 500;
    font-size: 26px;
}

.green_down_triangle {
    display: block;
    width: 0;
    margin: 20px auto;
    height: 0;
    border-style: solid;
    border-width: 30px 30px 0 30px;
    border-color: #34b78f transparent transparent transparent;
}

.info_popup {
    position: fixed;
    width: 95%;
    left: 0;
    top: 0;
    height: 100%;
    margin: 0 2.5%;
    background: rgba(255,255,255,1);
    z-index: 1001;
    box-shadow: 0 0 1px 52px rgba(0,0,0,0.7);
    box-sizing: border-box;
    padding: 40px;
    display: none;
    overflow: auto;
}

.info_popup .close_detail {
    position: absolute;
    top: 20px;
    right: 20px;
    font-weight: 600;
    font-style: normal;
    padding: 10px 15px;
    font-size: 1rem;
    z-index: 10;
}

.info_popup .close_detail:hover {
    transition: all ease 0.7s;
    background: #512683;
    color: #FFFFFF;
    cursor: pointer;
}

.row_center.save_a_life a.link_button,
.info_link_button {
    display: block;
    padding: 10px;
    background: #34b78f;
    color: #FFFFFF;
    text-align: center;
    font-weight: 600;
    margin: 30px auto 10px auto;
    width: 50%;
    border: none;
}

.row_center.save_a_life a.link_button:hover,
.info_link_button:hover {
    transition: all ease 0.7s;
    background: #512683;
    color: #FFFFFF;
    cursor: pointer;
}

.row_center .info_popup h2 {
    text-align: left;
}

.course_dates_table {
    width: 100%;
    border-collapse: collapse;
    border: none;
}

.course_dates_table th,
.course_dates_table td {
    padding: 10px;
    text-align: left;
    background: #f7f7f7;
}

.course_dates_table th {
    background: #512683;
    color: #FFFFFF;
}

.course_dates_table tr:nth-of-type(2n) td {
    background: #ffffff;
}

#homeAccreditations .row_flex > div.col_1_2 {
    width: 50%;
    display: block;
}

.review_stars {
    width: 300px;
    margin: 0 auto;
    text-align: center;
}

.accreditation-content img {
    display: block;
    width: 45%;
    margin: 1rem auto;
}

.review_stars i {
    width: 24px;
    margin: 0 13px;
    font-size: 40px;
}

.row_flex.rf_reviews > div {
    display: block;
    text-align: center;
}

.img_caption_below {
    display: block;
    color: #CCCCCC;
    width: 100%;
}

#home-testimonials-list a.internal_link {
    display: block;
    margin: 40px auto 10px auto;
    background: #eec007;
    color: #FFFFFF;
    padding: 10px;
    width: 260px;
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
    font-weight: 500;
    font-size: 15px;
    box-sizing: border-box;
}

#home-testimonials-list a.internal_link:hover {
    transition: background ease 0.7s;
    background: #512683;
}

#homeAccreditations img {
    display: block;
    margin: 0 auto;
    width: 100%;
    max-width: 220px;
    max-height: 80px;
}

#homeAccreditations img.img-svg {
    display: block;
    height: 120px;
    margin: 0 auto;
    width: 100%;
}

#homeAccreditations .cpd_logo {
    text-align: center;
}

.row_flex > div:first-of-type {
    margin-left: 0;
}

.row_flex > div a,
.row_flex > div a:hover {
    color: #FFFFFF;
    text-decoration: none;
    border: none;
}

.row_flex > div a:hover {
    text-decoration: underline;
}

.rf_mail:hover {
    transition: all ease 0.7s;
    background: #990b32;
    cursor: pointer;
}

.rf_mail:hover a {
    color: #FFFFFF;
}

.rf_phone .rf_text,
.rf_chat .rf_text {
    font-size: 26px;
    font-family: sofia-pro, sans-serif;
}

.save_a_life.nohero p {
    width: 90%;
}

.save_a_life .rf_text {
    font-size: 20px;
    margin-left: 40px;
}

.save_a_life .rf_icon {
    background: #512683;
    color: #FFFFFF;
}

.row_center.save_a_life .rf_text a {
    border: none;
    color: #512683;
    text-decoration: underline;
}

.row_center.save_a_life .rf_text a:hover {
    transition: all ease 0.7s;
    color: #212121;
}

.rf_phone div.rf_icon i {
    position: relative;
    top: 5px;
}

.rf_address div.address_text {
    font-family: sofia-pro, sans-serif;
    line-height: 26px;
    padding: 0;
    font-size: 20px;
}

.rf_address {
    display: flex;
    background: #ededed;
}

.rf_address div {
    padding: 20px;
}

.rf_address div.rf_text {
    padding: 20px 40px;
}

.cf_note {
    display: block;
    font-style: italic;
    line-height: 1.3rem;
    color: #999999;
}

.row_flex > div div {
    padding: 20px;
}

#homeAccreditations .row_flex > div {
    padding: 20px 60px;
}

.row_flex > div.rf_mail div {
    padding: 24px 20px 16px 20px;
}

.row_flex > div div.icon {
    background: rgba(0,0,0,0.2);
}

.rf_phone {
    background: #285f81;
}

.rf_mail {
    background: #512683;
}

.rf_chat {
    background: #34b78f;
}

.rf_icon {
    background: rgba(0,0,0,0.2);
    color: #FFFFFF;
}

ul#reviewList {
    margin: 0;
    padding: 0;
    list-style-type: none;
}

ul#reviewList li {
    width: 70%;
    margin: 0 auto;
    font-size: 1.2em;
}

ul#reviewList li p {
    font-weight: 500;
    margin: 10px 0 20px 0;
}

.review_name {
    font-weight: 600;
}

#home-testimonials-list {
    color: #212121;
}

.review_hover {
    text-decoration: none;
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    background: #eec007;
    color: #FFFFFF;
    left: -100%;
    z-index: 10;
    bottom: 0;
    transition: right 300ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
}

.row_reviews:hover .review_hover {
    left: 0px;
    transition: left 300ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
}

.review_stars {
    display: block;
}

.review_stars i {
    display: inline-block;
}

.row_top {
    padding-top: 0;
}

.row_top h1 {
    text-align: left;
    width: 100%;
    margin: 40px auto 40px auto;
    position: relative;
}

.row_top.nohero h1 {
    padding-bottom: 40px;
}

.row_top.text_page h1 {
    padding-bottom: 40px;
}

.row_top.text_page h1:after {
    content: "";
    display: block;
    width: 25%;
    box-sizing: border-box;
    height: 4px;
    margin-top: 20px;
    background: #009949;
    position: absolute;
    left: 0;
    bottom: 0;
}

.row p:first-of-type {
    margin-top: 0;
}

.row_top p {
    line-height: 26px;
}

.row_course_intro h1 {
    text-align: left;
    display: block;
    box-sizing: border-box;
}

.row_course_intro h1:after {
    content: "";
    display: block;
    width: 25%;
    box-sizing: border-box;
    height: 4px;
    margin-top: 20px;
    background: #009949;
}

.text_page p {
    width: 90%;
}

.course_page_intro {
    width: 50%;
    padding: 0 40px;
}

.course_page_intro h3 {
    margin-top: 0;
    font-weight: 600;
    color: #34b78f;
}

.page_intro_right {
    padding: 40px;
}

.page_intro_right .cost {
    display: flex;
    align-items: center;
    margin-top: 20px;
    padding: 10px;
}

.page_intro_right .product {
    margin-bottom: 10px;
    background: #EDEDED;
}

.page_intro_right .price {
    font-size: 50px;
}

.page_intro_right .price_note {
    font-size: 12px;
    padding: 10px;
    max-width: 120px;
}

.page_intro {
    background: #ededed;
    margin-bottom: 0;
    padding: 40px;
}

.venue_info,
.text_page {
    padding-top: 20px;
}

.share_block {
}

.pir_content {
}

.pir_content h3 {
    margin-top: 0;
    margin-bottom: 20px;
}

.pir_content p {
    margin-top: 30px;
}

.pir_content ul {
    margin: 10px 0 0 50px;
    padding: 0;
}

.page_intro h3 {
    line-height: 1.4em;
    font-size: 2em;
}

.course_intro_links {
    text-align: right;
}

a.book_link,
.row_top a.book_link,
.row_top a.git_link,
a.download_link {
    color: #FFFFFF;
    padding: 9px 20px;
    background: #34b78f;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    box-sizing: border-box;
    letter-spacing: 1px;
    font-family: sofia-pro, sans-serif;
}

a.download_link {
    background: #479667;
    background: var(--tlt-green);
    margin-top: 20px;
}

.red_link_box {
    color: #FFFFFF;
    padding: 12px 20px 10px 20px;
    background: transparent;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    border: 2px solid #512683;
    background: #512683;
    font-family: sofia-pro, sans-serif;
}

.grey_link_box,
.row_top a.contents_link {
    color: #FFFFFF;
    padding: 9px 20px 9px 20px;
    background: #F45D78;
    display: inline-block;
    border-radius: 0;
    border: none;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    font-family: sofia-pro, sans-serif;
}

.red_link_box .material-icons,
.grey_link_box .material-icons {
    position: relative;
    top: 8px;
    margin-left: 5px;
}

.red_link_box,
.grey_link_box {
    padding-top: 6px;
}

.course_highlights {
    display: flex;
    flex-wrap: wrap;
}

.course_highlights div {
    width: 50%;
    box-sizing: border-box;
    padding: 20px 80px;
    text-align: center;
}

.course_highlights h3 .material-icons {
    font-size: 80px;
    color: #eec007;
}

.link-box,
.grey_link_box,
.red_link_box {
    color: #ffffff;
    padding: 0.5rem 1rem;
    background: #479667;
    font-weight: 500;
    letter-spacing: 1px;
    font-size: 1rem;
    text-decoration: none;
    transition: all ease 0.7s;
    border: none;
    font-family: sofia-pro, sans-serif;
    width: 100%;
    text-align: center;
    box-sizing: border-box;
    display: block;
    margin: 0 0 1rem 0;
    line-height: 1.5rem;
    border-radius: 20px;
}

.course_highlights p {
    letter-spacing: 1px;
}

.cei_cost b {
    font-size: 60px;
    font-weight: 500;
    display: block;
    margin-left: 10px;
}

.link-box:hover,
.red_link_box:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    transition: 0.7s;
    text-decoration: none;
}

a.download_link:hover,
.grey_link_box:hover,
.row_top a.contents_link:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    transition: all ease 0.7s;
}

.page_intro h2 {
    margin-top: 0;
}

.page_intro p {
    width: 100%;
    text-align: center;
    margin: 20px auto;
    max-width: 1280px;
    line-height: 26px;
}

#homeIntro.page_intro p.impact {
    text-align: left;
    width: 100%;
    line-height: 60px;
}

#homeIntro.page_intro p:first-of-type {
    margin-top: 20px;
}

.course_download {
    display: block;
    width: 100%;
    background: #512683;
    color: #FFFFFF;
    padding: 40px;
    text-decoration: none;
    position: relative;
    transition: all ease 0.7s;
}

.course_download:hover {
    background: #512683;
    transition: all ease 0.7s;
}

.download_group {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.download_item {
    width: 24%;
    display: block;
    box-sizing: border-box;
    border: none !important;
    position: relative;
    transition: all ease 0.7s;
    margin: 0 0 1rem 0;
    text-decoration: none;
}

.download_item img {
    display: block;
    width: 100%;
}

.download_item span {
    display: block;
    box-sizing: border-box;
    padding: 20px;
    text-align: center;
    text-decoration: none;
    color: #FFFFFF;
    background: #512683;
    font-size: 1em;
    margin-top: 0.5rem;
}

.download_item:hover span {
    transition: all ease 0.7s;
    background: #009949;
}

.download_item:hover img {
    transition: all ease 0.7s;
    opacity: 0.8;
}

.download_item:hover:after {
    transition: all ease 0.7s;
    opacity: 1;
    top: 55%;
}

.white_link_box {
    color: #FFFFFF;
    padding: 3px 17px 9px 20px;
    background: none;
    display: inline-block;
    border-radius: 0;
    font-size: 1em;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    border: 2px solid #FFFFFF;
}

.white_link_box:hover {
    text-decoration: none;
    transition: all ease 0.7s;
    background: #FFFFFF;
    color: #212121;
    border: 2px solid #FFFFFF;
}

.white_link_box .material-icons {
    top: 7px;
    position: relative;
}

.course_download h3 {
    margin: 0 0 15px 0;
}

.course_download p {
    padding-right: 40px;
}

.row div {
    box-sizing: border-box;
}

.row_course_features {
    padding: 0;
}

#courseFeatures {
    width: 100%;
    background: #ededed;
    padding: 0;
    margin: 40px 0 0 0;
}

#courseFeatures > div {
    position: relative;
}

.cf_inner {
    margin: 20px 20px 20px 0;
    background: #FFFFFF;
    padding: 20px 40px;
    width: calc(67% - 20px);
    box-sizing: border-box;
}

blockquote p:before {
    content: '';
    background: url('') no-repeat;
    background-size: 15px;
    width: 25px;
    height: 15px;
    display: inline-block;
    margin-left: -25px;
}

.feature_testimonial {
    padding: 40px;
    background: #285f81;
    color: #FFFFFF;
    text-align: center;
    position: relative;
}

.feature_testimonial blockquote {
    font-size: 1.2em;
}

.feature_testimonial .material-icons.mi-chat {
    position: absolute;
    left: 20px;
    top: 20px;
    font-size: 3em;
}

.quote_by {
    font-weight: 600;
}

.feature_testimonial span.rating {
    margin: 10px auto;
    display: block;
}

.col_3_5 {
    width: 60%;
    float: left;
}

.col_2_5 {
    width: 40%;
    float: left;
}

.cf_paed {
}

.dark_overlay {
    color: #FFFFFF;
}

.medium_overlay:before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0,0,0,0.2);
    transition: background-color 0.25s;
    height: 100%;
}

.dark_overlay:before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0,0,0,0.5);
    transition: background-color 0.25s;
    height: 100%;
}

.col_1_3 {
    width: 33%;
    margin: 0;
    padding: 20px;
    box-sizing: border-box;
}

.col_2_3 {
    width: 67%;
    box-sizing: border-box;
    padding: 20px;
}

.col_1_4 {
    width: 25%;
    box-sizing: border-box;
}

.col_3_4 {
    width: 75%;
    box-sizing: border-box;
}

.text-page .col_3_4 {
    padding: 0 2rem 0 0;
}

.text-page.tp-terms {
    width:100%;
}

.text-page.tp-terms p {
    width:90%;
}

.col_flex {
    display: flex;
}

body.app #hero,
body.app .text-page h1 {
    display:none;
}

.col_flex .col_2_3,
.col_flex .col_1_3 {
    float: none;
}

.page_intro .col_3_4.intro_twocol p {
    text-align: left;
}

.page_intro .col_3_4.intro_twocol p:first-of-type {
    margin-top: 0;
}

.review_row .col_1_2 {
    box-sizing: border-box;
    padding: 0 40px;
    text-align: center;
}

.fb_reviews .fb_iframe_widget {
    margin: 20px;
}

.fb_reviews .fb_iframe_widget:first-of-type {
    margin-top: 0;
}

a.fb_review_link {
    padding: 15px;
    color: #FFFFFF;
    background: #285f81;
    display: block;
    font-size: 18px;
    border: none;
    width: 468px;
    margin: 20px auto;
}

a.fb_review_link:hover {
    transition: all ease 0.7s;
    text-decoration: none;
    background: #204c67;
    color: #FFFFFF;
    border: none;
}

.col_1_4.intro_twocol {
    text-align: center
}

.col_1_4.intro_twocol img {
    display: block;
    width: 100%;
    margin-top: 40px;
}

.col_1_4.intro_twocol a,
.col_1_4.intro_twocol a:hover {
    text-decoration: none;
    border: none;
}

a.anchor {
    display: none;
}

.course_content_container > div.col_1_1,
.col_1_1 {
    width: 75%;
}

.course_content_container .col_1_3 {
    width: 33.333%;
    padding: 0 80px;
    box-sizing: border-box;
    margin: 0;
}

.course_content_container .col_2_3 {
    width: 66.667%;
    padding: 0 80px;
    box-sizing: border-box;
    margin: 0;
}

.course_content_container .stage {
    font-size: 22px;
    font-weight: 500;
    display: block;
    margin-bottom: 10px;
}

.save_a_life .col_1_1 {
    width: 100%;
    float: none;
    padding: 0 40px;
}

.col_1_2 {
    width: 50%;
    box-sizing: border-box;
}

.flex_row {
    display: flex;
    flex-wrap: wrap;
}

.flex_row .col_1_2 {
    width: 50%;
    float: none;
}

.brochure_download {
    clear: both;
}

.brochure_download a {
    display: inline-block;
    padding: 5px 15px 12px 20px;
    background: #34b78f;
    color: #FFFFFF;
    font-weight: 500;
    text-decoration: none;
    border: none;
    margin-left: 22px;
    font-family: sofia-pro, sans-serif;
}

.brochure_download a:hover {
    transition: all ease 0.25s;
    background: #512683;
    color: #FFFFFF;
    border: none;
}

.brochure_download a .material-icons {
    position: relative;
    transition: all ease 0.25s;
    top: 8px;
    margin-left: 5px;
}

.brochure_download a:hover .material-icons {
    transition: all ease 0.7s;
    top: 10px;
}

.course_content .col_1_1,
.course_content .col_1_2,
.course_content .col_1_3 {
    color: #FFFFFF;
    box-sizing: border-box;
    padding: 40px 80px;
}

.course_content .col_1_2:nth-of-type(2) {
    background: rgba(0,0,0,0.05);
}

.grey_bg {
    background: #ededed;
}

.row_courses {
    margin: 0;
    padding: 0;
}

.row_courses a {
    position: relative;
    display: block;
    width: 25%;
    float: left;
    height: 200px;
    transition: all ease 0.7s;
    box-sizing: border-box;
    text-align: center;
    text-decoration: none;
    color: #4f4f4f;
    overflow: hidden;
}

.row_courses a:before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0,0,0,0.2);
    transition: background-color 0.25s;
}

.row_courses a:hover {
}

.row_courses a:hover:before {
    background-color: rgba(0,0,0,0.6);
    transition: all ease 0.7s;
}

.row_courses a img {
    display: block;
    width: 100%;
}

.row_courses a span {
    position: absolute;
    left: 50%;
    width: 80%;
    top: 50%;
    -webkit-transform: translate(-50%, -30%);
    -ms-transform: translate(-50%, -30%);
    transform: translate(-50%, -30%);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 1px;
    color: #FFFFFF;
    transition: all ease 0.7s;
    font-family: sofia-pro, sans-serif;
}


.small_print {
    box-sizing: border-box;
    background: #f2f2f2;
    border: 1px solid #ededed;
    padding: 20px 40px;
    font-size: 17px;
}

.small_print p {
    font-size: 15px;
    line-height: 150%;
}

/* Audience selector styles */

.row_audience {
    margin: 0;
    padding: 0;
    text-align: center;
    display: table;
    width: 100%;
}

.row_audience div {
    position: relative;
    display: table-cell;
    float: left;
    margin: 0;
    transition: all ease 0.7s;
    box-sizing: border-box;
    text-align: left;
    text-decoration: none;
    color: #4f4f4f;
    overflow: hidden;
    background-color: rgba(242,241,242,0.5);
    min-height: 480px;
    background-size: cover;
}

.row_audience div.ca_individual {
    width: 40%;
    background-image: url(/images/course-paediatric.jpg);
}

.row_audience div.ca_inhouse {
    width: 60%;
    background-image: url(/images/course-early-years.jpg);
}

.row_audience div:before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(0,0,0,0.2);
    transition: background-color 0.25s;
    height: 100%;
}

.row_audience div.ca_inhouse:before {
    background-color: rgba(0,0,0,0.5);
}

.row_audience div.ca_individual:before {
    background-color: rgba(0,0,0,0.4);
}

.row_audience div:hover:before {
    background-color: rgba(0,0,0,0.8);
    transition: all ease 0.7s;
}

.row_audience div img {
    display: block;
    width: 100%;
}

.row_audience div span {
    position: absolute;
    left: 50%;
    width: 70%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-size: 2em;
    font-weight: 500;
    color: #FFFFFF;
}

.row_audience div:hover {
    text-decoration: none;
    cursor: pointer;
    color: #FFFFFF;
    transition: all ease 0.7s;
}

.row_audience div span img {
    display: block;
    width: 35%;
    margin: 0 auto 40px auto;
    fill: white;
}

.row_audience div span {
    display: block;
    width: 85%;
    margin: auto;
    font-size: 1em;
    font-weight: 500;
}

.row_audience div span h4 {
    font-size: 3em;
    font-weight: 500;
    line-height: 1em;
    margin-bottom: 20px;
    letter-spacing: -2px;
}

.row_audience div a {
    display: inline-block;
    position: relative;
    z-index: 1;
    margin-top: 30px;
}

.row_audience div a.git_link,
.row_audience div a.book_link {
    clear: left;
}

.row_courses #courseList a {
    display: inline-block;
    float: none;
    transition: all ease 0.7s;
}


#courseList {
    text-align: center;
}

ol {
    width: 76%;
}

ol li {
    margin: 1em 0;
}

.tp-terms ol {
    width: 95%;
}

.tp-terms p {
    font-size: 1rem;
    font-weight: normal;
}

.tp-terms ol > li {
    margin: 2rem 0;
    font-weight: 600;
}

.tp-terms ol > li > ol li {
    margin: 1rem 0;
    font-weight: 500;
}

#courseList h2 {
    text-align: center;
    color: #4f4f4f;
    font-size: 2.5em;
    width: 84%;
    font-weight: 500;
    margin: 0 auto 20px auto;
}

#courseList.related h2 {
    margin: 40px auto;
}

a.logo_home_link {
    display: block;
    max-width: 300px;
    margin-left: 80px;
}

a.logo_home_link img {
    display: block;
    width: 100%;
}

.row_courses #courseList a em.course_more {
    display: block;
    font-style: normal;
    font-weight: 500;
    font-size: 0.6em;
    padding: 3px;
    border: 1px solid #FFFFFF;
    width: 140px;
    margin: 16px auto 0 auto;
    opacity: 0;
}

.row_courses #courseList a:hover em.course_more {
    opacity: 1;
    transition: ease-in-out 0.7s;
}

/* Course detail */

.header_center {
    text-align: center;
    margin-top: 0;
}

.massive_half {
    float: left;
    width: 50%;
    box-sizing: border-box;
    transition: all ease 1s;
}

.massive_half.mh_right {
    float: right;
}

.landscape_qtr {
    float: left;
    width: 25%;
    box-sizing: border-box;
    background: #ededed;
    position: relative;
    transition: all ease 1s;
    overflow: hidden;
}

.landscape_qtr img,
.landscape_half img,
.massive_half img {
    display: block;
    width: 100%;
}

.landscape_half {
    float: left;
    width: 50%;
    box-sizing: border-box;
    background: #ededed;
    position: relative;
    transition: all ease 1s;
}

.is_red {
    background: #C1272D;
    color: #FFFFFF;
}

.is_green {
    background: #34b78f;
    color: #FFFFFF;
}

.is_yellow {
    background: #eec007;
    color: #FFFFFF;
}

.is_navy {
    background: #140558;
    color: #FFFFFF;
}

.is_white {
    background: #FFFFFF;
}

.go_west {
    clear: left;
}

.course_text span {
    padding: 5px 40px 5px 10px;
    display: block;
    box-sizing: border-box;
    height: 100%;
    position: relative;
    z-index: 10;
}

.course_text h2:before {
    content: "";
    width: 40px;
    height: 2px;
    background: #C1272D;
}

.course_text h2 {
    font-size: 44px;
    margin: 0;
    font-weight: 600;
    letter-spacing: 1px;
}

.course_image {
    text-align: center;
    position: relative;
    padding-bottom: 60px;
}

.course_image img {
    box-shadow: 40px 40px 0 10px #512683;
    display: block;
    margin: 0 auto;
    width: 75%;
}

.course_content_note {
    color: #FFFFFF;
    display: block;
    font-size: 19px;
    width: 100%;
    text-align: center;
    padding: 20px 80px;
    margin-bottom: 0;
}

.col_1_1 + .course_content_note {
    padding-top: 40px;
}

.row_centrealign {
    text-align: center;
}

.course_content ul {
    margin: 0;
    padding: 0;
}

.course_content li {
    padding: 5px 10px;
    font-size: 16px;
    font-weight: 500;
    color: #FFFFFF;
    list-style-type: none;
    position: relative;
    padding-left: 40px;
}

.course_content li:before {
    font-family: 'Material Icons';
    content: "add_circle";
    position: absolute;
    display: block;
    color: #FFFFFF;
    font-size: 22px;
    left: 0;
    font-weight: normal;
}

.course_content_container {
    display: flex;
    flex-wrap: wrap;
}

.course_content_container .flex_row {
    padding: 40px 0;
}

.course_content_container .flex_row:nth-of-type(2) {
    background: #0db55e;
}

.course_content_container p {
    line-height: 26px;
    letter-spacing: 1px;
}

.course_content_container h4 {
    font-size: 30px;
    letter-spacing: 1px;
}

.course_content_container h5 {
    margin-top: 20px;
    color: #FFFFFF;
}

.course_content_container > div {
    box-sizing: border-box;
}

.course_content .col_1_3 {
    margin-bottom: 20px;
}

#courseExtraInfo {
    display: flex; /* equal height of the children */
    background: #ededed;
}

#courseExtraInfo > div {
    float: left;
    width: 25%;
    box-sizing: border-box;
    padding: 20px 40px;
    text-align: center;
    position: relative;
}

#courseExtraInfo > div:before {
    content: "";
    display: block;
    height: 80%;
    margin: 10% 0;
    width: 4px;
    background: #DDDDDD;
    position: absolute;
    bottom: 0;
    left: 0;
}

#courseExtraInfo > div:first-of-type:before {
    display: none;
}

#courseExtraInfo > div h4 {
    margin: 20px 0;
}

#courseExtraInfo > div img {
    display: block;
    width: 35%;
    margin: 10px auto 20px auto;
}

#courseExtraInfo p {
    font-size: 14px;
}

.course_cost_value {
    font-size: 26px;
    font-weight: 600;
}

#courseOptions {
    background: #223135;
    text-align: center;
}

#courseOptions h2,
#courseOptions h4 {
    font-size: 36px;
    text-align: center;
    color: #FFFFFF;
}

#courseOptions p {
    text-align: center;
    width: 60%;
    margin: 20px auto;
    font-size: 19px;
    font-weight: 500;
    letter-spacing: 1px;
    color: #FFFFFF;
}

.content_note {
    clear: left;
    padding: 10px 40px;
    background: #EDEDED;
    font-weight: 500;
    font-size: 1.2em;
    text-align: center;
    width: 96.5%;
    margin: 20px auto 0 auto;
}

.course_audience a.book_link,
.course_audience a.git_link,
.row_center a.book_link,
.row_center a.git_link {
    color: #FFFFFF;
    padding: 12px 20px 10px 20px;
    background: #512683;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    margin-right: 20px;
    border: none;
    font-family: sofia-pro, sans-serif;
}

a.contents_link,
.course_audience a.contents_link,
.row_center a.contents_link {
    color: #FFFFFF;
    padding: 9px 20px 9px 20px;
    background: none;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    border: 1px solid #FFFFFF;
    font-family: sofia-pro, sans-serif;
}

a.book_link:hover,
.course_audience a.git_link:hover,
.course_audience a.book_link:hover,
.row_center a.git_link:hover,
.row_center a.book_link:hover {
    text-decoration: none;
    transition: all ease 0.7s;
    background: #512683;
    border-color: #512683;
}

.course_audience .contents_link:hover,
.contents_link:hover {
    text-decoration: none;
    transition: all ease 0.7s;
    background: #34b78f;
    color: #FFFFFF;
    border: 1px solid #34b78f;
}

.h_tile .contents_link:hover {
    background: #34b78f;
    border-color: #34b78f;
}

.ht_content p {
    margin-top: 0;
}

.company-number {
    margin: 1rem 0;
}

.policies p {
    width:75%;
}

.footer_accred {
    display: flex;
    align-items: center;
}

.footer_accred a,
.footer_accred div {
    width: 50%;
    box-sizing: border-box;
    padding: 10px;
}

.faib,
.faib:hover {
    text-decoration: none;
    color: #FFFFFF;
    display: block;
}

.faib img {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 10px 10px 10px 0;
    margin-top: 5px;
}

.faib span {
    color: #FFFFFF;
    float: left;
    display: block;
    box-sizing: border-box;
    padding: 10px 0 10px 10px;
    font-size: 10px;
    width: 100%;
}

.approved img {
    width: 100%;
}

.share_block {
    display: flex;
    border-radius: 0;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid #ededed;
}

.share_text {
    margin-right: 1rem;
    position: relative;
    color: #4f4f4f;
    font-weight: 500;
    font-size: 1rem;
    font-family: sofia-pro, sans-serif;
}

.share_block .at-share-tbx-element .at-share-btn {
    margin: 0 5px 0 0;
}

/* PACEY Page */

.page_pacey h1 {
    color: #E90564;
    display: block;
    float: left;
    width: 70%;
    text-align: left;
}

.pacey_img {
    display: block;
    float: right;
    margin: 45px 20px 20px 40px;
    width: 210px;
}

.verify_membership_instructions {
    clear: both;
    color: #4f4f4f;
    font-size: 1em;
    padding: 20px;
    background: #EDEDED;
    margin: 20px 0;
}

.page_pacey input {
    font-family: lato, sans-serif;
    background: #FFFFFF;
    padding: 1%;
    color: #E90564;
    width: 39%;
    font-size: 1.2em;
    display: block;
    border-radius: 2px;
    border: 1px solid #DDDDDD;
    float: left;
    margin-right: 1%;
}

.page_pacey input.pacey_membership_name {
    width: 19%;
}

.page_pacey input.pacey_membership_postcode {
    width: 13%;
}

.page_pacey button {
    font-family: sofia-pro, sans-serif;
    color: #FFFFFF;
    display: block;
    border-radius: 25px;
    background: #E90564;
    padding: 8px 16px;
    color: #FFFFFF;
    border: none;
    width: fit-content;
    margin: 1rem 0;
    font-size: 1rem;
}

.page_pacey .member_details h2 {
    margin:2rem 0;
    text-align:left;
    font-size:2rem;
}

.page_pacey h3 {
    font-size:1.8rem;
    font-weight:600;
}

.page_pacey .member_details > div {
    margin:0.5rem 0;
}

.page_pacey button:hover {
    background: #04994b;
    transition: all 0.5s ease;
    cursor: pointer;
}

.page_pacey .member_not_found {
    color: #FFFFFF;
    font-size: 1em;
    display: block;
    padding: 2%;
    background: #b81f8b;
    margin-bottom: 20px;
}

.page_pacey .verify_controls {
    margin: 20px 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
}

.page_pacey .member_details {
    clear: both;
}

.member_details_content {
    clear: both;
    margin: 20px 0;
    padding: 20px;
    border: 1px solid #DDDDDD;
    background: #EDEDED;
    border-bottom: 2px solid #E90564;
}

.member_details_content div {
    margin: 10px 0;
}

.page_pacey label {
    font-weight: 600;
    display: inline-block;
    width: 20%;
    color: #E90564;
}

.page_pacey .course_details {
    clear: both;
    margin-top: 20px;
}

.page_pacey .course_details ul {
    column-count: 2;
}

.page_pacey .course_details ul.contents {
    list-style-type: none;
    padding: 0;
    display:flex;
    gap:16px;
    flex-wrap: wrap;
}

.page_pacey .course_details ul.contents li {
    display: block;
    padding: 8px 16px;
    font-size: 1rem;
    background: #b11e8c;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
    font-weight:600;
    width:fit-content;
    border-radius: 25px;
}

div.iconed {
    display: flex;
    align-items: center;
}

div.iconed > i {
    flex-grow: 0;
    flex-shrink: 0;
    width: 32px;
}

div.iconed.large > i {
    font-size: 64px;
    width: 78px;
}

div.iconed > p {
    text-align: left;
}

.quote {
    box-sizing: border-box;
    padding: 60px;
    background: #ededed;
    margin: 0 80px;
    font-size: 20px;
}

.quote p {
    line-height: 30px;
}

.quote .quote_name {
    font-weight: 600;
}

.booking_container button {
    float: none;
}

.booking_container button i {
    position: relative;
    top: 5px;
}


/* ================================================================================================================================================================ */
/* Means UI.popup does not have to have auto styles */
.popup.overlay {
    background: rgba(0,0,0,0.5);
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    min-height: 100%;
    z-index: 100;
}

.popup .content {
    background: rgba(255,255,255,1);
    position: fixed;
    left: 20%;
    right: 20%;
    top: 10%;
    z-index: 101;
    overflow-y: scroll;
    font-family: sofia-pro, sans-serif;
}

.popup .content.add_to_list {
    background: #ededed;
    padding: 20px;
    color: #4f4f4f;
    border: 2px solid rgba(0,0,0,0.2);
}

.popup .content.add_to_list h2 {
    color: #4f4f4f;
}

.add_to_list .text {
    padding: 10px;
}

.popup .content.add_to_list input {
    font-size: 14px;
    padding: 5px 10px;
    border: 1px solid #DDDDDD;
    font-family: sofia-pro, sans-serif;
    border-radius: 3px;
}

.popup .content.add_to_list input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
    color: #FFFFFF;
}

.popup .content.add_to_list input::-moz-placeholder { /* Firefox 19+ */
    color: #FFFFFF;
}

.popup .content.add_to_list input:-ms-input-placeholder { /* IE 10+ */
    color: #FFFFFF;
}

.popup .content.add_to_list input:-moz-placeholder { /* Firefox 18- */
    color: #FFFFFF;
}

.popup .buttons {
    padding-top: 10px;
    color: #FFFFFF;
}

.popup .btn {
    display: inline-block;
    min-width: 70px;
    background: #DDDDDD;
    padding: 10px;
}

.popup .content.add_to_list .btn {
    text-align: center;
    letter-spacing: 1px;
    border-radius: 25px;
    text-decoration:none;
    padding:6px 20px 8px 20px;
}

.popup .content.add_to_list .btn.btn_cancel {
    background: #999999;
    color:#444444;
}

.popup .content.add_to_list .btn.btn_ok {
    background: #479667;
    color:#FFFFFF;
}

.popup .content.add_to_list .btn:hover {
    cursor: pointer;
    transition: all ease 0.7s;
    background: #479667;
    color:#FFFFFF;
}

.popup .content.add_to_list .btn.btn_cancel:hover {
    background: #e11446;
}

.popup .content.add_to_list .btn.btn_ok:hover {
    back
}

.wl_item {
    display: inline-block;
    line-height: 24px;
}

.wl_item span {
    font-weight: 600;
}

.wl_item span.light {
    font-weight: 500;
}

.add_to_list em {
    display: block;
    width: 67%;
    font-size: 16px;
}

.add_to_list h2 {
    margin: 0 0 15px 20px;
    font-size: 32px;
    color: #b8b8b8;
    font-weight: 500;
}

.add_to_list h3 {
    margin-top: 0;
    font-size: 1.6rem;
}

.prf_group {
    position: relative;
}

.prf_group.disabled:before {
    display: block;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 1;
    background: rgba(255, 255, 255, 0.75);
    content: '';
    position: absolute;
}

.pair {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.pair .sub {
    font-size: 0.9em !important;
}

#provider-logos.disabled:before {
    height: 100%;
}

.fullscreen .form-fields.complex > .row > .section:nth-child(even) {
    background: rgba(48, 76, 60, 0.08);
    padding: 20px;
    margin-top: -20px;
}

.fullscreen .form-fields.complex > .row > .section:nth-child(even) .row {
    background: transparent;
}

/* ================================================================================================================================================================ */
/* clearfix */
.pr_inner:before,
.pr_inner:after,
.pageRow:before,
.pageRow:after,
.clearfix:before,
.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    overflow: hidden;
}

.pr_inner:after,
.clearfix:after,
.pageRow:after {
    clear: both;
}

.pr_inner,
.clearfix,
.pageRow {
    zoom: 1;
}
/* IE < 8 */

/* ================================================================================================================================================================ */
/* ================================================================================================================================================================ */
/* ================================================================================================================================================================ */
@media all and (max-width: 1780px) {
    .hero_ol_link {
        top: 90px;
    }
}

@media all and (max-width: 1670px) {
    .ha_learner_stats {
        display: none;
    }
}

@media all and (max-width: 1351px) {
    .ha_feedback {
        display: none;
    }
}

@media all and (max-width: 1200px) {
    .row_audience div {
        width: 45%;
        margin: 0 0 40px 0;
    }

    .book_link, .git_link, .contents_link {
        font-size: 0.9em;
    }

    .row_80 {
        width: 100%;
        margin: 0 auto;
    }

    .row_center {
        padding: 40px;
    }

    .row_center h2 {
        text-align: left;
    }

    .mSCaption h2 {
        font-size: 30px;
    }

    .mSCaption.infoBlockLeft span {
        font-size: 19px;
    }
}


@media all and (max-width: 1108px) {

    #header {
        width: 100%;
    }

    #sign-in span,
    nav > a span {
        font-size: 0.9em;
    }

    nav > a,
    nav > span {
        width: 110px;
    }

    .row_courses a span {
        font-size: 1.5em;
    }

    .row_course_intro h1 {
        width: 100%;
        font-size: 40px;
    }

    nav > a, nav > span {
        width: 100px;
    }
}

@media all and (max-width: 960px) {

    .course_row .course_name {
        width: 100%;
        padding: 10px 20px;
    }

    .course_row .course_price {
        width: 100%;
    }

    .course_price img {
        width: 50%;
        margin: 10px auto;
    }

    .course_row .controls span, .course_row .controls a {
        width: 100%;
    }

    .course_text span {
        transition: all ease 0.7s;
    }

    .row_audience div span img {
        display: none;
    }

    .h_tile {
        width: 100%;
    }

    #sign-in,
    .mi_venues {
        display: none;
    }
}

@media all and (max-width: 800px) {

    #popupNav .nav_group h3,
    .pn_nav > li a, .pn_nav > li span,
    .ng_2 .pn_nav li a, .pn_nav ul li a {
        padding: 10px;
    }

    #popupNav li.contact-us-title a:hover h3 {
        padding: 20px;
    }

    nav > a,
    nav #sign-in {
        display: none;
    }

    nav > span.mi_plus {
        display: block;
    }

    #logoHomeLink {
        width: 200px;
    }

    nav {
        right: 0;
        left: auto;
    }

    nav > span.mi_plus {
        width: 90px;
        height: 80px;
    }

    .mi_plus i {
        padding: 14px 25px 0px 15px;
    }

    #sign-in {
        width: 90px;
        height: 80px;
    }

    #headerOuter {
        min-height: 80px;
    }

    #sign-in span {
        font-size: 0.9em;
    }

    .menu_bars {
        width: 90px;
        height: 64px;
        padding: 8px 0;
    }

    .menu_bars span.menu_bar {
        width: 44px;
        height: 5px;
        margin: 8px auto;
    }

    #popupNav .nav_group {
        width: 100%;
        padding: 0;
    }

    a.logo_home_link {
        margin: 20px 0 0 0;
        padding: 20px;
    }

    .pn_close {
        width: 100%;
    }

    .footer_spacer {
        display: none;
    }

    footer {
        padding: 0;
        position: relative;
    }

    footer .col_1_4 {
        width: 50%;
        padding: 10px;
    }

    .row_flex {
        display: block;
    }

    .row_flex > div {
        width: 100%;
        margin: 10px 0;
    }

    .rf_address {
        display: block;
        width: 100%;
    }
}


@media all and (max-width: 780px) {
    /* Course detail */


    .course_content .col_1_2,
    .col_3_4,
    .col_1_4 {
        width: 100%;
        padding: 0;
    }

    .col_3_4:first-of-type {
        padding: 0;
    }

    .course_content_container .col_2_3,
    .course_content .col_1_2,
    .course_content .col_1_3,
    .col_1_3,
    .col_2_3 {
        width: 100%;
        padding: 20px;
        margin: 0;
    }

    #headerOuterSpacer {
        display: block;
        height: 147px;
    }

    .hero_text h2 {
        font-size: 30px;
    }

    .hero_text p {
        font-size: 19px;
        width: 100%;
    }

    .mSCaption h2 {
        font-size: 24px;
    }

    .mSCaption.infoBlockLeft span {
        font-size: 16px;
    }

    .hero_text {
        padding: 10px 40px 120px 40px;
    }

    .ht_full span, .ht_half span {
        bottom: 0;
    }

    .massive_half {
        width: 100%;
    }

    .landscape_qtr {
        width: 50%;
    }

    .landscape_half {
        width: 100%;
    }

    .course_text span {
        font-size: 0.9em;
    }

    .row_courses a {
        width: 50%;
    }

    .row_audience div {
        width: 100%;
        margin: 0;
    }

    .row_audience div span img {
        display: block;
    }

    .row_audience div.ca_individual,
    .row_audience div.ca_inhouse {
        width: 100%;
    }


    .hero_ol_link {
        display: none;
    }

    .course_content_container > div {
        width: 95%;
        margin: 0 2.5% 40px 2.5%;
    }

    .top_row_flex,
    #courseExtraInfo {
        flex-wrap: wrap;
    }

    .course_page_intro,
    .page_intro_right,
    #courseExtraInfo > div {
        width: 100%;
    }

    .popup .content {
        left: 20px;
        right: 20px;
        top: 20px;
        bottom: 20px;
        box-sizing: border-box;
        height: calc(100% - 40px);
    }

    .add_to_list em {
        width: 100%;
        font-size: 13px;
    }

    .add_to_list h2 {
        font-size: 24px;
    }

    .popup .content.add_to_list .btn {
        text-align: center;
        letter-spacing: 1px;
        margin: 0 0 10px 0;
        width: 100%;
        box-sizing: border-box;
    }

    .prf_item label {
        width: 100%;
    }

    .add_to_list h2 {
        margin: 10px 0;
    }

    .prf_group {
        padding: 10px 0;
    }
}

@media all and (max-width: 440px) {

    .social a {
        margin: 0;
    }

    .pn_nav .s_title {
        font-weight: 600;
        font-size: 17px;
        border-bottom: 2px solid #DDDDDD;
    }

    #popupNav a {
        width: 100%;
        box-sizing: border-box;
    }

    .pn_nav > li a,
    .pn_nav > li span {
        font-size: 17px;
    }

    .pn_nav .s_title {
        margin: 0;
        background: #ededed;
    }

    .pn_nav {
        margin: 0;
    }

    #popupNav .nav_group h3 {
        color: #ffffff;
        padding: 20px;
        background: #34b78f;
        font-weight: 500;
        font-size: 26px;
        margin: 0;
    }

    .course_highlights div {
        width: 100%;
        padding: 20px;
    }

    .page_intro_right {
        padding: 20px;
        width: 100%;
    }

    .hero_text a {
        width: 100%;
        margin-bottom: 10px;
    }

    .hero_text p {
        width: 100%;
    }

    .hero_text .controls {
        position: relative;
    }

    .course_row .controls span,
    .course_row .controls a {
        letter-spacing: 0;
        padding: 12px 8px 10px 8px;
    }

    .course_row {
        padding: 0;
    }

    .row_center.related_courses {
        padding-top: 0px;
        margin-top: 0px;
    }

    .row_center.related_courses h2 {
        padding-left: 0;
    }

    .booking_popup a .material-icons {
        top: 7px;
        line-height: 6px;
    }

    #homeIntro.page_intro p.impact,
    .row_center h2,
    p.impact {
        line-height: 40px;
        font-size: 30px;
    }

    .sb-section-help {
        font-size: 1em;
        font-weight: 500;
    }

    tlt-course-builder h3 {
        font-weight: 600;
        font-size: 1.25em;
    }

    .sort-button {
        font-size: 1em;
        padding: 10px 6px;
    }

    .cb_addr_dist {
        padding-top: 0 !important;
        font-size: 16px;
    }

    a.book_link, .row_top a.book_link, .row_top a.git_link {
        margin-right: 0;
        margin-bottom: 10px;
    }

    .course_name {
        padding: 15px;
        width: 100%;
        font-size: 16px;
    }

    .course_row {
        display: block;
    }

    .course_row .controls span,
    .course_row .controls a,
    .course_row .controls a.info,
    .course_row .controls a.book,
    .course_row .course_name,
    .course_row .course_price,
    .course_row .course_list_content,
    #homeAccreditations .row_flex > div.col_1_2,
    .course_list_image {
        width: 100%;
    }

    .course_price img {
        width: 50%;
        margin: 10px auto;
    }

    .course_list_content .course_data {
        display: block;
        margin-bottom: 0;
    }

    .course_row .controls {
        position: relative;
    }

    .course_row .course_price {
        float: none;
    }

    h1 {
        font-size: 1.5em;
        font-weight: 600;
    }

    .row_center h1 {
        text-align: left;
    }

    #header {
        background: #FFFFFF;
    }

    nav {
        right: 0;
        left: auto;
    }

    .mobile_top_button {
        display: block;
    }

    .row_audience div span h4 {
        margin-bottom: 10px;
    }

    .fa_section h2 {
        font-size: 1.2em;
        background: #4f4f4f;
        padding: 10px;
        color: #FFFFFF;
    }

    .nohero p {
        width: 100%;
        font-size: 16px;
    }

    .book_link,
    .git_link,
    .contents_link {
        margin-right: 0;
        padding: 8px 20px 4px 20px;
        font-size: 0.75em;
    }

    .row_audience div span img {
        display: none;
    }

    .row_audience div a {
        margin-top: 10px;
    }

    #popupNav .nav_group {
        width: 100%;
    }

    #sign-in {
        display: none;
    }

    .hero_text {
        width: 100%;
        left: 0;
        padding: 20px 40px;
    }

    .hero_text h2 {
        font-size: 1.2em;
    }

    .course_page_intro {
        width: 95%;
    }

    .hero_text p {
        font-size: 1em;
    }

    .page_intro_right {
        float: left;
        width: 95%;
        margin-left: 5%;
    }

    .ht_content p {
        display: none;
    }

    .h_tile h1, .h_tile h2 {
        font-size: 1.5em;
        padding-left: 0;
    }

    .ht_content {
        padding: 0;
    }

    #courseFeatures .col_3_5 {
        width: 100%;
    }

    #courseOptions p,
    .row_courses a,
    #courseFeatures .course_image {
        width: 100%;
    }

    #courseExtraInfo {
        display: block;
    }

    #courseExtraInfo > div {
        width: 100%;
    }

    footer .col_1_4 {
        width: 100%;
        padding: 10px;
    }

    .bb_social,
    .reminder,
    .footer_spacer {
        display: none;
    }

    footer {
        padding: 0;
        position: relative;
    }

    footer:before,
    footer:after {
        content: ".";
        display: block;
        height: 0;
        overflow: hidden;
    }

    footer:after {
        clear: both;
    }

    footer {
        zoom: 1;
    }
    /* IE < 8 */
    nav > span.mi_plus {
        display: none;
    }

    .page_intro,
    .row_course_intro,
    .row_top {
        margin-top: 0;
    }

    .row_top h1 {
        font-size: 30px;
        font-weight: 600;
    }

    .row_courses #courseList a {
        width: 100%;
    }

    .ht_full span,
    .ht_half span {
        bottom: 0px;
    }

    .h_tile h2 {
        font-size: 1.5em;
    }

    a.book_link,
    a.contents_link {
        font-size: 0.9em;
        padding: 4px 10px;
    }

    .call_us strong {
        display: none;
    }

    .call_us {
        padding: 10px 20px;
    }

    .pn_nav ul {
        margin: 0;
    }

    #homeIntro {
        position: relative;
    }

    #hero {
        background-position: 20% 0;
        min-height: 340px;
    }

    .top_row_flex {
        display: block;
    }

    .course_page_intro {
        width: 100%;
        padding: 0 20px;
    }

    .row_course_intro h1 {
        padding: 20px;
    }

    .course_page_intro p {
        max-width: 100%;
    }

    .row_flex > div.col_1_2 {
        width: 100%;
    }
}

/*.christmas_banner {
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:640px;
    background-image:url(https://tigerlilytraining.co.uk/media/1438/christmas-background.png);
    background-repeat:repeat-x;
    z-index:1010;
    pointer-events: none;
    display:none;
}*/

.green {
    color: #479667;
}

#wrapper {
    background: #FFFFFF;
    margin: 0 auto;
}

p {
    line-height: 1.6rem;
}

strong {
    font-weight: 600;
}

.venue-search strong {
    color: #FFF;
}

.inner {
    padding: 24px;
    max-width: 1260px;
    margin: auto;
    box-sizing: border-box;
    position:relative;
    z-index:2;
}

.current-course-finder {
    z-index:10;
}

.inner.course-filters {
    padding:0 24px;
}

.mSCaption.infoBlockLeft {
    background: none;
}


.hero_links {
    display: flex;
    justify-content: center;
}

.mSCaption .hero_links a {
    position: relative;
    margin: 0 20px 0 0;
}

.mSCaption .hero_links span {
    padding: 10px 20px 10px 0px;
}

.mSCaption .hero_links span strong {
    font-family: sofia-pro, sans-serif;
    margin-left: 10px;
    letter-spacing: 1px;
    font-size: 26px;
    line-height: 20px;
    font-weight: 600;
    position: relative;
    top: 2px;
}

.mSCaption .hero_links a.hero_book_link {
    background: #479667;
    color: #FFF;
    font-weight: 500;
    transtion: 0.7s;
}

.mSCaption .hero_links a.hero_book_link:hover {
    background: #607d8b;
    color: #FFFFFF;
}

.mSCaption .hero_links a.hero_info_link {
    color: #FFFFFF;
    padding: 9px 20px 9px 20px;
    background: none;
    display: inline-block;
    border-radius: 0;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    border: 1px solid #FFFFFF;
    font-family: sofia-pro, sans-serif;
    transition: 0.7s;
}

.red_hero_link .mSCaption .hero_links a.hero_info_link {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    font-weight: 500;
    border: none;
}

.mSCaption .hero_links a.hero_info_link:hover {
    color: #FFFFFF;
    background: #512683;
    background: var(--tlt-purple);
    border-color: transparent;
}

.light_background .mSCaption .hero_links a.hero_info_link {
    color: #4f4f4f;
    border: 1px solid #512683;
    border: 1px solid var(--tlt-purple);
}

.light_background .mSCaption .hero_links a.hero_info_link:hover {
    color: #FFFFFF;
    border: 1px solid #512683;
    border: 1px solid var(--tlt-purple);
}

.hero_tigerlily_logo {
    position: absolute;
    top: 40px;
    left: 40px;
    width: 300px;
    display: none;
}

.hero_tigerlily_logo img {
    display: block;
    width: 100%;
}

.hero_tigerlily_logo img.dark_logo {
    display: none;
}

.light_background .hero_tigerlily_logo img.dark_logo {
    display: block;
}

.light_background .hero_tigerlily_logo img.light_logo {
    display: none;
}

.mSCaption.infoBlockLeft span p {
    width: 60%;
    margin: 0 auto 30px auto;
    letter-spacing: 1px;
}

.mSCaption {
    font-family: sofia-pro, sans-serif;
}

.mSCaption h2 {
    font-size: 36px;
}

.hero_text,
.mSCaption.infoBlockLeft {
    width: 100%;
    margin: 0 auto;
    text-align: center;
    padding: 2rem;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    z-index: 1;
}

.f-a-c.mSCaption.infoBlockLeft {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    z-index: 1;
}

.f-a-c.mSCaption.infoBlockLeft .inner {
    width:100%;
}

.f-a-c.testimonial-row {
    background: #dcddf2;
    padding: 2rem;
    margin: 2rem auto 0 auto;
    max-width: 860px;
    border-radius: 20px;
}

.f-a-c.testimonial-row .quote {
    box-sizing: border-box;
    padding: 0;
    background: none;
    margin: 0 auto;
    max-width: 720px;
    font-size: 1.2rem;
}

.f-a-c.testimonial-row .testimonial-name {
    font-style: italic;
    font-weight: 600;
    font-family: 'sofia-pro';
    font-size: 1.2rem;
    margin-top: 0.4rem;
}

.quote-mark svg {
    display:block;
    width:48px;
    fill:#FFFFFF;
    margin:0 0 1rem 0;
}

.quote-stars {
    display:flex;
    justify-content:center;
    margin-top:1rem;
}

.f-a-c.testimonial-row .inner {
    padding:0;
}

.quote-stars svg {
    display:block;
    width:20px;
    height:20px;
    color:#512683;
    margin-right:3px;
    fill: #512683;
}

.f-a-c.testimonial-row .quote-mark svg {
    fill:#512683;
    margin:0 auto 1rem auto;
}

.f-a-c.mSCaption.infoBlockLeft .quote {
    box-sizing: border-box;
    padding:1rem 0;
    background:none;
    margin:0;
    font-size: 20px;
    color: #FFFFFF;
    text-align: left;
    width:90%;
    max-width:720px;
    font-size: 1.6rem;
    line-height: 2.4rem;
    font-weight:300;
}

.f-a-c.mSCaption.infoBlockLeft .testimonial-name {
    font-style:italic;
    font-weight:500;
    text-align: left;
    font-size: 1.6rem;
    line-height: 2.4rem;
    color:#FFFFFF;
}

.mSCaption.infoBlockLeft {
    display: none;
}

.mSSlide.active .mSCaption.infoBlockLeft {
    display: block;
}

.about-page .hero_text p {
    color: #FFFFFF;
}

.about-page h3 {
    color: #512683;
    font-size: 1.8rem;
    font-weight: 500;
    margin-top: 0;
    font-family: sofia-pro, sans-serif;
    line-height: 2.5rem;
}

.about-page .grey-bg img {
    display:block;
    width:100%;
    max-width:300px;
    margin: 1rem auto;
    border-radius: 15px;
}

.about-page .grey-bg .col-2-3 {
    padding:4rem;
    font-size:1.5rem;
}

.about-page .grey-bg .col-2-3 p {
    line-height:2rem;
        max-width: 680px;
}

.about-page .inner.offset-into-hero {
    padding:2rem 2rem 0 2rem;
}

.about-page .inner.offset-into-hero h1 {
    padding: 0 0 2rem 0;
    margin: 0;
}

.course-find-start h5 {
    font-size: 0.9em;
}

.hero_text h2 {
    font-size: 2rem;
    color: #FFFFFF;
    font-weight: 600;
    margin: 0 auto 10px auto;
    max-width: 680px;
}

.hero_text span {
    width: 60%;
    max-width: 960px;
    margin: 0 auto 30px auto;
    letter-spacing: 1px;
    display: block;
    color: #FFFFFF;
    font-size: 1.2rem;
}

.ss-page-title {
    display: block;
    text-align: center;
    color: #512683;
    color: var(--tlt-purple);
    margin: 0.5rem 2rem;
    padding: 1rem 0;
}

/* 
    
    faqs

*/


.faqs-container {
    margin: 4rem 0;
}

.faqs {
    margin: 2rem 0;
}

.faq:hover,
faq.active {
    transition: 0.7s;
}

.faq h4 {
    cursor: pointer;
    margin: 0;
    display: -webkit-flex;
    display: -webkit-box;
    display: -moz-flex;
    display: -moz-box;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #479667;
    padding-bottom: 1rem;
    font-weight: 600;
    font-size: 1.4rem;
    padding: 1.5rem 1rem;
    transition: background 0.7s;
    color: #512683;
}

.faq.active h4 {
    border: none;
    color: #512683;
}

.faq.active h4:hover,
.faq h4:hover {
    transition: 0.7s;
    color: #479667;
}

.faq.active {
    border-bottom: 2px solid #248037;
}

.faq h4 .fal {
    margin-left: 1rem;
}

.faq h4 .minus-circle,
.faq h4 .plus-circle {
    display: inline-block;
    margin: 0 1rem 0 0;
}

.faq h4 .minus-circle {
    display: none;
}

.faq.active h4 .plus-circle {
    display: none;
}

.faq.active h4 .minus-circle {
    display: inline-block;
}

.minus-circle svg,
.plus-circle svg {
    pointer-events: none;
}

.minus-circle circle,
.plus-circle circle {
    transition: 0.7s;
}

.faq_answer {
    padding-left: 4rem;
}

h4 .minus-circle svg circle,
h4 .plus-circle svg circle {
    fill: #512683;
}

h4:hover .minus-circle svg circle,
h4:hover .plus-circle svg circle {
    fill: #479667;
}

.faq_answer ul {
    width: 70%;
}

.answer-content {
    width: 100%;
    padding: 1.5rem;
}

.faq h4 svg {
    display: block;
    width: 30px;
    height: 30px;
}

.expandable_content {
    display: none;
}


.faq h4 svg {
    display: block;
    width: 30px;
    height: 30px;
}

/*
    EO FAQs
*/

.ss-page-title h2 {
    color: #512683;
    color: var(--tlt-purple);
    margin: 1rem 0;
    font-size: 2rem;
}

.category-intro {
    width: 90%;
    margin: 0 auto;
    max-width: 860px;
    font-size: 1.2rem;
}

.ss-page-title p {
    font-size: 1.2rem;
    line-height: 1.6rem;
}

.text {
    padding: 40px;
}

.text-page h3 {
    font-weight: 500;
    color: #479667;
}

.text-page table {
    margin: 2rem 0;
    border-collapse: collapse;
    width: 100%;
}

.text-page table td {
    border: 1px solid #CCCCCC;
    padding: 1rem;
}

.text-page table th {
    white-space: nowrap;
    text-align: left;
    padding: 1rem;
    border: 1px solid #CCCCCC;
    background: #EDEDED;
    color: var(--header-color);
    font-family: 'Larsseit Bold', sans-serif;
}


#homeIntro.page_intro p.impact {
    text-align: left;
    width: 100%;
}

.course-download {
    padding-bottom: 1rem;
}

.takeover {
    background: rgba(0,0,0,0.4);
    position: fixed;
    top: -100%;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100000004;
}

.takeover-note {
    padding: 2rem;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    text-align: center;
    max-width: 600px;
    border-radius: 5px;
    width: 90%;
    box-sizing: border-box;
    position: relative;
}

.takeover-note h4 {
    line-height: 2rem;
}

.takeover-note h5 {
    font-weight: 500;
}

.close-takeover {
    position: absolute;
    top: 1rem;
    right: 1rem;
    color: rgba(255,255,255,1);
    cursor: pointer;
    font-size: 2rem;
    display: block;
    transition: 0.7s;
}

.close-takeover:hover {
    color: rgba(255,255,255,0.6);
}

.course_list.flex-container {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

div.course-item,
a.course-item {
    width: calc(33.333% - 2rem);
    box-sizing: border-box;
    position: relative;
    display: flex;
    -webkit-transition: .2s;
    transition: .2s;
    margin: 1rem;
    min-height: 140px;
    text-decoration: none;
    overflow: hidden;
    flex-direction: column;
    border-radius: 20px;
}

div.course-item.Popular::after,
a.course-item.Popular::after {
    content: "";
    display: block;
    position: absolute;
}

.course-item .title_note {
    font-size: 0.9rem;
}

.course-item > * {
    position: relative;
    z-index: 2;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
}

.course-item h5 {
    font-weight: 500;
    font-size: 28px;
    margin: 0 0 0.25rem 0;
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    height: 100%;
    flex-direction: column;
    justify-content: space-between;
    color: #512683;
}

a.course-item:hover h5 {
    transition:color 0.5s;
    color:#FFFFFF;
}

.title_note {
    display: block;
    font-size: 1.5rem;
}

.mixed-content-page .title_note {
    color: #512683;
    color: var(--tlt-purple);
}

.mixed-content-page table {
    width: 100%;
}

.course-intro {
    margin-bottom: 2rem;
}

.course-item .course_name {
    padding: 1.5rem 1rem;
    width: 100%;
}

.course_img {
    width: 100%;
    height: 240px;
    transition: all .7s;
    background-size: cover;
    position: relative;
}

.course_img .virtual-course-label {
    top: unset;
    bottom: 0;
    right: 0;
    left: unset;
    border-top-right-radius: 0;
    background: rgba(0,0,0,0.5);
}

.course-item .course-data {
    display: flex;
    width: 100%;
    justify-content: space-between;
    background: #dcddf2;
    border-bottom-left-radius: 20px;
    flex-wrap: wrap;
    border-bottom-right-radius: 20px;
    flex-grow: 1;
    transition:background 0.5s;
}

a.course-item:hover .course-data {
    text-decoration: none;
    background:#8f91bd;
}

.course-item .controls {
    width: 100%;
    padding: 0 20px 10px 20px;
    justify-content: space-between;
    align-items: center;
    display: flex;
    box-sizing: border-box;
}

.course-item .controls a,
.course-item .controls span {
    text-align: center;
    text-decoration: none;
    transition: 0.7s;
    box-sizing: border-box;
    border: none;
    padding: 6px 20px 8px 20px;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 10px 0 10px 0;
    font-weight: 500;
    letter-spacing: 1px;
    background: #512683;
    color: #FFFFFF;
    transition: all ease 0.7s;
    outline: none;
    border-radius: 25px;
    cursor: pointer;
}

.course-item:hover .controls a,
.course-item:hover .controls span {
    background:#5f618c;
    cursor: pointer;
}

.course-item .controls a.book {
    background:#34b78f;
}

.course-item .controls a.book:hover {
    background:#56c282;
}

.course-data .controls a:visited {
    color: rgba(255,255,255,0.6);
}

.course-item .controls span:hover {
    cursor: pointer;
}

.col_1_2.e-learning_image .impact,
.impact {
    font-size: 32px;
    line-height: 46px;
}

.filter-row {
    width: calc(100% - 3rem);
    text-align: center;
    margin: 0 auto;
    background: #dcddf2;
    margin: 1.5rem;
    border-radius: 10px;
    box-sizing: border-box;
    padding: 0.5rem;
}

.filter-row h3 {
    color: #FFFFFF;
    padding: 20px;
    margin: 0;
    font-size: 1.3rem;
    font-weight: 500;
}

.filter-row ul {
    list-style-type: none;
    margin: 0 auto;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 1440px;
    flex-wrap:wrap;
}

.filter-row ul li {
    margin: 0.5rem;
    text-align: center;
}

.controls span.virtual-course {
    display:none;
    width: 40px;
    background: #34b78f;
    border-radius: 50%;
    height: 40px;
    align-items:center;
    justify-content:center;
}

.controls span.virtual-course svg {
    width:24px;
    height:24px;
}

.course-item.Virtual .controls span.virtual-course {
    display:flex;
    color:#FFFFFF;
}

.filter-row ul li span,
.filter-row ul li a {
    padding: 6px 20px 8px 20px;
    background: #512683;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
    border-radius: 25px;
    transition: background 0.5s;
    font-size: 17px;
    text-decoration: none;
    display: block;
}

.filter-row ul li span:hover,
.filter-row ul li a:hover {
    cursor: pointer;
    background: #5f618c;
    text-decoration: none;
}

.infographic {
    padding: 20px;
    border-radius: 10px;
    position: relative;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-transition: .2s;
    transition: .2s;
    background-size: cover;
    min-height: 260px;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    text-align: center;
}

.reviews-widget {
    margin: 1rem 0;
    padding: 20px;
    border-radius: 10px;
    position: relative;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    text-align: center;
    background: #479667;
}

.virtual-course-label {
    background: #479667;
    color: #FFFFFF;
    padding: 7px;
    display:flex;
    align-items: center;
    font-family: sofia-pro, sans-serif;
    font-weight: 400;
    font-size: 1rem;
    position: absolute;
    top: -38px;
    left: 26px;
    width: 120px;
    justify-content: center;
    letter-spacing: 1px;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
}

.virtual-course-label svg {
    display:block;
    width:20px;
    height:20px;
    margin-right:0.5rem;
}

.infographic > div {
    padding: 5px;
}

.ig-buff {
    background: #FFF;
    color: #512683;
    color: var(--tlt-purple);
}

.ig-purple {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
}

.ig-pink {
    background: #B965BE;
    color: #FFFFFF;
}

.ig-stat {
    font-size: 4rem;
    font-weight: 900;
}

.ig-img img {
    display: block;
    width: 40%;
    margin: 0 auto;
    max-width: 78px;
}

.fr-courses {
    padding-bottom: 40px;
}

.fr-courses .col_3_4 {
    padding: 0 1rem;
    width: calc(75% - 2rem);
}

.fr-courses .col_1_4 {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    display: grid;
    grid-gap: 1rem;
    grid-template-columns: repeat(1,1fr);
    margin: 0 1rem;
    width: calc(25% - 2rem);
}

.topbar {
    background: #34b78f; /* Old browsers */
    background: -moz-linear-gradient(top, #34b78f 0%, #24ae5c 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top, #34b78f 0%,#24ae5c 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom, #34b78f 0%,#24ae5c 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#34b78f', endColorstr='#24ae5c',GradientType=0 ); /* IE6-9 */
    color: #FFFFFF;
    padding: 15px 20px;
    box-sizing: border-box;
}

.topbar > div {
    flex-grow: 1;
}

.topbar div.tb_call {
    text-align: center;
    letter-spacing: 1px;
}

.topbar div.tb_login {
    text-align: right;
    letter-spacing: 1px;
}

.topbar div.tb_login a {
    text-decoration: none;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 600;
}

.main_menu_link {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
}

.main_menu_link:hover {
    background: #202150;
    transition: 0.7s;
}

.menu-nav nav div.main_menu_link > span,
.menu-nav nav div.main_menu_link a {
    color: #FFFFFF;
}

.menu-nav nav div.nav_item.main_menu_link > span {
    width: 100%;
}

.menu-nav nav div.main_menu_link i {
    position: relative;
    top: 1px;
    margin-right: 5px;
}

.menu-nav nav div.main_menu_link span i.fa-times {
    display: none;
}

.menu-nav nav div.main_menu_link span i.fa-bars {
    display: inline-block;
}

.menu-nav nav div.main_menu_link span.active i.fa-times {
    display: inline-block;
}

.menu-nav nav div.main_menu_link span.active i.fa-bars {
    display: none;
}

.menu-nav nav div.active > span,
.menu-nav nav div > span:hover,
.menu-nav nav div a:hover {
    color: #6466b9;
    cursor: pointer;
}

.menu-nav nav div > span:hover:after,
.menu-nav nav div a:hover:after {
    opacity: 1;
}

.menu-nav nav div.main_menu_link.active > span,
.menu-nav nav div.main_menu_link > span:hover,
.menu-nav nav div.main_menu_link a:hover {
    color: #FFFFFF;
    cursor: pointer;
}

.menu-nav nav div.main_menu_link > span:after,
.menu-nav nav div.main_menu_link a:after,
.menu-nav nav div.main_menu_link.active > span:after,
.menu-nav nav div.main_menu_link.active a:after {
    height: 0;
}

.menu-nav nav div.book_course a:hover {
    background: #d5cfbe;
}

.flex-container {
    display: -webkit-flex;
    display: -webkit-box;
    display: -moz-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}

.col-1-3 {
    width: 33.333%;
}

.col-2-3 {
    width: 66.667%;
}

.col-2-5 {
    width: 40%;
}

.col-3-5 {
    width: 60%;
}

.col-1-2 {
    width: 50%;
}

.book_online .col-1-3 {
    padding-right: 5px;
}

.cat_type {
    position: relative;
}

.cat_type:after {
    display: block;
    content: "";
    height: 90%;
    position: absolute;
    right: 0;
    top: 5%;
    background: #DDDDDD;
    width: 1px;
}

.courses_booking_intro {
    padding: 40px;
}

.courses_booking_intro p {
    width: 66.667%;
}

.contact_details_container,
.course-box,
.course_benefits {
    box-sizing: border-box;
    padding: 40px;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    border-radius:20px;
}

.course_extras {
}

.course_extras .ce-item:first-of-type p:first-of-type {
    margin-top: 0;
}

.ce-item {
    padding-bottom: 0.5rem;
}

.course-box a.contents_link,
.course-box a.book_link {
    margin-right: 0.1rem;
}

a.booking-link {
    color: #FFF;
    padding: 0.5rem 1rem;
    background: #512683;
    background: var(--tlt-purple);
    display: block;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    transition: all ease 0.7s;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    text-decoration: none;
    margin-bottom: 1rem;
    border-radius:25px;
}

a.content-link,
span.content-link,
span.expand-link {
    color: #FFFFFF;
    padding: 9px 20px;
    background: rgba(255,255,255,0.4);
    display: block;
    font-size: 1.1rem;
    font-weight: normal;
    text-align: center;
    transition: all ease 0.7s;
    box-sizing: border-box;
    font-family: sofia-pro, sans-serif;
    text-decoration: none;
    margin-bottom: 1rem;
    cursor: pointer;
}

span.expand-link {
    display: inline-block;
    margin-left: 3rem;
}

.mixed-content-page .ce-item a,
.mixed-content-page .ce-item a:visited {
    color: #479667;
}

.mixed-content-page .ce-item a:hover {
    color: #34b78f;
}

.toexpand {
    display: none;
}

.course_text h3 {
    margin: 0 0 1rem 0;
    font-weight: 500;
}

.course_text h5 {
    margin: 0;
    font-weight: 500;
}

.course_text ul {
    margin: 0;
    padding: 0 5rem 0 1rem;
}

.course_text ul li {
    margin: 0.75rem;
}

a.booking-link.online {
}

a.booking-link.group {
    background: #dcddf2;
    color: #512683;
    color: var(--tlt-purple);
}

a.booking-link:hover {
    transition: 0.7s;
    background: #479667;
    color: #FFFFFF;
}

.course_extras .ce-title {
    margin: 0 0 .2rem 0;
    display: inline-block;
    position: relative;
    padding-left: 2rem;
    font-family: sofia-pro,sans-serif;
    font-weight: 600;
}

.course_extras h5 i {
    margin-right: 0.6rem;
}

.ce-title:before {
    font-family: 'Font Awesome 5 Pro';
    position: absolute;
    display: block;
    left: 0;
    font-size: 1.6rem;
    display: block;
    top: 0;
}

.ce-title.cost:before {
    content: "\f154";
    border: 2px solid #502683;
    padding: 1px 7px 0px 7px;
    border-radius: 50%;
    font-size: 15px;
    font-weight: 900;
    top: -2px;
}

.ce-title.duration:before {
    content: "\f017";
    font-weight: 500;
}

.ce-title.assessment:before {
    content: "\f737";
}

.ce-title.certificate:before {
    content: "\f5a2";
}

.ce-title.location:before {
    content: "\f3c5";
}

.col-2 {
    column-count: 1;
}

.col-2 p {
    margin: 0 0 1rem 0;
}

.course-audience,
.course-syllabus {
    padding: 2rem;
    background: #479667;
    color: #FFFFFF;
    margin: 1.5rem 0;
    position: relative;
    overflow: hidden;
    border-radius: 20px;
}

.course-audience td {
    padding: 0 1rem;
}

.course-audience td.ca-images {
    white-space: nowrap;
}

.course-audience {
    background: #512683;
    background: var(--tlt-purple);
}

.mixed-content-page .course-audience .col-2-3 {
    padding-right: 2rem;
}

.course-audience .col-1-3 {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    justify-content: center;
}

.course-audience .col-1-3 img {
    display: block;
    width: 100%;
    max-width: 100px;
    margin: 0.5rem;
}

.contact_details_container h3,
.course_benefits h3 {
    margin-top: 0;
}

.course_benefits ul {
    margin: 30px 0;
}

.course_benefits ul li {
    margin: 12px;
}

.benefits_note {
    line-height: 26px;
    font-style: italic;
}

.contact_page .row_flex > div div.contact_details_container .call_us,
.course_benefits .call_us {
    padding: 12px 20px;
    margin-top: 30px;
    background: rgba(0,0,0,0.1);
    font-size: 1.1rem;
    font-weight: 500;
    letter-spacing: 2px;
    text-align: center;
    width: 100%;
    font-family: sofia-pro, sans-serif;
    border-radius: 10px;
}

.contact_details_container .tel {
    margin-top: 1rem;
}

.contact_details_container h4,
.contact_details_container .tel strong {
    color: #FFF;
}

.contact_details_container .call_us strong,
.course_benefits .call_us strong {
    font-size: 1.2rem;
    color: #FFF;
}

.contact_page .row_flex > div div.address_text {
    padding: 2rem;
    font-size: 1.2rem;
    letter-spacing: 1px;
}

.text-page li {
    margin: 1rem 0;
}

.col-1-1 {
    width:80%;
}


/* jobs */

.vacancies-list {
    width:calc(100% + 64px);
    margin-left:-32px;
    overflow:hidden;
    display:flex;
    flex-wrap:wrap;
}

.job-list h2 {
    color:#512683;
    margin: 0 0 24px 0;
    font-weight:500;
    text-align:center;
}

.job-list-row {
    background:#f2f0eb;
    padding:24px 0;
}

a.job-vacancy-item {
    text-decoration:none;
    color:#212121;
    display:block;
    background:#FFFFFF;
    border-radius:5px;
    padding:18px 24px;
    transition:0.5s;
    position:relative;
    width:calc(33.333% - 64px);
    margin:32px;
    box-sizing:border-box;
}

a.job-vacancy-item:hover {
    text-decoration: none;
    -moz-box-shadow: 0 2px 2px rgba(189, 189, 189, 0.2);
    -webkit-box-shadow: 0 2px 2px rgb(189 189 189 / 20%);
    box-shadow: 0 2px 2px rgb(189 189 189 / 20%);
    -webkit-backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
    -webkit-transform: translate3d(0, -2px, 0) scale(1.0, 1.0);
    transform: translate3d(0, -2px, 0);
    font-smoothing: antialiased !important;
    transition: 0.3s;
}

a.job-vacancy-item h3 {
    margin:0 0 8px 0;
    font-weight:600;
    color:#512683;
}

.careers-page {
    color:#512683;
}

.careers-svg svg {
    display:block;
    max-width:500px;
    width:80%;
    margin:24px auto;
    max-height:360px;
}

a.job-vacancy-item span.link-button {
    margin-top:36px;
}

a.job-vacancy-item:hover span.link-button.green {
    background:#512683;
}

.job-list-row .inner {
    padding-top:12px;
}


/* Reviews */

.review_item {
    display: block;
    position: relative;
    padding: 40px 60px;
    background: #ededed;
    margin: 10px 0;
}

.review_item .material-icons {
    display: block;
    padding: 10px;
    position: absolute;
    left: 0;
    top: 0;
    background: #eec007;
    color: #FFFFFF;
}

.review_name {
    font-family: sofia-pro, sans-serif;
}

footer {
    font-size: 0.9em;
    padding: 0;
    width: 100%;
    background: rgb(41,19,67);
    background: -moz-linear-gradient(0deg, rgba(41,19,67,1) 0%, rgba(80,38,130,1) 100%);
    background: -webkit-linear-gradient(0deg, rgba(41,19,67,1) 0%, rgba(80,38,130,1) 100%);
    background: linear-gradient(0deg, rgba(41,19,67,1) 0%, rgba(80,38,130,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#291343",endColorstr="#502682",GradientType=1);
    color: #fff;
    display: flex;
    flex-wrap: wrap;
}

footer .col_1_4 {
    padding: 20px 40px;
    box-sizing: border-box;
}

footer > div {
    width: 100%;
}

footer a {
    text-decoration: none;
    color: #FFFFFF;
}

footer ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
    font-size: 0.9em;
}

footer ul li {
    margin: 0.25em 0;
    letter-spacing: 1px;
}

footer ul li a {
    display: inline-block;
    padding: 4px 8px;
    position: relative;
    left: -8px;
}

footer a:hover,
footer ul li a:hover {
    color:#FFFFFF;
    text-decoration:underline;
    transition: all ease 0.7s;
}

footer .material-icons {
    position: relative;
    top: 7px;
    line-height: 0;
}

#footerBase {
    clear: both;
    background: rgba(0,0,0,0.2);
    color: #FFFFFF;
    padding: 20px;
}

#footerBase a {
    text-decoration: none;
    color: #FFFFFF;
    margin: 0 5px;
    transition: all ease 0.7s;
}

#footerBase a:hover {
    text-decoration: none;
    opacity: 0.8;
    margin: 0 5px;
    transition: all ease 0.7s;
}

#footerBase .col_1_2 {
    box-sizing: border-box;
}

#footerBase .right_col {
    text-align: right;
}

footer h3 {
    font-weight: 500;
}

footer .fa {
    margin-right: 5px;
}

footer strong {
    font-weight: 500;
    color: #FFF;
}

footer .legal {
    width: 100%;
    margin-top: 2rem;
}

footer h3 {
    margin: 0;
}

footer .social {
    margin-top: 10px;
}

footer .social a {
    display: inline-block;
    text-align: center;
    transition: all ease 0.7s;
    line-height: 100%;
    width: 32px;
    padding: 6px 0 6px 0;
    border: 1px solid rgba(255,255,255,0.2);
    margin: 0 10px 0 0;
}

footer .social a .fa {
    margin: 0;
}

footer .social a.facebook:hover {
    transition: all ease 0.7s;
    background: #3B5998;
}

footer .social a.twitter:hover {
    transition: all ease 0.7s;
    background: #55ACEE;
}

footer .social a.twitter {
    padding: 6px 0 6px 1px;
}

footer h3 {
    margin-bottom: 1rem;
    font-size: 1.6rem;
    color: #FFF;
}

.fa_section {
    text-align: left;
}

.fa_section h2 {
    text-align: left;
    margin-bottom: 0;
    border-bottom: 1px solid #DDDDDD;
    padding-bottom: 10px;
}

.course_row {
    padding: 0 80px;
    font-size: 19px;
    font-weight: normal;
    border-bottom: 20px solid transparent;
    position: relative;
    box-sizing: border-box;
    display: flex;
}

.nohero .course_row {
    padding: 0;
}

.course_row .controls {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    background: #dbe1e3;
}

.expand_text,
.contract_text {
    font-size: 12px;
    color: #2394dd;
}

.expand_text:hover,
.contract_text:hover {
    cursor: pointer;
    color: #34b78f;
}

.full_description {
    display: none;
}

.course_row .course_list_content {
    padding: 0;
    position: relative;
    width: 100%;
}

.course_row .controls span,
.course_row .controls a {
    padding: 12px 10px 10px 10px;
    box-sizing: border-box;
    display: block;
    border: none;
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    width: 33.3%;
    line-height: 22px;
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
}

.course_list_content .course_data {
    display: flex;
    flex-wrap: wrap;
    background: #eceff0;
}

.course_row .course_name {
    box-sizing: border-box;
    display: inline-block;
    width: calc(100% - 460px);
    padding: 15px 20px;
    font-size: 30px;
    font-family: sofia-pro, sans-serif;
}

.course_row .course_price {
    font-family: sofia-pro, sans-serif;
    box-sizing: border-box;
    float: right;
    display: inline-block;
    padding: 20px 20px 20px 20px;
    vertical-align: top;
    width: 260px;
    text-align: center;
    font-size: 20px;
}

.course_row .course_price b {
    font-size: 62px;
    font-weight: 500;
}

.course_price img {
    display: block;
    width: 75%;
    margin: 10px auto;
}

.course_list_image {
    width: 200px;
}

.course_list_image img {
    display: block;
    width: 100%;
    margin: 0;
}

.course_row a .material-icons {
    position: relative;
    top: 6px;
    line-height: 7px;
}

.booking_thanks {
    border: 1px solid #dddddd;
    padding: 0 20px 20px 32px;
    background: #ededed;
}

.refresher-course-item {
    display: flex;
    padding: 16px 0 0 0;
    margin: 16px 0 0 0;
    border-top: 1px solid #512683;
    justify-content: space-between;
    align-items: center;
}

.refresher-course-item a.link-button {
    margin:0;
}

.refresher-type-header {
    margin-top:48px;
    gap:16px;
    align-items:center;
}

.refresher-type-header img {
    border-radius:8px;
    display:block;
    width:60px;
}

.list_description {
    font-size: 16px;
    color: #4f4f4f;
    font-weight: 500;
    margin: 0;
    display: block;
    margin-top: 20px;
    font-family: lato, sans-serif;
}

.course_row .controls a:hover {
    cursor: pointer;
}

.course_row .controls a.info {
    background: #285f81;
    color: #FFFFFF;
}

.course_row .controls a.info:hover {
    background: #0494c9;
    color: #FFFFFF;
}

.course_row .controls a.book {
    background: #009949;
    color: #FFFFFF;
}

.course_row .controls a.book.enquiry {
    background: #512683;
}

.course_row .controls a.book:hover {
    background: #05d568;
    color: #FFFFFF;
}

.course_row .controls a.book.enquiry:hover {
    background: #7d0828;
    color: #FFFFFF;
}

/* Accreditation */
.tlt_accreditation {
    display: flex;
    text-align: center;
}

.tlt_accreditation h4 {
    margin: 30px 0 0 0;
    font-weight: 600;
}

.tlt_accreditation div:first-of-type {
    margin-right: 5%;
}

.tlt_accreditation div {
    padding: 60px 40px 40px 40px;
    background: #ededed;
}

.tlt_accreditation ol {
    margin: 40px 0 40px 13%;
    padding: 0;
    text-align: left;
    font-size: 0.9em;
}

.row_top.row_accreditation h1,
.row_top.row_accreditation h2 {
    width: 100%;
    text-align: left;
}

.row_top.row_accreditation h1 {
    margin-bottom: 20px;
}

.setting_contact h3 {
    position: relative;
    margin-bottom: 20px;
}

.setting_contact h3:before {
    content: "";
    display: block;
    height: 4px;
    width: 80px;
    background: #9e8f70;
    position: relative;
    margin-bottom: 24px;
}

.setting_contact a {
    display: inline-block;
    clear: left;
    padding: 10px 40px;
    background: #9e8f70;
    color: #FFFFFF;
    border-radius: 3px;
    border: none;
    font-size: 0.9em;
    font-weight: 600;
}

.setting_contact.accreditation_platinum h3:before,
.setting_contact.accreditation_platinum a {
    background: #a8a1a2;
}

.setting_contact a:hover {
    background: #009949;
    color: #FFFFFF;
    transition: background ease 0.7s;
}

.accreditation_intro {
    margin-bottom: 20px;
}

.accreditation_status {
    font-style: italic;
}

.accreditation_mark {
    margin-top: 4em;
    padding: 40px;
    border: 1px solid #dddddd;
    box-sizing: border-box;
    text-align: center;
}

.accreditation_mark img {
    display: block;
    margin: 10px auto 40px auto;
    width: 77%;
}

.setting_phone {
    margin: 20px 0;
}

.setting_address span {
    display: block;
}

#accrediationSearch {
    box-sizing: border-box;
    padding: 40px 80px;
    background: #ededed;
}

.venue-finder h4 {
    font-size: 1.2rem;
    font-weight: 500;
    margin: 0.5rem 0;
}

#venueSearch {
    padding: 0;
    box-sizing: border-box;
}

.venue_sessions {
    padding: 40px 80px;
}

table.venue_courses {
    width: 100%;
    border-collapse: collapse;
}

.venue_courses td,
.venue_courses th {
    padding: 0.5rem;
    border-bottom: 1px solid #dddddd;
}

.venue_courses td .additional {
    font-weight: 500;
}

.venue_courses th {
    font-family: sofia-pro, sans-serif;
    font-weight: 500;
    text-align: left;
}

.venue-session {
    display: none;
}

.venue-session.show {
    display: table-row;
}

.venue-session:hover td {
    transition: 0.5s;
    background: #f4f4f4;
}

#venueSearch {
    margin-bottom: 20px;
    padding: 7px 20px 6px 20px;
    background: #512683;
    background: var(--tlt-purple);
    border-radius: 10px;
    color: #FFFFFF;
    display:flex;
    align-items: center;
}

#accrediationSearch h3,
#venueSearch h3 {
    margin: 0 0 20px 0;
    color: #4f4f4f;
}

#accrediationSearch input {
    font-size: 1.3em;
    padding: 20px;
    background: #FFFFFF;
    border: none;
    outline: none;
    color: #4f4f4f;
    width: 77%;
    display: inline-block;
    box-sizing: border-box;
}

#venueSearch input {
    border: 2px solid transparent;
    border-radius: 5px;
    padding: 6px 10px 6px 10px;
    color: #212121;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 0 0 0 16px;
    max-width: 100%;
    box-sizing: border-box;
    outline: none;
}

#venueSearch input:focus {
    border: 2px solid #6f71d7;
}

#accrediationSearch button,
#venueSearch button {
    font-size: 1.3em;
    padding: 20px;
    background: #a7a1a2;
    border: none;
    outline: none;
    color: #FFFFFF;
    width: 20%;
    margin-left: 3%;
    display: inline-block;
    box-sizing: border-box;
}

/* Venue styles */

.venue_info {
    font-size: 0.9rem;
    padding: 1rem;
    font-family: sofia-pro,sans-serif;
}

.venue_info h4 {
    font-size: 1rem;
    margin: 0.25rem;
}

.venue_info p {
    margin-top: 0;
    line-height: 1.2rem;
}

.explore_venue {
    text-decoration: none;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    font-weight: 600;
    border-radius: 3px;
    padding: 0.25rem 1rem;
    display: inline-block;
}

.explore_venue:hover {
    transition: all ease 0.7s;
    color: #FFFFFF;
    background: #479667;
    text-decoration: none;
}

.venues-page .flex-container {
    height: 100%;
    overflow: hidden;
    position:relative;
    flex-wrap:wrap;
}

.col_1_2.venues-map,
.venues-map {
    width:100%;
}

.venues-page h1.no-margin-header {
    margin-bottom:0;
}

.venues-page .current-course-finder.ccf-page .course-finder-container {
    width:100%;
    margin:0;
    padding: 6px 15px;
}

.venues-page h4 {
    margin: 10px 0;
    color:#502682;
    font-weight:600;
}

#mapCanvas {
    min-height: 440px;
    position: relative;
    width: 100%;
    text-align: center;
    border-radius:10px;
    max-width:440px;
    margin:88px auto 20px auto;
}

.venues-page #mapCanvas {
    max-width:100%;
    margin:20px auto;
}

.venue_list {
    list-style-type: none;
    padding: 0;
    margin: 0;
    font-family: sofia-pro, sans-serif;
}

.venue_info h3 {
    border-bottom: 2px solid #C1272D;
    display: inline-block;
    padding-right: 40px;
    margin-top: 1em;
}

.venue_address {
    box-sizing: border-box;
    padding: 20px 40px;
    background: #ededed;
    margin-right: 10%;
}

.venues-page {
    padding-top: 36px;
    position: relative;
    z-index: 3;
}

.venue_list li a {
    box-sizing: border-box;
    border-bottom: none;
    font-size: 1em;
    color: #4f4f4f;
    text-decoration: none;
    transition: all ease 0.7s;
    padding: 0.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #CCCCCC;
}

.venue_list li a:hover {
    text-decoration: none;
    transition: all ease 0.7s;
    color: #479667;
}

.venue_list .venue-name {
    font-weight: 600;
}

.venue_list a .view_info {
    font-size: 0.9rem;
    padding: 8px 16px 10px 16px;
    background: #512683;
    color: #FFFFFF;
    border-radius: 25px;
    max-width: 200px;
    display: flex;
}

.venue_list a .view_info .material-icons {
    display:none;
    position: relative;
    top: 6px;
    margin-right: 5px;
}

.venue_list a:hover .view_info {
    background: #479667;
    transition: all ease 1s;
}

.location_data {
    background: rgb(142, 18, 52);
    color: #FFFFFF;
    position: absolute;
    left: 00px;
    bottom: 00px;
    box-sizing: border-box;
    padding: 30px 30px 75px 30px;
    font-size: 20px;
    width: 50%;
    line-height: 32px;
}

.location_data .fa {
    margin-right: 5px;
}

.location_data a {
    color: #FFFFFF;
    line-height: 24px;
    padding: 12px 20px;
    background: #512683;
    display: inline-block;
    border-radius: 0;
    font-size: 22px;
    font-weight: 500;
    text-decoration: none;
    transition: all ease 0.7s;
    bottom: 0;
    position: absolute;
    width: 100%;
    left: 0;
    box-sizing: border-box;
    text-align: right;
}

.location_data a:hover {
    background: #34b78f;
    transition: all ease 0.7s;
}


#accrediationSearch button:hover {
    cursor: pointer;
    background: #512683;
    color: #FFFFFF;
    transition: background ease 0.7s;
}

#accreditationResults {
    display: table;
    width: 100%;
}

.accreditation-page .col-1-3 {
    padding: 1rem 2rem 1rem 0;
}

.accreditation-page .col-1-3 img {
    display: block;
    width: 100%;
}

.accreditation_item_row {
    display: table-row;
    box-sizing: border-box;
    font-size: 1.2em;
}

.accreditation_item_row .logo {
    width: 9%;
    display: table-cell;
    padding: 10px;
    border-bottom: 1px solid #DDDDDD;
}

.accreditation_item_row .logo img {
    width: 180px;
    margin: 10px auto;
    display: block;
}

.accreditation_item_row .setting_name {
    display: table-cell;
    width: 70%;
    padding: 10px 20px;
    vertical-align: middle;
    border-bottom: 1px solid #DDDDDD;
}

.accreditation_item_row a.info_link .material-icons {
    position: relative;
    top: 6px;
}

.accreditation_item_row a.info_link {
    display: table-cell;
    width: 15%;
    text-align: center;
    color: #4f4f4f;
    text-decoration: none;
    vertical-align: middle;
    border: none;
    padding: 10px 20px;
    border-bottom: 1px solid #DDDDDD;
    border-left: 1px solid #DDDDDD;
}

.accreditation_item_row a.info_link:hover {
    cursor: pointer;
    background: #512683;
    color: #FFFFFF;
    transition: background ease 0.7s;
}

.prf_controls {
    justify-content: center;
    display: flex;
}

.cb_row .col_1_2 {
    box-sizing: border-box;
    padding: 0 40px 40px 40px;
}

.menu-nav #logoHomeLink {
    display: flex;
    margin: 0;
    text-decoration: none;
    padding: 10px;
    background: #FFFFFF;
    box-sizing: border-box;
    align-items: center;
    height: 100%;
    position: relative;
}

.menu-nav #logoHomeLink img {
    width: 170px;
}

.menu-nav nav div.header-social-links {
    width: 100%;
    position: relative;
    top: 0;
    display: flex;
    flex-wrap: wrap;
    background: #4B4C95;
    min-height: 37px;
}

.menu-nav nav div.header-social-links a {
    width: 25%;
    text-decoration: none;
    display: block;
    box-sizing: border-box;
    flex-grow: 1;
    padding: 0.5rem;
    transition: 0.7s;
    text-align: center;
}

.menu-nav nav div.header-social-links a i {
    top: 0;
    margin: 0;
}

.nav-social a:hover,
.header-social-links a:hover {
    text-decoration: none;
    transition: .7s;
}

.nav-social a.hsl-youtube:hover,
.header-social-links a.hsl-youtube:hover {
    background: #cc181e;
    color: #FFFFFF;
}


.nav-social a.hsl-facebook:hover,
.header-social-links a.hsl-facebook:hover {
    background: #3b5998;
    color: #FFFFFF;
}

.nav-social a.hsl-twitter:hover,
.header-social-links a.hsl-twitter:hover {
    background: #00aced;
    color: #FFFFFF;
}

.nav-social a.hsl-instagram:hover,
.header-social-links a.hsl-instagram:hover {
    background: #f09433;
    background: -moz-linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    background: -webkit-linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);
    background: linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f09433', endColorstr='#bc1888',GradientType=1 );
    color: #FFFFFF;
    transition: background .7s;
}

.menu-nav nav > a {
    height: auto;
}

.tb_social a, .tb_social a:visited {
    color: #FFFFFF;
}

.tb_social a {
    padding: 10px;
    box-sizing: border-box;
}

.tb_social a.twitter {
    position: relative;
    top: 1px;
    left: 2px;
}

.slide_feature {
    position: absolute;
    right: 40px;
    bottom: 40px;
    width: 300px;
    text-align: center;
}

.slide_feature a,
.slide_feature a:hover {
    background: transparent;
}

.slide_feature img {
    display: block;
    width: 100%;
}

.v2_page {
    padding: 0 20px;
}

.v2_page .row {
    background: #ededed;
}

.v2_page .row.course_content {
    background: #d5cfbe;
}


.v2_page .row.page_intro {
    background: #ededed;
    margin-bottom: 0;
    padding: 40px;
    position: relative;
    background: #FFFFFF;
    margin: 0 auto;
    text-align: left;
    box-sizing: border-box;
    box-shadow: 0 0 24px rgba(0,0,0,0.25);
    display: flex;
    flex-wrap: wrap;
}

.v2_page .row.page_intro h1,
.v2_page .row.page_intro p {
    text-align: left;
    padding: 0;
}

.v2_page .row_center {
    padding: 0;
    margin: 0 auto;
}

.v2_page .row_center.related_courses {
    margin-top: 0;
}

.v2_page .row_center.related_courses h2:after {
    display: none;
}

.v2_page .course_list_content .course_data {
    background: #FFFFFF;
    border-bottom: 3px solid #dcdcdc;
}

.v2_page .course_row,
.v2_page .row_center.related_courses h2 {
    padding: 0;
}

.v2_page .course_row .course_data {
}

.v2_page .course_row .course_data .course_name {
    width: calc(52% - 200px);
    font-weight: 600;
    font-size: 26px;
    padding: 20px;
}

.v2_page .course_row .course_data .course_price {
    width: 28%;
}

.v2_page .course_row .course_data .controls {
    display: block;
    width: 20%;
    box-sizing: border-box;
    padding: 20px;
    background: #FFFFFF;
}

.v2_page .course_row .controls span,
.v2_page .course_row .controls a {
    width: 100%;
    margin: 10px 0;
}

.v2_page .course_price > div {
    display: flex;
    align-items: center;
}

.v2_page .course_price > div > * {
    font-size: 12px;
    padding: 10px;
    width: 40%;
}

.v2_page .course_price > div.price_1 > strong {
    font-size: 44px;
    font-weight: 600;
}

.v2_page .course_price .price_note {
    text-align: left;
}

.v2_page .course_price .price_from {
    text-align: right;
    width: 20%;
}

.v2_page .course_row .controls span {
    padding: 0;
    font-size: 14px;
}

.v2_page .course_price > div.price_2 > strong {
    font-size: 36px;
    font-weight: 500;
}

.v2_page .course_name a {
    padding: 10px 10px 8px 10px;
    box-sizing: border-box;
    display: block;
    border: none;
    font-size: 16px;
    text-align: center;
    width: 184px;
    line-height: 22px;
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
    background: #2394dd;
    color: #ffffff;
    margin-top: 20px;
    font-weight: 500;
    text-decoration: none;
}

.v2_page .course_name a .fal {
    font-size: 18px;
    position: relative;
    top: 1px;
    margin-right: 3px;
}

.v2_page .course_row .controls a.book.group {
    background: #F45D78;
}

.v2_page .course_row .controls a.book.group:hover {
    background: #d92c4b;
}

.v2_page .promo_image {
}

.v2_page img.promo_image {
    display: block;
    width: 180px;
    float: left;
    margin-right: 10px;
}

.v2_page .title_note {
    font-size: 14px;
    line-height: 20px;
    display: block;
}

#homeAccreditations {
    width: 100%;
    margin: 0 auto;
}

.rf_accreds {
    background: #FFFFFF;
    padding: 40px;
}

.rf_accreds > div h3 {
    color: #512683;
    color: var(--tlt-purple);
}

.rf_accreds .inner {
    max-width: 1440px;
    margin: 0 auto;
}

.rf_accreds .flex-container div {
    display: block;
    width: calc(100% / 6 - 44px);
    max-width: 480px;
    text-align: center;
    box-sizing: border-box;
}

.rf_accreds .flex-container {
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 48px;
}

#homeAccreditations .row_flex > div {
    align-items: center;
    flex-wrap: wrap;
    display: flex
}

.v2_page .row_course_intro h1:after {
    display: none;
}

.v2_page .row_course_intro {
    background: #FFFFFF;
}

.v2_page .course_page_intro {
    width: 80%;
}

.v2_page .page_intro {
    background: #009949;
    padding: 40px;
    color: #FFFFFF;
}

.v2_page .page_intro h1,
.v2_page .page_intro p {
    text-align: left;
    color: #FFFFFF;
    max-width: 80%;
    margin-left: 0;
}

/* webinar row */

.webinar-intro p {
    font-size: 16px;
    line-height: 24px;
}

.event-type {
    display: flex;
    align-items: center;
    background:#FFFFFF;
    color: #512683;
    font-weight: 600;
    padding: 8px 14px 10px 14px;
    border-radius: 7px;
    width: fit-content;
    font-size: 0.9rem;
    font-family: ubuntu, sans-serif;
    margin: 0 0 1rem 0;
}

.event-type svg {
    display:block;
    width:20px;
    fill:#512683;
    margin-right:7px;
}

.rf-webinar {
    background: rgb(220,221,242);
    background: -moz-linear-gradient(90deg, rgba(220,221,242,1) 0%, rgba(255,255,255,1) 50%, rgba(255,255,255,1) 100%);
    background: -webkit-linear-gradient(90deg, rgba(220,221,242,1) 0%, rgba(255,255,255,1) 50%, rgba(255,255,255,1) 100%);
    background: linear-gradient(90deg, rgba(220,221,242,1) 0%, rgba(255,255,255,1) 50%, rgba(255,255,255,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#dcddf2",endColorstr="#ffffff",GradientType=1);
}

.row.rf-webinar.rf-home {
    padding:2rem 0;
}

.row.rf-webinar.rf-home .webinar-item {
    background: #dcddf3;
    padding: 16px;
    border-radius: 8px;
}

.row.rf-webinar.rf-home .webinar-item h5 {
    margin:6px 0;
}

.rf-webinar img {
    display:block;
    width:80%;
    margin:20px;
    border-radius: 20px;
}

.fc-webinars {
    display:flex;
    gap:32px;
}

.row.rf-webinar.rf-home .webinar-item {
    width:calc(33.333% - 22px);
}

.rf-webinar .col-1-2 {
    padding:40px 60px;
}

.rf-webinar .col-1-2:nth-of-type(1) {
    padding-left:0;
}

.rf-webinar h4,
.rf-webinar h5 {
    color:#512683;
}

.rf-webinar h4 {
    font-weight:600;
    margin-bottom:10px;
}

.rf-webinar p {
    color:#512683;
}

.row_course_intro h1 {
}

.row_course_intro h1 .title_note {
    display: block;
    font-size: 19px;
}

.row_course_intro h1:after {
    display: none;
}

.breadcrumb {
    list-style-type: none;
    display: flex;
    margin: 20px 0;
    padding: 0;
    font-family: sofia-pro, sans-serif;
    font-size: 15px;
}

.breadcrumb li {
    margin: 0 5px;
}

.breadcrumb li a,
.breadcrumb li a:visited {
    text-decoration: none;
    color: #999999;
    transition: all ease 0.7s;
}

.breadcrumb li a:hover {
    color: #d5cfbe;
}

.v2_page .row {
    padding: 0 0 40px 0;
}

.v2_page .row.course_notes {
    width: 33%;
    padding: 40px 40px 20px 40px;
    background: #FFFFFF;
    color: #999999;
    box-sizing: border-box;
    font-size: 16px;
}

.v2_page #courseOptions.row {
    text-align: center;
    padding: 40px;
}

#courseOptions h3 {
    color: #FFFFFF;
}

.fa_extras_items h5:first-of-type {
    margin-top: 0;
}

.course_advice .fal,
.fa_extras_items .fal {
    margin-right: 5px;
    color: #d5cfbe;
}

.course_extras .fa_extras_items .fal {
    color: #512683;
    color: var(--tlt-purple);
}

.book_online_results span {
    display: inline-block;
    margin-top: 0px;
    color: #FFFFFF;
    font-family: sofia-pro, sans-serif;
    font-size: 16px;
    font-style: italic;
}

#hero strong {
    color: #FFF;
}

.book_online_results h4 {
    margin: 0.25rem 0;
    font-size: 1.4rem;
    font-weight: 500;
    color: #FFF;
}

.book_online_results input,
.book_online_results select {
    border: 1px solid rgba(0,0,0,0.2);
    padding: 10px;
    color: #4f4f4f;
    font-family: sofia-pro, sans-serif;
    font-size: 19px;
    margin: 10px 0;
    max-width: 100%;
}

.book_online_results input {
    text-transform: uppercase;
    letter-spacing: 1px;
    width: 100px;
    border-radius: 3px;
}

.book_online_results .material-icons {
    line-height: 16px;
    position: relative;
    top: 5px;
}

.book_online_results button {
    border: none;
    padding: 12px 20px;
    color: #4f4f4f;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 20px 0 10px 0;
    font-weight: 500;
    letter-spacing: 1px;
    background: #479667;
    color: #FFF;
    transition: all ease 0.7s;
    border-radius: 3px;
}

.book_online_results button:hover {
    cursor: pointer;
    background: rgba(0,0,0,0.2);
    color: #FFFFFF;
}

.current-courses .search_options {
    display: -webkit-flex;
    display: -webkit-box;
    display: -moz-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    background: #512683;
    background: var(--tlt-purple);
    border-radius: 20px;
    padding: 10px;
    align-items: center;
    color: #FFFFFF;
    margin: 0.5rem 0;
}

.current-courses.is-virtual .ccl-miles,
.current-courses.is-virtual .search_options {
    display: none;
}

.current-courses .search_options > div:nth-child(1) {
    width: 60%;
    box-sizing: border-box;
}

.current-courses .search_options > div:nth-child(2) {
    width: 40%;
    box-sizing: border-box;
    display: flex;
    align-items: center;
}

.current-courses .search_options > div:nth-child(2) > div {
    padding: 0 1rem;
}

ul.sessions li.ccl_results_labels {
    display: flex;
    padding: 0;
    background: #EDEDED;
    margin: 0;
    text-decoration: none;
    color: #4f4f4f;
    align-items: center;
    border-top: none;
    font-weight: 600;
    border-radius: 12px;
}

.ccl_results_labels > span {
    padding: 0.5rem 1rem;
}

.ccl_address {
    font-weight: 500;
}

.ccl_additional_dates {
    display: flex;
    flex-direction: column;
    font-weight: 500;
}

ul.sessions li.selected a.book-now,
.book_button,
.full_button {
    border: none;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 20px 0 10px 0;
    font-weight: 500;
    color: #FFFFFF;
    background:#34b78f;
}

.book_button {
    background:none;
}

.full_button {
    background: none;
    color: #FFFFFF;
    display: inline-block;
    margin: 0;
}

.full_button .full_label {
    font-weight: 600;
}


.full_button .add_to {
    font-size: 12px;
}

ul .sessions li.selected a.book-now {
    text-align: center;
    width: 270px;
    display: block;
    font-size: 17px;
    padding: 6px 20px 10px 20px;
}

.current-courses .course_list .sessions li.selected {
    background: transparent;
}

.book-now .book_price,
.book_button .book_price {
    margin: 0 10px 0 5px;
    font-size: 26px;
    top: -4px;
    position: relative;
    display: inline-block;
}

ul.sessions li.selected a.book-now:hover,
.book_button:hover {
    background: #479667;
    cursor: pointer;
}

.li_option {
    font-size: 17px;
}

::-webkit-input-placeholder { /* Chrome/Opera/Safari */
    color: #CCCCCC;
}

::-moz-placeholder { /* Firefox 19+ */
    color: #CCCCCC;
}

:-ms-input-placeholder { /* IE 10+ */
    color: #CCCCCC;
}

:-moz-placeholder { /* Firefox 18- */
    color: #CCCCCC;
}

h2 span.light,
h3 span.light {
    font-weight: 500;
    font-style: italic;
    font-size: 19px;
    color: #512683;
    color: var(--tlt-purple);
}

h3.book_results {
    line-height: 2rem;
    margin: 0;
    padding: 1rem 0rem;
    font-size: 1.5rem;
    color: #512683;
    color: var(--tlt-purple);
}

.current-course-finder h3.book_results {
    font-size: 36px;
    margin: 20px 0;
    color: #512683;
    line-height: 44px;
    font-weight:600;
}

.current-course-finder h1 {
    color: #512683;
    font-size: 20px;
    font-weight: 500;
    margin: 0;
}

.book_client_venue {
    font-family: sofia-pro, sans-serif;
    letter-spacing: 1px;
    border-radius: 20px;
    background: #dcddf2;
    color: #512683;
}

.book_client_venue > div {
    flex-grow: 1;
}

.book_client_venue p {
    font-size: 0.9rem;
    line-height: 1.2rem;
}

.row_clients {
    color: #512683;
    padding-top: 20px;
    padding-bottom: 60px;
}

#clientList {
    width: 100%;
    height: 140px;
    text-align: center;
}

#clientList li {
}

#clientList li:nth-of-type(2n+1) {
}

#clientList img {
    display: block;
    width: 180px;
}

#clientList li a,
#clientList li a:hover {
    text-decoration: none;
    border: none;
}

.fc-align-center {
    align-items:center;
}

.row_clients h3,
.row_clients h2,
.rf_accreds h3,
.rf_reviews h3,
.rf_reviews h2,
.row-shop h2 {
    padding: 0;
    font-size: 44px;
    font-weight: 600;
    position: relative;
    text-align: center;
    color: #512683;
    color: var(--tlt-purple);
    margin: 20px 0;
}

.rf_reviews h2,
.rf_reviews h3 {
    padding:0;
}

.row-shop {
    background: #FFFFFF;   
}

.row.reviews-carousel {
    background: #dcddf2;
}

.row.reviews-carousel h3 {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 2.4rem;
    color: #512683;
    margin: 0 auto;
    letter-spacing: 0.5px;
    text-align: center;
    max-width: 600px;
}

.row.reviews-carousel .flex-container {
    align-items:center;
}

#reviewsio-carousel-widget {
    background: #cacbe6;
    padding: 24px 0 0 0;
    border-radius: 12px;
    margin: 16px 0;
}

.row-shop h2 {
    text-align:left;
}

.row-shop p {
    color:#512683;
    max-width:480px;
    width:80%;
}

.row-shop img {
    margin:40px auto;
    display:block;
    width:80%;
    max-width:480px;
}

.row_clients h2 a {
    text-decoration: none;
    color: #4f4f4f;
}

.row_clients.side {
    background: #FFFFFF;
}

.row_clients.side h2 {
    font-size: 30px;
    line-height: 36px;
}


.row_clients.side #clientList li {
    width: 50%;
}

.sorting button {
    border: none;
    padding: 0.5rem 1rem;
    font-family: sofia-pro, sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 1px;
    background: #e4e4e4;
    color: #FFFFFF;
    transition: all ease 0.7s;
    margin: 1rem;
    color: #4f4f4f;
    border-radius: 3px;
}

.sorting button:hover {
    cursor: pointer;
    background: #DDDDDD;
}

.sorting button.selected,
.sorting button.selected:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    cursor: default;
}

ul.sessions {
    list-style: none;
    margin: 0;
    padding: 0;
}

ul.sessions li {
    font-family: sofia-pro, sans-serif;
}

ul.sessions li {
    display: flex;
    padding: 1rem 0;
    background: #FFFFFF;
    margin: 0;
    text-decoration: none;
    color: #512683;
    color: var(--tlt-purple);
    align-items: center;
    border-top: 1px solid #DDDDDD;
}

ul.sessions li:first-of-type {
    border:none;
}

ul.sessions li.selected a,
ul.sessions li a:hover {
    background: #EDEDED;
    cursor: pointer;
}

ul.sessions li.full a {
    background: #e11446;
    border-color:#e11446;
    color: #FFFFFF;
}

ul.sessions li.full a:hover {
    background: #b5002c;
    border-color:#b5002c;
    color: #FFFFFF;
}

ul.sessions li > span,
ul.sessions li > div {
    padding: 0.5rem 1rem 0.7rem 1rem;
    box-sizing: border-box;
}

.ccl_course-title {
        display:none;
}

ul.sessions li > div.ccl-controls {
    padding: 0;
    display: flex;
    justify-content: stretch;
}

ul.sessions li a {
    text-decoration: none;
    flex-grow: 1;
    border-radius:25px;
    padding:6px 20px 8px 20px;
    border:2px solid #479667;
    display: flex;
    align-items: center;
    justify-content: center;
}

ul.sessions li a:hover {
    background:#479667;
    color:#FFFFFF;
}

ul.session-options {
    list-style: none;
    margin: 0;
    padding: 0;
}

ul.sessions li a.ccl_info,
ul.sessions li.full a.ccl_info {
    vertical-align: middle;
    text-align: center;
    display: inline-block;
    padding: 6px 20px 8px 20px;
    box-sizing: border-box;
    border: 2px solid #512683;
    font-family: sofia-pro, sans-serif;
    flex-grow: 0;
    width: 80px;
    margin-left: 10px;
    color: #512683;
    background:#FFFFFF;
}

ul.session-options li {
    padding: 10px;
}

ul.sessions li .book_button {
    font-size: 1rem;
    font-weight: 500;
    text-decoration: none;
    color: #479667;
    display: block;
    margin: 0;
    flex-grow: 1;
    text-align: center;
    background:none;
}

ul.sessions li .book_button i {
    position:relative;
    top:2px;
    left:4px;
}

ul.sessions li a:hover .book_button {
    color:#FFFFFF;
}

ul.sessions li a.ccl_info:hover {
    background:#512683;
    color:#FFFFFF;
}

.venue-search {
    padding: 2rem 0;
    width:100%;
}

.venue-search h4 {
    margin: 0.5rem 0;
    font-weight: 500;
    font-size: 1.2rem;
    color: #512683;
    color: var(--tlt-purple);
}

.venue-data {
    background: #512683;
    background: var(--tlt-purple);
    color: #ffffff;
    border-radius: 3px;
}

.venues-page .venue-search h4 {
    color: #FFF;
}

.venues-page .venue-data h4 {
    color: #FFFFFF;
}

.venue-address,
.venue-notes {
    display: flex;
    padding-right:40px;
}

.venue-address i,
.venue-notes i {
    font-size: 2rem;
    padding: 0.25rem 1rem 0 0;
}

.venue-notes {
    margin-top:20px;
}

.venue-address {
    line-height: 1.4rem;
}

.venue-courses {
    margin: 1rem 0 0.5rem 0;
    font-family: sofia-pro,sans-serif;
}

.venue-courses .course-finder-container {
    width:60%;
}

.session-options-container h5 {
    margin: 0 0 12px 0;
    font-size: 17px;
    font-weight: 600;
}

.venue-courses a {
    text-align: center;
    font-size: 0.9rem;
    padding: 0.5rem;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    border-radius: 3px;
    display: block;
    min-width: 100px;
}

.venue-courses a.full {
    background: #512683;
}

.venue-courses .no-courses {
    padding: 1rem;
}

.venue-courses .no-courses a {
    display: inline-block;
    background: none;
    padding: 0;
    color: #479667;
    text-decoration: underline;
}

.venue-courses .no-courses a:hover {
    color: #512683;
    color: var(--tlt-purple);
    background: none;
}

table.venue_courses {
    margin-top: 1em;
}

table.venue_courses th {
    background: #f4f4f4;
}

.venue-courses a:hover {
    transition: 0.7s;
    background: #479667;
    cursor: pointer;
}

.venue-courses select {
    border: 2px solid #999999;
    border-radius: 3px;
    padding: 10px;
    color: #212121;
    font-family: sofia-pro, sans-serif;
    font-size: 19px;
    margin: 10px 0 0 0;
    max-width: 100%;
    box-sizing: border-box;
    outline: none;
}

.venue-courses select:focus {
    border: 2px solid #6f71d7;
}

.tlt-selector.course-option-selector {
    background: rgba(0,0,0,0.5);
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
    z-index: 10001;
    top: 0;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 5px -2px rgba(0, 0, 0, 0.25);
}

.tlt-selector.course-option-selector .selector-box {
    width: 90%;
    background: #479667;
    padding: 2rem;
    border-radius: 10px;
    max-width: 480px;
}

.tlt-selector.course-option-selector h5 {
    font-family: sofia-pro, sans-serif;
    color: #FFFFFF;
    font-weight: 600;
    margin: 0 0 1rem 0;
}

.tlt-selector.course-option-selector .selector-items {
    margin: 0;
    padding: 0;
}

.tlt-selector.course-option-selector .selector-items li {
    margin: 0.5rem 0;
    padding: 0.5rem;
    color: #FFFFFF;
    border-radius: 3px;
}

.tlt-selector.course-option-selector .selector-items li .name,
.tlt-selector.course-option-selector .selector-items li .cost {
    font-family: sofia-pro, sans-serif;
    padding: 0.5rem;
    display: inline-block;
}

.tlt-selector.course-option-selector .selector-items li .check {
    background: none;
    color: rgba(255,255,255,0.5);
}

.tlt-selector.course-option-selector .selector-items li .check.checked {
    background: none;
    color: rgba(255,255,255,1);
}

.tlt-selector.course-option-selector .selector-items li {
    background: rgba(0,0,0,0.1);
}

.tlt-selector.course-option-selector .selector-items li:hover {
    background: rgba(0,0,0,0.3);
}

.tlt-selector.course-option-selector .controls button {
    border: none;
    padding: 0.5rem 1rem;
    font-family: sofia-pro, sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 1px;
    background: #512683;
    background: var(--tlt-purple);
    color: #FFFFFF;
    transition: all ease 0.7s;
    margin: 1rem 0.5rem 0 0;
    border-radius: 5px;
}

.tlt-selector.course-option-selector .controls button.cancel {
    background: #ededed;
    color: #4f4f4f;
}

.tlt-selector.course-option-selector .controls button:hover {
    background: rgba(0,0,0,0.3);
    cursor: pointer;
}

.tlt-selector.course-option-selector .controls button.cancel:hover {
    background: #512683;
    color: #FFFFFF;
}

.current-courses .sessions li.selected .session-options-container {
    padding: 20px;
    margin: 0 10px;
    display: block;
    background: #eff4f2;
    border-radius: 15px;
}

.current-courses .course_list .sessions li.selected .session-options li.selected {
    background: #dcddf2;
}

.ccl_date {
    width: 25%;
}

.ccl_primary_date {
    margin-right:0.5rem;
}

.ccl_venue {
    width: 30%;
}

.ccl-controls {
    width: 30%;
    text-align: center;
}

.ccl-miles {
    font-weight:600;
    font-style:italic;
    display:block;
}

.ccl_cost {
    width: 15%;
    text-align: center;
}

ul.sessions li a .controls {
    width: 33%;
    text-align: right;
}

.ko-late-bound {
    font-weight: 500;
}

ul.sessions span.highlight {
    font-weight: 600;
}

.book_client_venue a {
    border: none;
    padding:6px 20px 8px 20px;
    font-family: sofia-pro, sans-serif;
    font-size: 17px;
    margin: 20px;
    font-weight: 500;
    letter-spacing: 1px;
    background: #512683;
    color: #FFFFFF;
    transition: all ease 0.7s;
    text-decoration: none;
    white-space: nowrap;
    border-radius: 25px;
}

.book_client_venue a:hover {
    background: #512683;
    background: var(--tlt-purple);
    color: #fff;
}

.row .book_client_venue p {
    margin-top: 10px;
}

hr {
    border: 0;
    border-bottom: 1px solid rgba(0,0,0,0.2);
    margin: 40px 0;
    height: 1px;
}

.fa_reviews {
    width: 100%;
    background: #FFFFFF;
    padding: 20px 0;
    margin: 20px 0;
}

.fa_accred {
    display: flex;
    align-items: flex-start;
    width: calc(67% - 20px);
    box-sizing: border-box;
    background: #FFFFFF;
    padding: 20px;
    margin: 20px 20px 20px 0;
}

.fa_accred img {
    display: block;
    width: 120px;
}

#fixedReviewWidget {
    position: fixed;
    right: -8px;
    top: 50%;
    margin-top: -100px;
    z-index: 1005;
    max-width: 200px;
    transition: all ease 0.7s;
    height: 175px;
    overflow: hidden;
}

.course-booking-intro {
    display: block;
}

.resp-c2as,
.resp-c2as .course-booking-intro,
.resp-c2as .course-download {
    display: none;
}

.mixed-content-page .col-2-3 {
    padding-right: 6rem;
}

.flex-container.offset-into-hero > .col-2-3 {
    position: relative;
    top: -8rem;
    margin-bottom: -8rem;
    background: #FFF;
    padding: 2rem;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    z-index:1;
}

.flex-container.offset-into-hero.oih-cb > .col-2-3 {
    margin-bottom: -12rem;
}

.flex-container.offset-into-hero > .col-1-3 {
    padding-left: 2rem;
}

.award-logo img {
    display: block;
    width: 80%;
    margin: 1rem auto;
}

#fixedReviewWidget:hover {
    right: -2px;
}

.course_booking {
    padding: 10px 20px;
    font-family: sofia-pro, sans-serif;
}

.highlight-image {
    width: 60px;
    margin: 0.5rem 0;
}

.highlight-image img {
    display: block;
    width: 60px;
    max-height: 80px;
    margin: 0 auto;
}

.ko-static {
    opacity: 0;
}

.partner-list {
    padding: 0 2rem;
    display: flex;
    flex-wrap: wrap;
}

.partner-item {
    width: calc(50% - 2rem);
    padding: 2rem;
    background: #FFFFFF;
    margin-bottom: 4rem;
    box-sizing: border-box;
}

.partner-item:nth-of-type(2n+0) {
    margin-left: 2rem;
}

.partner-item:nth-of-type(2n+1) {
    margin-right: 2rem;
}

.partner-item h3 {
    font-weight: 600;
    color: #512683;
    position: relative;
    margin: 0 0 1rem 0;
    width: 90%;
}

.partner-item .logo {
    width: 30%;
    padding-left: 1rem;
    align-self: center;
}

.partner-item .content {
    width: 100%;
    padding-right: 1rem;
}

.partner-item .logo img,
.partner-item .logo svg {
    display: block;
    width: 100%;
}

.partner-logo {
    display: block;
    float: right;
    width: 195px;
    padding: 1rem 0 1rem 1rem;
}

.grey-bg {
    background: #EDEDED;
}

.in-page-book-online .inner {
    padding:2rem;
    background:#ededed;
}

.in-page-book-online .course-find-start {
    max-width:840px;
    margin:0 auto;
}

.book_online.in-page-book-online input, 
.book_online.in-page-book-online select {
    border: 2px solid #999999;
    border-radius: 3px;
    padding: 10px;
    color: #212121;
    font-family: sofia-pro, sans-serif;
    font-size: 19px;
    margin: 10px 0 0 0;
    max-width: 100%;
    box-sizing: border-box;
    outline: none;
}

.reviews-carousel .col-2-3 {
    padding:2rem;
}


/*
    APP ADJUSTMENTS
*/

body.app #reviewsio-carousel-widget,
body.app .offset-into-hero,
body.app #headerOuter,
body.app #headerOuterSpacer,
body.app .venues-page h1 {
    display:none;
}

body.app .fa-course .offset-into-hero {
    display:flex;
}

body.app .venues-page {
    padding-top:0;
}

body.app .fa-course .flex-container.offset-into-hero > .col-2-3 {
    top:0;
    margin-bottom:0;
}


/*
    MEDIA QUERIES
*/


@media all and (max-width: 1500px) {
    .ig-stat {
        font-size: 3rem;
    }
}

@media all and (max-width: 1280px) {

    .ig-stat {
        font-size: 2.5em;
    }

    .mSCaption h2 {
        font-size: 28px;
    }

    #badge-200 {
        display: none;
    }

    .select-wrapper .options {
        width: 800px;
    }

    div.optgroup {
        width: calc(50% - 1.2rem);
    }
}

@media all and (max-width: 1048px) {


    .filter-row ul {
        flex-wrap: wrap;
    }

    .rf_accreds .flex-container div {
        width: 33.333%;
    }

    .notice-resp {
        display: block;
    }

    .hero-title.notice-resp {
        position: relative;
    }

    #hero {
        min-height: 280px;
        height: 60vh !important;
    }

    .ig-stat {
        font-size: 2em;
    }

    .menu-nav #logoHomeLink {
        display: none;
    }

    .small_screen_logo {
        display: block;
    }

    #fixedReviewWidget {
        display: none;
    }

    .course_list.flex-container {
        grid-template-columns: repeat(2,1fr);
    }

    .mixed-content-page .col-2-3 {
        padding-right: 2rem;
    }

    a.course-item {
        width: calc(50% - 2rem);
    }

    .course-syllabus ul {
        width: 100%;
        box-sizing: border-box;
        padding: 0 0 0 2rem;
    }

    span.expand-link {
        margin-left: 0.5rem;
        margin-top: 1rem;
    }

    h3 {
        font-size: 1.3rem;
    }

    .row.reviews-carousel h3 {
        font-size: 1.5rem;
        line-height: 2rem;
        margin: 0 0 24px 0;
    }

    .reviews-carousel .col-2-3 {
        padding:0;
    }

    .about-page .grey-bg .col-2-3 {
        padding: 2rem 0;
        font-size: 1rem;
    }
}

@media all and (max-width: 768px) {

    .refresher-course-item {
        flex-wrap:wrap;
        gap:16px;
    }

    .refresher-course-item > * {
        width:100%;
    }

    .refresher-course-item > .link-button {
        width:fit-content;
    }

    .row.rf-webinar.rf-home .webinar-item {
        width:100%;
    }

    .ooo-msg {
        flex-wrap:wrap;
    }

    .webinar-item,
    .ooo-image {
        width:100%;
    }

    .ooo-image svg {
        margin:16px auto;
    }

    .policies p {
        width:100%;
    }

    #mapCanvas {
        min-height: 440px;
        max-width:unset;
        margin:20px auto;
    }
    
    .venue_list li a,
    #venueSearch {
        flex-wrap:wrap;
    }

    .venue_list li a > div {
        width:100%;
    }

    .venue_list a .view_info {
        max-width:unset;
        margin: 12px 0 6px 0;
    }

    #venueSearch input {
        margin:0 0 16px 0;
    }

    .venues-page {
        padding-top: 16px;
    }

    .venue-courses .course-finder-container {
        width: 100%;
    }

    .row.reviews-carousel {
        padding: 16px 0;
    }

    .about-page .inner.offset-into-hero h1 {
        padding: 0 0 2rem 0;
        margin: 0;
    }

    #header {
        justify-content: space-between;
    }

    .logo-nav {
        width: calc(100% - 100px);
        display: flex;
        align-items: center;
        justify-content: flex-start;
        flex-grow: 0;
    }

    .menu-nav {
        background: none;
    }

    .filter-row ul {
        display:block;
        padding:0px 16px;
    }

    .quote-mark svg {
        width: 32px;
    }

    .quote-stars svg {
        width: 16px;
        height: 16px;
        margin-right: 4px;
    }

    .venues-page h1, span.h2, h2, .ss-page-title h2 {
        font-size:28px;
    }

    .f-a-c.testimonial-row .testimonial-name,
    .f-a-c.testimonial-row .quote {
        font-size: 17px;
    }

    .menu-nav > div > span {
        display:none;
    }

    .filter-row {
        width: 100%;
        margin: 24px 0;
        padding: 16px;
    }

    .filter-row ul li {
        margin: 8px 0;
    }

    .filter-row ul li span, 
    .filter-row ul li a {
        padding: 6px 12px 8px 12px;
        border-radius: 8px;
        font-size: 16px;
    }

    .course-item h5 {
        font-size: 22px;
        margin: 0 0 8px 0;
    }

    .course-item .course_name {
        padding: 16px 16px 8px 16px;
        width: 100%;
    }

    .course-item .controls a, .course-item .controls span {
        padding: 4px 16px 6px 16px;
        font-size: 16px;
        margin: 8px 0;
    }

    .course_img {
        height: 140px;
    }

    .col-1-1,
    .vacancies-list {
        width:100%;
        margin:0;
    }

    a.job-vacancy-item {
        width:100%;
        margin:32px 0;
    }

    .current-courses .search_options, 
    ul.sessions li {
        flex-wrap:wrap;
    }

    ul.sessions li.ccl_results_labels {
        display:none;
    }

    .ccl_course-title {
        display:block;
    }

    .ccl_course-title,
    .current-courses .search_options > div:nth-child(1),
    .current-courses .search_options > div:nth-child(2),
    .ccl_date,
    .ccl_venue {
        width: 100%;
    }

    .ccl_cost {
        width: 100%;
        text-align: left;
    }

    ul.sessions li > span, ul.sessions li > div {
        padding: 0.5rem 0;
    }
    
    ul.sessions li > div.ccl-controls {
        width: 100%;
        padding: 0.5rem 0;
        text-align: center;
        margin-top: 12px;
    }

    #header {
        align-items: center;
    }

    .logo-home-link img {
        display: block;
        width: 100%;
        max-width: 240px;
    }

    #hero {
        min-height: 280px;
        height: 50vh !important;
    }

    .f-a-c.mSCaption.infoBlockLeft .quote,
    .f-a-c.mSCaption.infoBlockLeft .testimonial-name {
        font-size: 1rem;
        line-height: 1.4rem;
    }

    .flex-container.offset-into-hero > .col-2-3 {
        top: 0;
        margin-bottom:0;
        padding: 0;
    }

    .flex-container.offset-into-hero > .col-1-3 {
        padding-left:0;
    }

    .select-wrapper .options {
        width: 100%;
        flex-wrap: wrap;
    }

    div.optgroup {
        width: calc(100% - 1.2rem);
    }

    .site-msg-tab {
        top: 200px;
    }


    #homeAccreditations img {
        height: unset;
        width: 100%;
    }

    .course-syllabus {
        padding: 1rem;
        margin: 2rem 0;
    }

    .course_text h3 {
        width: 100%;
        font-size: 1.3rem;
    }

    .eld-smoke h2,
    .eld-smoke span {
        font-size: 1.2rem;
    }

    .eld-smoke img {
        width: 120px;
    }

    .eld-rocket {
        width: 150px;
        bottom: 210px;
        margin-left: -75px;
    }

    .main_menu .col-1-3 {
        width: 100%;
        padding: 20px 40px;
    }

    .course-item {
        width: 48%;
    }

    #hero.courses-page {
        display: none;
    }

    #headerOuter {
        box-shadow: 0px 1px 10px 0px rgba(0,0,0,0.1);
    }

    .home-benefits-row .title-container h3 {
        font-size: 1.8rem;
    }

    .fr-courses .col_3_4,
    .fr-courses .col_1_4 {
        width: 100%;
    }

    /* Course detail */

    .flex-container {
        flex-wrap: wrap;
    }

    .course-booking-intro,
    .course-download,
    .mixed-content-page .rf_reviews {
        display: none;
    }

    .resp-c2as {
        margin: 2rem 0;
    }

    .col-2 {
        column-count: 1;
    }

    .resp-c2as,
    .resp-c2as .course-booking-intro,
    .resp-c2as .course-download {
        display: block;
    }

    .partner-item,
    .rf_accreds .flex-container div,
    .col-1-2,
    .col_1_2,
    .col-1-3,
    .col-2-3,
    .row_flex > div.col_1_2,
    .col-2-5,
    .col-3-5,
    .flex_row .col_1_2 {
        width: 100%;
    }

    .flex-container.offset-into-hero.oih-cb > .col-2-3 {
        margin-bottom: 0;
    }

    .cb_row .col_1_2 {
        padding: 16px 0;
    }

    .partner-logo {
        width: 100%;
    }

    .col_1_3.vcard,
    .partner-item .content,
    .partner-list {
        padding: 0;
    }

    .partner-item h3 {
        overflow-wrap: break-word;
    }

    .partner-item:nth-of-type(2n+1) {
        margin-right: 0;
    }

    .partner-item:nth-of-type(2n+0) {
        margin-left: 0;
    }

    .mixed-content-page .course-audience .col-2-3,
    .mixed-content-page .col-2-3 {
        padding-right: 0rem;
    }

    .rf_accreds .flex-container div {
        margin: 1rem 0;
        width: 15%;
        padding: 1rem;
    }

    .rf_accreds {
        padding: 1rem;
    }

    .rf_accreds .flex-container {
        padding: 0;
    }

    .img_caption_below {
        font-size: 0.75rem;
    }

    .home-benefits-row > div {
        padding: 40px;
    }

    .home-benefits-row ul li {
        background-size: 30px;
        padding: 10px 20px 10px 50px;
        font-size: 1rem;
    }

    .cb_row .prf_group {
        padding: 10px;
    }

    .hbr-training .text-container:before,
    .hbr-tlt .text-container:before {
        display: none;
    }

    .v2_page .course_data .course_list_image {
        display: none;
    }

    .v2_page .course_row .course_data .course_name,
    .v2_page .course_row .course_data .course_price,
    .v2_page .course_row .course_data .controls {
        width: 100%;
    }

    .book-in-house-form input, .book-in-house-form select, .book-in-house-form textarea {
        width: 100%;
    }

    .hero_text h2 {
        font-size: 30px;
    }

    .mSCaption h2 {
        font-size: 24px;
    }

    .hero_tigerlily_logo {
        width: 240px;
    }

    .menu-nav nav .main_menu,
    .menu-nav nav .sub_menu {
        overflow-y: auto;
        height: calc(100vh - 210px);
    }

    .menu-nav nav .main_menu .flex_col > div,
    .menu-nav nav .sub_menu > div {
        width: 100%;
    }

    .topbar {
        flex-wrap: wrap;
        padding: 10px;
    }

    .topbar > div,
    .topbar > div.tb_login {
        flex-grow: 0;
        width: 50%;
        text-align: center;
        margin: 5px 0;
    }

    .topbar > div.tb_call {
        width: 70%;
    }

    .topbar > div.tb_login {
        width: 30%;
    }

    .small_screen_lose {
        display: none;
    }

    .small_screen_show {
        display: inline-block;
    }

    #clientList li {
        width: 25%;
        padding: 20px;
    }

    .row_clients.side #clientList li {
        width: 100%;
    }

    .logo-home-link:after,
    .menu-nav em,
    .menu-nav .contact-us,
    .logo-nav .nav,
    .header-social-links {
        display: none;
    }

    .logo-home-link {
        width: 80%;
    }

    nav {
        height: calc(100vh - 100px);
        overflow-x: hidden;
        overflow-y: scroll;
        -ms-overflow-style: none;
        -webkit-overflow-scrolling: touch;
    }
}

@media all and (max-width: 600px) {

    .rf_accreds .flex-container div {
        width: 50%;
    }

    a.course-item,
    div.course-item {
        width: 100%;
        margin: 1rem 0;
    }


    .hero_text,
    .mSCaption.infoBlockLeft {
        padding: 2rem 5% 7rem 5%;
    }

    @media all and (max-width: 480px) {

        h1 {
            font-size: 2rem;
        }

        .logo-home-link {
            padding: 1rem 1rem 0.5rem 1rem;
        }

        .logo-home-link img {
            max-width: 200px;
            margin: auto;
        }

        .menu-nav {
            width: 100px;
        }

        .course_list.flex-container {
            grid-template-columns: repeat(1,1fr);
        }

        #clientList li {
            width: 50%;
            padding: 20px;
        }

        .book_course h2 {
            font-size: 19px;
            font-weight: 600;
            margin-top: 0;
        }

        #home-testimonials-list {
            display: none;
        }

        .menu-nav nav div > span,
        .menu-nav nav div a {
            font-size: 14px;
        }

        .hero_links {
            display: block;
        }

        .mSCaption .hero_links a.hero_info_link,
        .mSCaption a {
            padding: 7px;
            font-size: 15px;
            margin-bottom: 10px;
        }

        .mSCaption .hero_links a {
            margin-bottom: 10px;
        }

        .mSCaption.infoBlockLeft span {
            display: none;
        }

        .col_1_3 {
            padding: 20px;
        }

        .hero_tigerlily_logo {
            width: 160px;
        }

        .mm_contact,
        .menu-nav nav .main_menu .flex_col div,
        .menu-nav nav .sub_menu > div {
            padding: 20px;
        }

        .course-title {
            font-weight: 900;
            font-size: 18px;
        }

        .currency.gbp {
            font-weight: 600;
            margin: 0 20px 0 0;
            padding: 5px 0;
            font-size: 24px;
            width: 100%;
        }

        #headerOuterSpacer {
            height: 147px;
        }
    }

    @media screen and (max-height: 680px) {
        .logo-nav .nav ul .subnav {
            overflow-y: scroll;
            max-height: 400px;
        }
    }
