@charset "UTF-8";
@-webkit-keyframes circlemovePC {
  0% {
    bottom: 2.5rem;
  }
  100% {
    bottom: -0.3125rem;
  }
}
@keyframes circlemovePC {
  0% {
    bottom: 2.5rem;
  }
  100% {
    bottom: -0.3125rem;
  }
}
@-webkit-keyframes circlemoveSP {
  0% {
    bottom: 2.8571428571rem;
  }
  100% {
    bottom: -0.3571428571rem;
  }
}
@keyframes circlemoveSP {
  0% {
    bottom: 2.8571428571rem;
  }
  100% {
    bottom: -0.3571428571rem;
  }
}
@-webkit-keyframes cirlemovehide {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    opacity: 0;
  }
}
@keyframes cirlemovehide {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes loadAnim {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes loadAnim {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
/*  KV
-------------------------------------------------*/
.kv {
  width: 100%;
  padding-top: 2.8125rem;
}
@media only screen and (max-width: 767px) {
  .kv {
    padding-top: 1.0714285714rem;
  }
}
.kv .kv_ttl {
  padding-top: 2.25rem;
  padding-bottom: 5.625rem;
}
@media only screen and (max-width: 767px) {
  .kv .kv_ttl {
    padding-top: 2.1428571429rem;
    padding-bottom: 2.1428571429rem;
  }
}
.kv .kv_ttl .date {
  display: inline-block;
  color: #7C777A;
  font-weight: 700;
  font-family: "BIZ UDPGothic", sans-serif;
}
@media print, screen and (min-width: 768px) {
  .kv .kv_ttl .date {
    font-size: 1.125rem;
  }
}
@media only screen and (max-width: 767px) {
  .kv .kv_ttl .date {
    font-size: 0.8571428571rem;
  }
}
.kv .kv_ttl .cat {
  display: inline-block;
  color: #7C777A;
  font-size: 1rem;
  font-weight: 700;
  padding: 0.375rem 0.625rem;
  margin-left: 1rem;
  border: 1px solid #CDC8CB;
  border-radius: 0.25rem;
}
@media only screen and (max-width: 767px) {
  .kv .kv_ttl .cat {
    font-size: 0.8571428571rem;
    padding: 0.4285714286rem 0.7142857143rem;
    margin-left: 0.9285714286rem;
    border-radius: 0.2857142857rem;
  }
}
.kv .kv_ttl h2 {
  font-family: "BIZ UDPGothic", sans-serif;
  line-height: 1.5;
  color: #04183D;
  font-size: 2.25rem;
  font-weight: 700;
  display: block;
  letter-spacing: 0.04em;
  margin-top: 1.25rem;
}
@media only screen and (max-width: 767px) {
  .kv .kv_ttl h2 {
    font-size: 1.2857142857rem;
    margin-top: 1.1428571429rem;
  }
}
.kv .breadcrumbs ul li {
  display: inline;
  color: #A49FA2;
  font-size: 0.75rem;
  margin-right: 0.625rem;
}
@media only screen and (max-width: 767px) {
  .kv .breadcrumbs ul li {
    font-size: 0.7857142857rem;
    margin-right: 0.7142857143rem;
  }
}
.kv .breadcrumbs ul li:after {
  content: "";
  width: 0.4375rem;
  height: 0.75rem;
  background: url(../img/news/arrow.svg) no-repeat center top/cover;
  background-size: 100% auto;
  display: inline-block;
  margin-left: 0.625rem;
}
@media only screen and (max-width: 767px) {
  .kv .breadcrumbs ul li:after {
    width: 0.5rem;
    height: 0.8571428571rem;
    margin-left: 0.7142857143rem;
  }
}
.kv .breadcrumbs ul li:last-child {
  margin-right: 0;
}
.kv .breadcrumbs ul li:last-child:after {
  display: none;
}
.kv .breadcrumbs ul li a {
  color: #04183D;
}
.kv .breadcrumbs ul li a:hover {
  text-decoration: underline;
}

/*  editor
-------------------------------------------------*/
.editor {
  padding: 5rem 0 0;
  position: relative;
  z-index: 2;
  border-top: 1px solid #CDC8CB;
  /* youtube */
}
@media only screen and (max-width: 767px) {
  .editor {
    padding: 2.8571428571rem 0 0;
  }
}
.editor > div {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .editor > div {
    margin-bottom: 4.2857142857rem;
  }
}
.editor h3 {
  font-size: 2rem;
  line-height: 1.6875;
  font-weight: 700;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .editor h3 {
    font-size: 1.7142857143rem;
    line-height: 1.5;
    margin-bottom: 2.1428571429rem;
  }
}
.editor h4 {
  font-size: 1.5rem;
  line-height: 1.75;
  font-weight: 700;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .editor h4 {
    font-size: 1.2857142857rem;
    line-height: 1.5;
    margin-bottom: 2.1428571429rem;
  }
}
.editor p {
  font-size: 1.125rem;
  line-height: 2;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .editor p {
    font-size: 1rem;
    margin-bottom: 2.8571428571rem;
  }
}
.editor a {
  color: #0D54D3;
  text-decoration: underline;
}
.editor .arrow:after {
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  background: url(../img/arrow_bk.svg) no-repeat center center/contain;
  display: inline-block;
  margin-bottom: -0.25rem;
  margin-left: 0.25rem;
}
@media only screen and (max-width: 767px) {
  .editor .arrow:after {
    width: 1.1428571429rem;
    height: 1.1428571429rem;
    margin-bottom: -0.2857142857rem;
    margin-left: 0.2857142857rem;
  }
}
.editor ul li {
  font-size: 1.125rem;
  line-height: 2;
  padding-left: 0.9375rem;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .editor ul li {
    font-size: 1rem;
    padding-left: 0.8571428571rem;
  }
}
.editor ul li:before {
  content: "";
  width: 0.25rem;
  height: 0.25rem;
  /*background-color:#DB0995;*/
  background: #04183D;
  border-radius: 50%;
  position: absolute;
  top: 0.9375rem;
  left: 0.125rem;
}
@media only screen and (max-width: 767px) {
  .editor ul li:before {
    width: 0.2857142857rem;
    height: 0.2857142857rem;
    top: 0.7857142857rem;
    left: 0;
  }
}
@media only screen and (max-width: 767px) {
  .editor .scroll_container {
    margin-right: -2.1428571429rem;
    padding-right: 2.1428571429rem;
  }
}
.editor table {
  width: 100%;
  font-size: 1.125rem;
  line-height: 2;
  border-spacing: 0;
}
@media only screen and (max-width: 767px) {
  .editor table {
    font-size: 1rem;
    width: 64rem;
  }
}
.editor table thead tr:first-of-type th, .editor table thead tr:first-of-type td {
  border-top: 1px solid #CDC8CB;
}
.editor table thead tr:first-of-type th:first-of-type,
.editor table thead tr:first-of-type td:first-of-type {
  border-radius: 1.25rem 0 0 0;
  border-left: 1px solid #CDC8CB;
  width: 21%;
}
@media only screen and (max-width: 767px) {
  .editor table thead tr:first-of-type th:first-of-type,
  .editor table thead tr:first-of-type td:first-of-type {
    border-radius: 1.4285714286rem 0 0 0;
  }
}
.editor table thead tr:first-of-type th:last-of-type,
.editor table thead tr:first-of-type td:last-of-type {
  border-radius: 0 1.25rem 0 0;
}
@media only screen and (max-width: 767px) {
  .editor table thead tr:first-of-type th:last-of-type,
  .editor table thead tr:first-of-type td:last-of-type {
    border-radius: 0 1.4285714286rem 0 0;
  }
}
.editor table tbody tr:last-of-type th:first-of-type,
.editor table tbody tr:last-of-type td:first-of-type {
  border-radius: 0 0 0 1.25rem;
}
@media only screen and (max-width: 767px) {
  .editor table tbody tr:last-of-type th:first-of-type,
  .editor table tbody tr:last-of-type td:first-of-type {
    border-radius: 0 0 0 1.4285714286rem;
  }
}
.editor table tbody tr:last-of-type th:last-of-type,
.editor table tbody tr:last-of-type td:last-of-type {
  border-radius: 0 0 1.25rem 0;
}
@media only screen and (max-width: 767px) {
  .editor table tbody tr:last-of-type th:last-of-type,
  .editor table tbody tr:last-of-type td:last-of-type {
    border-radius: 0 0 1.4285714286rem 0;
  }
}
.editor table th {
  color: #fff;
  background-color: #04183D;
  font-weight: 700;
  padding: 1.875rem 2.5rem;
  text-align: center;
  border-bottom: 1px solid #CDC8CB;
  border-right: 1px solid #CDC8CB;
  vertical-align: middle;
}
@media only screen and (max-width: 767px) {
  .editor table th {
    padding: 1.7142857143rem 2rem;
  }
}
.editor table td {
  padding: 1.875rem 2.5rem;
  border-bottom: 1px solid #CDC8CB;
  border-right: 1px solid #CDC8CB;
  vertical-align: middle;
}
@media only screen and (max-width: 767px) {
  .editor table td {
    padding: 1.7142857143rem 2rem;
  }
}
.editor table td:first-of-type {
  background: #F2F3F5;
  text-align: center;
  border-left: 1px solid #CDC8CB;
}
.editor .is-provider-youtube .wp-block-embed__wrapper {
  width: 100%;
  aspect-ratio: 16/9;
}
.editor .is-provider-youtube iframe {
  width: 100%;
  height: 100%;
}
.editor .movie p {
  margin-top: 1.5rem;
  font-size: 1rem;
  text-align: center;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .editor .movie p {
    margin-top: 0.7142857143rem;
    font-size: 0.9285714286rem;
    line-height: 1.6153846154;
  }
}
@media only screen and (max-width: 767px) {
  .editor .photo {
    margin-bottom: 2.8571428571rem;
  }
}
@media print, screen and (min-width: 768px) {
  .editor .photo_02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media print, screen and (min-width: 768px) {
  .editor .photo_02 .wp-block-column {
    width: calc(50% - 2.5rem);
  }
}
@media only screen and (max-width: 767px) {
  .editor .photo_02 .wp-block-column + .wp-block-column {
    margin-top: 2.8571428571rem;
  }
}
.editor .photo img {
  width: 100%;
  height: auto;
}
.editor .photo figcaption {
  margin-top: 1.5rem;
  font-size: 1rem;
  text-align: center;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .editor .photo figcaption {
    margin-top: 0.7142857143rem;
    font-size: 0.9285714286rem;
    line-height: 1.6153846154;
  }
}
.editor .wp-block-embed-youtube figcaption,
.editor .wp-block-image figcaption {
  margin-top: 1.5rem;
  font-size: 1rem;
  text-align: center;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .editor .wp-block-embed-youtube figcaption,
  .editor .wp-block-image figcaption {
    margin-top: 0.7142857143rem;
    font-size: 0.9285714286rem;
    line-height: 1.6153846154;
  }
}
.editor .wp-block-image {
  text-align: center;
}
.editor .wp-block-image img {
  max-width: 100%;
  height: auto;
}
@media only screen and (max-width: 767px) {
  .editor .wp-block-image img {
    width: 100%;
  }
}
.editor figure + p {
  margin-top: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .editor figure + p {
    margin-top: 2.1428571429rem;
  }
}

/*  backbtn
-------------------------------------------------*/
.backbtn {
  margin-top: 7.5rem;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .backbtn {
    margin-top: 4.2857142857rem;
    margin-bottom: 2.1428571429rem;
  }
}
.backbtn a {
  display: block;
  width: 20rem;
  height: 4.375rem;
  line-height: 4.375rem;
  border-radius: 2.1875rem;
  color: #04183D;
  border: 1px solid #04183D;
  font-size: 1.125rem;
  font-weight: 700;
  padding-left: 5.25rem;
  position: relative;
  z-index: 2;
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .backbtn a {
    width: 22.5rem;
    height: 4.2857142857rem;
    line-height: 4.2857142857rem;
    border-radius: 2.1428571429rem;
    font-size: 1.1428571429rem;
    padding-left: 5.7142857143rem;
  }
}
.backbtn a::after {
  position: absolute;
  content: "";
  width: 1.875rem;
  height: 1.875rem;
  background: url(../img/arrow_bk.svg) no-repeat center center/contain;
  left: 1.25rem;
  top: 50%;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: translateY(-50%) scale(-1, 1);
          transform: translateY(-50%) scale(-1, 1);
}
@media only screen and (max-width: 767px) {
  .backbtn a::after {
    width: 2.1428571429rem;
    height: 2.1428571429rem;
    left: 1.0714285714rem;
  }
}
@media print, screen and (min-width: 768px) {
  .backbtn a:hover::after {
    left: 0.9375rem;
  }
}

/*  お問い合わせ
-------------------------------------------------*/
#contact_bnr {
  background: #fff;
  padding: 6.25rem 0 7.875rem;
  position: relative;
}
@media only screen and (max-width: 767px) {
  #contact_bnr {
    padding: 5rem 0 4.2857142857rem;
  }
}
#contact_bnr::before, #contact_bnr::after {
  position: absolute;
  content: "";
}
#contact_bnr::before {
  background: url(../img/contact_bg-01_pc.svg) no-repeat left top/contain;
  width: 25rem;
  height: 27.25rem;
  left: 0;
  top: 0;
}
@media only screen and (max-width: 767px) {
  #contact_bnr::before {
    background-image: url(../img/contact_bg-01_sp.svg);
    width: 11.9285714286rem;
    height: 11rem;
  }
}
#contact_bnr::after {
  background: url(../img/contact_bg-02_pc.svg) no-repeat right bottom/contain;
  width: 25rem;
  height: 27.75rem;
  right: 0;
  bottom: 0;
}
@media only screen and (max-width: 767px) {
  #contact_bnr::after {
    background-image: url(../img/contact_bg-02_sp.svg);
    width: 11.9285714286rem;
    height: 11.2857142857rem;
  }
}
#contact_bnr a {
  height: 18.75rem;
  border-radius: 2.5rem;
  background: #04183D;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 2;
  padding: 0 10rem 0 7.5rem;
  -webkit-box-shadow: 0 0 3.125rem rgba(4, 24, 61, 0.2);
          box-shadow: 0 0 3.125rem rgba(4, 24, 61, 0.2);
  width: 88.8888888889vw;
  max-width: 1280px;
  margin: auto;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  #contact_bnr a {
    height: 18.5714285714rem;
    border-radius: 1.4285714286rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2.8571428571rem 0;
    -webkit-box-shadow: 0 0 3.5714285714rem rgba(4, 24, 61, 0.2);
            box-shadow: 0 0 3.5714285714rem rgba(4, 24, 61, 0.2);
    width: 94.6666666667%;
    max-width: 94.6666666667vw;
  }
}
#contact_bnr a::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  background: url(../img/contact_hover.svg) no-repeat left top/contain #092964;
  left: 0;
  top: 0;
  opacity: 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#contact_bnr a h2 {
  color: rgba(255, 255, 255, 0.1);
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  #contact_bnr a h2 {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media print, screen and (min-width: 768px) {
  #contact_bnr a h2 .ttl {
    width: 15.5rem;
    margin-top: -5rem;
  }
}
@media only screen and (max-width: 767px) {
  #contact_bnr a h2 .ttl {
    width: 14.1428571429rem;
  }
}
#contact_bnr a p {
  color: #fff;
  font-size: 1.125rem;
  font-weight: 700;
  padding-right: 3.75rem;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  #contact_bnr a p {
    font-size: 1rem;
    line-height: 1.5;
    padding-right: 4.2857142857rem;
  }
}
#contact_bnr a p::after {
  position: absolute;
  content: "";
  width: 2.5rem;
  height: 2.5rem;
  background: url(../img/arrow.svg) no-repeat center center/contain;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media only screen and (max-width: 767px) {
  #contact_bnr a p::after {
    width: 2.8571428571rem;
    height: 2.8571428571rem;
  }
}
@media print, screen and (min-width: 768px) {
  #contact_bnr a:hover::after {
    opacity: 1;
  }
  #contact_bnr a:hover p::after {
    right: -0.625rem;
  }
}