@charset "UTF-8";
/* CSS Document */
/*------------------------------------- Fonts -----------------------------------*/
@font-face {
	font-family: 'ProximaNova-Light';
    src: url('../fonts/Proxima-Light/ProximaNova-Light.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Proxima-Light/ProximaNova-Light.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Proxima-Light/ProximaNova-Light.woff2') format('woff2'), /* Super Modern Browsers */
         url('../fonts/Proxima-Light/ProximaNova-Light.woff') format('woff'), /* Pretty Modern Browsers */
         url('../fonts/Proxima-Light/ProximaNova-Light.ttf')  format('truetype'), /* Safari, Android, iOS */
         url('../fonts/Proxima-Light/ProximaNova-Light.svg#ProximaNova-Light') format('svg'); /* Legacy iOS */
    font-weight: normal;
    font-style: normal;
}
@font-face {
	font-family: 'ProximaNova-Regualar';
	src: url('../fonts/Proxima-Regular/ProximaNova-Regular.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Proxima-Regular/ProximaNova-Regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Proxima-Regular/ProximaNova-Regular.woff2') format('woff2'), /* Super Modern Browsers */
         url('../fonts/Proxima-Regular/ProximaNova-Regular.woff') format('woff'), /* Pretty Modern Browsers */
         url('../fonts/Proxima-Regular/ProximaNova-Regular.ttf')  format('truetype'), /* Safari, Android, iOS */
         url('../fonts/Proxima-Regular/ProximaNova-Regular.svg#ProximaNova-Regualar') format('svg'); /* Legacy iOS */
    font-weight: normal;
    font-style: normal;
}
@font-face {
	font-family: 'ProximaNova-Bold';
	src: url('../fonts/Proxima-Bold/ProximaNova-Bold.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Proxima-Bold/ProximaNova-Bold.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Proxima-Bold/ProximaNova-Bold.woff2') format('woff2'), /* Super Modern Browsers */
         url('../fonts/Proxima-Bold/ProximaNova-Bold.woff') format('woff'), /* Pretty Modern Browsers */
         url('../fonts/Proxima-Bold/ProximaNova-Bold.ttf')  format('truetype'), /* Safari, Android, iOS */
         url('../fonts/Proxima-Bold/ProximaNova-Bold.svg#ProximaNova-Bold') format('svg'); /* Legacy iOS */
    font-weight: normal;
    font-style: normal;
}
/*------------------------------------- Page Defaults -----------------------------------*/

*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
body, html { font-size: 100%; padding: 0; margin: 0; }

/* Clearfix hack by Nicolas Gallagher: http://nicolasgallagher.com/micro-clearfix-hack/ */
.clearfix:before, .clearfix:after { content: " "; display: table; }
.clearfix:after { clear: both; }

body {
	background: #FFF;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
}
img {width:100%;}
.clear {clear:both;}

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

/*------------------------------------- Brand Standards -----------------------------------*/

/* Font Families */

.light {
    font-family: 'ProximaNova-Light';
	font-weight: normal;
	font-style: normal;
}
.regular {
    font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
}
.bold {
    font-family: 'ProximaNova-Bold';
	font-weight: normal;
	font-style: normal;
}

/* Font Styles */

.italics {
	font-style: italic;
}
.uppercase {
	text-transform:uppercase;
}
.lowercase {
	text-transform:lowercase;
}
.underline {
    text-decoration: underline;
}
.centered {
    text-align: center;
}
.left-align {
    text-align: left;
}

/* Font Colours */

.invis {
	color: transparent;
}
.white {
	color: #FFF;
}
.blue {
    color: #271d67;
}
.green {
    color: #69c0b0;
}
.yellow {
    color: #f7a600;
}
.ota {
	color: #f58220;
}

/* Background Colours */

.grey-bg,
.white-bg,
.blue-bg,
.green-bg,
.yellow-bg {
	width: 100%;
	height: auto;
	position: relative;
}
.white-bg{
	background: #FFFFFF;
}
.grey-bg {
	background: #F8F8F8;
}
.blue-bg {
	background: #271d67;
}
.green-bg {
    background: #69c0b0;
}
.yellow-bg {
    background: #f7a600;
}

/* Logo */

.logo-colour {
	background: url('../gfx/logo/primary-color.png') no-repeat;
	background-size: contain;
}
.logo-white {
	background: url('../gfx/logo/primary-white.png') no-repeat;
	background-size: contain;
}

/* Background Images */

#home-bg {
	background: url('../gfx/banners/home.jpg') no-repeat;
	background-position: center top;
	background-size: cover;
}
#book-bg {
	background: url('../gfx/banners/about.jpg') no-repeat;
	background-position: center;
	background-size: cover;
}

/*------------------------------------- Navigation -----------------------------------*/

#main {
    position: relative;
	width: 100%;
	margin: 0;
	padding: 30px 0px 30px 0px;
}
#nav-contain {
	position: relative;
	width: 60vw;
	margin: 0 auto;
}
#nav-contain #logo-header {
    position: absolute;
    top: 50%;
    transform: translateX(0%) translateY(-50%);
    left: 0px;
    height: 60px;
    width: 185px;
}
#navigation {
	list-style: none;
	padding: 0px 0px 15px 0px;
    margin: 0px;
    float: right;
}
#navigation li {
	display: inline-block;
	padding: 5px 0px 3px 20px;
	font-size: 1.2em;
    line-height: 1em;
	margin: 0px 10px 0px 10px;
    color: #271d67;
    border-left: 3px solid #69c0b0;
}
#navigation li:hover,
#navigation li:focus {
	color: #69c0b0;
	transition: 0.2s all;
}
#navigation #cnrpp {
	display: inline-block;
    height: 50px;
    width: 70px;
    margin: 0px 0px -18px 40px;
    background: url('../gfx/logo/cnrpp.png') no-repeat;
    background-size: contain;
    color: transparent;
    border-left: none;
}

/*------------------------------------- Wrapper  ------------------------------------------*/

/* Flex Structure */

.flex-container {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}
.flex-container.flex-full,
.flex-container.flex-double,
.flex-container.flex-double-space,
.flex-container.flex-tripple,
.flex-container.flex-tripple-space,
.flex-container.flex-quad,
.flex-container.flex-quad-space {
    justify-content: space-around;
}
.flex-double .flex-item {
    width: 50%;
}
.flex-double-space .flex-item {
    width: calc(50% - 50px);
    margin: 25px;
}
.flex-tripple .flex-item {
    width: 33.3%;
}
.flex-tripple-space .flex-item {
    width: calc(33.3% - 50px);
    margin: 25px;
}
.flex-quad .flex-item {
    width: 25%;
}
.flex-quad-space .flex-item {
    width: calc(25% - 50px);
    margin: 25px;
}

/* Structure */

.wrapper {
	position: relative;
    z-index: 1;
	width: 60vw;
	margin: 0 auto;
	padding: 100px 0px 100px 0px;
}
.wrapper.limited-padding {
	padding: 75px 0px 75px 0px;
}
.wrapper.footer {
	padding: 30px 0px 30px 0px;
}
.wrapper .narrow {
    width: 100%;
	max-width: 900px;
    margin: 0 auto;
}
.wrapper .spacer {
    height: 70px;
    width: 100%;
}

/* Landing */

.flex-full .flex-item {
    position: relative;
    width: 50%;
}
.flex-full .flex-item.flex-content-left .wrapper {
    width: 100%;
    padding: 100px 100px 100px 20vw;
}
.flex-full .flex-item.flex-content-right .wrapper {
    width: 100%;
    padding: 100px 20vw 100px 100px;
}
.flex-full .wedge {
    position: absolute;
    top: 0;
    left: -80px;
    height: 100%;
    width: 100%;
    background: url('../gfx/banners/banner-accent.png') no-repeat;
    background-size: contain;
}

/* Font Sizing */

.wrapper h1 {
	font-size: 3.5em;
	line-height: 1.1em;
	padding: 0px;
    margin: 0px 0px 30px 0px;
}
.wrapper h2 {
	font-size: 2.2em;
	line-height: 1.1em;
	padding: 0px;
    margin: 0px 0px 25px 0px;
}
.wrapper.limited-padding h2 {
    margin: 0;
}
.wrapper p {
	font-size: 1.2em;
	line-height: 1.4em;
	padding: 0px;
    margin: 0px 0px 25px 0px;
}
.wrapper.footer p {
    font-size: 1em;
    margin: 0;
}
.wrapper p.large {
	font-size: 1.6em;
}
.wrapper a:hover,
.wrapper a:focus {
    opacity: 0.8;
    transition: 0.2s all;
}
.wrapper a:link,
.wrapper a:visited {
    color: inherit;
    text-decoration: underline;
}

/* Buttons */

.wrapper a.btn {
    display: inline-block;
    padding: 18px 30px 18px 30px;
    font-size: 1.2em;
    text-align: center;
    margin: 0px 0px 0px 0px;
    color: #FFF;
    text-decoration: none;
    background: #f7a600;
    border-radius: 5px;
}
.wrapper a.btn:hover,
.wrapper a.btn:focus {
    background: #69c0b0;
    opacity: 1;
    transition: 0.2s all;
}
.green-bg .wrapper a.btn {
    background: #271d67;
}
.green-bg .wrapper a.btn:hover,
.green-bg .wrapper a.btn:focus {
    background: rgba(0,0,0,0.4);
    opacity: 1;
    transition: 0.2s all;
}

/* Images */

.wrapper .affiliation {
    display: inline-block;
    width: 150px;
    height: auto;
    margin: 20px auto auto auto;
}
.wrapper .mobile-photo {
    position: relative;
    width: 100%;
    height: 300px;
    border-top-right-radius: 50px;
    border-bottom-left-radius: 50px;
    margin: 0px 0px 50px 0px;
    overflow: hidden;
}
.wrapper .mobile-photo img {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ota.studio badge */

.footer #ota {
    position: absolute;
    top: 10px;
    right: 0px;
    display: inline-block;
    padding: 20px 0px 0px 90px;
    font-size: inherit;
}
.footer #ota::before {
    content: '';
    display: block;
    position: absolute;
    top: 10px;
    left: 0;
    height: 40px;
    width: 80px;
    border-radius: 5px;
    background: #FFF;
    box-sizing: border-box;
    border: 1px solid #EDEDED;
}
.footer #ota::after {
    content: '';
    display: block;
    position: absolute;
    top: 20px;
    left: 20px;
    height: 20px;
    width: 40px;
    background: url('../gfx/logo/ota.png') no-repeat;
    background-size: contain;
}

/*----------------------------------- Mobile Menu Content ----------------------------------------*/

html, 
body, 
.container, 
.content-wrap {
	width: 100%;
}
.content-wrap {
    height: 100vh;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
	-webkit-transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
}
.content-wrap-active {
	overflow-x: hidden;
	overflow-y: hidden;
	max-height: 100vh;
}
#menu-overlay {
    position: absolute;
    z-index: 2;
    z-index: 998;
    height: 100vh;
    width: 100vw;
    background: rgba(0,0,0,0.4);
}
.overlay-hidden {
    opacity: 0;
    visibility: hidden;
}
.overlay-vis {
    opacity: 1;
    visibility: visible;
}
.menu-button {
    position: absolute;
    top: 38px;
    right: 0px;
    height: 25px;
    width: 30px;
    color: transparent;
}
.menu-button::before {
    position: absolute;
    top: 0.1em;
    right: 0.1em;
    bottom: 0.1em;
    left: 0.1em;
    background: linear-gradient(#271d67 20%, transparent 20%, transparent 40%, #271d67 40%, #271d67 60%, transparent 60%, transparent 80%, #271d67 80%);
    content: '';
}
.menu-button:hover::before {
    background: linear-gradient(#f7a600 20%, transparent 20%, transparent 40%, #f7a600 40%, #f7a600 60%, transparent 60%, transparent 80%, #f7a600 80%);
    transition: 0.2s all;
}
.menu-active {
    left: 0px;
    z-index: 999;
    opacity: 1;
    visibility: visible;
    /* Animations */
    transform-origin: left;
    animation-name: menu-in;
    animation-direction: normal;
    animation-duration: 300ms;
}
.menu-nonactive {
    left: -1000px;
    z-index: -999;
    opacity: 0;
    visibility: hidden;
    /* Animations */
    transform-origin: left;
    animation-name: menu-out;
    animation-direction: normal;
    animation-duration: 100ms;
}
.menu-wrap {
    position: absolute;
    height: 100vh;
    width: 300px;
    overflow: hidden;
    background: #FFF;
    /* Shadow */
    -webkit-box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.55);
    -moz-box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.55);
    box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.55);
}
.menu-wrap #menu-logo {
    position: absolute;
    top: 30px;
    left: 40px;
    width: 130px;
    height: 60px;
}
.menu-wrap .menu {
    list-style: none;
    padding: 110px 10px 0px 10px;
    margin: 0;
}
.menu-wrap .menu a:link,
.menu-wrap .menu a:visited {
    color: inherit;
    text-decoration: none;
}
.menu-wrap .menu li {
    position: relative;
    display: block;
    width: 100%;
    font-size: 1em;
    color: #271d67;
    padding: 0px 0px 10px 30px;
    margin: 0px 0px 10px 0px;
}
.menu-wrap .menu li:hover, 
.menu-wrap .menu li:focus {
    color: #69c0b0;
    transition: 0.2s all;
}

/* Close Button */

.close-button {
    width: 50px;
    height: 50px;
    position: absolute;
    right: 20px;
    top: 25px;
    overflow: hidden;
    text-indent: 16px;
    border: none;
    z-index: 1001;
    color: transparent;
    background: transparent;
}
.close-button::before,
.close-button::after {
    content: '';
    position: absolute;
    width: 2px;
    height: 20px;
    top: 14px;
    left: 50%;
    background: #69c0b0;
}
.close-button::before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.close-button::after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* Menu Animations */

@keyframes menu-in {
0% {
    left: -1000px;
}
100% {
    left: 0px;
}
}
@-webkit-keyframes menu-in {
0% {
    left: -1000px;
}
100% {
    left: 0px;
}
}
@keyframes menu-out {
0% {
    left: 0px;
}
100% {
    left: -1000px;
}
}
@-webkit-keyframes menu-out {
0% {
    left: 0px
}
100% {
    left: -1000px;
}
}

/*----------------------------------- Form ----------------------------------------*/

.required-wrap {
	position: relative;
}
.required-wrap .icon {
	position: absolute;
	top: calc(50% - 10px);
	right: 20px;
	transform: translateY(-50%);
	height: 20px;
	width: 20px;
	fill: #271d67;
}
.required-wrap .icon-notes {
	position: absolute;
	top: 30px;
	right: 20px;
	transform: translateY(-50%);
	height: 20px;
	width: 20px;
	fill: #271d67;
}
.required-wrap .astrix {
    position: absolute;
	top: 0px;
	right: -15px;
}

/* Structure */

.g-recaptcha {
    display: none;
    position: absolute;
    top: -5000px;
    left: -5000px;
}
#form .required-wrap .astrix-t {
	right: 20px;
}
#form {
    position: relative;
	padding: 0px 0px 0px 0px;
	margin: 0;
}
#form p {
    margin: 30px 0px 0px 0px;
	font-size: 0.9em;
    line-height: 1.5em;
}
#form #q4 {
	margin-bottom: 20px;
}
#form #vehicle-colour {
	display: none;
    visibility: hidden;
    opacity: 0;
}

/* Form Inputs */

#form input[type="text"],
#form input[type="email"],
#form input[type="phone"] {
  	display: inline-block;
  	width: 100%;
	/* Font Styles */
  	font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
	/* Font Styles */
  	color: #271d67;
  	font-size: 1.2em;
  	appearance: none;
  	box-shadow: none;
  	background: #FFFFFF;
    border: 3px solid #69c0b0;
    border-radius: 5px;
  	margin: 0px 0px 20px 0px;
 	padding: 15px 20px 15px 20px;
}
#form select {
  	-webkit-appearance: none;
  	-moz-appearance: none;
  	appearance: none;
  	display: inline-block;
  	width: 100%;
	/* Font Styles */
  	font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
	/* Font Styles */
  	color: #271d67;
  	font-size: 1.2em;
  	box-shadow: none;
  	background: #FFFFFF;
    border: 3px solid #69c0b0;
    border-radius: 5px;
  	margin: 0px 1.65% 20px 0px;
  	padding: 15px 20px 15px 20px;
}
#form textarea {
	width: 100%;
	height: calc(100% - 20px);
	display: block;
	/* Font Styles */
    font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
	/* Font Styles */
  	color: #271d67;
  	font-size: 1.2em;
  	appearance: none;
  	box-shadow: none;
  	background: #FFFFFF;
    border: 3px solid #69c0b0;
    border-radius: 5px;
  	margin-bottom: 15px; 
	padding: 15px 20px 15px 20px;
}

/* Submit Button */

#form #submit-btn {
    appearance: none;
  	box-shadow: none;
  	border: none;
    text-transform: uppercase;
	/* Font Styles */
	font-family: 'ProximaNova-Bold';
	font-weight: normal;
	font-style: normal;
	/* Font Styles */
    display: inline-block;
    padding: 18px 30px 18px 30px;
    font-size: 1.2em;
    text-align: center;
    margin: 0px 0px 0px 0px;
    color: #FFF;
    text-decoration: none;
    background: #f7a600;
    border-radius: 5px;
}
#form #submit-btn:hover,
#form #submit-btn:focus {
	background: #69c0b0;
    transition: 0.2s all;
}

/* Hovers */

#form input[type="text"]:focus,
#form input[type="email"]:focus,
#form input[type="phone"]:focus,
#form select:focus,
#form textarea:focus {
    outline: none !important;
    border: 3px solid #271d67;
    box-shadow: none;
}

/* Placeholders */

#form ::-webkit-input-placeholder { /* WebKit, Blink, Edge */
	font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
    color: #949494;
}
#form :-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
    color: #949494;
    opacity:  1;
}
#form ::-moz-placeholder { /* Mozilla Firefox 19+ */
    font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
    color: #949494;
    opacity:  1;
}
#form :-ms-input-placeholder { /* Internet Explorer 10-11 */
    font-family: 'ProximaNova-Regualar';
	font-weight: normal;
	font-style: normal;
    color: #949494;
}

/*------------------------------------- Media Queries -----------------------------------*/

@media (max-width: 1600px){
    
	/* Structure */
    #nav-contain {
	width: 80vw;
    }
	.wrapper {
	width: 80vw;
    }
    /* Flex */
    .flex-full .flex-item.flex-content-left .wrapper {
    padding: 100px 100px 100px 10vw;
    }
    .flex-full .flex-item.flex-content-right .wrapper {
    padding: 100px 10vw 100px 100px;
    }
    
}
@media (max-width: 1300px){
    
	/* Wrapper */
    .wrapper h1 {
	font-size: 3em;
    }
    .wrapper h2 {
	font-size: 2em;
    }
    .wrapper p {
	font-size: 1em;
    }
    .wrapper p.large {
	font-size: 1.6em;
    }
    /* Buttons */
    .wrapper a.btn {
    font-size: 1em;
    }
    /* Form */
    #form input[type="text"],
    #form input[type="email"],
    #form input[type="phone"],
    #form select,
    #form textarea,
    #form #submit-btn {
    font-size: 1em;
    }
    
}
@media (min-width: 1025px){
    
    .menu-button {
    display: none;
    }
    .mobile-photo {
    display: none;
    visibility: hidden;
    opacity: 0;
    }
    
}
@media (max-width: 1024px){
    
	/* -- nav -- */
    .menu-button {
    display: block;
    }
    #main {
    height: 100px;
	padding: 0px;
    }
    #nav-contain #logo-header {
    top: 20px;
    transform: translateX(0%) translateY(0%);
    }
    #navigation {
    display: none;
    visibility: hidden;
    opacity: 0;
    }
    /* Flex */
    .flex-double .flex-item {
    width: 100%;
    }
    .flex-double-space .flex-item {
    width: 100%;
    margin: 25px 0px 25px 0px;
    }
    .flex-tripple .flex-item,
    .flex-quad .flex-item {
    width: 50%;
    }
    .flex-tripple-space .flex-item,
    .flex-quad-space .flex-item {
    width: calc(50% - 50px);
    margin: 25px;
    }
    .flex-full .flex-item {
    position: relative;
    width: 100%;
    }
    .flex-full .flex-item.flex-content-left .wrapper,
    .flex-full .flex-item.flex-content-right .wrapper {
    padding: 100px 10vw 100px 10vw;
    }
    .flex-full .wedge {
    display: none;
    visibility: hidden;
    opacity: 0;
    }
    /* wrapper */
    .mobile-photo {
    display: block;
    visibility: visible;
    opacity: 1;
    }
    /* Form */
    #form .flex-double-space .flex-item {
    margin: 0;
    }
    /* OTA Badge */
    .footer #ota {
    position: relative;
    top: auto;
    right: auto;
    }
    
}
@media (max-width: 768px){
    
    /* Global */
    .centered {
    text-align: left;
    }
    /* Flex */
    .flex-tripple .flex-item,
    .flex-quad .flex-item {
    width: 100%;
    }
    .flex-tripple-space .flex-item,
    .flex-quad-space .flex-item {
    width: 100%;
    margin: 25px 0px 25px 0px;
    }
    /* Wrapper */
    .wrapper a.btn,
    #form #submit-btn {
    width: 100%;
    }
}