
.cart-page .page-content {
  padding: 0 0 40px; }
  .cart-page .page-content h1, .cart-page .page-content .h1 {
    font-weight: 600;
    font-size: 36px;
    text-align: center;
    margin: 0 0 50px; }

.cart-page .cart-container {
  margin-bottom: 30px; }
  .cart-page .cart-container:before, .cart-page .cart-container:after {
    content: " ";
    display: table; }
  .cart-page .cart-container:after {
    clear: both; }

.cart-page .cart-head {
  background-color: #EFF1F5;
  display: flex;
  font-size: 16px;
  text-align: center;
  padding: 12px 0;
  border-radius: 3px;
  font-weight: 400;
  margin-bottom: -2px;
  position: relative;
  z-index: 1;
  color: #555; }
  .cart-page .cart-head .img-cell {
    flex: 0 0 165px; }
  .cart-page .cart-head .name-cell {
    flex: 0 0 450px; }
  .cart-page .cart-head .cost-cell {
    flex: 0 0 150px; }
  .cart-page .cart-head .calc-cell {
    flex: 0 0 210px; }
  .cart-page .cart-head .sum-cell {
    flex: 0 0 160px; }

.cart-page .cart-item {
  border-top: 1px solid #C4C4C4;
  padding: 20px 0;
  padding-right: 35px;
  position: relative;
  width: 100%;
  display: flex;
  align-items: center; }
  .cart-page .cart-item:first-child {
    border-bottom: 0; }
  .cart-page .cart-item .text-block {
    margin-right: 30px;
    width: 420px; }
  .cart-page .cart-item .calc-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: -15px; }
  .cart-page .cart-item .img-block {
    width: 120px;
    height: 120px;
    margin-right: 30px;
    margin-left: 20px;
    overflow: hidden;
    transition: 0.3s; }
    .cart-page .cart-item .img-block a {
      display: flex;
      justify-content: center;
      align-items: center;
      width: 100%;
      height: 100%; }
    .cart-page .cart-item .img-block img {
      display: block;
      margin: auto;
      max-width: 100%;
      max-height: 100%; }
    .cart-page .cart-item .img-block:hover, .cart-page .cart-item .img-block:focus {
      opacity: 0.7; }
  .cart-page .cart-item .title {
    font-size: 18px;
    margin: 0 0 5px;
    max-width: 400px;
    font-weight: 400;
    line-height: 1.3; }
    .cart-page .cart-item .title a {
      color: inherit;
      text-decoration: none; }
      .cart-page .cart-item .title a:hover {
        text-decoration: underline; }
  .cart-page .cart-item .descr-text {
    color: #74747A; }
  .cart-page .cart-item .product-sum,
  .cart-page .cart-item .product-cost {
    margin: 0;
    font-size: 18px;
    text-align: center;
    width: 150px;
    font-weight: 500; }
    .cart-page .cart-item .product-sum span,
    .cart-page .cart-item .product-cost span {
      font-size: 20px; }
  .cart-page .cart-item .default-cost {
    font-size: 16px; }
    .cart-page .cart-item .default-cost span {
      font-size: 20px;
      font-weight: 500; }
  .cart-page .cart-item .new-cost {
    color: #ff2600;
    font-size: 16px;
    line-height: 1;
    margin-top: -7px; }
    .cart-page .cart-item .new-cost span {
      font-size: 20px;
      font-weight: 500; }
  .cart-page .cart-item .old-cost {
    display: inline-block;
    color: #74747a;
    font-size: 16px;
    line-height: 1;
    position: relative;
    top: -5px; }
    .cart-page .cart-item .old-cost span {
      font-size: 18px; }
    .cart-page .cart-item .old-cost:after {
      content: '';
      height: 1px;
      left: -1px;
      right: -1px;
      background-color: #74747a;
      position: absolute;
      top: 49%; }
  .cart-page .cart-item .close-btn {
    width: 24px;
    height: 24px;
    background: url(../img/icons/trash-icon.svg) no-repeat center;
    background-size: 20px;
    color: #fff;
    position: absolute;
    border: 0;
    top: 50%;
    right: 10px;
    margin-top: -15px;
    outline: none;
    font-size: 16px;
    text-align: center;
    transition: 0.3s;
    cursor: pointer;
    opacity: 0.3; }
    .cart-page .cart-item .close-btn:hover {
      opacity: 1; }
  .cart-page .cart-item .calc-block {
    display: inline-block;
    vertical-align: middle;
    width: 110px;
    height: 36px;
    position: relative;
    overflow: hidden;
    margin: 0 50px; }
    .cart-page .cart-item .calc-block .amount-control {
      display: block;
      margin: auto;
      height: 36px;
      width: 45px;
      text-align: center;
      font-size: 16px;
      line-height: 38px;
      border: 0;
      padding: 0 5px;
      outline: 0;
      background: #fff;
      font-family: "Roboto Bold", Arial, sans-serif; }
    .cart-page .cart-item .calc-block .increase-btn,
    .cart-page .cart-item .calc-block .decrease-btn {
      position: absolute;
      top: 0;
      height: 36px;
      width: 36px;
      padding: 0;
      background: transparent;
      border: 0;
      outline: none;
      cursor: pointer;
      border: 1px solid #787777; }
      .cart-page .cart-item .calc-block .increase-btn:hover,
      .cart-page .cart-item .calc-block .decrease-btn:hover {
        border-color: #FF4C00; }
        .cart-page .cart-item .calc-block .increase-btn:hover:before, .cart-page .cart-item .calc-block .increase-btn:hover:after,
        .cart-page .cart-item .calc-block .decrease-btn:hover:before,
        .cart-page .cart-item .calc-block .decrease-btn:hover:after {
          background: #FF4C00; }
    .cart-page .cart-item .calc-block .increase-btn {
      right: 0; }
    .cart-page .cart-item .calc-block .increase-btn:before,
    .cart-page .cart-item .calc-block .increase-btn:after {
      content: '';
      background: #212121;
      position: absolute; }
    .cart-page .cart-item .calc-block .increase-btn:before {
      top: 16px;
      left: 10px;
      width: 15px;
      height: 1px; }
    .cart-page .cart-item .calc-block .increase-btn:after {
      top: 9px;
      left: 17px;
      width: 1px;
      height: 15px; }
    .cart-page .cart-item .calc-block .decrease-btn {
      left: 0; }
    .cart-page .cart-item .calc-block .decrease-btn:after {
      content: '';
      width: 14px;
      height: 1px;
      background: #212121;
      position: absolute;
      top: 16px;
      left: 10px; }

.cart-page .together-container {
  border: 1px solid #DE3D3D;
  border-radius: 3px;
  position: relative;
  padding: 15px 10px 10px;
  margin-top: 15px;
  margin-bottom: -3px;
  background-color: #fff;
  z-index: 1; }
  .cart-page .together-container .together-title {
    display: inline-block;
    background-color: #fff;
    padding: 0 10px;
    color: #DE3D3D;
    position: absolute;
    left: 30px;
    top: -15px;
    font-weight: 400; }
  .cart-page .together-container .together-row {
    display: flex;
    align-items: center;
    justify-content: space-between; }
  .cart-page .together-container .together-item {
    display: flex;
    align-items: center;
    width: 45%; }
    .cart-page .together-container .together-item .img-block {
      flex: 0 0 120px;
      width: 120px;
      height: 120px;
      margin-right: 20px; }
      .cart-page .together-container .together-item .img-block a {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 100%; }
        .cart-page .together-container .together-item .img-block a img {
          display: block;
          max-width: 100%;
          max-height: 100%; }
    .cart-page .together-container .together-item .text-block .title {
      font-size: 18px;
      line-height: 1.2;
      font-weight: 600;
      max-width: 320px;
      margin: 0 10px 15px 0; }
      .cart-page .together-container .together-item .text-block .title a {
        color: inherit;
        text-decoration: none; }
        .cart-page .together-container .together-item .text-block .title a:hover {
          text-decoration: underline; }
    .cart-page .together-container .together-item .text-block .descr-text {
      color: #74747a; }
    .cart-page .together-container .together-item .product-cost .default-cost {
      color: #212121;
      font-size: 16px; }
      .cart-page .together-container .together-item .product-cost .default-cost span {
        font-size: 20px;
        font-weight: 500; }
    .cart-page .together-container .together-item .product-cost .new-cost {
      color: #DE3D3D;
      font-size: 16px;
      line-height: 1;
      margin-top: -7px; }
      .cart-page .together-container .together-item .product-cost .new-cost span {
        font-size: 20px;
        font-weight: 500; }
    .cart-page .together-container .together-item .product-cost .old-cost {
      display: inline-block;
      color: #74747a;
      font-size: 18px;
      line-height: 1;
      position: relative;
      top: -5px; }
      .cart-page .together-container .together-item .product-cost .old-cost span {
        font-size: 18px; }
      .cart-page .together-container .together-item .product-cost .old-cost:before {
        top: 51%; }
  .cart-page .together-container .together-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 30px;
    font-size: 16px;
    background-color: #EDF0F3;
    padding: 8px 12px; }
  .cart-page .together-container .calc-block {
    width: 110px;
    height: 30px;
    position: relative;
    overflow: hidden;
    margin-left: 10px;
    margin-top: -3px; }
    .cart-page .together-container .calc-block .amount-control {
      display: block;
      margin: auto;
      height: 35px;
      width: 45px;
      text-align: center;
      font-size: 16px;
      line-height: 38px;
      border: 0;
      padding: 0 5px;
      outline: 0;
      background: #EDF0F3; }
    .cart-page .together-container .calc-block .increase-btn,
    .cart-page .together-container .calc-block .decrease-btn {
      position: absolute;
      top: 0;
      height: 30px;
      width: 30px;
      padding: 0;
      background: transparent;
      border: 0;
      outline: none;
      cursor: pointer;
      border: 1px solid #212121;
      background-color: #fff; }
      .cart-page .together-container .calc-block .increase-btn:hover,
      .cart-page .together-container .calc-block .decrease-btn:hover {
        border-color: #FF4C00; }
        .cart-page .together-container .calc-block .increase-btn:hover:before, .cart-page .together-container .calc-block .increase-btn:hover:after,
        .cart-page .together-container .calc-block .decrease-btn:hover:before,
        .cart-page .together-container .calc-block .decrease-btn:hover:after {
          background: #FF4C00; }
    .cart-page .together-container .calc-block .increase-btn {
      right: 0; }
    .cart-page .together-container .calc-block .increase-btn:before,
    .cart-page .together-container .calc-block .increase-btn:after {
      content: '';
      background: #212121;
      position: absolute; }
    .cart-page .together-container .calc-block .increase-btn:before {
      top: 14px;
      left: 7px;
      width: 15px;
      height: 1px; }
    .cart-page .together-container .calc-block .increase-btn:after {
      top: 7px;
      left: 14px;
      width: 1px;
      height: 14px; }
    .cart-page .together-container .calc-block .decrease-btn {
      left: 0; }
    .cart-page .together-container .calc-block .decrease-btn:after {
      content: '';
      width: 14px;
      height: 1px;
      background: #212121;
      position: absolute;
      top: 14px;
      left: 7px; }
  .cart-page .together-container .together-calc,
  .cart-page .together-container .together-cost,
  .cart-page .together-container .together-sum {
    display: flex;
    align-items: center; }
  .cart-page .together-container .cost-text {
    margin-right: 10px;
    font-weight: 400;
    font-size: 17px; }
  .cart-page .together-container .calc-text {
    font-weight: 400;
    font-size: 17px; }
  .cart-page .together-container .cost-num {
    font-size: 20px;
    font-weight: 500;
    color: #DE3D3D;
    margin-top: -2px; }
  .cart-page .together-container .total-num {
    font-size: 20px;
    font-weight: 500;
    color: #DE3D3D;
    margin-top: -2px; }
  .cart-page .together-container .close-btn {
    width: 24px;
    height: 24px;
    background: url(../img/icons/trash-icon.svg) no-repeat center;
    background-size: 20px;
    color: #fff;
    position: absolute;
    border: 0;
    top: 25px;
    right: 10px;
    margin-top: -15px;
    outline: none;
    font-size: 16px;
    text-align: center;
    transition: 0.3s;
    cursor: pointer;
    opacity: 0.3; }
    .cart-page .together-container .close-btn:hover {
      opacity: 1; }

.cart-page .cart-footer {
  float: right;
  width: 400px;
  padding: 10px 0 0; }
  .cart-page .cart-footer .delivery-text {
    text-align: right;
    font-size: 14px;
    color: #74747a;
    margin: 10px 0; }
  .cart-page .cart-footer .cost-table {
    width: 100%;
    margin-top: 20px;
    margin-bottom: 25px; }
    .cart-page .cart-footer .cost-table span {
      background-color: #fff;
      position: relative;
      bottom: -7px;
      z-index: 1;
      display: inline-block; }
    .cart-page .cart-footer .cost-table .red-text {
      color: #DE3D3D; }
    .cart-page .cart-footer .cost-table strong {
      font-size: 20px;
      font-weight: 600; }
    .cart-page .cart-footer .cost-table td {
      padding: 3px 0;
      border-bottom: 1px dotted #BBB; }
      .cart-page .cart-footer .cost-table td:last-child {
        text-align: right; }
  .cart-page .cart-footer .btn-primary,
  .cart-page .cart-footer .btn-light {
    width: 100%;
    height: 48px;
    margin-bottom: 15px;
    font-weight: 400;
    font-size: 18px;
    display: flex;
    justify-content: center;
    align-items: center; }
  .cart-page .cart-footer .btn-success {
    margin-bottom: 15px; }

.cart-page .empty-cart {
  clear: both;
  padding: 150px 0; }
  .cart-page .empty-cart .lg-icon {
    margin-bottom: 15px; }
  .cart-page .empty-cart img {
    display: block;
    max-width: 90px;
    max-height: 90px;
    margin: 0 auto; }
  .cart-page .empty-cart .h2 {
    font-size: 32px;
    font-weight: 400;
    text-align: center;
    margin-bottom: 15px; }
  .cart-page .empty-cart p {
    font-size: 18px;
    color: #212121;
    text-align: center;
    max-width: 500px;
    margin: 0 auto; }
    .cart-page .empty-cart p a {
      color: #FF4C00; }
      .cart-page .empty-cart p a:hover {
        text-decoration: none; }

@media (max-width: 1399px) {
  .cart-page .cart-head .name-cell {
    flex: 0 0 440px; } }

@media (max-width: 1199px) {
  .cart-page .page-content h1, .cart-page .page-content .h1 {
    font-size: 32px; }
  .cart-page .cart-head .img-cell {
    flex: 0 0 140px; }
  .cart-page .cart-head .name-cell {
    flex: 0 0 230px; }
  .cart-page .cart-item .img-block {
    margin-left: 0;
    margin-right: 20px; }
  .cart-page .cart-item .text-block {
    width: auto;
    max-width: 200px;
    flex: 0 0 200px; }
  .cart-page .cart-item .title {
    font-size: 14px; }
  .cart-page .cart-item .descr-text {
    font-size: 13px; }
  .cart-page .cart-item .product-sum,
  .cart-page .cart-item .product-cost {
    font-size: 16px; }
    .cart-page .cart-item .product-sum span,
    .cart-page .cart-item .product-cost span {
      font-size: 16px; }
  .cart-page .together-container {
    padding: 15px; }
    .cart-page .together-container .together-item .text-block {
      flex: 0 0 200px; }
      .cart-page .together-container .together-item .text-block .title {
        font-size: 14px; }
      .cart-page .together-container .together-item .text-block .descr-text {
        font-size: 14px; }
    .cart-page .together-container .together-item .img-block {
      margin-bottom: 10px; }
    .cart-page .together-container .together-footer {
      margin-top: 10px; }
    .cart-page .together-container .together-calc,
    .cart-page .together-container .together-cost,
    .cart-page .together-container .together-sum {
      font-size: 13px; }
    .cart-page .together-container .cost-text {
      margin-right: 5px;
      font-size: 13px; }
    .cart-page .together-container .cost-num {
      font-size: 16px; }
    .cart-page .together-container .total-num {
      font-size: 16px; }
  .cart-page .empty-cart img {
    max-width: 60px;
    max-height: 60px; }
  .cart-page .empty-cart .h2 {
    font-size: 24px; } }

@media (max-width: 991px) {
  .cart-page .page-content h1, .cart-page .page-content .h1 {
    font-size: 28px;
    margin-bottom: 5px; }
  .cart-page .cart-container {
    overflow: hidden;
    position: relative; }
    .cart-page .cart-container:after {
      content: '';
      position: absolute;
      left: 0;
      top: -1px;
      height: 3px;
      background-color: #fff;
      width: 100%; }
  .cart-page .cart-head {
    display: none; }
  .cart-page .cart-item .img-block {
    width: auto;
    max-width: 100px;
    flex: 0 0 100px;
    margin-right: 10px; }
  .cart-page .cart-item .text-block {
    flex: 0 0 150px;
    max-width: 150px;
    margin-right: 20px; }
  .cart-page .cart-item .product-cost {
    width: auto;
    flex: 0 0 100px;
    max-width: 100px; }
  .cart-page .cart-item .calc-block {
    margin: 0 20px;
    flex: 0 0 100px; }
  .cart-page .cart-item .product-sum {
    width: auto;
    flex: 0 0 120px;
    max-width: 120px; }
  .cart-page .together-container {
    padding: 15px 10px 10px; }
    .cart-page .together-container .together-item {
      flex-wrap: wrap; }
      .cart-page .together-container .together-item .text-block {
        order: 3;
        flex: 0 0 100%; }
      .cart-page .together-container .together-item .product-cost .old-cost span {
        font-size: 14px; }
    .cart-page .together-container .cost-text,
    .cart-page .together-container .calc-text {
      font-size: 13px; }
    .cart-page .together-container .calc-block {
      width: 90px; }
      .cart-page .together-container .calc-block .amount-control {
        width: 40px; } }

@media (max-width: 767px) {
  .cart-page .page-content {
    padding-bottom: 20px; }
    .cart-page .page-content h1, .cart-page .page-content .h1 {
      font-size: 24px; }
  .cart-page .cart-item .img-block {
    max-width: 80px;
    flex: 0 0 80px;
    height: 80px; }
  .cart-page .cart-item .calc-wrap {
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 0; }
  .cart-page .cart-item .product-cost {
    flex: 0 0 100%;
    max-width: 100%; }
  .cart-page .cart-item .calc-block {
    margin: 10px auto; }
  .cart-page .cart-item .product-sum {
    flex: 0 0 100%;
    max-width: 100%;
    font-size: 13px; }
    .cart-page .cart-item .product-sum span {
      font-size: 13px; }
  .cart-page .cart-item .default-cost,
  .cart-page .cart-item .old-cost,
  .cart-page .cart-item .new-cost {
    font-size: 13px; }
    .cart-page .cart-item .default-cost span,
    .cart-page .cart-item .old-cost span,
    .cart-page .cart-item .new-cost span {
      font-size: 13px; }
  .cart-page .together-container .together-item .product-cost .default-cost span {
    font-size: 16px; }
  .cart-page .together-container .together-item .product-cost .new-cost span {
    font-size: 16px; }
  .cart-page .together-container .plus-sign {
    width: 16px;
    flex: 0 0 16px; }
    .cart-page .together-container .plus-sign img {
      width: 100%; }
  .cart-page .together-container .calc-block .amount-control {
    background-color: #F4F7FA; }
  .cart-page .together-container .together-footer {
    background-color: #F4F7FA;
    padding: 3px; }
  .cart-page .together-container .together-title {
    font-size: 12px;
    top: -10px;
    left: 5px;
    padding: 0 5px; }
  .cart-page .together-container .together-calc,
  .cart-page .together-container .together-cost,
  .cart-page .together-container .together-sum {
    display: block; }
  .cart-page .together-container .cost-text,
  .cart-page .together-container .calc-text {
    margin-bottom: 8px; }
  .cart-page .together-container .calc-block {
    margin-left: 0; }
  .cart-page .together-container .calc-text {
    display: none; }
  .cart-page .together-container .together-calc {
    margin: 0 auto; }
  .cart-page .cart-footer {
    float: none;
    width: 100%; }
  .cart-page .empty-cart .h2 {
    font-size: 20px; } }

@media (max-width: 575px) {
  .cart-page .page-content {
    padding-bottom: 20px; }
  .cart-page .cart-container {
    margin-bottom: 0; }
  .cart-page .cart-item {
    flex-wrap: wrap; }
    .cart-page .cart-item .text-block {
      width: calc(100% - 90px);
      flex: auto;
      max-width: none;
      margin-right: 0; }
      .cart-page .cart-item .text-block .title {
        max-width: none; }
    .cart-page .cart-item .calc-wrap {
      width: calc(100% + 30px);
      flex-wrap: nowrap;
      margin-right: -30px; }
      .cart-page .cart-item .calc-wrap .product-cost {
        max-width: 80px;
        flex: auto; }
      .cart-page .cart-item .calc-wrap .product-sum {
        max-width: 85px;
        flex: auto; }
      .cart-page .cart-item .calc-wrap .calc-block {
        margin: 0 10px; }
    .cart-page .cart-item .close-btn {
      top: 10px;
      margin-top: 0; }
  .cart-page .together-container {
    padding: 15px 10px; }
    .cart-page .together-container .together-footer {
      justify-content: center; }
    .cart-page .together-container .together-item {
      width: auto;
      flex: 0 0 130px;
      max-width: 130px; }
      .cart-page .together-container .together-item .img-block {
        width: auto;
        flex: 0 0 80px;
        max-width: 80px;
        height: 80px; }
      .cart-page .together-container .together-item .text-block .title {
        font-size: 13px; }
      .cart-page .together-container .together-item .text-block .descr-text {
        font-size: 12px;
        margin-bottom: 10px; }
      .cart-page .together-container .together-item .product-cost {
        order: 3; }
        .cart-page .together-container .together-item .product-cost .default-cost {
          font-size: 14px; }
          .cart-page .together-container .together-item .product-cost .default-cost span {
            font-size: 14px; }
        .cart-page .together-container .together-item .product-cost .old-cost {
          font-size: 14px; }
        .cart-page .together-container .together-item .product-cost .new-cost {
          font-size: 14px;
          margin-bottom: 1px; }
          .cart-page .together-container .together-item .product-cost .new-cost span {
            font-size: 14px; }
    .cart-page .together-container .together-sum,
    .cart-page .together-container .together-cost {
      width: 85px; }
    .cart-page .together-container .cost-text {
      font-weight: 500; }
    .cart-page .together-container .total-num {
      font-size: 14px; }
    .cart-page .together-container .cost-num {
      font-size: 14px; }
  .cart-page .empty-cart {
    padding: 100px 0; }
    .cart-page .empty-cart p {
      font-size: 16px; } }

@media (max-width: 375px) {
  .cart-page .together-container .plus-sign {
    position: relative;
    left: -8px; } }
