 * {
     box-sizing:border-box;
     margin:0;
     padding:0;
     font-family:Roboto,sans-serif;
    }
a {
    text-decoration: none;
}
.btn {
    width:220px;
    height:65px;
    display:flex;
    justify-content:center;
    align-items:center;
    background-color:#fff;
    font-size:18px;
    font-weight:700;
    border:1px solid rgba(0,0,0,.2);
    box-shadow:0 4px 15px rgba(0,0,0,.2);
    cursor:pointer;
    transition:.3s all;
    outline:0; 
}

.btn_white {
    background-color:#fff 
}
.btn_dark {
    background-color:#303030;
    color:#fff;
    border:none;
}
.btn_min {
    height:50px;
}
.btn:hover {
    box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.container {
    max-width: 1200px;
    margin: 0 auto;
}
.divider {
    width:330px;
    height:1px;
    margin:0 auto;
    background-color:rgba(0,0,0,.5);
}
.title {
    font-size:36px;
    font-weight:400;
}
@media screen and (max-width: 900px) {
    .title {
        text-align: center;
    }
}

.header {
    display:flex;
    justify-content:space-between;
    align-items:center;
    height:150px;
    padding:0 100px;
}
@media screen and (max-width: 900px) {
    .header {
        padding:0 30px;
        height: 100px;
    }
}
.header__left-block {
    display:flex;
    justify-content:space-between;
    width: 65%;
    }
@media screen and (max-width: 900px) {
    .header__left-block {
        width: 100%;
    }
}
.header__logo {
    max-width:170px;
}
.header__logo img {
    width:100%;
}
.header__links {
    display:flex;
    align-items:center;
}
.header__link {
    position:relative;
    margin-right:20px;
    margin-left: 20px;
    font-weight:700;
    font-size:18px;
    color:#303030;
    text-align: center;
}
@media screen and (max-width: 900px) {
    .header__link { 
        -margin-right:25px;
    }
}
.header__link:after {
    content:'';
    position:absolute;
    display:block;
    width:110%;
    left:-5%;
    bottom:-1px;
    z-index:-1;
    height:8px;
    background:#54ed39 
    }
.header__link:last-child {
    -margin-right:0;
}
.header__right-block {

}
@media screen and (max-width: 900px) {
    .header__right-block {
        display: none;
    }
}
.sidepanel {
    position:fixed;
    left:60px;
    top:240px;
    height:400px;
    width:25px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    align-items:center 
}
@media screen and (max-width: 900px) {
    .sidepanel {
        display: none;
}
}   
.sidepanel__text {
    width:120px;
    height:120px;
    font-size:14px; 
}
.sidepanel__text span {
    display:flex;
    transform:rotate(-90deg) translateX(-50px);
}
.sidepanel__divider {
    width:1px;
    height:165px;
    background-color:#000;
}
.sidepanel__icon {
    width:24px;
    height:24px;
}
.sidepanel__icon img {
    width:100%;
}
.preview {
    padding:28px 0 100px 0;
    position:relative;
}
@media screen and (max-width: 900px) {
    .preview {
        padding:28px 0 30px 0;
    }
}
.preview__life {
    font-weight:700;
    font-size:20px;
    margin-left:35px;
    margin-top:35px;
    }

@media screen and (max-width: 900px) {
    .preview__life {
        text-align: center;
    }
}
.bgc_blue {
    position:absolute;
    right:0;
    top:-155px;
    width:50vw;
    height:900px;
    background:rgba(146,242,255,.15);
    z-index:-1;
}
@media screen and (max-width: 900px) {
    .bgc_blue {
        display: none;
    }
}
.tabcontainer {
    display:flex;
    max-width:1130px;
    width: 100%;
    margin:0 auto;
    box-shadow:0 4px 30px rgba(0,0,0,.25);
}
@media screen and (max-width: 900px) {
    .tabcontainer { 
        display:block;
    }
}
.tabcontent{
    width:850px;
    position:relative;
}
@media screen and (max-width: 900px) {
    .tabcontent
    {
        width:100%;
    }
}
.tabcontent img {
    width:100%;
    height:100%;
    object-fit:cover;
}
.tabcontent__descr {
    position:absolute;
    top:300px;
    right:-177px;
    width:550px;
    height:359px;
    background:rgba(251,254,93,.8);
    padding:50px;
    font-size:24px;
    font-weight:300;
    line-height:36px;
    color:rgba(0,0,0,.7);
}
@media screen and (max-width: 900px) {
    .tabcontent__descr {
        position: inherit;
        top:0px;
        right:0px;
        width:100%;
        height: 130px;
        font-size: 16px;
        padding: 15px;
        line-height:20px;
    }
}
.tabheader {
    width:280px;
    padding:35px 30px;
    background-color:#fff;
}
.tabheader h3 {
    font-weight:700;
    font-size:16px;
}
.tabheader__items {
    margin-top:35px;
    padding-left:26px;
    border-left:1px solid #000;
}
.tabheader__item {
    font-weight:700;
    font-size:18px;
    font-weight:300;
    margin-top:10px;
    color:rgba(0,0,0,.6);
    cursor:pointer;
    transition:.3s all;
}
.tabheader__item_active {
    color:#000;
    font-size:22px;
    font-weight:700;
}
.offer {
    padding:70px 0 100px 0;
    position:relative;
}
.offer .container {
    display:flex;
    justify-content:space-between;
}
@media screen and (max-width: 900px) {
    .offer .container {
        flex-wrap: wrap;
    }
}
.offer .bgc_y {
    position:absolute;
    width:1109px;
    height:780px;
    background:rgba(243,255,222,.45);
    z-index:-1;
    top:50px;
}
@media screen and (max-width: 900px) {
    .offer .bgc_y {
        width: 100%;
}
}
.offer__text
{
    width:580px;
}
.offer__descr {
    font-size:18px;
    margin-top:30px;
    font-weight:300;
    line-height:24px;
}
@media screen and (max-width: 900px) {
    .offer__descr {
        padding: 0 20px;
    }
}
.offer__action {
    display:flex;
    align-items:center;
    justify-content:flex-end;
}
@media screen and (max-width: 900px) {
    .offer__action  {
        width: 220px;
        margin: 20px auto 0;
    }
}
.offer__advantages {
    width:330px;
    margin-top:50px;
}
@media screen and (max-width: 900px) {
    .offer__advantages {
        width: 100%;
        margin-top:10px;
        padding: 0 20px;

    } 
}
.offer__advantages h2 {
    font-weight:700;
    font-size:20px;
    margin-top:20px;
}
.offer__advantages h2:first-child {
    margin-top:70px;
}
.offer__advantages-text {
    margin-top:20px;
    font-size:18px;
    font-weight:300;
    line-height:21px;
}
.offer__slider {
    width:650px;
    margin-top:50px;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
}
.fotorama {
    display: none;
}
@media screen and (max-width: 900px) and (min-width: 600px)
{
    .offer__slider {
        width: 100%;
        margin-top: 50px;
        
    }
    .fotorama {
        display: block;
        width: 580px;
        margin: 0 auto;
    }
    .fotorama img{
        width: 580px;
        margin: 0 auto;
    }
}
@media screen and (max-width: 599px) 
{
    .offer__slider {
        /*width:350px;
        margin: 0 auto;*/
    }
    .fotorama {
        display: block;
        width: 400px;
        margin: 0 auto;
    }
}
.offer__slider-counter {
    display:flex;
    width:180px;
    align-items:center;
    font-size:24px;
    color:rgba(0,0,0,.5);
}
@media screen and (max-width: 900px)
{
    .offer__slider-counter {
        display: none;
    }
}
.offer__slider-wrapper {
    width:100%;
    margin-top:15px;
    box-shadow:0 4px 30px rgba(0,0,0,.25);
}
@media screen and (max-width: 900px)
{
    .offer__slider-wrapper {
        display: none;
    }
}
.offer__slider-prev {
    margin-right:10px;
    cursor:pointer;
}
.offer__slider-next {
    margin-left:10px;
    cursor:pointer;
}
.offer__slider #current {
    font-size:48px;
    font-weight:700;
    color:#000;
}
.offer__slide {
    width:100%;
    height:390px;
}
.offer__slide img {
    width:100%;
    height:100%;
    object-fit:cover;
}
.calculating {
    padding:50px 0;
}
.calculating .title {
    text-align:center;
}
.calculating__field {
    width:100%;
    margin-top:50px;
    background:rgba(146,242,255,.15);
    padding:30px 0 40px 0;
}
.calculating__subtitle {
    text-align:center;
    font-size:18px;
    font-weight:700;
    margin-top:30px;
}
.calculating__subtitle:first-child {
    margin-top:0;
}
.calculating #gender:after 
{
    content:'';
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    display:block;
    width:16px;
    height:16px;
    background:url(../icons/switch.svg) center center/cover no-repeat;
}
.calculating__choose 
{
    position:relative;
    display:flex;
    margin-top:30px;
    justify-content:center;
}
@media screen and (max-width: 900px) {
    .calculating__choose 
    {
        display: block;
        width: 380px;
        margin: 30px auto;
    }
}
.calculating__choose-item {
    display:flex;
    align-items:center;
    justify-content:center;
    width:170px;
    height:50px;
    padding:0 10px;
    background:#fff;
    box-shadow:0 4px 15px rgba(0,0,0,.2);
    border:none;
    text-align:center;
    font-size:14px;
    cursor:pointer;
    outline:0;
    transition:.3s all;
}
@media screen and (max-width: 900px) {
    .calculating__choose-item {
        width:380px;
        margin-bottom: 10px;
    }
}
.calculating__choose-item_active {
    color:#fff;
    background-color:#54ed39;
}
.calculating__choose_medium {
    width:743px;
    justify-content:space-between;
    margin:30px auto 0 auto;
}
@media screen and (max-width: 900px) {
    .calculating__choose_medium {
        width:380px;
    }
}
.calculating__choose_big {
    width:930px;
    justify-content:space-between;
    margin:30px auto 0 auto;
}
@media screen and (max-width: 900px) {
    .calculating__choose_big {
        width:100%;
    }
}
.calculating__choose_big .calculating__choose-item {
    width:200px;
}
@media screen and (max-width: 900px) {
    .calculating__choose_big .calculating__choose-item {
        width:380px;
        margin: 0 auto;
    } 
}
.calculating__divider {
    width:490px;
    height:1px;
    margin:40px auto;
    background-color:rgba(0,0,0,.2);
}
@media screen and (max-width: 900px) {
    .calculating__divider {
        width:330px; 
    }
}
.calculating__total {
    width:490px;
    margin:0 auto;
    display:flex;
    justify-content:space-between;
    align-items:center;
}
@media screen and (max-width: 900px) {
    .calculating__total {
        width:350px;
    }
}
.calculating__result {
    font-size:18px;
    font-weight:700;
}
.calculating__result span {
    font-size:42px;
}
.menu {
    padding:40px 0 50px 0;
}
.menu .container {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
}
@media screen and (max-width: 900px) {
    .menu .container {
        display:flex;
        flex-direction: column;
}
}
.menu .title {
    text-align:center;
}
.menu__field {
    margin-top:50px;
    padding:50px 0;
    width:100%;
    background:rgba(249,254,126,.25);
}
.menu__item {
    width:320px;
    min-height:450px;
    background:#fff;
    box-shadow:0 4px 25px rgba(0,0,0,.25);
    font-size:16px;
    font-weight:300;
}
@media screen and (max-width: 900px) {
    .menu__item {
        width:375px;
        min-height:550px;
        margin: 20px auto;
    }  
}
.menu__item img {
    width:100%;
    height:200px;
    object-fit:cover;
}
.menu__item-subtitle {
    font-weight:700;
    font-size:18px;
    padding:0 20px;
    margin-top:20px;
}
.menu__item-descr {
    margin-top:20px;
    padding:0 20px;
}
.menu__item-divider {
    width:100%;
    height:1px;
    background-color:rgba(0,0,0,.25);
    margin-top:40px;
}
.menu__item-price {
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:10px 20px;
}
.menu__item-price span {
    font-size:24px;
    font-weight:700;
}
.order {
    padding-bottom:80px;
}
@media screen and (max-width: 900px) {
    .order {
        padding: 0 20px;
    }
}
.order .title {
    text-align:center;
}
.order__form {
    margin-top:70px;
    padding:0 100px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}
@media screen and (max-width: 900px) {
    .order__form {
        flex-wrap: wrap;
        padding: 0 20px;
        margin-top: 40px;
    }
    .order__form .btn {
        width: 280px;
        margin: 10px auto;
    }
}
.order__form img {
    transform:scale(1.5);
}
@media screen and (max-width: 900px)
{
    .order__form img {
        display: none;
    }
}
.order__input {
    width:280px;
    height:50px;
    background:#fff;
    box-shadow:0 4px 15px rgba(0,0,0,.2);
    border:none;
    font-size:18px;
    text-align:center;
    padding:0 20px;
    outline:0;
}
@media screen and (max-width: 900px)
{
    .order__input {
        margin: 10px auto;
    }
}
.promotion {
    padding:70px 0 240px 0;
    position:relative;
}
@media screen and (max-width: 900px) {
    .promotion {
        padding:70px 0 40px 0;
}
}
.promotion .container {
    display:flex;
}
@media screen and (max-width: 900px) {
    .promotion .container {
        display:block;
        
    }
}
.promotion .bgc_y {
    position:absolute;
    width:50%;
    height:499px;
    background:rgba(243,255,222,.35);
    z-index:-1;
    top:-50px;
    left:0;
}
@media screen and (max-width: 900px) {
    .promotion .bgc_y {
        width:100%; 
    }
}
.promotion__text {
    width:50%;
}
@media screen and (max-width: 900px) {
    .promotion__text {
        width:100%;
        text-align: center;
}
}
.promotion__descr {
    margin-top:40px;
    font-size:20px;
    line-height:24px;
    font-weight:300;
}
@media screen and (max-width: 900px) {
    .promotion__descr {
        margin: 20px;
    }
}
.promotion__descr span {
    font-weight:700;
    font-size:26px;
}
.promotion__timer {
    width:50%;
}
@media screen and (max-width: 900px) {
    .promotion__timer {
        width:100%;
        padding: 10px 20px;
        text-align: center;
    }
}
.promotion__timer .title {
    text-align:right;
}
@media screen and (max-width: 900px) {
    .promotion__timer .title {
        text-align:center;
    }
}
.promotion__timer .timer {
    margin-top:60px;
    padding-left:95px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}
@media screen and (max-width: 900px) {
    .promotion__timer .timer {
        padding: 0 35px;
    }
}
.promotion__timer .timer__block {
    width:102px;
    height:120px;
    background:#fff;
    box-shadow:0 4px 20px rgba(0,0,0,.25);
    font-size:16px;
    font-weight:300;
    text-align:center;
}
.promotion__timer .timer__block span {
    display:block;
    margin-top:20px;
    margin-bottom:5px;
    font-size:56px;
    font-weight:700;
}
.footer {
    min-height:180px;
    background-color:#303030;
    padding:45px 0 50px 0;
    color:#fff;
}
@media screen and (max-width: 900px) {
    .footer {
        padding:40px 20px;
    }
}
.footer .container {
    height:100%;
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
}
.footer .subtitle {
    font-size:20px;
}
.footer .link {
    display:block;
    margin-top:15px;
    font-size:16px;
    color:#fff;
}
.footer .call {
    text-align:right;
}
.modal {
    position:fixed;
    top:0;
    left:0;
    z-index:1050;
    display:none;
    width:100%;
    height:100%;
    overflow:hidden;
    background-color:rgba(0,0,0,.5);
}
.modal__dialog {
    max-width:500px;
    margin:40px auto;
}
.modal__content {
    position:relative;
    width:100%;
    padding:40px;
    background-color:#fff;
    border:1px solid rgba(0,0,0,.2);
    border-radius:4px;
    max-height:80vh;
    overflow-y:auto;
}
.modal__close {
    position:absolute;
    top:8px;
    right:14px;
    font-size:30px;
    color:#000;
    opacity:.5;
    font-weight:700;
    border:none;
    background-color:transparent;
    cursor:pointer; 
}
.modal__title {
    text-align:center;
    font-size:22px;
    text-transform:uppercase;
}
.modal__input {
    display:block;
    margin:20px auto 20px auto;
    width:280px;
    height:50px;
    background:#fff;
    box-shadow:0 4px 15px rgba(0,0,0,.2);
    border:none;
    font-size:18px;
    text-align:center;
    padding:0 20px;
    outline:0;
}
.modal .btn {
    display:block;
    width:280px;
    margin:0 auto;
}
.show {
    display:block;
}
.hide {
    display:none;
}
.fade {
    animation-name: fade;
    animation-duration: 1.5s;
}
@keyframes fade {
    from {opacity: 0.1;}to{opacity: 1;}}

