@import url('https://fonts.googleapis.com/css?family=Cairo:400,600,700|Lora:400i');

/* HTML5 Tags */
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { display: block; }
audio, canvas, video { display: inline-block; }
audio:not([controls]) { display: none; height: 0; }

/* Misc */
input[type=button], input[type=submit]  { -webkit-appearance: none; -webkit-border-radius: 0; }
::-webkit-input-placeholder { color: #5e5e5e; }
:-moz-placeholder { color: #5e5e5e; opacity: 1; }
::-moz-placeholder { color: #5e5e5e; opacity: 1; }
:-ms-input-placeholder { color: #5e5e5e; }

/* Main */
* { border: 0px; margin: 0px; padding: 0px;}
html { -webkit-text-size-adjust: 100%; }
body { font-family: cairo; }
body:after { content: 'desktop'; display: none; }
@media (max-width:991px) { body:after { content: 'tablet'; } }
@media (max-width:766px) { body:after { content: 'mobile'; } }
.left { float: left; }
.right { float: right; }
.clr { clear: both; }
.point { cursor: pointer; }
ul, ol{ margin: 1em 0; padding: 0 0 0 40px; }
.img-responsive { width: 100%; display: block; }
.vdo-responsive { width: 100%; display: block; }
.img-hidden { visibility: hidden; }
.anchor { padding-top: 40px; margin-top: -40px; }
.maxlines { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; }
.border { border: solid 1px red; }
.container-fluid { max-width: 1200px; }
textarea { resize: none; }

@media (max-width:991px) { }
@media (max-width:766px) { }
@media (max-width:320px) { }

/* Colors
	blue { color: #144170; }
	navy { color: #182e46; }
	orange { color: #f7a516; }
	beige { color: #f7f6f6; }
	pink { color: #ff4081; }
	green { color: #22c064; }
*/

/* Header */
header { height: 80px; width: 100%; color: #000; font-size: 16px; background-color: #fff; }
header .logo { margin-top: 13px; cursor: pointer; }
header .logo:hover { opacity: 0.7; }
header nav { height: 43px; overflow-y: hidden; margin-top: 10px; text-align: right; text-transform: uppercase; }
header nav ul { list-style-type: none; margin-left: 0px; padding-left: 0px;}
header nav ul li { display: inline-block; margin-left: 0px; }
header nav ul .flexMenu-popup { z-index: 9999; position: absolute; top: 65px; right: 5px; padding: 0px; text-align: left; background-color: #fff; border: solid 1px #c6cacc; margin: 0px; }
header nav ul .flexMenu-popup li { white-space: nowrap; padding: 10px 20px 10px 10px; margin-bottom: 5px; display: block; border-bottom: solid 1px #555; }
header nav ul .flexMenu-popup li:last-child { border: 0px; }
header nav a, header .login a { color: #000; white-space: nowrap; border-bottom: solid 1px transparent; display: inline-block; margin-left: 10px; }
header nav a:hover, header nav .current, header .login a:hover, header .login a.current { color: #000; text-decoration: none; border-bottom: solid 1px #f7a516; }

header .favorites-counter { float: right; margin: 18px 20px 0px 0px; position: relative; }
header .favorites-counter .favorites-count { position: absolute; top: 1px; right: 2px; width: 15px; text-align: center; font-size: 12px; color: #fff; }
header .favorites-counter:hover { opacity: 0.7; cursor: pointer; }

header .ctawrap { float: right; margin: 19px 0px 0px 0px; }
header .ctawrap button { margin: 0px; }
@media (max-width:991px) {
}
@media (max-width:766px) { 
	header { height: 50px; }
	header .logo { margin-top: 10px; }
	header .logo img { width: 70px; }
	header .login { margin-top: 18px; margin-right: 5px; font-size: 12px; }
	header .ctawrap { margin-top: 7px; margin-left: 0px; }
}
@media (max-width:320px) {
	header .ctawrap { margin-left: 2px; }
	header .logo { margin-top: 12px; }
}

/* Media Wrap */
.mediawrap { min-height: 570px; overflow: hidden; background-repeat: no-repeat; background-position: top center; background-size: cover; }
.mediawrap_context { margin: 100px 0px 30px 0px; color: #fff; line-height: auto; }
.mediawrap_context h1 { font-size: 40px; }
.mediawrap_context h2 { font-size: 34px; margin: 10px 0px; }
.mediawrap_context h3 { font-size: 16px; margin-bottom: 30px; }
@media (max-width:766px) { 
	.mediawrap { min-height: 200px; }
	.mediawrap_context { margin-top: 30px; }
	.mediawrap_context h1 { font-size: 28px; }
	.mediawrap_context h2 { font-size: 24px; }
	.mediawrap_context h3 { font-size: 16px; }
}

/* Mobile Menu */
.mobilemenubutton { font-size: 18px; font-weight: 500; width: 68px; height: 68px; line-height: 68px; border-radius: 68px; text-align: center; background-color: #22c064; box-shadow: 0px 0px 10px #505050; color: #fff; text-transform: uppercase; cursor: pointer; position: fixed; bottom: 35px; right: 20px; z-index: 99; }
.mobilemenu { color: #fff; font-weight: 500; z-index: 9; position: absolute; top: 0px; padding: 0px 15px 20px 15px; background-color: #fff; width: 100%; }
.mobilemenu .mobheader { margin-bottom: 20px; }
.mobilemenu .ad { margin: auto; margin-bottom: 20px; text-align: center; }
.mobilemenu .ad img { }
.mobilemenu .items { margin-bottom: 10px; }
.mobilemenu .items a { border-bottom: solid 1px #e5e5e5; color: #000; font-weight: 600; text-transform: uppercase; line-height: 45px; font-size: 16px; background-image: url(/media/1018/arrow-right-orange.svg); background-repeat: no-repeat; background-size: 14px 14px; background-position: right center; display: block; }
.mobilemenu .items a:hover, .mobilemenu .items a.current, .mobilemenu .login a:hover { color: #000; text-decoration: none; }

/* Ad */
.ad { cursor: pointer; }
.ad:hover { opacity: 0.7; }
.ad.big { margin: 30px 0px; }
@media (max-width:991px) { 
	.ad { margin-top: 15px; }
}

/* Sticky */
.sticky { border-radius: 10px; position: fixed; z-index: 9999; cursor: pointer; bottom: 50px; left: 50px; }
.sticky img { border-radius: 10px; }
.sticky:hover { opacity: 0.7; }
@media (max-width:991px) {
	.sticky { bottom: 45px; left: 10px; }
}
@media (max-width:766px) { 
	.sticky img { width: 144px; }
}

/* Videos */
.videos { margin-bottom: -30px; }
.videobadge { background-color: #144170; color: #fff; font-size: 16px; font-weight: 600; padding: 1px 25px 1px 10px; display: inline-block; border-radius: 0px 10px 0px 0px; }
.videos .ad { margin-top: 26px; margin-bottom: 30px; }
.videos .videoitem { position: relative; background-color: #f7f6f6; border: solid 1px #e5e5e5; margin-bottom: 30px; }
.videos .videoitem .fav { position: absolute; right: 10px; top: 5px; cursor: pointer; z-index: 5; background-repeat: no-repeat; background-position: cover; width: 39px; height: 33px; }
.videos .videoitem .fav.add { background-image: url(/media/1052/add.svg); }
.videos .videoitem .fav.remove { background-image: url(/media/1054/remove.svg); }
.videos .videoitem .fav.delete { background-image: url(/media/1053/delete.svg); top: 10px; width: 28px; height: 28px; }
.videos .videoitem .image { position: relative; margin-bottom: 10px; }
.videos .videoitem .play { position: absolute; top: 40%; left: 40%; color: #fff; font-weight: 600; padding-top: 35px; background-image: url(/media/1050/play.svg); background-size: 33px 33px; background-repeat: no-repeat; background-position: top center; }
.videos .videoitem .play:hover { cursor: pointer; opacity: 0.7; }
.videos .videoitem .teacher { float: left; font-size: 14px; padding-left: 10px; text-decoration: underline; }
.videos .videoitem .teacher .name { text-transform: uppercase; }
.videos .videoitem .length { float: right; border-left: solid 1px #bfbfbf; font-size: 14px; padding: 0px 10px 0px 52px; background-image: url(/media/1051/clock.svg); background-repeat: no-repeat; background-size: 18px 18px; background-position: left 30px center; }
.videos .videoitem .header { font-size: 19px; margin: 10px 0px 5px 10px; padding-right: 30px; }
.videos .videoitem .teaser { font-size: 15px; margin: 15px 0px 5px 10px; padding-right: 30px; }
.videos .videoitem .text { position: absolute; z-index: 99; left: 0px; margin: 0px -1px 20px -1px; padding: 0px 30px 0px 10px; z-index: 99; background-color: #f7f6f6; border: solid 1px #e5e5e5; font-size: 15px; border-top: none; }
.videos .videoitem .readit { background-position: right center; background-repeat: no-repeat; background-size: 18px 18px; margin: auto; padding: 5px 0px 10px 0px; font-weight: 600; }
.videos .videoitem .readit:hover { cursor: pointer; opacity: 0.7; }
.videos .videoitem .readit.more { width: 120px; background-image: url(/media/1049/more.svg); }
.videos .videoitem .readit.less { width: 100px; background-image: url(/media/1048/less.svg); }
@media (max-width:991px) { 
	.videos .ad { margin-top: 0px; }
}

/* List */
.list { margin-top: 10px; margin-bottom: -30px; }
.list .ad { margin-bottom: 30px; }
.list .item { border: solid 1px #e5e5e5; margin-bottom: 30px; background-image: url(/media/1018/arrow-right-orange.svg); background-size: 20px 20px; background-repeat: no-repeat; background-position: right 10px bottom 10px; }
.list .item:hover { cursor: pointer; opacity: 0.7; }
.list .item .header { font-size: 19px; margin: 10px 0px 5px 10px; padding-right: 30px; }
.list .item .teaser { font-size: 15px; margin: 0px 0px 5px 10px; padding-right: 30px; }
@media (max-width:991px) { 
	.list .ad { margin-top: 0px; }
}

/* Breadcrumb */
.breadcrumb { margin: 25px 0px; font-size: 14px; font-weight: 500; padding: 0px; background-color: transparent; }
.breadcrumb a { color: #000; }
.breadcrumb .divider img { margin-top: -4px; }
.breadcrumb .active { color: #000; text-decoration: underline; }

/* Document */
.document { background-color: #f7f6f6; padding-bottom: 30px; }
.document .context { padding: 20px 20px 20px 20px; background-color: #fff; }
.document .context h1 { font-size: 25px; text-transform: uppercase; }
.document .context h2 { font-size: 18px; }
.document .context h3 { font-size: 16px; font-weight: 600; }
.document .context h4 { font-size: 22px; font-weight: 600; }
.document .context a { color: #ff9800; }
.document .context blockquote { color: #144170; font-size: 19px; font-weight: 600; max-width: 80%; margin: 30px auto; background-image: url(/media/1020/quote.svg); background-size: 38px 33px; text-align: center; background-repeat: no-repeat; padding-left: 55px; }
@media (max-width:766px) {
	.document .context blockquote { max-width: 100%; }
}

/* Feedback */
.feedback { padding: 25px; background-color: #f7f6f6; margin: 50px 0px 60px 0px; }
.feedback .context .headline { font-size: 29px; font-weight: 600; text-transform: uppercase; }
.feedback .context .teaser { font-size: 18px; }
@media (max-width:766px) {
	.feedback .context .headline { font-size: 22px; }
	.feedback .context .teaser { font-size: 16px; }
	.feedback .field { margin-top: 10px; }
}

/* Button */
button { border-radius: 10px !important; margin-right: 10px; text-transform: uppercase; font-size: 15px !important; font-family: Cairo; font-weight: 600; }
button:hover { opacity: 0.7; }
button.orange { color: #fff; background-color: #f7a516; }
button.green { color: #fff; background-color: #22c064; }
button.btn-link { padding-left: 0px; color: #000; text-transform: none; font-weight: 600; }
button.btn-link:hover { color: #000; opacity: 1; }
button.ico { padding-right: 35px; background-repeat: no-repeat; background-position: right 15px center; }
button.btn-link.ico { padding-right: 25px; background-repeat: no-repeat; background-position: right center; }
button.vdo { background-image: url(/media/1006/video.svg); background-size: 11px 14px; }
button.cta { background-image: url(/media/1005/arrow-right.svg); background-size: 8px 13px; }
button.arrow { background-image: url(/media/1018/arrow-right-orange.svg); background-size: 20px 20px; }
@media (max-width:320px) { 
	button { margin-bottom: 20px; }
}

/* Social bar */
.bar { min-height: 92px; background-color: #f7f6f6; }
.bar img { max-height: 40px; margin-top: 25px; }
@media (max-width:766px) { 
	.bar { min-height: 70px; }
}
@media (max-width:320px) { 
	.bar { min-height: 60px; }
}

/* Boxes */
.boxes { padding: 30px 0px 0px 0px; }
.boxes .headline { text-align: center; font-size: 25px; text-transform: uppercase; }
.boxes .teaser { text-align: center; font-size: 18px; font-weight: 200; }
.boxes .box { margin-top: 30px; cursor: pointer; position: relative; }
.boxes .box:hover { opacity: 0.7; }
.boxes .box .text { text-shadow: 0px 0px 10px #505050; position: absolute; text-align: center; padding: 0px 20px; width: 100%; top: 38%; color: #fff; }
.boxes .box .text .headline { font-size: 31px; margin: 0px; font-weight: 600; text-transform: uppercase; }
.boxes .box .text .teaser { font-size: 16px; margin: 0px; font-weight: 600; text-transform: uppercase; }
@media (max-width:766px) { 
	.boxes { padding: 10px 5px 10px 5px; }
	.boxes .headline { margin-bottom: 0px; }
	.boxes .box { margin: 0px; }
	.boxes .row div[class^="col"]{ padding: 5px; }
	.boxes .box .text { top: 20%; padding: 0px 10px; }
	.boxes .box .text .headline { font-size: 20px; }
	.boxes .box .text .teaser { font-size: 16px; }
}
@media (max-width:320px) { 
	.boxes .box .text { top: 15%; }
	.boxes .box .text .headline { font-size: 18px; }
	.boxes .box .text .teaser { font-size: 14px; }
}

/* Breadcrumb */
.breadcrumb { padding: 0px; background-color: transparent; }
.breadcrumb a { color: #000; }
.breadcrumb .divider img { margin-top: -4px; }
.breadcrumb .active { color: #000; text-decoration: underline; }

/* Back */
.back { min-height: 35px; font-size: 14px; padding-bottom: 10px; }
.back a { display: inline-block; color: #000; border-bottom: solid 1px transparent; }
.back a:hover { color: #000; text-decoration: none; border-bottom: solid 1px #d000a4; }
@media (max-width:766px) {
	.back { height: auto; text-align: center; }
	.back a { margin-bottom: 20px; margin-top: 20px; }
}

/* Responsive items */
table { max-width: 100%; height: auto !important; }
img { max-width: 100%; height: auto !important; }
iframe { max-width: 100%; max-height: auto !important; }

/* Fluid Youtube Video */
.vdowrap { position: relative; padding-bottom: 56.25%; /* 16:9 */ padding-top: 25px; height: 0; }
.vdowrap iframe{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* Form Error */
select.error, input[type=text].error, input[type=password].error, input[type=email].error, input[type=tel].error, textarea.error, button.error { border: solid 1px #e72121;}
.errormsg { display: inline-block; margin-top: 10px; font-weight: normal; position: relative; margin-left: 0px; color: #fff; background-color: #e72121; border-radius: 6px; padding: 5px 15px; line-height: 20px; white-space: nowrap; }
.errormsg .arrow { z-index: 1; position: absolute; top: -8px; left: 15px; width: 0; height: 0; border-left: 10px solid transparent; border-right: 10px solid transparent; border-bottom: 10px solid #e72121; }

/* Newsletter */
.newsletter { padding: 65px 0px; color: #fff; background-color: #182e46; background-size: cover; background-repeat: no-repeat; background-position: top left; }
.newsletter .header { font-size: 30px; text-transform: uppercase; }
.newsletter .teaser { font-size: 17px; margin: 15px 0px 25px 0px; }
.newsletter button { color: #fff; margin-top: 10px; }
.newsletter button:hover { opacity: 1; color: #fff; }
@media (max-width:991px) {
	.newsletter { padding: 25px 0px; background-image: none !IMPORTANT; }
	.newsletter .header { font-size: 22px; }
	.newsletter .teaser { font-size: 16px; margin: 10px 0px 15px 0px; }
}

footer { padding: 40px 0px; min-height: 400px; }
footer .headline { color: #fff; font-size: 18px; }
footer ul.menu { margin: 20px 0px 0px 0px; padding: 0; -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; }
footer ul.menu li { background-image: url(/media/1018/arrow-right-orange.svg); background-size: 14px 14px; background-repeat: no-repeat; background-position: left center; padding-left: 25px; display: inline-block; width: 100%; font-size: 16px; line-height: 30px; }
footer ul.menu li a { color: #fff; }
footer .quote { margin-bottom: 50px; text-align: center; background-image: url(/media/1063/quote_footer.svg); background-size: 50px 43px; background-repeat: no-repeat; background-position: top left; }
footer .quote .headline { padding-top: 30px; font-size: 26px; color: #fff; text-transform: uppercase; }
footer .quote .txt { font-size: 18px; color: #90a4b8; }
@media (max-width:766px) {
	footer ul.menu { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; }
	footer .quote { margin: 30px 0px 30px 0px; background-size: 26px 22px; }
	footer .quote .headline { padding-top: 20px; }
	footer .quote .headline { font-size: 22px; }
	footer .quote .txt { font-size: 16px; }
	footer .logo { text-align: center; margin-bottom: 40px; }
}