@charset "utf-8";
/*--------------------------------------
　MV
---------------------------------------*/
.mv_home {
  background: url(img/mv-bg.webp) center center no-repeat;
  padding-bottom: 4rem;
}
.mv_home .mv_inner {
  max-width: 100%;
  margin: auto;
  position: relative;
  padding: 0;
}
.mv_home .mv_ttl {
  width: 98%;
  margin-left: 2%;
  padding-top: 3rem;
  padding-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .mv_home {
    margin: auto;
    padding: 4rem 0 8rem;
  }
  .mv_home .mv_inner {
    max-width: 1169px;
    margin: auto;
    position: relative;
    padding: 0 4rem;
  }
  .mv_home .mv_inner .sub {
    position: absolute;
    left: 4rem;
    bottom: -5%;
    font-size: 0.8vw !important;
  }
}
@media screen and (min-width: 1200px) {
  .mv_home .mv_inner .sub {
    font-size: 1rem !important;
  }
}

/*--------------------------------------
　cta
---------------------------------------*/
.cta .upper {
  background: #fff;
  border: 1px solid #7f94a8;
  border-radius: 10px;
  padding: 0 1.5rem 2.5rem;
  margin: 4rem 0 6rem;
}
.cta .upper .ttl {
  width: 90%;
  background: #7f94a8;
  border-radius: 5px;
  color: #fff;
  font-size: 4.6vw;
  padding: 1rem;
  text-align: center;
  margin: -2rem auto 1.4rem;
}
.cta .upper .ttl span {
  display: inline-block;
  padding-left: 19%;
  position: relative;
}
.cta .upper .ttl .icon {
  width: 20%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.cta .btn p {
  display: table;
  position: relative;
  padding: 1rem 1.5rem;
  font-size: 1.5rem;
  text-align: center;
  margin: 0 auto;
}
.cta .btn p::before, .cta .btn p::after {
  position: absolute;
  top: 1.2rem;
  height: 1.8rem;
  content: '';
}
.cta .btn p::before {
  border-left: solid 1px;
  left: 0;
  transform: rotate(-30deg);
}
.cta .btn p::after {
  border-right: solid 1px;
  right: 0;
  transform: rotate(30deg);
}
.cta .btn a {
  display: block;
  width: 100%;
  margin: auto;
  background: #e70312;
  border-radius: 100px;
  color: #fff;
  font-size: 4.6vw;
  padding: 1rem;
  text-align: center;
  padding-left: 4%;
  position: relative;
  font-weight: bold;
  box-sizing: border-box;
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.2);
}
.cta .btn a .icon {
  width: 24px;
  position: absolute;
  left: 15%;
  top: 50%;
  transform: translateY(-50%);
}
.cta .btn_02 {
  margin-top: 1.2rem;
}
.cta .btn_02 a {
  color: #e70312;
  background: #fff;
  border: 2px solid #e70312;
}
.cta .btn a .icon {
  width: 24px;
  position: absolute;
  left: 15%;
  top: 50%;
  transform: translateY(-50%);
}
.cta .under {
  background: #fff;
  border: 1px solid #c88186;
  border-radius: 10px;
  padding: 0 1.5rem 2.5rem;
}
.cta .under .ttl {
  width: 85%;
  background: #c88186;
  border-radius: 5px;
  color: #fff;
  font-size: 4.6vw;
  padding: 1rem;
  text-align: center;
  margin: -2rem auto 3rem;
}
.cta .under .ttl span {
  display: inline-block;
  padding-left: 15%;
  position: relative;
}
.cta .under .ttl .icon {
  width: 12%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.cta .btn_03 a {
  background: #e70312;
}
.cta .btn_03 a .icon {
  width: 24px;
  position: absolute;
  left: 15%;
  top: 50%;
  transform: translateY(-50%);
}
.cta .btn_03 a .icon {
  width: 24px;
  position: absolute;
  left: 15%;
  top: 50%;
  transform: translateY(-50%);
}
.cta .txt_01 {
  margin: 1rem 0 0 0 !important;
  padding: 0 0 0.5rem 0;
  font-size: 1.2rem;
  line-height: 1.3;
  text-align: center;
}
.cta .txt_01 a {
  text-decoration: underline;
}
.cta .btn a::before {
  display: block;
  content: '';
  color: #fff;
  line-height: 1;
  position: absolute;
  width: 0.8em;
  height: 0.8em;
  border: 0.075em solid currentColor;
  background: currentColor;
  border-radius: 50%;
  box-sizing: content-box;
  right: 4%;
  top: 50%;
  transform: translate(0, -50%);
}
.cta .btn a::after {
  display: block;
  content: '';
  color: #e70312;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.18em 0.31177em;
  border-left-color: currentColor;
  border-right: 0;
  position: absolute;
  right: 5.5%;
  top: 50%;
  transform: translate(0, -50%);
}
.cta .btn_02 a::before {
  color: #e70312;
}
.cta .btn_02 a::after {
  color: #fff;
}
.cta .btn_03 a::after {
  color: #e70312;
}
@media screen and (min-width: 768px) {
  .cta .upper {
    background: #fff;
    border: 1px solid #7f94a8;
    border-radius: 10px;
    padding: 0 3rem 5rem;
    margin: 8rem 0 8rem;
  }
  .cta .upper .ttl {
    width: 80%;
    border-radius: 10px;
    font-size: 3rem;
    padding: 1.5rem;
    margin: -4rem auto 2rem;
  }
  .cta .upper .ttl span {
    display: inline-block;
    padding-left: 16%;
    position: relative;
  }
  .cta .upper .ttl .icon {
    width: 80px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .cta .upper .btn_box {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .cta .upper .btn_box .btn {
    width: 48%;
  }
  .cta .btn p {
    display: table;
    position: relative;
    padding: 1rem;
    font-size: 1.8rem;
    text-align: center;
    margin: 0 auto;
  }
  .cta .btn p::before, .cta .btn p::after {
    position: absolute;
    top: 1.5rem;
    height: 2rem;
    content: '';
  }
  .cta .btn p::before {
    border-left: solid 1px;
    left: 0;
    transform: rotate(-30deg);
  }
  .cta .btn p::after {
    border-right: solid 1px;
    right: 0;
    transform: rotate(30deg);
  }
  .cta .btn a {
    display: block;
    width: 100%;
    margin: 0 auto;
    color: #fff;
    font-size: 3rem;
    padding: 1.6rem;
    padding-left: 12%;
  }
  .cta .btn a .icon img {
    width: 100%;
  }
  .cta .btn_02 {
    margin: 0;
  }
  .cta .btn_02 a {
    color: #e70312;
    background: #fff;
    border: 2px solid #e70312;
  }
  .cta .btn a .icon {
    width: 36px;
    position: absolute;
    left: 10%;
    top: 50%;
    transform: translateY(-50%);
  }
  .cta .under {
    background: #fff;
    border: 1px solid #c88186;
    border-radius: 10px;
    padding: 0 3rem 3rem;
  }
  .cta .under .ttl {
    width: 95%;
    background: #c88186;
    border-radius: 10px;
    color: #fff;
    font-size: 2.8rem;
    padding: 1.5rem;
    margin: -4rem auto 2.4rem;
  }
  .cta .under .ttl span {
    display: inline-block;
    padding-left: 8%;
    position: relative;
  }
  .cta .under .ttl .icon {
    width: 35px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .cta .btn_03 a {
    background: none;
    color: #e70312;
    box-shadow: none;
    pointer-events: none;
    font-size: 6rem;
    line-height: 1;
    padding: 0 0 0 10% !important;
  }
  .cta .btn_03 a .icon {
    width: 48px;
    position: absolute;
    left: 23%;
    top: 50%;
    margin-top: 4px;
    transform: translateY(-50%);
  }
  .cta .txt_01 {
    margin: 2rem 0 0 0 !important;
    padding: 0 0 0.5rem 0;
    font-size: 1.8rem;
    line-height: 1.3;
    text-align: center;
  }
  .cta .txt_01 a {
    text-decoration: underline;
  }
  .cta .btn a::before {
    display: block;
    content: '';
    color: #fff;
    line-height: 1;
    position: absolute;
    width: 0.8em;
    height: 0.8em;
    border: 0.075em solid currentColor;
    background: currentColor;
    border-radius: 50%;
    box-sizing: content-box;
    right: 4%;
    top: 50%;
    transform: translate(0, -50%);
  }
  .cta .btn a::after {
    display: block;
    content: '';
    color: #e70312;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent;
    border-width: 0.18em 0.31177em;
    border-left-color: currentColor;
    border-right: 0;
    position: absolute;
    right: 6%;
    top: 50%;
    transform: translate(0, -50%);
  }
  .cta .btn_02 a::before {
    color: #e70312;
  }
  .cta .btn_02 a::after {
    color: #fff;
  }
  .cta .btn_03 a:before, .cta .btn_03 a:after {
    display: none !important;
  }
}
/*--------------------------------------
　Main Index
---------------------------------------*/
.contents_top {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.sec {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
  position: relative;
}
.inner {
  max-width: 100%;
  margin: auto;
  box-sizing: border-box;
  padding: 0 1.5rem;
}
@media screen and (min-width: 768px) {
  main {}
  .contents_top {
    width: 100%;
  }
  .sec {
    width: 100%;
  }
  .inner {
    max-width: inherit;
    width: 920px;
    margin: auto;
    box-sizing: border-box;
    padding: 0 2rem;
  }
}
/*--------------------------------------
　Title
---------------------------------------*/
@media screen and (max-width: 768px) {}
/*--------------------------------------
　テキスト
---------------------------------------*/
.contents_top p {
  margin: 3rem 0 3rem;
  font-size: 1.5rem;
  line-height: 1.8;
}
.txt {
  margin: 3rem 0 3rem;
  font-size: 1.5rem;
  text-align: justify;
  line-height: 1.8;
}
.lead {
  margin: 3rem 0 0 !important;
  font-size: 1.5rem;
  line-height: 2;
}
p.caption {
  margin: 1rem 0 0 0 !important;
  padding: 0 0 0.5rem 0;
  font-size: 1rem;
  line-height: 1.3;
}
.sec p {
  margin: 0 0 0;
}
.sub {
  margin: 1rem 0 0 0 !important;
  padding: 0 0 0.5rem 0;
  font-size: 1rem;
  color: #333333;
}
.sub li {
  text-indent: -1em;
  padding-left: 1em;
}
.pl-00 {
  padding-left: 0 !important;
}
@media screen and (min-width: 768px) {
  .contents_top p {
    margin: 4rem 0 4rem;
    line-height: 1.8;
  }
  .txt {
    margin: 4rem 0 0;
    line-height: 1.8;
    font-size: 1.8rem !important;
  }
  .lead {
    margin: 4rem 0 0 !important;
    line-height: 1.8;
  }
  p.caption {
    margin: 2rem 0 0 0 !important;
    padding: 0 0 0.5rem 0;
    font-size: 1rem;
    line-height: 1.3;
  }
  .sec p {
    margin: 0 0 0;
  }
  .sub {
    margin: 2rem 0 0 0 !important;
    padding: 0 0 1rem 0;
    font-size: 1.2rem !important;
    color: #333333;
  }
  .sub li {
    text-indent: -1em;
    padding-left: 1em;
  }
}
/*--------------------------------------
　sec01
---------------------------------------*/
.sec01 {
  background: #01519b;
  padding-bottom: 3rem;
}
.sec01 .upper {
  background: #eef9ff;
  padding: 6rem 0;
}
.sec01 .upper .ttl {
  color: #01519b;
  font-size: 3.7rem;
  text-align: center;
  line-height: 1.4;
  font-weight: 900;
}
.sec01 .upper .ttl span {
  font-weight: 900;
  font-size: 4.8rem;
}
.sec01 .image01 {
  width: 744px;
  margin: auto;
  padding-top: 3rem;
  padding-bottom: 2rem;
}
.sec01 .note {
  font-size: 1.1rem;
  color: #333;
  line-height: 1.4;
}
.sec01 .txt_01 {
  color: #333;
  font-weight: 900;
  font-size: 2.3rem;
  text-align: center;
  padding-top: 2rem;
  /* text-shadow: 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff; */
}
.sec01 .txt_01 .f-size {
  font-size: 3.3rem;
  font-weight: 900;
}
.sec01 .txt_01 .clr01 {
  font-size: 3.3rem;
  font-weight: 900;
}
.sec01 .item {
  background: #8a0009;
  border-radius: 10px;
  margin-top: 1rem;
}
.sec01 .item .image02 {
  width: 703px;
  margin: auto;
  padding: 3rem 0 0;
}
.sec01 .item .note {
  color: #fff;
  width: 703px;
  text-align: center;
  margin: auto;
  font-size: 1.1rem;
  margin-top: -5px;
}
.sec01 .item .i-txt {
  text-align: center;
  color: #fff;
  font-weight: 500;
  font-size: 1.2rem;
  padding: 1rem 0 2rem;
}
.sec01 .item .i-txt a {
  font-weight: 900;
  text-decoration: underline;
  color: #fff;
}
.sec01 .box_inner {
  width: 920px;
  margin: auto;
  box-sizing: border-box;
  padding: 5rem 2rem;
}
.sec01 .box_inner .ttl {
  color: #fff;
  font-weight: 900;
  text-align: center;
  font-size: 4.6rem;
  padding-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  .sec01 {
    background: #01519b;
    padding-bottom: 2rem;
  }
  .sec01 .upper {
    background: #eef9ff;
    padding: 4rem 0;
  }
  .sec01 .upper .ttl {
    color: #01519b;
    font-size: 2.5rem;
    text-align: center;
    line-height: 1.4;
    font-weight: 900;
  }
  .sec01 .upper .ttl span {
    font-weight: 900;
    font-size: 3.2rem;
    line-height: 1.3;
  }
  .sec01 .image01 {
    width: 100%;
    margin: auto;
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
  .sec01 .note {
    font-size: 1.1rem;
    color: #333;
    line-height: 1.4;
  }
  .sec01 .txt_01 {
    color: #333;
    font-weight: 900;
    font-size: 2rem;
    text-align: center;
    padding-top: 2rem;
    /* text-shadow: 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff; */
  }
  .sec01 .txt_01 .f-size {
    font-size: 3rem;
    font-weight: 900;
  }
  .sec01 .txt_01 .clr01 {
    font-size: 3.3rem;
    font-weight: 900;
  }
  .sec01 .item {
    background: #8a0009;
    border-radius: 10px;
    margin-top: 1rem;
  }
  .sec01 .item .image02 {
    width: 94%;
    margin: auto;
    padding: 3rem 0 0;
  }
  .sec01 .item .note {
    color: #fff;
    width: 94%;
    text-align: left;
    margin: auto;
    font-size: 0.9rem;
    margin-top: 4px;
  }
  .sec01 .item .i-txt {
    text-align: center;
    color: #fff;
    font-weight: 500;
    font-size: 1.7rem;
    padding: 1rem 0 3rem;
  }
  .sec01 .item .i-txt a {
    font-weight: 900;
    text-decoration: underline;
    color: #fff;
  }
  .sec01 .box_inner {
    width: 100%;
    margin: auto;
    box-sizing: border-box;
    padding: 4rem 2rem;
  }
  .sec01 .box_inner .ttl {
    color: #fff;
    font-weight: 900;
    text-align: center;
    font-size: 3.2rem;
    padding-bottom: 2rem;
  }
}
/*--------------------------------------
　sec02
---------------------------------------*/
.sec02 {
  padding: 7rem 0;
}
.sec02 .txt-img {
  width: 613px;
  text-align: center;
  margin: auto;
}
.sec02 .ttl {
  color: #01519b;
  font-size: 4.8rem;
  text-align: center;
  margin-bottom: 3rem;
  font-weight: 900;
}
.sec02 .item-box {
  position: relative;
  margin-top: 40px;
}
.sec02 .item-box::after {
  display: block;
  content: '';
  background: url(img/sec02_04.webp) 0 center no-repeat;
  background-size: 100% auto;
  position: absolute;
  left: 305px;
  top: 80px;
  margin: auto;
  width: 247px;
  height: 274px;
  z-index: -1;
}
.sec02 .security .nmv {
  background: #01519b;
  color: #fff;
  text-align: center;
  font-size: 4rem;
  width: 49px;
  height: 49px;
  border-radius: 100px;
  font-weight: bold;
  line-height: 49px;
  position: absolute;
  left: 0;
  top: -28px;
  right: 0;
  margin: auto;
}
.sec02 .security01 .nmv {
  top: -65px;
}
.sec02 .security {
  width: 410px;
  position: relative;
}
.sec02 .security01 .s-box {
  border: solid 2px #01519b;
  border-top: none;
  box-sizing: border-box;
  position: relative;
  background: #fff;
}
.sec02 .security .s-inner {
  padding: 1.5rem 2rem 2.5rem;
}
.sec02 .security01 .s-inner {
  padding: 0 2rem 2.5rem;
}
.sec02 .security h4 {
  font-weight: bold;
  color: #01519b;
  margin-bottom: 5px;
  font-size: 2.6rem;
}
.sec02 .security h4 span {
  display: inline-block;
}
.sec02 .security .txt {
  font-size: 2.1rem !important;
  line-height: 1.5;
}
.sec02 .security02 {
  position: absolute;
  right: 0;
  top: 44px;
}
.sec02 .security02 .s-txt {
  color: #01519b;
  font-weight: bold;
  font-size: 2.2rem;
  line-height: 1.5;
  margin-top: 10px;
}
.sec02 .security02 .s-box, .sec02 .security03 .s-box {
  border: solid 2px #01519b;
  box-sizing: border-box;
  position: relative;
  background: #fff;
}
.sec02 .security03 {
  margin-top: 70px;
}
.sec02 .txt_01 {
  font-size: 3.5rem;
  font-weight: bold;
  margin: 4rem 0 1rem;
  color: #01519b;
  text-align: center;
}
.sec02 .link_box {
  display: flex;
  justify-content: space-between;
  width: 80%;
  margin: auto;
}
.sec02 .link_box li {
  width: 31%;
}
.sec02 .link_box a {
  display: block;
  background: #01519b;
  font-size: 2.8rem;
  text-align: center;
  width: 100%;
  padding: 1rem 1.5rem 4rem 1.5rem;
  font-weight: bold;
  border-radius: 10px;
  position: relative;
  color: #fff;
  box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.3);
}
.sec02 .link_box a::before {
  display: block;
  content: '';
  color: #fff;
  line-height: 1;
  position: absolute;
  width: 0.8em;
  height: 0.8em;
  border: 0.075em solid currentColor;
  background: currentColor;
  border-radius: 50%;
  box-sizing: content-box;
  left: 50%;
  bottom: 1.2rem;
  transform: translate(-50%, 0);
}
.sec02 .link_box a::after {
  display: block;
  content: '';
  color: #01519b;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.31177em 0.28em;
  border-top-color: currentColor;
  border-bottom: 0;
  position: absolute;
  left: 50%;
  bottom: 2rem;
  transform: translate(-50%, 0);
}
@media screen and (max-width: 768px) {
  .sec02 {
    padding: 5rem 0;
  }
  .sec02 .txt-img {
    width: 290px;
    text-align: center;
    margin: auto;
  }
  .sec02 .ttl {
    color: #01519b;
    font-size: 2.3rem;
    text-align: center;
    margin-bottom: 3rem;
    font-weight: 900;
  }
  .sec02 .item-box {
    position: relative;
    margin-top: 30px;
  }
  .sec02 .item-box::after {
    display: block;
    content: '';
    background: url(img/sec02_04.webp) 0 center no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: 35%;
    top: -3%;
    margin: auto;
    width: 27%;
    height: 100%;
    z-index: -1;
  }
  .sec02 .security .nmv {
    background: #01519b;
    color: #fff;
    text-align: center;
    font-size: 3rem;
    width: 38px;
    height: 38px;
    border-radius: 100px;
    font-weight: bold;
    line-height: 35px;
    position: absolute;
    left: 0;
    top: -24px;
    right: 0;
    margin: auto;
  }
  .sec02 .security01 .nmv {
    top: -47px;
  }
  .sec02 .security {
    width: 45%;
    position: relative;
  }
  .sec02 .security01 .s-box {
    border: solid 1px #01519b;
    border-top: none;
    box-sizing: border-box;
    position: relative;
    background: #fff;
  }
  .sec02 .security .s-inner {
    padding: 1.5rem 1.4rem 1.5rem;
  }
  .sec02 .security01 .s-inner {
    padding: 0 2rem 2.5rem;
  }
  .sec02 .security h4 {
    font-weight: bold;
    color: #01519b;
    margin-bottom: 5px;
    font-size: 1.7rem;
  }
  .sec02 .security h4 span {
    display: none;
  }
  .sec02 .security .txt {
    font-size: 1.5rem !important;
    line-height: 1.5;
  }
  .sec02 .security02 {
    position: absolute;
    right: 0;
    top: 44px;
  }
  .sec02 .security02 .s-txt {
    color: #01519b;
    font-weight: bold;
    font-size: 1.3rem;
    line-height: 1.5;
    margin-top: 10px;
  }
  .sec02 .security02 .s-box, .sec02 .security03 .s-box {
    border: solid 1px #01519b;
    box-sizing: border-box;
    position: relative;
    background: #fff;
  }
  .sec02 .security03 {
    margin-top: 10%;
  }
  .sec02 .txt_01 {
    font-size: 1.7rem;
    font-weight: bold;
    margin: 4rem 0 .8rem;
    color: #01519b;
    text-align: center;
  }
  .sec02 .link_box {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: auto;
  }
  .sec02 .link_box li {
    width: 31%;
  }
  .sec02 .link_box a {
    display: block;
    background: #01519b;
    font-size: 3.3vw;
    text-align: center;
    width: 100%;
    padding: 1rem 1.2rem 2.5rem 1.2rem;
    font-weight: bold;
    border-radius: 5px;
    position: relative;
    color: #fff;
    box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.3);
  }
  .sec02 .link_box a::before {
    display: block;
    content: '';
    color: #fff;
    line-height: 1;
    position: absolute;
    width: 1.1em;
    height: 1.1em;
    border: 0.075em solid currentColor;
    background: currentColor;
    border-radius: 50%;
    box-sizing: content-box;
    left: 50%;
    bottom: 7px;
    transform: translate(-50%, 0);
  }
  .sec02 .link_box a::after {
    display: block;
    content: '';
    color: #01519b;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent;
    border-width: 0.40177em 0.35em;
    border-top-color: currentColor;
    border-bottom: 0;
    position: absolute;
    left: 50%;
    bottom: 11px;
    transform: translate(-50%, 0);
  }
}
/*--------------------------------------
　sec03
---------------------------------------*/
.sec03 {
  padding-bottom: 6rem;
  background: #eef9ff;
}
.sec03 .img01 {
  background: #00132d;
  margin-bottom: 6rem;
}
.sec03 .img01 img {
  max-width: 920px;
  margin: auto;
}
.sec03 .inner {
  width: 1030px;
}
.sec03 .box01 {
  background: #fff;
  margin-bottom: 4rem;
  box-shadow: 0px 0px 15px -5px #777777;
  border-radius: 20px;
  padding: 3rem 4rem 4rem;
}
.sec03 .box01 {
  position: relative;
  height: auto;
  display: block;
}
.sec03 .box01 .fix_box, .sec03 .box02 .fix_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.sec03 .box01 .item {
  width: 46%;
}
.sec03 .box01::before {
  content: '';
  background: #01519b;
  width: 2px;
  height: 87%;
  position: absolute;
  top: 6%;
  left: 0;
  right: 0;
  display: block;
  margin: auto;
}
.sec03 .box h4 {
  color: #01519b;
  font-size: 3.3rem;
  font-weight: 900;
}
.sec03 .box .txt_box {
  position: relative;
}
.sec03 .box .txt_box .image {
  width: 160px;
  position: absolute;
  right: 0;
  top: 0;
}
.sec03 .box .txt_box .txt_01 {
  position: relative;
  z-index: 1;
  font-size: 2rem;
  line-height: 1.6;
  width: 78%;
  margin-top: 1rem;
  text-shadow: 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff;
}
.sec03 .box01 .pt_box {
  margin: 2rem 0 0;
}
.sec03 .box01 .pt_box .f_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 2rem 2rem 2rem;
  /*コレ*/ align-items: stretch;
  height: 100%;
  background: #01519b;
}
.sec03 .box01 .pt_box .f_box .image {
  display: flex;
  align-items: center;
  width: 30%;
}
.sec03 .box01 .pt_box .f_box .image > div {
  width: 100%;
  height: 100%;
}
.sec03 .box01 .pt_box .f_box .image img {
  object-fit: cover;
  height: 100%;
  border-radius: 10px;
}
.sec03 .box01 .pt_box .f_box .t_area {
  display: flex;
  align-items: center;
  width: 65%;
  height: 100%;
}
.sec03 .box01 .pt_box .f_box .t_area .p_txt {
  font-weight: bold;
  font-size: 2.6rem;
  color: #fff;
  text-decoration: underline;
}
.sec03 .box01 .pt_box .f_box .t_area .txt {
  font-weight: bold;
  font-size: 1.8rem;
  color: #fff;
  line-height: 1.5;
  margin-top: 0.5rem;
}
.sec03 .box02 .item {
  width: 48%;
  background: #fff;
  margin-bottom: 4rem;
  box-shadow: 0px 0px 15px -5px #777777;
  border-radius: 20px;
  padding: 2rem 4rem 2rem;
}
.sec03 .box02 .item .txt_box .txt_01 {
  width: 74%;
}
.sec03 .toggle {
  display: none;
}
.sec03 .Label { /*タイトル*/
  padding: 1em;
  display: block;
  color: #fff;
  background: #01519b;
  text-align: center;
  border-radius: 20px;
}
.sec03 .Label span {
  display: block;
  font-weight: bold;
  font-size: 2.3rem;
  position: relative;
}
.sec03 .Label span::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	background: url("img/acc_open.webp") left top no-repeat;
  background-size: contain;
	width: 24px;
	height: 24px;
	margin-top: -12px;
  box-sizing: border-box;
	transition: all 0.4s;
}
.sec03 .toggle:checked + .Label span::after {
	background: url("img/acc_close.webp") left top no-repeat;
  background-size: contain;
}

.sec03 .Label, .sec03 .content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}
.sec03 .toggle:checked + .Label + .content { /*開閉時*/
  height: auto;
  padding: 2rem 4rem 2rem;
  transition: all .3s;
}

.sec03 .toggle:checked + .Label {
  border-radius: 20px 20px 0 0 !important;
}
.sec03 .content { /*本文*/
  height: 0;
  margin-bottom: 10px;
  padding: 0 20px;
  box-shadow: 0px 0px 15px -5px #777777;
  background: #fff;
  overflow: hidden;
  border-radius: 0 0 20px 20px;
}
.sec03 .content .fix_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.sec03 .content .fix_box .item {
  width: 48%;
  margin-bottom: 2rem;
}
.sec03 .content .fix_box .item .i_fix_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.sec03 .content .fix_box .item .i_fix_box .image {
  width: 28%;
}
.sec03 .content .fix_box .item .i_fix_box .txt_box {
  width: 67%;
  height: inherit !important;
}
.sec03 .content .fix_box .item .i_fix_box .txt_box h4 {
  font-size: 2.5rem;
}
.sec03 .content .fix_box .item .i_fix_box .txt_box .txt_01 {
  font-size: 1.7rem;
  line-height: 1.5;
  width: 100%;
  margin-top: 5px;
}
@media screen and (max-width: 768px) {
  .sec03 {
    padding-bottom: 4rem;
    background: #eef9ff;
  }
  .sec03 .img01 {
    background: #00132d;
    margin-bottom: 4rem;
  }
  .sec03 .img01 img {
    max-width: 100%;
    margin: auto;
  }
  .sec03 .inner {
    width: 100%;
  }
  .sec03 .box01 {
    background: #fff;
    margin-bottom: 2rem;
    box-shadow: 0px 0px 15px -5px #777777;
    border-radius: 10px;
    padding: 3rem 2rem 3rem;
  }
  .sec03 .box01 {
    position: relative;
    height: auto;
    display: block;
  }
  .sec03 .box01 .fix_box, .sec03 .box02 .fix_box {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec03 .box01 .item {
    width: 100%;
  }
  .sec03 .box01::before {
    content: '';
    background: #01519b;
    width: 2px;
    height: 87%;
    position: absolute;
    top: 6%;
    left: 0;
    right: 0;
    display: none;
    margin: auto;
  }
  .sec03 .box01 .item:first-child {
    border-bottom: solid 2px #01519b;
    padding-bottom: 3rem;
    margin-bottom: 3rem;
  }
  .sec03 .box h4 {
    color: #01519b;
    font-size: 2.3rem;
    font-weight: 900;
  }
  .sec03 .box .txt_box {
    position: relative;
    height: auto;
  }
  .sec03 .box .txt_box .image {
    width: 40%;
    position: absolute;
    right: 0;
    top: 0;
  }
  .sec03 .box .txt_box .txt_01 {
    position: relative;
    z-index: 1;
    font-size: 1.5rem;
    width: 78%;
    margin-top: 0.5rem;
    text-shadow: 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff, 2px 2px 4px #fff, -2px -2px 4px #fff, 2px -2px 4px #fff, -2px 2px 4px #fff, 0 0 10px #fff;
  }
  .sec03 .box01 .pt_box {
    margin-top: 2rem;
  }
  .sec03 .box01 .pt_box .f_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 2rem 2rem 2rem;
    /*コレ*/ align-items: stretch;
    height: 100%;
    background: #01519b;
  }
  .sec03 .box01 .pt_box .f_box .image {
    width: 30%;
  }
  .sec03 .box01 .pt_box .f_box .image img {
    border-radius: 5px;
  }  
  .sec03 .box01 .pt_box .f_box .t_area {
    width: 65%;
  }
  .sec03 .box01 .pt_box .f_box .t_area .p_txt {
    font-weight: bold;
    font-size: 2rem;
    color: #fff;
    text-decoration: underline;
  }
  .sec03 .box01 .pt_box .f_box .t_area .txt {
    font-weight: bold;
    font-size: 1.4rem;
    color: #fff;
    line-height: 1.5;
    margin-top: 0.5rem;
  }
  .sec03 .box02 .item {
    width: 100%;
    background: #fff;
    margin-bottom: 2rem;
    box-shadow: 0px 0px 15px -5px #777777;
    border-radius: 10px;
    padding: 2rem 2rem 2rem;
  }
  .sec03 .box02 .item .txt_box .txt_01 {
    width: 74%;
  }
  .sec03 .toggle {
    display: none;
  }
  .sec03 .Label { /*タイトル*/
    padding: 1em;
    display: block;
    color: #fff;
    background: #01519b;
    text-align: center;
    border-radius: 10px;
  }
  .sec03 .Label span {
    font-weight: bold;
    font-size: 4.2vw;
    position: relative;
  }
  .sec03 .Label span::after {
    width: 14px;
    height: 14px;
    margin-top: -7px;
  }
  .sec03 .Label, .sec03 .content {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
  }
  .sec03 .toggle:checked + .Label + .content { /*開閉時*/
    height: auto;
    padding: 2rem 2rem 0;
    transition: all .3s;
  }
  .sec03 .toggle:checked + .Label {
    border-radius: 10px 10px 0 0 !important;
  }
  .sec03 .content { /*本文*/
    height: 0;
    margin-bottom: 10px;
    padding: 0 20px;
    box-shadow: 0px 0px 15px -5px #777777;
    background: #fff;
    overflow: hidden;
    border-radius: 0 0 10px 10px;
  }
  .sec03 .content .fix_box {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec03 .content .fix_box .item {
    width: 100%;
    border-bottom: solid 2px #01519b;
    padding-bottom: 2rem;
    margin-bottom: 2rem;
  }
  .sec03 .content .fix_box .item:last-child {
    border-bottom: none;
  }
  .sec03 .content .fix_box .item .i_fix_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .sec03 .content .fix_box .item .i_fix_box .image {
    width: 28%;
  }
  .sec03 .content .fix_box .item .i_fix_box .txt_box {
    width: 67%;
    height: inherit !important;
  }
  .sec03 .content .fix_box .item .i_fix_box .txt_box h4 {
    font-size: 1.8rem;
  }
  .sec03 .content .fix_box .item .i_fix_box .txt_box .txt_01 {
    font-size: 1.5rem;
    line-height: 1.5;
    width: 100%;
    margin-top: 5px;
  }
}
/*--------------------------------------
　sec04
---------------------------------------*/
.sec04 {
  background: #fff2eb;
  padding-bottom: 2rem;
}
.sec04 .img01 {
  background: #00132d;
  margin-bottom: 5rem;
}
.sec04 .img01 img {
  max-width: 100%;
  margin: auto;
}
.video-thumb {
  position: relative;
  width: 100%;
  max-width: 560px;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
  cursor: pointer;
}
.video-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80px;
  height: 80px;
  background-size: 60%;
  transform: translate(-50%, -50%);
  opacity: 0.8;
}
.video-modal {
  display: none;
  position: fixed;
  z-index: 9999;
  padding-top: 60px;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.8);
}
.video-modal-content {
  position: absolute; /* fixedではなくabsoluteで中央揃え */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 800px;
  opacity: 0;
  transition: all 0.5s ease;
  border: 4px solid #fff;
  box-sizing: border-box;
}
.video-modal-content.show {
  opacity: 1;
  transform: translate(-50%, -40%);
}
.video-frame-wrap {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}
.video-frame-wrap iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.close {
  color: #fff;
  position: absolute;
  top: -50px;
  right: 0;
  font-size: 30px;
  font-weight: bold;
  cursor: pointer;
}
.sec04 ul li {
  background: #fff;
  box-shadow: 0px 0px 15px -5px #777777;
  margin-bottom: 5rem;
}
.sec04 ul li .midashi {
  font-weight: bold;
  text-align: center;
  font-size: 2rem;
  padding: 1.5rem 0;
  position: relative;
}
.sec04 ul li .midashi::after {
  display: block;
  content: '';
  background: url("img/arrow03.png") 0 center no-repeat;
  background-size: 100% auto;
  position: absolute;
  width: 25px;
  height: 21px;
  top: 50%;
  right: 30px;
  margin-top: -7px;
}
.sec04 ul li .midashi::before {
  display: block;
  content: '';
  background: url("img/arrow03.png") 0 center no-repeat;
  background-size: 100% auto;
  position: absolute;
  width: 25px;
  height: 21px;
  top: 50%;
  left: 30px;
  margin-top: -7px;
}
.sec04 .movie {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9; /* CSSで比率を保つ場合 */
}
@media screen and (min-width: 768px) {
  .sec04 {
    padding-bottom: 4rem;
  }
  .sec04 .img01 {
    background: #00132d;
    margin-bottom: 6rem;
  }
  .sec04 .img01 img {
    max-width: 920px;
    margin: auto;
  }
  .sec04 ul {
    display: block;
    width: 700px;
    margin: auto;
    justify-content: space-between;
  }
  .sec04 ul li {
    width: 100%;
    background: none;
    box-shadow: none;
    margin-bottom: 0;
    box-shadow: 0px 0px 15px -5px #777777;
    margin: 0 auto 4rem;
    padding: 0 !important
  }
  .sec04 ul li .midashi {
    font-weight: bold;
    text-align: center;
    font-size: 3rem;
    padding: 2rem 0;
    background: #fff;
    position: relative;
  }
  .sec04 ul li .midashi::after {
    display: block;
    content: '';
    background: url("img/arrow03.png") 0 center no-repeat;
    background-size: 100% auto;
    position: absolute;
    width: 30px;
    height: 26px;
    top: 50%;
    right: 60px;
    margin-top: -7px;
  }
  .sec04 ul li .midashi::before {
    display: block;
    content: '';
    background: url("img/arrow03.png") 0 center no-repeat;
    background-size: 100% auto;
    position: absolute;
    width: 30px;
    height: 26px;
    top: 50%;
    left: 60px;
    margin-top: -7px;
  }
  .sec04 .video-thumb {
    width: 100% !important;
    max-width: 100% !important;
    height: auto;
    aspect-ratio: 16 / 9;
    display: block;
    padding: 0 !important;
    margin: 0 !important;
  }
}
/*--------------------------------------
　sec05
---------------------------------------*/
.sec05 {
  padding: 0;
}
.sec05 .img01 {
  margin: 3rem 0 2rem;
  width: 100%;
}
.sec05 .ttl {
  background: #00132d;
  margin: 0;
  padding: 0;
}
.sec05 .ttl img {
  width: 100%;
  margin: auto;
}
.link_01 {
  color: #004495;
  position: relative;
  padding-left: 1.5rem;
  line-height: 1;
  text-decoration: underline;
  display: table;
  margin: 0 auto 2rem;
}
.link_01:before {
  background: url("img/arrow_01.png") center no-repeat;
  background-size: cover;
  width: 12px;
  height: 12px;
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(0, -50%);
}
.sec05 .label {
  padding: 0.7rem 0 0.9rem;
  display: block;
  color: #fff;
  background: #555555;
  text-align: center;
  margin-top: 2rem;
  font-weight: bold;
  font-size: 2rem;
}

.sec05 .content {
  margin: 2rem 0 0;
}
.equipment__table table {
  width: 100%
}
.equipment__table table td, .equipment__table table th {
  line-height: 1.2;
  border: #555 solid 1px;
  vertical-align: top;
  padding: .5em 1.5em
}
.equipment__table table thead tr th {
  font-size: 138.9%;
  font-weight: 700;
  text-align: center;
  color: #fff;
  background: #555;
  border-right: #fff solid 1px;
}
.equipment__table table thead tr .bl01 {
  border-right: none !important;
}
.equipment__table table thead tr .ma01 {
  padding-right: 200px !important;
}
.equipment__table table thead tr th:last-of-type {
  border-left: #fff solid 1px
}
.equipment__table table tbody tr td, .equipment__table table tbody tr th {
  font-size: 111.1%;
  font-weight: 700
}
.equipment__table table tbody tr th {
  padding: 25px 0;
  font-weight: 700;
  color: #ac2925;
  background: #f5f5f5;
  text-align: left
}
.equipment__table table tbody tr th .num {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 1.5em;
  height: 1.5em;
  background: #fff;
  font-weight: bold;
  border: .1em solid #ac2925;
  border-radius: 50%;
  line-height: 1.5em;
  text-align: center;
  font-size: 2.8rem;
}
.equipment__table table tbody tr .th-txt {
  text-align: center;
  font-weight: bold;
}
.equipment__table table tbody tr .th-txt span {
  text-align: center;
  font-weight: bold;
  font-size: 2.6rem;
}
.equipment__table table tbody tr td {
  text-align: center
}
.equipment__table table tbody .t_bg01 {
  font-weight: 900;
  text-align: left;
  padding-left: 2rem;
  background: #f5f5f5;
}
.equipment__table table .t_left {
  text-align: left !important;
  padding-left: 2rem;
}
.equipment__table table tbody tr td {
  padding: 2rem 0;
}
.sec05 .sub {
  margin-top: 1rem !important;
  margin-bottom: 3rem !important;
  padding-bottom: 0 !important;
}
.sec05 .u_txt {
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1.4;
  text-align: center;
  margin-top: 0.02rem;
}
.sec05 .u_txt a {
  font-weight: bold;
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .equipment__table table {
    width: 100%
  }
  .equipment__table table thead tr th {
    font-size: 4vw;
    padding: .5em 0
  }
  .equipment__table table thead tr th:last-of-type {
    border-left: #fff solid 1px
  }
  .equipment__table table tbody tr td, .equipment__table table tbody tr th {
    font-weight: 700;
    padding: .85em .15em
  }
  .equipment__table table tbody tr th {
    font-size: 3.7333333333vw;
    text-align: center;
    padding: .5em;
  }
  .equipment__table table tbody tr th .num {
    margin: 0 auto 0 !important;
    line-height: 1.2;
  }
  .equipment__table table tbody .t_bg01 {
    text-align: center;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .equipment__table table .t_left {
    text-align: center!important;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .equipment__table table tbody tr td {
    font-size: 3.4666666667vw;
    width: 8em;
  }
  .equipment__table table tbody tr td:last-of-type {
    width: 3em
  }
  .equipment__table table thead tr .ma01 {
    padding-right: 28% !important;
  }
  .equipment__table table tbody tr .th-txt {
    text-align: center;
    font-weight: bold;
    line-height: 1;
  }
  .equipment__table table tbody tr .th-txt span {
    text-align: center;
    font-weight: bold;
    font-size: 2.2rem;
  }
  .sec05 .sub {
    margin-bottom: 1.5rem !important;
  }
  .sec05 .u_txt {
    font-weight: bold;
    font-size: 1.4rem;
    line-height: 1.4;
    margin-top: 0.4rem;
  }
}
.equipment__notes {
  font-size: 66.7%;
  margin-top: 1em;
  margin-left: .5em
}
.equipment__notes li {
  position: relative;
  padding-left: 1em
}
.equipment__notes li::before {
  position: absolute;
  top: auto;
  left: 0;
  display: inline;
  content: '※'
}
.sec05 .js-accordion {
  border: 2px solid #bc111a;
  width: 75%;
  margin: 3rem auto 0;
  display: block;
  color: #bc111a;
  padding: 0.5rem 0;
  border-radius: 6px;
}
.sec05 .js-accordion p {
  font-size: 1.8rem;
  font-weight: bold !important;
}
.sec05 .js-accordion::before {
  background: #bc111a;
}
.sec05 .js-accordion::after {
  background: #bc111a;
}
@media screen and (min-width: 768px) {
  .sec05 {
    padding: 0 0 8rem;
  }
  .sec05 .ttl {
    background: #00132d;
  }
  .sec05 .ttl img {
    width: 920px;
    margin: auto;
  }
  .sec05 .img01 {
    margin: 6rem auto 3rem;
    width: 900px;
  }
  .link_01 {
    color: #004495;
    position: relative;
    padding-left: 3rem;
    line-height: 1;
    text-decoration: underline;
    display: table;
    margin: 0 auto 3rem;
    font-size: 2.6rem;
  }
  .link_01:before {
    background: url("img/arrow_01.png") center no-repeat;
    background-size: cover;
    width: 24px;
    height: 24px;
    display: block;
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
  }
  .sec05 .label {
    padding: 0.3rem 0 0.5rem;
    display: block;
    color: #fff;
    background: #555555;
    text-align: center;
    margin-top: 6rem;
    font-weight: bold;
    font-size: 4rem;
  }
  .sec05 .content {
    margin: 4rem 0 0;
  }
}
.equipment-detail-wrap {
  margin-top: 50px
}
.equipment-detail.is-open .equipment-detail__button .icn--open::after {
  height: 0
}
.equipment-detail__link {
  text-align: center;
  width: 100%;
  max-width: 520px;
  margin: 0 auto
}
.equipment-detail__button {
  font-size: 155.6%;
  letter-spacing: .1em;
  background: #fff;
  color: #ac2925;
  border: #ac2925 solid .125em;
  padding: .75em 1em .75em .25em;
  border-radius: 100vh
}
.equipment-detail__button:hover {
  opacity: .8;
  background-color: #ffe5e3
}
.equipment-detail__button .icn--open {
  width: 1em;
  height: 1em;
  position: absolute;
  top: 50%;
  right: 5%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: all .15s cubic-bezier(.23, 1, .32, 1);
  -o-transition: all .15s cubic-bezier(.23, 1, .32, 1);
  transition: all .15s cubic-bezier(.23, 1, .32, 1)
}
.equipment-detail__button .icn--open::after, .equipment-detail__button .icn--open::before {
  display: block;
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  -webkit-transition: all .15s cubic-bezier(.23, 1, .32, 1);
  -o-transition: all .15s cubic-bezier(.23, 1, .32, 1);
  transition: all .15s cubic-bezier(.23, 1, .32, 1);
  background: #ac2925;
  border-radius: 2px
}
.equipment-detail__button .icn--open::before {
  width: 100%;
  height: 20%
}
.equipment-detail__button .icn--open::after {
  width: 20%;
  height: 100%
}
@media (min-width: 768px), print {
  .sec05 .js-accordion {
    display: table;
    border: 2px solid #bc111a;
    width: inherit;
    margin: 6rem auto 0;
    display: block;
    color: #bc111a;
    padding: 1rem 8rem 1rem 4rem;
    border-radius: 6px;
    box-sizing: border-box;
  }
  .sec05 .js-accordion p {
    font-size: 2.4rem;
  }
  .equipment__table table tbody tr td {
    padding: 2rem 0;
  }
}
@media only screen and (max-width: 768px) {
  .sec05 .cta__buttons {
    margin: 0 0 8vw
  }
  .equipment__text {
    margin-bottom: 1.5em
  }
  .equipment__table table {
    width: 100%
  }
  .equipment__table table thead tr th {
    font-size: 4vw;
    padding: .5em 0;
  }
  .equipment__table table thead tr th:last-of-type {
    border-left: #fff solid 1px !important;
  }
  .equipment__table table tbody tr td, .equipment__table table tbody tr th {
    font-weight: 700;
    padding: .85em .15em
  }
  .equipment__table table tbody tr th {
    font-size: 3.7333333333vw;
    text-align: center;
    padding: 15px 0;
  }
  .equipment__table table tbody tr th .num {
    margin: 0 auto .25em
  }
  .equipment__table table tbody tr td {
    font-size: 3.4666666667vw;
    width: 8em
  }
  .equipment__table table tbody tr td:last-of-type {
    width: 3em
  }
  .equipment__notes {
    font-size: 2.4vw
  }
  .equipment-detail-wrap {
    margin-top: 6.6666666667vw
  }
  .equipment-detail__link {
    max-width: 80vw
  }
  .equipment-detail__button {
    font-size: 4.6666666667vw
  }
  .sec05 .goods-list-block {
    margin-top: 20px
  }
  .sec05 .goods-list-block + .goods-list-block {
    margin-top: 5px
  }
  .sec05 .goods-list-block .goods-ttl {
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 15px
  }
  .sec05 .goods-list-block .goods-ttl02 {
    font-size: 18px;
    font-size: 1.8rem;
    margin-bottom: 5px
  }
  .sec05 .goods-list-block .goods-list-border > .goods-ttl02:first-child {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px #ccc solid
  }
  .sec05 .goods-list-block .goods-list > * {
    font-size: 14px;
    font-size: 1.4rem
  }
  .sec05 .goods-list-block .goods-list > * + * {
    margin-top: 10px
  }
  .sec05 .goods-list-block .goods-list > * > .goods-ttl02 {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px #ccc solid
  }
  .sec05 .goods-list-block .goods-list .goods-item-top {
    margin-bottom: 5px
  }
  .sec05 .goods-list-block .goods-list ._name {
    font-size: 1.6rem;
    padding-left: 10px
  }
  .sec05 .goods-list-block .goods-list ._wide .goods-item-side ._name {
    margin-top: 10px;
    padding-left: 0 !important
  }
  .sec05 .goods-list-block .goods-list .goods-item-smp .smp-img {
    width: 100px
  }
  .sec05 .goods-list-block .goods-list .goods-item-smp .smp-name {
    font-size: 16px;
    font-size: 1.6rem
  }
}
.sec05 .accordion-box .block {
  background: #f5f5f5;
  padding: 3rem 0 5rem;
  margin-top: 4rem;
}
.sec05 .accordion-box .block .b_box {
  width: 90%;
  margin: 0 auto 4rem;
}
.sec05 .accordion-box .block .b_box:last-child {
  margin: 0 auto 0;
}
.sec05 .accordion-box .b_ttl {
  position: relative;
}
.sec05 .accordion-box .b_ttl span {
  font-weight: bold;
  background: #f5f5f5;
  font-size: 4rem;
  color: #9c0008;
  display: inline-block;
  position: relative;
  z-index: 1;
  padding-right: 3rem;
}
.sec05 .accordion-box .b_ttl::before {
  display: block;
  content: '';
  position: absolute;
  top: 50%;
  background: #9c0008;
  width: 100%;
  height: 2px;
}
.sec05 .accordion-box .i_area {
  background: #fff;
  margin-top: 2rem;
  margin-bottom: 2.5rem;
  box-shadow: 0px 0px 15px -5px #777777;
}
.sec05 .accordion-box .i_area .fix-box01 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.sec05 .accordion-box .i_area .fix-box02 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.sec05 .accordion-box .i_area01 .image {
  display: flex;
  align-items: center;
  width: 45%;
}
.sec05 .accordion-box .i_area01 .image > div {
  width: 100%;
  height: 100%;
}
.sec05 .accordion-box .i_area02 .image {
  display: flex;
  align-items: center;
  width: 20%;
}
.sec05 .accordion-box .i_area02 .image > div {
  width: 100%;
  height: 100%;
}
.sec05 .accordion-box .i_area .image img {
  object-fit: cover;
  font-family: 'object-fit: cover';
  width: 100%;
  height: 100%;
}
.sec05 .accordion-box .i_area02 .image img {
  object-fit: cover;
  font-family: 'object-fit: cover';
  width: 100%;
  height: 100%;
}
.sec05 .accordion-box .i_area01 .txt_box {
  display: flex;
  align-items: center;
  width: 55%;
  padding: 2rem 3rem;
}
.sec05 .accordion-box .i_area02 .txt_box {
  display: flex;
  align-items: center;
  width: 80%;
  padding: 2rem 3rem;
}
.sec05 .accordion-box .i_area .txt_box .t_ttl {
  font-size: 2.3rem;
  font-weight: bold;
}
.sec05 .accordion-box .i_area .txt_box .txt {
  line-height: 1.5;
  font-size: 1.7rem;
  margin-top: 0.6rem;
}
.sec05 .accordion-box .note {
  font-size: 1rem;
  margin-top: 0.4rem;
}
.sec05 .accordion-box .i_area03 {
  margin-top: 2rem;
}
.sec05 .accordion-box .i_ttl {
  font-weight: bold;
  font-size: 3rem;
}
.sec05 .accordion-box .i_area03 .fix-box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  height: 100%;
  margin-top: 1rem;
}
.sec05 .accordion-box .i_area03 .fix-box .i_box {
  background: #fff;
  padding: 1rem 2rem 1.5rem;
  width: 48%;
  box-shadow: 0px 0px 15px -5px #777777;
}
.sec05 .accordion-box .i_area03 .t_ttl {
  font-size: 2.3rem;
  font-weight: bold;
}
.sec05 .accordion-box .i_area03 .t_ttl span {
  font-size: 1rem;
  position: relative;
  top: -1.3rem;
}
.sec05 .accordion-box .i_area03 .txt {
  line-height: 1.5;
  font-size: 1.7rem;
  margin-top: 0.6rem;
}
/*.sec05 .accordion-box .i_area04 .fix-box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 2rem;
}
.sec05 .accordion-box .i_area04 .i_box {
  width: 48%;
}
.sec05 .accordion-box .i_area04 .t_box {
  background: #fff;
  margin-top: 1rem;
  box-shadow: 0px 0px 15px -5px #777777;
}
.sec05 .accordion-box .i_area04 .t_ttl {
  font-size: 2.3rem;
  font-weight: bold;
  padding: 1rem 2rem 0;
}
.sec05 .accordion-box .i_area04 .txt {
  line-height: 1.5;
  font-size: 1.7rem;
  margin-top: 0.6rem;
  padding: 0 2rem 2rem;
}
.sec05 .accordion-box .i_area04 .f_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.sec05 .accordion-box .i_area04 .f_box .image {
  width: 40%;
}
.sec05 .accordion-box .i_area04 .f_box .image img {
  object-fit: cover;
  font-family: 'object-fit: cover';
  height: 290px;
}
.sec05 .accordion-box .i_area04 .f_box .t_area {
  width: 60%;
}
.sec05 .accordion-box .i_area04 .f_box .t_area .txt {
  padding: 0 2rem 0;
}
.sec05 .accordion-box .i_area04 .f_box .t_area .note {
  padding: 0 2rem 2rem;
  line-height: 1.3;
}*/
@media screen and (max-width: 768px) {
  .sec05 .accordion-box .block {
    background: #f5f5f5;
    padding: 3rem 0 2rem;
    margin-top: 4rem;
  }
  .sec05 .accordion-box .block .b_box {
    width: 90%;
    margin: auto;
  }
  .sec05 .accordion-box .b_ttl {
    position: relative;
  }
  .sec05 .accordion-box .b_ttl span {
    font-weight: bold;
    background: #f5f5f5;
    font-size: 2rem;
    color: #9c0008;
    display: inline-block;
    position: relative;
    z-index: 1;
    padding-right: 3rem;
  }
  .sec05 .accordion-box .b_ttl::before {
    display: block;
    content: '';
    position: absolute;
    top: 50%;
    background: #9c0008;
    width: 100%;
    height: 2px;
  }
  .sec05 .accordion-box .i_area {
    background: #fff;
    margin-top: 2rem;
    margin-bottom: 2.5rem;
    box-shadow: 0px 0px 15px -5px #777777;
  }
  .sec05 .accordion-box .i_area .fix-box01 {
    display: block;
  }
  .sec05 .accordion-box .i_area .fix-box02 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .sec05 .accordion-box .i_area01 .image {
    display: block;
    width: 100%;
  }
  .sec05 .accordion-box .i_area02 .image {
    display: flex;
    align-items: center;
    width: 40%;
  }
  .sec05 .accordion-box .i_area01 .txt_box {
    display: block;
    width: 100%;
    padding: 1.5rem 1.5rem;
  }
  .sec05 .accordion-box .i_area02 .txt_box {
    display: flex;
    align-items: center;
    width: 60%;
    padding: 1.5rem 1.5rem;
  }
  .sec05 .accordion-box .i_area .txt_box .t_ttl {
    font-size: 1.7rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .sec05 .accordion-box .i_area .txt_box .txt {
    line-height: 1.5;
    font-size: 1.3rem;
    margin-top: 0.6rem;
  }
  .sec05 .accordion-box .note {
    font-size: 1rem;
    margin-top: 0.4rem;
    line-height: 1.3;
  }
  .sec05 .accordion-box .i_area03 {
    margin-top: 1rem;
  }
  .sec05 .accordion-box .i_ttl {
    font-weight: bold;
    font-size: 2rem;
  }
  .sec05 .accordion-box .i_area03 .fix-box {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
    height: auto;
    margin-top: 1rem;
  }
  .sec05 .accordion-box .i_area03 .fix-box .i_box {
    background: #fff;
    padding: 1.5rem 2rem 1.5rem;
    width: 100%;
    box-shadow: 0px 0px 15px -5px #777777;
    margin-bottom: 2.5rem;
  }
  .sec05 .accordion-box .i_area03 .t_ttl {
    font-size: 1.7rem;
    font-weight: bold;
  }
  .sec05 .accordion-box .i_area03 .t_ttl span {
    font-size: 1rem;
    position: relative;
    top: -1rem;
  }
  .sec05 .accordion-box .i_area03 .txt {
    line-height: 1.5;
    font-size: 1.3rem;
    margin-top: 0.6rem;
  }
  /*.sec05 .accordion-box .i_area04 .fix-box {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 2rem;
  }
  .sec05 .accordion-box .i_area04 .i_box {
    width: 100%;
    margin-bottom: 3rem;
  }
  .sec05 .accordion-box .i_area04 .t_box {
    background: #fff;
    margin-top: 1rem;
    box-shadow: 0px 0px 15px -5px #777777;
  }
  .sec05 .accordion-box .i_area04 .t_ttl {
    font-size: 1.7rem;
    font-weight: bold;
    padding: 1rem 2rem 0;
  }
  .sec05 .accordion-box .i_area04 .txt {
    line-height: 1.5;
    font-size: 1.3rem;
    margin-top: 0.6rem;
    padding: 0 2rem 2rem;
  }
  .sec05 .accordion-box .i_area04 .f_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: inherit;
  }
  .sec05 .accordion-box .i_area04 .f_box .image {
    display: flex;
    align-items: center;
    width: 40%;
  }
  .sec05 .accordion-box .i_area04 .f_box .image div {
    width: 100%;
    height: 100%;
  }
  .sec05 .accordion-box .i_area04 .f_box .image img {
    object-fit: cover;
    font-family: 'object-fit: cover';
    width: 100%;
    height: 100%;
  }
  .sec05 .accordion-box .i_area04 .f_box .t_area {
    display: flex;
    align-items: center;
    width: 60%;
  }
  .sec05 .accordion-box .i_area04 .f_box .t_area .txt {
    padding: 0 2rem 0;
  }
  .sec05 .accordion-box .i_area04 .f_box .t_area .note {
    padding: 0 2rem 2rem;
    line-height: 1.3;
  }
  .sec05 .accordion-box .i_area04 .i_box:nth-child(1) .t_box {
    display: flex;
    justify-content: space-between;
  }
  .sec05 .accordion-box .i_area04 .i_box:nth-child(1) .image {
    display: flex;
    align-items: center;
    width: 40%;
  }
  .sec05 .accordion-box .i_area04 .i_box:nth-child(1) .image div {
    width: 100%;
    height: 100%;
  }
  .sec05 .accordion-box .i_area04 .i_box:nth-child(1) .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .sec05 .accordion-box .i_area04 .i_box:nth-child(1) .t_area {
    display: flex;
    align-items: center;
    width: 60%;
  }*/
}
.sp_block {
  margin-top: -1rem;
  margin-bottom: 4rem;
}
.sp_block .s_txt {
  font-size: 3.5vw;
  text-align: center;
  font-weight: bold;
}
/*--------------------------------------
　voice
---------------------------------------*/
.voice {
  background: #fff2eb;
  padding-bottom: 4rem;
}
.voice .ttl {
  background: #e70312;
  text-align: center;
  font-weight: bold;
  font-size: 4.6rem;
  color: #fff;
  padding: 1rem 0;
}
.voice .note {
  text-align: right;
  color: #333333;
  font-size: 1.4rem;
  margin-top: 3rem;
}
.voice .v_box {
  background: #fff;
  border-radius: 10px;
  padding: 3.5rem 4rem 2rem;
  margin-top: 1rem;
  margin-bottom: 5rem;
}
.voice .v_box .fix_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.voice .v_box .fix_box .image {
  width: 20%;
}
.voice .v_box .text_box {
  width: 76%;
}
.voice .v_box h4 {
  color: #ec6d65;
  font-weight: bold;
  line-height: 1.4;
  font-size: 2.6rem;
}
.voice .v_box .c_txt {
  font-size: 2.1rem;
  font-weight: bold;
  margin-top: 1rem;
  margin-bottom: 1rem;
}
.voice .v_box .bg_txt .clr_txt01 {
  background: #008e6b;
  color: #fff;
  display: inline-block;
  font-weight: bold;
  font-size: 2.3rem;
  line-height: 1;
  border-radius: 10px;
  margin-right: 1rem;
  padding: 0.6rem 2rem;
}
.voice .v_box .bg_txt .clr_txt02 {
  background: #ed9700;
  color: #fff;
  display: inline-block;
  font-weight: bold;
  font-size: 2.3rem;
  line-height: 1;
  border-radius: 10px;
  margin-right: 1rem;
  padding: 0.6rem 2rem;
}
.voice .accordion-content .txt {
  line-height: 1.6;
  margin-bottom: 3rem;
}
.voice .clr02 {
  color: #e70312;
}
.voice .accordion-wrapper {
  width: 100%;
  margin-top: 3rem;
}
/* チェックボックスを非表示 */
.voice .accordion-toggle {
  display: none;
}
/* テキスト部分 */
.voice .accordion-content {
  position: relative;
  overflow: hidden;
  max-height: 3em; /* 1行分 */
  transition: max-height 0.4s ease;
}
/* フェードアウト効果 */
.voice .accordion-content::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3em;
  width: 100%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, white 100%);
  pointer-events: none;
}
/* 展開状態のとき（:checked） */
.voice .accordion-toggle:checked ~ .accordion-content {
  max-height: 1000px; /* 任意の最大高さ */
}
.voice .accordion-toggle:checked ~ .accordion-content::after {
  display: none;
}
/* ボタンの共通スタイル */
.voice .accordion-button {
  display: inline-block;
  margin-top: 0;
  border: solid 2px #ec6d65;
  color: #ec6d65;
  padding: 4px 34px 4px 20px;
  border-radius: 100px;
  cursor: pointer;
  font-size: 18px;
  font-weight: bold;
  position: relative;
}
.accordion-button::after {
  content: "▼"; /* 初期は下矢印 */
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
}
/* デフォルトは「続きを読む」だけ表示 */
.voice .read-more-label, .voice .read-less-label {
  display: none;
}
.button-container {
  text-align: center;
}
/* 「続きを読む」表示（非チェック時） */
.accordion-toggle:not(:checked) ~ .button-container .read-more-label {
  display: inline-block;
}
/* 「閉じる」表示（チェック時） */
.accordion-toggle:checked ~ .button-container .read-less-label {
  display: inline-block;
}
/* 上向き三角に変更 */
.accordion-toggle:checked ~ .button-container .read-less-label::after {
  content: "▲";
}
@media screen and (max-width: 768px) {
  .voice {
    background: #fff2eb;
    padding-bottom: 1rem;
  }
  .voice .ttl {
    background: #e70312;
    text-align: center;
    font-weight: bold;
    font-size: 2.5rem;
    color: #fff;
    padding: 1rem 0;
  }
  .voice .note {
    text-align: right;
    color: #333333;
    font-size: 1rem;
    margin-top: 1rem;
  }
  .voice .v_box {
    background: #fff;
    border-radius: 6px;
    padding: 2rem 2rem 2rem;
    margin-top: 0.6rem;
    margin-bottom: 3rem;
  }
  .voice .v_box .fix_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .voice .v_box .fix_box .image {
    width: 48%;
  }
  .voice .v_box .text_box {
    width: 48%;
  }
  .voice .v_box h4 {
    color: #ec6d65;
    font-weight: bold;
    line-height: 1.4;
    font-size: 2rem;
    text-align: center;
    margin: auto;
    margin-bottom: 1.2rem;
  }
  .voice .v_box .c_txt {
    font-size: 1.6rem;
    font-weight: bold;
    margin-top: 1rem;
    text-align: center;
    line-height: 1.4;
    margin-bottom: 1rem;
  }
  .voice .v_box .bg_txt .clr_txt01 {
    background: #008e6b;
    color: #fff;
    display: inline-block;
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 1;
    border-radius: 6px;
    margin-right: 0;
    padding: 0.6rem 0;
    width: 100%;
    text-align: center;
    margin-bottom: 1rem;
  }
  .voice .v_box .bg_txt .clr_txt02 {
    background: #ed9700;
    color: #fff;
    display: inline-block;
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 1;
    border-radius: 6px;
    margin-right: 0;
    padding: 0.6rem 0;
    width: 100%;
    text-align: center;
  }
  .voice .accordion-content .txt {
    line-height: 1.6;
    margin-bottom: 2rem;
  }
  .voice .clr02 {
    color: #e70312;
  }
  .voice .accordion-wrapper {
    width: 100%;
    margin-top: 1rem;
  }
  /* チェックボックスを非表示 */
  .voice .accordion-toggle {
    display: none;
  }
  /* 展開状態のとき（:checked） */
  .voice .accordion-toggle:checked ~ .accordion-content {
    max-height: 100%; /* 任意の最大高さ */
  }
  /* ボタンの共通スタイル */
  .voice .accordion-button {
    display: inline-block;
    margin-top: 0;
    border: solid 2px #ec6d65;
    color: #ec6d65;
    padding: 4px 34px 4px 20px;
    border-radius: 100px;
    cursor: pointer;
    font-size: 16px;
    font-weight: bold;
    position: relative;
  }
  .accordion-button::after {
    content: "▼"; /* 初期は下矢印 */
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
  }
  /* デフォルトは「続きを読む」だけ表示 */
  .voice .read-more-label, .voice .read-less-label {
    display: none;
  }
  .button-container {
    text-align: center;
  }
  /* 「続きを読む」表示（非チェック時） */
  .accordion-toggle:not(:checked) ~ .button-container .read-more-label {
    display: inline-block;
  }
  /* 「閉じる」表示（チェック時） */
  .accordion-toggle:checked ~ .button-container .read-less-label {
    display: inline-block;
  }
  /* 上向き三角に変更 */
  .accordion-toggle:checked ~ .button-container .read-less-label::after {
    content: "▲";
  }
}
/*--------------------------------------
　sec06
---------------------------------------*/
.sec06 {
  padding: 0 0 4rem;
  background: #cfdff3;
}
.sec06 .ttl {
  background: #004495;
  color: #fff;
  font-weight: bold;
  text-align: center;
  font-size: 2.5rem;
  padding: 0.4rem 0;
  margin-bottom: 2.5rem;
}
.sec06 .cta .ttl {
  font-size: 4.2vw;
  width: 90%;
}
.sec06 ul li {
  background: #fff;
  padding: 2rem 1.5rem 3rem;
  border-radius: 6px;
  position: relative;
}
.sec06 ul li:not(:last-child) {
  margin-bottom: 6rem;
}
.sec06 ul li:not(:last-child):after {
  display: block;
  position: absolute;
  content: "";
  bottom: -43px;
  left: 50%;
  transform: translate(-50%, 0);
  background: #004495;
  height: calc(55px / 2);
  width: 70px;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sec06 ul li .midashi {
  font-size: 4.8vw;
  font-weight: bold;
  text-align: center;
  margin-bottom: 1.2rem;
}
.sec06 ul li .midashi .num {
  width: 30px;
  height: 30px;
  display: table;
  font-size: 4.8vw;
  color: #fff;
  background: #004495;
  border-radius: 50%;
  font-weight: bold;
  text-align: center;
  margin: 0 auto 0.5rem;
  padding-top: 4px;
}
.sec06 ul li .img {
  margin-bottom: 1rem;
}
.sec06 ul .txt {
  line-height: 1.4;
}
.sec06 ul .bg_no {
  background: none;
  padding: 0;
}
.sec06 ul .st_txt {
  text-align: center;
  font-weight: bold;
  color: #004495;
  font-size: 5vw;
  background: #fff;
  border: solid 2px #004495;
  border-radius: 6px;
  padding: 1rem 0;
}
@media screen and (min-width: 768px) {
  .sec06 {
    padding: 0 0 8rem;
  }
  .sec06 .ttl {
    font-size: 4rem;
    padding: 1.4rem 0;
    margin-bottom: 6rem;
  }
  .sec06 ul li {
    padding: 4rem 4rem 4rem;
    border-radius: 10px;
  }
  .sec06 ul li:not(:last-child) {
    margin-bottom: 12rem;
  }
  .sec06 ul li:not(:last-child):after {
    display: block;
    position: absolute;
    content: "";
    bottom: -85px;
    left: 50%;
    transform: translate(-50%, 0);
    background: #004495;
    height: calc(110px / 2);
    width: 130px;
    clip-path: polygon(0 0, 100% 0%, 50% 100%);
  }
  .sec06 ul li .midashi {
    font-size: 3.5rem;
    font-weight: bold;
    text-align: center;
    margin-bottom: 2rem;
  }
  .sec06 ul li .midashi .num {
    width: 60px;
    height: 60px;
    display: table;
    line-height: 55px;
    font-size: 4.2rem;
    color: #fff;
    background: #004495;
    border-radius: 50%;
    font-weight: bold;
    text-align: center;
    margin: 0 auto 0.5rem;
  }
  .sec06 ul li .img {
    margin: 0;
    width: 58%;
  }
  .sec06 ul li .txtbox {
    width: 38%;
  }
  .sec06 ul .fx_box {
    display: flex;
    justify-content: space-between;
  }
  .sec06 ul .txt {
    font-size: 2.5rem !important;
    line-height: 1.5;
  }
  .sec06 ul .bg_no {
    background: none;
    padding: 0;
  }
  .sec06 ul .st_txt {
    text-align: center;
    font-weight: bold;
    color: #004495;
    font-size: 4rem;
    background: #fff;
    border: solid 4px #004495;
    border-radius: 10px;
    padding: 1.2rem 0;
  }
}
/*--------------------------------------
　sec07
---------------------------------------*/
.sec07 .ttl {
  background: #444444;
  color: #fff;
  font-weight: bold;
  text-align: center;
  font-size: 2rem;
  padding: 0.4rem 0;
  margin-bottom: 2.5rem;
}
.sec07 .upper {
  margin-bottom: 2.5rem;
}
.sec07 .link_box {
  background: #f5f5f5;
  padding: 1rem 2rem 0 2rem;
  display: flex;
  flex-wrap: wrap;
  border-radius: 6px;
}
.sec07 .link_box a {
  display: block;
  width: 50%;
  position: relative;
  margin-bottom: 1rem;
  padding-left: 2rem;
}
.sec07 .link_box a:before {
  display: block;
  position: absolute;
  content: "";
  width: 14px;
  height: 14px;
  background: url("img/arrow_02.png") center no-repeat;
  background-size: cover;
  left: 0;
  top: 50%;
  transform: translate(0, -50%);
}
.sec07 .box {
  background: #cfdff3;
  padding: 2rem 1.5rem;
}
.sec07 .box:nth-child(even) {
  background: #f8edef;
}
.sec07 .box .item:not(:last-child) {
  margin-bottom: 2rem;
}
.sec07 .box .midashi {
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 1rem;
}
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  width: 100%;
}
.js-accordion--close {
  display: none;
}
.accordion-box {
  height: 0;
  overflow: hidden;
  transition: .4s ease;
}
.js-accordion {
  position: relative;
}
.js-accordion::before {
  content: "";
  width: 3px;
  height: 16px;
  background: #01519b;
  position: absolute;
  right: 18px;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 2px;
  transition: .6s ease;
}
.js-accordion::after {
  content: "";
  width: 16px;
  height: 3px;
  background: #01519b;
  position: absolute;
  border-radius: 2px;
  right: 11px;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: .6s ease;
}
.js-accordion.is-accordion--open::before {
  transform: rotate(90deg);
}
.js-accordion.is-accordion--open::after {
  transform: rotate(-180deg);
}
.js-accordion.is-accordion--open + .accordion-box {
  height: auto;
  display: block;
}
.sec07 .js-accordion > div {
  padding: 0 35px 0 10px;
  padding: 1rem 6rem 1rem 5rem;
  text-align: left;
  background: #f5f5f5;
  border-radius: 6px;
}
.sec07 .js-accordion.is-accordion--open > div {
  border-radius: 6px 6px 0 0;
}
.sec07 .js-accordion {
  color: #000!important;
}
.sec07 .js-accordion > div p {
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1.4;
  color: #000!important;
}
.sec07 .js-accordion > div:before {
  display: block;
  position: absolute;
  content: "Q";
  color: #01519b;
  font-weight: bold;
  font-size: 2.6rem;
  background-size: cover;
  left: 1.5rem;
  top: 50%;
  transform: translate(0, -50%);
}
.sec07 .accordion-box {
  background: #fff;
  border-radius: 0 0 6px 6px;
}
.sec07 .accordion-box div {
  padding: 1.5rem 1.5rem 1.5rem 5rem;
  position: relative;
}
.sec07 .accordion-box div:before {
  display: block;
  position: absolute;
  content: "A";
  font-size: 2.2rem;
  background-size: cover;
  left: 2rem;
  top: 1.5rem;
}
.sec07 .cover {
  padding: 4rem 1.5rem;
}
.sec07 .cover .under_ttl {
  font-size: 2rem;
  text-align: center;
  font-weight: bold;
}
.sec07 .cover .upper {
  margin-bottom: 6rem;
}
.c_blue {
  color: #01519b;
}
.sec07 .sub2 {
  font-size: 1rem;
  color: #333;
  line-height: 1.3;
}
.sec07 .txt_link a {
  color: #366ea9;
  position: relative;
  display: inline-block;
  text-decoration: underline;
  font-size: 1.4rem;
  padding-left: 1.4rem;
}
.sec07 .txt_link a::after {
  display: block;
  position: absolute;
  content: "";
  background: url("img/arrow04.png") center no-repeat;
  background-size: 100% auto;
  width: 8px;
  height: 16px;
  top: 4px;
  left: 0;
}
@media screen and (min-width: 768px) {
  .sec07 .ttl {
    font-size: 4rem;
    padding: 1rem 0;
    margin-bottom: 4rem;
  }
  .sec07 .upper {
    margin-bottom: 5rem;
  }
  .sec07 .link_box {
    background: #f5f5f5;
    padding: 4rem 4rem 0 4rem;
    display: flex;
    flex-wrap: wrap;
    border-radius: 10px;
  }
  .sec07 .link_box a {
    display: block;
    width: 33%;
    position: relative;
    margin-bottom: 3rem;
    padding-left: 3rem;
    font-size: 2rem;
  }
  .sec07 .link_box a:before {
    display: block;
    position: absolute;
    content: "";
    width: 24px;
    height: 24px;
    background: url("img/arrow_02.png") center no-repeat;
    background-size: cover;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
  }
  .sec07 .box {
    background: #cfdff3;
    padding: 3rem 4rem 4rem;
  }
  .sec07 .box:nth-child(even) {
    background: #f8edef;
  }
  .sec07 .box .item:not(:last-child) {
    margin-bottom: 4rem;
  }
  .sec07 .box .midashi {
    text-align: center;
    font-weight: bold;
    font-size: 3.5rem;
    margin-bottom: 3rem;
  }
  .sec07 .box .item {
    width: 920px;
    margin: auto;
    box-sizing: border-box;
  }
  button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
    width: 100%;
  }
  .js-accordion--close {
    display: none;
  }
  .accordion-box {
    height: 0;
    overflow: hidden;
    transition: .4s ease;
  }
  .js-accordion {
    position: relative;
  }
  .js-accordion::before {
    content: "";
    width: 4px;
    height: 32px;
    background: #01519b;
    position: absolute;
    right: 37px;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: .6s ease;
    border-radius: 2px;
  }
  .js-accordion::after {
    content: "";
    width: 32px;
    height: 4px;
    background: #01519b;
    position: absolute;
    right: 22px;
    border-radius: 2px;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: .6s ease;
  }
  .js-accordion.is-accordion--open::before {
    transform: rotate(90deg);
  }
  .js-accordion.is-accordion--open::after {
    transform: rotate(-180deg);
  }
  .js-accordion.is-accordion--open + .accordion-box {
    height: auto;
    display: block;
  }
  .sec07 .js-accordion > div {
    padding: 2rem 12rem 2rem 7rem;
    text-align: left;
    background: #f5f5f5;
    border-radius: 10px;
  }
  .sec07 .js-accordion.is-accordion--open > div {
    border-radius: 10px 10px 0 0;
  }
  .sec07 .js-accordion > div p {
    font-weight: bold;
    font-size: 2.4rem;
  }
  .sec07 .js-accordion > div:before {
    display: block;
    position: absolute;
    content: "Q";
    color: #01519b;
    font-weight: 500;
    font-size: 3.5rem;
    background-size: cover;
    left: 3rem;
    top: 50%;
    transform: translate(0, -50%);
  }
  .sec07 .accordion-box {
    background: #fff;
    border-radius: 0 0 10px 10px;
  }
  .sec07 .accordion-box div {
    padding: 2rem 4rem 2rem 7.4rem;
    position: relative;
  }
  .sec07 .accordion-box div:before {
    display: block;
    position: absolute;
    content: "A";
    font-size: 2.6rem;
    background-size: cover;
    left: 4rem;
    top: 2.8rem;
  }
  .sec07 .cover {
    padding: 8rem 3rem;
  }
  .sec07 .cover .under_ttl {
    font-size: 4.4rem;
  }
  .sec07 .cover .upper {
    margin-bottom: 12rem;
  }
  .sec07 .txt_link a {
    color: #366ea9;
    position: relative;
    display: inline-block;
    text-decoration: underline;
    font-size: 1.7rem;
    padding-left: 2rem;
  }
  .sec07 .txt_link a::after {
    display: block;
    position: absolute;
    content: "";
    background: url("img/arrow04.png") center no-repeat;
    background-size: 100% auto;
    width: 11px;
    height: 20px;
    top: 4px;
    left: 0;
  }
}
/*--------------------------------------
　モーダル
---------------------------------------*/
.modal-open {}
/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 50%);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 999 !important;
}
/*モーダル本体の擬似要素の指定*/
.modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
  z-index: 999;
}
/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active {
  opacity: 1;
  visibility: visible;
}
/*モーダル枠の指定*/
.modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 500px;
  width: 90%;
}
/*モーダルを閉じるボタンの指定*/
.modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -40px;
  right: -40px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #fff;
  cursor: pointer;
}
/*モーダル内のコンテンツの指定*/
.modal-content {
  background: #fff;
  text-align: left;
  padding: 20px;
}
.modal-content .box_02 {
  background: #f1f1f1;
  padding: 2rem;
  border-radius: 10px;
  margin-top: 2rem;
}
.modal-content .box_02 .m_img02 {
  width: 80%;
  margin: 0 auto 1rem;
}
.modal-content .m_ttl {
  font-size: 2rem;
  text-align: center;
  font-weight: bold;
  margin-bottom: 2rem;
}
.ta_center {
  text-align: center;
}
.ta_right {
  text-align: right;
}
.modal-content .txt_01 {
  font-size: 1.5rem;
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .modal-open {}
  /*モーダル本体の指定 + モーダル外側の背景の指定*/
  .modal-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    background: rgba(0, 0, 0, 50%);
    padding: 40px 20px;
    overflow: auto;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
    box-sizing: border-box;
    z-index: 999 !important;
  }
  /*モーダル本体の擬似要素の指定*/
  .modal-container:before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    height: 100%;
    z-index: 999;
  }
  /*モーダル本体に「active」クラス付与した時のスタイル*/
  .modal-container.active {
    opacity: 1;
    visibility: visible;
  }
  /*モーダル枠の指定*/
  .modal-body {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    max-width: 650px;
    width: 90%;
  }
  /*モーダルを閉じるボタンの指定*/
  .modal-close {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    top: -40px;
    right: -40px;
    width: 40px;
    height: 40px;
    font-size: 40px;
    color: #fff;
    cursor: pointer;
  }
  /*モーダル内のコンテンツの指定*/
  .modal-content {
    background: #fff;
    text-align: left;
    padding: 30px;
  }
  .modal-content .box_02 {
    background: #f1f1f1;
    padding: 2rem;
    border-radius: 10px;
    margin-top: 2rem;
  }
  .modal-content .box_02 .m_img02 {
    width: 80%;
    margin: 0 auto 1rem;
  }
  .modal-content .m_ttl {
    font-size: 2.8rem;
    text-align: center;
    font-weight: bold;
    margin-bottom: 2rem;
  }
  .ta_center {
    text-align: center;
  }
  .ta_right {
    text-align: right;
  }
  .modal-content .txt_01 {
    font-size: 1.4rem;
    margin-top: 1rem;
  }
}