*, *:after, *:before {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
}

*[class*="fa-"]:before {
    font-family: "Font Awesome 5 Free"
}

embed, video, iframe, iframe[style] {
    max-width: 100%;
    height: auto;
}

.wc_info_modal {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999999;
}

.wc_info_modal_content {
    display: block;
    width: 540px;
    max-width: 90%;
    margin: 3% auto 0 auto;
    background: #fff;
    border-radius: 5px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
    position: relative;
    padding: 30px;
    min-height: 200px;
}

.wc_info_close {
    position: absolute;
    right: -12px;
    top: -12px;
    padding: 7px 12px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    font-size: 1em;
    font-weight: bold;
    color: #fff;
    background: #cf7171;
    cursor: pointer;
    border: 2px solid #fff;
    font-size: 0.875em;
}

.wc_info_close:hover {
    background: #f45563;
}

.wc_info_modal_content > p {
    font-size: 1.2em;
    color: #555;
    font-weight: 300;
    border-bottom: 1px solid #ccc;
    padding-bottom: 6px;
    margin-bottom: 20px;
}

.wc_info_modal_content > p span {
    border-bottom: 5px solid #ccc;
    padding-bottom: 6px;
}

select {
    border: 1px solid #ccc;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    border-radius: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    background-image: url(../../admin/_img/select.png);
    background-size: auto 70%;
    background-repeat: no-repeat;
    background-position: right 10px center;
    cursor: pointer;
    font-size: 1em;
}

.embed-container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
}

.embed-container iframe, .embed-container object, .embed-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

img {
    max-width: 100%;
    vertical-align: middle;
    margin: 0;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

a img {
    border: none;
    margin: 0;
}

ul {
    list-style: none;
}

fieldset {
    border: 0;
}

input, select, textarea {
    padding: 10px;
    width: 100%;
    border-radius: 4px;
}

input.btn {
    width: auto;
    cursor: pointer;
}

.container {
    display: block;
    width: 100%;
}

.content {
    display: block;
    margin: 0 auto;
    max-width: 1400px;
}

/*WORKCONTROL UPLOAD MODAL*/
.workcontrol_upload {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 998;
    vertical-align: middle;
    display: none;
}

.workcontrol_upload_bar {
    display: block;
    width: 100%;
    text-align: center;
    vertical-align: middle;
    margin: auto;
}

.workcontrol_upload_bar p {
    display: block;
    margin: 0;
    font-size: 0.8em;
    color: #fff;
    text-transform: uppercase;
    text-shadow: 1px 1px 0px #555;
}

/***********************************
######## VIDEO PARALAX #########
***********************************/
.testimony {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 101;
    display: none;
}

.testimony_content {
    display: block;
    position: relative;
    width: 660px;
    max-width: 90%;
    margin: 3% auto 0 auto;
    background: #fff;
    border-radius: 5px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
}

.testimony_content h1 {
    font-size: 1.2em;
    font-weight: 300;
    color: #555;
    padding: 20px;
}

.testimony_content h1 b {
    font-weight: bold;
    color: #ec6d09;
}

.testimony_close {
    color: #fff;
    background: #000;
    border: 3px solid #fff;
    padding: 6px 10px;
    position: absolute;
    right: -15px;
    top: -15px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    cursor: pointer;
}

.testimony_close:hover {
    background: red;
}

.thumb {
    cursor: zoom-in;
}

.clear {
    clear: both;
}

.fl_right {
    float: right;
}

.fl_left {
    float: left;
}

.progress {
    display: block;
    width: 100%;
    background: #333;
}

.progress_bar {
    display: inline-block;
    background: #00b494;
    color: #fff;
    padding: 5px;
    font-size: 0.7em;
    text-align: center;
    max-width: 100%;
    font-weight: 600;
    text-shadow: 1px 1px 0 #333;
    text-transform: uppercase;
}

.radius {
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
}

.rounded {
    border-radius: 50% !important;
    -moz-border-radius: 50% !important;;
    -webkit-border-radius: 50% !important;;
}

.label_50 label {
    display: inline-block;
    width: 48%;
}

.label_50 label:nth-child(2n+0) {
    margin-left: 3%;
}

/***********************************
######## HTML CHARS CONFIG #########
**********************************/
.htmlchars {
    display: block;
    width: 100%;
    padding: 30px;
}

.htmlchars h3 {
    display: block;
    font-size: 2em;
    font-weight: 300;
    margin: 20px 0;
    color: #222222;
}

.htmlchars h4 {
    display: block;
    font-size: 1.8em;
    font-weight: 300;
    margin-bottom: 20px;
    color: #222222;
}

.htmlchars h5 {
    display: block;
    font-size: 1.6em;
    font-weight: 300;
    margin-bottom: 20px;
    color: #222222;
}

.htmlchars p {
    margin-bottom: 20px;
    font-size: 1em;
    font-weight: 400;
    line-height: 25px;
    color: #333333;
}

.htmlchars iframe {
    width: 100%;
    border: none;
}

.htmlchars ul {
    list-style: circle;
    margin: 20px 30px;
}

.htmlchars ol {
    margin: 20px 30px;
}

.htmlchars form {
    padding: 30px;
    background: #fbfbfb;
    margin: 20px 0;
    text-align: center;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
}

.htmlchars form label {
    display: block;
    margin-bottom: 15px;
    font-size: 0.9em;
    text-transform: uppercase;
}

.htmlchars form input, .htmlchars form textarea {
    border: 1px solid #ccc;
    display: block;
    margin-top: 15px;
    font-size: 1em;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
}

.htmlchars form button, .htmlchars form input[type="submit"] {
    display: block;
    border: 0;
    color: #fff;
    text-shadow: 0 1px #000;
    cursor: pointer;
    padding: 15px 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    background: #00b494;
    border-bottom: 5px solid #008068;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
}

.htmlchars form button:hover, .htmlchars form input[type="submit"]:hover {
    background-color: #008068;
    border-color: #0b5747;
}

.htmlchars a {
    color: #0e96e5;
    text-decoration: none;
}

.htmlchars a:hover {
    text-decoration: underline;
}

.htmlchars pre {
    margin-bottom: 30px;
    font-size: 0.8em;
}

.htmlchars .btn {
    display: block;
    color: #fff;
}

.htmlchars .btn:hover {
    text-decoration: none !Important;
}

/*TRIGGER*/
.trigger {
    font-size: 1em;
    font-weight: 500;
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    margin-bottom: 15px;
    padding: 15px;
    color: #ffffff;
    border-radius: 8px;
    background: #333333;
    box-shadow: 2px 2px 8px 2px rgba(0, 0, 0, 0.1), inset 2px 2px 8px 2px rgba(0, 0, 0, 0.1);
}

.trigger_none {
    margin-bottom: 0;
}

.trigger > span, .trigger > p {
    line-height: 1.15em;
}

.trigger b {
    flex-wrap: nowrap;
    color: #2a2a2a;
}

.trigger_ajax {
    cursor: pointer;
}

.trigger:before {
    width: 58px !important;
    height: 55px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Font Awesome 5 Pro';
    font-size: 2em;
    margin-right: 8px;
    border-radius: 50%;
    background-color: rgba(0, 0, 0, 0.3);
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2), inset 1px 1px 5px rgba(0, 0, 0, 0.1);
    text-shadow: -2px -2px 3px rgba(0, 0, 0, 0.2);
}

.trigger_success {
    background-color: #00b494;
}

.trigger_info {
    background-color: #0e96e5;
}

.trigger_alert {
    background-color: #faad50;
}

.trigger_error {
    background-color: #f45563;
}

.trigger_success:before {
    content: '\f00c';
}

.trigger_info:before {
    content: '\f129';
}

.trigger_alert:before {
    content: '\f071';
}

.trigger_error:before {
    content: '\f05e';
}

.trigger_modal {
    position: fixed;
    z-index: 999;
    top: 0;
    right: 0;
    width: 460px;
    max-width: 80%;
    padding: 20px 20px 0 0;
    cursor: pointer;
}

.trigger_modal .trigger {
    margin: auto 30px auto auto;
    padding: 20px;
}

.trigger_none {
    margin-bottom: 0;
}

.paginator {
    display: block;
    width: 100%;
    text-align: center;
    margin-top: 20px;
}

.paginator li {
    display: inline-block;
}

.paginator li span,
.paginator li a {
    font-size: 0.8em;
    display: inline-block;
    padding: 6px 12px;
    background: #006699;
    margin: 0 5px;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    text-decoration: none;
    color: #fff;
    font-weight: 600;
    text-shadow: 1px 1px #006699;
}

.paginator li a:hover {
    background: #0e96e5;
}

.paginator li span {
    background: #888;
    text-shadow: 1px 1px #333;
}

/*DISPLAY MODE*/
.ds_none {
    display: none;
}

.ds_block {
    display: block;
}

.ds_inline {
    display: inline;
}

.ds_inblock {
    display: inline-block;
}

/*MARGIN MODE*/
.m_top {
    margin-top: 20px;
}

.m_bottom {
    margin-bottom: 20px;
}

.m_left {
    margin-left: 20px;
}

.m_right {
    /* margin-right: 20px; */
}

/*ALIGN*/
.al_center {
    text-align: center !important;
}

.al_left {
    text-align: left !important;
}

.al_right {
    text-align: right !important;
}

.al_justify {
    text-align: justify !important;
}

/*TOOLTIP*/
.wc_tooltip {
    display: inline-block;
    vertical-align: top;
    position: relative;
}

.wc_tooltip:hover .wc_tooltip_balloon {
    display: inline;
}

.wc_tooltip_balloon {
    display: none;
    position: absolute;
    left: 50%;
    margin-left: -100px;
    bottom: 100%;
    margin-bottom: 10px;
    font-weight: 500;
    width: 200px;
    padding: 15px;
    background: #000;
    opacity: 0.9;
    z-index: 99;
    color: #fff;
    font-size: 0.75rem;
    text-align: center;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    text-shadow: none !important;
}

.wc_tooltip_balloon::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -8px;
    width: 0;
    height: 0;
    border-top: 8px solid #000000;
    border-right: 8px solid transparent;
    border-left: 8px solid transparent;
}

/***********************************
######### CUSTON BUTTONS ###########
**********************************/
.btn {
    display: inline-block;
    cursor: pointer;
    padding: 7px 12px;
    /* margin-top: 2px; */
    background: #888;
    font-size: 0.9em;
    color: #fff;
    text-decoration: none !important;
    text-align: center;
    border: none;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    text-shadow: 1px 1px #555;
}

.btn_medium {
    padding: 10px 20px;
    font-size: 1.1em;
    text-transform: uppercase;
    font-weight: bold;
}

.btn_rounded {
    border-radius: 30px !important;
}

.btn:hover {
    background: #555;
    text-decoration: none !important;
}

.btn_blue {
    background-color: #0e96e5;
    text-shadow: 1px 1px #096397;
}

.btn_blue:hover {
    background-color: #096397;
}

.btn_green {
    background-color: #00b494;
    text-shadow: 1px 1px #008068;
}

.btn_green:hover {
    background-color: #008068;
}

.btn_yellow {
    background-color: #faad50;
    text-shadow: 1px 1px #cc8d41;
}

.btn_yellow:hover {
    background-color: #cc8d41;
}

.btn_red {
    background-color: #f45563;
    text-shadow: 1px 1px #c54550;
}

.btn_red:hover {
    background-color: #c54550;
}

.btn_cta_blue {
    padding: 15px 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    background: #0e96e5;
    border-bottom: 5px solid #096397;
}

.btn_cta_blue:hover {
    background-color: #096397;
    border-color: #0a537d;
}

.btn_cta_green {
    padding: 15px 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    background: #00b494;
    border-bottom: 5px solid #008068;
}

.btn_cta_green:hover {
    background-color: #008068;
    border-color: #0b5747;
}

.btn_cta_yellow {
    padding: 15px 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    background: #faad50;
    border-bottom: 5px solid #cc8d41;
}

.btn_cta_yellow:hover {
    background-color: #cc8d41;
    border-color: #a67436;
}

.btn_cta_red {
    padding: 15px 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    background: #f45563;
    border-bottom: 5px solid #c54550;
}

.btn_cta_red:hover {
    background-color: #c54550;
    border-color: #93343c;
}

.btn_green_noaction:hover {
    background: #00b494 !important;
    cursor: default !important;
}

.btn_blue_noaction:hover {
    background: #0e96e5 !important;
    cursor: default !important;
}

.btn_yellow_noaction:hover {
    background: #faad50 !important;
    cursor: default !important;
}

.btn_red_noaction:hover {
    background: #f45563 !important;
    cursor: default !important;
}

/*********************************** ############### BARS  ############## **********************************/
.bar_green {
    display: inline-block;
    vertical-align: middle;
    padding: 4px 10px 5px 10px;
    background: #00b494;
    font-size: 0.8em;
    color: #fff;
}

.bar_blue {
    display: inline-block;
    vertical-align: middle;
    padding: 4px 10px 5px 10px;
    background: #0e96e5;
    font-size: 0.8em;
    color: #fff;
}

.bar_red {
    display: inline-block;
    vertical-align: middle;
    padding: 4px 10px 5px 10px;
    background: #f45563;
    font-size: 0.8em;
    color: #fff;
}

.bar_yellow {
    display: inline-block;
    vertical-align: middle;
    padding: 4px 10px 5px 10px;
    background: #faad50;
    font-size: 0.8em;
    color: #fff;
}

.bar_icon:before {
    display: inline-block;
    margin-right: 4px !important;
}

/***********************************
########## FONT COLOR  #############
**********************************/
.font_black {
    color: black !important;
}

.font_white {
    color: white !important;
}

.font_yellow {
    color: #faad50 !important;
}

.font_green {
    color: #00b494 !important;
}

.font_blue {
    color: #0e96e5 !important;
}

.font_red {
    color: #c54550;
}

.font_purple {
    color: #b78fd3 !important;
}

.font_vintage {
    color: #7eb1bc !important;
}

/***********************************
########## BACK COLOR  #############
**********************************/
.bg_yellow {
    background-color: #faad50 !important;
}

.bg_green {
    background-color: #00b494 !important;
}

.bg_blue {
    background-color: #0e96e5 !important;
}

.bg_red {
    background-color: #c54550 !important;
}

.bg_purple {
    background-color: #b78fd3 !important;
}

.bg_vintage {
    background-color: #7eb1bc !important;
}

/***********************************
############ BOX MODEL #############
**********************************/
.box {
    display: inline-block;
    width: 100%;
    vertical-align: top;
}

.box:before {
    clear: both;
}

.box1 {
    width: 100%;
    margin: 15px 0 15px 0;
}

.box2 {
    width: 49%;
    margin: 1% 1% 1% 0;
}

.box2:nth-of-type(2n+0) {
    margin-right: 0;
}

.box3 {
    width: 32%;
    margin: 1% 1% 1% 0;
}

.box3:nth-of-type(3n+0) {
    margin-right: 0;
}

.box4 {
    width: 23.5%;
    margin: 1% 1% 1% 0;
}

.box4:nth-of-type(4n+0) {
    margin-right: 0;
}

.box5 {
    width: 18.4%;
    margin: 1% 1% 1% 0;
}

.box5:nth-of-type(5n+0) {
    margin-right: 0;
}

.box_side {
    width: 70%;
    padding-right: 40px;
}

.box_bar {
    width: 30%;
}

/*FLEX BOX*/
/* Flex */
.flex {
    display: flex;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-item-1 {
    flex: 1;
}

/* Os itens não se expandem para ocupar o container. */
.grow0 {
    flex-grow: 0;
}

/* Os itens se expandem igualmente para ocupar o container. Utilizando apenas o flex-grow, o crescimento é distribuído igualmente antes e depois do conteúdo de cada elemento. (pois por padrão o flex-basis é auto) */
.grow1 {
    flex-grow: 1;

}

/* Os itens se expandem duas vezes mais que aqueles com flex-grow: 1; */
.grow2 {
    flex-grow: 2;
}

/* Flex Item */
.item {
    margin: 5px;
    text-align: center;
    font-size: 1.5em;
}

.tab-img-pay:hover, .tab-img-pay.wc_active {
    background-color: #1affc9
}


/***********************************
############# OPTIN`S ##############
**********************************/
.calltoaction {
    background-color: #4caf50;
    border: none;
    color: white !important;
    padding: 20px;
    width: 100%;
    text-align: center;
    text-decoration: none !important;
    display: inline-block;
    font-size: 1.4em;
    font-weight: bold;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    text-shadow: 1px 1px 0 #000;
    -webkit-transition-duration: 0.2s; /* Safari */
    transition-duration: 0.2s;
    cursor: pointer;
    box-shadow: 1px 1px 3px 1px #ccc;
    -moz-box-shadow: 1px 1px 3px 1px #ccc;
    -webkit-box-shadow: 1px 1px 3px 1px #ccc;
}

.calltoaction:hover {
    background-color: #55c25c; /* Green */
    color: white;
}

#optin {
    width: 100%;
    text-align: center;
}

#optin * {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
}

#optin input {
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
}

#optin input[type="text"], #optin input[type="email"] {
    border: 1px solid #ccc;
    font-size: 15px;
    margin-bottom: 15px;
    padding: 8px 10px;
    width: 100%
}

#optin input.email {
    background: #fff url(images/email.png) no-repeat center right;
}

#optin input.name {
    background: #fff url(images/name.png) no-repeat center right;
}

#optin input[type="submit"] {
    display: block;
    width: 100%;
    padding: 15px;
    background: #56b748;
    border: 1px #4a9e3e solid;
    color: #fff;
    text-shadow: 1px 1px 0 #333;
    font-size: 1.21em;
    font-weight: bold;
    text-decoration: none !important;
    cursor: pointer;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
    -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
}

#optin input[type="submit"]:hover {
    background: #4a9e3e;
    border-color: #3e8434;
}

#optin .termos {
    font-size: 0.8em;
    margin: 10px 0 0 0;
    display: inline-block;
    padding-left: 25px;
    background: url(images/privace.png) left center no-repeat;
    text-transform: uppercase;
    color: #555;
}

/***********************************
############# MAINTENANCE ##############
**********************************/
.workcontrol_maintenance {
    padding: 20px;
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    background: #ba8585;
    color: #fff;
    text-shadow: 1px 1px 0px #855e5e;
}

/***********************************
########## MEDIA QUERIES ###########
**********************************/
@media (max-width: 34em) {
    .box2, .box3, .box4, .box5 {
        width: 100%;
        margin: 15px 0 15px 0 !important;
    }

    .label_50 label {
        display: block;
        width: 100%;
    }

    .label_50 label:nth-child(2n+0) {
        margin-left: 0;
    }

    .wc_ead_enter_actions, .form_actions {
        text-align: center !important;
    }
}

@media (min-width: 34em) and (max-width: 48em) {
    .box2, .box3, .box4, .box5 {
        width: 49%;
        margin: 1% 2% 1% 0 !important;
    }

    .box2:nth-of-type(2n+0), .box3:nth-of-type(2n+0), .box4:nth-of-type(2n+0), .box5:nth-of-type(2n+0) {
        margin-right: 0 !important;
    }
}

@media (min-width: 48em) and (max-width: 64em) {
    .box3, .box4, .box5 {
        /* width: 32%; */
        margin: 1% 1% 1% 0 !important;
    }

    .box3:nth-of-type(3n+0), .box4:nth-of-type(3n+0), .box5:nth-of-type(3n+0) {
        margin-right: 0 !important;
    }
}

@media (max-width: 60em) {
    .box_bar, .box_side {
        width: 100%;
        padding: 0;
    }
}

@media (min-width: 64em) and (max-width: 80em) {
    .box4, .box5 {
        width: 23.5%;
        margin: 1% 1% 1% 0 !important;
    }

    .box4:nth-of-type(4n+0), .box5:nth-of-type(4n+0) {
        margin-right: 0 !important;
    }
}
