@charset "UTF-8";

/* ********** TOP ********** */

/* ---------- visual ---------- */

section#top .visual_sp {
  display: none;
}
section#top .visual {
  width: 100%;
  margin: 0 0 30px 0;
  overflow: hidden;
}
section#top .visual {
  margin: 0 0 60px 0;
  background: #0071f1;
  position: relative;
}
section#top .visual::before {
  content: "";
  width: 50%;
  height: 100%;
  background: #0052d1;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
section#top .visual::after {
  content: "";
  width: 50%;
  height: 100%;
  background: #288eff;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}
section#top .visual .accordion {
  container-type: inline-size;
  width: 100%;
  max-width: 1800px;
  height: 350px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  pointer-events: none;
}
section#top .visual .accordion.active {
  pointer-events: auto;
}
section#top .visual .accordion ul {
  width: calc(100% + 400px);
  height: 100%;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}
section#top .visual .accordion ul li {
  height: 100%;
  color: #fff;
  transition: .3s;
}
section#top .visual .accordion ul li:nth-child(1) {
  width: 33.33%;
  background: #0052d1;
  clip-path: polygon(0 0, 100% 0, calc(100% - 200px) 100%, 0% 100%);
}
section#top .visual .accordion ul li:nth-child(2) {
  width: 33.33%;
  padding: 0 2.5cqw;
  background: #0071f1;
  clip-path: polygon(200px 0, 100% 0, calc(100% - 200px) 100%, 0% 100%);
  transform: translate(-200px, 0);
}
section#top .visual .accordion ul li:nth-child(3) {
  width: 33.33%;
  background: #288eff;
  clip-path: polygon(200px 0, 100% 0, 100% 100%, 0% 100%);
  transform: translate(-400px, 0);
}
section#top .visual .accordion ul:hover li {
  padding: 0 30px;
}
section#top .visual .accordion ul:hover li:nth-child(2) {
  padding: 0 50px;
}
@media screen and (max-width: 1500px) {
  section#top .visual .accordion ul:hover li:nth-child(2) {
    padding: 0 70px;
  }
}
@media screen and (max-width: 1300px) {
  section#top .visual .accordion ul:hover li:nth-child(2) {
    padding: 0 90px;
  }
}
@media screen and (max-width: 1100px) {
  section#top .visual .accordion ul:hover li:nth-child(2) {
    padding: 0 110px;
  }
}
section#top .visual .accordion ul:hover li:nth-child(1):hover {
  width: 200%;
}
section#top .visual .accordion ul:hover li:nth-child(2):hover {
  width: 200%;
}
section#top .visual .accordion ul:hover li:nth-child(3):hover {
  width: 200%;
}
section#top .visual .accordion ul li .content {
  width: 100%;
  height: 100%;
}
section#top .visual .accordion ul li .content a {
  width: calc(100% + 200px);
  height: 100%;
  color: #fff;
  text-decoration: none;
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transition: all 200ms ease;
}
section#top .visual .accordion ul li .content a:hover {
  opacity: 1;
}
section#top .visual .accordion ul li:nth-child(1) .content a {
  transform: translate(-120px,0);
}
section#top .visual .accordion ul li:nth-child(2) .content a {
  transform: translate(-100px,0);
}
section#top .visual .accordion ul li:nth-child(3) .content a {
  transform: translate(-80px,0);
}
section#top .visual .accordion ul li .content a .lead h2 {
  margin: 0 0 1.3cqw 0;
  font-size: 1.4cqw;
  font-weight: 600;
  text-align: center;
  line-height: 1.5em;
}
section#top .visual .accordion ul li .content a .lead p {
  padding: 0 3%;
}
section#top .visual .accordion ul li .content a .lead img {
  width: auto;
  height: 2.8cqw;
}
section#top .visual .accordion ul li .content a .logo {
  display: none;
  width: 225px;
  position: absolute;
  top: 50%;
}
section#top .visual .accordion ul li:nth-child(1) .content a .logo {
  right: 0;
  transform: translate(-100px,-50%) rotate(-60deg);
}
section#top .visual .accordion ul li:nth-child(2) .content a .logo {
  left: 50%;
  transform: translate(-50%,-50%) rotate(-60deg);
}
section#top .visual .accordion ul li:nth-child(3) .content a .logo {
  left: 0;
  transform: translate(100px,-50%) rotate(-60deg);
}
@media screen and (max-width: 1400px) {
  section#top .visual .accordion ul li:nth-child(1) .content a .logo {
    transform: translate(-80px,-50%) rotate(-60deg);
  }
  section#top .visual .accordion ul li:nth-child(2) .content a .logo {
    transform: translate(-50%,-50%) rotate(-60deg);
  }
  section#top .visual .accordion ul li:nth-child(3) .content a .logo {
    transform: translate(80px,-50%) rotate(-60deg);
  }
}
section#top .visual .accordion ul li .content a .logo img {
  width: 100%;
}
section#top .visual .accordion ul li .content a .detail {
  padding: 0 0 0 150px;
  display: none;
  transform: translate(5%,0);
}
@media screen and (max-width: 1600px) {
  section#top .visual .accordion ul li:nth-child(1) .content a .detail {
    padding: 0 0 0 100px;
  }
}
@media screen and (max-width: 1300px) {
  section#top .visual .accordion ul li:nth-child(1) .content a .detail {
    padding: 0 0 0 50px;
  }
  section#top .visual .accordion ul li:nth-child(2) .content a .detail {
    padding: 0 0 0 70px;
  }
  section#top .visual .accordion ul li:nth-child(3) .content a .detail {
    padding: 0 0 0 100px;
  }
}
@media screen and (max-width: 1000px) {
  section#top .visual .accordion ul li:nth-child(1) .content a .detail {
    padding: 0 0 0 30px;
  }
  section#top .visual .accordion ul li:nth-child(2) .content a .detail {
    padding: 0 0 0 60px;
  }
  section#top .visual .accordion ul li:nth-child(3) .content a .detail {
    padding: 0 0 0 100px;
  }
}
section#top .visual .accordion ul li .content a .detail .flex {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2%;
}
section#top .visual .accordion ul li .content a .detail .flex dl {
  width: 25%;
  text-align: center;
}
section#top .visual .accordion ul li:nth-child(1) .content a .detail .flex dl {
  transform: translate(7%,0);
}
section#top .visual .accordion ul li:nth-child(2) .content a .detail .flex dl {
  transform: translate(3%,0);
}
section#top .visual .accordion ul li .content a .detail .flex dl dt {
  margin: 0 0 1.3cqw 0;
  font-size: 1.3cqw;
  font-weight: 600;
}
section#top .visual .accordion ul li .content a .detail .flex dl dd {
  width: 100%;
  text-align: center;
}
section#top .visual .accordion ul li .content a .detail .flex .img {
  width: 18%;
}
section#top .visual .accordion ul li .content a .detail .flex .txt {
  width: 40%;
}
section#top .visual .accordion ul li .content a .detail .flex .txt p {
  padding: 0 0 0 20px;
  font-size: 1.1cqw;
  font-weight: 500;
  line-height: 2em;
  background: url(../images/top/visual_check.png) no-repeat  left center / 14px auto;
}
section#top .visual .accordion ul li .content a .detail .btn {
  margin: 1.5cqw auto 0;
  text-align: center;
  transform: translate(5%,0);
}
section#top .visual .accordion ul li .content a .detail .btn p {
  margin: 0 auto;
  padding: 5px 40px 5px 30px;
  color: #0052d1;
  font-size: 16px;
  font-weight: 600;
  border-radius: 30px;
  background: #fff;
  display: inline-block;
  position: relative;
  transition: opacity .3s;
}
@media screen and (max-width: 1200px) {
  section#top .visual .accordion ul li .content a .detail .btn p {
    font-size: 14px;
  }
}
section#top .visual .accordion ul li .content a .detail .btn p::after {
  content: "";
  width: 7px;
  height: 7px;
  border-top: 2px solid #0052d1;
  border-right: 2px solid #0052d1;
  position: absolute;
  right: 25px;
  top: 47%;
  transform: rotate(45deg) translate(-50%,0);
}
section#top .visual .accordion ul li:nth-child(1) .content a .detail .btn p {
  color: #0052d1;
}
section#top .visual .accordion ul li:nth-child(2) .content a .detail .btn p {
  color: #0071f1;
}
section#top .visual .accordion ul li:nth-child(3) .content a .detail .btn p {
  color: #288eff;
}
section#top .visual .accordion ul li:nth-child(1) .content a .detail .btn p::after {
  border-top: 2px solid #0052d1;
  border-right: 2px solid #0052d1;
}
section#top .visual .accordion ul li:nth-child(2) .content a .detail .btn p::after {
  border-top: 2px solid #0071f1;
  border-right: 2px solid #0071f1;
}
section#top .visual .accordion ul li:nth-child(3) .content a .detail .btn p::after {
  border-top: 2px solid #288eff;
  border-right: 2px solid #288eff;
}
section#top .visual .accordion ul li .content a .detail .btn p:hover {
  opacity: .7;
}

/* タブレット・スマホ（タッチデバイス）では hover を無効化 */
@media (hover: none) and (pointer: coarse) {
  section#top .visual .accordion ul:hover li:nth-child(1):hover {
      transition: none;
      width: 33.33% !important;
  }
  section#top .visual .accordion ul:hover li:nth-child(2):hover {
      transition: none;
      width: 33.33% !important;
  }
  section#top .visual .accordion ul:hover li:nth-child(3):hover {
      transition: none;
      width: 33.33% !important;
  }
  section#top .visual .accordion ul:hover li {
    padding: 0 30px!important;
  }
}

@media screen and (max-width: 960px) {
  section#top .visual {
    display: none;
  }
  section#top .visual_sp {
    margin: 0 0 20px 0;
    display: block;
  }
  section#top .visual_sp ul {
    width: 100%;
  }
  section#top .visual_sp ul li {
    height: 100%;
    color: #fff;
    transition: .3s;
  }
  section#top .visual_sp ul li:nth-child(1) {
    width: 100%;
    background: #0052d1;
  }
  section#top .visual_sp ul li:nth-child(2) {
    width: 100%;
    background: #0071f1;
  }
  section#top .visual_sp ul li:nth-child(3) {
    width: 100%;
    background: #288eff;
  }
  section#top .visual_sp ul li a {
    padding: 0 5%;
    display: block;
  }
  section#top .visual_sp ul li a .inner {
    container-type: inline-size;
    max-width: 560px;
    margin: 0 auto;
    padding: 20px 0;
    color: #fff;
  }
  section#top .visual_sp ul li a .lead {
    text-align: center;
  }
  section#top .visual_sp ul li a .lead h2 {
    margin: 0 0 1.5cqw 0;
    font-size: 3.6cqw;
    font-weight: 600;
    text-align: center;
    line-height: 1.5em;
  }
  section#top .visual_sp ul li a .lead img {
    width: 50cqw;
  }
  section#top .visual_sp ul li a .flex {
    margin: 2cqw 0 0 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.5%;
  }
  section#top .visual_sp ul li a .flex .img {
    width: 40%;
    padding: 0 0 0 3%;
  }
  section#top .visual_sp ul li a .flex .txt {
    container-type: inline-size;
    width: 57%;
  }
  section#top .visual_sp ul li a .flex .txt p {
    padding: 0 0 0 6cqw;
    font-size: 4.8cqw;
    font-weight: 500;
    line-height: 2em;
    background: url(../images/top/visual_check.png) no-repeat  left center / 4.8cqw auto;
  }
  section#top .visual_sp ul li a .btn {
    margin: 3cqw auto 0;
    text-align: center;
    transform: translate(3%,0);
  }
    section#top .visual_sp ul li a .btn p {
    margin: 0 auto;
    padding: 5px 40px 5px 30px;
    color: #0052d1;
    font-size: 3cqw;
    font-weight: 600;
    border-radius: 30px;
    background: #fff;
    display: inline-block;
    position: relative;
    transition: opacity .3s;
  }
  section#top .visual_sp ul li:nth-child(1) a .btn p {
    color: #0052d1;
  }
  section#top .visual_sp ul li:nth-child(2) a .btn p {
    color: #0071f1;
  }
  section#top .visual_sp ul li:nth-child(3) a .btn p {
    color: #288eff;
  }
  section#top .visual_sp ul li a .btn p::after {
    content: "";
    width: 1.5cqw;
    height: 1.5cqw;
    border-top: 2px solid #0052d1;
    border-right: 2px solid #0052d1;
    position: absolute;
    right: 25px;
    top: 47%;
    transform: rotate(45deg) translate(-50%,0);
  }

  section#top .visual_sp ul li:nth-child(1) a .btn p::after {
    border-top: 2px solid #0052d1;
    border-right: 2px solid #0052d1;
  }
  section#top .visual_sp ul li:nth-child(2) a .btn p::after {
    border-top: 2px solid #0071f1;
    border-right: 2px solid #0071f1;
  }
  section#top .visual_sp ul li:nth-child(3) a .btn p::after {
    border-top: 2px solid #288eff;
    border-right: 2px solid #288eff;
  }

}


section#top .top_txt {
margin: 0 0 50px 0;
text-align: center;
}
section#top .top_txt p {
  font-size: 46px;
  font-weight: 600;
}
section#top .no1 {
  margin: 100px 10% 0;
}
section#top .no1 .inner {
  max-width: 1000px;
  margin: 0 auto;
}
section#top .no1 dl {
  margin: 80px 0 60px;
  text-align: center;
}
section#top .no1 dl dt {
  font-size: 23px;
  font-weight: 600;
}
section#top .no1 dl dd {
  margin: 20px 0 0 0;
  font-size: 17px;
}

@media screen and (max-width: 768px) {
  section#top .top_txt {
  margin: 0 0 30px 0;
  }
  section#top .top_txt p {
    font-size: 24px;
  }
  section#top .no1 {
    container-type: inline-size;
    margin: 50px 5% 0;
  }
  section#top .no1 dl {
    margin: 40px 0 30px;
  }
  section#top .no1 dl dt {
    font-size: 4.8cqw;
  }
  section#top .no1 dl dd {
    margin: 10px 0 0 0;
    font-size: 3.5cqw;
  }
}


section#top .slide_logo {
  height: 50px;
  margin: 0 0 20px 0;
}
section#top .slide_logo #js-infiniteslide,
section#top .slide_logo #js-infiniteslide2 {
  display: none;
}
section#top .slide_logo #js-infiniteslide img,
section#top .slide_logo #js-infiniteslide2 img {
  width: auto;
  height: 50px;
  margin: 0 20px;
}
section#top .block_about {
  padding: 40px 5% 80px 5%;
}
section#top .block_about .block_inner {
  max-width: 1200px;
  margin: 0 auto;
}
section#top .block_about h2 {
  font-size: 27px;
  font-weight: 600;
  text-align: center;
}
section#top .block_about h2 span {
  font-size: 20px;
  font-weight: 600;
}
section#top .block_about h2 strong {
  padding: 0 5px;
  color: #194480;
  font-size: 35px;
  font-weight: 600;
  position: relative;
}
section#top .block_about h2 strong:before {
content: "";
width: 100%;
height: 10px;
background: #e8ecf4;
position: absolute;
left: 0;
bottom: 5px;
z-index: -1;
}
section#top .block_about p.desc {
  margin: 30px 0 0 0;
  font-size: 18px;
  text-align: center;
}
section#top .block_about .btn {
  margin: 40px 0 0 0;
  text-align: center;
}
section#top .block_about .btn a {
  padding: 5px 50px;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  text-align: center;
  border-radius: 5px;
  border: 2px solid #194480;
  background: #194480;
  display: inline-flex;
  align-items: center;
}
section#top .block_about .btn a span {
  font-size: 27px;
  font-weight: 500;
}
section#top .block_about .btn a:hover {
  color: #194480;
  background: #fff;
  opacity: 1;
}
section .block_download {
  width: 100%;
  padding: 40px 5%;
  background: #d3dbe9;
}
section .block_download .block_inner {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
}
section .block_download .txt p {
  margin: 0 0 10px 0;
  font-weight: 500;
}
section .block_download .btn a {
  width: 360px;
  padding: 10px 20px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  border-radius: 5px;
  background: #c9171e;
  display: block;
}
section .block_download .btn a span {
  margin: 0 0 7px 0;
  padding: 2px 10px;
  color: #c9171e;
  font-size: 12px;
  font-weight: 700;
  border-radius: 30px;
  background: #fff;
  display: inline-block;
}
section .block_download .btn_scr {
  margin: 0 auto!important;
}
section .block_download .btn_scr a {
  width: 380px;
  padding: 10px 20px;
  color: #18477f;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  border-radius: 5px;
  background: #ffc700;
  display: block;
}

section .block_download .btn_scr a span {
  margin: 0 0 7px 0;
  padding: 2px 10px;
  color: #18477f;
  font-size: 12px;
  font-weight: 700;
  border-radius: 30px;
  background: #fff;
  display: inline-block;
}

section#top .block_award {
  padding: 80px 5%;
}
section#top .block_award .inner {
  max-width: 680px;
  margin: 0 auto;
}
section#top .block_award h2 {
  margin: 0 0 40px 0;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
section#top .block_award figure + figure {
  margin: 60px 0 0 0;
}
section#top .block_award figure figcaption {
  max-width: 500px;
  margin: 20px auto 0;
  font-size: 11px;
  text-align: center;
}
section .block_case {
  padding: 0 5% 100px 5%;
  overflow: hidden;
}
section .block_case .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section .block_case h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section .block_case h2 span {
  padding: 0 5px 5px;
  color: #000;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  display: inline-block;
}
section .block_case .item {
  width: 31%;
  height: 100%;
  position: relative;
  display: flex;
}
section .block_case .item a {
  display: flex;
  flex-direction: column;
}
section .block_case .item figure {
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section .block_case .item figure img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section .block_case .item .txt {
  flex: 1;
  padding: 15px;
  border-left: 1px solid #bababa;
  border-right: 1px solid #bababa;
  border-bottom: 1px solid #bababa;
}
section .block_case .item .txt h3 {
  color: #194480;
  font-size: 16px;
  font-weight: 600;
}
section .block_case .item .txt p {
  color: #595757;
  font-size: 14px;
}
section .block_case a.btn {
  width: 320px;
  margin: 50px auto 0;
  padding: 10px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  border: 1px solid #194480;
  border-radius: 30px;
  background: #194480;
  font-size: 20px;
  display: block;
}
section .block_case .btn {
  margin: 30px 0 0 0;
  text-align: center;
}
section .block_case .btn a {
  padding: 10px 50px;
  color: #fff;
  font-size: 17px;
  font-weight: 500;
  text-align: center;
  border-radius: 30px;
  border: 2px solid #194480;
  background: #194480;
  display: inline-flex;
  align-items: center;
}
section .block_case .btn a:hover {
  color: #194480;
  background: #fff;
  opacity: 1;
}
section .block_case .pager {
  max-width: 240px;
  height: 34px;
  margin: 30px auto 0;
  position: relative;
}
section .block_case .swiper {
  overflow: visible;
}
section .block_case .swiper-area .swiper-pagination {
  bottom: 12px;
}
section .block_case .swiper-area .swiper-button-prev {
  width: 32px;
  height: 32px;
  background: url(../images/top/ico_prev.png) no-repeat center center / 100% 100%;
  left: 14px;
}
section .block_case .swiper-area .swiper-button-next {
  width: 32px;
  height: 32px;
  background: url(../images/top/ico_next.png) no-repeat center center / 100% 100%;
  right: 14px;
}
section .block_case .swiper-area .swiper-button-prev::after,
section .block_case .swiper-area .swiper-button-next::after {
  display: none;
}
section .block_case .swiper-area .swiper-pagination-bullet {
  margin: 0 3px;
  background: #194480;
}
section .block_case .swiper-area .swiper-slide {
  height: auto;
}
section#top .block_contents {
  padding: 40px 5% 100px 5%;
}
section#top .block_contents .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#top .block_contents h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section#top .block_contents h2 span {
  padding: 0 5px 5px;
  color: #000;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  display: inline-block;
}
section#top .block_contents .list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#top .block_contents .list .item {
  width: calc(33.33% - 20px);
  position: relative;
}
section#top .block_contents .list .item a {
  display: block;
}
section#top .block_contents .list .item figure {
  margin: 0 0 10px 0;
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section#top .block_contents .list .item figure img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section#top .block_contents .list .item p {
  color: #194480;
  font-size: 14px;
  font-weight: 600;
}
section#top .block_contents .list .item time {
  margin: 5px 0 0 0;
  font-size: 12px;
}
section#top .block_contents a.btn {
  width: 320px;
  margin: 50px auto 0;
  padding: 10px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  border: 1px solid #2667d7;
  border-radius: 30px;
  background: #2667d7;
  font-size: 20px;
  display: block;
} 
section#top .block_contents .btn {
  margin: 30px 0 0 0;
  text-align: center;
}
section#top .block_contents .btn a {
  padding: 10px 50px;
  color: #fff;
  font-size: 17px;
  font-weight: 500;
  text-align: center;
  border-radius: 30px;
  border: 2px solid #2667d7;
  background: #2667d7;
  display: inline-flex;
  align-items: center;
}
section#top .block_contents .btn a:hover {
  color: #2667d7;
  background: #fff;
  opacity: 1;
}
section#top .block_seminar {
  padding: 0 5% 100px 5%;
}
section#top .block_seminar .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#top .block_seminar h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section#top .block_seminar h2 span {
  padding: 0 5px 5px;
  color: #000;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  display: inline-block;
}
section#top .block_seminar .list ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
}
section#top .block_seminar .list ul li {
  width: calc(50% - 15px);
  min-width: 585px;
}
section#top .block_seminar .list ul li a {
  padding: 20px;
  background: #e8ecf3;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}
section#top .block_seminar .list ul li a .image {
  width: calc(50% - 10px);
}
section#top .block_seminar .list ul li a .text {
  width: calc(50% - 10px);
}
section#top .block_seminar .list ul li a .text .cat {
  color: #646464;
  font-size: 15px;
  line-height: 1.4;
}
section#top .block_seminar .list ul li a .text .ttl {
  margin: 5px 0 0 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
}
section#top .block_seminar .list ul li a .text .outline {
  margin: 5px 0 0 0;
  font-size: 14px;
  line-height: 1.6;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  line-clamp: 4;
}

section#top .block_seminar .list p.center {
  padding: 50px 20px;
  font-size: 24px;
  text-align: center;
  font-weight: 600;
  background: #e8ecf3;
}
section#top .block_seminar .btn {
  margin: 40px 0 0 0;
  text-align: center;
}
section#top .block_seminar .btn a {
  padding: 10px 50px;
  color: #fff;
  font-size: 17px;
  font-weight: 500;
  text-align: center;
  border-radius: 30px;
  border: 2px solid #2667d7;
  background: #2667d7;
  display: inline-flex;
  align-items: center;
}
section#top .block_seminar .btn a:hover {
  color: #2667d7;
  background: #fff;
  opacity: 1;
}
section#top .block_news {
  padding: 0 5% 100px 5%;
}
section#top .block_news .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#top .block_news h2 {
  margin: 0 0 20px 0;
  text-align: center;
}
section#top .block_news h2 span {
  padding: 0 5px 5px;
  color: #000;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  display: inline-block;
}
section#top .block_news ul {
  margin: 0 0 10px 0;
}
section#top .block_news ul li {
  border-bottom: 1px solid #000;
}
section#top .block_news ul li a {
  padding: 15px 0;
  display: block;
  transition: .3s;
}
section#top .block_news ul li a:hover {
  opacity: .7;
}
section#top .block_news ul li dl {
  display: flex;
  align-items: center;
}
section#top .block_news ul li dl dt {
  font-size: 20px;
  font-weight: 600;
}
section#top .block_news ul li dl dd {
  margin: 0 0 0 10px;
  padding: 5px 10px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  border-radius: 20px;
  background: #2667d7;
  display: inline-block;
}
section#top .block_news ul li p {
  padding: 0 25px 0 0;
  font-size: 18px;
  background: url(../images/top/news_icon.jpg) no-repeat right center / 14px auto;
}
section#top .block_news p.link {
  text-align: right;
}
section#top .block_news p a {
  color: #2667d7;
  font-size: 20px;
  font-weight: 600;
}
section#top .block_nvidia {
  padding: 50px 5%;
  background: #f1f1f1;
}
section#top .block_nvidia .block_inner {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section#top .block_nvidia .box {
  width: calc(50% - 30px);
}
section#top .block_nvidia p {
  margin: 10px 0 0 0;
  font-size: 14px;
}
section .block_tel {
  width: 100%;
  padding: 50px 30px;
  text-align: center;
}
section .block_tel h3 {
  margin: 0 0 20px 0;
  font-size: 24px;
  font-weight: 600;
}
section .block_tel p.tel a {
  width: 300px;
  margin: 0 auto;
  padding: 0 0 5px 0;
  color: #194480;
  font-size: 36px;
  font-weight: 600;
  text-align: right;
  line-height: 1;
  background: url(../images/form/tel_icon.jpg) no-repeat left center;
  display: block;
  pointer-events: none;
}
section .block_tel p.time {
  margin: 0 0 20px 0;
  font-size: 16px;
}
section .block_btn {
  padding: 50px 30px;
  color: #fff;
  text-align: center;
  background: #194480;
}
section .block_btn dl dt {
  font-size: 24px;
}
section .block_btn dl dd {
  margin: 0 0 20px 0;
  font-size: 18px;
}
section .block_btn .btn {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding: 15px 0;
  display: flex;
  justify-content: space-between;
}
section .block_btn .btn a {
  width: 48%;
  padding: 15px 0;
  color: #fff;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
}
section .block_btn .btn a.trial {
  color: #fff;
  background: #b41919;
}
section .block_btn .btn a.download {
  color: #194489;
  justify-content: center;
  flex-flow: column;
  background: #fff;
}
section .block_btn .btn a.download span {
  font-size: 16px;
  font-weight: 600;
  display: block;
}

section .trial_banner {
  width: 50px;
  position: fixed;
  right: 0;
  bottom: 260px;
  z-index: 999;
  opacity: 0;
  transition: .7s;
  pointer-events: none;
  transform: translate(30px,0);
}
section .trial_banner.active {
  pointer-events: auto;
  transform: translate(0,0);
  opacity: 1;
}
section .fixed_box_wrap {
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 999;
  opacity: 0;
  transition: .7s;
  pointer-events: none;
  transform: translate(30px,0);
}
section .fixed_box_wrap.active {
  pointer-events: auto;
  transform: translate(0,0);
  opacity: 1;
}
section .fixed_box_wrap .close {
  width: 36px;
  height: 36px;
  background: url(../images/top/fixed_movie_close.png) no-repeat center center / 100% auto;
  cursor: pointer;
  position: absolute;
  top: -14px;
  left: -14px;
  z-index: 100;
}
section .fixed_box_wrap .fixed_box {
  width: 300px;
  padding: 20px 50px;
  background: #7e858e;
}
section .fixed_box_wrap .fixed_box a {
  display: block;
}
section .fixed_box_wrap .fixed_box dl {
  margin: 0 0 15px 0;
  line-height: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
section .fixed_box_wrap .fixed_box dl dt {
  padding:  5px 10px;
  color: #b81919;
  font-size: 18px;
  font-weight: 600;
  border-radius: 5px;
  background: #fff;
}
section .fixed_box_wrap .fixed_box dl dd {
  color: #fff;
  font-size: 31px;
  font-weight: 600;
}
section .fixed_box_wrap .fixed_box img {
  margin: 0 0 10px 0;
  border: 3px solid #fff;
}
section .fixed_box_wrap .fixed_box p {
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
}
section .fixed_box_wrap .banner_box {
  border-radius: 8px;
  background: #fff;
}
section .fixed_box_wrap .banner_box img {
  width: 240px;
  height: auto;
}

section .fixed_box_wrap .trial {
  width: 240px;
  padding: 7px;
  border-radius: 5px;
  border: 3px solid #2a62cd;
  background: #fff;
}
section .fixed_box_wrap .trial .box1 {
  padding: 10px 10px 20px 10px;
  text-align: center;
  background: #194489;
}
section .fixed_box_wrap .trial .box1 p {
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  line-height: 1.4;
}
section .fixed_box_wrap .trial .box1 a {
  margin: 15px 0 0 0;
  padding: 10px 0 12px;
  color: #fff;
  font-size: 21px;
  font-weight: 600;
  line-height: 1;
  border-radius: 5px;
  background: #ca0012;
  display: block;
}
section .fixed_box_wrap .trial .box2 {
  padding: 20px 10px;
  text-align: center;
  background: #2a62cd;
}
section .fixed_box_wrap .trial .box2 a {
  padding: 11px 0 13px;
  color: #000;
  font-size: 18px;
  font-weight: 600;
  line-height: 1;
  border-radius: 5px;
  background: #ffb800;
  display: block;
}


section .fixed_movie_wrap {
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 999;
}
section .fixed_movie_wrap.hide {
  display: none;
}
section .fixed_movie_wrap .close {
  width: 36px;
  height: 36px;
  background: url(../images/top/fixed_movie_close.png) no-repeat center center / 100% auto;
  cursor: pointer;
  position: absolute;
  top: -14px;
  left: -14px;
  z-index: 100;
}
section .movie_box {
  width: 314px;
  height: auto;
  margin: 0 auto;
  padding: 7px;
  background: #19448e;
}
section .movie_box .video_wrap {
  width: 300px;
  height: 169px;
  margin: 0 0 7px 0;
  background: #fff;
  position: relative;
  z-index: 1;
}
section .movie_box .video_wrap video {
  width: 100%;
  cursor: pointer;
}
section .movie_box .video_wrap a.btn {
  width: 300px;
  height: 169px;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}
section .movie_box p.more a {
  padding: 10px 0;
  text-align: center;
  line-height: 1;
  border-radius: 5px;
  border: 1px solid #fff;
  display: block;
  transition: .3s;
}
section .movie_box p.more a span {
  padding: 0 22px 0 0;
  color: #fff;
  font-weight: 600;
  background: url(../images/top/link_icon.png) no-repeat right center;
  transition: .3s;
}
section .movie_box p.more a:hover {
  background: #fff;
  opacity: 1;
}
section .movie_box p.more a:hover span {
  color: #19448e;
  background: url(../images/top/link_icon_on.png) no-repeat right center;
}
section .movie_box p.earthshot a {
  padding: 7px 0 2px 0;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  display: block;
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  section#top .block_about ul li h3 {
    font-size: 19px;
  }
  section#top .block_about ul li h3 br {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  section#top .slide_logo {
    height: 30px;
    margin: 0 0 30px 0;
  }
  section#top .slide_logo #js-infiniteslide img,
  section#top .slide_logo #js-infiniteslide2 img {
    height: 30px;
    margin: 0 10px;
  }
  section#top .block_about {
    padding: 0 5% 40px 5%;
  }
  section#top .block_about h2 {
    font-size: 20px;
  }
  section#top .block_about h2 span {
    font-size: 14px;
  }
  section#top .block_about h2 strong {
    padding: 0;
    color: #194480;
    font-size: 26px;
    line-height: 1.5;
  }
  section#top .block_about h2 strong:before {
  height: 6px;
  bottom: 3px;
  }
  section#top .block_about p.desc {
    margin: 20px 0 0 0;
    font-size: 14px;
    text-align: left;
  }
  section#top .block_about .btn {
    margin: 30px 0 0 0;
  }
  section#top .block_about .btn a {
    padding: 10px 20px;
    font-size: 13px;
  }
  section#top .block_about .btn a span {
    font-size: 16px;
  }
  section#top .block_about .btn a:hover {
    color: #194480;
    background: #fff;
    opacity: 1;
  }
  section .block_download {
    padding: 30px 5%;
  }
  section .block_download .block_inner {
    display: block;
  }
  section .block_download .btn {
    margin: 20px 0 0 0;
  }
  section .block_download .btn a {
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    font-size: 16px;
  }
  section .block_download .btn a span {
    margin: 0 0 7px 0;
    padding: 2px 10px;
    color: #c9171e;
    font-size: 12px;
    font-weight: 700;
    border-radius: 30px;
    background: #fff;
    display: inline-block;
  }
  section .block_download .btn_scr a {
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    padding: 10px 15px;
    font-size: 16px;
  }
  section .block_download .btn_scr a span {
    margin: 0 0 7px 0;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 30px;
    background: #fff;
    display: inline-block;
  }
  section#top .block_award {
    padding: 40px 5%;
  }
  section#top .block_award h2 {
    margin: 0 0 30px 0;
    font-size: 16px;
  }
  section#top .block_award figure + figure {
    margin: 40px 0 0 0;
  }
  section#top .block_award figure figcaption {
    margin: 10px auto 0;
    font-size: 10px;
    text-align: center;
  }
  section .block_case {
    padding: 0 5% 60px 5%;
  }
  section .block_case h2 {
    margin: 0 0 30px 0;
    text-align: center;
  }
  section .block_case h2 span {
    font-size: 18px;
  }
  section .block_case .item .txt h3 {
    font-size: 15px;
  }
  section .block_case .item .txt p {
    font-size: 13px;
  }
  section .block_case .swiper-area .swiper-button-prev {
    left: 0;
  }
  section .block_case .swiper-area .swiper-button-next {
    right: 0;
  }
  section .block_case .btn {
    margin: 20px 0 0 0;
  }
  section .block_case .btn a {
    font-size: 14px;
  }
  section#top .block_contents {
    padding: 20px 5% 60px 5%;
  }
  section#top .block_contents h2 {
    margin: 0 0 30px 0;
  }
  section#top .block_contents h2 span {
    font-size: 18px;
  }
  section#top .block_contents .list {
    display: block;
  }
  section#top .block_contents .list .item {
    width: 100%;
    margin: 0 0 30px 0;
  }
  section#top .block_contents .list .item em {
    font-size: 10px;
  }
  section#top .block_contents .list .item p {
    font-size: 12px;
  }
  section#top .block_contents .btn a {
    margin:  0 auto;
    font-size: 14px;
  }
  section#top .block_seminar {
    padding: 0 5% 60px 5%;
  }
  section#top .block_seminar h2 {
    margin: 0 0 30px 0;
    text-align: center;
  }
  section#top .block_seminar h2 span {
    font-size: 18px;
  }

  

  section#top .block_seminar .list ul {
    gap: 15px;
  }
  section#top .block_seminar .list ul li {
    width: 100%;
    min-width: 100%;
  }
  section#top .block_seminar .list ul li a {
    padding: 15px;
    gap: 10px;
  }
  section#top .block_seminar .list ul li a .image {
    width: 100%;
  }
  section#top .block_seminar .list ul li a .text {
    width: 100%;
  }
  section#top .block_seminar .list ul li a .text .cat {
    color: #646464;
    font-size: 15px;
    line-height: 1.4;
  }
  section#top .block_seminar .list ul li a .text .ttl {
    margin: 5px 0 0 0;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.4;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }
  section#top .block_seminar .list ul li a .text .outline {
    margin: 5px 0 0 0;
    font-size: 14px;
    line-height: 1.6;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
  }
  section#top .block_seminar .list p.center {
    font-size: 18px;
  }
  section#top .block_seminar .btn {
    margin: 40px 0 0 0;
    text-align: center;
  }
  section#top .block_seminar .btn a {
    padding: 10px 30px;
    font-size: 13px;
  }
  section#top .block_seminar .btn a:hover {
    color: #194480;
    background: #fff;
    opacity: 1;
  }
  section#top .block_news {
    padding: 0 5% 60px;
  }
  section#top .block_news h2 {
    margin: 0 0 20px 0;
  }
  section#top .block_news h2 span {
    font-size: 18px;
  }
  section#top .block_news ul {
    margin: 0 0 10px 0;
  }
  section#top .block_news ul li a {
    padding: 10px 0;
  }
  section#top .block_news ul li dl dt {
    font-size: 14px;
  }
  section#top .block_news ul li dl dd {
    padding: 3px 7px;
  }
  section#top .block_news ul li p {
    padding: 0 25px 0 0;
    font-size: 12px;
    background: url(../images/top/news_icon.jpg) no-repeat right center / 12px auto;
  }
  section#top .block_news p a {
    font-size: 14px;
  }
  section#top .block_nvidia {
    padding: 30px 5%;
  }
  section#top .block_nvidia .block_inner {
    width: 100%;
    gap: 20px;
  }
  section#top .block_nvidia .box {
    width: 100%;
  }
  section#top .block_nvidia p {
    font-size: 13px;
  }
  section .fixed_box_wrap {
    display: none;
  }
  section .fixed_movie_wrap {
    display: none;
  }
  section .trial_banner {
    display: none;
  }
  section .block_cv {
    margin: 40px 0 0 0;
    padding: 40px 20px;
  }
  section .block_cv h3 {
    font-size: 11px;
    display: inline-block;
  }
  section .block_cv h3 strong {
    font-size: 14px;
  }
  section .block_cv ul {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 20px;
  }
  section .block_cv ul li {
    width: 100%;
    padding: 20px;
    flex-direction: column;
  }
  section .block_cv ul li figure {
    width: 50px;
  }
  section .block_cv ul li dl dt {
    font-size: 18px;
  }
  section .block_cv ul li dl dd {
    margin: 5px 0 0 0;
    font-size: 12px;
  }
  section .block_cv ul li .btn {
    margin: 20px 0 0 0;
  }
  section .block_cv ul li .btn a {
    width: 260px;
    padding: 10px 20px;
    font-size: 14px;
  }
  section .block_cv ul li .btn a span {
    font-size: 22px;
    font-weight: 500;
  }
  section .block_cv ul li .btn a:hover {
    color: #fff;
    background: #194480;
    opacity: 1;
  }
  section .block_tel {
    padding: 40px 20px;
    text-align: center;
  }
  section .block_tel h3 {
    font-size: 16px;
  }
  section .block_tel p.tel a {
    width: 250px;
    font-size: 30px;
    background: url(../images/form/tel_icon.jpg) no-repeat left center / 30px auto;
    pointer-events: auto;
  }
  section .block_tel p {
    font-size: 11px;
  }
  section .block_tel p.time {
    margin: 0 0 20px 0;
    font-size: 13px;
  }
}

/* ********** SPECTEE ********** */

section#spectee {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#spectee .fixed_box_wrap {
  right: 330px;
}
@media screen and (max-width: 1100px) {
  section#specte .fixed_box_wrap {
    right: 10px;
  }
}
section#spectee .mainColumn {
  width: calc(100% - 320px);
  overflow: hidden;
}
section#spectee .sideColumn {
  width: 320px;
  padding: 20px;
  background: #eaeffb;
  box-shadow: 0px 0px 10px rgba(0,0,0,.5);
}
section#spectee .sideColumn .sticky {
  position: sticky;
  top: 100px;
  left: 0;
}
section#spectee .sideColumn h3 {
  margin: 0 0 10px 0;
  color: #2a62d3;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  line-height: 1.4;
  font-feature-settings: "palt";
  z-index: 2;
}
section#spectee .sideColumn iframe {
  width: 100%;
  height: calc(100vh - 170px);
  overflow: hidden;
  display: block;
}

section#spectee .sp_button {
  display: none;
}

@media screen and (max-width: 1100px) {
  section#spectee .mainColumn {
    width: 100%;
  }
  section#spectee .sideColumn {
    display: none;
  }
  section#spectee .sp_button {
    width: 100%;
    background: #fff;
    position: sticky;
    bottom: 0;
    left: 0;
    display: block;
    z-index: 50;
  }
  section#spectee .sp_button a {
    padding: 15px;
    color: #fff;
    font-weight: 500;
    text-align: center;
    background: #2667d6;
    display: block;
  }
}
@media screen and (max-width: 768px) {
  section#spectee .sp_button a {
    padding: 10px;
    font-size: 12px;
  }
}

section#spectee .visual {
  height: 356px;
  padding: 0 5%;
}
section#spectee .visual .inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: row-reverse;
}
section#spectee .visual .inner::after {
  content: "";
  width: 2000px;
  height: 356px;
  background: url(../images/spectee/visual_bg.png) no-repeat center center / 100% auto;
  position: absolute;
  top: 0;
  right: 30%;
  z-index: -1;
}
section#spectee .visual .txt {
  width: 47%;
  padding: 30px 0;
}
section#spectee .visual .txt h1 {
  color: #fff;
  font-size: clamp(18px, 1.8vw, 34px);
  font-weight: 600;
  line-height: 1.5;
}
section#spectee .visual .txt .box {
  margin: 30px 0 0 0;
  color: #fff;
  font-size: 17px;
}
section#spectee .visual .txt .box p {
  font-size: 17px;
}
@media screen and (max-width: 1640px) {
  section#spectee .visual .txt .box {
    margin: 20px 0 0 0;
  }
  section#spectee .visual .txt .box p {
    font-size: 16px;
  }
}
@media screen and (max-width: 1180px) {
  section#spectee .visual .txt .box p {
    font-size: 14px;
  }
}
section#spectee .visual .image {
  width: 50%;
  margin: -20px 0 0 0;
}
section#spectee .nav {
  padding: 30px 5% 0;
}
section#spectee .nav .inner {
  max-width: 1200px;
  margin: 0 auto;
}
section#spectee .nav .inner ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 30px;
}
section#spectee .nav .inner ul li {
  width: calc(33.33% - 20px);
  text-align: center;
  border: 2px solid #194480;
}
section#spectee .nav .inner ul li a {
  height: 100%;
  padding: 10px;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
}
section#spectee .nav .inner ul li a:after {
  content: "";
  width: 24px;
  height: 14px;
  background: url(../images/spectee/ico_nav.jpg) no-repeat center center / 100% auto;
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translate(-50%,0);
}
section#spectee .nav .inner ul li a:hover {
  opacity: 1;
}
section#spectee .nav .inner ul li a em {
  margin: 0 0 2px 0;
  color: #727171;
  font-size: 12px;
  font-weight: 500;
  font-style: normal;
}
section#spectee .nav .inner ul li a span {
  width: 100%;
  padding: 0 5px 1px;
  color: #194480;
  font-size: 29px;
  font-weight: 500;
  display: block;
  transition: .5s;
}
section#spectee .nav .inner ul li a:hover span {
  color: #fff;
  background: #194480;
}
section#spectee .nav .inner ul.snav {
  margin: 30px 0 0 0;
}
section#spectee .nav .inner ul.snav li {
  width: calc(25% - 22.5px);
}
section#spectee .nav .inner ul.snav li span {
  font-size: 22px;
}
@media screen and (max-width: 1280px) {
  section#spectee .nav .inner ul li a span {
    font-size: 22px;
  }
  section#spectee .nav .inner ul.snav li span {
    font-size: 16px;
  }
}
section#spectee .block_video {
  padding: 50px 5% 80px;
}
section#spectee .block_video .block_inner {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
section#spectee .block_video p {
  color: #646464;
  font-size: 19px;
  font-weight: 700;
  position: relative;
  display: inline;
}
section#spectee .block_video p::before {
  content: "";
  width: 1.5px;
  height: 20px;
  background: #646464;
  position: absolute;
  left: -12px;
  top: 5px;
  transform: rotate(-20deg);
}
section#spectee .block_video p::after {
  content: "";
  width: 1.5px;
  height: 20px;
  background: #646464;
  position: absolute;
  right: -12px;
  top: 5px;
  transform: rotate(20deg);
}
section#spectee .block_video h2 {
  width: 100%;
  font-size: 27px;
  font-weight: 600;
  text-align: center;
  position: relative;
}
section#spectee .block_video h2 span {
  color: #194480;
  font-weight: 600;
}
section#spectee .block_video video {
  width: 100%;
  margin: 20px 0 0 0;
}
section#spectee .block_video .youtube {
  width: 100%;
  margin: 30px 0 0 0;
  padding-top: 56.25%;
  position: relative;
}
section#spectee .block_video .youtube #player {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
section#spectee .block {
  margin: -80px 0 0 0;
  padding: 80px 0 80px 0;
}
section#spectee .block .block_outer {
  padding: 0 5% 80px;
  background: linear-gradient(to bottom, #fff, #e1e7f0);
}
section#spectee .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#spectee .block .lead {
  text-align: center;
}
section#spectee .block .lead h2 {
  color: #194480;
  font-size: 22px;
  position: relative;
}
section#spectee .block .lead h2 span {
  padding: 0 20px;
  font-weight: 600;
  background: #fff;
  position: relative;
  z-index: 2;
}
section#spectee .block .lead h2::before {
  content: "";
  width: 100%;
  height: 1px;
  background: #194480;
  position: absolute;
  top: 50%;
  left: 0;
  will-change: transform;
}
section#spectee .block .lead strong {
  margin: 20px 0;
  padding: 10px 60px 13px;
  color: #fff;
  font-size: 58px;
  line-height: 1;
  background: #194480;
  display: inline-block;
}
section#spectee .block .lead dl dt {
  margin: 0 0 10px 0;
  font-size: 34px;
  font-weight: 500;
}
section#spectee .block .lead dl dt span {
  color: #194480;
  font-weight: 500;
}
section#spectee .block ul {
  margin: 40px 0 0 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 30px;
}
section#spectee .block ul li {
  width: calc(33.33% - 20px);
  padding: 20px;
  border-radius: 15px;
  box-shadow: 3px 3px 5px rgba(0,0,0,.3);
  background: #fff;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
section#spectee .block ul li h3 {
  margin: 5px 0 15px 0;
  color: #194480;
  font-size: 19px;
  font-weight: 600;
  line-height: 1.4;
}
section#spectee .block ul li figure {
  margin: 15px 0 0 0;
}
section#spectee .block ul li p {
  font-size: 13px;
}
section#spectee .block_api {
  margin: -100px 0 0 0;
  padding: 100px 5%;
}
section#spectee .block_api .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  background: #3b609b;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#spectee .block_api .txt {
  width: calc(50% - 10px);
  padding: 0 3%;
  color: #fff;
}
section#spectee .block_api .txt .large {
  font-size: 20px;
  font-weight: 600;
}
section#spectee .block_api .txt h2 {
  margin: 0 0 5px 0;
  font-size: 34px;
  font-weight: 600;
  line-height: 1.5;
}
section#spectee .block_api .txt p {
  font-size: 16px;
}
section#spectee .block_api .txt .btn a {
  margin: 20px 0 0 0;
  padding: 8px 70px;
  color: #194480;
  font-size: 17px;
  font-weight: 600;
  text-align: center;
  border-radius: 50px;
  background: #fff;
  display: inline-block;
}
section#spectee .block_api .img {
  width: calc(50% - 10px);
}
section#spectee .block_flow {
  margin: -80px 0 80px 0;
  padding: 80px 0 0 0;
}
section#spectee .block_flow .outer {
  padding: 50px 5%;
  background: #d1dae7;
}
section#spectee .block_flow .inner {
  max-width: 1000px;
  margin: 0 auto;
}
section#spectee .block_flow h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section#spectee .block_flow h2 span {
  padding: 0 5px 5px;
  color: #000;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  display: inline-block;
}
section#spectee .block_flow dl {
  max-width: 730px;
  margin: 0 auto 50px;
}
section#spectee .block_flow dl dt {
  margin: 0 0 20px 0;
  color: #194480;
  font-size: 22px;
  font-weight: 600;
  text-align: center;
}
section#spectee .block_flow dl dd {
  font-size: 16px;
}
section#spectee .block_price {
  margin: -80px 0 0 0;
  padding: 80px 0 0 0;
}
section#spectee .block_price .outer {
  padding: 50px 5%;
  background: #3b609b;
}
section#spectee .block_price .inner {
  max-width: 1000px;
  margin: 0 auto;
}
section#spectee .block_price h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section#spectee .block_price h2 span {
  padding: 0 5px 5px;
  color: #fff;
  font-size: 23px;
  font-weight: 600;
  border-bottom: 1px solid #fff;
  display: inline-block;
}
section#spectee .block_price .box {
  padding: 30px 5%;
  text-align: center;
  border: 7px solid #e8ecf3;
  background: #fff;
}
section#spectee .block_price .box p {
  margin: 20px 0 0 0;
  color: #194480;
  font-size: 23px;
  font-weight: 600;
}
section#spectee .block_price .box a {
  margin: 20px 0 0 0;
  padding: 8px 70px;
  color: #fff;
  font-size: 23px;
  font-weight: 600;
  text-align: center;
  border-radius: 50px;
  background: #c8171e;
  display: inline-block;
}
section#spectee .block_case {
  margin: -80px 0 100px 0;
  padding: 160px 5% 0 5%;
}
section#spectee .block_award {
  padding:  0 5% 80px;
}
section#spectee .block_award .outer {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 30px 30px;
  border: 1px solid #a7a8a8;  
}
section#spectee .block_award .inner {
  max-width: 680px;
  margin: 0 auto;
}
section#spectee .block_award .title {
  margin: -17px 0 40px 0;
  text-align: center;
}
section#spectee .block_award .title h2 {
  padding: 0 20px;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
  background: #fff;
  display: inline-block;
}
section#spectee .block_award figure + figure {
  margin: 60px 0 0 0;
}
section#spectee .block_award figure figcaption {
  max-width: 500px;
  margin: 20px auto 0;
  font-size: 11px;
  text-align: center;
}
section#spectee .block_award .logo {
	margin: 60px 0 0 0;
	text-align: center;
}
section#spectee .block_award .logo img {
	width: auto;
	height: 55px;
	margin: 10px 15px;
}
section#spectee .block_award .center {
	margin: 20px 0 0 0;
	text-align: center;
}
@media screen and (max-width: 1280px) {
  section#spectee .visual .txt .box {
    margin: 20px 0 0 0;
    font-size: 16px;
  }
}
section#spectee .visual .image {
  width: 50%;
  margin: -20px 0 0 0;
}

@media screen and (max-width: 767px) {
  section#spectee .visual {
    height: auto;
  }
  section#spectee .visual .inner {
    padding: 0 0 30px 0;
  }
  section#spectee .visual .inner::after {
    content: "";
    width: 2000px;
    height: 400px;
    background: url(../images/spectee/visual_bg.png) no-repeat center center / auto 100%;
    position: absolute;
    top: auto;
    bottom: 0;
    right: -20%;
    z-index: -1;
  }
  section#spectee .visual .txt {
    width: 100%;
    padding: 30px 0 0 0;
  }
  section#spectee .visual .txt h1 {
    max-width: 500px;
  }
  section#spectee .visual .txt .box {
    font-size: 14px;
  }
  section#spectee .visual .image {
    width: 100%;
    max-width: 300px;
    text-align: center;
    margin: 0 auto!important;
  }
  section#spectee .nav {
    padding: 30px 5% 0;
  }
  section#spectee .nav .inner ul {
    gap: 20px;
  }
  section#spectee .nav .inner ul li {
    width: 100%;
    text-align: center;
    border: 2px solid #194480;
  }
  section#spectee .nav .inner ul li a em {
    margin: 0 0 2px 0;
    color: #727171;
    font-size: 12px;
    font-weight: 500;
    font-style: normal;
  }
  section#spectee .nav .inner ul li a span {
    font-size: 20px;
  }
  section#spectee .nav .inner ul li a:hover span {
    color: #fff;
    background: #194480;
  }
  section#spectee .nav .inner ul.snav {
    margin: 20px 0 0 0;
  }
  section#spectee .nav .inner ul.snav li {
    width: calc(50% - 10px);
  }
  section#spectee .nav .inner ul.snav li span {
    font-size: 16px;
  }
  section#spectee .block_video {
    padding: 50px 5% 60px;
  }
  section#spectee .block_video .block_inner {
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
  }
  section#spectee .block_video p {
    color: #646464;
    font-size: 19px;
    font-weight: 700;
    position: relative;
    display: inline;
  }
  section#spectee .block_video p::before {
    content: "";
    width: 1.5px;
    height: 20px;
    background: #646464;
    position: absolute;
    left: -12px;
    top: 5px;
    transform: rotate(-20deg);
  }
  section#spectee .block_video p::after {
    content: "";
    width: 1.5px;
    height: 20px;
    background: #646464;
    position: absolute;
    right: -12px;
    top: 5px;
    transform: rotate(20deg);
  }
  section#spectee .block_video p {
    margin: 0 0 10px 0;
    font-size: 13px;
  }
  section#spectee .block_video p::before {
    height: 15px;
    left: -12px;
    top: 3px;
  }
  section#spectee .block_video p::after {
    height: 15px;
    right: -12px;
    top: 3px;
  }
  section#spectee .block_video h2 {
    width: 100%;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    position: relative;
  }
  section#spectee .block_video h2 span {
    color: #194480;
    font-weight: 600;
  }
  section#spectee .block_video video {
    width: 100%;
    margin: 20px 0 0 0;
  }
  section#spectee .block_video .youtube {
    margin: 20px 0 0 0;
  }
  section#spectee .block {
    margin: -60px 0 0 0;
    padding: 60px 0 40px 0;
  }
  section#spectee .block .block_outer {
    padding: 0 5% 40px;
  }
  section#spectee .block .lead h2 {
    font-size: 15px;
  }
  section#spectee .block .lead h2 span {
    padding: 0 10px;
  }
  section#spectee .block .lead strong {
    margin: 20px 0;
    padding: 6px 30px 8px;
    font-size: 30px;
  }
  section#spectee .block .lead dl dt {
    font-size: 16px;
  }
  section#spectee .block .lead dl dd {
    font-size: 13px;
  }
  section#spectee .block ul {
    margin: 30px 0 0 0;
    gap: 20px;
  }
  section#spectee .block ul li {
    width: 100%;
  }
  section#spectee .block ul li h3 {
    font-size: 16px;
  }
  section#spectee .block ul li figure {
    margin: 15px 0 0 0;
  }
  section#spectee .block ul li p {
    font-size: 13px;
  }
  section#spectee .block_api {
    margin: -60px 0 0 0;
    padding: 60px 5% 40px;
  }
  section#spectee .block_api .inner {
    flex-direction: column-reverse;
  }
  section#spectee .block_api .txt {
    width: 100%;
    padding: 0;
  }
  section#spectee .block_api .txt .large {
    font-size: 13px;
  }
  section#spectee .block_api .txt h2 {
    margin: 0 0 5px 0;
    font-size: 20px;
  }
  section#spectee .block_api .txt p {
    font-size: 13px;
  }
  section#spectee .block_api .txt .btn {
    text-align: center;
  }
  section#spectee .block_api .txt .btn a {
    font-size: 15px;
  }
  section#spectee .block_api .img {
    width: 100%;
    margin: 0 0 10px 0;
  }
  section#spectee .block_flow {
    margin: -60px 0 60px 0;
    padding: 60px 0 0 0;
  }
  section#spectee .block_flow .outer {
    padding: 30px 5%;
  }
  section#spectee .block_flow h2 {
    margin: 0 0 30px 0;
  }
  section#spectee .block_flow h2 span {
    font-size: 18px;
  }
  section#spectee .block_flow dl {
    margin: 0 auto 20px;
  }
  section#spectee .block_flow dl dt {
    margin: 0 0 10px 0;
    font-size: 16px;
  }
  section#spectee .block_flow dl dd {
    font-size: 13px;
  }
  section#spectee .block_price {
    margin: -60px 0 0 0;
    padding: 60px 0 0 0;
  }
  section#spectee .block_price .outer {
    padding: 30px 5%;
  }
  section#spectee .block_case {
    margin: -60px 0 0 0;
    padding: 100px 5% 60px 5%;
  }
  section#spectee .block_price h2 {
    margin: 0 0 30px 0;
  }
  section#spectee .block_price h2 span {
    font-size: 18px;
  }
  section#spectee .block_price .box {
    padding: 20px;
    border: 5px solid #e8ecf3;
  }
  section#spectee .block_price .box p {
    margin: 20px 0 0 0;
    font-size: 16px;
  }
  section#spectee .block_price .box a {
    width: 100%;
    margin: 20px 0 0 0;
    padding: 10px;
    font-size: 14px;
  }
  section#spectee .block_award {
    padding:  0 5% 40px;
  }
  section#spectee .block_award .outer {
    padding: 0 20px 20px;
  }
  section#spectee .block_award .title {
    margin: -22px 0 30px 0;
    text-align: center;
  }
  section#spectee .block_award .title h2 {
    padding: 0 10px;
    font-size: 15px;
  }
  section#spectee .block_award figure + figure {
    margin: 40px 0 0 0;
  }
  section#spectee .block_award figure figcaption {
    margin: 10px auto 0;
    font-size: 10px;
	text-align: center;
  }
  section#spectee .block_award .logo {
		margin: 30px 0 0 0;
  }
  section#spectee .block_award .logo img {
		height: 30px;
		margin: 5px 10px;
  }
  section#spectee .block_award .center {
    font-size: 10px;
  }
}

/* ********** SPECTEE SCR ********** */

section#specteescr {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#specteescr .fixed_box_wrap {
  right: 330px;
}
@media screen and (max-width: 1100px) {
  section#specteescr .fixed_box_wrap {
    right: 10px;
  }
}
section#specteescr .mainColumn {
  width: calc(100% - 320px);
  overflow: hidden;
}
section#specteescr .sideColumn {
  width: 320px;
  padding: 20px;
  background: #eaeffb;
  box-shadow: 0px 0px 10px rgba(0,0,0,.5);
}
section#specteescr .sideColumn .sticky {
  position: sticky;
  top: 100px;
  left: 0;
}
section#specteescr .sideColumn h3 {
  margin: 0 0 10px 0;
  color: #2a62d3;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  line-height: 1.4;
  font-feature-settings: "palt";
  z-index: 2;
}
section#specteescr .sideColumn iframe {
  width: 100%;
  height: calc(100vh - 170px);
  overflow: hidden;
  display: block;
}
section#specteescr .sp_button {
  display: none;
}

@media screen and (max-width: 1100px) {
  section#specteescr .mainColumn {
    width: 100%;
  }
  section#specteescr .sideColumn {
    display: none;
  }
  section#specteescr .sp_button {
    width: 100%;
    background: #fff;
    position: sticky;
    bottom: 0;
    left: 0;
    display: block;
    z-index: 50;
  }
  section#specteescr .sp_button a {
    padding: 15px;
    color: #fff;
    font-weight: 500;
    text-align: center;
    background: #2a62d3;
    display: block;
  }
}
@media screen and (max-width: 768px) {
  section#specteescr .sp_button a {
    padding: 10px;
    font-size: 12px;
  }
}

section#specteescr .visual {
  padding: 0 5%;
  background: #001531 url(../images/specteescr/visual_img.png) no-repeat center top / auto 100%;
}
section#specteescr .visual .inner {
  max-width: 1200px;
  height: 370px;
  margin: 0 auto;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
section#specteescr .visual .txt {
  width: 55%;
  padding: 40px 0;
}
section#specteescr .visual .txt h1 {
  color: #fff;
  font-size: clamp(17px, 2vw, 33px);
  font-weight: 600;
}
section#specteescr .visual .txt .box {
  margin: 30px 0 0 0;
  color: #fff;
  font-size: 15px;
}
@media screen and (max-width: 1400px) {
  section#specteescr .visual .txt .box {
    font-size: 13px;
  }
  section#specteescr .visual .txt .box br.tb {
    display: none;
  }
}
section#specteescr .visual .txt .box a {
  max-width: 420px;
  margin: 30px 0 0 0;
  display: block;
}
section#specteescr .visual .image {
  width: 50%;
  margin: -20px 0 0 0;
}
section#specteescr .block_video {
  padding: 40px 5% 20px;
}
section#specteescr .block_video .block_inner {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
section#specteescr .block_video p {
  color: #646464;
  font-size: 19px;
  font-weight: 700;
  position: relative;
  display: inline;
}
section#specteescr .block_video p::before {
  content: "";
  width: 1.5px;
  height: 20px;
  background: #646464;
  position: absolute;
  left: -12px;
  top: 5px;
  transform: rotate(-20deg);
}
section#specteescr .block_video p::after {
  content: "";
  width: 1.5px;
  height: 20px;
  background: #646464;
  position: absolute;
  right: -12px;
  top: 5px;
  transform: rotate(20deg);
}
section#specteescr .block_video h2 {
  width: 100%;
  font-size: 27px;
  font-weight: 600;
  text-align: center;
  position: relative;
}
section#specteescr .block_video h2 span {
  color: #194480;
  font-weight: 600;
}
section#specteescr .block_video video {
  width: 100%;
  margin: 20px 0 0 0;
}
section#specteescr .block_video .youtube {
  width: 100%;
  margin: 30px 0 0 0;
  padding-top: 56.25%;
  position: relative;
}
section#specteescr .block_video .youtube #player {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
section#specteescr .block {
  padding: 0 5%;
}
section#specteescr .block .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 60px 0 80px;
}
section#specteescr .block .service {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#specteescr .block .service .left {
  width: calc(60% - 40px);
}
section#specteescr .block .service .left h2 {
  margin: 0 0 30px 0;
  color: #2667d4;
  font-size: 23px;
  font-weight: 700;
}
section#specteescr .block .service .left h2 span {
  margin: 0 0 0 5px;
  font-size: 19px;
  font-weight: 700;
}
section#specteescr .block .service .left p {
  font-size: 29px;
  font-weight: 700;
}
section#specteescr .block .service .left p span {
  padding: 0 4px 3px 5px;
  margin: 0 2px 0 0;
  color: #fff;
  font-weight: 700;
  background: #2667d4;
}
@media screen and (max-width: 1660px) {
  section#specteescr .block .service .left h2 {
    font-size: 26px;
  }
  section#specteescr .block .service .left h2 span {
    font-size: 18px;
  }
  section#specteescr .block .service .left p {
    font-size: 26px;
  }
}
@media screen and (max-width: 1480px) {
  section#specteescr .block .service .left h2 {
    font-size: 22px;
  }
  section#specteescr .block .service .left h2 span {
    font-size: 15px;
  }
  section#specteescr .block .service .left p {
    font-size: 21px;
  }
}
@media screen and (max-width: 1340px) {
  section#specteescr .block .service .left h2 span {
    margin: 0;
    display: block;
  }
}
section#specteescr .block .service .right {
  width: 40%;
}
section#specteescr .block .merit {
  margin: 50px 0 0 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
section#specteescr .block .merit .left {
  width: 45%;
}
section#specteescr .block .merit .right {
  width: 55%;
}
section#specteescr .block .merit .right ul li {
  width: 90%;
  padding: 0 0 0 35px;
  background: url(../images/specteescr/arrow.png) no-repeat left center / 15px  auto;
}
section#specteescr .block .merit .right ul li:nth-child(2) {
  margin: 30px 0 0 5%;
}
section#specteescr .block .merit .right ul li:nth-child(3) {
  margin: 30px 0 0 10%;
}
section#specteescr .block .merit .right ul li dl {
  padding: 15px;
  border-radius: 5px;
  border: 1px solid #c5c5c5;
  box-shadow: 3px 3px 5px rgba(0,0,0,.2);
}
section#specteescr .block .merit .right ul li dl dt {
  margin: 0 0 10px 0;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 1640px) {
  section#specteescr .block .merit .right ul li dl dt {
    font-size: 20px;
  }
}
@media screen and (max-width: 1440px) {
  section#specteescr .block .merit .right ul li {
    margin-top: 20px!important;
  }
  section#specteescr .block .merit .right ul li dl br {
    display: none;
  }
  section#specteescr .block .merit .right ul li dl dt {
    font-size: 17px;
  }
}
section#specteescr .block .function {
  margin: 50px 0 0 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
section#specteescr .block .function h2 {
  width: 100%;
  margin: 0 0 30px 0;
  color: #2667d4;
  font-size: 23px;
  position: relative;
}
section#specteescr .block .function h2 em {
  padding: 0 30px 0 0;
  font-weight: 700;
  font-style: normal;
  background: #fff;
  position: relative;
  z-index: 2;
}
section#specteescr .block .function h2 span {
  margin: 0 0 0 5px;
  font-size: 19px;
  font-weight: 700;
}
section#specteescr .block .function h2::before {
  content: "";
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 0;
  top: 57%;
}
section#specteescr .block .function .outer {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap:60px;
}
section#specteescr .block .function .outer .box {
  width: calc(50% - 30px);
}
section#specteescr .block .function .outer .box h3 {
  margin: 0 0 20px 0;
  font-size: 28px;
  font-weight: 700;
}
@media screen and (max-width: 1640px) {
  section#specteescr .block .function .outer .box h3 {
    font-size: 22px;
  }
}
section#specteescr .block .function .outer .box h3 span {
  padding: 0 5px 3px 5px;
  margin: 0 3px 0 0;
  color: #fff;
  font-weight: 700;
  background: #2667d4;
}
section#specteescr .block .function .outer .box .flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#specteescr .block .function .outer .box .flex ul {
  width: calc(65% - 20px);
}
section#specteescr .block .function .outer .box .flex ul li {
  margin: 0 0 7px 0;
  padding: 0 0 0 15px;
  line-height: 1.5;
  background: url(../images/specteescr/check.png) no-repeat left 5px / 10px auto;
}
section#specteescr .block .function .outer .box .flex .img {
  width: 35%;
}
section#specteescr .block .function .outer .box .flex .img img.trans {
  transform: translate(0,-47px);
}
@media screen and (max-width: 1640px) {
  section#specteescr .block .function .outer .box .flex .img img.trans {
    transform: translate(0,-33px);
  }
}
@media screen and (max-width: 767px) {
  section#specteescr .block .function .outer .box .flex .img img.trans {
    transform: translate(0,0);
  }
}
@media screen and (max-width: 1420px) {
  section#specteescr .block .function .outer {
    gap:40px;
  }
  section#specteescr .block .function .outer .box {
    width: calc(50% - 20px);
  }
  section#specteescr .block .function .outer .box h3 {
    font-size: 20px;
  }
}

section#specteescr .block .banner {
  max-width: 720px;
  margin: 60px auto 0;
}

section#specteescr .block .banner .banner_sp {
  display: none;
}

@media screen and (max-width: 767px) {

  section#specteescr .block .banner {
  margin: 40px auto 0;
  }

  section#specteescr .block .banner .banner_pc {
    display: none;
  }
  section#specteescr .block .banner .banner_sp {
    display: block;
  }

}

@media screen and (max-width: 767px) {
  section#specteescr .visual {
    background: #001f40 url(../images/specteescr/visual_img_sp.png) no-repeat center bottom / auto 420px;
  }
  section#specteescr .visual .inner {
    max-width: 500px;
    height: auto;
  }
  section#specteescr .visual .txt {
    width: 100%;
    padding: 30px 0 230px;
  }
  section#specteescr .visual .txt .box {
    margin: 20px 0 0 0;
    font-size: 14px;
  }
  section#specteescr .visual .txt .box a {
    max-width: 350px;
    margin: 210px auto 0;
  }
  section#specteescr .block_video {
    padding: 30px 5% 10px;
  }
  section#specteescr .block_video .block_inner {
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
  }
  section#specteescr .block_video p {
    color: #646464;
    font-size: 19px;
    font-weight: 700;
    position: relative;
    display: inline;
  }
  section#specteescr .block_video p::before {
    content: "";
    width: 1.5px;
    height: 20px;
    background: #646464;
    position: absolute;
    left: -12px;
    top: 5px;
    transform: rotate(-20deg);
  }
  section#specteescr .block_video p::after {
    content: "";
    width: 1.5px;
    height: 20px;
    background: #646464;
    position: absolute;
    right: -12px;
    top: 5px;
    transform: rotate(20deg);
  }
  section#specteescr .block_video p {
    margin: 0 0 10px 0;
    font-size: 13px;
  }
  section#specteescr .block_video p::before {
    height: 15px;
    left: -12px;
    top: 3px;
  }
  section#specteescr .block_video p::after {
    height: 15px;
    right: -12px;
    top: 3px;
  }
  section#specteescr .block_video h2 {
    width: 100%;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    position: relative;
  }
  section#specteescr .block_video h2 span {
    color: #194480;
    font-weight: 600;
  }
  section#specteescr .block_video video {
    width: 100%;
    margin: 20px 0 0 0;
  }
  section#specteescr .block_video .youtube {
    margin: 20px 0 0 0;
  }
  section#specteescr .block .inner {
    padding: 20px 0 40px;
  }
  section#specteescr .block .service .left {
    width: 100%;
  }
  section#specteescr .block .service .left h2 {
    margin: 0 0 20px 0;
    font-size: 18px;
  }
  section#specteescr .block .service .left h2 span {
    font-size: 14px;
  }
  section#specteescr .block .service .left p {
    font-size: 16px;
  }
  section#specteescr .block .service .right {
    width: 100%;
    max-width: 250px;
    margin: 20px auto 0;
  }
  section#specteescr .block .merit {
    margin: 30px 0 0 0;
  }
  section#specteescr .block .merit .left {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
  }
  section#specteescr .block .merit .right {
    width: 100%;
  }
  section#specteescr .block .merit .right ul li {
    width: 100%;
    padding: 0;
    background: none;
  }
  section#specteescr .block .merit .right ul li:nth-child(2) {
    margin: 20px 0 0 0;
  }
  section#specteescr .block .merit .right ul li:nth-child(3) {
    margin: 20px 0 0 0;
  }
  section#specteescr .block .merit .right ul li dl {
    padding: 10px;
  }
  section#specteescr .block .merit .right ul li dl dt {
    margin: 0 0 5px 0;
    font-size: 16px;
  }
  section#specteescr .block .merit .right ul li dl dd {
    font-size: 13px;
  }
  section#specteescr .block .function {
    margin: 50px 0 0 0;
  }
  section#specteescr .block .function h2 {
    margin: 0 0 20px 0;
    font-size: 18px;
    position: relative;
  }
  section#specteescr .block .function h2 em {
    padding: 0;
  }
  section#specteescr .block .function h2 span {
    margin: 0;
    font-size: 14px;
    display: block;
  }
  section#specteescr .block .function h2::before {
    display: none;
  }
  section#specteescr .block .function .outer {
    gap:30px;
  }
  section#specteescr .block .function .outer .box {
    width: 100%;
  }
  section#specteescr .block .function .outer .box h3 {
    margin: 0 0 10px 0;
    font-size: 18px;
    font-weight: 700;
  }
  section#specteescr .block .function .outer .box .flex ul {
    width: 100%;
    font-size: 13px;
  }
  section#specteescr .block .function .outer .box .flex .img {
    width: 100%;
    margin: 10px auto 0;
    text-align: center;
  }
}

/* ********** TABS ********** */

section .block ul.tabs {
  margin: 0 0 20px 0;
  border-bottom: 3px solid #001531;
  display: flex;
  justify-content: space-between;
}
section .block ul.tabs li {
  flex: 1 1 100%;
  margin: 0 10px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  section .block ul.tabs li:first-child {
    margin: 0 10px 0 0;
  }
  section .block ul.tabs li:last-child {
    margin: 0 0 0 10px;
  }
}
section .block ul.tabs li a {
  padding: 8px 0;
  color: #5e7cac;
  font-size: 22px;
  font-weight: 600;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  background: #bac7dc;
  display: block;
  transition: .3s;
}
@media screen and (max-width: 1000px) {
  section .block ul.tabs li a {
    font-size: 18px;
    letter-spacing: 0;
  }
}
section .block ul.tabs li.current a,
section .block ul.tabs li a:hover {
  color: #fff;
  background: #5e7cac;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  section .block ul.tabs {
    margin: 0 0 10px 0;
    flex-wrap: wrap;
  }
  section .block ul.tabs li {
    width: calc(50% - 5px);
    margin: 0 10px 10px 0;
    flex: 0 0 auto;
  }
  section .block ul.tabs li:nth-child(even) {
    margin: 0 0 10px 0;
  }
  section .block ul.tabs li a {
    font-size: 15px;
    border-radius: 0;
  }
}

/* ********** PAGER ********** */

section .block .pager ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
section .block .pager ul li {
  margin: 0 5px;
  text-align: center;
  line-height: 1.8;
}
section .block .pager ul li span {
  width: 40px;
  height: 40px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  border: 1px solid #2667d7;
  background: #2667d7;
  display: block;
}
section .block .pager ul li a.page-numbers {
  width: 40px;
  height: 40px;
  color: #2667d7;
  font-size: 20px;
  font-weight: 600;
  border: 1px solid #2667d7;
  display: block;
}
section .block .pager ul li .dots {
  color: #2667d7;
  border: none;
  background: #fff;
}
section .block .pager ul li a.page-numbers:hover {
  color: #fff;
  background: #2667d7;
  opacity: 1;
}
section .block .pager ul li .next {
  position: relative;
}
section .block .pager ul li .next:hover {
  color: #fff;
  background: #2667d7;
}
section .block .pager ul li .next:after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #2667d7;
  border-right: 2px solid #2667d7;
  position: absolute;
  top: 13px;
  right: 16px;
  transform: rotate(45deg);
  transition: .3s;
}
section .block .pager ul li .next:hover:after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
section .block .pager ul li .prev {
  position: relative;
}
section .block .pager ul li .prev:hover {
  color: #fff;
  background: #2667d7;
}
section .block .pager ul li .prev:after {
  content: "";
  width: 10px;
  height: 10px;
  border-left: 2px solid #2667d7;
  border-bottom: 2px solid #2667d7;
  position: absolute;
  top: 13px;
  left: 16px;
  transform: rotate(45deg);
  transition: .3s;
}
section .block .pager ul li .prev:hover:after {
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
}

@media screen and (max-width: 767px) {
  section .block .pager ul {
    margin: 20px 0;
  }
  section .block .pager ul li {
    margin: 0 3px;
  }
  section .block .pager ul li span {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
  section .block .pager ul li a.page-numbers {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
  section .block .pager ul li .next:after {
    width: 8px;
    height: 8px;
    top: 9px;
    right: 11px;
  }
  section .block .pager ul li .prev:after {
    width: 8px;
    height: 8px;
    top: 9px;
    left: 11px;
  }
}

/* ********** SLIDER ********** */

section .block_slide {
  padding: 0 50px;
  position: relative;
}
section .block_slide h3 {
  margin: 100px 0 30px 0;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
}
section .block_slide div a {
  display: block;
}
section .block_slide .image {
  margin: 0 0 10px 0;
  position: relative;
}
section .block_slide .image figure {
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section .block_slide .image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section .block_slide .image .new {
  width: 45px;
  height: 45px;
  background: url(../images/common/new.png) no-repeat center top / 100% auto;
  position: absolute;
  top: 0;
  right: 0;
}
section .block_slide div ul {
  margin: 0 0 5px 0;
  display: flex;
  flex-wrap: wrap;
}
section .block_slide div ul li {
  margin: 0 5px 5px 0;
  padding: 5px;
  color: #727171;
  font-size: 10px;
  line-height: 1;
  background: #c3c4c4;
}
section .block_slide.case div dl dt {
  margin: 0 0 5px 0;
  font-size: 18px;
  font-weight: 600;
}
section .block_slide.case div dl dd {
  color: #194480;
  font-size: 14px;
  font-weight: 600;
}
section .block_slide.contents div em {
  padding: 5px 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  font-style: normal;
  line-height: 1;
  border-radius: 20px;
  background: #194480;
  position: absolute;
  top: 10px;
  left: 10px;
}
section .block_slide.contents div p {
  color: #194480;
  font-size: 14px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  section .block_slide {
    padding: 0 50px;
    position: relative;
  }
  section .block_slide h3 {
    width: calc(100% + 100px);
    margin: 60px 0 20px -50px;
    font-size: 18px;
  }
  section .block_slide div img {
    width: 100%;
    margin: 0 0 10px 0;
  }
  section .block_slide.case div dl dd {
    font-size: 12px;
  }	
  section .block_slide.contents div em {
    font-size: 10px;
  }
  section .block_slide.contents div p {
    font-size: 12px;
  }
}

/* ********** API ********** */

section#api .block {
  padding: 0 5% 100px;
}
section#api .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}
section#api .block h2 {
  margin: 0 0 60px 0;
  text-align: center;
}
section#api .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 33px;
  font-weight: 600;
  display: inline;
}
section#api .block .lead {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#api .block .lead .txt {
  width: 40%;
  font-size: 16px;
}
section#api .block .lead .img {
  width: 55%;
}
section#api .block .box {
  margin: 60px 0 40px 0;
  padding: 40px 40px 60px 40px;
  border: 5px solid #d1dae7;
}
section#api .block .box .center {
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
}
section#api .block .box .center h3 {
  padding: 0 5px 5px;
  font-size: 24px;
  font-weight: 600;
  display: inline;
  border-bottom: 1px solid #000;
}
section#api .block .box .center p {
  margin: 30px 0 0 0;
  font-size: 16px;
}
section#api .block .box ul {
  max-width: 1000px;
  margin: 60px auto 0;
  display: flex;
  justify-content: space-between;
  align-items: atretch;
  flex-wrap: wrap;
}
section#api .block .box ul li {
  width: calc(50% - 20px);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  border-bottom: 2px solid #194480;
  display: flex;
  align-items: center;
}
section#api .block .box ul li dl {
  width: 100%;
  padding: 15px 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
section#api .block .box ul li dl dt {
  width: 36px;
}
section#api .block .box ul li dl dd {
  width: calc(100% - 46px);
}
section#api .block .btn {
  text-align: center;
}
section#api .block .btn a {
  padding: 10px 30px 12px;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;
  border: 2px solid #194480;
  border-radius: 30px;
  display: inline-block;
}
section#api .block .btn a:hover {
  color: #fff;
  background: #194480;
  opacity: 1;
}

section#api .block .banner {
  text-align: center;
}

section#api .block .banner a{
  text-align: center;
}

section#api .block .banner img {
  text-align: center;
  margin: 30px auto;
}

section#api .block .banner:hover {
  opacity: 1;
}


@media screen and (max-width: 767px) {

  section#api .block {
    padding: 0 5% 40px;
  }
  section#api .block h2 {
    margin: 0 0 30px 0;
  }
  section#api .block h2 {
    margin: 0 0 30px 0;
  }
  section#api .block h2 span {
    font-size: 20px;
  }
  section#api .block .lead .txt {
    width: 100%;
    font-size: 14px;
  }
  section#api .block .lead .img {
    width: 100%;
    margin: 20px 0 0 0;
  }
  section#api .block .box {
    margin: 30px 0 30px 0;
    padding: 20px 20px 30px 20px;
    border: 5px solid #d1dae7;
  }
  section#api .block .box .center h3 {
    font-size: 18px;
  }
  section#api .block .box .center p {
    margin: 30px 0 0 0;
    font-size: 14px;
  }
  section#api .block .box ul {
    margin: 30px auto 0;
  }
  section#api .block .box ul li {
    width: 100%;
    font-size: 13px;
  }
  section#api .block .box ul li dl {
    padding: 10px 0;
  }
  section#api .block .box ul li dl dt {
    width: 36px;
  }
  section#api .block .box ul li dl dd {
    width: calc(100% - 46px);
  }
  section#api .block .btn a {
    padding: 10px 20px 12px;
    font-size: 13px;
    letter-spacing: 0;
  }
  section#api .block .btn a:hover {
    color: #fff;
    background: #194480;
    opacity: 1;
  }






}


/* ********** CASE ********** */

section#case .block {
  padding: 0 5% 100px;
}
section#case .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}
section#case .block h2 {
  margin: 0 0 40px 0;
  text-align: center;
}
section#case .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}
section#case .block .download {
  margin: 0 0 40px 0;
  padding: 20px 50px;
  border: 1px solid #d2d2d2;
}
section#case .block .download h3 {
  margin: 0 0 5px 0;
  color: #0b4383;
  font-size: 22px;
  font-weight: 600;
}
section#case .block .download .flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 30px;
}
section#case .block .download .txt {
  flex: 1;  
}
section#case .block .download .txt p {
  font-size: 19px;
  line-height: 1.5;
}
section#case .block .download a {
  width: 300px;
  padding: 10px 0;
  color: #fff;
  font-size: 19px;
  text-align: center;
  border-radius: 5px;
  background: #2667d6;
  display: block;
}
@media screen and (max-width: 1360px) {
  section#case .block .download .txt p {
    font-size: 18px;
    line-height: 1.5;
  }
}
@media screen and (max-width: 1100px) {
  section#case .block .download h3 {
    font-size: 20px;
  }
  section#case .block .download .txt p {
    font-size: 16px;
  }
  section#case .block .download a {
    width: 220px;
    font-size: 17px;
  }
}
section#case .block .item_wrap {
  margin: 40px 0 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 2%;
}
section#case .block .item_wrap .item {
  width: 32%;
  margin: 0 0 20px 0;
}
section#case .block .item_wrap .item a {
  width: 100%;
  display: block;
}
section#case .block .item_wrap .item .image {
  margin: 0 0 10px 0;
  position: relative;
}
section#case .block .item_wrap .item .image figure {
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section#case .block .item_wrap .item .image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section#case .block .item_wrap .item .image .new {
  width: 45px;
  height: 45px;
  background: url(../images/common/new.png) no-repeat center top / 100% auto;
  position: absolute;
  top: 0;
  right: 0;
}
section#case .block .item_wrap .item ul {
  margin: 0 0 5px 0;
  display: flex;
  flex-wrap: wrap;
}
section#case .block .item_wrap .item ul li {
  margin: 0 5px 5px 0;
  padding: 5px;
  color: #727171;
  font-size: 10px;
  line-height: 1;
  background: #c3c4c4;
}
section#case .block .item_wrap .item dl dt {
  margin: 0 0 5px 0;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
}
section#case .block .item_wrap .item dl dd {
  color: #595757;
  font-size: 15px;
}

@media screen and (max-width: 767px) {
  section#case .block {
    padding: 0 5% 30px;
  }
  section#case .block h2 {
    margin: 0 0 30px 0;
  }
  section#case .block h2 span {
    font-size: 20px;
  }
  section#case .block .download {
    margin: 0 0 30px 0;
    padding: 20px;
  }
  section#case .block .download .flex {
    display: flex;
    gap: 15px;
  }
  section#case .block .download .txt {
    width: 100%;
    flex: auto;
  }
  section#case .block .download .txt p {
    font-size: 14px;
  }
  section#case .block .download a {
    width: 100%;
  }
  section#case .block .item_wrap {
    margin: 30px 0 40px 0;
    display: block;
  }
  section#case .block .item_wrap .item {
    width: 100%;
    margin: 0 0 30px 0!important;
  }
  section#case .block .item_wrap .item a {
    width: 100%;
    display: block;
  }
  section#case .block .item_wrap .item .image {
    width: 100%!important;
  }
  section#case .block .item_wrap .item .inner {
    width: 100%!important;
  }
  section#case .block .item_wrap .item ul {
    margin: 0 0 5px 0;
    display: flex;
    flex-wrap: wrap;
  }
  section#case .block .item_wrap .item ul li {
    margin: 0 5px 5px 0;
    padding: 5px;
    color: #727171;
    font-size: 10px;
    line-height: 1;
    background: #c3c4c4;
  }
  section#case .block .item_wrap .item dl dt {
    margin: 0 0 5px 0;
    font-size: 16px;
  }
  section#case .block .item_wrap .item dl dd {
    color: #194480;
    font-size: 12px;
    font-weight: 600;
  }
  section#case .block .item_wrap .item:first-of-type a {
    display: block;
  }
  section#case .block .item_wrap .item:first-of-type dl dt {
    font-size: 14px;
  }
  section#case .block .item_wrap .item:first-of-type dl dd {
    font-size: 12px;
  }
}

/* ********** CASE SINGLE ********** */

section#case-single .block {
  padding: 0 5%;
}
section#case-single .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#case-single .block .content {
  padding: 0 0 100px 0;
}
section#case-single .block .content h1 {
  margin: 0 0 40px 0;
  font-size: 45px;
  font-weight: 600;
  line-height: 1.4;
}
section#case-single .block .content h1 span {
  font-weight: 600;
}
section#case-single .block .content h2 {
  margin: 60px 0 40px;
  padding: 0 0 10px 0;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.4;
  border-bottom: 1px solid #000;
}
section#case-single .block .content h3 {
  margin: 60px 0 40px;
  color: #194480;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.4;
}
section#case-single .block .content h4 {
  margin: 60px 0 40px;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.4;
}
section#case-single .block .content p + p {
  margin: 40px 0 0 0;
}
section#case-single .block .content strong {
  color: #bf1919;
}
section#case-single .block .content b {
  font-weight: 600;
}
section#case-single .block .content figure {
  margin: 40px 0;
}
section#case-single .block .content figure figcaption {
  margin: 10px 0 0 0;
  font-size: 12px;
}
section#case-single .block .content a {
  color: #194480;
  text-decoration: underline;
}
section#case-single .block .content a:hover {
  opacity: 1;
  text-decoration: none;
}
section#case-single .block .summary {
  margin: 0 0 100px 0;
  font-size: 21px;
}
section#case-single .block .summary ul {
  margin: 20px 0 10px 0;
  display: flex;
  flex-wrap: wrap;
}
section#case-single .block .summary ul li {
  margin: 0 10px 10px 0;
  padding: 5px;
  color: #727171;
  font-size: 12px;
  line-height: 1;
  background: #c3c4c4;
}
section#case-single .block .summary dl {
  margin: -20px 0 0 0;
}
section#case-single .block .summary dl dt {
  margin: 40px 0 20px 0;
  padding: 10px 0 5px;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline-block;
}
section#case-single .block .newspaper {
  font-size: 18px;
}
section#case-single .block .newspaper .flex {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  justify-content: space-between;
}
section#case-single .block .newspaper .flex figure {
  width: 42%;
  margin: 0;
}
section#case-single .block .newspaper .flex .txt {
  width: 55%;
}
section#case-single .block a.back {
  width: 220px;
  margin: 0 auto;
  padding: 8px 0 8px 28px;
  font-size: 18px;
  line-height: 1;
  background: url(../images/top/news_icon2.jpg) no-repeat left center / 14px auto;
  display: block;
}
section#case-single .block a.btn {
  width: 320px;
  margin: 50px auto 0;
  padding: 10px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  border-radius: 30px;
  background: #194480;
  font-size: 20px;
  display: block;
}

@media screen and (max-width: 767px) {
  section#case-single .block {
    padding: 0 5% 30px;
  }
  section#case-single .block .block_inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
  }
  section#case-single .block .content {
    padding: 0 0 20px 0;
  }
  section#case-single .block .content h1 {
    margin: 0 0 30px 0;
    font-size: 22px;
  }
  section#case-single .block .content h2 {
    margin: 30px 0 20px;
    font-size: 20px;
  }
  section#case-single .block .content h3 {
    margin: 30px 0 20px;
    font-size: 18px;
  }
  section#case-single .block .content h4 {
    margin: 30px 0 20px;
    font-size: 16px;
  }
  section#case-single .block .content p + p {
    margin: 20px 0 0 0;
  }
  section#case-single .block .content figure {
    margin: 20px 0;
  }
  section#case-single .block .content figure figcaption {
    font-size: 10px;
  }
  section#case-single .block .summary {
    margin: 0 0 40px 0;
    font-size: 14px;
  }
  section#case-single .block .summary ul {
    margin: 20px 0 10px 0;
  }
  section#case-single .block .summary ul li {
    margin: 0 5px 5px 0;
    font-size: 10px;
  }
  section#case-single .block .summary dl {
    margin: -20px 0 0 0;
  }
  section#case-single .block .summary dl dt {
    margin: 20px 0 10px 0;
    padding: 5px 15px;
    font-size: 14px;
  }
  section#case-single .block .newspaper {
    font-size: 13px;
  }
  section#case-single .block .newspaper .flex {
    display: block;
  }
  section#case-single .block .newspaper .flex figure {
    width: 100%;
    margin: 20px 0;
  }
  section#case-single .block .newspaper .flex .txt {
    width: 100%;
  }
  section#case-single .block a.back {
    width: 170px;
    padding: 8px 0 8px 25px;
    font-size: 14px;
    background: url(../images/top/news_icon2.jpg) no-repeat left center / 12px auto;
    display: block;
  }
  section#case-single .block a.btn {
    width: 300px;
    margin:  30px auto 0;
    font-size: 16px;
  }
}

/* ********** REPORT ********** */

section#report .block {
  padding: 0 5% 100px;
}
section#report .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#report .block h2 {
  margin: 0 0 60px 0;
  text-align: center;
}
section#report .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}
section#report .block .search {
  padding: 20px;
  border: 1px solid #d2d2d2;
  position: relative;
}
section#report .block .search h3 {
  margin: 0 auto 20px;
  color: #505050;
  line-height: 1;
  text-align: center;
}
section#report .block .search h3 span {
  padding: 0 22px 0 0;
  font-size: 18px;
  font-weight: 600;
  background: url(../images/common/ico_search.png) no-repeat right 7px / 15px auto;
}
section#report .block .search .clear {
  position: absolute;
  top: 15px;
  right: 20px;
}
section#report .block .search .clear a {
  padding: 8px 8px 8px 23px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
  background: url(../images/common/ico_clear.png) no-repeat 5px 11px / 12px auto;

}
section#report .block .search form {
  max-width: 1000px;
  margin: 0 auto;
}
section#report .block .search form ul {
  text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
section#report .block .search form ul li {
  margin: 0;
  padding: 0;
}
section#report .block .search form label {
  padding: 2px 15px 3px;
  font-size: 15px;
  font-weight: 500;
  border-radius: 30px;
  border: 1px solid #2667d7;
  transition: .2s;
}
section#report .block .search form input[type=submit] {
  display: none;
}
@media screen and (max-width: 1160px) {
  section#report .block .search form label {
    font-size: 13px;
  }
}
section#report .block .search form label:hover {
  background: #d4e1f7;
}
section#report .block .search form label:has(input:checked) {
  color: #fff;
  background: #2667d7;
}
section#report .block .search form label input {
  position: absolute;
  appearance: none;
}
section#report .block .item_wrap {
  margin: 30px 0 40px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 2%;
}
section#report .block .item_wrap .item {
  width: 32%;
  border-bottom: 1px solid #d2d2d2;
  display: flex;
}
section#report .block .item_wrap .item a {
  width: 100%;
  display: flex;
  flex-direction: column;
}
section#report .block .item_wrap .item .image {
  margin: 0 0 10px 0;
  position: relative;
}
section#report .block .item_wrap .item .image figure {
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section#report .block .item_wrap .item .image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section#report .block .item_wrap .item time {
  margin: 10px 0 5px 0;
  color: #808080;
  font-size: 12px;
  font-weight: 600;
  display: block;
}
section#report .block .item_wrap .item p {
  color: #0b4383;
  font-size: 16px;
  font-weight: 600;
}
section#report .block .item_wrap .item .inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

section#report .mailmag {
  max-width: 760px;
  margin: 60px auto;
  text-align: center;
}

@media screen and (max-width: 767px) {
  section#report .block {
    padding: 0 5% 30px 5%;
  }
  section#report .block h2 {
    margin: 0 0 30px 0;
  }
  section#report .block h2 span {
    font-size: 20px;
  }
  section#report .block .search {
    padding: 15px;
  }
  section#report .block .search h3 span {
    padding: 0 18px 0 0;
    font-size: 15px;
    font-weight: 600;
    background: url(../images/common/ico_search.png) no-repeat right 7px / 12px auto;
  }
  section#report .block .search .clear {
    margin: 5px 0 0 0;
    text-align: center;
    position: static;
  }
  section#report .block .search form ul {
    gap: 7px;
  }
  section#report .block .search form label {
    padding: 2px 10px 3px;
    font-size: 10px;
  }
  section#report .block .item_wrap {
    margin: 20px 0 0 0;
    display: block;
  }
  section#report .block .item_wrap .item {
    width: 100%;
    margin: 0 0 30px 0;
  }
  section#report .block .item_wrap .item a {
    width: 100%;
    display: block;
  }
  section#report .block .item_wrap .item .image {
    width: 100%!important;
  }
  section#report .block .item_wrap .item img {
    width: 100%;
    margin: 0 0 10px 0;
  }
  section#report .block .item_wrap .item .inner {
    width: 100%!important;
  }
  section#report .block .item_wrap .item p {
    font-size: 14px;
  }
  section#report .block .item_wrap .item time {
    margin: 5px 0;
    font-size: 10px;
  }
  section#report .mailmag {
    margin: 30px 0;
  }
}

/* ********** CONTENTS SINGLE ********** */

section#report-single .block {
  padding: 40px 5% 100px;
  overflow: hidden;
}
section#report-single .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#report-single .block .mainContent {
  width: 65%;
}
section#report-single .block .content {
  color: #4d4d4d;
}
section#report-single .block .content h1 {
  margin: 0 0 20px 0;
  color: #194480;
  font-size: 30px;
  font-weight: 600;
  line-height: 1.4;
}
section#report-single .block .content h1 span {
  font-weight: 600;
}
section#report-single .block .content h2 {
  margin: 60px 0 40px;
  padding: 0 0 10px 16px;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.4;
  border-bottom: 1px solid #000;
  position: relative;
}
section#report-single .block .content h2::before {
  content: "";
  width: 6px;
  height: calc(100% - 20px);
  background: #0b4383;
  display: block;
  position: absolute;
  top: 7px;
  left: 0;
}
section#report-single .block .content .newspaper h3 {
  margin: 60px 0 40px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.4;
}
section#report-single .block .content .newspaper h4 {
  margin: 60px 0 40px;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.4;
}
section#report-single .block .content .newspaper p {
  margin: 30px 0;
  line-height: 2;
}
section#report-single .block .content .newspaper strong {
  color: #bf1919;
}
section#report-single .block .content .newspaper b {
  font-weight: 600;
}
section#report-single .block .content .newspaper figure {
  margin: 40px auto;
}
section#report-single .block .content .newspaper figure figcaption {
  margin: 10px 0 0 0;
  font-size: 12px;
}
section#report-single .block .content .newspaper dl {
  margin: 40px 0;
}
section#report-single .block .content .newspaper dl dt {
  font-size: 24px;
  font-weight: 600;
  line-height: 2;
}
section#report-single .block .content .newspaper dl dd {
  margin: 5px 0 0 0;
  line-height: 2.5;
}
section#report-single .block .content .newspaper dl dd + dt {
  margin: 20px 0 0 0;
}

section#report-single .block .content .newspaper ul {
  line-height: 2.2;
}
section#report-single .block .content .newspaper a {
  color: #194480;
  text-decoration: underline;
}
section#report-single .block .content .newspaper a:hover {
  opacity: 1;
  text-decoration: none;
}
section#report-single .block .title {
  margin: 0 0 30px 0;
}
section#report-single .block .title time {
  font-size: 14px;
  font-weight: 600;
}
section#report-single .block .title ul {
  margin: 30px 0 10px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
section#report-single .block .title ul li {
  padding: 5px 10px 6px;
  color: #464646;
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  border-radius: 30px;
  border: 1px solid #464646;
}
section#report-single .block .newspaper {
  font-size: 16px;
}
section#report-single .block .addtoany_header {
  margin: 40px 0 16px 0;
  font-size: 10px;
}
section#report-single .block .newspaper iframe {
  max-width: 550px;
  margin: 0 auto;
}
section#report-single .block a.back {
  width: 240px;
  margin: 0 auto;
  padding: 8px 0 8px 28px;
  font-size: 18px;
  line-height: 1;
  background: url(../images/top/news_icon2.jpg) no-repeat left center / 14px auto;
  display: block;
}
section#report-single .block a.btn {
  width: 320px;
  margin: 50px auto 0;
  padding: 10px;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  border-radius: 30px;
  background: #194480;
  font-size: 20px;
  display: block;
}
section#report-single .block .newspaper .mailmag {
  margin: 0 0 60px 0;
  text-align: center;
}


section#report-single .block .newspaper .cv_button {
  margin: 30px 0;
  padding: 20px 8%;
  text-align: center;
  border-radius: 10px;
  background: #e3e3e3;
}
section#report-single .block .newspaper .cv_button p.cv_ttl {
  margin: 0 0 10px 0;
  font-size: 18px;
  font-weight: 700;
}
section#report-single .block .newspaper .cv_button .flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#report-single .block .newspaper .cv_button .flex a {
  width: 100%;
  margin: 10px 0 0 0;
  padding: 15px 0 10px 0;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  text-decoration: none;
  border-radius: 5px;
  display: block;
}
section#report-single .block .newspaper .cv_button .flex a:hover {
  opacity: .7;
}
section#report-single .block .newspaper .cv_button .flex a img {
  max-width: 110px;
  margin: 0 auto;
  display: block;
}
section#report-single .block .newspaper .cv_button .flex > div {
  width: calc(50% - 15px);
}
section#report-single .block .newspaper .cv_button .flex > div > img {
  display: block;
}
section#report-single .block .newspaper .cv_button .flex .pro a {
  background: #194489;
}
section#report-single .block .newspaper .cv_button .flex .scr a {
  background: #2a62cd;
}
@media screen and (max-width: 1140px) {
  section#report-single .block .newspaper .cv_button {
    padding: 20px 5%;
  }
  section#report-single .block .newspaper .cv_button .flex > div {
    width: calc(50% - 10px);
  }
  section#report-single .block .newspaper .cv_button .flex a {
    font-size: 18px;
  }
}
@media screen and (max-width: 860px) {
  section#report-single .block .newspaper .cv_button p.cv_ttl {
    font-size: 16px;
  }
  section#report-single .block .newspaper .cv_button {
    padding: 20px;
  }
  section#report-single .block .newspaper .cv_button .flex a {
    font-size: 15px;
  }
}
@media screen and (max-width: 500px) {
  section#report-single .block .newspaper .cv_button .flex > div {
    width: 100%;
  }
  section#report-single .block .newspaper .cv_button .flex > div + div {
    margin: 20px 0 0 0;
  }
}

section#report-single .block .cv_download {
  margin: 30px 0 0 0;
  padding: 30px 8%;
  text-align: center;
  border-radius: 10px;
  background: #e3e3e3;
}
section#report-single .block .cv_download h3 {
  margin: 0 0 20px 0;
  color: #0b4383;
  font-size: 21px;
  font-weight: 700;
}
section#report-single .block .cv_download img {
  width: 100%;
  max-width: 500px;
}
section#report-single .block .cv_download .btn {
  margin: 20px 0 0 0;
  display: flex;
  justify-content: space-between;
}
section#report-single .block .cv_download .btn a {
  width: calc(50% - 15px);
  padding: 10px 0;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  border-radius: 5px;
  display: block;
}
section#report-single .block .cv_download .btn a.pro {
  background: #194489;
}
section#report-single .block .cv_download .btn a.scr {
  background: #2a62cd;
}
@media screen and (max-width: 1140px) {
  section#report-single .block .cv_download {
    padding: 30px 5%;
  }
  section#report-single .block .cv_download .btn a {
    width: calc(50% - 10px);
    font-size: 18px;
  }
}
@media screen and (max-width: 860px) {
  section#report-single .block .cv_download h3 {
    margin: 0 0 15px 0;
    font-size: 16px;
  }
  section#report-single .block .cv_download {
    margin: 0 0 30px 0;
    padding: 20px;
  }
  section#report-single .block .cv_download .btn a {
    width: calc(50% - 10px);
    font-size: 15px;
  }
}
@media screen and (max-width: 500px) {
  section#report-single .block .cv_download .btn a {
    font-size: 12px;
  }
  section#report-single .block .cv_download .btn a.pro {
    width: calc(45% - 5px);
  }
  section#report-single .block .cv_download .btn a.scr {
    width: calc(55% - 5px);
  }
}

section#report-single .block .sideColumn {
  width: 30%;
}
section#report-single .block .sideColumn h2 {
  margin: 0 0 20px 0;
  padding: 0 0 5px 0;
  color: #0b4383;
  font-size: 17px;
  font-feature-settings: "palt";
  font-weight: 600;
  letter-spacing: 1px;
  border-bottom: 1px solid #0b4383;
}
section#report-single .block .sideColumn .popular {
  margin: 0 0 30px 0;
}
section#report-single .block .sideColumn .popular ul li + li {
  margin: 15px 0 0 0;
}
section#report-single .block .sideColumn .popular ul li a {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: flex-start;
}
section#report-single .block .sideColumn .popular ul li a figure {
  width: 35%;
  aspect-ratio: 3 / 2;
  display: block;

}
section#report-single .block .sideColumn .popular ul li a figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section#report-single .block .sideColumn .popular ul li a .txt {
  width: 60%;
}
section#report-single .block .sideColumn .popular ul li a .txt h3 {
  font-size: 13px;
  line-height: 1.5;
}
section#report-single .block .sideColumn .popular ul li a .txt time {
  margin: 10px 0 0 0;
  color: #808080;
  font-size: 12px;
  display: block;
}
section#report-single .block .sideColumn .category {
  margin: 0 0 30px 0;
}
section#report-single .block .sideColumn .category ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
section#report-single .block .sideColumn .category ul li a {
  padding: 5px 10px 6px;
  font-size: 13px;
  line-height: 1;
  border-radius: 30px;
  border: 1px solid #464646;
  display: block;
}
section#report-single .block .sideColumn .category ul li a:hover {
  color: #fff;
  background: #464646;
  opacity: 1;
}
section#report-single .block .sideColumn .seminar-info {
  margin: 0 0 30px 0;
}
section#report-single .block .sideColumn .seminar-info ul li + li {
  margin: 15px 0 0 0;
}
section#report-single .block .sideColumn .documents a.button {
  max-width: 280px;
  margin: 20px auto 0;
  padding: 10px 0;
  color: #fff;
  font-weight: 600;
  text-align: center;
  border-radius: 30px;
  background: #2a62cd;
  display: block;
}
section#report-single .block .sideColumn .documents ul li + li {
  margin: 30px 0 0 0;
}

@media screen and (max-width: 767px) {
  section#report-single .block {
    padding: 0 20px 30px;
  }
  section#report-single .block .block_inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
  }
  section#report-single .block .mainContent {
    width: 100%;
  }
  section#report-single .block .content h1 {
    margin: 0 0 10px 0;
    font-size: 20px;
  }
  section#report-single .block .content .newspaper h2 {
    margin: 30px 0 20px;
    padding: 0 0 10px 14px;
    font-size: 20px;
  }
  section#report-single .block .content .newspaper h2::before {
    width: 4px;
    height: calc(100% - 16px);
    background: #0b4383;
    display: block;
    position: absolute;
    top: 5px;
  }
  section#report-single .block .content .newspaper h3 {
    margin: 30px 0 20px;
    font-size: 18px;
  }
  section#report-single .block .content .newspaper h4 {
    margin: 30px 0 20px;
    font-size: 16px;
  }
  section#report-single .block .content .newspaper p {
    margin: 20px 0;
  }
  section#report-single .block .content .newspaper figure {
    margin: 20px auto;
  }
  section#report-single .block .content .newspaper figure figcaption {
    font-size: 10px;
  }
  section#report-single .block .content .newspaper dl {
    margin: 20px 0 20px;
  }
  section#report-single .block .content .newspaper dl dt {
    font-size: 18px;
  }
  section#report-single .block .title {
    font-size: 14px;
  }
  section#report-single .block .title time {
    font-size: 12px;
  }
  section#report-single .block .title ul {
    margin: 20px 0 10px 0;
    gap: 7px;
  }
  section#report-single .block .title ul li {
    font-size: 10px;
  }
  section#report-single .block .newspaper {
    font-size: 14px;
  }
  section#report-single .block a.back {
    width: 180px;
    padding: 8px 0 8px 25px;
    font-size: 14px;
    background: url(../images/top/news_icon2.jpg) no-repeat left center / 12px auto;
    display: block;
  }
  section#report-single .block a.btn {
    width: 300px;
    margin:  30px auto 0;
    font-size: 16px;
  }
  section#report-single .block .sideColumn {
    width: 100%;
  }
  section#report-single .block .sideColumn h2 {
    font-size: 16px;
  }
  section#report-single .block .sideColumn .category ul {
    gap: 7px;
  }
  section#report-single .block .sideColumn .category ul li a {
    font-size: 12px;
  }
}

/* ********** POST ********** */

.list-bullet,
.list-order,
.list-alpha,
.list-chara {
  padding-left: 1.2em;
  margin: 20px 0;
}
.list-bullet>li+li,
.list-order>li+li,
.list-alpha>li+li,
.list-chara>li+li {
  margin-top: .5em;
}
.list-bullet {
  list-style-type: disc;
}
.list-order {
  list-style-type: decimal;
}
.list-alpha {
  list-style-type: lower-latin;
}
.list-chara {
  list-style: none;
}
.list-chara>li:before {
  content: attr(data-list-chara);
  display: inline-block;
  width: 1.2em;
  margin-left: -1.2em;
  text-align: center;
}
.panel {
  margin: 40px auto;
  padding: 0 40px;
  border: #ccc solid 2px;
  border-radius: 4px;
}
.w90 {
  width: 90%;
}
.w80 {
  width: 80%;
}
.w70 {
  width: 70%;
}
.w60 {
  width: 60%;
}
.w50 {
  width: 50%;
}
.w40 {
  width: 40%;
}
.w30 {
  width: 30%;
}
.w20 {
  width: 20%;
}
.w10 {
  width: 10%;
}

@media only screen and (min-width:769px) {
  
  .wpc90 {
    width: 90%;
  }
  .wpc80 {
    width: 80%;
  }
  .wpc70 {
    width: 70%;
  }
  .wpc60 {
    width: 60%;
  }
  .wpc50 {
    width: 50%;
  }
  .wpc40 {
    width: 40%;
  }
  .wpc30 {
    width: 30%;
  }
  .wpc20 {
    width: 20%;
  }
  .wpc10 {
    width: 10%;
  }
}

@media screen and (max-width: 767px) {
  .panel {
    margin: 20px auto;
    padding: 0 20px;
  }
  .wsp90 {
    width: 90%
  }
  .wsp80 {
    width: 80%
  }
  .wsp70 {
    width: 70%
  }
  .wsp60 {
    width: 60%
  }
  .wsp50 {
    width: 50%
  }
  .wsp40 {
    width: 40%
  }
  .wsp30 {
    width: 30%
  }
  .wsp20 {
    width: 20%
  }
  .wsp10 {
    width: 10%
  }
}

/* ********** SEMINAR ********** */

section#seminar .block {
  padding: 0 5% 100px;
  position: relative;
}
section#seminar .block .inner {
  max-width: 1200px;
  margin: 0 auto;
}
section#seminar .block + .block {
  margin: 40px 0 100px;
}
section#seminar .block h1,
section#seminar .block h2 {
  margin: 0 0 30px 0;
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
  border-bottom: 2px solid #194480;
}
section#seminar .block .search {
  padding: 20px;
  border: 1px solid #d2d2d2;
  position: relative;
}
section#seminar .block .search h3 {
  margin: 0 auto 20px;
  color: #505050;
  line-height: 1;
  text-align: center;
}
section#seminar .block .search h3 span {
  padding: 0 22px 0 0;
  font-size: 18px;
  font-weight: 600;
  background: url(../images/common/ico_search.png) no-repeat right 7px / 15px auto;
}
section#seminar .block .search .clear {
  position: absolute;
  top: 15px;
  right: 20px;
}
section#seminar .block .search .clear a {
  padding: 8px 8px 8px 23px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
  background: url(../images/common/ico_clear.png) no-repeat 5px 11px / 12px auto;

}
section#seminar .block .search form {
  max-width: 1000px;
  margin: 0 auto;
}
section#seminar .block .search form ul {
  text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
section#seminar .block .search form ul li {
  margin: 0;
  padding: 0;
}
section#seminar .block .search form label {
  padding: 2px 15px 3px;
  font-size: 15px;
  font-weight: 500;
  border-radius: 30px;
  border: 1px solid #2667d7;
  transition: .2s;
}
section#seminar .block .search form input[type=submit] {
  display: none;
}
@media screen and (max-width: 1160px) {
  section#seminar .block .search form label {
    font-size: 13px;
  }
}
section#seminar .block .search form label:hover {
  background: #d4e1f7;
}
section#seminar .block .search form label:has(input:checked) {
  color: #fff;
  background: #2667d7;
}
section#seminar .block .search form label input {
  position: absolute;
  appearance: none;
}
section#seminar .block .item_wrap {
  margin: 30px 0 40px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 2%;
}
section#seminar .block .item_wrap.accept {
  justify-content: center;
}
section#seminar .block .item_wrap .item {
  width: 32%;
  border-bottom: 1px solid #d2d2d2;
  display: flex;
}
section#seminar .block .item_wrap.accept .item {
  border-bottom: none;
}
section#seminar .block .item_wrap .item a {
  width: 100%;
  display: flex;
  flex-direction: column;
}
section#seminar .block .item_wrap .item .image {
  margin: 0 0 10px 0;
  position: relative;
}
section#seminar .block .item_wrap .item .image figure {
  padding-top: 68.18182%;
  position: relative;
  display: block;
}
section#seminar .block .item_wrap .item .image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section#seminar .block .item_wrap .item .image figure.w100 {
  padding-top: 0;
  display: block;
}
section#seminar .block .item_wrap .item .image figure.w100 img {
  position: static;
}
section#seminar .block .item_wrap .item time {
  margin: 10px 0 5px 0;
  color: #808080;
  font-size: 12px;
  font-weight: 600;
  display: block;
}
section#seminar .block .item_wrap .item p {
  color: #0b4383;
  font-size: 16px;
  font-weight: 600;
}
section#seminar .block .item_wrap .item .inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

section#seminar .mailmag {
  max-width: 760px;
  margin: 60px auto;
  text-align: center;
}

@media screen and (max-width: 767px) {
  section#seminar .block {
    padding: 0 5% 30px;
  }
  section#seminar .block h1,
  section#seminar .block h2 {
    margin: 0 0 20px 0;
    font-size: 17px;
    letter-spacing: 0;
  }
  section#seminar .block + .block {
    margin: 40px 0 50px 0;
  }
  section#seminar .block .search {
    padding: 15px;
  }
  section#seminar .block .search h3 span {
    padding: 0 18px 0 0;
    font-size: 15px;
    font-weight: 600;
    background: url(../images/common/ico_search.png) no-repeat right 7px / 12px auto;
  }
  section#seminar .block .search .clear {
    margin: 5px 0 0 0;
    text-align: center;
    position: static;
  }
  section#seminar .block .search form ul {
    gap: 7px;
  }
  section#seminar .block .search form label {
    padding: 2px 10px 3px;
    font-size: 10px;
  }
  section#seminar .block .item_wrap {
    margin: 20px 0 0 0;
    display: block;
  }
  section#seminar .block .item_wrap .item {
    width: 100%;
    margin: 0 0 30px 0;
  }
  section#seminar .block .item_wrap .item a {
    width: 100%;
    display: block;
  }
  section#seminar .block .item_wrap .item .image {
    width: 100%!important;
  }
  section#seminar .block .item_wrap .item img {
    width: 100%;
    margin: 0 0 10px 0;
  }
  section#seminar .block .item_wrap .item .inner {
    width: 100%!important;
  }
  section#seminar .block .item_wrap .item p {
    font-size: 14px;
  }
  section#seminar .block .item_wrap .item time {
    margin: 5px 0;
    font-size: 10px;
  }
  section#seminar .mailmag {
    margin: 30px 0;
  }
}

/* ********** NEWS ********** */

section#news .block {
  padding: 0 5% 100px;
}
section#news .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#news .block h2 {
  margin: 0 0 60px 0;
  text-align: center;
}
section#news .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}
section#news .block ul.contents {
  margin: 0 0 100px 0;
}
section#news .block ul.contents li {
  border-bottom: 1px solid #000;
}
section#news .block ul.contents li a {
  padding: 15px 0;
  display: block;
  transition: .3s;
}
section#news .block ul.contents li a:hover {
  opacity: .7;
}
section#news .block ul.contents li dl {
  display: flex;
  align-items: center;
}
section#news .block ul.contents li dl dt {
  font-size: 20px;
  font-weight: 600;
}
section#news .block ul.contents li dl dd {
  margin: 0 0 0 10px;
  padding: 5px 10px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  border-radius: 20px;
  background: #2667d7;
  display: inline-block;
}
section#news .block ul.contents li p {
  padding: 0 25px 0 0;
  font-size: 18px;
  background: url(../images/top/news_icon.jpg) no-repeat right center / 14px auto;
}

@media screen and (max-width: 767px) {
  section#news .block {
    padding: 0 5% 30px;
  }
  section#news .block h2 {
    margin: 0 0 30px 0;
  }
  section#news .block h2 span {
    font-size: 20px;
  }
  section#news .block ul.contents {
    margin: 0 0 10px 0;
  }
  section#news .block ul.contents li a {
    padding: 10px 0;
  }
  section#news .block ul.contents li dl dt {
    font-size: 14px;
  }
  section#news .block ul.contents li dl dd {
    padding: 3px 7px;
  }
  section#news .block ul.contents li p {
    padding: 0 25px 0 0;
    font-size: 12px;
    background: url(../images/top/news_icon.jpg) no-repeat right center / 12px auto;
  }
}

/* ********** NEWS SINGLE ********** */

section#news-single .block {
  padding: 80px 5% 150px;
}
section#news-single .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#news-single .block dl.date {
  margin: 0 0 5px 0;
  display: flex;
  align-items: center;
}
section#news-single .block dl.date dt {
  font-size: 18px;
  font-weight: 600;
}
section#news-single .block dl.date dd {
  margin: 0 0 0 10px;
  padding: 5px 10px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  border-radius: 20px;
  background: #2667d7;
  display: inline-block;
}
section#news-single .block h2 {
  padding:  0 0 20px 0;
  font-size: 28px;
  border-bottom: 1px solid #194480;
}
section#news-single .block .content {
  padding: 20px 0 100px 0;
  color: #4d4d4d;
  font-size: 20px;
  line-height: 2.5;
}
section#news-single .block .content h3 {
  margin: 50px 0 30px 0;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
}
section#news-single .block .content h4 {
  margin: 50px 0 30px 0;
  font-weight: 600;
}
section#news-single .block .content p {
  margin: 30px 0;
}
section#news-single .block .content figure {
  margin: 30px 0;
}
section#news-single .block .content figcaption {
  font-size: 12px;
}
section#news-single .block .content a {
  color: #194480;
  text-decoration: underline;
}
section#news-single .block .content a:hover {
  text-decoration: none;
  opacity: 1;
}
section#news-single .block a.back {
  width: 220px;
  margin: 0 auto;
  padding: 8px 0 8px 28px;
  font-size: 18px;
  line-height: 1;
  background: url(../images/top/news_icon2.jpg) no-repeat left center / 14px auto;
  display: block;
}

@media screen and (max-width: 767px) {
  section#news-single .block {
    padding: 30px 5% 60px;
  }
  section#news-single .block .date {
    font-size: 13px;
  }
  section#news-single .block h2 {
    padding:  0 0 15px 0;
    font-size: 20px;
    border-bottom: 1px solid #194480;
  }
  section#news-single .block .content {
    padding: 0 0 40px 0;
    font-size: 14px;
  }
  section#news-single .block .content h3 {
    margin: 40px 0 20px 0;
    font-size: 18px;
  }
  section#news-single .block .content h4 {
    margin: 40px 0 20px 0;
  }
  section#news-single .block .content p {
    margin: 20px 0;
  }
  section#news-single .block .content figure {
    margin: 20px 0;
  }
  section#news-single .block .content figcaption {
    font-size: 10px;
  }
  section#news-single .block a.back {
    width: 170px;
    padding: 8px 0 8px 25px;
    font-size: 14px;
    background: url(../images/top/news_icon2.jpg) no-repeat left center / 12px auto;
    display: block;
  }
}

/* ********** COMPANY ********** */

section#company .pnav {
  width: 100%;
  max-width: 860px;
  margin: 20px auto 50px;
  padding: 0 5%;
}
section#company .pnav ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}
section#company .pnav ul li {
  width: calc(33.33% - 20px);

  text-align: center;
  border-radius: 5px;
  border: 1px solid #194480;
  transition: .3s;
}
section#company .pnav ul li a {
  padding: 10px 10px 40px 10px;
  color: #194480;
  font-size: 20px;
  font-weight: 600;
  background: url(../images/company/icon1.png) no-repeat center bottom 15px;
  display: block;
}
@media screen and (max-width: 880px) {
  section#company .pnav ul li a {
    font-size: 18px;
  }
}
section#company .pnav ul li:hover a {
  color: #fff;
  background: #194480 url(../images/company/icon2.png) no-repeat center bottom 15px;
  opacity: 1;
}

section#company .block {
  margin: -80px 0 0 0;
  padding: 80px 0 0 0;
}
section#company .title {
  padding: 0 30px;
  background: #d1d5dc;
}
section#company .title h2 {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 30px 0;
  color: #194480;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}

section#company .block_outer {
  padding: 80px 5%;
}
section#company .block_inner {
  max-width: 1200px;
  margin: 0 auto;
}
section#company .block_inner h3 {
  margin: 0 0 50px 0;
  color: #194480;
  font-size: 28px;
  font-weight: 600;
}
section#company #mission p {
  margin: 0 0 30px 0;
  font-size: 18px;
}
section#company #mission p.more {
  margin: 0;
  font-size: 14px;
}
section#company #mission .large {
  font-size: 20px;
  font-weight: 600;
}
section#company #mission em {
  color: #194480;
  font-size: 22px;
  font-weight: 600;
  font-style: normal;
}
section#company #mission figure {
  margin: 0 0 30px 0;
}
section#company #mission .lead {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section#company #mission .lead .txt {
  width: calc(100% - 370px);
}
section#company #mission .lead .banner {
  max-width: 320px;
}
section#company #mission .box {
  margin: 0 0 50px 0;
  padding: 20px;
  border: 1px solid #194480;
  display: inline-block;
}
section#company #mission dl {
  font-size: 27px;
  line-height: 1.5;
  display: flex;
}
section#company #mission dl + dl {
  margin: 10px 0 0 0;
}
section#company #mission dl dt {
  white-space: nowrap;
}
section#company #mission dl dd {
  color: #194480;
  font-weight: 600;
}
section#company #block2 p {
  margin: 0 0 30px 0;
  font-size: 18px;
}
section#company #block2 dl {
  width: 154px;
  margin: 0 0 0 auto;
}
section#company #block2 dl dt {
  margin: 0 0 5px 0;
  font-size: 13px;
}
section#company #block2 dl dd {
  font-size: 28px;
}
section#company #team .block_inner {
  padding: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#company #team .box {
  padding: 40px 0;
  border-bottom: 1px solid #194480;
  width: calc(50% - 20px);
}
section#company #team .box:first-of-type {
  width: 100%;
  padding: 0 0 40px;
}
section#company #team .box .wrap {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#company #team .box .wrap figure {
  width: 30%;
}
section#company #team .box .wrap .inner {
  width: 65%;
}
section#company #team .box:first-of-type figure {
  width: 25%;
}
section#company #team .box:first-of-type .inner {
  width: 70%;
}
section#company #team .box .wrap .inner dl {
  color: #194480;
}
section#company #team .box .wrap .inner dl dt {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
}
section#company #team .box .wrap .inner dl dd {
  font-size: 21px;
  font-weight: 600;
}
section#company #team .box .wrap .inner ul {
  margin: 20px 0 0 0;
  font-size: 14px;
}
section#company #team .box .wrap p {
  margin: 20px 0 0 0;
  font-size: 15px;
}
section#company #team .box .wrap a {
  text-decoration: underline;
}
section#company #team .box .wrap a:hover {
  opacity: 1;
  text-decoration: none;
}
section#company #team .box .wrap a.fb {
  padding: 5px 0 5px 30px;
  background: url(../images/company/ico_facebook.jpg) no-repeat left center;
  display: inline-block;
}
section#company #companyinfo .info dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
section#company #companyinfo .info dl dt {
  width: 200px;
  margin: 0 0 20px 0;
  padding: 5px 20px;
  color: #194480;
  font-size: 16px;
  font-weight: 600;
  background: #e3e4e4;
  display: flex;
  align-items: center;
  justify-content: center;
}
section#company #companyinfo .info dl dd {
  width: calc(100% - 200px);
  padding: 5px 20px;
  margin: 0 0 20px 0;
  font-size: 19px;
  align-items: center;
}
section#company #companyinfo .office {
  padding: 80px 0 0 0;
}
section#company #companyinfo .office img {
margin: 0 0 30px 0;
}
section#company #companyinfo .office dl {
  width: 100%;
  margin: 0 0 30px 0;
  text-align: center;
}
section#company #companyinfo .office dl dt {
  font-size: 21px;
  font-weight: 600;
}
section#company #companyinfo .office dl dd {
  font-size: 19px;
}
section#company #companyinfo .office iframe {
  width: 100%;
  height: 350px;
}
section#company #block5 .history {
  max-width: 860px;
  margin: 0 auto;
}
section#company #block5 .history p.ttl {
  color: #194480;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
section#company #block5 .history p + p {
  margin: 20px 0 0 0;
}
section#company #block5 .history a {
  width: 300px;
  margin: 30px auto 0;
  padding: 10px;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  border-radius: 30px;
  border: 2px solid #194480;
  font-size: 20px;
  display: block;
}
section#company #block5 .history a:hover {
  color: #fff;
  background: #194480;
  opacity: 1;
}
section#company #partner .partner .icon dl {
  display: flex;
}
section#company #partner .partner .icon dl + dl {
  margin: 20px 0 0 0;
}
section#company #partner .partner .icon dl dt {
  font-size: 10px;
  white-space: nowrap;
}
section#company #partner .partner .icon dl dt span {
  width: 125px;
  margin: 0 10px 0 0;
  display: inline-block;
}
section#company #partner .partner ul {
  margin: 60px 0 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
section#company #partner .partner ul li {
  width: calc(20% - 24px);
}
section#company #partner .partner ul li a {
  display: block;
}
section#company #partner .partner ul li .icon {
  margin: 0 0 10px 0;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
section#company #partner .partner ul li .icon span {
  width: calc(50% - 5px);
  display: flex;
}
section#company #partner .partner ul li figure {
  margin: 0 0 10px 0;
  border: 1px solid #d7d7d7;
}
section#company #partner .partner ul li figure img {
  width: 100%;
}
section#company #partner .partner ul li p {
  font-size: 11px;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1160px) {
  section#company #partner .partner ul li {
    width: calc(25% - 22.5px);
  }
}
@media screen and (min-width: 768px) and (max-width: 940px) {
  section#company #partner .partner ul li {
    width: calc(33.33% - 20px);
  }
}
section#company #block8 .recruit {
  padding: 0 0 50px 0;
}
section#company #block8 .recruit a {
  padding: 30px;
  border: 3px solid #194480;
  background: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
section#company #block8 .recruit h4 {
  width: 140px;
  color: #194480;
  font-size: 30px;
  font-weight: 600;
}
section#company #block8 .recruit p {
  width: calc(100% - 200px);
  color: #194480;
  font-size: 17px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  section#company .pnav {
    margin: 10px auto 20px;
    padding: 0 5%;
  }
  section#company .pnav ul {
    gap: 10px;
  }
  section#company .pnav ul li {
    width: calc(50% - 5px);
  }
  section#company .pnav ul li a {
    padding: 5px 10px 25px 10px;
    font-size: 15px;
    background: url(../images/company/icon1.png) no-repeat center bottom 10px / 14px auto;
  }
  section#company .pnav ul li:hover a {
    background: #194480 url(../images/company/icon2.png) no-repeat center bottom 10px / 14px auto;
  }

  section#company .block {
    margin: -60px 0 0 0;
    padding: 60px 0 0 0;
  }
  section#company .title {
    padding: 0;
  }
  section#company .title h2 {
    padding: 10px 0;
    font-size: 18px;
  }
  section#company .block_outer {
    padding: 30px 5% 60px;
  }
  section#company .block_inner h3 {
    margin: 0 0 20px 0;
    font-size: 18px;
  }
  section#company #mission p {
    margin: 0 0 20px 0;
    font-size: 13px;
  }
  section#company #mission .large {
    font-size: 16px;
  }
  section#company #mission em {
    font-size: 16px;
  }
  section#company #mission figure {
    margin: 0 0 20px 0;
  }
  section#company #mission .lead {
    margin: 0 0 30px 0;
    display: block;
  }
  section#company #mission .lead .txt {
    width: 100%;
  }
  section#company #mission .lead .banner {
    margin: 0 auto;
  }
  section#company #mission .box {
    margin: 0 0 30px 0;
    padding: 10px;
  }
  section#company #mission dl {
    font-size: 15px;
    line-height: 1.5;
    display: block;
  }
  section#company #mission dl dt {
    white-space: nowrap;
  }
  section#company #mission dl dd {
    color: #194480;
    font-weight: 600;
  }
  section#company #block2 p {
    margin: 0 0 20px 0;
    font-size: 13px;
  }
  section#company #block2 dl {
    width: 140px;
  }
  section#company #block2 dl dt {
    margin: 0 0 5px 0;
    font-size: 12px;
  }
  section#company #team .box {
    width: 100%;
    padding: 20px 0;
  }
  section#company #team .box .wrap {
    display: block;
  }
  section#company #team .box .wrap figure {
    width: 30%;
    float: left;
  }
  section#company #team .box .wrap .inner {
    width: 100%;
  }
  section#company #team .box:first-of-type figure {
    width: 30%;
  }
  section#company #team .box:first-of-type .inner {
    width: 100%;
  }
  section#company #team .box .wrap .inner dl {
    width: 65%;
    float: right;
  }
  section#company #team .box .wrap .inner dl dt {
    font-size: 12px;
  }
  section#company #team .box .wrap .inner dl dd {
    font-size: 16px;
  }
  section#company #team .box .wrap .inner ul {
    width: 65%;
    margin: 10px 0 15px 0;
    font-size: 11px;
    float: right;
  }
  section#company #team .box .wrap p {
    margin: 0;
    font-size: 13px;
    clear: both;
  }
  section#company #companyinfo .info dl {
    width: 100%;
  }
  section#company #companyinfo .info dl dt {
    width: 30%;
    margin: 0 0 10px 0;
    padding: 5px;
    font-size: 12px;
  }
  section#company #companyinfo .info dl dd {
    width: 70%;
    padding: 0;
    margin: 0 0 10px 0;
    padding: 0 0 0 10px;
    font-size: 12px;
  }
  section#company #companyinfo .info p {
    font-size: 12px;
  }
  section#company #companyinfo .office {
    padding: 30px 0 0 0;
  }
  section#company #companyinfo .office img {
  margin: 0 0 20px 0;
  }
  section#company #companyinfo .office dl {
    width: 100%;
    margin: 0 0 20px 0;
  }
  section#company #companyinfo .office dl dt {
    font-size: 14px;
  }
  section#company #companyinfo .office dl dd {
    font-size: 13px;
  }
  section#company #companyinfo .office iframe {
    height: 300px;
  }
  section#company #block5 .history p.ttl {
    font-size: 16px;
  }
  section#company #block5 .history {
    font-size: 13px;
  }
  section#company #block5 .history a {
    width: 260px;
    font-size: 15px;
  }
  section#company #partner .partner .icon dl + dl {
    margin: 10px 0 0 0;
  }
  section#company #partner .partner .icon dl dt span {
    width: 90px;
    margin: 0 10px 0 0;
    padding: 3px 0;
    font-size: 10px;
    letter-spacing: 0;
    text-align: center;
    display: inline-block;
  }
  section#company #partner .partner .icon dl dd {
    font-size: 11px;
  }
  section#company #partner .partner ul {
    margin: 40px 0 0 0;
    gap: 30px 20px;
  }
  section#company #partner .partner ul li {
    width: calc(50% - 10px);
  }
  section#company #partner .partner ul li a {
    display: block;
  }
  section#company #partner .partner ul li .icon {
    margin: 0 0 5px 0;
    gap: 5px;
  }
  section#company #partner .partner ul li .icon span {
    width: calc(50% - 2.5px);
  }
  section#company #partner .partner ul li figure {
    margin: 0 0 5px 0;
  }
  section#company #partner .partner ul li p {
    font-size: 10px;
  }
}

/* ********** RECRUIT ********** */

section#recruit {
  padding: 0 0 70px 0;
  overflow: hidden;
}
section#recruit .visual {
  position: relative;
}
section#recruit .visual img {
  width: 100%;
}
section#recruit .visual h2 {
  width: 100%;
  color: #fff;
  font-size: 40px;
  font-weight: 600;
  text-align: center;
  position: absolute;
  top: 50%;
  transform: translate(0,-50%);
}
section#recruit .block {
  padding: 80px 5% 0;
}
section#recruit .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#recruit .block p.desc {
  margin: 0 0 100px 0;
  font-size: 16px;
  text-align: center;
}
section#recruit h3 {
  margin: 0 0 30px 0;
  color: #194480;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}
section#recruit .block .credo {
  margin: 0 0 80px 0;
}
section#recruit .block .credo dl {
  width: 100%;
  line-height: 1.5;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
section#recruit .block .credo dl dt {
  width: 220px;
  padding: 0 0 20px 0;
  color: #b41919;
  font-size: 18px;
  font-weight: 600;
}
section#recruit .block .credo dl dd {
  width: calc(100% - 220px);
  padding: 0 0 20px 0;
  font-size: 18px;
  font-weight: 600;
}
section#recruit .block .flow {
  margin: 0 0 100px 0;
}
section#recruit .block .requirements {
  margin: 0 0 100px 0;
}
section#recruit .block .requirements .box {
  margin: 0 0 30px 0;
}
section#recruit .block .requirements .box h4 {
  padding: 20px 0;
  font-size: 23px;
  font-weight: 600;
  text-align: center;
  border: 1px solid #194480;
  position: relative;
  cursor: pointer;
}
section#recruit .block .requirements .box h4:after {
  content: "";
  width: 15px;
  height: 15px;
  border-right: 2px solid #194480;
  border-bottom: 2px solid #194480;
  position: absolute;
  top: 35%;
  right: 40px;
  transform: rotate(45deg);
}
section#recruit .block .requirements .box h4.active:after {
  border-top: 2px solid #194480;
  border-left: 2px solid #194480;
  border-right: none;
  border-bottom: none;
  top: 45%;
  right: 40px;
}
section#recruit .block .requirements .box .inner {
  display: none;
}
section#recruit .block .requirements .box dl {
  margin: 0 30px;
  padding: 30px 0;
  font-size: 18px;
  border-bottom: 1px solid #194480;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#recruit .block .requirements .box dl dt {
  width: 200px;
  font-weight: 600;
}
section#recruit .block .requirements .box dl dd {
  width: calc(100% - 200px);
}
section#recruit .block .requirements .box .txt {
  margin: 50px 0 100px;
  font-size: 19px;
  text-align: center;
}
section#recruit .block .requirements .box .txt p {
  margin: 0 0 30px 0;
}
section#recruit .block .requirements .no_entry {
  font-size: 20px;
  text-align: center;
}
section#recruit .block .requirements .wantedly {
  margin: 80px 0 0 0;
  text-align: center;
  border: 1px solid #194480;
}
section#recruit .block .requirements .wantedly a {
  padding: 30px 0;
  display: block;
}
section#recruit .block .requirements .wantedly p {
  margin: 0 0 15px 0;
  font-size: 14px;
  color: #194480;
  font-weight: 600;
}
section#recruit .block .requirements .wantedly img {
  width: 190px;
}
section#recruit .block .gallery ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#recruit .block .gallery ul li {
  width: 31%;
  margin: 0 0 3.5% 0;
}

@media screen and (max-width: 767px) {
  section#recruit .visual {
    position: relative;
  }
  section#recruit .visual img {
    width: 140%;
    margin: 0 0 0 -20%;
    max-width: 140%;
  }
  section#recruit .visual h2 {
    font-size: 18px;
  }
  section#recruit .block {
    padding: 30px 5% 0;
  }
  section#recruit .block p.desc {
    margin: 0 0 40px 0;
    font-size: 13px;
  }
  section#recruit h3 {
    margin: 0 0 20px 0;
    font-size: 16px;
  }
  section#recruit .block .credo {
    margin: 0 0 40px 0;
  }
  section#recruit .block .credo dl {
    display: block;
  }
  section#recruit .block .credo dl dt {
    width: 100%;
    padding: 0 0 5px 0;
    font-size: 16px;
  }
  section#recruit .block .credo dl dd {
    width: 100%;
    padding: 0 0 15px 0;
    font-size: 14px;
  }
  section#recruit .block .flow {
    margin: 0 0 40px 0;
  }
  section#recruit .block .requirements {
    margin: 0 0 40px 0;
  }
  section#recruit .block .requirements .box {
    margin: 0 0 20px 0;
  }
  section#recruit .block .requirements .box h4 {
    padding: 15px 0;
    font-size: 16px;
  }
  section#recruit .block .requirements .box h4:after {
    width: 12px;
    height: 12px;
    top: 32%;
    right: 20px;
  }
  section#recruit .block .requirements .box h4.active:after {
    top: 45%;
    right: 20px;
  }
  section#recruit .block .requirements .box dl {
    margin: 0 10px;
    padding: 20px 0;
    font-size: 13px;
    display: block;
  }
  section#recruit .block .requirements .box dl dt {
    width: 100%;
    margin: 0 0 5px 0;
    font-size: 15px;
  }
  section#recruit .block .requirements .box dl dd {
    width: 100%;
  }
  section#recruit .block .requirements .box .txt {
    margin: 20px 0 40px;
    font-size: 12px;
  }
  section#recruit .block .requirements .box .txt p {
    margin: 0 0 20px 0;
  }
  section#recruit .block .requirements .no_entry {
    font-size: 12px;
  }
  section#recruit .block .requirements .wantedly {
    margin: 40px 0 0 0;
  }
  section#recruit .block .requirements .wantedly a {
    padding: 20px 0;
  }
  section#recruit .block .requirements .wantedly p {
    margin: 0 0 10px 0;
    font-size: 13px;
  }
  section#recruit .block .requirements .wantedly img {
    width: 160px;
  }
  section#recruit .block .gallery ul li {
    width: 48%;
    margin: 0 0 4% 0;
  }
}

/* ********** CONTACT FORM ********** */

section .form_block {
  width: 100%;
  max-width: 1060px;
  padding: 0 5% 30px;
  margin: 0 auto;
}
section .form_block h2 {
  color: #194480;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}
section .form_block h2 span {
  font-size: 22px;
  font-weight: 700;
}
section .form_block .desc {
  width: 100%;
  max-width: 640px;
  margin: 30px auto 60px;
  font-size: 14px;
}
section .form_block .download {
  margin: 50px auto;
  text-align: center;
}
section .form_block .download p {
  color: #194480;
  font-size: 17px;
  font-weight: 600;
}
section .form_block .download p a {
  color: #194480;
  text-decoration: underline;
}
section .form_block .download p a:hover {
  text-decoration: none;
  opacity: 1;
}
section .form_block .center {
  margin: 30px 0 20px 0;
  font-size: 17px;
  font-weight: 600;
  text-align: center;
}
section .form_block .center span {
  padding: 10px 0 0 0;
  font-size: 15px;
  font-weight: 600;
  display: block;
}
section .form_block dl {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
section .form_block dl dt {
  width: 250px;
  min-height: 50px;
  margin: 0 0 15px 0;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  background: #d6ddea;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
}
section .form_block dl dt span {
  font-size: 11px;
  font-weight: 600;
}
section .form_block dl dd {
  width: calc(100% - 250px);
  padding: 0 0 0 15px;
  margin: 0 0 15px 0;
  font-size: 18px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
section .form_block dl dd input[type="text"],
section .form_block dl dd input[type="tel"],
section .form_block dl dd input[type="email"] {
  width: 100%;
  height: 50px;
  padding: 20px;
  font-size: 18px;
  border: 1px solid #b5b6b6;
}
section .form_block dl dd label {
  margin: 0 20px 0 0;
  display: inline-block;
}
section .form_block dl dd select {
  width: 100%;
  height: 50px;
  padding: 0 10px;
  font-size: 18px;
  border: 1px solid #b5b6b6;
}
section .form_block dl dd input[type="radio"] {
  margin: 0 0 3px 0;
}
section .form_block dl dd textarea {
  width: 100%;
  height: 220px;
  padding: 20px;
  font-size: 18px;
  border: 1px solid #b5b6b6;
}
section .form_block .checkbox {
  margin: 10px 0 50px 0;
  text-align: center;
}
section .form_block .checkbox p {
  margin: 0 0 30px 0;
}
section .form_block .checkbox a {
  text-decoration: underline;
}
section .form_block .checkbox label {
  font-size: 19px;
}
section .form_block .checkbox label input[type="checkbox"] {
  margin: 0 0 3px 0;
}
section .form_block .btn {
  margin: 50px 0 0 0;
  text-align: center;
}
section .form_block .btn input[type="submit"] {
  width: 280px;
  height: 70px;
  margin: 0 10px;
  font-size: 22px;
  color: #fff;
  border: none;
  background: #2667d7;
  transition: .3s;
}
section .form_block .btn input[type="submit"]:hover {
  opacity: .7;
}
section .form_block .btn .wpcf7-spinner {
    display: none !important;
}
section .form_block .tel_box {
  margin: 80px 0 0 0;
  text-align: center;
}
section .form_block .tel_box h3 {
  margin: 0 0 20px 0;
  font-size: 24px;
  font-weight: 600;
}
section .form_block .tel_box .tel a {
  width: 300px;
  margin: 0 auto;
  padding: 0 0 5px 0;
  color: #194480;
  font-size: 36px;
  font-weight: 600;
  text-align: right;
  line-height: 1;
  background: url(../images/form/tel_icon.jpg) no-repeat left center;
  display: block;
  pointer-events: none;
}
section .form_block .tel_box .time {
  margin: 0 0 20px 0;
  font-size: 16px;
}
section .form_block .wpcf7-form-control-wrap {
  width: 100%;
}
section .form_block .wpcf7-not-valid-tip {
  font-size: 14px;
}
section .form_block .wpcf7-list-item {
  margin: 0;
}
section .form_block div.wpcf7-response-output {
  text-align: center;
  font-size: 16px;
}
section .form_block div.wpcf7-mail-sent-ok {
  background-color: #e9fde0;
}
section .form_block div.wpcf7-mail-sent-ng,
section .form_block div.wpcf7-aborted {
  background-color: #ffe5e5;
}
section .form_block div.wpcf7-spam-blocked {
  background-color: #f9edd8;
}
section .form_block div.wpcf7-validation-errors,
section .form_block div.wpcf7-acceptance-missing {
  background-color: #fffdde;
}
section .form_block div.wpcf7-mail-sent-ok {
  display: none!important;
}
section .form_block iframe {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  display: block;
}

@media screen and (max-width: 767px) {
  section .form_block {
    padding: 30px 5% 0;
  }
  section .form_block h2 {
    font-size: 20px;
  }
  section .form_block h2 span {
    font-size: 16px;
  }
  section .form_block .desc {
    margin: 30px auto;
    font-size: 13px;
  }
  section .form_block .image {
    width: 100%;
    margin: 30px auto;
    display: block;
    text-align: center;
  }
  section .form_block .image figure {
    width: 160px;
    margin: 0 auto 10px;
  }
  section .form_block .image p {
    font-size: 13px;
  }
  section .form_block .center {
    margin: 30px 0 20px 0;
    font-size: 15px;
  }
  section .form_block .center span {
    padding: 10px 0 0 0;
    font-size: 13px;
  }
  section .form_block dl {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
  }
  section .form_block dl dt {
    width: 120px;
    min-height: 40px;
    padding: 0 10px;
    font-size: 12px;
    text-align: center;
    letter-spacing: 0;
  }
  section .form_block dl dt span {
    font-size: 10px;
  }
  section .form_block dl dd {
    width: calc(100% - 120px);
    padding: 0 0 0 10px;
    margin: 0 0 15px 0;
    font-size: 12px;
  }
  section .form_block dl dd input[type="text"],
  section .form_block dl dd input[type="tel"],
  section .form_block dl dd input[type="email"] {
    height: 40px;
    padding: 10px;
    font-size: 12px;
  }
  section .form_block dl dd select {
    height: 40px;
    padding: 10px;
    font-size: 12px;
  }
  section .form_block dl dd label {
    width: 100%;
    margin: 3px 0;
    display: block;
  }
  section .form_block dl dd textarea {
    width: 100%;
    height: 160px;
    padding: 10px;
    font-size: 12px;
    border: 1px solid #b5b6b6;
  }
  section .form_block .checkbox {
    margin: 10px 0 30px 0;
  }
  section .form_block .checkbox p {
    margin: 0 0 30px 0;
    font-size: 12px;
  }
  section .form_block .checkbox p br {
    display: none;
  }
  section .form_block .checkbox label {
    font-size: 16px;
  }
  section .form_block .btn {
    margin: 30px 0 0 0;
  }
  section .form_block .btn input[type="submit"] {
    width: 100%;
    margin: 0 0 20px 0;
    height: 60px;
    font-size: 18px;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0;
  }
  section .form_block .tel_box {
    margin: 30px 0 0 0;
  }
  section .form_block .tel_box p {
    font-size: 11px;
  }
  section .form_block .tel_box h3 {
    font-size: 16px;
  }
  section .form_block .tel_box .tel a {
    width: 250px;
    font-size: 30px;
    background: url(../images/form/tel_icon.jpg) no-repeat left center / 30px auto;
    pointer-events: auto;
  }
  section .form_block .tel_box .time {
    margin: 0 0 20px 0;
    font-size: 13px;
  }
  section .form_block .wpcf7-list-item {
    display: block;
  }
  section .form_block .wpcf7-not-valid-tip {
    font-size: 12px;
  }
  section .form_block div.wpcf7-response-output {
    font-size: 12px;
  }

}

/* ********** DOWNLOAD ********** */

section#download .block {
  padding: 50px 5% 100px 5%;
}
section#download .block .inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#download .block .video {
  width: 42%;
}
section#download .block .video h1 {
  margin: 0 0 20px 0;
  color: #0b4383;
  font-size: 22px;
  font-weight: 700;
  text-align: center;
}
section#download .block .video p {
  color: #194480;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}
section#download .block .video figure {
  max-width: 250px;
  margin: 10px auto 0;
}
section#download .block .video video {
  width: 100%;
  filter: drop-shadow(0px 0px rgba(0,0,0,0));
  outline: none;
  border: none;
}

section#download .block .case {
  width: 40%;
}
section#download .block .case h1 {
  margin: 0 0 20px 0;
  color: #0b4383;
  font-size: 22px;
  font-weight: 700;
  text-align: center;
}
section#download .block .case p {
  font-size: 16px;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 1100px) {
  section#download .block .case p {
    font-size: 14px;
  }
}
section#download .block .case figure {
  margin: 0 auto 20px;
}



section#download .block .inner .form {
  width: 55%;
}
section#download .block .inner .form iframe {
  width: 100%;
  display: block;
}

@media screen and (max-width: 767px) {
  section#download .block {
    padding: 30px 5% 40px 5%;
  }
  section#download .block .video {
    width: 100%;
  }
  section#download .block .video p {
    color: #194480;
    font-size: 16px;
    font-weight: 700;
    text-align: center;
  }
  section#download .block .case {
    width: 100%;
  }
  section#download .block .case p {
    font-size: 13px;
  }
  section#download .block .inner .form {
    width: 100%;
    margin: 20px 0 0 0;
  }
}



/* ********** PRIVACY POLICY ********** */

section#privacypolicy .block {
  padding: 20px 5% 100px 5%;
}
section#privacypolicy .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  font-size: 18px;
}
section#privacypolicy .block h2 {
  margin: 0 0 60px 0;
  text-align: center;
}
section#privacypolicy .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}
section#privacypolicy .block h3 {
  margin: 50px 0 10px;
  color: #194480;
  font-size: 22px;
  font-weight: 600;
}
section#privacypolicy .block h4 {
  margin: 40px 0 10px;
  font-size: 20px;
  font-weight: 600;
}
section#privacypolicy .block .list-bullet,
section#privacypolicy .block .list-order,
section#privacypolicy .block .list-alpha,
section#privacypolicy .block .list-chara {
  padding-left: 22px;
  margin: 1em 0;
}
section#privacypolicy .block .list-bullet li + li,
section#privacypolicy .block .list-order li + li,
section#privacypolicy .block .list-alpha li + li,
section#privacypolicy .block .list-chara li + li {
  margin: 10px 0 0 0;
}
section#privacypolicy .block .list-bullet {
  list-style-type: disc;
}
section#privacypolicy .block .list-order {
  list-style-type: decimal;
}
section#privacypolicy .block .list-alpha {
  list-style-type: lower-latin;
}
section#privacypolicy .block p + p {
  margin: 10px 0 0 0;
}
section#privacypolicy .block em {
  color: #194480;
  font-style: normal;
  font-weight: 600;
}
section#privacypolicy .block a {
  text-decoration: underline;
}
section#privacypolicy .block a:hover {
  text-decoration: none;
  opacity: 1;
}

@media screen and (max-width: 767px) {
  section#privacypolicy .block {
    padding: 30px 5%;
  }
  section#privacypolicy .block .block_inner {
    font-size: 14px;
  }
  section#privacypolicy .block h2 {
    margin: 0 0 30px 0;
  }
  section#privacypolicy .block h2 span {
    font-size: 20px;
    border-bottom: 2px solid #194480;
  }
  section#privacypolicy .block h3 {
    margin: 40px 0 10px;
    font-size: 18px;
  }
  section#privacypolicy .block h4 {
    margin: 30px 0 10px;
    font-size: 16px;
  }
  section#privacypolicy .block .list-bullet,
  section#privacypolicy .block .list-order,
  section#privacypolicy .block .list-alpha,
  section#privacypolicy .block .list-chara {
    padding-left: 20px;
  }
}

/* ********** COMMON ********** */

section#common .block {
  padding: 20px 5% 100px;
}
section#common .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  font-size: 18px;
}
section#common .block h2 {
  margin: 0 0 30px 0;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
}
section#common .block h3 {
  margin: 50px 0 10px;
  color: #194480;
  font-size: 22px;
  font-weight: 600;
}
section#common .block h4 {
  margin: 40px 0 10px;
  font-size: 20px;
  font-weight: 600;
}
section#common .block .list-bullet,
section#common .block .list-order,
section#common .block .list-alpha,
section#common .block .list-chara {
  padding-left: 22px;
  margin: 1em 0;
}
section#common .block .list-bullet li + li,
section#common .block .list-order li + li,
section#common .block .list-alpha li + li,
section#common .block .list-chara li + li {
  margin: 10px 0 0 0;
}
section#common .block .list-bullet {
  list-style-type: disc;
}
section#common .block .list-order {
  list-style-type: decimal;
}
section#common .block .list-alpha {
  list-style-type: lower-latin;
}
section#common .block p + p {
  margin: 10px 0 0 0;
}
section#common .block em {
  color: #194480;
  font-style: normal;
  font-weight: 600;
}
section#common .block a {
  color: #194480;
  text-decoration: underline;
}
section#common .block b {
  font-weight: bold;
}
section#common .block strong {
  color: #bf1919;
}
section#common .block a:hover {
  text-decoration: none;
  opacity: 1;
}
section#common .block dl.right {
  width: 260px;
  margin: 40px 0 0 auto;
}

@media screen and (max-width: 767px) {
  section#common .block {
    padding: 30px 5%;
  }
  section#common .block .block_inner {
    font-size: 14px;
  }
  section#common .block h2 {
    margin: 0 0 30px 0;
  }
  section#common .block h2 span {
    font-size: 20px;
  }
  section#common .block h3 {
    margin: 40px 0 10px;
    font-size: 18px;
  }
  section#common .block h4 {
    margin: 30px 0 10px;
    font-size: 16px;
  }
  section#common .block .list-bullet,
  section#common .block .list-order,
  section#common .block .list-alpha,
  section#common .block .list-chara {
    padding-left: 20px;
  }
  section#common .block dl.right {
    width: 210px;
    margin: 30px 0 10px auto;
  }
}

section#common .questionnaire_form {
  max-width: 1000px;
  margin: 40px auto 0;
}
section#common .questionnaire_form input[type=text],
section#common .questionnaire_form input[type=email] {
  width: 100%;
  padding: 5px;
  font-size: 16px;
  border-radius: 3px;
  border: 1px solid #ced4da;
}
section#common .questionnaire_form select {
  width: 100%;
  padding: 5px;
  font-size: 16px;
  border-radius: 3px;
  border: 1px solid #ced4da;
  background: #fff;
}
section#common .questionnaire_form textarea {
  width: 100%;
  height: 200px;
  padding: 5px;
  font-size: 16px;
  border-radius: 3px;
  border: 1px solid #ced4da;
}
section#common .questionnaire_form input[type=submit] {
  min-width: 200px;
  margin: 0 auto;
  padding: 18px;
  color: #fff;
  font-size: 18px;
  border-radius: 5px;
  border: none;
  outline: none;
  background: #2667d7;
  display: inline-block;
  cursor: pointer;
  transition: .3s;
}
section#common .questionnaire_form dd a {
  color: #0b4383;
}
section#common .questionnaire_form .btn {
  margin: 40px 0 0 0;
  text-align: center;
}
section#common .questionnaire_form input[type=submit]:hover {
  opacity: .7;
}
section#common .questionnaire_form label {
  margin: 0 0 3px 0;
  font-weight: 600;
  line-height: 1.3;
  display: inline-block;
}
section#common .questionnaire_form dl dt {
  margin: 0 0 5px 0;
  font-size: 16px;
  font-weight: 600;
}
section#common .questionnaire_form dl dt span {
  margin: 0 0 0 5px;
  color: #dc3545;
  font-size: 13px;
  font-weight: 600;
}
section#common .questionnaire_form dl dd {
  font-size: 16px;
}
section#common .questionnaire_form dl dd p {
  font-size: 0.9em;
}
section#common .questionnaire_form form > dl > dt + dd {
  margin: 0 0 15px 0;
}
section#common .questionnaire_form dl dd .name {
  display: flex;
  gap: 20px;
}
section#common .questionnaire_form dl dd .name dl {
  width: calc(50% - 10px);
  display: flex;
}
section#common .questionnaire_form dl dd .name dl dt {
  width: 25px;
}
section#common .questionnaire_form dl dd .wpcf7-list-item {
  margin: 0;
  display: block;
}
section#common .questionnaire_form #thanks_url {
  display: none;
}

section#common .questionnaire_form iframe {
  width: 100%;
}

@media screen and (max-width: 767px) {

  section#common .questionnaire_form input[type=text],
  section#common .questionnaire_form input[type=email] {
    font-size: 14px;
  }
  section#common .questionnaire_form select {
    font-size: 14px;
  }
  section#common .questionnaire_form textarea {
    font-size: 14px;
  }
  section#common .questionnaire_form input[type=submit] {
    font-size: 16px;
  }
  section#common .questionnaire_form dl dt {
    font-size: 14px;
  }
  section#common .questionnaire_form dl dd {
    font-size: 14px;
  }
}

section#common .cv_download {
  margin: 30px 0 0 0;
  padding: 30px 8%;
  text-align: center;
  border-radius: 10px;
  background: #e3e3e3;
}
section#common .cv_download h3 {
  margin: 0 0 20px 0;
  color: #0b4383;
  font-size: 21px;
  font-weight: 700;
}
section#common .cv_download img {
  width: 100%;
  max-width: 500px;
}
section#common .cv_download .btn {
  margin: 20px 0 0 0;
  display: flex;
  justify-content: space-between;
}
section#common .cv_download .btn a {
  width: calc(50% - 15px);
  padding: 10px 0;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  text-decoration: none;
  border-radius: 5px;
  display: block;
  transition: opacity .3s;
}
section#common .cv_download .btn a:hover {
  opacity: .7;
}
section#common .cv_download .btn a.pro {
  background: #194489;
}
section#common .cv_download .btn a.scr {
  background: #2a62cd;
}
@media screen and (max-width: 1140px) {
  section#common .cv_download {
    padding: 30px 5%;
  }
  section#common .cv_download .btn a {
    width: calc(50% - 10px);
    font-size: 18px;
  }
}
@media screen and (max-width: 860px) {
  section#common .cv_download h3 {
    margin: 0 0 15px 0;
    font-size: 16px;
  }
  section#common .cv_download {
    margin: 0 0 30px 0;
    padding: 20px;
  }
  section#common .cv_download .btn a {
    width: calc(50% - 10px);
    font-size: 15px;
  }
}
@media screen and (max-width: 500px) {
  section#common .cv_download .btn a {
    font-size: 12px;
  }
  section#common .cv_download .btn a.pro {
    width: calc(45% - 5px);
  }
  section#common .cv_download .btn a.scr {
    width: calc(55% - 5px);
  }
}

/* ********** HISTORY ********** */

section#history .block {
  padding: 0 5% 100px;
}
section#history .block .block_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
section#history .block h2 {
  margin: 0 0 60px 0;
  text-align: center;
}
section#history .block h2 span {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}

section#history .lead .inner {
  max-width: 800px;
  margin: 0 auto;
}
section#history .lead .inner h3 {
  color: #194480;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
}
section#history .lead .inner p {
  margin: 30px 0 0 0;
}
section#history .list {
  margin: 40px 0 0 0;
  position: relative;
}
section#history .list .inner:after {
  content: "";
  width: 5px;
  height: 100%;
  background: #194480;
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;
  transform: translate(-50%,0);
}
section#history .list .banner {
  max-width: 350px;
  position: absolute;
  top: 0;
  z-index: 2;
  right: calc(50% + 25px);
}
section#history .list .banner img {
  width: 100%;
}
section#history .list .box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
section#history .list .box .left {
  width: 50%;
  padding: 0 25px 0 0;
}
section#history .list .box .right {
  width: 50%;
  padding: 0 0 0 25px;
}
section#history .list .box .year h3 {
  color: #194480;
  font-size: 18px;
  position: relative;
}
section#history .list .box .year h3 span {
  padding: 0 3px 0 0;
  font-size: 36px;
}
section#history .list .box .year h3:before {
  content: "";
  width: 17px;
  height: 17px;
  border-radius: 20px;
  border: 2px solid #194480;
  background: #fff;
  position: absolute;
  left: -35px;
  top: 22px;
}
section#history .list .box .year dl {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section#history .list .box .year dl dt {
  width: 53px;
  font-size: 18px;
  text-align: right;
}
section#history .list .box .year dl dt span {
  padding: 0 3px 0 0;
  font-size: 24px;
}
section#history .list .box .year dl dd {
  width: calc(100% - 65px);
  padding: 10px 0 0 50px;
  font-size: 15px;
  position: relative;
}
section#history .list .box .year dl dd:before {
  content: "";
  width: 35px;
  height: 1px;
  background: #646464;
  position: absolute;
  top: 22px;
  left: 0;
  will-change: transform;
}
section#history .list .box .left .year {
  text-align: right;
}
section#history .list .box .left .year h3:before {
  left: auto;
  right: -35px;
}
section#history .list .box .left .year dl {
  flex-direction: row-reverse;
}
section#history .list .box .left .year dl dd {
  padding: 10px 50px 0 0;
}
section#history .list .box .left .year dl dd:before {
  left: auto;
  right: 0
}
section#history .list .box .item {
  padding: 20px;
  background: #d1dae7;
}
section#history .list .box .item h3 {
  padding: 10px 10px 20px 10px;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5;
}
section#history .list .box .item .txt {
  padding: 20px;
  background: #fff url(../images/step/corner.jpg) no-repeat right top;
}
section#history .list .mt50 {
  margin-top: 50px;
}
section#history .list .box .item1 {
  margin-top: -150px;
}
section#history .list .txt_box {
  padding: 30px 0 0 0;
  text-align: center;
}
section#history .list .txt_box p {
  color: #194480;
  font-size: 24px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  section#history .block {
    padding: 0 5% 30px;
  }
  section#history .block h2 {
    margin: 0 0 30px 0;
  }
  section#history .block h2 span {
    font-size: 20px;
  }

  section#history .lead .inner {
    padding: 0;
  }
  section#history .lead .inner h3 {
    font-size: 16px;
  }
  section#history .lead .inner p {
    margin: 20px 0 0 0;
  }
  section#history .list .inner:after {
    width: 3px;
    top: 0;
    left: 5px;
    transform: translate(0,0);
  }
  section#history .list .banner {
    max-width: 350px;
    margin: 0 0 40px 20px;
    position: static;
  }
  section#history .list .banner img {
    width: 100%;
  }
  section#history .list .box {
    margin: 0 0 30px 0;
  }
  section#history .list .box.reverse {
    flex-direction: column-reverse;
  }
  section#history .list .box .left {
    width: 100%;
    padding: 0 0 0 25px;
  }
  section#history .list .box .right {
    width: 100%;
    padding: 0 0 0 25px;
  }
  section#history .list .box .year h3 {
    font-size: 14px;
  }
  section#history .list .box .year h3 span {
    padding: 0 3px 0 0;
    font-size: 22px;
  }
  section#history .list .box .year h3:before {
    content: "";
    width: 13px;
    height: 13px;
    left: -27px;
    top: 12px;
  }
  section#history .list .box .year dl dt {
    width: 40px;
    font-size: 13px;
    text-align: right;
  }
  section#history .list .box .year dl dt span {
    padding: 0 3px 0 0;
    font-size: 18px;
  }
  section#history .list .box .year dl dd {
    width: calc(100% - 50px);
    padding: 5px 0 0 40px;
    font-size: 13px;
  }
  section#history .list .box .year dl dd:before {
    width: 25px;
    top: 17px;
    left: 0;
  }
  section#history .list .box .left .year {
    text-align: left;
  }
  section#history .list .box .left .year h3:before {
    left: -27px;
  }
  section#history .list .box .left .year dl {
    flex-direction: row;
  }
  section#history .list .box .left .year dl dd {
    padding: 5px 0 0 40px;
  }
  section#history .list .box .left .year dl dd:before {
    top: 17px;
    left: 0;
  }
  section#history .list .box .item {
    margin: 15px 0 0 0!important;
  }
  section#history .list .box .item h3 {
    padding: 0 0 20px 0;
    font-size: 16px;
  }
  section#history .list .box .item .txt {
    font-size: 13px;
  }
  section#history .list .mt50 {
    margin-top: 0;
  }
  section#history .list .box .item1 {
    margin-top: 0;
  }
  section#history .list .txt_box {
    padding: 30px 0 0 0;
    text-align: center;
  }
  section#history .list .txt_box p {
    font-size: 16px;
  }
}

/* ********** DOCUMENTS ********** */

section#documents .block {
  padding: 0 5% 0;
  position: relative;
}
section#documents .block .inner {
  max-width: 1200px;
  margin: 0 auto;
}
section#documents .block .title {
  text-align: center;
}
section#documents .block .title h1 {
  padding: 0 5px 5px;
  color: #194480;
  font-size: 24px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline;
}
section#documents .block .title p {
  margin: 20px 0 0 0;
  font-size: 16px;
}
section#documents .block ul {
  margin: 60px 0 100px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
section#documents .block ul li {
  width: calc(33.33% - 20px);
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
section#documents .block ul li p {
  color: #194480;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  flex: 1;
}
section#documents .block ul li p span {
  font-size: 14px;
  font-weight: 700;
  display: block;
}
section#documents .block ul li p em {
  color: #c7161e;
  font-weight: 700;
  font-style: normal;
}
section#documents .block ul li .box {
  margin: 10px 0 0 0;
}
section#documents .block ul li .box figure {
  position: relative;
}
section#documents .block ul li .box figure img {
  width: 100%;
}
section#documents .block ul li .box figure .icon {
  width: 30%;
  position: absolute;
  left: 0;
  top: 0;
}
section#documents .block ul li .btn {
  margin: 20px 0 0 0;
  padding: 0 15px 15px 15px;
  text-align: center;
}
section#documents .block ul li .btn a {
  padding: 10px 30px;
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  border-radius: 30px;
  border: 2px solid #2667d6;
  background: #2667d6;
  display: inline-block;
}
section#documents .block ul li .btn a:hover {
  color: #2667d6;
  background: #fff;
  opacity: 1;
}

@media screen and (max-width: 767px) {
  section#documents .block {
    padding: 20px 5% 40px;
  }
  section#documents .block .title h1 {
    font-size: 20px;
  }
  section#documents .block .title p {
    font-size: 14px;
  }
  section#documents .block ul {
    margin: 40px 0 0 0;
    gap: 20px;
  }
  section#documents .block ul li {
    width: 100%;
  }
  section#documents .block ul li p {
    font-size: 18px;
  }
  section#documents .block ul li p span {
    font-size: 13px;
  }
  section#documents .block ul li .btn {
    padding: 0 15px 15px 15px;
    text-align: center;
  }
  section#documents .block ul li .btn a {
    padding: 5px 30px;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    border-radius: 30px;
    border: 2px solid #194480;
    background: #194480;
    display: inline-block;
  }
  section#documents .block ul li .btn a:hover {
    color: #194480;
    background: #fff;
    opacity: 1;
  }
}

/* ********** DOCUMENTS SINGLE ********** */

section#documents_single .block {
  padding: 30px 5% 100px;
  position: relative;
  display: flex;
}
section#documents_single .block .inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
section#documents_single .block .form iframe {
  width: 100%;
  position: sticky;
  top: 110px;
}
section#documents_single .block .txt_block {
  width: 60%;
}
section#documents_single .block .txt_block h1 {
  margin: 0 0 20px 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4;
}
section#documents_single .block .txt_block h1 em {
  color: #c7161e;
  font-weight: 500;
  font-style: normal;
}
section#documents_single .block .txt_block h1 strong {
  padding: 0 0 0 20px;
  font-size: 15px;
}
section#documents_single .block .swiper-button-prev {
  width: 32px;
  height: 32px;
  left: 10px;
  background: url(../images/top/ico_prev.png) no-repeat center center / 100% 100%;
}
section#documents_single .block .swiper-button-next {
  width: 32px;
  height: 32px;
  right: 10px;
  background: url(../images/top/ico_next.png) no-repeat center center / 100% 100%;
}
section#documents_single .block .swiper-button-prev::after,
section#documents_single .block .swiper-button-next::after {
  display: none;
}
section#documents_single .txt_block .slider-thumbnail {
  margin: 20px 0 0 0;
}
section#documents_single .txt_block .image figure {
  max-width: 385px;
  margin: 0 auto;
}
section#documents_single .txt_block .image ul {
  margin: 20px 0 0 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
section#documents_single .txt_block .image ul li {
  width: calc(33.33% - 13.4px);
}
section#documents_single .txt_block .image .swiper-slide {
  position: relative;
}
section#documents_single .txt_block .image .swiper-slide .icon {
  width: 30%;
  position: absolute;
  left: 0;
  top: 0;
}
section#documents_single .txt_block .content {
  font-size: 15px;
}
section#documents_single .txt_block .content p + p {
  margin: 30px 0 0 0;
}
section#documents_single .txt_block .content h2 {
  margin: 40px 0 20px 0;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
}
section#documents_single .block .form {
  width: 40%;
  margin: 0 -30px 0 0;
  /* background: #e8ecf4; */
}
section#documents_single .block .form .title {
  text-align: center;
}
section#documents_single .block .form h3 {
  margin: 0 0 20px 0;
  color: #194480;
  font-size: 17px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline-block;
}
section#documents_single .block .form p {
  padding: 0 15px 10px;
}

@media screen and (max-width: 767px) {
  section#documents_single .block {
    padding: 20px 5% 40px;
  }
  section#documents_single .block .inner {
    display: block;
  }
  section#documents_single .block .txt_block h1 {
    flex-direction: column;
    align-items: flex-start;
  }
  section#documents_single .block .txt_block h1 strong {
    padding: 0;
    font-size: 14px;
  }
  section#documents_single .block .form {
    width: calc(100% + 40px);
    margin: 40px 0 0 -20px;
  }
  section#documents_single .block .txt_block {
    width: 100%;
  }
  section#documents_single .block .txt_block h1 {
    font-size: 18px;
    margin: 0 0 15px 0;
  }
  section#documents_single .txt_block .slider-thumbnail {
    margin: 10px 0 0 0;
  }

  section#documents_single .txt_block .content {
    font-size: 13px;
  }
  section#documents_single .txt_block .content p + p {
    margin: 20px 0 0 0;
  }
  section#documents_single .txt_block .content h2 {
    margin: 30px 0 20px 0;
    color: #194480;
    font-size: 18px;
    font-weight: 600;
  }
}

/* ********** SEMINAR-INFO SINGLE ********** */

section#seminar-info_single .block {
  padding: 30px 5% 100px;
  position: relative;
  display: flex;
}
section#seminar-info_single .block .inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
section#seminar-info_single .block .inner.center {
  justify-content: center;
}
section#seminar-info_single .block .form iframe {
  width: 100%;
}
section#seminar-info_single .block .txt_block {
  width: 60%;
}
section#seminar-info_single .block .txt_block h1 {
  margin: 0 0 20px 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4;
}
section#seminar-info_single .block .txt_block h1 span {
  font-weight: 500;
}
section#seminar-info_single .block .txt_block h1 strong {
  padding: 0 0 0 20px;
  font-size: 15px;
}
section#seminar-info_single .txt_block h2 {
  margin: 0 0 10px 0;
  color: #194480;
  font-size: 18px;
  font-weight: 600;
}
section#seminar-info_single .txt_block .box {
  margin: 40px 0;
  font-size: 16px;
}
section#seminar-info_single .txt_block .box_top {
  color: #c8171e;
  font-size: 18px;
  font-weight: 700;
}
section#seminar-info_single .block .form {
  width: calc(40% - 40px);
}
section#seminar-info_single .block .form .box {
  position: sticky;
  top: 110px;
}
section#seminar-info_single .block .form .title {
  text-align: center;
}
section#seminar-info_single .block .form h3 {
  margin: 0 0 20px 0;
  color: #194480;
  font-size: 17px;
  font-weight: 600;
  border-bottom: 1px solid #194480;
  display: inline-block;
}
section#seminar-info_single .block .form p {
  padding: 0 15px 10px;
}

@media screen and (max-width: 767px) {
  section#seminar-info_single .block {
    padding: 20px 5% 40px;
  }
  section#seminar-info_single .block .inner {
    display: block;
  }
  section#seminar-info_single .block .txt_block h1 {
    flex-direction: column;
    align-items: flex-start;
  }
  section#seminar-info_single .block .txt_block h1 strong {
    padding: 0;
    font-size: 14px;
  }
  section#seminar-info_single .block .form {
    width: calc(100% + 40px);
    margin: 40px 0 0 -20px;
  }
  section#seminar-info_single .block .txt_block {
    width: 100%;
  }
  section#seminar-info_single .block .txt_block h1 {
    font-size: 18px;
    margin: 0 0 15px 0;
  }
  section#seminar-info_single .txt_block h2 {
    font-size: 16px;
  }
  section#seminar-info_single .txt_block .box {
    margin: 20px 0;
    font-size: 14px;
  }
  section#seminar-info_single .txt_block .box_top {
    font-size: 16px;
  }
}