/*

	enbox public site stylesheet.
	author: cfront (sabn)
	created: 21-3-18
	
	fonts:
	
	
	colors:
    blue: #0075B2;

*/

* {
    box-sizing: border-box;
}

html {
    overflow-y: visible;
}

body {
    margin: 0;
    padding: 0;
    font-size: 19px;
    font-family: 'Mulish', sans-serif;
    color: #7f7f7f;
}


.no-scrollbar::-webkit-scrollbar {
    display: none;
}

.no-scrollbar {
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
}

h1, h2, h3, h4, h5 {
    font-weight: 700;
}

h1 {
    font-size: 48px;
    letter-spacing: 1px;
    color: #0075b2;
}

.slide_caption h1,
#hero h1 {
    color: #FFFFFF;
}

h2 {
    font-size: 44px;
}

h3 {
    font-size: 30px;
}

h4 {
    font-size: 26px;
}

h5 {
    font-size: 22px;
}

p {
    line-height: 30px;
}

a {
}

a:hover {
}

.faq_section {
}

a.page-notice {
    display: block;
    text-align: center;
    background: #0075b2;
    font-size: 1.2rem;
    color: #FFFFFF;
    padding: 0.5rem;
    text-decoration: none;
    transition: 0.7s;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    font-weight: 600;
    z-index: 3;
}

a.page-notice:hover {
    text-decoration: none;
    background: #004163;
}
/*
    PRICING
*/
.contact-us-button a {
    padding: 11px 1rem 12px 1rem;
    border-radius: 8px;
    color: #FFFFFF;
    background: #0075b2;
    text-decoration: none;
    font-size: 1.5rem;
    font-weight: 600;
    transition: 0.6s;
    margin: 2rem auto 4rem auto;
    display: block;
    width: calc(33.333% - 2rem);
    text-align: center;
    min-width: 220px;
}

.contact-us-button a:hover {
    background: #004868;
}

.special-intro {
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
    line-height: 2.8rem;
}

.special-intro p {
    line-height: 2.8rem;
}

.special-intro a {
    color: #0075b2;
    font-weight: 600;
}

.special-intro a:hover {
    color: #004868;
}

.flex-container {
    display: flex;
    flex-wrap: wrap;
}

.pricing-item.col-1-3 {
    width: calc(33.333% - 2rem);
    margin: 1rem;
    border-radius: 20px;
    background: #FFFFFF;
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
}

.pricing-item.col-1-3:nth-of-type(1),
.pricing-item.col-1-3:nth-of-type(3) {
    margin-top: 112px;
}

.pi-head {
    padding: 1rem;
    background: #ededed;
    text-align: center;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
}

.s61 .pi-head {
    color: #004868;
    background: rgb(231,247,11);
    background: -moz-linear-gradient(180deg, rgba(231,247,11,1) 0%, rgba(211,226,0,1) 100%);
    background: -webkit-linear-gradient(180deg, rgba(231,247,11,1) 0%, rgba(211,226,0,1) 100%);
    background: linear-gradient(180deg, rgba(231,247,11,1) 0%, rgba(211,226,0,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#e7f70b",endColorstr="#d3e200",GradientType=1);
}

.enbox-live .pi-head {
    color: #FFFFFF;
    background: rgb(0,117,178);
    background: -moz-linear-gradient(180deg, rgba(0,117,178,1) 0%, rgba(0,59,89,1) 100%);
    background: -webkit-linear-gradient(180deg, rgba(0,117,178,1) 0%, rgba(0,59,89,1) 100%);
    background: linear-gradient(180deg, rgba(0,117,178,1) 0%, rgba(0,59,89,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#0075b2",endColorstr="#003b59",GradientType=1);
}

.bespoke .pi-head {
    color: #FFFFFF;
    background: rgb(0,72,104);
    background: -moz-linear-gradient(180deg, rgba(0,72,104,1) 0%, rgba(0,36,52,1) 100%);
    background: -webkit-linear-gradient(180deg, rgba(0,72,104,1) 0%, rgba(0,36,52,1) 100%);
    background: linear-gradient(180deg, rgba(0,72,104,1) 0%, rgba(0,36,52,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#004868",endColorstr="#002434",GradientType=1);
}

.pi-price {
    padding: 1rem;
    text-align: center;
    color: #004868;
}

.pi-price h3 {
    font-weight: 900;
    font-size: 3.6rem;
    margin: 0.5rem 0;
}

.pi-head h2 {
    font-size: 2rem;
    margin: 1rem 2rem;
}

.head-sub {
    padding-bottom: 1rem;
    font-size: 1.5rem;
    font-weight: 700;
}

.price-note {
    color: #686E71;
    font-size: 1rem;
}

.pi-features {
    color: #333333;
    font-size: 1rem;
    padding: 0 2rem 2rem 2rem;
}

.feature-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 1rem 0;
}

.feature-row .feature {
    width: 75%;
    line-height: 1.5rem;
}

.feature-row-note {
    color: #AEAEAE;
}

.price-special-note {
    font-weight: 900;
    font-size: 1.3rem;
    padding: 0rem 1rem 0.5rem 1rem;
    text-align: center;
    color: #004868;
    max-width: 340px;
    margin: 0 auto;
}

.bespoke .pi-price h3 {
    font-size: 3rem;
    margin: 28px 0;
}

input[type=range] {
    -webkit-appearance: none;
    margin: 20px 0;
    width: 100%;
    border-radius: 25px;
    outline: none;
    font-size: 16px;
    position: relative;
}

input[type=range]:focus {
    outline: none;
}

input[type=range]::-webkit-slider-runnable-track {
    width: 0;
    height: 8px;
    cursor: pointer;
    animate: 0.2s;
    border-radius: 25px;
}

input[type=range]::-webkit-slider-thumb {
    height: 20px;
    width: 20px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 4px 0 rgba(0,0,0, 1);
    cursor: pointer;
    -webkit-appearance: none;
    margin-top: -6px;
    z-index: 2;
    position: relative;
}

input[type=range]:focus::-webkit-slider-runnable-track {
}

.range-wrap {
    width: 80%;
    position: relative;
    margin: 3rem auto 1rem auto;
}

.range-wrap::after {
    display: block;
    content: "";
    position: absolute;
    top: 15px;
    left: 0;
    width: 100%;
    background: -webkit-repeating-linear-gradient(90deg, #07283a, #07283a 1px, transparent 1px, transparent 40px) no-repeat 50% 50%;
    background: -moz-repeating-linear-gradient(90deg, #07283a, #07283a 1px, transparent 1px, transparent 40px) no-repeat 50% 50%;
    background: repeating-linear-gradient(90deg, #07283a, #07283a 2px, transparent 1px, transparent 98%) no-repeat 50% 50%;
    background-size: 32% 8px;
    height: 18px;
    pointer-events: none;
    z-index: 1;
}

.range-value {
    position: absolute;
    top: -50%;
}

.range-value span {
    width: 114px;
    text-align: center;
    background: #0075B2;
    color: #fff;
    font-size: 14px;
    display: block;
    position: absolute;
    left: 50%;
    padding: 7px 0;
    transform: translate(-50%, 0);
    border-radius: 6px;
    font-weight: 600;
    bottom: -27px;
}

.range-value span:before {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-top: 10px solid #0075B2;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    margin-top: -1px;
}

.system-status-banner {
    min-height: 50px;
    position: fixed;
    top: 0;
    z-index: 100;
    background: #22b573;
    color: #FFFFFF;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.5px;
    padding: 10px;
    font-family: fieldwork-hum, sans-serif;
    font-size: 16px;
}

.system-status-banner.system-issue {
    color: #FFFFFF;
    background: #ED1C24;
}


.system-status-banner .ok {
    display: inline-block;
    width: unset;
}

.system-status-banner.system-issue .ok {
    display: none;
}

.system-status-banner .system {
    display: none;
    width: unset;
}

.system-status-banner.system-issue .system {
    display: inline-block;
}

.system-status-banner svg {
    display: block;
    width: 24px;
    height: 24px;
    fill: #FFFFFF;
    margin-right: 10px;
}

.faq_section h3 {
    padding: 20px 80px 20px 20px;
    background: #ededed;
    margin-bottom: 0;
    position: relative;
    font-size: 24px;
    font-weight: 500;
}

.faq_section h3:hover {
    cursor: pointer;
    transition: all ease 1.5s;
    background: rgba(0,0,0,0.1);
    color: #0075b2;
}

.faq_answer {
    display: none;
    padding: 10px 20% 10px 20px;
    background: #f4f4f4;
    border-top: 1px solid #d8d8d8;
}

.faq_section h3 .material-icons {
    position: absolute;
    top: 20px;
    right: 20px;
    font-size: 32px;
    line-height: 32px;
    color: #CCCCCC;
    transition: all ease 0.7s;
}

.faq_section h3.active {
    color: #0075b2;
}

.faq_section h3.active .material-icons {
    transform: rotate(90deg);
}

.expand_all,
.contract_all {
    display: inline-block;
    padding: 10px 15px;
    margin: 0 20px 0 0;
    background: #0075b2;
    color: #FFFFFF;
    transition: all ease 0.7s;
}

.expand_all:not(.active):hover,
.contract_all:not(.active):hover {
    cursor: pointer;
    background:rgb(231,247,11);
    color:#07283a;
}

.expand_all.active,
.contract_all.active {
    background: #EDEDED;
    color: #7f7f7f;
}

.dark_blue_row {
    background: #01242d;
}

.dark_blue_row p {
    padding: 10px 0;
}

#header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    color: #FFFFFF;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

#header > * {
    flex-grow: 1;
}

nav a {
    color: #FFFFFF;
    text-decoration: none;
    margin: 0 15px;
    padding: 7px;
    font-size: 17px;
    transition: all ease 0.7s;
    letter-spacing: 1px;
    text-align: center;
    position: relative;
}

nav a::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 2px;
    border-radius: 0px;
    background-color: #FFFFFF;
    bottom: 0;
    left: 0;
    transform-origin: right;
    transform: scaleX(0);
    transition: transform .3s ease-in-out;
}

nav a.current::before,
nav a:hover::before {
    transform-origin: left;
    transform: scaleX(1);
}

.no_hero nav a {
    color: #0075B2;
}

.no_hero #header {
    color: #0075b2;
}

.video-link-button {
    display: flex;
    text-decoration: none;
    padding: 12px 10px;
    background: #0075B2;
    color: #FFFFFF;
    border-radius: 5px;
    transition: 0.5s;
    font-weight: 600;
    width: 200px;
    text-align: center;
    align-items: center;
    margin: 0 auto;
    font-size: 1rem;
    justify-content: center;
}

.video-link-button:hover {
    background: rgb(231,247,11);
    color: #07283a;
}

.video-link-button svg {
    display: block;
    margin-left: 8px;
    height: 20px;
    fill: #FFFFFF;
    transition: 0.5s;
    position: relative;
    top: 1px;
}

.video-link-button svg #circle-play-regular_1_ {
    fill: #FFFFFF;
    transition: 0.5s;
}

.video-link-image {
    text-decoration: none;
}

.video-link-button:hover svg #circle-play-regular_1_ {
    fill: #07283a;
}

.section-links {
    display: flex;
    align-items: center;
}

.section-links a {
    margin: 0 1rem 0 0;
}

#popupNav {
    display: none;
}

#logo {
    transition: all ease 1.27s;
}

#logo img {
    display: block;
    width: 100%;
    transition: all ease 1.27s;
}

.section_image_bg .col_1_2 img {
    display: none;
}
/* when header fixed - after scroll */
#header.fix {
    background: #FFFFFF;
    height: 60px;
    box-shadow: 0 0 2px rgba(0,0,0,0.2);
}

.page-not-found {
    height:100vh;
    width:100%;
    background-image:url('/images/public/enbox-clouds.jpg');
    background-size:cover;
}

.page-not-found .inner,
.page-not-found .content {
    height:100%;
}

.page-not-found .content {
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
}

.page-not-found .content img {
    display:block;
    width:80%;
    max-width:500px;
    margin:0 auto 1rem auto;
}

.page-not-found .content h1,
.page-not-found .content a {
    color:#212121;
}

#header.fix #logo img {
    height: 60px;
    transition: all ease 0.7s
}

#header.fix nav a {
    color: #0075B2;
    transition: all ease 0.7s;
    height: 100%;
    display: flex;
    align-items: center;
}

.no_hero nav a.current::before,
.no_hero nav a:hover::before,
#header.fix nav a.current::before,
#header.fix nav a:hover::before {
    background-color:#0075b2;
}

#header.fix nav a.try_it, 
nav a.try_it {
    background: #0075B2;
    color: #FFFFFF;
    padding:7px 10px;
    border-radius:3px;
    height:unset;
}

#header.fix nav a.try_it:hover,
nav a.try_it:hover {
    background: #e7f70b;
    color: #0075B2;
}

nav a.try_it:hover::before {
    display:none;
}

#hero {
    position: relative;
    margin: auto;
    height: 100vh;
    background-size: cover;
    background-attachment: fixed;
    margin-top: 0px;
}

.features_page #hero {
    background-position: 0 bottom;
}

.short_hero #hero {
    height: 60vh;
    min-height: 440px;
}

.hero_content {
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    align-items: flex-end;
    z-index: 2;
}


#hero:before {
    content: "";
    display: block;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    position: absolute;
    background: rgba(0,0,0,0.3);
    background: -webkit-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.7));
    background: -o-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.7));
    background: -moz-linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.7));
    background: linear-gradient(rgba(0,0,0,0), rgba(0,0,0,0.7));
    z-index: 1;
}

.hero_caption {
    max-width: 1280px;
    margin: 0 auto;
    color: #FFFFFF;
    text-align: center;
    margin-bottom: 120px;
    width: 54%;
}

.hero_caption h4 {
    letter-spacing: 1px;
    font-weight: 200;
    font-size: 30px;
    line-height: 44px;
    margin-bottom: 0;
}

.personnel_page h2 {
    color: #0075b2;
}

.features_row {
    background: #ededed;
}

.row {
    margin: 0;
    padding: 40px 0;
    background-size: cover;
    background-repeat: no-repeat;
    outline: none;
}

.registration_page {
    margin-top: 120px;
}

.row.bg-dark-grey {
    background: #e0e0e0;
}

.registration_page .row.form-items {
    background: #EDEDED;
    padding: 40px 0 60px 0;
}

.registration_page .row.form-items .section {
    max-width: 1280px;
    margin: 0 auto;
    outline: none;
}

.inner {
    max-width: 1280px;
    margin: 0 auto;
    outline: none;
}

.flex_row {
    display: flex;
    flex-wrap: wrap;
}

nav {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    margin-right: 40px;
    align-items: center;
    height: 100%;
}

.staggered_background {
    background-image: url(/media/1013/staggered-graph.svg);
    background-position: 0 50%;
}

.graph_background {
    background-image: url(/media/1008/graph-background.svg);
}

.particle_background {
    background-image: url(/media/1018/air-quality-bg.svg);
    background-attachment: fixed;
    background-size: 100%;
}

.fixed_background {
    background-attachment: fixed;
}

li {
    margin: 0 0 10px 0;
}

span.c2a,
a.link_button,
a.c2a {
    display: inline-block;
    padding: 12px 24px;
    background: #0075B2;
    color: #FFFFFF;
    text-decoration: none;
    font-size: 17px;
    letter-spacing: 1px;
    transition: all ease 0.7s;
    border-radius: 4px;
}

span.c2a:hover,
a.link_button:hover,
a.c2a:hover {
    cursor: pointer;
    background: #e7f70b;
    color: #0075B2;
}

.static_caption .link_button {
    font-size: 24px;
}

.material-icons {
    line-height: 10px;
}

a.link_button .material-icons {
    margin-right: 5px;
    position: relative;
    top: 5px;
}

.hero_scroll_container {
    position: absolute;
    bottom: 0;
    width: 100%;
    text-align: center;
    height: 86px;
    color: #FFFFFF;
    z-index: 2;
    display: flex;
    flex-direction: row;
    justify-content: center;
}

.hero_scroll {
    display: block;
    width: 140px;
    font-size: 30px;
}

.scroll_label {
    font-size: 11px;
    letter-spacing: 2px;
    display: block;
    margin-bottom: 5px;
}

.hero_scroll:hover {
    cursor: pointer;
}

.hero_scroll img,
.hero_scroll svg {
    display:block;
    width: 30px;
    fill: #FFFFFF;
    margin: auto;
}

.hero_scroll svg {
    position: relative;
    transition: top 0.25s linear;
    top: 0;
}

.hero_scroll:hover svg {
    top: 5px;
}

.search {
    padding: 12px 0;
    margin-bottom: 24px;
}

.search_input_container {
    width:100%;
    position:relative;
}

.search input {
    padding:12px;
    font-size:1.2rem;
    border:none;
    border-bottom:1px solid #999999;
    outline:none;
    transition:.5s;
    width:100%;
    font-family: 'Mulish', sans-serif;
}

.search input:focus {
    border-color:#0075b2;
}

.search button {
    border: none;
    outline: none;
    position: absolute;
    right: 2px;
    top: 7px;
    background: #ededed;
    padding: 6px;
    border-radius: 50%;
    cursor:pointer;
    transition:.5s;
}

.search-clear {
    border: none;
    outline: none;
    background: #ededed;
    padding: 6px;
    border-radius: 50%;
    cursor:pointer;
    transition:.5s;
}

.search-clear:hover,
.search button:hover {
    background:rgb(231,247,11);
}

.search-clear svg,
.search button svg {
    display:block;
    width:24px;
    height:24px;
    fill:#07283a;
}

.expand-controls {
    padding: 0 0 24px 0;
}

.search-terms {
    padding: 0 0 12px 0;
    display:flex;
    justify-content:space-between;
}

.search-terms strong {
    color:#000000;
}

.col_1_1 {
    width: 100%;
}

.faq_section h3:first-of-type {
    margin-top:0;
}


.col_1_2 {
    width: 50%;
    padding: 40px;
}

.col_1_2 img {
    display: block;
    max-width: 100%;
    margin: 0 auto;
}

.img_70pc .col_1_2 img {
    max-width: 70%;
}

.col_2_3 {
    width: 66.667%;
}

.col-1-3,
.col_1_3 {
    width: 33.333%;
}

.quotes {
    font-size: 75px;
    color: #0075b2;
    font-family: 'Mulish', sans-serif;
    position: relative;
    top: 31px;
    margin: 0 5px 0 0;
    left: -2px;
}

p.quote {
    font-style: italic;
}

.body_text {
    padding-bottom: 20px;
}

.row:nth-of-type(2n) .flex_row {
    flex-direction: row-reverse;
}

.grey_row {
    background: #EDEDED;
    padding: 40px 0 60px 0;
}

.v_center .flex_row {
    align-items: center;
}

.v_center .flex_row h2 {
    margin-top: 0;
}

.item_detail {
    width: 100%;
    margin: 0;
    position: fixed;
    height: 100vh;
    box-sizing: border-box;
    background: #0075B2;
    z-index: 1002;
    color: #333333;
    overflow-y: auto;
    right: -100%;
    top: 0;
}


ul ul {
    margin: 10px 0 20px 0;
}

.item_detail .container {
    background: #FFFFFF;
    padding: 40px 0;
}

.close_nav,
.close_detail {
    position: absolute;
    top: 20px;
    right: 20px;
    cursor: pointer;
    color: #0075B2;
    transition: background ease 0.5s;
    -webkit-transition: -webkit-transform .3s ease-in-out;
    transition: transform .3s ease-in-out;
    font-size: 40px;
}

.close_detail .material-icons {
    line-height: 60px;
    font-size: 60px;
}

.close_detail svg,
.close_nav svg {
    display:block;
    fill:#FFFFFF;
    color: #FFFFFF;
    width:30px;
    height:30px;
    transition:0.7s;
}

.close_detail svg {
    fill:#0075b2;
    color:#0075b2;
}

.close_detail:hover svg,
.close_nav:hover svg,
.close_detail:hover svg {
    fill:rgb(231,247,11);
}

.close_nav:hover {
    color: #e7f70b;
}

/* footer */
footer {
    background: #0075B2;
    color: #FFFFFF;
}

.flex_row.two_col {
    flex-wrap: wrap;
}

.flex_row.two_col > div {
    width: 50%;
}

.sub_item {
    display: flex;
}

.sub_item_image {
    width: 180px;
    padding: 20px;
    box-sizing: border-box;
}

.sub_item_image img {
    display: block;
    width: 100%;
}

.sub_item_text {
    width: calc(100% - 180px);
    padding: 20px;
}


.page_intro {
    display: flex;
    text-align: center;
    align-items: center;
    padding: 140px 0;
    position: relative;
}

.row.text_page,
.small_intro .page_intro {
    padding: 140px 0 0 0;
}

.row.text_page {
    padding: 140px 0 40px 0;
}

.page_features {
    padding: 40px 0;
    position: relative;
}

table {
    margin: 20px 0;
    border-collapse: collapse
}

table td,
table th {
    border: 1px solid #CCC;
    padding: 5px
}

table tr th:nth-of-type(1),
table tr th:nth-of-type(2) {
    width: 20%;
}

table tr th:nth-of-type(3) {
    width: 60%;
}


table th {
    background: #ededed;
    font-weight: 700;
}

.page_intro_content {
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
}

.faq-page .page_intro_content {
    width: 100%;
    margin: 0 auto;
    background: #ededed;
    max-width:unset;
}

.faq-page .row {
    padding:24px 0 40px 0;
}

.page_intro_content h3 {
}

.page_features {
    display: flex;
    flex-wrap: wrap;
    text-align: center;
}

.page_feature {
    width: 25%;
    box-sizing: border-box;
    padding: 40px;
    position: relative;
    display: block;
    text-decoration: none;
    color: #7f7f7f;
}

.pf_image {
    margin-bottom: 40px;
}

.pf_text h4 {
    margin-bottom: 5px;
    font-size: 28px;
}

footer a, footer a:link, footer a:visited {
    text-decoration: none;
    color: #FFFFFF;
}

footer a:hover {
    transition: all ease 0.7s;
    color: #ededed;
}

footer .col_1_3:nth-of-type(1) {
    padding-left: 0;
}

footer .col_1_3:nth-of-type(3) {
    padding-right: 0;
}

footer .base {
    font-size: 14px;
    padding: 40px 0;
    border-top: 1px solid rgba(255,255,255,0.1);
    display: flex;
    flex-wrap: wrap;
    box-sizing: border-box;
    font-weight: 200;
    letter-spacing: 1px;
}

footer .fa {
    font-size: 26px;
}

footer .col_1_3 {
    padding: 20px 0;
}

footer .vcard {
    letter-spacing: 1px;
    line-height: 26px;
}

footer .addr {
    font-weight: 200;
    font-size: 16px;
}

.footer_logo {
    width: 206px;
    padding: 20px 0 0 0;
}

.footer_logo img {
    display: block;
    width: 100%;
}

.contact_page footer .email a, .contact_page footer .tel, footer .email a, footer .tel {
    border: none;
}

footer .email a:hover,
.contact_page footer .email a:hover {
    color: #e7f70b;
}

.tagline {
    margin-top: 10px;
    letter-spacing: 1px;
    font-size: 16px;
}

.contact_page footer .email a:after {
    display: none;
}

.contact_page footer .email a {
    padding: 0 0 5px 0;
}

.contact_page footer .email {
    margin: 0;
}

.home_page h2 {
    font-size: 44px;
    color: #0075b2;
}

.page_intro_text,
.home_page .body_text p {
    font-size: 28px;
    line-height: 40px;
}

.page_intro_content h1,
.page_intro_text h1 {
    font-size: 2rem;
    line-height: 2.5rem;
}


.contact_form input,
.contact_form textarea,
.contact_form select {
    font-weight: 200;
    font-size: 16px;
    padding: 10px;
    border: 1px solid #ededed;
    outline: 0;
    display: block;
    margin: 10px 0;
    width: 50%;
    min-width: 233px;
    font-family: 'Mulish', sans-serif;
    border-radius: 4px;
    transition: 0.5s;
}

.contact_form input:focus,
.contact_form textarea:focus,
.contact_form select:focus {
    border-color: #0075b2;
}

.contact_form textarea {
    width: 60%;
    min-width: 233px;
    height: 140px;
}

.contact_form input[type=submit],
.register_form button {
    background: #0075b2;
    color: #FFFFFF;
    font-weight: 600;
    width: 180px;
    letter-spacing: 1px;
    font-size: 18px;
    text-transform: uppercase;
    font-family: 'Mulish', sans-serif;
    padding: 10px;
    margin-top: 30px;
    border: none;
}

.register_form button {
    width: 260px;
    margin: 1rem 0;
    border-radius: 8px;
}

.field-validation-error {
    font-weight: 500;
    color: #FF3300;
    margin-bottom: 10px;
    display: block
}

.register_form button:hover,
.contact_form input[type=submit]:hover {
    background: #e7f70b;
    cursor: pointer;
    transition: all ease .7s;
    color: #FFFFFF;
}


.register_form input[type=checkbox] {
    display: none;
}
/* to hide the checkbox itself */
.register_form input[type=checkbox] + label:before {
    font-family: FontAwesome;
    display: inline-block;
}

.register_form input[type=checkbox] + label:before {
    content: "\f096";
}
/* unchecked icon */
.register_form input[type=checkbox] + label:before {
    letter-spacing: 10px;
    font-size: 30px;
    position: relative;
    top: 5px;
    line-height: 36px;
}
/* space between checkbox and label */

.register_form input[type=checkbox]:checked + label:before {
    content: "\f046";
}
/* checked icon */
.register_form input[type=checkbox]:checked + label:before {
    letter-spacing: 5px;
    color: #2776b4;
}

.register_form input[type=checkbox] + label:before {
    content: '' !important;
}

.contact_page .social a {
    color: #0075b2;
}

button.agree_button {
    border: 0;
    background: transparent;
    color: #DDDDDD;
    font-weight: 500;
    padding: 0;
    box-sizing: border-box;
    margin: 10px 20px 10px 0;
    letter-spacing: 1px;
    outline: none;
}

button.agree_button:hover {
    cursor: pointer;
}

button.agree_button .material-icons {
    font-size: 60px;
    color: rgba(0,0,0,0.2);
    margin-left: 0;
    line-height: unset;
}

.form_agree {
    display: flex;
    align-items: center;
    margin: 10px 0;
    flex-wrap: wrap;
}

.register_form input[type="checkbox"] {
    width: 180px;
    min-width: 180px;
}

.register_form .form_agree label {
    width: calc(80% - 180px);
    font-weight: 200;
}

.register_form .captcha {
    margin: 2rem 0 10px 0;
}

.form_agree svg {
    display:block;
    width:24px;
    height:24px;
    fill:#CCCCCC;
    flex-shrink: 0;
}

.form_agree svg.checked {
    fill:#0075b2;
}

button .agree_button.selected, button.agree_button.selected .material-icons {
    color: #0075b2;
}

.ef.static {
    background: #ef6932;
    padding: 10px;
    color: #FFFFFF;
    margin: 0 0 10px 0;
    font-size: 15px;
    width: fit-content;
}

label {
    font-weight: 600;
    margin-top: 2rem;
    display: block;
}

.pricing-form-note {
    width: 100%;
    max-width: 640px;
}

.form_agree label {
    display:flex;
    display:-webkit-flex;
}

.form_agree label svg {
    margin-right:12px;
}

.form_agree label svg.fa-check-square {
    fill:#0075b2;
    color:#0075b2;
}

.form_agree label:nth-of-type(1) {
    margin-top: 1rem;
}

.agreement_notice a,
.contact_page .vcard a {
    color: #0075b2;
    text-decoration: none;
}

.agreement_notice a:hover,
.contact_page .vcard a:hover {
    text-decoration: underline;
}

.contact_page footer .vcard a {
    color: #FFFFFF;
}

footer .contact {
    text-align: right;
    margin-top: 40px;
}

footer .logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

footer .logos a {
    display: block;
    width: 33.333%;
    box-sizing: border-box;
    padding: 10px;
}

footer .logos a img {
    display: block;
    width: 100%;
}

.social {
    margin-top: 20px;
}

.social svg {
    display:block;
    width:30px;
    height:30px;
    color: #FFFFFF;
    fill:#FFFFFF;
    margin-left:auto;
}

.social a {
    color: #FFFFFF;
    text-decoration: none;
    font-size: 30px;
}

.social a:hover {
    color: #e7f70b;
    text-decoration: none;
    transition: all ease 0.7s;
}

.social a:hover svg {
    color: #e7f70b;
    fill:#e7f70b;
}

.base_right,
.base_left {
    box-sizing: border-box;
    width: 50%;
}

.base_right {
    width: 0;
    text-align: right;
}

.base_left {
    width: 100%;
}

.inner ul.footer_nav {
    padding: 0;
    margin: 30px 0 0 0;
    list-style-type: none;
    width: 80%;
    font-size: 19px;
    letter-spacing: 1px;
}

.inner ul.footer_nav li {
    margin: 0;
}

.footer_nav li a,
.footer_nav li a:visited,
.footer_nav li a:link {
    display: block;
    padding: 10px 0;
    position: relative;
    color: #FFFFFF;
}

.footer_nav li a:after {
    content: "";
    display: block;
    width: 90%;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    background: rgba(255, 255, 255,0.1);
}

.footer_nav li a:hover {
    color: #e7f70b;
}

.base_row {
    background: rgba(0,0,0,0.2);
}

.footer_nav li a:hover:after {
    background: #e7f70b;
    transition: all ease 0.7s;
}

img.footer_logo {
    display: block;
    width: 80%;
    margin-bottom: 20px;
}

.base_left a {
    margin: 0 10px;
}

.org {
    font-weight: 600;
}

.vcard span {
    display: block;
}

.vcard span.locality,
.vcard span.region {
    display: inline-block;
}

.vcard .tel {
    margin-top: 10px;
}

#popUpMenuLink {
    font-size: 36px;
    text-align: right;
    right: 30px;
    width: 30px;
    flex-grow: 0;
    position: relative;
    display:none;
}

#header.fix #popUpMenuLink,
#header.fix #popUpMenuLink svg{
    color: #0075b2;
    fill: #0075b2;
}

#header.fix #popUpMenuLink:hover,
#popUpMenuLink:hover,
#header.fix #popUpMenuLink:hover svg,
#popUpMenuLink:hover svg {
    transition: color ease 0.7s;
    color: #e7f70b;
    fill: #e7f70b;
    cursor: pointer;
}

#popUpMenuLink svg {
    display:block;
    width:30px;
    height:30px;
    fill:#FFFFFF;
    margin-left: auto;
}

popUpMenuLink.active {
    background: transparent;
}

#popupNav {
    position: fixed;
    background: #0075b2;
    opacity: 0.9;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    color: #FFFFFF;
    box-sizing: border-box;
    display: none;
    flex-wrap: wrap;
    align-items: center;
}

#popupNav ul {
    margin: 0;
    list-style-type: none;
    padding: 0;
    text-align: center;
    width: 100%;
}

#popupNav ul li {
    font-size: 30px;
    margin: 10px 0;
}

#popupNav ul li a {
    text-decoration: none;
    letter-spacing: 1px;
    color: #FFFFFF;
}

#popupNav ul li a:hover {
    text-decoration: none;
    color: #e7f70b;
    transition: all ease 0.7s;
}

.staff_detail {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 40px;
    z-index: 1004;
    overflow: auto;
    align-items: center;
    justify-content: center;
}

.staff_detail_inner {
    background: #FFFFFF;
    padding: 40px;
    width: 70%;
    box-shadow: 0 0 120px 10px rgba(0,0,0,0.2);
    position: relative;
}

.staff_list_item {
    width: 50%;
    padding: 20px 40px;
    text-align: center;
}

.staff_list_item img {
    display: block;
    width: 100%;
}

.staff_list_item h4 {
    color: #0075b2;
    margin: 20px 0 0 0;
}

.staff_list_item h5 {
    margin: 0 0 10px 0;
}

.staff_list_item .view_detail {
    display: block;
    font-size: 13px;
    letter-spacing: 1px;
    color: #CCCCCC;
    margin: 10px 0;
}

.staff_list_item .view_detail:hover {
    cursor: pointer;
}

.staff_detail .staff_photo {
    width: 33%;
}

.staff_detail .staff_info {
    width: 100%;
    margin-top: 40px;
}

.staff_detail .staff_photo img {
    display: block;
    width: 100%;
}

.staff_info h2 {
    color: #0075b2;
    margin: 0 0 5px 0;
}

.staff_info .staff_role {
    color: #CCCCCC;
    margin: 0 0 30px 0;
    display: block;
}

.system-status-banner > span svg {
    position: relative;
}

.change-requests-table {
    border-collapse:collapse;
    width:100%;
}

.change-requests-table th,
.change-requests-table td {
    padding:12px;
    text-align:left;
    vertical-align:top;
    border:none;
    font-size:0.9rem;
    line-height:1.5rem;
}

.change-requests-table td p {
    margin:1rem 0;
    line-height:1.5rem;
}

.icons span,
.change-requests-table td.icons span {
    padding: 1px 6px;
    background: #CCCCCC;
    border-radius: 3px;
    display: inline-block;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 1px;
}

.task-data .icons span {
    padding: 2px 6px 3px 6px;
}

.icons span.SN,
.change-requests-table td.icons span.SN {
    background:#673ab7;
    color:#FFFFFF;
}

.icons span.RW,
.change-requests-table td.icons span.RW {
    background:#ff5722;
    color:#FFFFFF;
}

.icons span.NA,
.change-requests-table td.icons span.NA {
    background:#0075b2;
    color:#FFFFFF;
}

.icons span.DN,
.change-requests-table td.icons span.DN {
    background:rgb(231,247,11);
    color:#07283a;
}

.change-requests-table td a {
    color:#000000;
    text-decoration:none;
}

.change-requests-table td a:hover {
    color:#0075b2;
    text-decoration:underline;
}

.change-requests-table td p:first-of-type {
    margin:0;
}

.change-requests-table th.task {
    width:44%;
}

.tasks-controls {
    display:flex;
    gap:16px;
}

.tasks-controls a {
    padding: 4px 8px 6px 8px;
    background: #0075b2;
    border-radius: 3px;
    display: inline-block;
    font-size: 1rem;
    color: #FFFFFF;
    font-weight: 500;
    text-decoration: none;
    transition:0.5s;
}

.tasks-controls a:hover {
    background:rgb(231,247,11);
    color:#07283a;
}

.change-requests-table th.date {
    width:8%;
}

.change-requests-table th.status {
    width:10%;
}

.change-requests-table th.icons {
    width:10%;
}

.change-requests-table td {
    border-bottom:1px solid #CCCCCC;
}

td.status {
    text-transform:capitalize;
}

.grid {
    display:grid;
    gap:36px;
}

.fg-3-1 {
    grid-template-columns:3fr 1fr;
}

.task h1 {
    font-size:1.2rem;
}

.task .rte {
    font-size:0.95rem;
}

.task .rte p:first-of-type {
    margin-top:0;
}

.task-data {
    font-size:0.95rem;
    color:#000000;
    font-weight:700;
}

.task-data > div {
    margin:0 0 1rem 0;
    display:flex;
    justify-content:space-between;
}

.task .c2a {
    letter-spacing:0;
    font-size:0.95rem;
}

.task .controls {
    margin:1rem 0;
    padding:1rem 0;
    border-top:1px solid #CCCCCC;
}

.task-data label {
    display:inline-block;
    margin:0 8px 0 0;
    font-weight:400;
}

/* MEDIA QUERIES */
@media all and (max-width: 1360px) {

    .inner {
        padding: 0 40px;
    }

    footer .base {
        padding: 40px;
    }

    .hero_caption {
        width: 70%;
    }
}

@media all and (max-width: 1280px) {

    .hero_caption h4 {
        font-size: 28px;
        line-height: 40px;
    }

    .system-status-banner > span {
        display: block;
        width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        text-align: center;
    }

    .system-status-banner > span svg {
        position: relative;
    }
}

@media all and (max-width: 960px) {

    .pricing-item.col-1-3:nth-of-type(1), .pricing-item.col-1-3:nth-of-type(3) {
        margin: 1rem 0;
    }

    .pricing-item.col-1-3 {
        width: 100%;
        margin: 1rem 0;
    }

    .page_feature {
        width: 50%;
    }

    nav {
        display: none;
    }

    #popUpMenuLink {
        display: block;
    }

    #logo img {
        width: 200px;
    }

    .staff_list_item {
        width: 100%;
    }

    .page_intro {
        padding: 80px 0 40px;
    }

    .page_intro_content {
        padding: 0 20px;
    }

    .faq_section h3 {
        font-size: 19px;
    }

    .flex_row.two_col > div {
        width: 100%;
    }

    .hero_caption {
        width: 80%;
    }

    .hero_caption h4 {
        font-size: 24px;
        line-height: 38px;
    }


    .staff_detail {
        padding: 20px;
    }

    .staff_detail_inner {
        width: 100%;
    }

    .close_nav, .close_detail {
        top: 40px;
    }
}

@media all and (max-width: 640px) {


    .contact_form input,
    .contact_form textarea,
    .contact_form select,
    .register_form .form_agree label {
        width: 100%;
    }

    a.page-notice {
        font-size: 1rem;
        padding: 0.5rem 5rem;
    }

    #header {
        top: 56px;
    }

    #hero {
        margin-top: 40px;
    }

    .flex_row.two_col > div,
    .col_1_2,
    .col_1_3,
    .col_2_3 {
        width: 100%;
    }

    #hero {
        height: 60vh;
    }

    #hero h4 {
        padding: 20px;
        font-size: 20px;
    }

    .hero_caption {
        margin-bottom: 70px;
    }

    .flex_row.two_col > div,
    .col_1_2,
    .col_1_3,
    .col_2_3 {
        padding: 20px 0;
        word-break: break-word;
    }

    .home_page .col_1_2 {
        padding: 40px 0;
    }

    h1 {
        font-size: 36px;
    }

    .home_page h2, h2 {
        font-size: 32px;
    }

    .staff_detail .staff_photo,
    .staff_detail .staff_info {
        width: 100%;
        margin: 0;
    }

    .staff_detail .staff_info {
        margin-top: 20px;
    }

    .staff_detail .inner {
        padding: 0;
    }

    .form_row {
        flex-wrap: wrap;
    }

    .col_1_3 .vcard {
        margin-top: 40px;
    }

    .base_left {
        box-sizing: border-box;
        width: 100%;
    }

    .slideshow-container {
        height: 60vh;
        min-height: 440px;
    }

    .sub_item {
        flex-wrap: wrap;
    }

    .sub_item_image,
    .sub_item_text {
        width: 100%;
    }

    .sub_item_image img {
        width: 50%;
        margin: 0 auto;
    }

    footer a, footer a:link, footer a:visited {
        display: block;
        margin: 10px 0;
    }

    footer .tel a, footer .tel a:link, footer .tel a:visited,
    footer .email a, footer .email a:link, footer .email a:visited {
        display: inline;
        margin: 0;
    }

    footer .contact {
        text-align: left;
    }

    footer .vcard {
        line-height: 22px;
    }

    .inner ul.footer_nav {
        font-size: 17px;
    }

    .footer_nav li a, .footer_nav li a:visited, .footer_nav li a:link {
        padding: 5px 0px;
    }
}

@media all and (max-width: 440px) {

    body {
        font-size: 17px;
    }

    .home_page h2, h2 {
        font-size: 26px;
    }

    .page_feature {
        width: 100%;
    }

    #hero h4 {
        line-height: 22px;
    }

    .hero_caption {
        width: 100%;
        padding: 20px;
    }

    .page_intro_text, .home_page .body_text p {
        font-size: 20px;
        line-height: 36px;
    }

    .features_row {
        display: none;
    }

    .features_page .row .flex_row {
        flex-direction: column-reverse;
    }

    .features_page .row:nth-of-type(2n) .flex_row {
        flex-direction: column-reverse;
    }

    .particle_background {
        background: unset;
    }

    .section_image_bg .col_1_2 img {
        display: block;
    }

    ul {
        padding: 0 0 0 20px;
    }

    .col_1_2 img {
        max-width: 70%;
    }
}

.splash-wrapper {
    display: flex;
    background-image: url(https://enbox.co.uk/media/1003/hero-rail.jpg);
    background-size: cover;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.splash-content {
    width: 100%;
    padding: 4rem;
    background: #0075b2;
    color: #FFFFFF;
}
