@charset "UTF-8";
@media screen and (min-width: 768px) {
  .u-pc {
    display: block;
  }
  .u-sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .u-pc {
    display: none;
  }
  .u-sp {
    display: block;
  }
}

body {
  min-width: 1200px;
  background: #f5f2eb;
  color: #2b2b2b;
}
main {
  min-width: 90%;
  margin: 0 auto;
}
.l-header {
  min-height: 620px;
  background: url(../img/top/main.jpg) no-repeat bottom center / cover;
}
.l-header h1 {
  max-width: 802px;
  margin: 0 auto;
  padding: 110px 0 0;
}
@media screen and (max-width: 767px) {
  body {
    min-width: 100%;
  }
  .l-header {
    min-height: 542px;
    background: url(../img/top/main-sp.jpg) no-repeat bottom center / cover;
  }
  .l-header h1 {
    max-width: 390px;
    margin: 0 auto;
    padding: 50px 0 0;
  }
}
.inner_link {
  max-width: 1200px;
  width: 90%;
  background: #b2912b;
  border-radius: 6px;
  margin: -110px auto 120px;
  padding: 19px 0;
}
.inner_link ul {
  display: flex;
}
.inner_link ul li {
  width: 50%;
  position: relative;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: 20px;
  text-align: center;
}
.inner_link ul li + li {
  border-left: 1px solid #fff;
}
.inner_link ul li a {
  display: block;
  width: 80%;
  margin: 0 auto;
  padding: 10px 0;
  transition: 0.3s;
  background: url(../img/top/icon_arrow.svg) no-repeat right center;
}
.inner_link ul li a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .inner_link {
    margin: -105px auto 50px;
    padding: 14px 0;
  }
  .inner_link ul li{
    font-size: 16px;
  }
  .inner_link ul li a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    width: 80%;
    margin: 0 auto;
    padding: 2px 0 24px;
    background: url(../img/top/icon_arrow.svg) no-repeat center bottom;
  }
}
.h2__wrap01 {
  padding: 5vw 0;
  background: url(../img/top/bg01.jpg) no-repeat center / cover;
}
.h2__wrap01 .c-title01 {
  width: 842px;
  margin: 0 auto;
}
.main_content01 {
  padding: 140px 0;
  position: relative;
}
.main_content01 .inner {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}
.main_content01 .bg01 {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.main_content01 .bg02 {
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.title_style {
  font-size: 28px;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-bottom: 20px;
  line-height: 1.6;
}
.title_style.c-p {
  text-align: center;
}
.title_style span {
  color: #912011;
}
.flex_wrap {
  display: flex;
  gap: 3%;
  margin: 0 0 100px;
}
.flex_wrap .img {
  width: 55%;
}
.flex_wrap .textArea {
  width: 42%;
  line-height: 2em;
  letter-spacing: 0.08em;
}
.imgFlex {
  display: flex;
  gap: 2%;
  margin: 0 0 30px;
}
.imgFlex div img {
  border-radius: 6px;
}
.text_h {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .h2__wrap01 {
    padding: 4.103vw 0 9.231vw;
    background: url(../img/top/bg01.jpg) no-repeat left center / cover;
  }
  .h2__wrap01 .c-title01 {
    width: 100%;
    margin: 0 auto;
  }
  .main_content01 {
    padding: 80px 0;
  }
  .title_style {
    font-size: clamp(18px, 6.154vw, 24px);
    margin-bottom: 20px;
  }
  .title_style.c-p {
    text-align: left;
  }
  .flex_wrap {
    display: block;
    margin: 0 0 60px;
  }
  .flex_wrap .img {
    width: 100%;
    margin: 0 0 20px;
  }
  .flex_wrap .textArea {
    width: 100%;
  }
  .imgFlex {
    display: block;
    margin: 0 0 30px;
  }
  .imgFlex div + div {
    margin-top: 16px;
  }
}
.h2__wrap02 {
  padding: 5vw 0;
  background: url(../img/top/bg04.jpg) no-repeat center / cover;
}
.h2__wrap02 .c-title02 {
  width: 661px;
  margin: 0 auto;
}
.main_content02 {
  background: url(../img/top/bg_footer02.jpg) repeat-y center / 100%;
  padding: 120px 0 80px;
}
.main_content02 .inner {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}
.main_content02 .list_style li {
  position: relative;
  border: 1px solid #cccccc;
  background: #f5f2eb;
  border-radius: 10px;
  display: flex;
  gap: 3.3%;
  align-items: center;
}
.main_content02 .list_style li::after {
  content: "";
  position: absolute;
  display: block;
  top: 6px;
  bottom: 6px;
  left: 6px;
  right: 6px;
  border: 2px solid #b2912b;
  border-radius: 8px;
  pointer-events: none;
}
.main_content02 .list_style li .img {
  width: 38%;
}
.main_content02 .list_style li .img img {
  border-radius: 10px 0 0 10px;
}
.main_content02 .list_style li .textArea {
  width: 53%;
}
.main_content02 .list_style li .textArea h3 {
  font-size: 28px;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-bottom: 20px;
  line-height: 1.6;
}
.main_content02 .list_style li .textArea h3 span {
  font-size: 18px;
  display: block;
}
.main_content02 .list_style li .textArea p {
  line-height: 1.8em;
  letter-spacing: 0.08em;
  margin: 0 0 30px;
}
.main_content02 .list_style li .textArea .btn a {
  display: inline-block;
  background: #912011 url(../img/top/icon_arrow02.svg) no-repeat right 15px center;
  color: #fff;
  padding: 12px 36px;
  border-radius: 100px;
  transition: 0.3s;
}
.main_content02 .list_style li .textArea .btn a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .main_content01 .inner,
  .main_content02 .inner {
    width: 87.692vw;
  }
  .h2__wrap02{
    padding: 11.026vw 0;
  }
  .h2__wrap02 .c-title02 {
    width: 100%;
    margin: 0 auto;
  }
  .main_content02 {
    background: url(../img/top/bg_footer02.jpg) repeat-y center / 100%;
    padding: 100px 0 80px;
  }
  .main_content02 .list_style li {
    border-radius: 10px;
    display: block;
  }
  .main_content02 .list_style li .img {
    width: 100%;
  }
  .main_content02 .list_style li .img img {
    border-radius: 10px 10px 0 0;
  }
  .main_content02 .list_style li .textArea {
    width: 100%;
    padding: 30px 24px;
  }
  .main_content02 .list_style li .textArea h3 {
    font-size: clamp(18px, 6.154vw, 24px);
  }
  .main_content02 .list_style li .textArea h3 span {
    font-size: 14px;
  }
  .main_content02 .list_style li .textArea p {
    line-height: 1.8em;
    letter-spacing: 0.08em;
    margin: 0 0 30px;
  }
  .main_content02 .list_style li .textArea .btn {
    text-align: center;
  }
  .main_content02 .list_style li .textArea .btn a{
    max-width: 260px;
    width: 100%;
  }
}
@media screen and (max-width: 374px) {
  .inner_link ul li,
  .main_content02 .list_style li .textArea .btn a{
    font-size: 14px;
  }
  .main_content02 .list_style li .textArea h3 span{
    font-size: 13px;
  }
}