@charset "UTF-8";
/* ==========================================================================//
//
// メッセージ
//
// ========================================================================== */
.page_body {
  padding: 45px 0 60px;
}
@media all and (min-width: 751px) {
  .page_body {
    padding: 96px 0 140px;
  }
}

.section {
  background-repeat: no-repeat;
  background-position: center 30%;
  background-size: 100% auto;
}
@media all and (min-width: 751px) {
  .section {
    background-position: center 40%;
  }
}
.section.ceo {
  background-image: url(../images/message/bg_wave01_sp.svg);
}
@media all and (min-width: 751px) {
  .section.ceo {
    background-image: url(../images/message/bg_wave01_pc.svg);
  }
}
.section.hr {
  background-image: url(../images/message/bg_wave01_sp.svg);
}
@media all and (min-width: 751px) {
  .section.hr {
    background-image: url(../images/message/bg_wave02_pc.svg);
  }
}
.section .container {
  background-color: rgba(255, 247, 240, 0.7);
  border: 1px solid #c1bbb5;
  border-radius: 6px;
  padding: 20px 20px 34px;
}
@media all and (min-width: 751px) {
  .section .container {
    border-radius: 10px;
  }
}
@media all and (min-width: 751px) {
  .section .container {
    padding: 77px 80px 70px;
  }
}
.section .sec_ttl {
  font-size: 20px;
  letter-spacing: 0.02em;
  margin-bottom: 20px;
}
@media all and (min-width: 751px) {
  .section .sec_ttl {
    font-size: 34px;
    padding-bottom: 25px;
    border-bottom: 1px solid #c1bbb5;
    margin-bottom: 54px;
  }
}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  .section .sec_ttl {
    font-size: 26px;
  }
}
.section .sec_ttl span {
  position: relative;
  padding-left: 10px;
}
@media all and (min-width: 751px) {
  .section .sec_ttl span {
    padding-left: 17px;
  }
}
.section .sec_ttl span::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #d63032;
  width: 3px;
  height: 70%;
}
@media all and (min-width: 751px) {
  .section .sec_ttl span::before {
    width: 4px;
  }
}
.section .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 22px;
  margin-bottom: 1.5em;
}
@media all and (min-width: 751px) {
  .section .wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 6.6%;
    margin-bottom: 34px;
  }
}
@media all and (min-width: 751px) {
  .section .image {
    width: 44.5%;
  }
}
.section .image img {
  border-radius: 6px;
}
@media all and (min-width: 751px) {
  .section .image img {
    border-radius: 10px;
  }
}
@media all and (min-width: 751px) {
  .section .texts {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
.section .copy {
  font-size: 20px;
  letter-spacing: 0.02em;
  margin-bottom: 15px;
}
@media all and (min-width: 751px) {
  .section .copy {
    font-size: 30px;
    margin-bottom: 38px;
  }
}
.section .text {
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.03em;
}
@media all and (min-width: 751px) {
  .section .text {
    font-size: 17px;
  }
}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  .section .text {
    font-size: 15px;
  }
}
.section .text p:not(:last-child) {
  margin-bottom: 1.5em;
}
@media all and (min-width: 751px) {
  .section .text p:not(:last-child) {
    margin-bottom: 2em;
  }
}

.full_img {
  overflow: hidden;
  margin: 50px 0;
}
@media all and (min-width: 751px) {
  .full_img {
    margin: 120px 0;
  }
}
.full_img.js_scroll {
  position: relative;
}
.full_img.js_scroll::before {
  position: absolute;
  content: "";
  background-color: #fef1e7;
  inset: 0;
  -webkit-transform-origin: right;
          transform-origin: right;
  -webkit-transition: -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1);
  transition: -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1);
  transition: transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1);
  transition: transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1), -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1);
  z-index: 1;
}
.full_img.js_scroll::after {
  position: absolute;
  content: "";
  background-color: #fef1e7;
  opacity: 0.7;
  inset: 0;
  -webkit-transform-origin: right;
          transform-origin: right;
  -webkit-transition: -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1) 0.2s;
  transition: -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1) 0.2s;
  transition: transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1) 0.2s;
  transition: transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1) 0.2s, -webkit-transform 0.75s cubic-bezier(0.76, 0.09, 0.215, 1) 0.2s;
  z-index: 2;
}
.full_img.js_scroll img {
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}
.full_img.js_scroll.scroll_active::before {
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
}
.full_img.js_scroll.scroll_active::after {
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
}
.full_img.js_scroll.scroll_active img {
  -webkit-animation: zoomOut 2.6s cubic-bezier(0.23, 1, 0.32, 1) forwards;
          animation: zoomOut 2.6s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}