body {
    font-family: CorporateS;
    font-size: 16px;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.38;
    letter-spacing: normal;
}

input {
    background-color: #F2F2F2;
    color: #000000;
    font-family: CorporateS;
    line-height: 2;
    padding: 1em;
}

input[type=text], input[type=email], input[type=password], textarea {
    width: calc(100% - 4em);
    background-color: #F2F2F2;
    color: #000000;
    line-height: 2;
    font-size: 0.8em;
    font-family: CorporateS;
    padding: 0.5em 2em;
    margin-bottom: 1em;
    border: none;
}

button {
    background-color: #000000;
    color: #FFFFFF;
    border: none;
    padding: 1em 5em;
}

a {
    text-decoration: none;
    color: #000000;
    font-weight: bold;
}

.content {
    margin: 0 20%;
    min-height: 100vh;
    padding-bottom: 4em;
}

h3 {
    font-family: CorporateACon-Reg;
}

.form-error-message {
    color: red;
    padding: 1em;
}

#menu {
    display: none;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: calc(20% - 6em);
    padding: 3em;
    padding-top: 7em;
    background-color: #000000;
    color: #FFFFFF;
    z-index: 1000;
}

#menu .menu-container {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
}

#menu a {
    padding: 0.5em;
    color: #FFFFFF;
    width: 100%;
    border-bottom: 1px solid #FFFFFF;
    font-family: CorporateACon-Reg;
    font-size: 0.9em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 2;
    letter-spacing: normal;
    text-align: left;
}

#menu a:hover {
    color: #000000;
    background-color: #FFFFFF;
}

.top-container {
    padding: 0 20%;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    background-color: #000000;
    color: #FFFFFF;
}

.top-container a {
    color: #FFFFFF;
    font-family: CorporateACon-Reg;
    font-size: 1em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.44;
    letter-spacing: normal;
}

.top-container > div {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.top-container h3.service-name {
    font-size: 1.2em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.38;
    letter-spacing: normal;
    font-size: 1em;
    padding-left: 3em;
}

.top-container .logo img {
    max-height: 3em;
    padding: 1em 3em 1em 0;
    border-right: 1px solid #000000;
}

.top-container .menu-second-sub-container a {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.top-container .menu-second-sub-container div, .top-container .menu-second-sub-container img {
    margin-left: 1em;
}

.top-container .menu-second-sub-container img {
    height: 2em;
    width: auto;
}

.top-container img.menu-img {
    background-color: #FFFFFF;
    margin-left: 3em;
}

#menu-button {
    height: 1.2em;
    padding: 0.5em;
    border-radius: 5px;
    background-color: #ffffff;
}

.footer-container {
    padding: 0 20%;
    display: flex;
    flex-direction: row;
    align-items: center;
    background-color: #000000;
    color: #FFFFFF;
}

.footer-container h3.service-name {
    font-size: 26px;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.38;
    letter-spacing: normal;
    font-size: 1em;
}

.content .container {
    border-top: 1px solid #000000;
    padding: 3em 0;
}

.content .container:nth-of-type(n+1) {
    border-top: none;
}

.see-more-homepage-container {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    margin-bottom: 3em;
}

.see-more-homepage-container a {
    border-bottom: 1px solid #000000;
    display: inline-block;
    font-family: CorporateS;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.38;
    letter-spacing: normal;
}

.info-container {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.info-container .info-container-sub1 {
    max-width: 60%;
}

.info-container .info-container-sub2 {
    max-width: 40%;
    display: flex;
    flex-direction: row;
}

.info-container .worker-image {
    padding: 1em;
}

.news-container-sub {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    padding-top: 1em;
    flex-wrap: wrap;
}

.news-container-sub .single-news-container {
    background-color: #f5f5f5;
    width: 30%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    margin-bottom: 3em;
}

.news-container-sub .single-news-container:nth-of-type(3n - 1) {
    margin-left: 4.5%;
    margin-right: 4.5%;
}

.news-container-sub .img-news-container {
    width: 100%;
    height: 14em;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.news-container-sub .text-news-container {
    padding: 1em;
}

.single-news-container-sub2 {
    padding: 1em;
    padding-top: 0;
}

.news-container-sub .date {
    font-size: 0.7em;
}

.news-container-sub .news-more-button {
    font-family: CorporateS-Demi;
    display: inline-block;
    padding: 1em 3em;
    margin: 1em 0;
    background-color: #000000;
    color: #FFFFFF;
    text-transform: uppercase;
    font-size: 0.8em;
}

.category-container-sub {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-top: 1em;
}

.category-container-sub .single-category-container {
    background-color: #f5f5f5;
    width: 18%;
    margin-bottom: 2em;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.category-container-sub .img-category-container {
    width: 50%;
    height: 5em;
    margin: 1em 25%;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

.category-container-sub .title-category-container {
    padding: 1em 0.5em;
    background-color: #000000;
    color: #FFFFFF;
    font-weight: normal;
    font-size: 0.8em;
    text-align: center;
}

.campaigns-container .campaign-container-sub {
    display: flex;
    flex-direction: row;
    justify-content: space-between;

}

.campaigns-container .single-campaign-container {
    width: 49%;
}

.campaigns-container .campaign-image {
    width: 100%;
    height: 10vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.campaigns-container .campaign-title {
    display: flex;
    flex-direction: row;
    color: #FFFFFF;
    font-family: CorporateACon-Reg;
    font-size: 1em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.44;
    letter-spacing: normal;
}

.campaigns-container .campaign-title > div {
    background-color: #000000;
    padding: 1em 3em;
}

.newsSinglePage .image {
    width: 100%;
    height: 15vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    margin: 3em 0;
}

.newsSinglePage .date {
    font-size: 0.8em;
    padding: 1em 0;
    margin: 3em 0 0 0;
}

.newsSinglePage .title {
    font-family: CorporateACon-Reg;
    font-size: 1.5em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.42;
    letter-spacing: normal;
    padding: 1em 0;
}

.newsSinglePage .description {
    font-family: CorporateS;
    font-weight: 300;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.5;
    letter-spacing: normal;
    padding: 1em 0;
}

.newsSinglePage .description img {
    height: 17em;
    margin: 1em 2em 2em 0;
}

.campaignSinglePage .image {
    width: 100%;
    height: 15vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    margin: 3em 0;
}

.campaignSinglePage .date {
    font-size: 0.8em;
    padding: 1em 0;
}

.campaignSinglePage .title {
    font-family: CorporateACon-Reg;
    font-size: 1.5em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.42;
    letter-spacing: normal;
    padding: 1em 0;
}

.campaignSinglePage .products-container {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    padding-top: 1em;
    flex-wrap: wrap;
}

.campaignSinglePage .single-product-container {
    width: 30%;
}

.campaignSinglePage .single-product-container:nth-of-type(3n - 1) {
    margin-left: 4.5%;
    margin-right: 4.5%;
}

.campaignSinglePage .single-product-container .image-product {
    width: 100%;
    height: 9vw;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: top center;
}

.campaignSinglePage .single-product-link-container {
    padding: 2em;
    padding-top: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    text-align: center;
}

.campaignSinglePage .single-product-link-container a {
    font-family: CorporateACon-Reg;
    font-weight: normal;
    border-bottom: 3px solid #F2F2F2;
}

.contactFormCampaign-container {
    padding: 2em 0;
}

.contactFormCampaign-container h3 {
    display: inline-block;
    width: 100%;
    text-align: center;
}

.productSinglePage {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    padding: 3em 0;
}

.productSinglePage > div {
    width: 48%;
}

.productSinglePage .big-image-product {
    width: 100%;
    height: 20vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.productSinglePage .product-shop-panel {
    display: flex;
    justify-content: space-between;
}

.productSinglePage .quantity-box {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.productSinglePage > div {
    padding: 0 3px;
}

.productSinglePage .quantity-input-container input {
    width: 6em;
    text-align: center;
    padding: 0;
    margin: 0 0.5em;
}

.productSinglePage .quantity-label, .productSinglePage .price-label {
    font-family: CorporateS;
    font-size: 0.7em;
    font-weight: 300;
    font-stretch: normal;
    font-style: normal;
    line-height: 2;
    letter-spacing: normal;
}

.productSinglePage .price-value {
    font-weight: bold;
}

.productSinglePage .input-container {
    padding: 2em 0;
}

.productSinglePage .product-second-container-youtube {
    width: 100%;
}

.productSinglePage .product-videos-panel {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    padding-top: 1em;
}

.single-video-youtube {
    text-align: center;
}

.confirm-make-order {
    display: flex;
    justify-content: flex-end;
    flex-direction: row;
}

.confirm-make-order button {
    background-color: #000000;
    color: #FFFFFF;
    border: none;
    padding: 1em 5em;
}

#button-quantity-order-plus, #button-quantity-order-minus {
    cursor: default;
    padding: 0 0.5em;
}

.news-container-sub .single-productSubCategory-container {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2em 3em;
    width: calc(30% - 6em);
}

.paging a.paging-button {
    font-weight: normal;
    font-family: CorporateS;
    padding: 0.5em;
}

.paging a.paging-button:hover {
    font-weight: bold;
}

.paging a.active {
    font-weight: bold;
}

.loginPage {
    text-align: center;
    padding-top: 3em;
}

.loginPage .register-new-account {
    padding-top: 3em;
}

.registerPage {
    text-align: center;
}

.registerSuccess {
    padding-top: 4em;
}

.appPage .news-container-sub {
    justify-content: space-between;
}

.appPage .news-container-sub .single-news-container-homepage {
    width: 48%;
}

.appPage .news-container-sub .single-news-container-homepage {
    margin-left: 0;
    margin-right: 0;
}

.prev-top-button-container {
    padding: 3em 0 0 0;
}

.prev-top-button-container a {
    color: #d2d2d2;
}

.infoPage {
    padding-top: 5em;
    text-align: center;
}

.banner-container {
    width: 100%;
}

.banner-container .banner-image {
    width: 100%;
    height: 15vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}
.banner-container .banner-title {
    display: flex;
    flex-direction: row;
    color: #FFFFFF;
    font-family: CorporateACon-Reg;
    font-size: 1em;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.44;
    letter-spacing: normal;
}
.banner-container .banner-title > div {
    background-color: #000000;
    padding: 1em 3em;
}