@charset "UTF-8";
/* CSS Document */
body {
  font-family: var(--zenkaku);
}
main {
  overflow: hidden;
}
section {
  position: relative;
  z-index: 10;
}
h3 {
  font-size: 2.2rem;
  font-family: var(--zenmaru);
  color: var(--green);
  letter-spacing: 0.1em;
  text-align: center;
}
.message .inner .flex:not(.content_right), .point .inner .flex {
  align-items: center;
}
/*---------------------------------------------------------------------
	about
---------------------------------------------------------------------*/
.about_title {
  width: 100%;
  height: 380px;
  background-image: url("../img/about/about_img.jpg");
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  position: relative;
}
.about_title .black {
  width: 100%;
  height: 380px;
  background-color: rgba(0, 0, 0, 0.28);
}
.section-ttl {
  font-family: var(--zenmaru);
  font-size: 3.6rem;
  color: #ffffff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  letter-spacing: 0.1em;
  text-align: center;
  width: 100%;
}
.about_title_bottom {
  width: 100%;
  height: 100%;
  bottom: -1px;
  overflow: hidden;
  position: absolute;
  z-index: 10;
}
.about_title_bottom::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: -1vw;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 61.9vw 3.52vw 40.1vw;
  border-color: transparent transparent #ffffff transparent;
  z-index: 2;
}
.about_title_bottom::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -4.22vw;
  left: -1vw;
  width: 102vw;
  height: 7.04vw;
  background-color: var(--green);
  background-image: url("../img/bg.png");
  z-index: 1;
  transform: rotate(3.3deg);
}
/*---------------------------------------------------------------------
	message
---------------------------------------------------------------------*/
.message {
  background-color: #ffffff;
  margin-bottom: 60px;
  line-height: 3.0rem;
  padding-top: 50px;
}
.message h3 {
  text-align: left;
  margin-bottom: 24px;
  -webkit-text-stroke: 0.5px var(--green);
  text-stroke: 0.5px var(--green);
}
.message .content_left {
  width: 56.5%;
}
.message .content_right {
  align-items: flex-end;
  width: 37.5%;
}
.message .content_right img {
  width: 200px;
  height: 200px;
}
.message .content_right div {
  text-align: right;
  font-size: 1.2rem;
  font-family: var(--zenmaru);
  color: #6F6F6F;
}
.message .content_right div span {
  margin-left: 12px;
  font-size: 1.6rem;
}
/*---------------------------------------------------------------------
	point
---------------------------------------------------------------------*/
.point {
  background-color: #ffffff;
  line-height: 3.0rem;
}
.point .point_content {
  position: relative;
  padding: 32px 0;
}
.point .point_content.bg {
  position: relative;
  padding: 112px 0 88px;
  background-color: #FFF8E5;
  background-image: url("../img/bg.png");
  background-size: 400px 400px;
  background-repeat: repeat;
}
.point .point_content h3 {
  margin-bottom: 48px;
}
.point .point_content .img_wrap {
  max-width: 320px;
  width: 36.4%;
  max-height: 220px;
}
.point .point_content .img_wrap img {
  width: 100%;
  height: 220px;
  object-fit: contain;
}
.point .point_content p {
  width: 60.2%;
}
.point .point_content .right {
  flex-direction: row-reverse;
}
.diagonal::before {
  content: '';
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  border-top: 6.25vw solid #ffffff;
  border-right: 100vw solid transparent;
}
.diagonal::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  border-bottom: 4.2vw solid #ffffff;
  border-right: 100vw solid transparent;
}
.diagonal_right::before {
  content: '';
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  border-bottom: 6.25vw solid #ffffff;
  border-left: 100vw solid transparent;
}
.diagonal_right::after {
  content: '';
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  border-top: 4.2vw solid #ffffff;
  border-left: 100vw solid transparent;
}
.point .side_img_01 {
  position: absolute;
  top: 30px;
  right: 0;
  width: 13.4vw;
  max-width: 240px;
  min-width: 190px;
}
.point .side_img_02 {
  position: absolute;
  top: -72px;
  left: 3.9vw;
  width: 11.7vw;
  max-width: 200px;
  min-width: 150px;
}
.point .side_img_03 {
  position: absolute;
  top: 80px;
  right: 5.5vw;
  width: 11.7vw;
  max-width: 200px;
  min-width: 150px;
  z-index: 1;
}
.point .side_img_04 {
  position: absolute;
  top: -40px;
  left: 3.9vw;
  width: 7.8vw;
  max-width: 150px;
  min-width: 100px;
}
.point .side_img_05 {
  position: absolute;
  top: -50px;
  right: 4.3vw;
  width: 7.8vw;
  max-width: 150px;
  min-width: 100px;
}
/*---------------------------------------------------------------------
	button
---------------------------------------------------------------------*/
.button_content {
  position: relative;
  padding-bottom: 120px;
}
.button_content .side_img_06 {
  position: absolute;
  bottom: 0;
  left: 7.8vw;
  width: 17.4vw;
  max-width: 270px;
  min-width: 220px;
}
.button a::before {
  content: "";
  position: absolute;
  width: 13px;
  height: 2px;
  top: calc(50% + 4px);
  left: 30px;
  background-color: #ffffff;
  transform: translateY(-50%) rotate(30deg);
  border-radius: 10px;
}
.button a::after {
  content: "";
  position: absolute;
  width: 13px;
  height: 2px;
  top: calc(50% - 2px);
  left: 30px;
  background-color: #ffffff;
  transform: translateY(-50%) rotate(-30deg);
  border-radius: 10px;
}
/* 25.03.27 追記 */
/*---------------------------------------------------------------------
	DX
---------------------------------------------------------------------*/
.dx {
  padding-top: 100px;
}
.dx p {
  line-height: 1.8;
}
.dx_title {
  width: 100%;
  height: 380px;
  position: relative;
  background-color: var(--green);
  background-image: url(../img/bg.png);
  background-repeat: repeat;
  background-size: 400px 400px;
}
.dx-content-item {
  margin-bottom: 80px;
}
.dx-content-item p {
  margin-bottom: 30px;
}
.dx-content-item ol {
  counter-reset: number;
}
.dx-content-item ol li {
  position: relative;
  padding-left: 20px;
}
.dx-content-item ol li:not(:last-child) {
  margin-bottom: 8px;
}
.dx-content-item ol li:before {
  counter-increment: number;
  content: ''counter(number) '.';
  position: absolute;
  left: 0;
}
.dx-content-item > dl:first-of-type {
  margin-bottom: 40px;
}
.dx-content-item > dl dt {
  margin-bottom: 8px;
  font-weight: 700;
}
.dx-content-item .dot_ul {
  display: flex;
  flex-direction: column;
  grid-row-gap: 24px;
}
.dx-content-item .dot_ul > li {
  position: relative;
  padding-left: 20px;
}
.dx-content-item .dot_ul > li::before {
  content: "●";
  position: absolute;
  left: 0;
}