/* Reset */
* { margin: 0; padding: 0; }
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{padding:0;border:0;margin:0;vertical-align:baseline;box-sizing:border-box;}
body{}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}table{border-collapse:collapse;border-spacing:0}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}

/* Set Initial Values */
html { background-color: #242e39; }
body { padding-top: 0px; background: #fff; font-size: 100%; font-family: 'Open Sans', Arial, sans-serif; color: #333333; }
img { max-width: 100%; height: auto; border: none; }
h1, h2, h3, h4, h5, h6 { font-family: 'Open Sans', sans-serif; color: #111; font-weight: 700; }
a { text-decoration: none; color: #242e39; }
a:hover { color: #3276ff; }

/* Utility Classes */
.f { width: 100%; max-width: 1300px; margin: 0 auto; box-sizing: border-box; } /* Full Width Wrapper */
.w { width: 93.75%; max-width: 1280px;  margin: 0 auto; box-sizing: border-box; } /* Padded Width Wrapper */
.x { clear: both; } /* Clear Class */
.group:after { visibility: hidden; display: block; content: ""; clear: both; height: 0; }
* html .group, *:first-child+html .group { zoom: 1; } /* IE6 / IE7 */
*.serif { font-family: 'Merriweather', serif; }

button, input, textarea, select { font-size: 16px; border: 1px solid #ccc; font-family: inherit; padding: 8px; box-sizing: border-box; -webkit-appearance: none; }
button, input { line-height: normal; }
textarea { font-size: 100%; overflow: auto; vertical-align: top; }
input[type="text"], input[type="submit"] { -webkit-appearance: none; }

.cols { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -ms-flex-direction: row; flex-direction: row; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.cols > .col { -webkit-box-flex: 1; -ms-flex: 1 1 0px; flex: 1 1 0; }
.cols > .col.f1 { -webkit-box-flex: 1; -ms-flex-positive: 1; flex-grow: 1; }
.cols > .col.f2 { -webkit-box-flex: 2; -ms-flex-positive: 2; flex-grow: 2; }
.cols > .col.f3 { -webkit-box-flex: 3; -ms-flex-positive: 3; flex-grow: 3; }
.cols > .col.f4 { -webkit-box-flex: 4; -ms-flex-positive: 4; flex-grow: 4; }
.cols > .col.f5 { -webkit-box-flex: 5; -ms-flex-positive: 5; flex-grow: 5; }
.cols > .col.f6 { -webkit-box-flex: 6; -ms-flex-positive: 6; flex-grow: 6; }

.cols.center { -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.cols.stretch { -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; }
.cols.reverse { flex-direction: row-reverse; }
.cols.spacing { margin-bottom: 45px; }
.cols.spacing > .col { margin: 0 20px; }
.cols.spacing.small > .col { margin: 0 10px; }
.cols.spacing > .col:first-child { margin-left: 0; }
.cols.spacing > .col:last-child { margin-right: 0; }
.cols.spacing.reverse > .col:first-child { margin-left: 20px; margin-right: 0; }
.cols.spacing.reverse > .col:last-child { margin-right: 20px; margin-left: 0; }

.cols.spacing_padding { padding-bottom: 45px; }
.cols.spacing_padding > .col { padding: 0 20px; }
.cols.spacing_padding.small > .col { padding: 0 10px; }
.cols.spacing_padding > .col:first-child { padding-left: 0; }
.cols.spacing_padding > .col:last-child { padding-right: 0; }
.cols.spacing_padding.reverse > .col:first-child { padding-left: 20px; padding-right: 0; }
.cols.spacing_padding.reverse > .col:last-child { padding-right: 20px; padding-left: 0; }

.cols.no-bottom-padding { padding-bottom: 0; margin-bottom: 0; }

.cols.bordered > .col { border: 2px solid #f3f3f3; border-top: none; border-bottom: none; }
.cols.bordered > .col:first-child { border-left: none; }
.cols.bordered > .col:last-child { border-right: none; }

.shadow-box { border-radius: 4px; box-shadow: 0 0 6px rgba(0,0,0,.08); background-color: #ffffff; padding: 25px 30px; margin-bottom: 20px; }

.submit input,
.button,
button[type="submit"] { font-size: 16px; border-radius: 3px; display: inline-block; padding: 11px 23px; color: #242e39; background: #fec119; text-decoration: none; line-height: 1; font-weight: 400; border: 0; cursor: pointer; }
.submit input:hover,
.button:hover,
button[type="submit"]:hover { color: #242e39; background-color: #e9ac03; }

.submit.big input,
.button.big,
button[type="submit"].big { padding: 16px 30px; font-size: 18px; font-weight: normal; }

ul.inline,
.container ul.inline { margin: 0; padding: 0; list-style: none; }
ul.inline li,
.container ul.inline li { display: inline-block; padding: 0; margin: 0; }

/* Header */
header.body {  }
header.body .topline { background-color: #242e39; color: #b1c2d5; }
header.body .topline .w { padding: 10px 0; font-size: 14px; }
header.body .topline .support {  }
header.body .topline .phone { text-align: right; text-transform: uppercase; letter-spacing: 2px; }
header.body .topline .phone b { color: #d3d8df; }
header.body .topline a { color: #fff; border-left: 1px solid #b1c2d5; margin-left: 4px; padding-left: 10px }
header.body .topline a:hover { color: #fec119; }
header.body .navline { background-color: #ffffff; border-bottom: 1px solid #a9aaab; }
header.body .navline .w { padding: 20px 0 12px; }
header.body .navline .logo { display: inline-block; }
header.body .navline .logo svg { height: 40px; }
header.body .navigation { display: inline-block; text-align: right; }
header.body .navigation ul { list-style: none; margin: 0; padding: 0; }
header.body .navigation ul li { display: inline-block; margin: 0 0 10px 0; padding: 0; margin-left: 13px; }
header.body .navigation ul li a { color: #222222; display: inline-block; }
header.body .navigation ul li a:hover { color: #3276ff; }
header.body .navigation ul li.button a { padding: 11px 23px; color: #242e39; }
header.body .navigation ul li ul.sub-menu { display: none; background: #fff; position: absolute; margin: 10px 0 0 -90px; padding: 15px 0 0 0; border-radius: 2px; box-shadow: 0px 1px 4px rgba(0,0,0,.25); z-index: 9999; }

header.body .navigation ul li ul.sub-menu li .description { font-size: 13px; font-weight: normal; }

header.body.home { background: #576ab3; }
header.body.home .navigation ul li a { color: #fff; }
header.body.home .content-wrapper { background: rgba(0,0,0,.2); }

header.body .navigation #mobiletrigger { display: none; padding: 10px; background: rgb(255, 204, 0); cursor: pointer; color: #463800; border-radius: 2px; } 
header.body .navigation #mobiletrigger .menu { float: left; }

/* Footer */
footer.body { clear: both; background: #242e39; padding: 30px 0 0 0; margin-top: 70px; }
footer.body .widget.brand { }
footer.body .widget.brand img { max-width: 140px; }
footer.body .widget h3 { color: #fff; margin-bottom: 18px; font-family: 'Open Sans', sans-serif; font-size: 17px;  }
footer.body .widget ul { list-style: none; margin: 0; padding: 0; }
footer.body .widget ul li { color: #bac0c3; margin: 0 0 8px; padding: 0; }
footer.body .widget ul li a { color: #bac0c3; }
footer.body .widget p { color: #bac0c3; }
footer.body .widget.disclaimers { padding-right: 25px; }
footer.body .widget.disclaimers p { font-size: 12px; color: #bac0c3; margin-bottom: 20px; line-height: 1.6; }
footer.body .widget.cta { border: 1px solid #0f141a; text-align: center; background: #16202a; border-radius: 4px; position: relative; margin-bottom: -20px; margin-top: -60px; padding: 15px 25px 25px; }
footer.body .widget.cta h3 { font-family: 'Merriweather', serif; font-size: 26px; margin-bottom: 10px; }
footer.body .widget.cta p.icon { color: #23a9b5; margin-bottom: 10px; font-size: 22px; }
footer.body .widget.cta p { font-size: 18px; margin-bottom: 24px; }
footer.body .widget.cta p.cta { margin-bottom: 0; }
footer.body .secondary { background: #242e39; margin-top: 30px; padding: 15px 0; }
footer.body .secondary .w { border-top: 1px solid #16202a; padding-top: 15px; }
footer.body .secondary .copyright { text-align: left;  }
footer.body .secondary .copyright p { font-size: 13px; color: #bac0c3; text-align: left; float: left;}
footer.body .secondary .privacy { text-align: right; }
footer.body .secondary .privacy ul { list-style: none; padding: 0; margin: 0; }
footer.body .secondary .privacy ul li { display: inline; padding: 0; margin: 0 0 0 10px; font-size: 13px; }
footer.body .secondary .privacy ul li a { color: #bac0c3; }

/* Default Styles */
.container { padding: 30px 0; }
.container h1 { font-size: 38px; line-height: 1.2; padding: 0 0 20px 0; font-weight: bold; }
.container h2 { font-size: 32px; line-height: 1.2; padding: 0 0 20px 0; }
.container h3 { font-size: 26px; line-height: 1.4; padding: 0 0 10px 0; }
.container h4 { font-size: 24px; line-height: 1.4; padding: 0 0 20px 0; }
.container h5 { font-size: 22px; line-height: 1.4; padding: 0 0 20px 0; }
.container h6 { font-size: 20px; line-height: 1.4; padding: 0 0 20px 0; }
.container p { font-size: 16px; line-height: 1.6; padding: 0 0 20px 0; }
.container p.big { font-size: 20px; }
.container ol,
.container ul { font-size: 16px; padding: 0 0 20px 0; margin-left: 40px; }
.container ol li,
.container ul li { line-height: 1.6; }
.container ol.none,
.container ul.none { list-style: none; margin-left: 0; }
.container ol.none li,
.container ul.none li { padding-left: 0; }
.container hr { clear: both; height: 4px; padding: 0; margin: 25px auto; border: none; background-color: #fec119; max-width: 120px; }
.container hr.line { height: 0; margin: 0 0 20px 0; border-top: 1px solid #ccc; }
.container img.max { width: 100%; margin-bottom: 8px; }
.container table { margin: 0 0 20px 0; table-layout: auto; border-spacing:0; width:100% }
.container table tr th,
.container table tr td { border-bottom:0.1rem solid #e1e1e1; padding: 12px; text-align:left; }
.container table tr th { vertical-align: bottom; }
.container table thead td { font-weight: bold; }
.container .video-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; margin: 25px 0; }
.container .video-container iframe,
.container .video-container object,
.container .video-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.container .inner { margin: 0 auto; max-width: 920px; }

.container .shadow-box { border-radius: 4px; box-shadow: 0 0 6px rgba(0,0,0,.08); background-color: #ffffff; padding: 25px 30px; margin-bottom: 20px; }

.container .red { color: #ff253a; }
.container .green { color: #9bbd48; }

.container .input { margin-bottom: 10px;}
.container .submit { margin-top: 16px; }
.container .input label { display: block; margin-bottom: 5px; }
.container .input input,
.container .input select,
.container .input textarea { margin: 0; width: 100%; border-radius: 4px; padding: 6px 8px; }
.container .input select { background: #ffffff url('../img/bg.select.gif') right 12px center no-repeat; -webkit-appearance: none; padding: 6px 8px; }
.container .input.error input,
.container .input.error select,
.container .input.error textarea { border: 1px solid #ff5d78; }
.container .input.file { margin-top: 10px; }
.container .input.file input { border: none; padding: 0; }
.container .input .after { font-size: 12px; margin-top: 2px; margin-left: 4px; }
.container .input.checkbox input { display: inline-block; width: 20px; vertical-align: middle; position: relative; top: -2px; margin-right: 10px; }
.container .input.checkbox label { display: inline-block; width: calc(100% - 40px); vertical-align: middle; margin-bottom: 0; }
.container .input.required label:after { content: ""; display: inline-block; width: 6px; height: 6px; background: #ff253a; border-radius: 20px; position: relative; top: -6px; margin-left: 5px; }
.container .input.required label.error:after { content: none; }
.container .input.checkbox input { top: auto; position: relative; -webkit-appearance: none; -moz-appearance: none; appearance: none; display: inline-block; vertical-align: middle; background-color: #fff; color: #666; height: 25px; width: 25px; border: 1px solid #ccc; border-radius: 3px; cursor: pointer; margin-right: 8px; outline: none; }
.container .input.checkbox input:checked::before { position: absolute; font: 13px 'Open Sans', sans-serif; left: 7px; top: 0; content: '\02143'; transform: rotate(40deg); font-weight: bold; text-shadow: 1px 1px 2px rgba(0,0,0,.5); }
.container .input.checkbox input:hover { background-color: #f7f7f7; }
.container .input.checkbox input:checked { background-color: #0085FF; color: #fff; border-color: #044c8e; }
.container .input.radio input { top: auto; position: relative; -webkit-appearance: none; -moz-appearance: none; appearance: none; display: inline-block; vertical-align: middle; background-color: #fff; color: #666; height: 25px; width: 25px; border: 1px solid #ccc; border-radius: 3px; cursor: pointer; margin-right: 8px; outline: none; }
.container .input.radio input:checked::before { position: absolute; font: 13px 'Open Sans', sans-serif; left: 7px; top: 0; content: '\02143'; transform: rotate(40deg); font-weight: bold; text-shadow: 1px 1px 2px rgba(0,0,0,.5); }
.container .input.radio input:hover { background-color: #f7f7f7; }
.container .input.radio input:checked { background-color: #0085FF; color: #fff; border-color: #044c8e; }
.container .input .error-message { color: #ff5d78; font-size: 14px; padding-top: 8px; }
.container .input.required label:after { content: ""; display: inline-block; width: 6px; height: 6px; background: #e00000; border-radius: 20px; position: relative; top: -6px; margin-left: 5px; }
.container .input.required label.error:after { content: none; }

.container .table-responsive { display: block; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

.container .content { padding: 0; }
.container .content #auth { max-width: 540px; margin: 0 auto; }
.container .content #auth .forgot { float: right; }

/* Elements */
.element#message .message { background: #5baf12; color: #fff; text-align: center; font-weight: bold; font-size: 18px; padding: 20px; }
.element#message .message a { color: #fff; text-decoration: underline; }
.element#message .message.hidden { display: none; }

.element.modal { position: fixed; height: 100%; width: 100%; z-index: 99999; top: 0; left: 0; display: none; }
.element.modal:after { visibility: hidden; display: block; content: ""; clear: both; height: 0; }
.element.modal .modal-background { height: 100%; width: 100%; background: rgba(0,0,0,.5); }
.element.modal .modal-background .modal-content { padding: 25px; min-height: 0; overflow: scroll; border-radius: 6px; margin: 0 auto; position: relative; background: #fff; width: auto; max-width: 700px; max-height: 80vh; box-shadow: 0 0 10px rgba(0,0,0,.5); top: 25vh; }
.element.modal .modal-background .modal-content img.max { width: 100%; margin: 0; }
.element.modal .modal-background .modal-content #close { position: absolute; right: 14px; top: 13px; color: rgba(222, 222, 222, 0.7); padding-top: 20px; display: block; font-size: 22px; cursor: pointer; padding: 0; border: none; font-weight: 600; }
.element.modal .modal-background .modal-content #close:hover { color: #4886ff; }
.element.modal .modal-background .modal-content .video-container { position: relative; overflow: hidden; padding-bottom: 56.25%;  height: 0; margin: 0; padding-top: 0; }
.element.modal .modal-background .modal-content .video-container iframe, 
.element.modal .modal-background .modal-content .video-container object, 
.element.modal .modal-background .modal-content .video-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.element.modal .modal-background .modal-content .navigation { position: absolute; left: 0; width: 100%; top: 50%; padding: 0 14px;}
.element.modal .modal-background .modal-content .navigation a { font-size: 22px !important; color: rgba(255,255,255,.7); cursor: pointer; }
.element.modal .modal-background .modal-content .navigation a:hover { color: #4886ff; }
.element.modal .modal-background .modal-content .navigation .prev { float: left; }
.element.modal .modal-background .modal-content .navigation .next { float: right; }
.element.modal.video .modal-background .modal-content { min-width: 720px; }

.element#subscription { text-align: center; }
.element#subscription .shadow-box { margin-bottom: 0; }
.element#subscription .header { border-bottom: 1px solid #ededed; margin-bottom: 12px; }
.element#subscription .header .inline li { vertical-align: middle; }
.element#subscription .header h3 { padding: 14px 0 10px 0; font-size: 26px; }
.element#subscription .header ul.switch { font-size: 14px; padding: 10px 10px 13px 10px; background: #ededed; border-radius: 20px; display: inline; }
.element#subscription .header ul.switch li { cursor: pointer; color: #7e7e7e; display: inline-block; padding: 8px 15px; border-radius: 20px; text-transform: uppercase; line-height: 1; }
.element#subscription .header ul.switch li.active { background-color: #242e39; color: #fff; }
.element#subscription .plan .price { font-size: 26px; font-weight: 600; padding-bottom: 13px; }
.element#subscription .plan .price span { font-size: 14px; }

.element#paginator .pagination { list-style: none; text-align: right; }
.element#paginator .pagination li { display: inline-block; }
.element#paginator .pagination li a { display: inline-block; border: 1px solid #ddd; border-right: 0; padding: 3px 16px; }
.element#paginator .pagination li:first-child a { border-top-left-radius: 4px; border-bottom-left-radius: 4px; }
.element#paginator .pagination li:last-child a { display: inline-block; border: 1px solid #ddd; border-top-right-radius: 4px; border-bottom-right-radius: 4px; }
.element#paginator .pagination li a:hover { background: #0085FF; color: #fff; border-color: #0085FF; }

.element#processing { position: fixed; height: 100%; width: 100%; z-index: 99999; top: 0; left: 0; display: none; }
.element#processing:after { visibility: hidden; display: block; content: ""; clear: both; height: 0; }
.element#processing .background { height: 100%; width: 100%; background: rgba(0,0,0,.5); }
.element#processing .background .content { padding: 0; min-height: 0; text-align: center; overflow: hidden; overflow: scroll; margin: 0 auto; position: relative; width: auto; max-width: 700px; max-height: 80vh; line-height: 0; top: 25vh; }

/* Stripe */
.container #processing { position: fixed; left: 50%; top: 25%; text-align: center; padding: 45px 70px; margin-left: -120px; background: #fff; border-radius: 5px; box-shadow: 0 0 9px rgba(0,0,0,.4); text-transform: uppercase;}
.container #processing p { margin: 0; padding: 0; }