@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Noto+Sans+JP:wght@100..900&display=swap");
.hero_area {
  position: relative;
  overflow: hidden;
  max-height: 100vh;
}
@media screen and (max-width: 767px) {
  .hero_area {
    max-height: none;
  }
}
.hero_area .swiper::before {
  display: block;
  content: "";
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
  height: 100%;
  background: rgba(53, 70, 92, 0.45);
  mix-blend-mode: multiply;
  z-index: 2;
}
.hero_area .swiper-wrapper {
  transition-timing-function: linear;
}
.hero_area .swiper-wrapper img {
  width: 100%;
}
.hero_area .hero_txt_wrap {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.hero_area .hero_txt_wrap .tit {
  width: 100%;
  max-width: 416px;
}
@media screen and (max-width: 767px) {
  .hero_area .hero_txt_wrap .tit {
    width: 55.46%;
  }
}

.sec_head {
  padding: 120px 0px;
}
@media screen and (max-width: 767px) {
  .sec_head {
    padding: 35px 0px 70px;
  }
}
.sec_head .flex01 {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 100px;
}
@media screen and (max-width: 1079px) {
  .sec_head .flex01 {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .sec_head .flex01 {
    margin-bottom: 40px;
  }
}
.sec_head .tit01 {
  font-size: 20px;
  line-height: 2;
  width: 34.72%;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1079px) {
  .sec_head .tit01 {
    text-align: center;
    width: 100%;
    margin-bottom: 25px;
  }
}
@media screen and (max-width: 767px) {
  .sec_head .tit01 {
    font-size: 15px;
  }
}
.sec_head .tit01 .jp {
  font-weight: 500;
  display: block;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .sec_head .tit01 .jp {
    margin-bottom: 10px;
  }
}
.sec_head .tit01 .logo {
  display: block;
  width: 100%;
}
@media screen and (max-width: 1079px) {
  .sec_head .tit01 .logo {
    margin: 0px auto;
    width: 73.01%;
    max-width: 375px;
  }
}
.sec_head .tit01 .logo img {
  width: 100%;
}
.sec_head .txtBox {
  width: 56.94%;
}
@media screen and (max-width: 1079px) {
  .sec_head .txtBox {
    width: 100%;
    text-align: center;
  }
}
.sec_head .txtBox p {
  font-size: 18px;
  line-height: 2.22;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_head .txtBox p {
    font-weight: 400;
    font-size: 14px;
  }
}
.sec_head .swiper .swiper-slide {
  width: 330px;
}
.sec_head .swiper .swiper-slide.tate {
  width: 240px;
}
.sec_head .swiper-wrapper {
  transition-timing-function: linear;
  align-items: center;
}

.sec_performance {
  background-color: #E6EFF2;
  padding: 120px 0px;
  margin-bottom: 150px;
}
@media screen and (max-width: 1079px) {
  .sec_performance {
    padding: 100px 20px;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 767px) {
  .sec_performance {
    padding: 60px 20px;
    margin-bottom: 60px;
  }
}
.sec_performance .sec_performance_in {
  width: 100%;
  max-width: 1180px;
  margin: 0px auto;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in {
    width: 100%;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex {
    margin-bottom: 15px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside {
  width: 23.72%;
  background-color: #fff;
  border-radius: 10px;
  padding: 25px 20px 80px;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside {
    width: 48.55%;
    border-radius: 5px;
    padding: 25px 20px 60px;
    margin-bottom: 10px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .img01 {
  width: 160px;
  margin: 0px auto;
  margin-bottom: 20px;
}
@media screen and (max-width: 1079px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .img01 {
    width: 59.7%;
    margin-bottom: 15px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .tit01 {
  text-align: center;
  margin-bottom: 10px;
}
.sec_performance .sec_performance_in .sec_performance_flex aside .tit01 span {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-size: 26px;
  background: linear-gradient(transparent 70%, #ff0 0%);
  display: inline-block;
  line-height: 1;
  padding: 0 1px 0px;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .tit01 span {
    font-size: 18px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .tit02 {
  font-size: 16px;
  font-weight: bold;
  font-weight: 700;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .tit02 {
    font-size: 12px;
    margin-bottom: 15px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .txt01 {
  font-size: 15px;
  line-height: 1.73;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .txt01 {
    font-size: 12px;
    line-height: 1.5;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .txt01 strong {
  text-align: center;
  display: block;
  margin-bottom: 15px;
  letter-spacing: -0.05em;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .txt01 strong {
    margin-bottom: 10px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .btn01 {
  display: block;
  text-align: center;
  font-size: 16px;
  color: #7FABBC;
  position: absolute;
  left: 0px;
  bottom: 30px;
  width: 100%;
  letter-spacing: 1px;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .btn01 {
    font-size: 12px;
    bottom: 20px;
  }
}
.sec_performance .sec_performance_in .sec_performance_flex aside .btn01::after {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  background: url(/ichi-yume/img/index/icon_cur.webp) 0px 0px/cover no-repeat;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .sec_performance_flex aside .btn01::after {
    width: 15px;
    height: 15px;
  }
}
.sec_performance .sec_performance_in .txt02 {
  text-align: center;
}
.sec_performance .sec_performance_in .txt02 span {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-size: 30px;
  color: #7FABBC;
  background: linear-gradient(transparent 70%, #ff0 0%);
  display: inline;
  line-height: 1.4;
  padding: 0 1px 0px;
  letter-spacing: 2px;
}
@media screen and (max-width: 767px) {
  .sec_performance .sec_performance_in .txt02 span {
    font-size: 18px;
  }
}

.sec_dream {
  margin-bottom: 150px;
}
@media screen and (max-width: 767px) {
  .sec_dream {
    margin-bottom: 75px;
  }
}
.sec_dream .swiper {
  box-sizing: border-box;
  padding: 0px max((100vw - 1080px) / 2, 30px);
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper {
    margin-bottom: 30px;
  }
}
.sec_dream .swiper-pagination {
  position: static;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  margin-bottom: 35px;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination {
    display: block;
    border-top: solid 1px #7FABBC;
    margin-bottom: 40px;
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet {
  width: 100%;
  margin: 0;
  height: auto;
  background: none;
  border-radius: 0px;
  font-size: 18px;
  line-height: 1.44;
  letter-spacing: 0.1em;
  opacity: 1;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  row-gap: 0px;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet {
    display: flex;
    flex-wrap: wrap;
    border-bottom: solid 1px #7FABBC;
    padding: 5px;
    box-sizing: border-box;
    justify-content: space-between;
    align-items: center;
    font-size: min(3.73vw, 14px);
    position: relative;
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet b {
  display: block;
  font-size: 1.11em;
  border: solid 1px #7FABBC;
  border-radius: 20px;
  line-height: 40px;
  text-align: center;
  color: #7FABBC;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet b {
    width: 90px;
    background: none;
    border: none;
    font-size: 15px;
    text-align: left;
    line-height: 1;
    margin-bottom: 0px;
    border-radius: 0px;
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet::after {
  white-space: pre;
  font-weight: 500;
  align-self: center;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet::after {
    width: calc(100% - 90px);
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet::before {
    display: block;
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    border: solid 1px #7FABBC;
    border-bottom: none;
    border-left: none;
    top: 50%;
    right: 10px;
    transform: translateY(-50%) rotate(45deg) skew(-10deg, -10deg);
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #7FABBC;
    color: #fff;
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active b {
  color: #fff;
  background: #7FABBC;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active b {
    background: none;
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
    border-color: #fff;
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(1)::after {
  content: "開放感溢れる\aテラス";
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(1)::after {
    content: "開放感溢れるテラス";
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(2)::after {
  content: "猫と過ごす\aリビング";
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(2)::after {
    content: "猫と過ごすリビング";
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(3)::after {
  content: "カフェのような\aキッチン";
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(3)::after {
    content: "カフェのようなキッチン";
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(4)::after {
  content: "想像力が広がる\aアトリエ";
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(4)::after {
    content: "想像力が広がるアトリエ";
  }
}
.sec_dream .swiper-pagination .swiper-pagination-bullet:nth-child(5)::after {
  content: "ゲーム部屋";
}
.sec_dream .swiper-slide {
  box-sizing: border-box;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(127, 171, 188, 0.14);
}
@media screen and (max-width: 1079px) {
  .sec_dream .swiper-slide {
    display: block;
    height: auto;
  }
}
.sec_dream .swiper-slide a {
  display: flex;
  flex-wrap: wrap;
}
.sec_dream .swiper-slide .imgBox {
  width: 69.44%;
}
@media screen and (max-width: 1079px) {
  .sec_dream .swiper-slide .imgBox {
    width: 100%;
  }
}
.sec_dream .swiper-slide .imgBox img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%;
  width: 100%;
}
.sec_dream .swiper-slide .txtBox {
  width: 30.55%;
  box-sizing: border-box;
  padding: 35px 40px;
}
@media screen and (max-width: 1079px) {
  .sec_dream .swiper-slide .txtBox {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-slide .txtBox {
    padding: 15px 20px;
  }
}
.sec_dream .swiper-slide .txtBox .tit01 {
  font-size: 22px;
  line-height: 1.36;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: 65px;
}
@media screen and (max-width: 1079px) {
  .sec_dream .swiper-slide .txtBox .tit01 {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-slide .txtBox .tit01 {
    font-size: 15px;
  }
}
.sec_dream .swiper-slide .txtBox .tit01 .sub {
  display: block;
  font-size: 18px;
  border-bottom: solid 1px #707070;
  padding-bottom: 5px;
  margin-bottom: 10px;
}
@media screen and (max-width: 1079px) {
  .sec_dream .swiper-slide .txtBox .tit01 .sub {
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-slide .txtBox .tit01 .sub {
    font-size: 13px;
    margin-bottom: 5px;
  }
}
.sec_dream .swiper-slide .txtBox .txt01 {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-slide .txtBox .txt01 {
    font-size: 21px;
  }
}
.sec_dream .swiper-button-prev, .sec_dream .swiper-button-next {
  width: 26px;
  height: 40px;
  top: auto;
  bottom: 205px;
  margin: 0;
}
.sec_dream .swiper-button-prev::after, .sec_dream .swiper-button-next::after {
  display: none;
}
.sec_dream .swiper-button-prev {
  background: url(/ichi-yume/img/index/slide_arrow_prev.svg) center center/contain no-repeat;
  left: auto;
  right: calc((100vw - 1080px) / 2 + 1080px + 50px);
}
@media screen and (max-width: 1279px) {
  .sec_dream .swiper-button-prev {
    display: none;
  }
}
.sec_dream .swiper-button-next {
  background: url(/ichi-yume/img/index/slide_arrow_next.svg) center center/contain no-repeat;
  right: auto;
  left: calc((100vw - 1080px) / 2 + 1080px + 50px);
}
@media screen and (max-width: 1279px) {
  .sec_dream .swiper-button-next {
    display: none;
  }
}
.sec_dream .swiper-scrollbar {
  display: none;
}
@media screen and (max-width: 1279px) {
  .sec_dream .swiper-scrollbar {
    display: block;
    position: static;
    width: 100%;
    margin-top: 40px;
    background: rgba(127, 171, 188, 0.15);
  }
}
@media screen and (max-width: 767px) {
  .sec_dream .swiper-scrollbar {
    margin-top: 20px;
  }
}
.sec_dream .swiper-scrollbar .swiper-scrollbar-drag {
  background: rgba(127, 171, 188, 0.69);
}
.sec_dream .btn_wrap {
  width: calc(100% - 60px);
  max-width: 1080px;
  margin: 0px auto;
}

.sec_order {
  background: #F5F5F5;
  padding: 150px 0px;
}
@media screen and (max-width: 767px) {
  .sec_order {
    padding: 70px 0px;
  }
}
.sec_order .tit01 {
  text-align: center;
  font-size: 32px;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 10px 0px;
  border-top: solid 1px #000;
  border-bottom: solid 1px #000;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .sec_order .tit01 {
    font-size: 21px;
    margin-bottom: 25px;
  }
}
.sec_order .txt01 {
  text-align: center;
  font-size: 28px;
  line-height: 1.71;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .sec_order .txt01 {
    font-size: 18px;
    margin-bottom: 25px;
  }
}
.sec_order .img01 {
  margin-bottom: 15px;
}
.sec_order .img01 img {
  width: 100%;
}
.sec_order .price_wrap {
  text-align: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap {
    margin-bottom: 35px;
  }
}
.sec_order .price_wrap .price {
  display: inline-block;
  background: linear-gradient(to top, #FFFF00 0%, #FFFF00 12px, rgba(255, 255, 0, 0) 13px, rgba(255, 255, 0, 0) 100%);
  font-size: 28px;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .price {
    background: linear-gradient(to top, #FFFF00 0%, #FFFF00 6px, rgba(255, 255, 0, 0) 7px, rgba(255, 255, 0, 0) 100%);
    font-size: min(5.1vw, 20px);
    margin-bottom: 15px;
  }
}
.sec_order .price_wrap .price .tubo_n {
  font-size: 60px;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .price .tubo_n {
    font-size: 1.5em;
  }
}
.sec_order .price_wrap .price .tubo_t {
  font-size: 34px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .price .tubo_t {
    font-size: 1em;
  }
}
.sec_order .price_wrap .price .price_n {
  font-size: 100px;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .price .price_n {
    font-size: 2.5em;
  }
}
.sec_order .price_wrap .price small {
  display: inline;
  font-size: 20px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .price small {
    font-size: 0.7em;
  }
}
.sec_order .price_wrap .caption {
  display: inline-block;
  text-align: left;
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .sec_order .price_wrap .caption {
    font-size: 10px;
    letter-spacing: 0em;
  }
}
.sec_order .tit02 {
  text-align: center;
  letter-spacing: 0.1em;
  font-size: 34px;
  font-weight: 700;
  margin-bottom: 30px;
  line-height: 1.45;
}
@media screen and (max-width: 767px) {
  .sec_order .tit02 {
    font-size: 20px;
    margin-bottom: 15px;
  }
}
.sec_order .txt02 {
  text-align: center;
  font-size: 18px;
  line-height: 2.11;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-bottom: 45px;
}
@media screen and (max-width: 767px) {
  .sec_order .txt02 {
    font-size: 13px;
    margin-bottom: 40px;
  }
}
.sec_order .plan_list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 25px;
  margin-bottom: 80px;
}
@media screen and (max-width: 1079px) {
  .sec_order .plan_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
}
@media screen and (max-width: 767px) {
  .sec_order .plan_list {
    margin-bottom: 30px;
  }
}
.sec_order .plan_list li {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  row-gap: 0px;
  border-radius: 10px;
  overflow: hidden;
}
.sec_order .plan_list li .img {
  grid-column-start: 1;
  grid-row-start: 1;
  grid-row-end: 3;
}
.sec_order .plan_list li .txt {
  grid-column-start: 1;
  grid-row-start: 2;
  grid-row-end: 3;
  color: #fff;
  z-index: 1;
  box-sizing: border-box;
  padding: 10px 20px;
  font-size: 16px;
  letter-spacing: 0.03em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec_order .plan_list li .txt {
    padding: 10px;
    font-size: 10px;
  }
}
.sec_order .plan_list li .txt .eng {
  display: block;
  font-family: "Avenir Next", "Lato", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 24px;
  letter-spacing: 0.03em;
  font-weight: 600;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .sec_order .plan_list li .txt .eng {
    font-size: 15px;
  }
}
.sec_order .plan_list li::after {
  display: block;
  content: "";
  background: rgba(53, 70, 92, 0.6);
  mix-blend-mode: multiply;
  z-index: 0;
  grid-column-start: 1;
  grid-row-start: 2;
  grid-row-end: 3;
}

.sec_quality {
  position: relative;
}
.sec_quality .bg_wrap {
  position: absolute;
  z-index: -1;
  display: flex;
  flex-wrap: wrap;
  top: 0px;
  left: 0px;
  height: 100%;
  width: 100%;
}
.sec_quality .bg_wrap::after {
  display: block;
  content: "";
  background: rgba(53, 70, 92, 0.65);
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  mix-blend-mode: multiply;
}
.sec_quality .bg_wrap figure {
  width: 50%;
  height: 50%;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure {
    height: 34%;
  }
}
.sec_quality .bg_wrap figure img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure.img01 {
    width: 100%;
  }
}
.sec_quality .bg_wrap figure.img02 {
  position: relative;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure.img02 {
    width: 100%;
  }
}
.sec_quality .bg_wrap figure.img02 .logo {
  position: absolute;
  width: 10.69%;
  top: 10px;
  left: 10px;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure.img03 {
    height: 32%;
  }
}
.sec_quality .bg_wrap figure.img03 img {
  -o-object-position: left center;
  object-position: left center;
}
.sec_quality .bg_wrap figure.img04 {
  width: 25%;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure.img04 {
    height: 32%;
    width: 50%;
  }
}
.sec_quality .bg_wrap figure.img05 {
  width: 25%;
}
@media screen and (max-width: 1079px) {
  .sec_quality .bg_wrap figure.img05 {
    display: none;
  }
}
.sec_quality .quality_contents {
  color: #fff;
  padding: 180px 0px;
}
@media screen and (max-width: 767px) {
  .sec_quality .quality_contents {
    padding: 90px 0px;
  }
}
.sec_quality .quality_contents .txt01 {
  font-size: 34px;
  line-height: 1.47;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .sec_quality .quality_contents .txt01 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}

.sec_feature {
  padding: 100px 0px;
  background: rgba(127, 171, 188, 0.8);
  color: #fff;
}
@media screen and (max-width: 767px) {
  .sec_feature {
    padding: 75px 0px;
  }
}
.sec_feature .swiper {
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .sec_feature .swiper {
    margin-left: -30px;
    margin-right: -30px;
    margin-bottom: 40px;
  }
}
.sec_feature .swiper-slide {
  border-radius: 20px;
  overflow: hidden;
}
.sec_feature .swiper-wrapper {
  transition-timing-function: linear;
}