@charset "UTF-8";
/* ----------------------------------------------------------------------------------------------------
*  基本情報
* --------------------------------------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap");
html, body {
  height: 100%;
}

html {
  font-size: 62.5%;
  overflow-y: scroll;
}
@media screen and (max-width: 1160px) {
  html {
    font-size: calc(100vw * 10 / 1160);
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: calc(100vw * 10 / 750);
  }
}

body, h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, th, td, img, form, figure {
  margin: 0;
  padding: 0;
  border: none;
  font-size: 1.8rem;
  line-height: calc(32/18);
  list-style-type: none;
  font-style: normal;
  font-weight: normal;
  font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック",Arial,Verdana,sans-serif;
  text-align: left;
  color: #333;
}

div, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li, form, input, textarea, button, table, tr, th, td, article, aside, footer, header, hgroup, nav, section, a, span, img {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

a {
  color: #000;
  font-size: 1.5rem;
  text-decoration: none;
  transition: opacity 0.3s ease-out;
}
a:hover {
  opacity: .7;
}
a img {
  transition: opacity 0.3s ease-out;
}
a:hover {
  opacity: 0.7;
}
a:hover img {
  opacity: 0.7;
}

section {
  margin: 0 auto;
  position: relative;
}

figure {
  text-align: center;
  line-height: 0;
}

p {
  font-size: 1.8rem;
  line-height: calc(32/18);
}

figure {
  text-align: center;
  line-height: 0;
}

img, object {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

.sp {
  display: none;
}

.wrap {
  width: 96%;
  max-width: 95rem;
  margin: auto;
}

.wrapper {
  width: 100%;
  max-width: 160rem;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

@media screen and (max-width: 767px) {
  body {
    min-width: inherit;
  }

  figure {
    width: 100%;
    text-align: center;
  }

  img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
  }

  p {
    font-size: 3.8vw;
  }

  .sp {
    display: block;
  }

  .pc {
    display: none;
  }
}
/* ------------------------------
    text/font
------------------------------ */
.ta_c {
  text-align: center;
}

.fwb {
  font-weight: bold;
}

.color_red {
  color: #ad1104;
}

.txt_grad {
  background: linear-gradient(to right, #fda110 0%, #fb0e9a 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.highlight {
  background: linear-gradient(transparent 40%, #fcf68b 40%, #fcf68b 98%, transparent 98%);
}

.highlight_sl {
  background: linear-gradient(transparent 56%, #fcf68b 56%, #fcf68b 98%, transparent 98%);
}

.highlight_pk {
  background: linear-gradient(transparent 40%, #fababf 40%, #fababf 98%, transparent 98%);
}

.udl {
  background: linear-gradient(transparent 88%, #333 88%, #333 92%, transparent 92%);
}

.udl_pink {
  background: linear-gradient(transparent 88%, #e21270 88%, #e21270 92%, transparent 92%);
}

.mac .udl {
  border-bottom: 1px solid #333;
  padding-bottom: .1em;
  background: none;
}

.mac .udl_pink {
  border-bottom: 1px solid #e21270;
  padding-bottom: .1em;
  background: none;
}

@media screen and (max-width: 767px) {
  .udl, .mac .udl {
    background: none;
    border-bottom: 1px solid #333;
    padding: .05em 0;
  }

  .udl_pink {
    background: none;
    border-bottom: 1px solid #e21270;
    padding: .05em 0;
  }
}
/* ------------------------------
    flex
------------------------------ */
.flex {
  display: flex;
  display: -webkit-flex;
  display: -ms-flex;
}

.justifycontent_spacebetween {
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.justifycontent_center {
  -webkit-justify-content: center;
  justify-content: center;
}

.alignitems_center {
  -webkit-align-items: center;
  align-items: center;
}

/* ------------------------------
    float
------------------------------ */
.alignleft {
  float: left;
}

.alignright {
  float: right;
}

/* ------------------------------
    clearfix
------------------------------ */
.cf {
  *zoom: 1;
}
.cf:before {
  content: " ";
  display: table;
}
.cf:after {
  content: " ";
  display: table;
  clear: both;
}

.clear {
  clear: both;
}

/* ------------------------------
*  btn
------------------------------ */
.btn a {
  position: relative;
  display: block;
}

@media screen and (min-width: 768px) {
  .btn {
    text-align: center;
  }
  .btn a {
    width: 62.3rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .btn {
    text-align: center;
  }
  .btn.btn_sp {
    width: 100vw;
    margin: 0 -4.933vw;
  }
}
/* ------------------------------
*  mv
------------------------------ */
#mv {
  width: 100%;
  position: relative;
  margin: auto;
}

.mv_wrap {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.mv_ttl {
  position: relative;
  width: 100%;
  margin: 0 auto;
  line-height: 0;
}
.mv_ttl img {
  width: 100%;
}

.mv_btn {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 3rem;
  width: 100%;
  max-width: 79.8rem;
  margin: 0;
}
.mv_btn a {
  display: block;
}
@media screen and (min-width: 1025px) and (max-width: 1600px) {
  .mv_btn {
    max-width: 49.875vw;
    bottom: 1.8vw;
  }
  .mv_btn a img {
    max-width: 38.938vw;
  }
}
@media screen and (max-width: 1024px) {
  .mv_btn {
    max-width: inherit;
    padding-left: 29rem;
    bottom: 2.2rem;
  }
  .mv_btn a img {
    max-width: 44rem;
  }
}

@media screen and (max-width: 767px) {
  .mv_wrap {
    height: auto;
    max-width: inherit;
    padding-top: 0;
  }

  .mv_btn {
    z-index: 100;
    max-width: 100%;
    padding-left: 0;
    bottom: -38.6vw;
  }
  .mv_btn a img {
    max-width: 100%;
  }
}
/* ------------------------------
*  footer
------------------------------ */
.footer {
  position: relative;
  padding: 6.4rem 0 4.4rem;
  text-align: center;
  background: #020202;
}
.footer::before {
  position: absolute;
  content: "";
  background: url("../img/line_gold.png") repeat-x;
  width: 100%;
  height: 1rem;
  left: 0;
  top: 0;
}
.footer * {
  color: #fff;
  font-size: 2rem;
  letter-spacing: -.01em;
}
.footer .inner {
  padding-top: 1rem;
}
.footer .link {
  display: flex;
  justify-content: center;
  margin-bottom: 0.6rem;
}
.footer .link li {
  position: relative;
  display: inline-block;
}
.footer .link li:nth-child(n + 2)::before {
  position: absolute;
  content: "";
  background: #fff;
  width: 1px;
  height: calc(100% - 0.8em);
  left: -0.5em;
  top: .3em;
}
.footer .link li + li {
  margin-left: 1em;
}

@media screen and (max-width: 767px) {
  .footer {
    padding: 5% 0;
  }
  .footer * {
    font-size: 3.2vw;
  }
  .footer .inner {
    padding-top: 5%;
  }
  .footer .link {
    margin-bottom: 5%;
  }
  .footer .link li:nth-child(n + 2)::before {
    left: -1.6em;
  }
  .footer .link li + li {
    margin-left: 3.2em;
  }
}
/* ------------------------------
*  main
------------------------------ */
.deco {
  position: absolute;
}

.obi {
  position: relative;
  max-width: 100%;
  height: 14.7rem;
  background-position: center center;
  z-index: 2;
}
.obi.obi01 {
  background-image: url("../img/img_obi01_pc.jpg");
}
.obi.obi02 {
  background-image: url("../img/img_obi02_pc.jpg");
}
.obi.line_bottom::before {
  position: absolute;
  content: "";
  background: url("../img/line_gold.png") repeat-x;
  width: 100%;
  height: 0.7rem;
  left: 0;
  bottom: 0;
}
.obi.line_bottom.-wide::before {
  height: 1rem;
}

.contents_wrap {
  position: relative;
  max-width: 93rem;
  box-shadow: 0 0 4px 2px rgba(102, 102, 102, 0.3);
  background-color: #fff;
  margin: auto;
}

@media screen and (max-width: 767px) {
  .obi {
    background-image: url("../img/img_obi_sp.jpg") !important;
    background-size: cover;
    background-position: left center;
    height: 21.333vw;
  }

  .contents_wrap {
    width: 100% !important;
  }
}
/* ------------------------------
*  sec01
------------------------------ */
.sec01 {
  background: url("../img/bg_sec01.jpg") no-repeat center top/cover;
  padding: 2.6rem 0 7rem;
}
.sec01 .sub_txt {
  line-height: 1;
  margin: 10rem auto 9.4rem;
  width: 65.5rem;
}
.sec01 .contents_wrap {
  position: relative;
  padding: 9rem 4.8rem 13rem;
}
.sec01 .contents_wrap::before, .sec01 .contents_wrap::after {
  position: absolute;
  content: "";
  background: url("../img/frame_sec01.png") no-repeat center center/contain;
  width: 91.4rem;
  height: 9.3rem;
  left: 50%;
}
.sec01 .contents_wrap::before {
  top: 1.2rem;
  transform: translateX(-50%);
}
.sec01 .contents_wrap::after {
  bottom: 1.6rem;
  transform: translateX(-50%) rotate(180deg);
}
.sec01 .contents_wrap p + p {
  margin-top: 3rem;
}
.sec01 .contents_wrap .lg {
  font-size: 3rem;
  font-weight: 700;
  color: #b60002;
  margin-bottom: -1.5rem;
}
.sec01 .cont.cont01 {
  justify-content: space-between;
  gap: 0 3.4rem;
  margin-bottom: 3rem;
}
.sec01 .cont.cont01 .txt {
  flex: 1;
}
.sec01 .img_book {
  margin: 5.4rem auto 4.8rem;
  width: 84.5rem;
}
.sec01 .img01 {
  width: 32rem;
}
.sec01 .img08 {
  margin: 4.8rem auto 7rem;
  width: 73.8rem;
}
.sec01 .img_clm_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sec01 .img_clm_box .img {
  width: 40.2rem;
}
.sec01 .img_clm_box.box01 {
  margin: 3rem auto 4rem;
}
.sec01 .img_clm_box.box02 {
  margin: 6.8rem auto 5.2rem;
}
.sec01 .img_clm_box.box03 {
  margin: 2.6rem auto 5.2rem;
}
.sec01 .movie {
  margin: 3.8rem auto 6rem;
  text-align: center;
}
.sec01 .movie iframe {
  width: 64.2rem;
  height: 100%;
  aspect-ratio: 642 / 340;
  margin: 0 auto;
  border: 0;
}

@media screen and (max-width: 767px) {
  .sec01 {
    padding: 20% 0 8%;
  }
  .sec01 .sub_txt {
    margin: 10% auto;
    width: 80%;
  }
  .sec01 .contents_wrap {
    padding: 12% 6.5%;
  }
  .sec01 .contents_wrap::before, .sec01 .contents_wrap::after {
    width: 90.667vw;
    height: 9.333vw;
  }
  .sec01 .contents_wrap::before {
    top: 2.667vw;
  }
  .sec01 .contents_wrap::after {
    bottom: 2.667vw;
  }
  .sec01 .contents_wrap p + p {
    margin-top: 5%;
  }
  .sec01 .contents_wrap .lg {
    font-size: 4.5vw;
    margin-bottom: auto;
  }
  .sec01 .cont.cont01 {
    flex-direction: column;
    margin-bottom: 5%;
  }
  .sec01 .img_book {
    margin: 5% auto;
    width: 86%;
  }
  .sec01 .img01 {
    width: 60%;
    margin: 5% auto 0;
  }
  .sec01 .img08 {
    margin: 6.5% auto;
    width: 96%;
    position: relative;
    right: -1em;
  }
  .sec01 .img_clm_box {
    gap: 0 3vw;
  }
  .sec01 .img_clm_box .img {
    width: calc((100% - 3vw) / 2);
  }
  .sec01 .img_clm_box.box01 {
    margin: 5% auto;
  }
  .sec01 .img_clm_box.box02 {
    margin: 5% auto;
  }
  .sec01 .img_clm_box.box03 {
    margin: 5% auto;
  }
  .sec01 .movie {
    margin: 6.5% auto;
  }
  .sec01 .movie iframe {
    width: 100%;
  }
}
/* ------------------------------
*  sec02
------------------------------ */
.sec02 .sec_ttl {
  background: url("../img/bg_secttl_pc.jpg") no-repeat center top/cover;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 28.1rem;
}
.sec02 .sec_ttl .ttl {
  width: 67.7rem;
}
.sec02 .bg {
  position: relative;
  background: url("../img/bg_sec02.jpg") no-repeat center top/cover;
  padding: 6rem 0 8.2rem;
}
.sec02 .bg::before {
  content: "";
  position: absolute;
  background: url("../img/line_gold02.png") repeat-x;
  width: 100%;
  height: 1.1rem;
  bottom: 0;
  left: 0;
}
.sec02 .inner {
  padding: 0 6.8rem;
}
.sec02 .inner p + p {
  margin-top: 3rem;
}
.sec02 .item + .item {
  margin-top: 9.2rem;
}
.sec02 .item:last-of-type {
  margin-bottom: 8rem;
}
.sec02 .mes_ttl {
  color: #ad1104;
  font-family: "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 600;
  line-height: calc(40/30);
  letter-spacing: -.01em;
}
.sec02 .mes_txt {
  color: #000101;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.2;
  margin-top: 2.6rem;
  margin-bottom: 2rem;
  letter-spacing: -.01em;
}
.sec02 .movie iframe {
  width: 65.4rem;
  height: 100%;
  aspect-ratio: 654 / 368;
  margin: 0 auto;
  border: 0;
  border-radius: 0.8rem;
}

@media screen and (max-width: 767px) {
  .sec02 .sec_ttl {
    background-image: url("../img/bg_secttl_sp.jpg");
    height: 26.667vw;
  }
  .sec02 .sec_ttl .ttl {
    width: 72%;
  }
  .sec02 .bg {
    padding: 8% 0;
  }
  .sec02 .bg::before {
    height: 6px;
  }
  .sec02 .inner {
    padding: 0 3%;
  }
  .sec02 .inner p + p {
    margin-top: 5%;
  }
  .sec02 .item + .item {
    margin-top: 10%;
  }
  .sec02 .item:last-of-type {
    margin-bottom: 10%;
  }
  .sec02 .mes_ttl {
    font-size: 5.2vw;
  }
  .sec02 .mes_txt {
    font-size: 4.4vw;
    margin-top: 5%;
    margin-bottom: 5%;
  }
  .sec02 .movie iframe {
    width: 100%;
  }
}
/* ------------------------------
*  sec03
------------------------------ */
.sec03 .head {
  width: 100%;
}
.sec03 .body {
  margin-top: -25.6rem;
  background: url("../img/bg_sec03.jpg") no-repeat center top/cover;
  padding-top: 8.8rem;
  padding-bottom: 14.2rem;
}
.sec03 .sub_txt {
  margin-top: 8rem;
  margin-bottom: 8rem;
  margin-left: auto;
  margin-right: auto;
}
.sec03 .sub_txt.sub_txt01 {
  width: 66.5rem;
}
.sec03 .sub_txt.sub_txt021 {
  width: 82rem;
}
.sec03 .sub_txt.sub_txt03 {
  width: 86.8rem;
}
.sec03 .sub_txt.sub_txt04 {
  width: 89.6rem;
  margin-top: 11.6rem;
  margin-bottom: 11.2rem;
}
.sec03 .inner {
  margin: 0 auto;
  padding: 0 6.5rem;
}
.sec03 .inner p + p {
  margin-top: 3rem;
}
.sec03 .cont {
  display: flex;
  justify-content: space-between;
}
.sec03 .cont.cont01 {
  gap: 0 1.5rem;
  margin: 3.8rem auto;
  flex-direction: row-reverse;
}
.sec03 .cont.cont01 .img {
  margin-left: -5rem;
}
.sec03 .cont.cont02 {
  gap: 0 4rem;
  margin: 0 auto;
}
.sec03 .cont.cont02 .img {
  margin-right: -4rem;
  margin-top: 1.5rem;
}
.sec03 .cont.cont03 {
  gap: 0 4rem;
  margin: 3.4rem auto 9.8rem;
  flex-direction: row-reverse;
}
.sec03 .cont.cont03 .img {
  margin-left: -5rem;
}
.sec03 .cont .txt {
  flex: 1;
}
.sec03 .img01, .sec03 .img02, .sec03 .img03 {
  width: 39.3rem;
}
.sec03 .img04 {
  margin: 4.6rem auto 5rem;
  text-align: center;
  width: 79.2rem;
}
.sec03 .about_head {
  margin-top: 16.5rem;
}
.sec03 .about_ttl {
  position: relative;
  width: 100%;
  margin: 0 auto;
  max-width: 95rem;
}
.sec03 .about_ttl .ttl {
  position: relative;
  z-index: 2;
  width: 66.9rem;
  margin-left: 2rem;
}
.sec03 .about_ttl .deco.flower_left {
  left: -32rem;
  top: -15.6rem;
  width: 33rem;
}
.sec03 .about_ttl .deco.flower_right {
  right: -32.6rem;
  bottom: -10rem;
  z-index: 2;
  width: 61.6rem;
}
.sec03 .about_ttl .deco.shingo {
  right: -33rem;
  top: -19.5rem;
  width: 60.1rem;
}
.sec03 .about_ttl .deco.cloud {
  right: -32.9rem;
  bottom: -56rem;
  width: 157.8rem;
}
.sec03 .inner {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 86.7rem;
  padding: 3.8rem 0 0;
}
.sec03 .inner p {
  padding: 0 2rem;
}
.sec03 .list_check {
  position: relative;
  width: 100%;
  padding: 8.8rem 3.2rem 6.4rem;
  margin: 1rem auto 8rem;
}
.sec03 .list_check::before, .sec03 .list_check::after {
  position: absolute;
  content: "";
  background: url("../img/frame_sec03.png") no-repeat center center/contain;
  width: 86.6rem;
  height: 12.9rem;
  left: 50%;
  transform: translateX(-50%);
}
.sec03 .list_check::before {
  top: 1.2rem;
  transform: translateX(-50%);
}
.sec03 .list_check::after {
  bottom: 1.6rem;
  transform: translateX(-50%) rotate(180deg);
}
.sec03 .list_check li {
  position: relative;
  font-size: 3rem;
  font-family: "Noto Serif JP", serif;
  color: #030203;
  font-weight: 600;
  line-height: calc(48/30);
  letter-spacing: -.01em;
  padding-left: 1.8em;
}
.sec03 .list_check li.wide {
  letter-spacing: .05em;
}
.sec03 .list_check li::before {
  position: absolute;
  content: "";
  background: url("../img/icn_check.png") no-repeat center center/contain;
  width: 4rem;
  height: 4rem;
  left: 0;
  top: .1em;
}
.sec03 .list_check li + li {
  margin-top: 4rem;
}
.sec03 .btn {
  margin-top: 11.5rem;
}
.sec03 .marker {
  background: linear-gradient(transparent 64%, #fcf68b 64%, #fcf68b 98%, transparent 98%);
}

@media screen and (max-width: 767px) {
  .sec03 .head {
    width: 100%;
  }
  .sec03 .body {
    margin-top: -25.6vw;
    padding-top: 3%;
    padding-bottom: 8%;
  }
  .sec03 .sub_txt {
    margin-top: 8% !important;
    margin-bottom: 8% !important;
  }
  .sec03 .sub_txt.sub_txt01 {
    width: 68%;
  }
  .sec03 .sub_txt.sub_txt02 {
    width: 80%;
  }
  .sec03 .sub_txt.sub_txt03 {
    width: 86%;
  }
  .sec03 .sub_txt.sub_txt04 {
    width: 90%;
  }
  .sec03 .inner {
    padding: 0 3%;
  }
  .sec03 .inner p + p {
    margin-top: 5%;
  }
  .sec03 .cont {
    flex-direction: column !important;
  }
  .sec03 .cont .img {
    margin-left: auto !important;
    margin-right: auto !important;
    margin-top: 5% !important;
    margin-bottom: 5% !important;
  }
  .sec03 .cont.cont01, .sec03 .cont.cont02, .sec03 .cont.cont03 {
    margin: 5% auto;
  }
  .sec03 .img01, .sec03 .img02, .sec03 .img03 {
    width: 68%;
  }
  .sec03 .img04 {
    width: 80%;
  }
  .sec03 .about_head {
    margin-top: 20%;
  }
  .sec03 .about_ttl {
    max-width: inherit;
  }
  .sec03 .about_ttl .ttl {
    width: 66vw;
    margin-left: 6vw;
  }
  .sec03 .about_ttl .deco.flower_left {
    left: -21.333vw;
    top: -20.267vw;
    width: 40vw;
  }
  .sec03 .about_ttl .deco.flower_right {
    right: -27.4vw;
    bottom: -26.6vw;
    z-index: 2;
    width: 72vw;
  }
  .sec03 .about_ttl .deco.shingo {
    right: -35vw;
    top: -25.333vw;
    width: 74.667vw;
  }
  .sec03 .about_ttl .deco.cloud {
    right: -33vw;
    bottom: -82.2vw;
    width: 200vw;
  }
  .sec03 .inner {
    max-width: inherit;
    padding: 15% 3% 0;
  }
  .sec03 .inner p {
    padding: 0;
  }
  .sec03 .list_check {
    padding: 12% 5%;
    margin: 3% auto 5%;
  }
  .sec03 .list_check::before, .sec03 .list_check::after {
    width: 90.667vw;
    height: 13.6vw;
  }
  .sec03 .list_check::before {
    top: 5%;
  }
  .sec03 .list_check::after {
    bottom: 5%;
  }
  .sec03 .list_check li {
    font-size: 4.2vw;
    padding-left: 1.6em;
    letter-spacing: normal !important;
  }
  .sec03 .list_check li::before {
    width: 4.8vw;
    height: 4.8vw;
    top: .2em;
  }
  .sec03 .list_check li + li {
    margin-top: 3%;
  }
  .sec03 .btn {
    margin-top: 8%;
  }
}
/* ------------------------------
*  sec04
------------------------------ */
.sec04 {
  position: relative;
  background: url("../img/bg_sec04.jpg") no-repeat center top/cover;
  padding: 5.8rem 0 6.5rem;
}
.sec04 .logo_ttl {
  margin: 0 auto 5.4rem;
  line-height: 1;
  width: 72.4rem;
}
.sec04 .contents_wrap {
  padding: 4.2rem 3rem 8.3rem;
}
.sec04 .contents_wrap p + p {
  margin-top: 3rem;
}
.sec04 .ttl {
  line-height: 1;
  margin: 0 auto 3rem;
  width: 74.8rem;
}
.sec04 .img_main {
  width: 76rem;
}
.sec04 .item_reason .inner {
  padding: 0 1.5rem;
}
.sec04 .item_reason.reason01 .sub_ttl_wrap {
  gap: 0 1.4rem;
}
.sec04 .item_reason.reason02 {
  margin-top: 7.5rem;
}
.sec04 .item_reason.reason02 .sub_ttl_wrap {
  gap: 0 3rem;
}
.sec04 .item_reason.reason03 {
  margin-top: 9.4rem;
}
.sec04 .item_reason.reason04 {
  margin-top: 7.8rem;
}
.sec04 .item_reason.reason05 {
  margin-top: 5rem;
  margin-bottom: 9.5rem;
}
.sec04 .sub_ttl_wrap {
  display: flex;
  align-items: center;
  gap: 0 2.4rem;
  margin-bottom: 4.5rem;
  margin-right: auto;
}
.sec04 .sub_ttl_wrap .num {
  width: 12.9rem;
}
.sec04 .sub_ttl_wrap .sub_ttl {
  flex: 1;
  font-size: 4.8rem;
  line-height: calc(57.8/48);
  color: #111;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
}
.sec04 .sub_ttl_wrap .sub_ttl.wide {
  letter-spacing: .075em;
}
.sec04 .sub_ttl_wrap .sub_ttl.nrw, .sec04 .sub_ttl_wrap .sub_ttl .nrw {
  letter-spacing: -.06em;
}
.sec04 .sub_ttl_wrap .sub_ttl.nrw02 {
  letter-spacing: -.1em;
}
.sec04 .detail .img {
  width: 40.2rem;
}
.sec04 .detail .txt {
  flex: 1;
}
.sec04 .detail.reverse {
  flex-direction: row-reverse;
}
.sec04 .detail.detail01 {
  margin: 4rem auto 0;
  gap: 0 3rem;
}
.sec04 .detail.detail01 .img {
  margin-right: -1rem;
  margin-top: .5rem;
}
.sec04 .detail.detail02 {
  margin: 3.4rem auto 0;
  gap: 0 3rem;
}
.sec04 .detail.detail02 .txt {
  margin-right: -2rem;
}
.sec04 .detail.detail02 .img {
  margin-top: 0.7rem;
}
.sec04 .detail.detail03 {
  margin: 3.2rem auto 0;
  gap: 0 3rem;
}
.sec04 .detail.detail03 .img {
  margin-right: -1rem;
  margin-top: .5rem;
}
.sec04 .detail.detail05 {
  margin: 3.2rem auto 0;
  gap: 0 3rem;
}
.sec04 .detail.detail05 .img {
  margin-right: -1rem;
  margin-top: .5rem;
}
.sec04 .member {
  width: 100%;
  max-width: 84.9rem;
  background: #fff;
  border: 5px solid #a26613;
  padding: 0 1.4rem;
  margin: 7.6rem auto 3.6rem;
}
.sec04 .member_list li {
  display: flex;
  align-items: center;
  gap: 0 1rem;
  padding: 2rem 0;
  border-bottom: 1px solid #999;
}
.sec04 .member_list li:last-child {
  border-bottom: none;
}
.sec04 .member_list .img {
  width: 22.4rem;
  text-align: center;
}
.sec04 .member_list .img img {
  width: 20.4rem;
}
.sec04 .member_list dl {
  flex: 1;
}
.sec04 .member_list dt span {
  font-weight: 700;
  color: #000;
  display: block;
  line-height: 1.5;
}
.sec04 .member_list dt .name {
  font-size: 2.4rem;
}
.sec04 .member_list dt .name:first-letter {
  color: #312d73;
}
.sec04 .member_list dt .pos {
  font-size: 1.8rem;
}
.sec04 .member_list dd {
  font-size: 1.6rem;
  line-height: calc(32/16);
  letter-spacing: -.02em;
  padding-top: 0.5rem;
}
.sec04 .member_list dd.sm {
  font-size: 1.58rem;
  letter-spacing: -.03em;
}
.sec04 .sub_txt {
  margin: 0 auto 6.3rem;
  line-height: 1;
  width: 79rem;
}
.sec04 .btm_block {
  padding: 0 1.5rem;
}
.sec04 .btn {
  margin-top: 6.8rem;
}

@media screen and (max-width: 767px) {
  .sec04 {
    padding: 8% 0;
  }
  .sec04 .logo_ttl {
    margin: 0 auto 5%;
    width: 86%;
  }
  .sec04 .contents_wrap {
    padding: 5% 3% 6.5%;
  }
  .sec04 .contents_wrap p + p {
    margin-top: 5%;
  }
  .sec04 .ttl {
    margin: 0 auto 5%;
    width: 100%;
  }
  .sec04 .img_main {
    width: 90%;
    margin: 0 auto;
  }
  .sec04 .item_reason {
    margin-top: 10% !important;
  }
  .sec04 .item_reason .inner {
    padding: 0 3%;
  }
  .sec04 .item_reason.reason05 {
    margin-bottom: 10%;
  }
  .sec04 .sub_ttl_wrap {
    gap: 0 2vw !important;
    margin-bottom: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  .sec04 .sub_ttl_wrap .num {
    width: 17.067vw;
  }
  .sec04 .sub_ttl_wrap .sub_ttl {
    font-size: 5.2vw;
    line-height: 1.5;
    letter-spacing: normal !important;
  }
  .sec04 .detail {
    flex-direction: column !important;
    margin: 0 auto !important;
  }
  .sec04 .detail .img {
    width: 68%;
    margin: 5% auto !important;
  }
  .sec04 .detail .txt {
    margin: 0 auto !important;
  }
  .sec04 .member {
    max-width: inherit;
    border-width: 3px;
    padding: 0.8% 5% 5%;
    margin: 8% auto;
  }
  .sec04 .member_list li {
    flex-direction: column;
    align-items: center;
    gap: 3vw 0;
    padding: 8% 0;
  }
  .sec04 .member_list li:last-child {
    padding-bottom: 0;
  }
  .sec04 .member_list .img {
    width: 100%;
  }
  .sec04 .member_list .img img {
    width: 32vw;
  }
  .sec04 .member_list dt .name {
    font-size: 4.2vw;
  }
  .sec04 .member_list dt .pos {
    font-size: 3.8vw;
  }
  .sec04 .member_list dd {
    font-size: 3.6vw !important;
  }
  .sec04 .sub_txt {
    margin: 0 auto 8%;
    width: 100%;
  }
  .sec04 .btm_block {
    padding: 0 3%;
  }
  .sec04 .btn {
    margin-top: 8%;
  }
}
/* ------------------------------
*  sec05
------------------------------ */
.sec05 {
  background: url("../img/bg_sec05.jpg") no-repeat center top/cover;
}
.sec05 .head {
  padding: 13.2rem 0 0;
}
.sec05 .head .ttl_wrap {
  position: relative;
  width: 100%;
  margin: 0 auto;
  max-width: 95rem;
}
.sec05 .head .ttl_wrap .ttl {
  position: relative;
  width: 77rem;
  margin-left: 5.5rem;
}
.sec05 .head .ttl_wrap .ttl::before {
  position: absolute;
  content: "";
  background: url("../img/img_ttl_light.png") no-repeat center center/contain;
  width: 114.9rem;
  height: 46.6rem;
  left: -22rem;
  top: -7rem;
  mix-blend-mode: screen;
}
.sec05 .head .ttl_wrap .deco.flower_left {
  left: -32rem;
  top: -8.8rem;
  width: 38.7rem;
}
.sec05 .head .ttl_wrap .deco.flower_right {
  right: -32.6rem;
  bottom: -15rem;
  z-index: 2;
  width: 52.6rem;
}
.sec05 .head .ttl_wrap .deco.shingo {
  right: -33rem;
  top: -12rem;
  width: 48.5rem;
}
.sec05 .head .ttl_wrap .deco.cloud {
  right: -54.42rem;
  bottom: -53rem;
  width: 157.8rem;
}
.sec05 .body {
  position: relative;
  padding: 5rem 0 15.8rem;
  z-index: 3;
}
.sec05 .body .inner {
  padding: 0 3.5rem;
}
.sec05 .body .inner p + p {
  margin-top: 3rem;
}
.sec05 .body .txt_box {
  margin-top: 0;
  padding: 0 2.4rem;
}
.sec05 .body .img_clm_box {
  display: flex;
  align-items: center;
  justify-content: center;
}
.sec05 .body .img_clm_box.box01 {
  margin: 5.2rem auto 3.8rem;
  gap: 0 2.8rem;
}
.sec05 .body .img_clm_box.box02 {
  margin: 6.3rem auto 0;
  gap: 0 2.3rem;
}
.sec05 .body .img_clm_box .img {
  width: 42.5rem;
}
.sec05 .body .list_box {
  width: 100%;
  background: url("../img/bg_sec05_list.png") no-repeat center top/cover;
  padding: 1.3rem 1.3rem;
  margin: 6.6rem auto 5.8rem;
}
.sec05 .body .list_check {
  position: relative;
  background: #fff;
  width: 100%;
  padding: 9.6rem 2.6rem 9rem 4rem;
}
.sec05 .body .list_check::before, .sec05 .body .list_check::after {
  position: absolute;
  content: "";
  background: url("../img/frame_sec05.png") no-repeat center center/contain;
  width: 82.9rem;
  height: 9.3rem;
  left: 50%;
  transform: translateX(-50%);
}
.sec05 .body .list_check::before {
  top: 1.6rem;
  transform: translateX(-50%);
}
.sec05 .body .list_check::after {
  bottom: 1rem;
  transform: translateX(-50%) rotate(180deg);
}
.sec05 .body .list_check li {
  position: relative;
  font-size: 2.4rem;
  color: #030203;
  line-height: calc(32/24);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: calc(48/30);
  letter-spacing: -.01em;
  padding-left: 2.2em;
}
.sec05 .body .list_check li.wide {
  letter-spacing: .05em;
}
.sec05 .body .list_check li::before {
  position: absolute;
  content: "";
  background: url("../img/icn_check.png") no-repeat center center/contain;
  width: 3.2rem;
  height: 3.2rem;
  left: .1em;
  top: .1em;
}
.sec05 .body .list_check li + li {
  margin-top: 2.6rem;
}
.sec05 .body .apply dt {
  line-height: 1;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  height: 10.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 7.8rem;
}
.sec05 .body .apply dd {
  padding: 0 2.4rem;
}
.sec05 .body .apply dd + dt {
  margin-top: 9.6rem;
}
.sec05 .body .btn {
  margin-top: 6rem;
}
.sec05 .profile {
  width: 100%;
  margin: 14.3rem auto 13.4rem;
}
.sec05 .profile_ttl {
  line-height: 1;
  margin: 0 auto 6.8rem;
  width: 56rem;
}
.sec05 .profile .detail {
  gap: 0 4.2rem;
  margin-bottom: 4rem;
  align-items: center;
}
.sec05 .profile .detail .img {
  width: 32.3rem;
}
.sec05 .profile .detail .txt {
  flex: 1;
}
.sec05 .profile .name {
  line-height: 0;
  margin-bottom: 2.6rem;
  width: 27rem;
}
.sec05 .profile .pos {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 2rem;
  line-height: calc(36/20);
}
.sec05 .profile .pos + p {
  margin-top: 1.8rem !important;
}

@media screen and (max-width: 767px) {
  .sec05 .head {
    padding: 20% 0 0;
  }
  .sec05 .head .ttl_wrap {
    max-width: inherit;
  }
  .sec05 .head .ttl_wrap .ttl {
    width: 66vw;
    margin-left: 6vw;
  }
  .sec05 .head .ttl_wrap .ttl::before {
    width: 360px;
    height: 146px;
    left: -64px;
    top: -19px;
  }
  .sec05 .head .ttl_wrap .deco.flower_left {
    left: -10.133vw;
    top: -24vw;
    width: 37.333vw;
  }
  .sec05 .head .ttl_wrap .deco.flower_right {
    right: -20vw;
    bottom: -28vw;
    z-index: 2;
    width: 60vw;
  }
  .sec05 .head .ttl_wrap .deco.shingo {
    right: -26vw;
    top: -25.333vw;
    width: 60vw;
  }
  .sec05 .head .ttl_wrap .deco.cloud {
    right: -24.6vw;
    bottom: -74vw;
    width: 172vw;
  }
  .sec05 .body {
    padding: 10% 0;
  }
  .sec05 .body .inner {
    padding: 0 3%;
  }
  .sec05 .body .inner p + p {
    margin-top: 5%;
  }
  .sec05 .body .txt_box {
    margin-top: 0;
    padding: 0;
  }
  .sec05 .body .img_clm_box {
    margin: 5% auto !important;
    gap: 0 3vw;
  }
  .sec05 .body .img_clm_box .img {
    width: calc((100% - 3vw) / 2);
  }
  .sec05 .body .list_box {
    padding: 1.6%;
    margin: 6.5% auto;
  }
  .sec05 .body .list_check {
    padding: 11.6% 6.5%;
  }
  .sec05 .body .list_check::before, .sec05 .body .list_check::after {
    width: 84.8vw;
    height: 9.6vw;
  }
  .sec05 .body .list_check::before {
    top: 2.2%;
  }
  .sec05 .body .list_check::after {
    bottom: 2.2%;
  }
  .sec05 .body .list_check li {
    font-size: 4vw;
    padding-left: 1.8em;
  }
  .sec05 .body .list_check li.wide {
    letter-spacing: .05em;
  }
  .sec05 .body .list_check li::before {
    width: 4.8vw;
    height: 4.8vw;
    top: .15em;
  }
  .sec05 .body .list_check li + li {
    margin-top: 3%;
  }
  .sec05 .body .apply dt {
    height: auto;
    margin-bottom: 5%;
  }
  .sec05 .body .apply dt.ttl01 {
    padding: 3% 8%;
  }
  .sec05 .body .apply dt.ttl02 {
    padding: 3% 3%;
  }
  .sec05 .body .apply dd {
    padding: 0;
  }
  .sec05 .body .apply dd + dt {
    margin-top: 8%;
  }
  .sec05 .body .btn {
    margin-top: 8%;
  }
  .sec05 .profile {
    margin: 18% auto 15%;
  }
  .sec05 .profile_ttl {
    margin: 0 auto 5%;
    width: 68%;
  }
  .sec05 .profile .detail {
    flex-direction: column;
    align-items: center;
    margin-bottom: 5%;
  }
  .sec05 .profile .detail .img {
    width: 50%;
    margin-bottom: 5%;
  }
  .sec05 .profile .name {
    margin: 0 auto 5%;
    width: 35%;
    text-align: center;
  }
  .sec05 .profile .pos {
    font-size: 4.2vw;
  }
  .sec05 .profile .pos + p {
    margin-top: 5% !important;
  }
}
/* ------------------------------
*  sec06
------------------------------ */
.sec06 .sec_ttl {
  background: url("../img/bg_secttl_pc.jpg") no-repeat center top/cover;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 28.1rem;
  padding-top: .5em;
}
.sec06 .sec_ttl .ttl {
  width: 82.1rem;
  line-height: 1;
}
.sec06 .bg {
  position: relative;
  background: url("../img/bg_sec06.jpg") no-repeat center top/cover;
  padding: 13.6rem 0 9.5rem;
}
.sec06 .bg::before {
  position: absolute;
  content: "";
  background: url("../img/frame_sec06.png") no-repeat center center/contain;
  width: 91.4rem;
  height: 9.3rem;
  top: 5.4rem;
  left: 50%;
  transform: translateX(-50%);
}
.sec06 .inner {
  padding: 0 6.2rem;
}
.sec06 .inner p {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  letter-spacing: -.01em;
}
.sec06 .inner p + p {
  margin-top: 3.5rem;
}
.sec06 .sign {
  text-align: right;
  margin-top: 4.6rem;
  margin-right: -3.6rem;
  line-height: 1;
}
.sec06 .sign img {
  width: 28.9rem;
  display: inline-block;
  mix-blend-mode: multiply;
}
.sec06 .btm {
  margin-top: 12rem;
}
.sec06 .btm .ttl_wrap {
  position: relative;
  width: 100%;
  margin: 0 auto;
  max-width: 95rem;
}
.sec06 .btm .ttl_wrap .ttl {
  position: relative;
  width: 77rem;
  margin-left: 5.5rem;
}
.sec06 .btm .ttl_wrap .ttl::before {
  position: absolute;
  content: "";
  background: url("../img/img_ttl_light.png") no-repeat center center/contain;
  width: 114.9rem;
  height: 46.6rem;
  left: -22rem;
  top: -7rem;
  mix-blend-mode: screen;
}
.sec06 .btm .ttl_wrap .deco.flower_left {
  left: -32rem;
  top: -8.8rem;
  width: 38.7rem;
}
.sec06 .btm .ttl_wrap .deco.flower_right {
  right: -32.6rem;
  bottom: -15rem;
  z-index: 2;
  width: 52.6rem;
}
.sec06 .btm .ttl_wrap .deco.shingo {
  right: -33rem;
  top: -12rem;
  width: 48.5rem;
}
.sec06 .btm .ttl_wrap .deco.cloud {
  right: -54.42rem;
  bottom: -53rem;
  width: 157.8rem;
}

@media screen and (max-width: 767px) {
  .sec06 .sec_ttl {
    background-image: url("../img/bg_secttl_sp.jpg");
    height: 31vw;
  }
  .sec06 .sec_ttl .ttl {
    width: 86%;
  }
  .sec06 .bg {
    padding: 12% 0 10%;
  }
  .sec06 .bg::before {
    width: 96vw;
    height: 9.867vw;
    top: 1.2%;
  }
  .sec06 .inner {
    padding: 0 5%;
  }
  .sec06 .inner p + p {
    margin-top: 5%;
  }
  .sec06 .sign {
    margin-top: 8% !important;
    margin-right: -1.6%;
  }
  .sec06 .sign img {
    width: 28vw;
  }
  .sec06 .btm {
    margin-top: 24%;
  }
  .sec06 .btm .ttl_wrap {
    max-width: inherit;
  }
  .sec06 .btm .ttl_wrap .ttl {
    width: 66vw;
    margin-left: 6vw;
  }
  .sec06 .btm .ttl_wrap .ttl::before {
    width: 96vw;
    height: 38.933vw;
    left: -17.067vw;
    top: -5.067vw;
  }
  .sec06 .btm .ttl_wrap .deco.flower_left {
    left: -10.133vw;
    top: -24vw;
    width: 37.333vw;
  }
  .sec06 .btm .ttl_wrap .deco.flower_right {
    right: -20vw;
    bottom: -24vw;
    z-index: 2;
    width: 60vw;
  }
  .sec06 .btm .ttl_wrap .deco.shingo {
    right: -26vw;
    top: -25.333vw;
    width: 60vw;
  }
  .sec06 .btm .ttl_wrap .deco.cloud {
    right: -24.6vw;
    bottom: -70vw;
    width: 172vw;
  }
}
/* ------------------------------
*  sec07
------------------------------ */
.sec07 {
  background: url("../img/bg_sec07.jpg") no-repeat center top/cover;
  padding: 2.5rem 0 7rem;
}
.sec07 .contents_wrap {
  padding: 4rem 4.5rem 10rem;
}
.sec07 .contents_wrap p + p {
  margin-top: 3rem;
}
.sec07 .seminar_tbl {
  margin-top: 5.8rem;
  margin-bottom: 2.8rem;
}

@media screen and (max-width: 767px) {
  .sec07 {
    padding: 5% 0 6.5%;
  }
  .sec07_body {
    padding: 6.5% 0;
  }
  .sec07 .contents_wrap {
    padding: 6.5% 5.8%;
  }
  .sec07 .contents_wrap p + p {
    margin-top: 5%;
  }
  .sec07 .seminar_tbl {
    margin-top: 5%;
    margin-bottom: 5%;
  }
}
/* seminar_tbl */
.seminar_tbl table {
  width: 100%;
  max-width: 83rem;
  margin: 0 auto 3rem;
  pading: 0;
  border: 1px solid #666;
  border-collapse: collapse;
}
.seminar_tbl table th, .seminar_tbl table td {
  border-bottom: 1px solid #666;
  letter-spacing: .025em;
  line-height: calc(24/18);
}
.seminar_tbl table th {
  padding: .6rem 0 .5rem;
  background-color: #e9f0f9;
  width: 19%;
  font-size: 1.6rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  text-align: center;
}
.seminar_tbl table td {
  width: 81%;
  padding: 1.3rem 0.8rem 1.2rem 1.8rem;
  margin: 0 auto;
  font-size: 1.8rem;
}
.seminar_tbl table td.wide {
  padding: 2.5rem 0.8rem 2.5rem 1.8rem;
}
.seminar_tbl table td .sm {
  font-size: 1.4rem;
  letter-spacing: -.02em;
}
.seminar_tbl table .list li {
  position: relative;
  font-size: 1.8rem;
  line-height: calc(36/18);
  padding-left: 1.5em;
}
.seminar_tbl table .list li::before {
  position: absolute;
  content: "●";
  color: #ad1104;
  left: 0;
  top: -.1em;
}

@media screen and (max-width: 767px) {
  .seminar_tbl table {
    max-width: inherit;
    margin: 0 auto 5%;
  }
  .seminar_tbl table th {
    padding: 3% 0;
    width: 28%;
    font-size: 3.6vw;
    line-height: 1.5;
  }
  .seminar_tbl table td {
    width: 72%;
    padding: 3% !important;
    font-size: 3.6vw;
  }
  .seminar_tbl table td .sm {
    font-size: 3.2vw;
  }
  .seminar_tbl table .list li {
    font-size: 3.4vw;
    padding-left: 1.3em;
  }
}
/* ------------------------------
*  policy
------------------------------ */
.form_policy {
  max-width: 79rem;
  width: 100%;
  height: 22rem;
  padding: 2% 3% 2% 2%;
  margin: 6.5rem auto 0;
  overflow: hidden;
  overflow-y: scroll;
  background: #fff;
  border: 1px solid #9b9b9b;
}
.form_policy p, .form_policy a, .form_policy dt, .form_policy dd, .form_policy li {
  font-size: 1.5rem !important;
  line-height: 1.4;
}
.form_policy dl {
  margin-top: 2rem;
}
.form_policy dt {
  font-weight: 600;
  margin-bottom: .5rem;
}
.form_policy p + p, .form_policy li + li, .form_policy p + ol {
  margin-top: 1rem;
}
.form_policy ol > li > ol {
  margin-top: 1rem;
}
.form_policy ol li {
  list-style-type: decimal;
  margin-left: 1.5em;
}

@media screen and (max-width: 767px) {
  .form_policy {
    width: 96%;
    height: 28vw;
    margin-top: 5%;
  }
  .form_policy p, .form_policy a, .form_policy dt, .form_policy dd, .form_policy li {
    font-size: 3.2vw !important;
  }
}
/* ------------------------------
*  fixbtn
------------------------------ */
.fixbtn {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
  padding: 1rem 0;
  max-width: 100%;
  z-index: 10;
}

@media screen and (max-width: 767px) {
  .fixbtn {
    padding: 3% 0;
  }
  .fixbtn .btn {
    width: 100%;
    margin: auto;
  }
}
