/*
================================================================================

  Reset

================================================================================
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

/*
================================================================================

  Base

================================================================================
*/

/* Typography */
html { font-size: 100%; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }
body { font-family: montserrat, sans-serif; font-size: 18px; line-height: 1em; font-weight: 400; color: #1C2245; }
h1, h2, h3, h4 { font-weight: bold; line-height: 1.25em; }
h1, h2 { font-size: 36px; color: #4459B8; margin-bottom: 0.5em; }
h2 { font-size: 20px; }
h3 { font-size: 20px; margin-bottom: 1em; }
h4 { font-size: 16px; }
p { line-height: 1.5em; margin-bottom: 1.5em; }
b, strong { font-weight: 700; }
i, em { font-style: italic; }
small { font-size: 0.8em; }
sup { font-size: 8px; position: relative; top: -5px; margin-left: 1px; }

/* Lists */
ul { list-style-type: disc; margin: 0 0 1.5em 2em; }
ol { list-style-type: decimal; margin: 0 0 1.5em 2em; }
ul li, ol li { margin-bottom: 0.75em; line-height: 1.5em; }
ul.no-list, ol.no-list, nav ul, ul.gform_fields { list-style-type: none; margin: 0px; padding: 0px; }
ul.no-list li, ol.no-list li, nav ul li, ul.gform_fields li { margin: 0px; padding: 0px; }

/* Navigation */
a { text-decoration: none; outline: none; transition: 0.3s; color: #4459B8; }
a:hover { color: #1C2245; }

/* Forms */
input[type=text], input[type=email], input[type=password], input.text, input.search, textarea { font-family: inherit; font-size: inherit; -webkit-appearance: none; outline: none; }
textarea { overflow: auto; vertical-align: top; resize: vertical; }
label { cursor: pointer; }

/* Buttons */
.buttons { display: flex; }
.button { cursor: pointer; font-family: inherit; -webkit-appearance: none; border-radius: 0; border: solid 1px #43b0a0; color: #fff !important; font-size: 18px; line-height: 50px; background: #43b0a0; height: 50px; display: block; min-width: 175px; text-align: center; transition: 0.3s; text-transform: uppercase; font-weight: 500; transform: skewX(-15deg); position: relative; padding: 0 20px 0 25px; }
.button span { transform: skewX(15deg); display: block; }
.button::before { content: ''; background: #fff; width: 10px; position: absolute; top: -1px; bottom: -1px; left: -2px; }
.button:hover { background: #2d3c7d; border-color: #43b0a0; }

/* Text Selection */
::-moz-selection { background: #333; color: #fff; text-shadow: none; }
::selection { background: #333; color: #fff; text-shadow: none; }

/* Misc */
img { border: 0; -ms-interpolation-mode: bicubic; vertical-align: middle; max-width: 100%; height: auto; }

/* Enable Box Sizing */
*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

/*
================================================================================

  Header

================================================================================
*/

body { background: #2c3c7d; }
.wrapper { max-width: 1280px; margin: 0 auto; }

.page-header { position: fixed; top: 0; left: 0; right: 0; z-index: 5; }
.page-header .wrapper { display: flex; }

.page-header::before, .page-header::after { content: ''; display: block; position: fixed; z-index: 4; top: 0; left: 0; right: calc(50% + 600px); background: #1c2245; }
.page-header::after { left: calc(50% + 600px); right: 0; background: #43b0a0; }

.page-header::before, 
.page-header::after,
.page-header .logo,
.page-header .logo::after,
.page-header .login .button {
	height: 100px;
}

.page-header .logo { background: #1c2245; padding-top: 32px; position: relative; z-index: 5; padding-right: 30px; }
.page-header .logo::after { content: ''; display: block; width: 35px; background: #1c2245; clip-path: polygon(100% 0, 0% 100%, 0 0); position: absolute; top: 0; right: -35px; }
.page-header .logo a { width: 160px; display: block; }

.page-header .login { margin-left: auto; position: relative; z-index: 5; }
.page-header .login .button { border: none !important; padding-top: 20px; }
.page-header .login .button::before { top: 0; bottom: 0; }
.page-header .login span { position: relative; top: 3px; }

/*
================================================================================

  Main

================================================================================
*/

.page-main { position: relative; }

.page-main, .page-content { background: #2c3c7d; background: linear-gradient(180deg, rgba(44, 60, 125, 1) 25%, rgba(38, 52, 111, 1) 50%, rgba(6, 9, 36, 1) 100%); }

.page-content { padding: 150px 0 75px; max-width: 70%; padding-right: 275px; clip-path: polygon(0 0, 100% 0%, 65% 100%, 0% 100%); position: relative; z-index: 3; }
.page-content, .page-content h1 { color: #fff; }
.page-content h1 { font-size: 100px; line-height: 1em; }
.page-content p.intro { font-size: 24px; }
.page-content strong { color: #43b0a0; }
.page-content .buttons { padding: 20px 0 0 10px; }
.page-content .button span { position: relative; top: -2px; }

/* bxSlider reset */
.bx-wrapper { margin-bottom: 0 !important; border: none !important; box-shadow: none !important; background: transparent !important; }

.page-slideshow { position: absolute; top: 0; bottom: 0; right: 0; left: 45%; z-index: 2; background: #ccc; }
ul.slideshow li { background-size: cover !important; }

.page-slideshow, ul.slideshow li, .page-content { height: 1000px !important; }


/*
================================================================================

  Footer

================================================================================
*/

.page-footer { background: #43b0a0; padding: 50px 0; text-transform: uppercase; position: relative; z-index: 10; }
.page-footer .wrapper { display: flex; }

.page-footer .logo { margin-right: 50px; }
.page-footer .logo a { display: block; width: 118px; }

.footer-nav ul li, .copyright p { font-size: 12px; line-height: 1.75em; }

.footer-nav { margin-right: 0.5em; }
.footer-nav ul { display: flex; }
.footer-nav ul li { position: relative; padding-left: 9px; margin-left: 6px; }
.footer-nav ul li:first-child { padding-left: 0; margin-left: 0; }
.footer-nav ul li::before { content: '/'; display: block; position: absolute; top: 0; left: 0; color: #1c2245; font-weight: 600; }
.footer-nav ul li:first-child::before { display: none; }
.footer-nav a { font-weight: 500; color: #fff; }
.footer-nav a:hover { opacity: 0.65; }

.copyright p { margin: 0; }

.rr-corner { position: absolute; bottom: 0; right: 0; background: #2c3c7d; width: 200px; height: 600px; clip-path: polygon(100% 0, 0% 100%, 100% 100%); }
.rr-logo { position: absolute; right: 60px; bottom: 40px; width: 38px; }
.rr-logo a { display: block; }

/*
================================================================================

  Responsiveness

================================================================================
*/

@media only screen and (max-width:1375px) {
	body { font-size: 16px; }
	p { margin-bottom: 1em; }
	.wrapper { max-width: 100%; padding-left: 50px; padding-right: 50px; }
	.page-header::before { right: auto; width: 100px; }
	.page-header::after { left: auto; width: 100px; }
	.page-slideshow, ul.slideshow li, .page-content { height: 800px !important; }
	.page-content h1 { font-size: 6vw; }
	.page-content p.intro { font-size: 20px; }
}

@media only screen and (max-width:1200px) {
	.page-content { padding-right: 225px; }
	.page-content p.intro { font-size: 18px; }
}

@media only screen and (max-width:1023px) {
	.page-main .wrapper { background: #2c3c7d; background: linear-gradient(180deg, rgba(44, 60, 125, 1) 25%, rgba(38, 52, 111, 1) 50%, rgba(6, 9, 36, 1) 100%); }
	.page-slideshow { position: relative; top: auto; bottom: auto; left: auto; right: auto; }
	.page-slideshow, ul.slideshow li { height: 300px !important; }
	.page-content { height: auto !important; max-width: 80%; padding-right: 0; clip-path: none; }
	.page-content h1 { font-size: 60px; }
	.page-footer .wrapper { display: block; }
}

@media only screen and (max-width:767px) {
	.wrapper { padding-left: 30px; padding-right: 30px; }
	.page-header::before, .page-header::after, .page-header .logo, .page-header .logo::after, .page-header .login .button { height: 80px; }
	.page-header .logo { padding-top: 25px; }
	.page-header .login .button { padding-top: 10px; }
	.page-content { padding: 125px 0 50px; max-width: 100%; }
	.page-footer { padding: 30px 0; }
	.footer-nav { margin: 12px 0 6px; }
	.page-header .logo::after { width: 23px; right: -23px; }
	.button { min-width: 125px; }
	.rr-corner { width: 100px; height: 400px; }
	.rr-logo { right: 20px; bottom: 30px; }
}

@media only screen and (max-width:480px) {
	.footer-nav ul { display: block; }
	.footer-nav ul li { margin: 0; padding: 0; }
	.footer-nav ul li::before { display: none; }
	.copyright { padding-right: 75px; }
	.copyright p { text-wrap: balance; }
}

@media only screen and (max-width:420px) {
	.page-header .logo { padding-top: 23px; padding-right: 20px; }
	.page-header .logo a { width: 100px; }
	.page-header .logo::after { width: 18px; right: -18px; }
	.page-header::before, .page-header::after, .page-header .logo, .page-header .logo::after, .page-header .login .button { height: 65px; }
	.button { font-size: 16px; }
	.page-header .login span { top: -2px; }
	.login .button { min-width: 100px; padding-left: 20px; padding-right: 10px; }
	.page-content h1 { font-size: 50px; }
}