/********************************************/
/*************** main__visual ***************/
/********************************************/

.main__visual {
  width: 1900px;
  padding: 0 0px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 2rem;
  margin-bottom: 50px;
}

.main__visual_left img,
.main__visual_right img {
  width: 100%;
}

@media screen and (max-width: 1700px) {
  .main__visual {
    width: 100%;
  }
}

@media screen and (max-width: 1024px) {
  .main__visual {
    padding: 0;
  }
}

@media screen and (max-width: 768px) {
  .main__visual {
    flex-direction: column;
    gap: 0;
    margin-bottom: 0px;
  }

  .main__visual_right {
    width: 100%;
    height: 250px;
    overflow: hidden;
  }

  .main__visual_right img {
    width: 102%;
    height: 102%;
    object-fit: cover;
    object-position: bottom;
    /* ✅ 아래쪽 보이게 */
  }
}

/********************************************/
/**************** main__intro ***************/
/********************************************/

.main__intro {
  padding: 50px 0;
  background-color: #f4efe9;
}

.main__intro_layout {
  width: 1820px;
  padding-left: 160px;
  margin: 0 auto;
}

.main__intro .main__intro_layout {
  display: flex;
  justify-content: space-between;
}

.main__intro_text {
  width: 35%;
}

.main__intro_slide {
  width: 65%;
}

.main__intro_slide .swiper {
  position: relative;
}

.main__intro_slide .swiper img {
  width: 100%;
}

@media screen and (max-width: 1820px) {
  .main__intro_layout {
    width: 100%;
    padding-right: 50px;
  }
}

@media screen and (max-width: 1700px) {
  .main__intro_layout {
    width: 100%;
    padding: 0 50px;
  }
}

@media screen and (max-width: 1024px) {
  .main__intro .main__intro_layout {
    flex-direction: column;
  }

  .main__intro_text {
    width: 100%;
  }

  .main__intro_slide {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .main__intro_layout {
    padding: 0 24px;
  }
}

/********************************************/
/**************** main__shop ****************/
/********************************************/

.main__shop {
  padding: 50px 0;
  overflow: hidden;
}

.main__shop_layout {
  width: 1920px;
  padding-left: 210px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}

.main__shop_text {
  width: 25%;
}

.main__shop_slide {
  width: 75%;
}

.main__shop_slide .swiper {
  padding-bottom: 50px !important;
}

.main__shop_slide .swiper .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #aeaead;
  opacity: 1;
  border-radius: 50%;
  display: inline-block;
  margin: 0 8px !important;
  transition: background 0.3s ease;
}

.main__shop_slide .swiper .swiper-pagination-bullet-active {
  background: #333;
}

@media screen and (max-width: 1820px) {
  .main__shop_layout {
    width: 100%;
    padding-left: 160px;
  }
}

@media screen and (max-width: 1700px) {
  .main__shop_layout {
    padding-left: 50px;
  }
}

@media screen and (max-width: 1024px) {
  .main__shop_layout {
    flex-direction: column;
    padding: 0 50px;
  }

  .main__shop_text {
    width: 100%;
  }

  .main__shop_slide {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .main__shop_layout {
    padding: 0 24px;
  }
}

/********************************************/
/*************** main__about ****************/
/********************************************/

.main__about {
  padding: 110px 0;
  margin-bottom: 50px;
}

.main__about_layout {
  width: 1820px;
  padding-left: 160px;
  margin: 0 auto;
}

.main__about .main__about_layout {
  display: flex;
  justify-content: space-between;
}

.main__about_text {
  width: 45%;
  display: flex;
  flex-direction: column;
  margin-top: 29px;
}

.main__about_miniimg {
  margin-top: auto;
}

.main__about_miniimg img {
  width: 49%;
}

.main__about_slide {
  width: 55%;
}

.main__about_img img {
  width: 100%;
  border-radius: 300px 0 0 0;
}

@media screen and (max-width: 1820px) {
  .main__about_layout {
    width: 100%;
    padding-right: 50px;
  }
}

@media screen and (max-width: 1700px) {
  .main__about_layout {
    width: 100%;
    padding: 0 50px;
  }
}

@media screen and (max-width: 1024px) {
  .main__about .main__about_layout {
    flex-direction: column;
    gap: 1rem;
  }

  .main__about_text {
    width: 100%;
  }

  .main__about_miniimg {
    display: flex;
    justify-content: space-between;
  }

  .main__about_miniimg img {
    width: 50%;
  }

  .main__about_slide {
    width: 100%;
  }

  .main__about_img img {
    border-radius: 0 0 0 0;
  }
}

@media screen and (max-width: 768px) {
  .main__about_layout {
    padding: 0 24px;
  }
}