/*==========================================================================================================
                                                BASE SETTINGS
 ============================================================================================================*/
html,body {
    height: 100%;
    min-height: 100%;
}

 * html .clearfix             { zoom: 1; } /* IE6 */
 *:first-child+html .clearfix { zoom: 1; } /* IE7 */

 body {
    font-size: 14px;
    font-family: "Muli","Helvetica Neue",Helvetica,Arial,sans-serif;
    margin: 0;
    padding: 0;
}

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

/*Remove default fieldset styles.*/
fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

a{
    text-decoration: none;
}

a,
a *,
a:link,
a:focus,
a:before,
a:after {
    -webkit-transition: all 100ms ease-in-out;
    -moz-transition: all 100ms ease-in-out;
    -o-transition: all 100ms ease-in-out;
    transition: all 100ms ease-in-out;
}

a,
a:link,
a:active,
a:focus,
a:hover,
button,
button:link,
button:active,
button:focus,
button:hover,
.bootstrap-select .dropdown-toggle:focus {
    outline: none !important;
    text-decoration: none;
}

b{
  font-family: 'Poppins';
  font-weight:bold;
  font-size: 90%;
}

/***** Header Styles *****/
h1, h2, h3, h4, h5, h6 {
    margin:0;
    padding:0;
    font-style: normal;
    -webkit-font-smoothing: antialiased;
}

a{color:#414142;font-size:15px;font-family: "Muli"; line-height: 150%;}
/* a:hover {color:#777 !important;} */
h1{font-size:50px;letter-spacing:-2px;font-family: "Quicksand";}
h2{font-size:35px;letter-spacing:0px;font-family: "Muli";}
h3{font-size:32px;letter-spacing:-2px;font-family: "Quicksand";}
h4{font-size:18px;letter-spacing:0px;font-family: "Quicksand";}
h5{font-size:18px;letter-spacing:0px;font-family: "Muli";}
h6{font-size:14px;letter-spacing:0px;font-family: "Muli";}
p{font-size:14px;font-family: "Muli";}
ul { padding-left: 0px; }
/*li { list-style: none; }*/
label{font-family: 'Quicksand';}

a.aTagNormalFontSize {
    font-size: 14px;
}

.fail {
    margin-top: 15px;
}

.transition{
    -webkit-transition: all .35s ease;
    -moz-transition: all .35s ease;
    -ms-transition: all .35s ease;
    -o-transition: all .35s ease;
    transition: all .35s ease;
}

.center{
    margin:0 auto;
}

/*Centers a col- to its container*/
.col-centered {
    display: block;
    float: none;
    margin: 0 auto;
}

/*Centers content Vertically*/
.verticalCenter {
-webkit-transform: translateY(-50%);
   -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
     -o-transform: translateY(-50%);
        transform: translateY(-50%);
        margin: 0px;
        top: 50%;
}

/*Centers content Horizontally*/
.horizontalCenter {
-webkit-transform: translateX(-50%);
   -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
     -o-transform: translateX(-50%);
        transform: translateX(-50%);
        margin: 0px;
        top: 50%;
}
.table {
    display: table;
}

.tableCell {
    display: table-cell;
    vertical-align: middle;
}

.clearfix:after,
.cc-container:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0;
}

.passed input,
.passed textarea,
.passed select {
    -webkit-box-shadow: 0 1px 5px 1px rgba(0, 250, 17, 1);
    -moz-box-shadow: 0 1px 5px 1px rgba(0, 250, 17, 1);
    box-shadow: 0 1px 5px 1px rgba(0, 250, 17, 1);
    border:1px solid transparent;
}

.errorFailed input,
.errorFailed textarea,
.errorFailed select {
    -webkit-box-shadow: 0 1px 5px 1px red;
    -moz-box-shadow: 0 1px 5px 1px red;
    box-shadow: 0 1px 5px 1px red;
    border:1px solid transparent;
}

.errorMessage {
    display: none;
    color: red;
}

.errorFailed .errorMessage {
    display: block;
}

.signUpContainer .errorMessage {
    margin-top: 5px;
}

/*==========================================================================================================
                                                STYLES
 ============================================================================================================*/
.close {
    font-size: 30px;
    /* padding: 8px !important; */
}

/*Buttons*/
.btn-primary,
.btn-secondary,
.btn-primary-shadow,
.btn-secondary-shadow{
    font-family:"Muli";
    font-size:14px;
    color:#414142;
    border-radius: 0px;
    border: 0px;
    text-transform: uppercase;
    padding: 15px 45px;
    transition:all 250ms ease;
}

/* yellow button white hover */
.btn-primary,
.btn-primary-shadow ,
.btn-secondary-shadow {
    background-color:#f8ee4d;
}

.btn-primary:hover,         .btn-primary:focus,         .btn-primary:active,
.btn-primary-shadow:hover,  .btn-primary-shadow:focus,  .btn-primary-shadow:active,
.btn-secondary-shadow:hover,.btn-secondary-shadow:focus,.btn-secondary-shadow:active{
    color:#414142 !important;
    background-color:white !important;
}

/* yellow button white hover with drop shadow */
.btn-primary-shadow,
.btn-secondary-shadow{
    box-shadow:5px 5px 0px #414142;
}

.btn-secondary-shadow {
    background-color: #FFFFFF;
    border-radius: 4px;
    color: #000000;
   padding: 12px 20px;
    box-shadow: 13px 13px 0px #414142;
    color: #414142;
}
/* yellow button gray hover */
.btn-secondary {
    background-color:#f8ee4d;
}

.btn-secondary:hover{
    background-color:#414142;
    color: white;
}

/* white button gray hover */
.btn-primary-white-shadow{

}

.btn-primary-shadow small,
.btn-secondary-shadow small{
    font-weight: bold;
    display: inline-block;
    white-space: normal;
}

.btn-secondary-shadow small{
    color: #000000;
    display: inline-block;
    vertical-align: middle;
}

.btn-secondary-shadow strong{
    font-size: 75px;
    padding: 0px 12px;
    display: inline-block;
    vertical-align: middle;
}

.btn-secondary-shadow h2 {
    font-size: 35px;
    letter-spacing: 0px;
    font-family: "Quicksand";
}

.container{
    height: inherit;
}

section{
    position: relative;
    transition: all 350ms ease;
}

.gray{
   background-color:#f2f3f5;
}

.darkGray{
   background-color:#414142;
}

.yellow{
    background-color:#f5ef4f;
}

.yellow.infoSection h2{
    border-bottom-color:white;
}
.yellow.infoSection div > img.img-responsive{
    border: 5px solid white;
}

.general, .infoSection{
    padding: 65px 5% 70px 5%;
}

.introParagraph {
    font-size: 18px;
}

.introParagraph {
    background: url('../img/watermark-cc.png') no-repeat;
    background-color: #f2f2f2;
    background-position: -170px -120px;
}

.infoSection h2{
   border-bottom-color:#fced54;
   border-bottom-width: 5px;
   border-bottom-style: solid;
    padding-bottom: 25px;
    margin-bottom:25px;
}

.infoSection h4{
    /* margin-bottom:25px; */
}

.infoSection ul{
    padding-left: 15px;
}

.infoSection ul > li{
    list-style: disc;
}

.infoSection ul > li > ul > li{
    list-style: circle;
}

.infoSection ul > li > ul > li > ul > li {
    list-style-type: square;
}

.titleBar {
    position: absolute;
    top:0;
    left:0;
    width: 100%;
    text-align: center;
    background-color:white;
    padding: 25px 0px;
}

.titleBar:after {
    content:'';
    width:35px;
    height:18px;
    background-color: inherit;
    position: absolute;
    left:calc(50% - 17px);
    bottom:-17px;
}



.filler{
    width: 100%;
    display: table-cell;
}

.newsletterSignupBar {
    background-color: #f8ee4d;
    padding: 45px 0;
}

.signUpBar .signUpButton{
    position: relative;
    padding:32px 0px;
}

.signUpBar .signUpButton .btn-primary{
    font-weight: bold;
    padding: 15px 52px;
}

.dividerArrow:after{
    content: '';
    position: absolute;
    top:100%;
    left:50%;
    margin-left: -17px;
    width: 0;
    height: 0;
    border-left: 16px solid transparent;
    border-right: 16px solid transparent;
    border-top: 16px solid #414142;
}

.signUpBar .signUpPrice{
    padding:53px 0px;
}

/*========================================
    PAGE ELEMENTS SETTINGS
========================================*/

/***** Main Container Elements *****/
.siteWrapper{
    position: relative;
    height: auto !important;
    height: 100%;
    /* IE6: treaded as min-height; */
    min-height: 100%;
}

.container.setup{
    visibility: hidden;
    position: absolute;
    z-index: -1;
    pointer-events:none;
}

main {
    /*padding set in globals.js*/
    padding-top: 202px;
    min-height: 80%;
    position: relative;
    margin: 0 auto;
    background: #ffffff;
    /*transition:padding 300ms linear;*/
}

/*==========================================================================================================
                                                HEADER
 ============================================================================================================*/
header {
    position: fixed;
    width: 100%;
    height: auto;
    background-color:white;
    top:46px;
    left:0;
    z-index: 100;
}

header.scrolled{
    position: fixed;
    top:0px;
}

/* on scroll height in sm.css */

header .logo{
    position: relative;
    z-index: 1;
    text-align: center;
    width: 148px;
    height: auto;
    display: table-cell;
    vertical-align: middle;
    margin-top:5px;
    margin-bottom:5px;
}

header .logo img{
    display: inline-block;
    max-width: 60px;
}

header .logo h3{
    font-weight: bold;
    display: inline-block;
    text-transform: none;
    font-size: 32px;
}
/* sets all values for top nav */
.topNav{
    display: table;
    height: 46px;
    font-size: 12px;
    color: white;
    background-color: #414142;
    text-align: right;
    display: table;
    width: 100%;
    position: fixed;
    z-index: 20;
    top: 0px;
}

/* pushes cells right */
.topNav span.filler{
    display: table-cell;
    width: 100%;
    height: inherit;
}

/* inherits from parent */
.topNav a{
    display: table-cell;
    color: inherit;
    font-size: inherit;
    width: 100%;
    height: inherit;
    vertical-align: middle;
    white-space: nowrap;
    padding: 10px;
}
.topNav a:hover {
    color: #f8ee4d;
}
/* spaces icons */
.topNav a > span {
    display: inline-block;
    margin: 0px 5px 0px 15px;
}

/* sets height minusing the top nav */
.mainNav{
    position:relative;
    width: 100%;
    height: 156px;
    display: table;
    font-size:15px;
    text-transform: uppercase;
    -webkit-transition: height .25s ease, border 660ms ease;
       -moz-transition: height .25s ease, border 660ms ease;
        -ms-transition: height .25s ease, border 660ms ease;
         -o-transition: height .25s ease, border 660ms ease;
            transition: height .25s ease, border 660ms ease;
}
.mainNav.open {
    border-bottom: 1px solid #efefef !important;
    height: 76px;
}
.mainNav a:hover, .mainNav a:focus, .mainNav a:active, .mainNav a.active{
    color:#555 !important;
}
.cover{
    z-index: 0;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    background: white;
    box-shadow: 0px 2px 10px rgba(0,0,0,0.1);
}

nav{
    display: table-cell;
    vertical-align: middle;
    text-align: right;
}

nav a{
    position:relative;
    display: inline-block;
    padding:10px 0px;
}

/* header nav links */
header nav a{
    border-bottom-width:0px;
    border-bottom-style: solid;
    border-bottom-color: white;
    -webkit-transition: none;
            transition: none;
}

/* Nav hover and animations are in sm.css */

nav > *{
    margin-left: 25px;
}

/* mobile nav */
.navbar-toggle {
    margin-top: 18px;
    z-index:1;
    margin-right:0px;
}
.navbar-toggle .icon-bar {
    display: block;
    width: 30px;
    height: 4px;
    background: #414142;
    border-radius: 1px;
}
.menuBackground {
    transition: all 360ms ease;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    right: 0;
    background: rgba(0,0,0,0);
}
/* the other mobi nav settings are in xs.css */


/*==========================================================================================================
                                                CAROUSEL
 ============================================================================================================*/

/*Remvoes uneeded padding on images*/
.carousel {
    padding:0px;
    max-height: 530px;
    overflow: hidden;
}

/*Default size for carousel titles*/
.carousel-inner {
    height: auto;
}

.carousel-inner .item {
    height: inherit;
    overflow: hidden;
}
.carousel-inner>.item>img, .carousel-inner>.item>a>img{
    width:100%;
    pointer-events:none;
}
.carousel-indicators {
    text-align: left;
    margin: 0;
    padding: 0;
    transform: inherit;
    left: inherit;
    bottom: 6%;
}

/* white circle indicators */
.carousel-indicators li {
    width:16px;
    height:16px;
    border: 3px solid black;
    border-radius: 10px;
    background-color: white;
    margin:0;
    margin-right:8px !important;
}

/* yellow circle indicators, width & height are only set to overide Bootstraps */
.carousel-indicators .active {
    width: 16px;
    height: 16px;
    background-color: #f8ee4d;
}

.carousel .carouselCopy {
    position: absolute;
    width: 535px;
    top: 40.1%;
}

.carouselCopy a{
    margin-top: 38px;
    padding: 13px 24px;
}
/*Hides mobile banners*/
.mobileBanner {
    display: none;
}


/*==========================================================================================================
                                                MODALS
 ============================================================================================================*/

.fixHeightSuccess .alert-danger {
    margin-bottom: 0px;
    margin-top: 10px;
}

.modal-header h2{
    margin-bottom: 5px;
}
.modal-header .close {
    padding: 6px;
    margin-top: 0px;
}
/*styles for the modal*/
.signUpContainer .personalDetails {
    background: #f8ee4d;
    border-radius: 4px;
    padding: 20px;
    margin: -37px 0 20px 0;
}

.signUpContainer .personalDetails h3{
    font-size: 27px;
}
.signUpContainer .row {
    margin-top: 10px;
}

.signUpContainer input[type="text"] {
    width: 100%;
}

.signUpContainer textarea{
    min-width: 100%;
    max-width: 100%;
    height: 120px;
}

#support textarea {
    min-height: 150px;
}

.signUpContainer h2{
    font-weight: bold;
}

h3.firstHead.popiHead {
    font-size: 25px;
    margin-top: 13px;
    margin-bottom: 20px;
}

.modal-header{
    border: none;
    padding: 23px;
}

.modal-body{
    padding: 23px;
}

/*Manage Modal*/

.checkboxFive {
    width: 25px;
    position: relative;
}

.checkboxFive label {
    background: none repeat scroll 0 0 #fff;
    border: 3px solid #f8ee4d;
    border-radius: 25px;
    cursor: pointer;
    height: 25px;
    left: -6px;
    position: absolute;
    top: -2px;
    width: 25px;
}

.checkboxFive label:after {
    background: none repeat scroll 0 0 transparent;
    border-color: #0088ff -moz-use-text-color #0088ff #0088ff;
    border-image: none;
    border-style: solid none solid solid;
    border-width: 0 0 3px 3px;
    content: "";
    height: 9px;
    left: 3px;
    opacity: 0.2;
    position: absolute;
    top: 2px;
    width: 20px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.checkboxFive label:hover::after {
    opacity: 0.5;
}

.checkboxFive input[type=checkbox]:checked + label:after {
    opacity: 1;
}

/*========================================
=======    NEWSLETTER SIGN UP    =========
=========================================*/
.newsletterMessage  {
    display: inline-block;
    margin-top: -20px;
    margin-right: 20px;
    width: 38px;
}

.newsletterTextLeft p{
    display: inline-block;
    line-height: 122%;
    text-align: left;
    text-transform: uppercase;
    font-size: 13px;
    margin-top: 5px;
}

.newsletterSignupBar input{
    padding: 10px;
    border: 1px solid #666666;
    width: 100%;
}

.newsletterSignupBar .submit{
    background-color: #414142;
    color: #f8ee4d;
    padding: 11px 28px;
}

.newsletterSignupBar .submit.loader{
    background-color: #777777;
    color: #f8ee4d;
    padding: 11px 28px;
}

/*========================================
==============    HOW TO    ==============
=========================================*/

/*==========================================================================================================
                                               FOOTER
 ============================================================================================================*/
footer {
    margin-bottom: 70px;
    z-index: 2;
}

footer .logo,
footer .logo img,
footer .logo a,
footer nav{
    margin: 0 auto;
    display: block;
    text-align: center;
}

footer .logo h3 ,
footer .logo a,
footer nav a {
    display: inline-block;
}

footer .logo {
    margin-top: 50px;
    margin-bottom: 20px;
}

footer .logo h3 {
    font-weight: bold;
    text-transform: none;
    font-size: 32px;
}

footer .logo img{
    max-width: 100px;
}

footer nav {
    text-align: center;
    margin-top: 10px;
}

footer nav a,
footer nav p {
    font-size: 12px;
}

footer nav p {
    padding-top: 10px;
}

footer nav a {
    border-right: 1px solid black;
    padding: 0px;
    padding-right: 10px;
    border-bottom: 0px;
    margin-left: 10px;
}

footer nav a:nth-child(4) {
    border:0px;
}

/*==========================================================================================================
                                                LOADER
 ============================================================================================================*/
.loader img{
    width: 32px;
    position: absolute;
    bottom: 30px;
    right: 180px;
}

.loader {
    background-image: url('../img/sunny.gif');
    background-position: center center;
    background-size: 30px;
    background-repeat: no-repeat;
    color: rgba(0,0,0,0) !important;
}

.loader:hover{
    color: rgba(0,0,0,0) !important;
}

.loaderSupport img{
    position: absolute;
    bottom: 28px;
    width: 32px;
    right: 172px;
}

/*Sets all variables for footer*/
.bottomNav {
    /* height: 46px; */
    font-size: 12px;
    color: #414142;
    background-color: #f2f3f5;
    text-align: center;
    padding-bottom: 30px;
}

.bottomLinkWrapper {
    margin: 0 auto;
    display: table;
    height: inherit;
    padding: 10px 0px;
}


.bottomLinkWrapper a {
    display: table-cell;
    color: inherit;
    font-size: inherit;
    height: inherit;
    vertical-align: middle;
    white-space: nowrap;
    padding-left: 30px;
}

.bottomLinkWrapper a > span{
    margin-right: 10px;
}
/*==========================================================================================================
                                                404 PAGE
 ============================================================================================================*/
.errorContainer.carousel-inner{
    height:auto;
}
.errorContainer h1{
    font-size: 176px;
    color: #f5ef4f;
    position: relative;
    display: inline-block;
    text-shadow: 3px 3px 0px #414142;
    margin-bottom: 30px;
}

.errorContainer h1 span{
    font-size: 21px;
    position: absolute;
    right: 60px;
    bottom: 30px;
    color: #414142;
    text-shadow: none;
}

.errorContainer h3{
    margin-bottom: 12px;
}

.errorContainer p{
    margin-bottom: 40px;
}

.errorBgImage{
    background: url('../img/banners/404-bg.jpg');
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 20px;
    padding-bottom: 50px;
    background-position: 40%;
}

.infoSection h4 > img{
    float: left;
    height: 30px;
    margin-right: 15px;
}


.covidWrap{
    display: none!important;
    z-index: 9999997!important;
    justify-content: center!important;
    align-items: center!important;
    font-size: 14px!important;
    position: fixed!important;
    top: 0!important;
    left: 0!important;
    width: 100%!important;
    height: 100%!important;
}
.covidWrap.shown{
    display: flex!important;
}
.covidModal{
    background: #FFF!important;
    box-shadow: 0 0 15px rgba(0,0,0,0.8)!important;
    margin: 5px!important;
    max-width: 400px!important;
    border-radius: 4px!important;
    z-index: 9999999!important;
}
.covidWrap:before{
    content: ""!important;
    display: block!important;
    position: absolute!important;
    top: 0!important;
    left: 0!important;
    width: 100%!important;
    height: 100%!important;
    z-index: 9999998!important;
    background: rgba(0,0,0,0.8)!important;
}
.covidHeader{
    font-style: normal!important;
    font-family: Arial, Helvetica, sans-serif!important;
    font-weight: bold!important;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    font-size: 1.4em!important;
}
.covidHeader, .covidFooter{
    padding: 10px 15px;
}
.covidHeader{
    display: flex!important;
    justify-content: space-between!important;
    align-items: center!important;
}
.covidHeader svg{
    width: 15px!important;
    height: 15px!important;
    margin-left: 10px!important;
    cursor: pointer!important;
}
.covidBody{
    padding: 20px 10px!important;
}
.covidFooter{
    border-top: 1px solid rgba(0,0,0,0.1)!important;
    display: flex!important;
    justify-content: flex-end!important;
    align-items: center!important;
}

.covidWrap p{
    font-family: Arial, Helvetica, sans-serif!important;
    margin: 0 0 10px!important;
    padding: 0!important;
    color: #666!important;
    font-size: 1em!important;
    font-weight: lighter!important;
}

.covidWrap p a{
    color: #005DFF!important;
}

.covidClose{
    display: block!important;
    font-family: Arial, Helvetica, sans-serif!important;
    color: #FFF!important;
    background: #515151!important;
    border-radius: 3px!important;
    padding: 5px 20px!important;
    font-size: 1em!important;
    transition: all 0.2s ease!important;
}

.covidClose:hover{
    text-decoration: none!important;
    background: #333333!important;
}

/* LIVE MODAL CORRECTION */

#mylib-popup-container,
.modal-backdrop {
    display: none;
}

body.modal-open #mylib-popup-container,
body.modal-open .modal-backdrop {
    display: block;
}