@media screen and (max-width: 1590px) {
  .main__aside-container {
    right: 40px;
  }

  .products-section .on-slider-card.-position-1 {
    left: 10px;
  }
  
  .products-section .on-slider-card.-position-2 {
    left: 378px;
  }
  
  .products-section .on-slider-card.-position-3 {
    left: 746px;
  }
}

@media screen and (max-width: 1540px) {
  :root {
    --button-width: (100vw - 1440px) / 2;
  }

  /*navigation button*/

  .reviews__navigation div {
    width: 200px;
  }

  .products-section__navigation div {
    width: 200px;
  }

  .reviews__navigation div.next {    
    width: 200px;
  }
}

@media screen and (max-width: 1440px) {

  /* 404 */

  .error-block .error {
    /*height: 210px;*/
    /*height: 14.583vw;*/
  }

  /* single | main-single */

  .main-single__info .text br {
    display: none;
  }

  /* single | single-product-section */

  .single-product-section__wrapper .brand-card .title-2 {
    font-size: 39px;
    line-height: 100%;
  }


}

@media screen and (max-width: 1260px) {

  /*navigation button*/

  .reviews__navigation div {
    width: 150px;
  }

  .products-section__navigation div {
    width: 150px;
  }

  .reviews__navigation div.next {
    width: 150px;
  }

	/* index | .main */

  .main {
    height: auto;
  }

  .main .container {
    position: relative;
    flex-wrap: wrap;
    align-items: flex-start;
    padding-top: 118px;
    padding-bottom: 0;
  }

  .main__slider {
    position: relative;
    left: 0;
    max-width: none;
    transform: none;
    height: auto;
  }

  .main__slider .swiper-wrapper {
    align-items: stretch;
    height: auto;
  }

  .main__slider .swiper-slide img, 
  .main__slider .swiper-slide picture,
  .main__slider .swiper-slide picture>img {
    height: auto;
    position: relative;
  }

  .main__slider .swiper-slide img {
    height: 600px;
  }

  .main__slider .swiper-slide {
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    padding-bottom: 0;
    height: auto;
  }

  .main__aside-container-text {
    position: relative;
    margin: 0 0 auto 0;
    padding-top: 0;
    padding-bottom: 40px;
  }

  .main__aside-container {
    right: 0;
    padding-right: 0;
  }

  .main .swiper-pagination {
    right: 40px;
  }

  .main .anchor-link {
    position: absolute;
    right: 40px;
    bottom: 80px;
  }

  .main__aside-container {
    padding: 0;
  }

  .main__text-container {
    margin: 0 0 auto 0;
  }

  /* index | about-us */

  .about-us .description-1,
  .about-us .description-1 *:not(a) {
    line-height: 150%;
  }

  .about-us .description-1 a * {
    line-height: 100%;
  }

  .about-us {
    margin: 80px 0;
    overflow: hidden;
  }

  .about-us .description-1 a {
    margin: 4px 10px;
  }

  .about-us .text {
    max-width: 100%;
  }

  .about-us a.-dot-before:before {
    left: -9px;
    width: 4px;
    height: 4px;
  }

    /* index | products-section */

    .products-section .on-slider-card {
      display: none;
    }

    .products-section__slider .brand-card {
      display: none !important;
    }
  
    .products-section__slider {
      width: auto;
      margin: 0 -40px;
      padding: 0 40px;
    }
  
    .products-section__navigation {
      display: none;
    }
  
    .products-section {
      padding: 0 0 80px 0;
    }
  
    .products-section .before-slider-card {
      display: flex;
      margin-bottom: 30px;
    }
  
    .products-section .container > .button {
      display: flex;
      width: 100%;
      margin-top: 30px;
      height: 52px;
    }

  /* reviews */

  .reviews__navigation.--pc-display {
    display: block;
  }

  .reviews__navigation.--mob-display {
    display: none;
  }

  .reviews {
    margin: 80px 0;
  }

  .reviews__slider {
    margin-top: 40px;
  }

  .reviews .title sup {
    top: 13px;
    right: -15px;
  }

  /* index | seminar-section */

  .seminar-section .container > .title {
    line-height: 100%;
  }

  .seminar-section__photo-list {
    justify-content: space-between;
  }

  .seminar-section__row {
    display: block;
  }

  .seminar-section__col-left {
    max-width: 100%;
    width: 100%;
  }

  .seminar-section__col-right {
    margin: 80px 0 0 0;
  }


  .seminar-section__mask-container {
    width: 47.25vw;
    margin-left: 6.316%;
    min-height: 37.25vw;
    position: absolute;
    right: 0;
  }

  /* 404 */

  /*.error-block .error {*/
  /*  height: 175px;*/
  /*}*/

  .error-block .text {
    margin-top: 10px;
  }

  .error-block .button {
    margin-top: 30px;
  }


  /* single | main-single */

  .main.main-single {
    padding-top: 78px;
  }

  .main-single__slider-container {
    height: auto;
  }

  .main.main-single .container {
    padding-left: 30px;
  }

  .main-single__info {
    padding: 30px 0;
  }

  .main-single__info.brand-card .title {
    margin-bottom: 30px;
  }

  .main-single__info .description {
    margin: 10px 0;
  }

  .main-single__info .text {
    margin-top: 10px;
  }

  .main-single__info .button-container {
    flex-wrap: wrap;
  }

  .main-single__info .button-container .button {
    width: 100%;
    height: 52px;
  }

  .main-single__info .button-container .button:first-child {
    margin-right: 0;
    margin-bottom: 10px;
  }

  .main-single__info.brand-card .title:after {
    right: -8px;
    width: 6px;
    height: 6px;
  }

  /* single | single-product-section */

  .brand-card .brand-card__bottom .expert-icon {
    min-width: 50px;
    width: 50px;
    height: 50px;
    margin-right: 10px;
  }

  .single-product-section .title sup {
    right: -16px;
    top: 6px;
  }

  .single-product-section__wrapper {
    grid-template-columns: repeat(3, 1fr);
    column-gap: 10px;
    row-gap: 30px;
  }

  .single-product-section__wrapper .brand-card .mob-description-1 {
    font-size: 24px;
    line-height: 120%;
  }

  .expert-text .description-2 {
    line-height: 150%;
  }

  .review__link {
    overflow: visible;
    max-width: none;
  }


}

@media screen and (max-width: 1024px) {

  /* index | .main__slider */

  .main__slider {
    height: auto;
  }

  .main__slider .swiper-wrapper {
    height: auto;
  }

  .main__slider .swiper-slide {
    height: auto;
  }

  .main__slider .swiper-slide img, 
  .main__slider .swiper-slide picture {
    height: auto;
  }

  /* reviews */

  .reviews__navigation.--pc-display {
    display: none;
  }

  .reviews__navigation.--mob-display {
    display: flex;
  }

  .reviews__navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .reviews__navigation div {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;

    width: 40px;
    height: 40px;

    border: 1px solid var(--dark);
    border-radius: 50%;
    transition: opacity 0.3s;
  }

  .reviews__navigation div.prev {
    cursor: pointer;
    width: 40px;
    height: 40px;
    margin-right: 6px;
    background: no-repeat center url(../images/icons/prev-circle.svg);
    background-size: 18px;
  }

  .reviews__navigation div.next {
    cursor: pointer;
    background: no-repeat center url(../images/icons/next-circle.svg);
    background-size: 18px;
    width: 40px;
  }

  .reviews__navigation div.swiper-button-disabled {
    opacity: 0.5;
    pointer-events: none;
  }

  .reviews__top-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }

  /* index | seminar-section */


  .seminar-section {
    padding: 80px 0;
  }

  .seminar-section__photo-list {
    flex-direction: column;
    margin-top: 0;
  }

  .seminar-section__photo-list .list {
    margin-top: 40px;
    max-width: none;
  }

  .seminar-section__mask-container {
    max-width: none;
    margin: 0 auto;
  }

  .seminar-section__mask-img {
    left: 0;
  }

  .svg-text {
    left: 5vw;
  }

  .seminar-section__col-left .spa-sticker {
    left: 10.5%;
    bottom: 43%;
    width: 88px;
    height: 88px;
  }

  .seminar-section__col-left .spa-sticker .circle-label-svg {
    left: 2px;
    top: 2px;
    width: calc(100% - 4px);
    height: calc(100% - 4px);
}

  .seminar-section__col-right {
    margin-top: 68px;
  }

  .seminar-section__col-right .text {
    margin-top: 10px;
  }

  .circle-label-svg * {
    font-size: 14px;
  }

  .seminar-section__col-right .button {
    height: 52px;
    width: 100%;
    margin: 30px 0 0 0;
  }

  /* 404 */

  body.-error-page {
    display: flex;
    align-items: stretch;
    flex-direction: column;
    min-height: 100vh;
  }

  body.-error-page main,
  body.-error-page main .error-section,
  body.-error-page main .error-section .container {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
  }

  body.-error-page main .error-section .container {
    width: 100%;
  }

  body.-error-page main .error-section .error-block {
    flex-grow: 1;
  }

  .error-block {
    min-height: auto;
    padding-top: 138px;
    padding-bottom: 80px;
  }

  .error-block .error {
    /*height: 115px;*/
    margin-left: 60px;
  }


  /* single | main-single */

  .main.main-single {
    display: block;
  }

  .main-single__slider-container {
    width: 100%;
  }

  .main-single__slider {
    width: 70%;
    height: 100%;
    margin: 0 auto;
  }

  .main-single__slider-container .swiper-wrapper {
    align-items: stretch;
  }

  .main-single__slider-container .swiper-slide picture,
  .main-single__slider-container .swiper-slide img {
    max-width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: bottom;
  }

  .main.main-single .container {
    width: 100%;
  }

  .main-single__info {
    padding: 20px 0 0 0;
    min-height: auto;
  }

  .main-single__info.brand-card .title {
    margin: 10px 0 30px 0
  }

  .main-single__info .description {
    margin: 30px 0 10px 0;
  }


  .main-single__info .button-container {
    margin-top: 30px;
  }

  .main-single__info .button-container .button {
    display: flex;
    width: fit-content;
  }

  .main-single__info .button-container .button:first-child {
    margin-right: 10px;
    margin-bottom: 0;
  }

  /* single | single-product-section */

  .single-product-section__wrapper {
    margin-top: 40px;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 10px;
    row-gap: 30px;
  }

  .single-product-section__wrapper .brand-card {
    grid-column: span 4;
    height: auto;
    min-height: auto;
    max-width: none;
    padding: 10px 0;
  }

  .single-product-section__wrapper .brand-card .text {
    color: var(--dark-grey);
    margin-top: 10px;
  }

  .single-product-section__wrapper .brand-card .button {
    display: flex;
    margin-top: 30px;
    height: 52px;
  }

  .single-product-section__wrapper .product-card {
    width: 100%;
  }

  .single-product-section__wrapper .product-card:nth-child(5) {
    order: 4;
  }

  .single-product-section__wrapper .product-card {
    min-height: auto;
    max-width: none;
  }

  .single-product-section__wrapper .brand-card .hide-on-pc {
    display: block;
  }

  .single-product-section__wrapper .brand-card .hide-on-mobile {
    display: none;
  }

  .single-product-section .container > .button {
    height: 52px;
    margin-top: 30px;
  }

  .single-product-section {
    margin: 80px 0;
  }

  .hover-reveal {
    display: none;
  }

}

@media screen and (max-width: 760px) {

  /*navigation button*/

  .reviews__navigation div {
    width: 40px;
  }

  .products-section__navigation div {
    width: 40px;
  }

  .reviews__navigation div.next {
    width: 40px;
  }

  /* index | .main */

  .main__text-container {
    max-width: 100%;
    padding: 0 20px;
    margin: 0;
  }

  .main__slider .swiper-slide {
    align-items: flex-start;
    flex-direction: column;
    justify-content: space-between;
  }

  .main__aside-container-text {
    padding: 0 20px;
    margin: 40px 0 auto 0;
  }

  .main .container {
    padding-top: 118px;
  }

  .main__aside-container {
    padding: 0;
    max-width: none;
  }

  .main__slider {
    width: calc(100% + 40px);
    margin-left: -20px;
    height: auto;
  }

  .main__slider .swiper-slide img {
    margin-top: 35px;
  }

  .main .swiper-pagination {
    right: 20px;
  }

  .main .anchor-link {
    right: 20px;
  }

  /* index | products-section */

  .products-section__slider {
    margin: 0 -20px;
    padding: 0 20px;
  }

  /* index | seminar-section */

  .seminar-section {
    overflow: hidden;
  }

  .seminar-section__mask-container {
    position: relative;
    width: calc(100% + 40px);
    margin: 0 -20px;
    min-height: auto;
    height: 100.8vw;
  }

  .seminar-section__col-left .spa-sticker {
    left: 2.7%;
    bottom: 65%;
  }

  .seminar-section__mask-img {
    position: relative;
    width: 126vw;
    height: 126vw;
    clip-path: ellipse(25.3% 47.1% at 50% 50%);
    top: -20vw;
    left: -13vw;
  }

  .svg-text.svg-text-mobile {
    display: block;
    font-size: 13px;
  }

  .svg-text:not(.svg-text-mobile) {
    display: none;
  }

  .seminar-section__photo-list .list {
    margin-top: 43px;
  }

  .svg-text {
    top: -7.72vw;
    left: -1.1333vw;
    transform: none;
    width: 102.9vw;
  }

  .svg-text * {
    letter-spacing: 0.15px;
  }

  .seminar-section__col-left .default-list li:before {
    top: 6px;
  }

  .seminar-section__col-right {
    margin-top: 30px;
    min-width: 100%;
  }


  /* single | main-single */

  .main.main-single .slider-label {
    right: 16px;
    top: 16px;
    width: 60px;
    height: 60px;
  }

  .slider-label .center-img {
    width: 17px;
    height: 17px;
  }

  .main.main-single .container {
    padding-left: 20px;
  }

  .main-single__slider {
    width: 100%;
  }

  .main.main-single .swiper-pagination {
    right: 20px;
  }

  .main-single__slider-container {
    height: 335px;
  }

  .main-single__info .button-container .button:first-child {
    margin: 0 0 10px 0;
  }

  .main-single__info .button-container .button {
    width: 100%;
  }

  /* single | single-product-section */

  .single-product-section__wrapper {
    grid-template-columns : repeat(2, 1fr);
  }

  .single-product-section__wrapper .brand-card {
    grid-column: span 2;
  }

  .single-product-section__wrapper .product-card {
    max-width: none;
    width: 100%;
  }

  /*404 */

  .error-block {
    flex-direction: column-reverse;
  }

  .error-block .error {
    height: 115px;
    margin-left: 0;
    margin-bottom: 60px;
  }

  .error-block .error .error-circle {
    width: 90%;
  }

  .error-block .title-box {
    max-width: none;
  }

  .error-block .button {
    width: 100%;
  }

}

@media screen and (max-height: 700px) {
  .error-block {
    padding-top: 120px;
  }

  .error-block .error {
  max-height: 41vh;
}

}