@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 h2 {
  padding-top: 2.8125rem;
  padding-bottom: 3.125rem;
}
@media only screen and (max-width: 767px) {
  .kv h2 {
    padding-top: 2.8571428571rem;
    padding-bottom: 2.1428571429rem;
    text-align: center;
  }
}
.kv h2 .ttl {
  width: 10.0625rem;
  margin-top: -4.375rem;
}
@media only screen and (max-width: 767px) {
  .kv h2 .ttl {
    width: 7.4285714286rem;
    margin-left: auto;
    margin-right: auto;
  }
}
.kv .breadcrumbs {
  padding-top: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .kv .breadcrumbs {
    padding-top: 2.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;
}

/*  news_content
-------------------------------------------------*/
.news_content .news_cat_wrap {
  margin-bottom: 3.75rem;
}
@media only screen and (max-width: 767px) {
  .news_content .news_cat_wrap {
    margin-bottom: 2.1428571429rem;
  }
}
@media only screen and (max-width: 767px) {
  .news_content .news_cat_wrap .news_cat_pc {
    display: none;
  }
}
.news_content .news_cat_wrap .news_cat_pc ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border-bottom: 1px solid #CDC8CB;
}
.news_content .news_cat_wrap .news_cat_pc ul li {
  width: 25%;
}
.news_content .news_cat_wrap .news_cat_pc ul li a {
  font-size: 1.125rem;
  font-weight: 700;
  color: #04183D;
  display: block;
  padding-bottom: 1.25rem;
  text-align: center;
  position: relative;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.news_content .news_cat_wrap .news_cat_pc ul li a:after {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  content: "";
  width: 100%;
  height: 0.1875rem;
  background-color: #04183D;
  position: absolute;
  bottom: -0.125rem;
  left: 0;
  opacity: 0;
}
.news_content .news_cat_wrap .news_cat_pc ul li a:hover {
  opacity: 0.8;
}
.news_content .news_cat_wrap .news_cat_pc ul li a.is-current:after {
  opacity: 1;
}
@media print, screen and (min-width: 768px) {
  .news_content .news_cat_wrap .news_cat_sp {
    display: none;
  }
}
.news_content .news_cat_wrap .news_cat_sp select {
  border: 1px solid #CDC8CB;
  border-radius: 0.2857142857rem;
  font-size: 0.9285714286rem;
  font-weight: 700;
  padding: 1.4285714286rem;
  width: 100%;
  background: url(../img/news/select.svg) right 1.4285714286rem center no-repeat;
  background-size: 0.5714285714rem auto;
}
.news_content .news_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 768px) {
  .news_content .news_list {
    margin-left: -2.5rem;
    margin-top: -2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .news_content .news_list {
    margin-top: -1.4285714286rem;
  }
}
.news_content .news_list li {
  width: calc(33.333% - 2.5rem);
}
@media print, screen and (min-width: 768px) {
  .news_content .news_list li {
    margin-left: 2.5rem;
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .news_content .news_list li {
    width: 100%;
    margin-top: 1.4285714286rem;
  }
}
.news_content .news_list li a {
  background: #F2F3F5;
  border-radius: 1.25rem;
  overflow: hidden;
  display: block;
  height: 100%;
  border: 1px solid #F2F3F5;
  position: relative;
}
.news_content .news_list li a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(4, 24, 61, 0.05);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 0;
}
.news_content .news_list li a .thum {
  overflow: hidden;
}
.news_content .news_list li a .news_dc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 1.25rem 1.875rem;
}
@media only screen and (max-width: 767px) {
  .news_content .news_list li a .news_dc {
    padding: 1.4285714286rem 1.4285714286rem 1.0714285714rem;
  }
}
.news_content .news_list li a .date {
  display: inline-block;
  color: #7C777A;
  letter-spacing: 0.08em;
  font-weight: 700;
}
@media print, screen and (min-width: 768px) {
  .news_content .news_list li a .date {
    font-size: 0.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .news_content .news_list li a .date {
    font-size: 0.8571428571rem;
  }
}
.news_content .news_list li a .cat {
  display: inline-block;
  color: #7C777A;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.375rem 0.625rem;
  border: 1px solid #CDC8CB;
  border-radius: 0.25rem;
}
@media only screen and (max-width: 767px) {
  .news_content .news_list li a .cat {
    font-size: 0.8571428571rem;
    padding: 0.4285714286rem 0.7142857143rem;
    border-radius: 0.2857142857rem;
  }
}
.news_content .news_list li a p {
  line-height: 1.5;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  color: #04183D;
  font-size: 1rem;
  letter-spacing: 0.08em;
  padding: 0 1.875rem 1.875rem;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .news_content .news_list li a p {
    font-size: 1.1428571429rem;
    padding: 0 1.4285714286rem 2.1428571429rem;
  }
}
@media print, screen and (min-width: 768px) {
  .news_content .news_list li a:hover:before {
    opacity: 1;
  }
  .news_content .news_list li a:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

/*  ページャー
-------------------------------------------------*/
.nav-links {
  margin-top: 5rem;
  padding-bottom: 1.25rem;
}
@media only screen and (max-width: 767px) {
  .nav-links {
    margin-top: 4.2857142857rem;
    padding-bottom: 0.3571428571rem;
  }
}
.nav-links .page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 768px) {
  .nav-links .page-numbers li a.page-numbers:hover {
    color: #fff;
    background-color: #04183D;
    border-color: #04183D;
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
}
.nav-links .page-numbers li .page-numbers {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.25rem;
  font-weight: 500;
  font-family: "Baloo Tamma 2", system-ui;
  color: #04183D;
  border: 1px solid #CDC8CB;
  margin: 0 0.25rem;
  line-height: 3.125rem;
}
@media only screen and (max-width: 767px) {
  .nav-links .page-numbers li .page-numbers {
    width: 2.8571428571rem;
    height: 2.8571428571rem;
    font-size: 1.1428571429rem;
    margin: 0 0.3571428571rem;
    line-height: 2.9285714286rem;
  }
}
.nav-links .page-numbers li .current {
  background: #F2F3F5;
  border-color: #F2F3F5;
}
.nav-links .page-numbers li .dots {
  border: none;
  margin: 0;
  width: 3.125rem;
}
@media only screen and (max-width: 767px) {
  .nav-links .page-numbers li .dots {
    width: 1.0714285714rem;
  }
}
.nav-links .page-numbers li .prev {
  font-size: 0;
  border: none;
  background: url(../img/news/pager.svg) no-repeat center top/cover;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
  margin-right: 0.75rem;
}
@media print, screen and (min-width: 768px) {
  .nav-links .page-numbers li .prev:hover {
    -webkit-transform: scale(-1.25, 1.25) !important;
            transform: scale(-1.25, 1.25) !important;
  }
}
@media only screen and (max-width: 767px) {
  .nav-links .page-numbers li .prev {
    margin-right: 0.3571428571rem;
  }
}
.nav-links .page-numbers li .next {
  font-size: 0;
  border: none;
  background: url(../img/news/pager.svg) no-repeat center top/cover;
  margin-left: 0.75rem;
}
@media only screen and (max-width: 767px) {
  .nav-links .page-numbers li .next {
    margin-left: 0.3571428571rem;
  }
}

/*  お問い合わせ
-------------------------------------------------*/
#contact_bnr {
  background: #fff;
  padding: 5rem 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;
  }
}