@charset "utf-8";
/* CSS Document */
.fv {
  position: relative;
  width: 100%;
  overflow: hidden;
  align-items: center;
  justify-content: flex-start;
}
/* 編集画面用 */
body.on .fv {
  height: 100vh;
  min-height: 720px;
}
body.gjs-dashed .fv {
  height: auto;
}
body.gjs-dashed .fv .swiper {
 position: static;
}

/* swiperをFVいっぱいに広げる */
.fv .swiper {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 1;
}
.fv .swiper-wrapper, .fv .swiper-slide {
  width: 100% !important;
  height: 100% !important;
}
.fv .swiper-img {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.fv .swiper-img img {
  display: block !important;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1 !important;
}
body.on .fv .swiper-img::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(113, 79, 56, .68) 0%, rgba(113, 79, 56, .50) 34%, rgba(113, 79, 56, .20) 62%, rgba(113, 79, 56, .26) 100%);
  z-index: 2;
  pointer-events: none;
}
/* テキスト */
.fv .txtbox {
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: clamp(100px, 12vw, 150px) clamp(20px, 8vw, 120px) 0;
  align-items: flex-start;
  gap: clamp(18px, 2vw, 26px);
}
.fv .txtbox .salon_name, .fv .txtbox h1, .fv .txtbox > p, .fv .txtbox .en_copy {
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .18);
}
.fv .txtbox h1 {
  line-height: 1.8;
  letter-spacing: .14em;
  font-weight: 400;
}
.fv .txtbox .en_copy {
  margin-top: 10px;
  font-size: clamp(13px, 1.1vw, 16px);
  line-height: 1.8;
  letter-spacing: .16em;
  font-weight: 400;
}
/* 草装飾 */
.fv .fv_deco {
  position: absolute;
  z-index: 5;
  pointer-events: none;
}
.fv .fv_deco img {
  display: block;
  width: 100%;
  height: auto;
}
.fv .deco_left {
  left: -50px;
  top: 50px;
  height: 100%;
  width: auto;
}
.fv .deco_right {
  right: -50px;
  top: 50px;
  height: 100%;
  width: auto;
}
/* ズームアニメーション */
@keyframes fvZoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.08);
  }
}
body:not(.on) .fv .swiper-slide-active .swiper-img img, body:not(.on) .fv .swiper-slide-duplicate-active .swiper-img img, body:not(.on) .fv .swiper-slide-prev .swiper-img img {
  animation: fvZoom 9s linear 0s normal both;
}
@media screen and (max-width: 768px) {
  .fv, body.on .fv {
    min-height: 660px;
  }
  .fv .txtbox {
    padding: 120px 50px 0;
  }
  .fv .deco_left, .fv .deco_right {
    width: 160px;
  }
}
@media screen and (max-width: 576px) {
  .fv, body.on .fv {
    min-height: 600px;
  }
  .fv .txtbox {
    padding: 100px 20px 0;
    gap: 16px;
  }
  .fv .txtbox h1 {
    line-height: 1.7;
  }

  .fv .deco_left, .fv .deco_right {
    width: 120px;
  }
}
.section01 {
  position: relative;
}
.section01 .concept_wrap {
  position: relative;
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(40px, 5vw, 80px);
  min-height: clamp(680px, 72vw, 900px);
}
.section01 .big_en {
  position: absolute;
  top: -40px;
  right: 0;
  color: rgba(113, 79, 56, .14);
  font-size: clamp(72px, 9vw, 140px);
  line-height: 1;
  letter-spacing: .12em;
  font-family: "Zen Old Mincho", "游明朝", "YuMincho", serif;
  font-weight: 400;
  z-index: 1;
}
/* left image */
.section01 .leftbox {
  position: relative;
  z-index: 3;
  width: 25%;
  display: flex;
  flex-direction: column;
  gap: clamp(60px, 8vw, 110px);
  padding-top: clamp(70px, 8vw, 120px);
}
.section01 .leftbox .imgbox1 {
  width: 82%;
  margin-left: -12%;
  aspect-ratio: 1 / .88;
}
.section01 .leftbox .imgbox2 {
  width: 90%;
  margin-left: auto;
  aspect-ratio: 1 / 1.25;
}
/* center text */
.section01 .txtbox {
  position: relative;
  z-index: 5;
  width: 31%;
  max-width: 430px;
}
.section01 .txtbox .sub_en {
  margin-bottom: clamp(28px, 4vw, 46px);
  color: #714F38;
  font-size: 13px;
  line-height: 1.7;
  letter-spacing: .18em;
  font-weight: 400;
}
.section01 .txtbox h2 {
  color: #714F38;
  line-height: 1.75;
  letter-spacing: .14em;
  font-weight: 400;
}
.section01 .txtbox h2 span {
  color: #98B900;
}
.section01 .txtbox .lead {
  margin-top: clamp(28px, 4vw, 44px);
  color: #714F38;
  line-height: 2;
  letter-spacing: .12em;
}
.section01 .txtbox p {
  color: #714F38;
}
/* right image */
.section01 .rightbox {
  position: relative;
  z-index: 3;
  width: 42%;
}
.section01 .main_img {
  width: 100%;
  aspect-ratio: .86 / 1;
  overflow: hidden;
  border-radius: 14px;
}
.section01 .imgbox3 {
  position: absolute;
  right: clamp(30px, 5vw, 80px);
  bottom: clamp(-80px, -6vw, -40px);
  width: clamp(160px, 16vw, 240px);
  aspect-ratio: 1 / 1.15;
  border-radius: 14px;
  z-index: 6;
}
/* common image */
.section01 .imgbox, .section01 .main_img {
  overflow: hidden;
  border-radius: 12px;
}
.section01 .imgbox img, .section01 .main_img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* decoration */
.section01 .concept_deco {
  position: absolute;
  z-index: 2;
  pointer-events: none;
}
.section01 .concept_deco img {
  display: block;
  width: 100%;
  height: auto;
}
.section01 .deco_left_top {
  top: 0;
  left: 0;
  width: clamp(180px, 22vw, 360px);
}
.section01 .deco_right_bottom {
  right: 0;
  bottom: 0;
  width: clamp(200px, 25vw, 420px);
}
/* ---------- section01 responsive ---------- */
@media screen and (max-width: 1280px) {
  .section01 .concept_wrap {
    gap: clamp(30px, 4vw, 50px);
  }
  .section01 .leftbox {
    width: 23%;
  }
  .section01 .txtbox {
    width: 32%;
  }
  .section01 .rightbox {
    width: 42%;
  }
  .section01 .big_en {
    right: 20px;
    font-size: clamp(64px, 8vw, 110px);
  }
}
@media screen and (max-width: 1080px) {
  .section01 .concept_wrap {
    display: grid;
    grid-template-columns: 1fr 1.05fr;
    align-items: center;
    gap: 50px;
    min-height: auto;
    padding: 0 60px;
  }
  .section01 .big_en {
    top: -50px;
    right: 40px;
    font-size: clamp(60px, 9vw, 100px);
  }
  .section01 .txtbox {
    width: 100%;
    max-width: none;
    grid-column: 1 / 2;
    grid-row: 1 / 2;
    padding-top: clamp(80px, 10vw, 120px);
  }
  .section01 .rightbox {
    width: 100%;
    grid-column: 2 / 3;
    grid-row: 1 / 2;
  }
  .section01 .main_img {
    aspect-ratio: .86 / 1;
  }
  .section01 .imgbox3 {
    right: 24px;
    bottom: -46px;
    width: clamp(180px, 24vw, 260px);
    aspect-ratio: 1 / 1.15;
  }
  .section01 .leftbox {
    width: 100%;
    grid-column: 1 / 3;
    grid-row: 2 / 3;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-end;
    gap: clamp(24px, 5vw, 50px);
    padding-top: 0;
    margin-top: clamp(-60px, -4vw, -30px);
  }
  .section01 .leftbox .imgbox1, .section01 .leftbox .imgbox2 {
    margin: 0;
    flex-shrink: 0;
  }
  .section01 .leftbox .imgbox1 {
    width: min(30%, 340px);
    aspect-ratio: 1 / .88;
    transform: translateY(-34px);
  }
  .section01 .leftbox .imgbox2 {
    width: min(38%, 420px);
    aspect-ratio: 1 / 1.25;
  }
  .section01 .deco_left_top {
    width: clamp(150px, 24vw, 260px);
  }
  .section01 .deco_right_bottom {
    width: clamp(180px, 28vw, 320px);
  }
}
@media screen and (max-width: 768px) {
  .section01 .concept_wrap {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 38px;
    padding: 0 50px;
  }
  .section01 .big_en {
    position: relative;
    top: auto;
    right: auto;
    order: 1;
    font-size: clamp(52px, 12vw, 84px);
    line-height: 1;
    letter-spacing: .1em;
    text-align: right;
  }
  .section01 .rightbox {
    order: 2;
    width: 100%;
  }
  .section01 .main_img {
    aspect-ratio: .86 / 1;
    border-radius: 12px;
  }
  .section01 .imgbox3 {
    position: relative;
    right: auto;
    bottom: auto;
    width: 68%;
    margin: -64px 24px 0 auto;
    aspect-ratio: 1 / 1.15;
    border-radius: 12px;
  }
  .section01 .txtbox {
    order: 3;
    width: 100%;
    max-width: none;
    padding-top: 0;
  }
  .section01 .txtbox .sub_en {
    margin-bottom: 28px;
  }
  .section01 .txtbox .lead {
    margin-top: 28px;
  }
  .section01 .leftbox {
    order: 4;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: center;
    gap: 22px;
    padding-top: 0;
    margin-top: 4px;
  }
  .section01 .leftbox .imgbox1 {
    width: calc(42% - 11px);
    max-width: none;
    aspect-ratio: 1 / .88;
    transform: translateY(-24px);
  }
  .section01 .leftbox .imgbox2 {
    width: calc(58% - 11px);
    max-width: none;
    aspect-ratio: 1 / 1.25;
  }
  .section01 .deco_left_top {
    width: 170px;
  }
  .section01 .deco_right_bottom {
    width: 220px;
  }
}
@media screen and (max-width: 576px) {
  .section01 .concept_wrap {
    padding: 0 20px;
    gap: 30px;
  }
  .section01 .big_en {
    font-size: 44px;
    letter-spacing: .08em;
    text-align: left;
  }
  .section01 .main_img {
    aspect-ratio: .86 / 1;
  }
  .section01 .imgbox3 {
    width: 82%;
    margin: -42px 0 0 auto;
    aspect-ratio: 1 / 1.15;
  }
  .section01 .leftbox {
    gap: 16px;
  }
  .section01 .leftbox .imgbox1 {
    width: calc(44% - 8px);
    transform: translateY(-18px);
  }
  .section01 .leftbox .imgbox2 {
    width: calc(56% - 8px);
  }
  .section01 .txtbox h2 {
    line-height: 1.65;
  }
  .section01 .txtbox .lead {
    line-height: 1.9;
  }
  .section01 .deco_left_top {
    width: 130px;
  }
  .section01 .deco_right_bottom {
    width: 160px;
  }
}
.trouble_a {
  position: relative;
}
.trouble_a .trouble_wrap {
  max-width: 1280px;
  margin: 0 auto;
}
.trouble_a .trouble_list {
  align-items: stretch;
  justify-content: center;
  gap: clamp(30px, 4vw, 46px);
}
.trouble_a .trouble_item {
  position: relative;
  width: calc((100% - 92px) / 3);
  padding-top: 48px;
}
.trouble_a .iconbox {
  position: absolute;
  top: -20px;
  left: 50%;
  z-index: 4;
  width: clamp(92px, 8vw, 124px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: #D0C2B4;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.trouble_a .iconbox img {
  display: block;
  width: 70%;
  height: auto;
}
.trouble_a .item_inner {
  height: 100%;
  padding: clamp(62px, 6vw, 76px) clamp(18px, 2.4vw, 30px) clamp(30px, 3vw, 40px);
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 14px rgba(113, 79, 56, .14);
  text-align: center;
}
.trouble_a .item_inner .titlebox {
  text-align: center;
}
.trouble_a .item_inner .titlebox h3 {
  color: #714F38;
  letter-spacing: .16em;
  font-weight: 400;
}
.trouble_a .item_inner .titlebox .jp {
  margin-top: 8px;
  color: #714F38;
  line-height: 1;
  letter-spacing: .12em;
}
.trouble_a .imgbox {
  width: 100%;
  aspect-ratio: 1.55 / 1;
  margin-top: clamp(22px, 3vw, 28px);
  overflow: hidden;
  border-radius: 6px;
}
.trouble_a .imgbox img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.trouble_a .trouble_point_wrap {
  margin-top: 22px;
}
.trouble_a .trouble_point {
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px dotted rgba(113, 79, 56, .34);
  justify-content: flex-start;
}
.trouble_a .check_icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #D0C2B4;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trouble_a .check_icon i {
  line-height: 1;
  transform: scale(.58);
}
.trouble_a .trouble_point p {
  color: #714F38;
  line-height: 1.5;
  letter-spacing: .06em;
  text-align: left;
  font-weight: 400;
}
.trouble_a .bottom_txt {
  margin-top: clamp(42px, 5vw, 64px);
}
.trouble_a .bottom_txt .arrow {
  width: 80px;
  height: 24px;
  margin: 0 auto 22px;
  position: relative;
}
.trouble_a .bottom_txt .arrow::before, .trouble_a .bottom_txt .arrow::after {
  content: "";
  position: absolute;
  top: 8px;
  left: 50%;
  width: 40px;
  height: 1px;
  background: rgba(113, 79, 56, .6);
}
.trouble_a .bottom_txt .arrow::before {
  transform: translateX(-100%) rotate(28deg);
  transform-origin: right center;
}
.trouble_a .bottom_txt .arrow::after {
  transform: rotate(-28deg);
  transform-origin: left center;
}
.trouble_a .bottom_txt p {
  color: #714F38;
  line-height: 2;
  letter-spacing: .12em;
}
.trouble_a .bottom_txt .more_btn {
  justify-content: center;
}
@media screen and (max-width: 1280px) {
  .trouble_a .trouble_list {
    flex-wrap: wrap;
    gap: 60px 36px;
  }
  .trouble_a .trouble_item {
    width: calc((100% - 36px) / 2);
  }
  .trouble_a .trouble_item:nth-child(3) {
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 1080px) {
  .trouble_a .trouble_list {
    flex-wrap: wrap;
    gap: 54px 24px;
  }
  .trouble_a .trouble_item {
    width: calc((100% - 24px) / 2);
  }
  .trouble_a .item_inner {
    padding-left: 18px;
    padding-right: 18px;
  }
}
@media screen and (max-width: 768px) {
  .trouble_a .trouble_wrap {
    margin-top: 70px;
  }
  .trouble_a .trouble_list {
    flex-direction: column;
    gap: 42px;
  }
  .trouble_a .trouble_item {
    width: 100%;
    max-width: 460px;
    margin: 0 auto;
  }
  .trouble_a .imgbox {
    aspect-ratio: 16 / 9;
  }
}
@media screen and (max-width: 576px) {
  .trouble_a .trouble_wrap {
    margin-top: 60px;
  }
  .trouble_a .trouble_item {
    padding-top: 42px;
  }
  .trouble_a .iconbox {
    width: 92px;
  }
  .trouble_a .item_inner {
    padding: 58px 18px 30px;
  }
  .trouble_a .item_inner .titlebox h3 {
    letter-spacing: .12em;
  }

}
.service_a .imgbox {
  position: relative;
}
.service_a .service_block:nth-of-type(1) .imgbox::before, .service_a .service_block:nth-of-type(3) .imgbox::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(254, 252, 251, 1) 0%, rgba(254, 252, 251, .72) 16%, rgba(254, 252, 251, .32) 34%, rgba(254, 252, 251, 0) 58%);
}
.service_a .service_block .imgbox::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(0deg, rgba(254, 252, 251, .9) 0%, rgba(254, 252, 251, .35) 18%, rgba(254, 252, 251, 0) 42%);
}
.service_a .service_block:nth-of-type(2) .imgbox::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(270deg, rgba(254, 252, 251, 1) 0%, rgba(254, 252, 251, .72) 16%, rgba(254, 252, 251, .32) 34%, rgba(254, 252, 251, 0) 58%);
}
.service_a {
  position: relative;
  overflow: hidden;
}
.service_a .service_wrap {
  margin: 0 auto;
}
.service_a .service_block {
  max-width: 1280px;
  --service-gap: clamp(50px, 8vw, 120px);
  position: relative;
  justify-content: space-between;
  gap: var(--service-gap);
  margin: 0 auto;
}
.service_a .service_block + .service_block {
  margin-top: clamp(100px, 12vw, 160px);
}
.service_a .service_reverse {
  flex-direction: row-reverse;
}
.service_a .txtbox {
  position: relative;
  z-index: 2;
  width: calc((100% - var(--service-gap)) * .38);
}
.service_a .imgbox {
  width: calc((100% - var(--service-gap)) * .62);
  overflow: hidden;
  border-radius: 12px;
  height: 100%;
}
.service_a .imgbox img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.service_a .num {
  position: absolute;
  top: clamp(-54px, -5vw, -30px);
  left: clamp(-18px, -2vw, -6px);
  color: rgba(113, 79, 56, .08);
  line-height: 1;
  letter-spacing: .02em;
  font-weight: 400;
  z-index: -1;
  transform: scale(2.4);
  transform-origin: left top;
}
.service_a .service_titlebox h3 {
  color: #714F38;
  line-height: 1.35;
  letter-spacing: .16em;
  font-weight: 400;
}
.service_a .service_titlebox .jp {
  margin-top: 6px;
  color: #714F38;
  line-height: 1;
  letter-spacing: .12em;
}
.service_a .lead {
  color: #714F38;
  line-height: 1.9;
  letter-spacing: .12em;
  font-weight: 400;
}
.service_a .lineheight22 {
  color: #714F38;
}
.service_a .service_deco {
  position: absolute;
  z-index: 1;
  pointer-events: none;
}
.service_a .service_deco img {
  display: block;
  width: 100%;
  height: auto;
}
.service_a .deco_left {
  top: 0;
  left: 0;
  width: clamp(220px, 26vw, 420px);
}
.service_a .deco_right {
  right: -20px;
  bottom: -20px;
  width: clamp(240px, 30vw, 480px);
}
@media screen and (max-width: 1080px) {
  .service_a .service_block {
    --service-gap: 50px;
    align-items: stretch;
  }
  .service_a .txtbox {
    width: calc((100% - var(--service-gap)) * .4);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .service_a .imgbox {
    width: calc((100% - var(--service-gap)) * .6);
    height: auto;
    min-height: clamp(460px, 58vw, 620px);
  }
  .service_a .imgbox img {
    height: 100%;
    object-fit: cover;
  }
  .service_a .num {
    top: 0;
  }
}
@media screen and (max-width: 768px) {
  .service_a .service_block, .service_a .service_reverse {
    flex-direction: column-reverse;
    gap: 70px;
  }
  .service_a .service_block + .service_block {
    margin-top: 100px;
  }
  .service_a .txtbox, .service_a .imgbox {
    width: 100%;
  }
  .service_a .imgbox {
    aspect-ratio: 16 / 10;
  }
  .service_a .num {
    top: -42px;
    left: 0;
    transform: scale(1.8);
  }
  .service_a .deco_left {
    width: 230px;
  }
  .service_a .deco_right {
    right: -30px;
    bottom: -10px;
    width: 260px;
  }
  .service_a .service_block:nth-of-type(1) .imgbox::before, .service_a .service_block:nth-of-type(2) .imgbox::before, .service_a .service_block:nth-of-type(3) .imgbox::before {
    display: none;
  }
    .service_a .service_block .imgbox::after {
           display: none;
    }
    
}
@media screen and (max-width: 576px) {
  .service_a .service_block {
    gap: 50px;
  }
  .service_a .service_block + .service_block {
    margin-top: 80px;
  }
  .service_a .imgbox {
    aspect-ratio: 2 / 1;
    border-radius: 10px;
              min-height: 0;
  }
  .service_a .num {
    top: -34px;
    transform: scale(1.45);
  }
  .service_a .service_titlebox h3 {
    letter-spacing: .12em;
  }
  .service_a .lead {
    line-height: 1.8;
  }

  .service_a .deco_left {
    width: 180px;
  }
  .service_a .deco_right {
    right: -35px;
    bottom: -10px;
    width: 200px;
  }
}
.reason_a {
  position: relative;
  overflow: hidden;
}
.reason_a .titlebox h2 {
  color: #714F38;
  line-height: 1.6;
  letter-spacing: .14em;
  font-weight: 400;
}
.reason_a .titlebox .sub_en {
  margin-top: 4px;
  color: #714F38;
  line-height: 1;
  letter-spacing: .16em;
}
.reason_a .reason_wrap {
  position: relative;
  z-index: 2;
  margin: 0 auto;
}
.reason_a .reason_list {
  --reason-gap-x: clamp(26px, 3vw, 36px);
  --reason-gap-y: clamp(54px, 5vw, 84px);
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  gap: var(--reason-gap-y) var(--reason-gap-x);
}
.reason_a .reason_item {
  position: relative;
  width: calc((100% - (var(--reason-gap-x) * 2)) / 3);
  padding-top: 26px;
}
.reason_a .item_inner {
  position: relative;
  height: 100%;
  padding: 56px 26px 34px;
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(205, 168, 135, .9);
  border-radius: 8px;
  overflow: hidden;
}
.reason_a .num {
  position: absolute!important;
  top: 18px;
  left: 18px;
  color: rgba(113, 79, 56, .08);
  line-height: 1;
  letter-spacing: .02em;
  font-weight: 400;
  z-index: 1;
    color: rgba(209,204,201,.3)!important;
}
.reason_a .iconbox {
  position: absolute;
  top: 2%;
  left: 50%;
  z-index: 4;
  width: clamp(100px, 8vw, 120px);
  aspect-ratio: 1 / 1;
  transform: translate(-50%, -42%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.reason_a .iconbox img {
  display: block;
  width: 100%;
  height: auto;
}
.reason_a .reason_titlebox {
  position: relative;
  z-index: 2;
  text-align: center;
}
.reason_a .reason_titlebox h3 {
  color: #714F38;
  line-height: 1.8;
  letter-spacing: .12em;
  font-weight: 400;
}
.reason_a .reason_titlebox::after {
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  background: rgba(205, 168, 135, .95);
  margin: 14px auto 0;
}
.reason_a .item_inner > p {
  position: relative;
  z-index: 2;
  color: #714F38;
}
.reason_a .lineheight22 {
  font-weight: 400;
}
.reason_a .reason_deco {
  position: absolute;
  z-index: 1;
  pointer-events: none;
}
.reason_a .reason_deco img {
  display: block;
  width: 100%;
  height: auto;
}
.reason_a .deco_left_top {
  top: 0;
  left: 0;
  width: clamp(550px, 22vw, 600px);
}
.reason_a .deco_right_bottom {
  right: 0;
  bottom: 0;
  width: clamp(280px, 22vw, 600px);
}
@media screen and (max-width: 1280px) {
  .reason_a .reason_list {
    --reason-gap-x: 28px;
    --reason-gap-y: 60px;
  }
  .reason_a .reason_item {
    width: calc((100% - var(--reason-gap-x)) / 2);
  }
}
@media screen and (max-width: 768px) {
  .reason_a .reason_list {
    --reason-gap-x: 0px;
    --reason-gap-y: 54px;
  }
  .reason_a .reason_item {
    width: 100%;
    max-width: 450px;
  }
  .reason_a .item_inner {
    padding: 52px 22px 30px;
  }

  .reason_a .deco_right_bottom {
    width: 160px;
  }
}
@media screen and (max-width: 576px) {
  .reason_a .item_inner {
    padding: 48px 18px 26px;
  }
  .reason_a .reason_titlebox h3 {
    letter-spacing: .08em;
  }


  .reason_a .deco_right_bottom {
    width: 120px;
  }
}
.news_b {
  position: relative;
  overflow: hidden;
 
}

.news_b .contents {
  position: relative;
  z-index: 2;
  margin: 0 auto;
}

.news_b .titlebox {
  text-align: left;
}

.news_b .titlebox h2 {
  color: #714F38;
  letter-spacing: .14em;
  font-weight: 400;
  line-height: 1.6;
}

.news_b .titlebox .sub_en {
  margin-top: 4px;
  color: #714F38;
  line-height: 1;
  letter-spacing: .16em;
}

.news_b .webgene-blog {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: 32px;
}

.news_b .webgene-blog .webgene-item {
  width: calc((100% - 64px) / 3);
}

.news_b .webgene-blog .webgene-item a {
  display: block;
  height: 100%;
  padding: 18px;
  background: #fff;
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(113, 79, 56, .08);
  transition: .3s;
}

.news_b .webgene-blog .webgene-item a:hover {
  transform: translateY(4px);
  opacity: .9;
}

.news_b .webgene-blog .webgene-item .imgbox {
  width: 100%;
  aspect-ratio: 1.55 / 1;
  overflow: hidden;
  border-radius: 6px;
  margin-bottom: 10px;
}

.news_b .webgene-blog .webgene-item .imgbox img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news_b .news_meta {
  align-items: center;
  margin-bottom: 14px;
}

.news_b .webgene-blog .webgene-item .date {
  color: #714F38;
  line-height: 1;
  letter-spacing: .06em;
}

.news_b .webgene-blog .webgene-item .catename {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 14px;
  border-radius: 999px;
  background: #714F38;
  color: #fff;
  line-height: 1;
  letter-spacing: .08em;
}

.news_b .webgene-blog .webgene-item h2 {
  color: #714F38;
  line-height: 1.6;
  letter-spacing: .08em;
  font-weight: 500;
  margin-bottom: 8px;
}

.news_b .webgene-blog .webgene-item .text {
  color: #714F38;
  line-height: 1.8;
  letter-spacing: .04em;
  font-weight: 400;
}

.news_b .more_btn {
  justify-content: center;
}

.news_b .news_deco {
  position: absolute;
  z-index: 1;
  pointer-events: none;
}

.news_b .news_deco img {
  display: block;
  width: 100%;
  height: auto;
}

.news_b .deco_left {
  top: -80px;
  left: -80px;
  width: clamp(360px, 42vw, 760px);
  opacity: .55;
}

@media screen and (max-width: 1080px) {
  .news_b .webgene-blog {
    gap: 28px;
  }

  .news_b .webgene-blog .webgene-item {
    width: calc((100% - 56px) / 3);
  }

  .news_b .webgene-blog .webgene-item a {
    padding: 14px;
  }
}

@media screen and (max-width: 900px) {
  .news_b .webgene-blog {
    gap: 28px;
    justify-content: center;
  }

  .news_b .webgene-blog .webgene-item {
    width: calc((100% - 28px) / 2);
  }

  .news_b .webgene-blog .webgene-item:nth-child(3) {
    margin-left: auto;
    margin-right: auto;
  }

  .news_b .deco_left {
    top: -40px;
    left: -80px;
    width: 420px;
  }
}

@media screen and (max-width: 576px) {
  .news_b .webgene-blog {
    gap: 30px;
  }

  .news_b .webgene-blog .webgene-item {
    width: 100%;
  }

  .news_b .webgene-blog .webgene-item a {
    padding: 14px;
  }

  .news_b .titlebox {
    text-align: center;
  }

  .news_b .deco_left {
    top: -20px;
    left: -90px;
    width: 300px;
  }
}

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px) {}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px) {}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px) {}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px) {}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px) {}