/*
Theme Name: beyond
Version: 0.2
*/

/* ==========================================================================
Foundation
========================================================================== */

/* Reset
----------------------------------------------------------------- */

* { box-sizing: border-box; }
html, body{
  margin: 0;
  padding: 0;
  overflow-wrap: break-word;
}
h1,h2,h3,h4,h5,p,figure {
  margin: 0;
  padding: 0;
}
ul,ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
img {
  max-width: 100%;
  vertical-align: bottom;
  height: auto;
}
:focus {
  outline: none;
}

/* Base
----------------------------------------------------------------- */
@font-face {
  font-family: number;
  src: local('Hiragino Mincho ProN');
  unicode-range: U+005C;
}

body {
  font-family: number,"游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: #313543;
}

a:hover {
  transition: all .5s;
}

.syntaxhighlighter {
  background-color: #3b4653!important;
}

/* ==========================================================================
Layout
========================================================================== */
.l-lang {
  display: none;
}
.l-lang--sp {
  width: calc(100% - 140px);
}
.l-lang__list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.l-lang__list li a {
  display: block;
  padding: 0 .5em;
  color: #000;
  text-decoration: none;
  line-height: 1;
  font-size: 12px;
}
.l-lang__list li a:hover {
  text-decoration: underline;
}
.l-lang__list li:not(:first-of-type) a {
  border-left: solid 1px #999;
}
.l-site {}
.l-site__navi {
  align-items: center;
  background-color: #fff;
  display: flex;
  justify-content: space-between;
  height: 60px;
  padding: 0 15px;
  position: fixed;
  top:0;
  left: 0;
  width: 100%;
  z-index: 999;
  box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.2);
}
.l-site__content-contain {
  margin-top: 60px;
}
.l-site-footer {
  background-image: url(img/bg--1.jpg);
  background-size: cover;
  padding: 15px;
}

/*2カラム用*/
.l-content-area--post {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
.l-content-area__main--post {
  width: 100%;
  margin: 30px 0 0;
}
.l-single-post .l-content-area__main--post {
  margin: 0;
}
.l-content-area__side--post {
  padding: 50px 0 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
}
.l-content-area--post .p-flexible-container .l-wrap--page {
  padding-right: 0;
  padding-left: 0;
}

/* ==========================================================================
Object
========================================================================== */

/* Component
----------------------------------------------------------------- */
.c-link {
  color: #23a5c2;
}
.c-link:hover {
  text-decoration: none;
}
.c-link-opa:hover {
  opacity: .8;
}
.c-breadcrumb-wrap {
  font-size: 12px;
}
.c-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 5px 15px;
  overflow-x: auto;
}
.c-breadcrumb__item {
  display: flex;
  padding: 5px 0;
}
.c-breadcrumb__item:not(:last-child)::after {
  content: '>';
  margin: 0 5px;
}
.c-breadcrumb__item__link {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #313543;
  text-decoration: none;
}
.c-breadcrumb__item__link__icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-breadcrumb__item__link__icon__home {}


.c-page-nav {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 30px 0 10px;
}
.c-page-nav > a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 10px 30px;
  background: #23A5C2;
  color: #fff;
  text-decoration: none;
  margin: 0 0 20px;
}
.c-page-nav > a:hover {
  opacity: .8;
}
.c-page-nav > a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;

}
.c-page-nav > a.c-page-nav__prev::after {
  left: 10px;
  transform: rotate(225deg);
}
.c-page-nav > a.c-page-nav__next::after {
  right: 10px;
  transform: rotate(45deg);
}

.c-content-block--1 {
  padding: 30px 0;
}
.c-content-block--2 {
  padding: 20px 0;
}

.c-content-child {
  margin-top: 15px;
}

.c-content-bgc--1 {
  background-color: #f2f7fa;
}

.c-content-bgimg--1 {
  background-image: url(img/bg--2.jpg);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
}

.c-content-break-line {
  padding-top: 80px;
}

.c-content-break-line--1 {
  background-image: url(img/break-line--1_g.png), url(img/bg--2.jpg);
  background-position: top center, top center;
  background-repeat: no-repeat, no-repeat;
  background-size: contain, cover;
}
.c-content-break-line--2 {
  background-image: url(img/break-line--2.png);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: contain;
  background-color: #f2f7f9;
}
.c-content-break-line--2_b {
  background-image: url(img/break-line--2_b.png);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: contain;
  background-color: #E6F2FF;
}

.c-content-width--1 {
  padding: 0 15px;
}
.c-content-width--2 {
  padding: 0 15px;
}
.c-content-width--3 {
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px;
  /*max-width: 400px;*/
}
.c-content-width--4 {
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px;
  /*max-width: 400px;*/
}
.c-content-width--5 {
  padding: 0 15px;
}

.c-hamburger-wrap {
  cursor: pointer;
  display: block;
  top: 50%;
}
.c-hamburger {
  width: 30px;
  height: 24px;
  display: inline-block;
  position: relative;
}
.c-hamburger__inner {
  display: block;
  top: 50%;
}
.c-hamburger__inner,
.c-hamburger__inner:before,
.c-hamburger__inner:after {
  width: 30px;
  height: 2px;
  background: linear-gradient(90deg,#105b92,#24a5c2);
  position: absolute;
  transition-property: transform;
  transition-duration: .15s;
  transition-timing-function: ease;
}
.c-hamburger__inner:before,
.c-hamburger__inner:after {
  content: '';
  display: block;
}
.c-hamburger__inner:before {
  top: -10px;
}
.c-hamburger__inner:after {
  bottom: -10px;
}
.c-hamburger-wrap.active .c-hamburger__inner {
  transform: rotate(45deg);
}
.c-hamburger-wrap.active .c-hamburger__inner:before {
  top: 0;
  opacity: 0;
}
.c-hamburger-wrap.active .c-hamburger__inner:after {
  bottom: 0;
  transform: rotate(-90deg);
}


.c-title-1-wrap {
  display: flex;
  justify-content: center;
}
.c-title-1 {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.c-title-1__main {
  color: #0f2f62;
  font-size: 22px;
  line-height: 1.4;
  letter-spacing: .04em;
  text-align: center;
}
.c-title-1__main--fc-white {
  color: #fff;
}
.c-title-1__main__s {
  font-size: 18px;
}
.c-title-1__sub {
  font-family: 'Lato', sans-serif;
  align-items: flex-end;
  color: #24a4c1;
  display: flex;
  font-size: 12px;
  font-weight: 700;
  margin-top: 7px;
  white-space: nowrap;
  line-height: 1.2;
}
.c-title-1__sub::after {
  background-color: #23a6c4;
  content: '';
  display: block;
  height: 1px;
  margin:0 0 5px 5px;
  width: 100%;
  opacity: 0;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
  transition: opacity .2s linear .1s,-webkit-transform 2s cubic-bezier(.19,1,.22,1) .1s;
  transition: opacity .2s linear .1s,transform 2s cubic-bezier(.19,1,.22,1) .1s;
  transition: opacity .2s linear .1s,transform 2s cubic-bezier(.19,1,.22,1) .1s,-webkit-transform 2s cubic-bezier(.19,1,.22,1) .1s;
}
.aos-animate.c-title-1__sub::after {
  opacity: 1;
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}
.c-title-1__sub--2 {
  color: #24a4c1;
  font-size: 12px;
  font-weight: 700;
  margin-top: 7px;
  white-space: nowrap;
  text-align: center;
}
.c-bg--img .c-title-1__main {
  color: #fff;
}
.c-bg--img .c-title-1__sub--2 {
  color: #23a5c2;
}
.c-bg--img__txt p {
  font-size: 14px;
  margin: 0 0 15px;
  text-align: center;
  line-height: 2;
}
.c-bg--img__txt > p:last-of-type {
  margin: 0;
}

.c-title-2 {
  margin-top: 30px;
  color: #0e2e5f;
  display: flex;
  flex-direction: column;
}
.c-title-2__main {
  font-size: 20px;
  letter-spacing: .05em;
  white-space: nowrap;
  line-height: 1.2;
}
.c-title-2__sub {
  font-family: 'Lato', sans-serif;
  align-items: flex-end;
  display: flex;
  font-size: 12px;
  font-weight: 700;
  margin-top: 5px;
  white-space: nowrap;
  width: 100%;
  line-height: 1.2;
}
.c-title-2__sub::after {
  background-color: #0e2e5f;
  content: '';
  display: block;
  height: 1px;
  margin:0 0 5px 10px;
  width: 100%;
  opacity: 0;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform 1.3s;
}
.aos-animate.c-title-2__sub::after {
  opacity: 1;
  transform: scale(1, 1);
}

.c-title-2__sub:empty::after {
  margin-left: 0;
}


.c-title-3 {
  color: #313543;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.9;
}

.c-title-4 {
  margin: 0 0 20px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
}
.c-title-5 {
  margin: 0 0 20px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: .1rem;
}
.c-title-6 {
  margin: 0 0 15px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: .1rem;
}

.c-title-7 {
  margin: 2em 0 1em;
  padding: 0 0 5px;
  font-size: 20px;
  font-weight: bold;
  color: #0f2f62;
  border-bottom: solid 3px #0a3874;
}
.c-title-8 {
  margin: 0 0 15px;
  font-size: 18px;
  font-weight: bold;
}
.c-title-9 {
  position: relative;
  padding: 0 0 0 .5em;
  margin: 2em 0 1em;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.3;
}
.c-title-9::before {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 6px;
  height: 100%;
  background: linear-gradient(to bottom, #1e5799 0%,#1F97B8 100%);
}
.c-title-10 {
  margin: 0 0 15px;
  font-size: 16px;
  font-weight: bold;
}

.c-em--1 {
  color: #106196;
  font-weight: bold;
}
h2 .c-em--1 {
  background: #c9e7ee;
  padding: .2em;
  font-weight: bold;
  color: #333;
}

.c-btn--1 {
  align-items: center;
  background-color: #aaa;
  border-radius: 30px;
  box-shadow: 0px 6px 7px 0px rgba(174, 167, 180, 0.21);
  color: #fff;
  display: flex;
  font-size: 14px;
  justify-content: space-between;
  padding: 15px;
  text-decoration: none;
}
.c-btn--1::after {
  content: '';
  background-repeat: no-repeat;
  background-size: cover;
  width: 24px;
  height: 20px;
}
.c-btn--1--contact-us {
  background-color: #e0102b;
}
.c-btn--1--contact-us::after {
  position: absolute;
  right: 15px;
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url(img/icon-mail--1.png);
}
.c-btn--1--download {
  background-color: #0a3874;
}
.c-btn--1--download::after {
  position: absolute;
  right: 15px;
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url(img/icon-book--1.png);
}
.c-btn--1--faq {
  background-color: #008b8b;
}
.c-btn--1--faq::after {
  position: absolute;
  right: 15px;
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url(img/icon-faq--1.png?v2);
}
.c-btn--1--contact-us,
.c-btn--1--download,
.c-btn--1--faq {
  max-width: 450px;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  width: calc(100% - 30px);
  justify-content: center;
}

.c-btn--2 {
  align-items: center;
  background-color: #fff;
  box-shadow: 0px 5px 15px 0px rgba(14, 46, 95, 0.05);
  color: #313543;
  display: flex;
  font-size: 14px;
  padding: 15px;
  text-decoration: none;
  width: 100%;
}
.c-btn--2--col {
  flex-direction: column;
}
.c-btn--2--row {}

.c-btn--2--col__icon__img {
  max-width: 65px;
}
.c-btn--2--col__icon__img--2 {
  max-width: 97px;
}
.c-btn--2--col__title {
  font-size: 18px;
  font-weight: 700;
  margin: 10px 0;
}
.c-btn--2--col__text {
  font-size: 14px;
  line-height: 1.8;
  margin-top: 5px;
}
.c-btn--2--row__icon {
  margin-right: 12px;
}
.c-btn--2--row__icon__img {
  max-width: 47px;
}
.c-btn--2--row__title {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
.c-btn--2--row-2__icon {
  margin-right: 12px;
}
.c-btn--2--row-2__icon__img {
  max-width: 93px;
}
.c-btn--2--row-2__text {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
}

.c-btn--3 {
  background-image: linear-gradient(90deg,#105b92 0%,#24a5c2 50%,#105b92 100%);
  /* background-image: linear-gradient(90deg,#1287cd 0,#3cc 50%,#1287cd); */
  color: #fff;
  display: block;
  font-size: 16px;
  text-decoration: none;
  text-align: center;
  background-position: 100%;
  background-size: 200% auto;
  transition: background 1s cubic-bezier(.19,1,.22,1);
}
.c-btn--3:hover {
  background-position: 0;
}
.c-btn--3__inner {
  background-image: url(img/icon-arrow--2.png);
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding: 21px 25px 21px 15px;
}
.c-btn--3--white {
  background: #fff;
  color: #313543;
}
.c-btn--3--white__inner {
  background-image: url(img/icon-arrow--3.png);
}
.c-btn {
  display: inline-block;
}
.c-btn--fc {
  max-width: 80%;
  font-size: 14px;
  color: #e0102b;
}
.c-btn--fc-bg {
  min-width: 280px;
  padding: 1rem 3rem;
  background-position: right 1.8rem center;
  background-repeat: no-repeat;
  background-size: 4px;
  border-radius: 30px;
  border: 2px solid #e0102b;
}
.c-btn--fc-1 {
  background-color: #e0102b;
  background-image: url(img/icon-arrow--2.png);
  color: #fff;
  transition: all .5s;
}
.c-btn--fc-1:hover {
  background-color: #fff;
  background-image: url(img/icon-arrow--4.png);
  color: #e0102b;
}
.c-btn--subtxt {
  display: block;
  font-size: 90%;
}
.wpcf7 input[type="submit"][disabled].c-btn--fc-1:hover {
  background-image: url(img/icon-arrow--2.png);
}
.c-btn--narrow {
  font-feature-settings: "palt";
  white-space: nowrap;
}
@media screen and (max-width:340px) {
  .c-btn--narrow {
    font-size: 15px;
  }
}

.c-post-list {
  display: flex;
  flex-wrap: wrap;
}
.c-post-list--works {}
.c-post-list__item {
  width: 48.5%;
}
.c-post-list__item:nth-child(odd) {
  margin-right: 3%;
}
.c-post-list__item:nth-child(n + 3) {
  margin-top: 10px;
}
.c-post-list__item__link {
  color: #313543;
  display: block;
  text-decoration: none;
}
.c-post-list__item__link__img-wrap {
  background-color: #fff;
  border: 1px solid #80c2df;
}
.c-post-list__item__link__img {
  display: block;
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  padding: 59.1% 0 0;
}

.c-post-list__item__link__date {
  font-size: 14px;
  margin-top: 5px;
  padding: 4px 0;
}
.c-post-list__item__link__tag {
  background-color: #67c3e5;
  border-radius: 4px;
  color: #fff;
  display: inline-block;
  font-size: 12px;
  margin-top: 5px;
  padding: 4px;
}
.c-post-list__item__link__title {
  font-size: 16px;
  line-height: 1.4;
  margin-top: 5px;
}
.c-post-list__item__link__name {
  font-size: 14px;
  margin-top: 5px;
}
.c-post-list--news__item__link {
  color: #fff;
}
.c-post-list--news__item__link__img-wrap {
  border: none;
}
.c-post-list--news__item__link__date-tag-wrap {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
.c-post-list--news__item__link__tag {
  display: block;
  padding-bottom: 2px;
}

.c-post-share {
  display: flex;
  align-items: center;
  margin: 0 0 20px auto;
  justify-content: flex-end;
  flex: 0 0 auto;
}
.c-post-rating {
  margin: 0 10px 0 0;
}
.c-rating {
  display: flex;
  align-items: center;
  background: url(img/post-favorite.svg) no-repeat left center;
  background-size: 16px;
  font-size: 14px;
  font-weight: bold;
  color: #FF6666;
  line-height: 1;
}
.c-rating img {
  opacity: 0;
  margin: 0 5px 0 0 !important;
}
.c-rating:hover,
.c-rating--done {
  background-image: url(img/post-favorite_on.svg?v3);
}
.post-ratings-loading {
  position: absolute;
  opacity: 0;
}
.c-post-vote {
  margin: 0 auto 0 0;
  border: 1px solid #555555;
  padding: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin: 0 0 15px;
}
.c-post-vote span {
  display: inline-block;
}
.c-post-vote__txt {
  font-size: 16px;
  color: #FF6666;
  margin: 0 0 10px 0;
  font-weight: bold;
}
.c-post-vote__rating {
  background: #FFFFDD;
  padding: 5px 10px;
  border-radius: 4px;
}
@media screen and (max-width: 480px) {
  .c-post-vote {
    padding: 10px;
    text-align: center;
  }
}


.c-post-sns {
  display: flex;
}
.c-post-sns a {
  margin: 0 0 0 12px;
}
.c-post-sns img {
  margin: 0 !important;
}
.c-post-view {
  background: url(img/post-view.svg?v2) no-repeat left center;
  background-size: 16px;
  padding: 0 0 0 20px;
  font-weight: bold;
  font-size: 14px;
  color: #339966;
}
.c-tag-news {
  background-color: #67c3e5;
}
.c-tag-blog {
  background-color: #e56767;
}
.c-tag-event {
  background-color: #5fcd83;
}


.c-table {
  align-items: center;
  border-top: 1px solid #b3dee8;
  margin: 0;
  padding: 0;
}
.c-table__th {
  background-color: #eef8f9;
  border-bottom: 1px dashed #b3dee8;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.8;
  margin: 0;
  padding: 10px;
  width: 100%;
}
.c-table__th__notice {
  font-size: 12px;
  font-weight: 400;
}
.c-table__td {
  border-bottom: 1px solid #b3dee8;
  font-size: 14px;
  line-height: 1.8;
  margin: 0;
  padding: 10px 10px 20px;
  width: 100%;
}
.c-table__td p + p {
  margin-top: 15px;
}

.c-table-min {
  border-collapse: collapse;
}
.c-table-min th,
.c-table-min td {
  font-size: 90%;
  border: 1px solid #ccc;
  padding: 5px;
  line-height: 1.4;
}
.c-table-min__verticalhead {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-align: center;
  line-height: 1;
  letter-spacing: .3em;
}

.c-timeline-wrapper {
  padding-bottom: 60px;
}
.c-timeline {
  position: relative;
  margin: 30px 0 0;
  padding: 40px 50px 0 130px;
  display: flex;
  justify-content: space-between;
}
.c-timeline::before {
  content: "";
  position: absolute;
  display: inline-block;
  background-color: #143c74;
  border: 1px solid #143c74;
  width: 80px;
  height: 100%;
  left: 28px;
  top: 42px;
}
.c-timeline::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  position: absolute;
  left: 28px;
  bottom: -30px;
  border-style: solid;
  border-width: 30px 41px 0 41px;
  border-color: #143c74 #fff #fff #fff;
  z-index: 10;
  bottom: -44px;
}
.c-timeline__item {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.c-timeline {
  counter-increment: term;
}
.c-timeline .c-timeline__item:nth-of-type(1) dt::before {
  content: "第" counter(term, decimal-leading-zero) "期";
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: .05em;
  position: absolute;
  left: -89px;
  top: 0;
  z-index: 10;
}


.c-timeline__dt {
  color: #143c74;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.8;
  margin: 0;
  padding: 0 5px;
  width: 100%;
  position: relative;
}
.c-timeline__dd {
  font-size: 16px;
  line-height: 1.8;
  margin: 0;
  padding: 5px;
  width: 100%;
}
.c-timeline__img {
  margin: 0 0 0 20px;
  width: 360px;
  flex: 0 0 auto;
}
.c-timeline__dd p + p {
  margin-top: 5px;
}

@media screen and (max-width: 768px) {
  .c-timeline {
    margin: 30px 0 0;
    padding: 30px 25px 0 130px;
    flex-direction: column;
  }
  .c-timeline::before {
    left: 24px;
    top: 36px;
  }
  .c-timeline::after {
    left: 24px;
    bottom: -38px;
  }
  .c-timeline .c-timeline__item:nth-of-type(1) dt::before {
    left: -94px;
  }
  .c-timeline__dd {
    flex-direction: column;
  }
  .c-timeline__img {
    margin: 0;
    width: 100%;
  }
}

@media screen and (max-width: 480px) {
  .c-timeline {
    padding: 30px 20px 30px 45px;
  }
  .c-timeline__content,
  .c-timeline__img {
    padding: 0 0 0 30px;
  }
  .c-timeline::before {
    width: 56px;
    left: 8px;
  }
  .c-timeline::after {
    left: 8px;
    bottom: -48px;
    border-width: 30px 29px 0 29px;
  }
  .c-timeline__dt {
    font-size: 16px;
  }
  .c-timeline__dd {
    font-size: 14px;
  }
  .c-timeline .c-timeline__item:nth-of-type(1) dt::before {
    font-size: 14px;
    letter-spacing: 0;
    left: -60px;
    top: .1em;
  }
}


.c-list__item {
  display: flex;
}
.c-list__item::before {
  content: '■';
  padding-right: 5px;
}
.c-list--1 > .c-list__item:not(:first-child) {
  margin-top: 15px;
}
.c-list--2 > .c-list__item::before {
  content: none;
}
.c-list--3 > .c-list__item::before {
  content: '〇';
}

.c-google-map {
  position: relative;
  padding-bottom: 53.448275862%;
  height: 0;
  overflow: hidden;
}
.c-google-map iframe,
.c-google-map object,
.c-google-map embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.c-gradient-box--1 {
  border-image: linear-gradient(45deg, #1e5799 0%,#00c4c9 100%) 1/1px;
  border-style: solid;
}
.c-gradient-box--2 {
  border-image: linear-gradient(45deg, #1e5799 0%,#00c4c9 100%) 1/2px;
  border-style: solid;
}

.c-bg--1 {
  background: #f2f7f9;
}
.c-bg--2 {
  background: #fff;
}
.c-bg--img {
  color: #fff;
}

.c-box--1 {
  background: #fff;
}

.c-wrap--1 {
  margin: 35px 0 0;
}
.c-wrap--2 {
  margin: 15px 0 0;
}

.c-list--ol,
.c-list--ul {
  padding: 0 0 0 2em;
}
.c-list--ol {
  list-style-type: decimal;
}
.c-list--ul {
  list-style-type: disc;
}

.c-tag-list {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  padding: 8px 0 8px 20px;
  margin: 0 0 24px 0;
  background: url(img/ico_tag.png) no-repeat left center;
  font-size: .9rem;
}
.c-tag-list a {
  text-decoration: none;
  color: #333;
  transition: all .0s;
}

.c-blog-status {
  background: #ffff99;
  padding: 10px 15px;
}
.c-blog-status p {
  line-height: 1.6 !important;
  margin: 0 !important;
  font-size: 14px;
}
.c-blog-status p::before {
  content: '';
  display: inline-block;
  margin: 0 .5em 0 0;
  width: 15px;
  height: 22px;
  vertical-align: middle;
  background: url(img/ico_exclam.svg) no-repeat left 2px;
  background-size: contain;
}

.c-single-content p.p-event-date {
  margin: 0 0 10px;
  width: 100%;
  color: #23a5c2;
  font-size: 14px;
  font-weight: bold;
}
.c-single-content .c-article-info .p-archive-block__txt__cat {
  width: 100%;
}
.c-single-content .c-article-info .p-archive-block__txt__cat ul {
  margin: 0 0 10px;
}
.c-single-content .c-article-info .p-archive-block__txt__cat ul li {
  padding-left: 8px;
  text-indent: 0;
}
.c-single-content .c-article-info .p-archive-block__txt__cat ul li::before {
  content: "";
  margin: 0;
}
.c-single-content .c-article-info .p-archive-block__txt__cat ul li a {
  color: #313543;
  text-decoration: none;
}
.c-single-content .c-article-info .p-archive-block__txt__cat ul li a:hover {
  opacity: .8;
}


.c-single-content {
  padding-top: 15px;
  padding-bottom: 15px;
  line-height: 1.5;
}
.c-single-content h1 {
  margin: 0 0 20px;
  font-size: 22px;
  font-weight: bold;
}
.c-single-content h2,
.c-single-content h3,
.c-single-content h4 {
  clear: both;
}
.c-single-content .c-article-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (max-width: 589px) {
  .c-post-share {
    width: 100%;
    margin-top: -12px;
  }
  .c-post-share--footer {
    margin-top: 0;
  }
}

.c-single-content h2 {
  margin: 1.5em 0 1.5em;
  padding: 5px 12px;
  font-size: 20px;
  font-weight: bold;
  color: #0f2f62;
  background: #f2f7f9;
  border: 3px solid #0f2f62;
  box-shadow: 5px 5px 0 #0f2f62;
  /*border-bottom: solid 3px #0a3874;*/
  /*border-bottom: solid 3px #23a5c2;*/
}
.c-single-content h3 {
  margin: 1.7em 0 1em;
  padding: .3em .5em;
  font-size: 17px;
  font-weight: bold;
  background: #f2f7f9;
  border-left: solid 5.5px #0a3874;
  /*border-left: solid 4px #23a5c2;*/

}
.c-single-content h4 {
  margin: 1.5em 0 1em;
  font-size: 15px;
  font-weight: bold;
  /*border-left: solid 4px #23a5c2;*/
}
.c-single-content p {
  margin: 0 0 1.5em;
  line-height: 2;
  word-wrap: break-word;
}
.c-single-content * {
  max-width: 100%;
}
.c-single-content img,
.c-single-content .thumb {
  height: auto!important;
  margin: 1em 0;
}
.c-single-content .thumb img {
  margin: 0;
}
.c-single-content img.aligncenter,
.c-single-content img.alignleft,
.c-single-content img.alignright {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.c-single-content hr {
  margin: 1.5em 0;
  border: solid 0.5px #ccc;
}
.c-single-content ol {
  list-style: none;
  padding: 0;
  counter-reset: item;
  margin: 0 0 1.2em;
}
.c-single-content ol li {
  /* text-indent: -1.5em;
  padding-left: 1.5em; */
  padding-left: 32px;
  margin: 0 0 .5em;
}
.c-single-content ol li::before {
  display: block;
  float: left;
  counter-increment: item;
  content: counter(item);
  background: #0a3874;
  color: #fff;
  font-weight: bold;
  font-size: .8em;
  /* padding: .15em .6em; */
  width: 22px;
  height: 22px;
  line-height: 23px;
  border-radius: 50%;
  text-align: center;
  margin: 0 0 0 -32px;
}
.c-single-content ul {
  margin: 0 0 1.2em;
}
.c-single-content ul li {
  text-indent: -1.5em;
  padding-left: 1.5em;
  margin: 0 .5em .5em 0;
}
.c-single-content ul li::before {
  content: "・";
  margin: 0 .5rem 0 0;
  color: #0a3874;
  font-weight: bold;
}
.c-single-content blockquote {
  position: relative;
  margin: 0 0 1.2em;
  background: #f2f7f9;
  padding: 1.5em;
}
.c-single-content blockquote::before {
  position: absolute;
  left: .2em;
  top: .2em;
  content: url(img/single-quote--1.png);
}
.c-single-content blockquote::after {
  position: absolute;
  right: .2em;
  bottom: .2em;
  content: url(img/single-quote--2.png);
}
.c-single-content .c-single-info {
  border: solid 2px #23a5c2;
  padding: 1.5em;
  margin: 1.5em 0;
}
.c-single-content .c-single-info > *:last-child,
.c-single-content blockquote > *:last-child {
  margin-bottom: 0;
}

.c-single-content table,
.c-table--1 {
  min-width: 770px;
  border: solid 1px #d9dbdd;
  margin: 0 0 1.5em;
  border-collapse: collapse;
}
.c-single-content table th,
.c-table--1 th {
  padding: 1em;
  border: solid 1px #d9dbdd;
  background: #f2f7f9;
  font-weight: bold;
  text-align: center;
}
.c-single-content table td,
.c-table--1 td {
  padding: 1em;
  border: solid 1px #d9dbdd;
}
/* .c-single-content table tr:last-of-type > *:last-child {
border-bottom: none;
} */
.c-single-content pre {
  position: relative;
  padding: 1.5em;
  margin: 0 0 1.2em;
  white-space: pre-wrap;
}
.c-single-content a {
  color: #23a5c2;
  text-decoration: underline;
}
.c-single-content a:hover {
  text-decoration: none;
}
.c-single-content a:hover img {
  opacity: .8;
}
.c-single-content .taC {
  text-align: center;
}
.c-single-content strong {
  background: linear-gradient(transparent 60%, #f2f7f9 0%) ;
  font-weight: bold;
}
.c-single-content a.c-single-btn {
  position: relative;
  background: linear-gradient(90deg,#105b92,#24a5c2);
  color: #fff;
  display: block;
  padding: 15px 25px 15px 15px;
  margin: 1.2em auto;
  max-width: 370px;
  font-size: 14px;
  text-decoration: none;
  text-align: center;
}
.c-single-content a.c-single-btn::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 10px;
  width: 8px;
  height: 11px;
  margin: auto;
  background: url(img/icon-arrow--2.png) no-repeat;
}
.c-single-content .c-btn--3 {
  color: #fff;
  text-decoration: none;
}
.c-scrollable-table {
  overflow-x: auto;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .c-spblock-table {
    min-width: inherit !important;
  }
  .c-spblock-table,
  .c-spblock-table tbody,
  .c-spblock-table tr,
  .c-spblock-table th,
  .c-spblock-table td {
    display: block;
    width: 100% !important;
    height: auto !important;
    white-space: normal !important;
  }
}

.c-slide-arrow {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 30px;
  height: 30px;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  z-index: 2;
}
.c-prev-arrow {
  background: url(img/arrow-prev.png);
  background-size: cover;
  left: 5px;
}
.c-next-arrow {
  background: url(img/arrow-next.png);
  background-size: cover;
  right: 5px;
}

.c-table--1 th {
  background: #eff6f8;
}


.c-tax {
  display: inline-block;
  padding: 3px 10px;
  z-index: 2;
  font-size: .93rem;
  font-weight: bold;
  line-height: 1.3;
  background-color: #C3273C;
  color: #fff;
}
.c-tax--form {
  margin: 5px 0;
  margin-left: 10px;
  font-weight: normal;
}
.c-tax--form--any {
  background-color: #8E8E8E;
}

.c-tax-list {
  display: flex;
  flex-wrap: wrap;
}
.c-tax-list__item {
  display: inline-block;
  padding: 4px 8px;
  margin: 0 .5em .5em 0;
  background: #DAE8EF;
  font-size: 12px;
  font-weight: bold;
}


.c-author-box {
  background: #fff;
  margin: 30px 0 0;
  padding: 15px;
  line-height: 1.5;
}
.c-author-box__info {
  margin: 30px 0 0;
}
.c-author-box__info__img {
  width: 150px;
  margin: 0 auto;
}
.c-author-box__info__img img {
  height: auto;
}
.c-author-box__info__txt {
  margin: 20px 0 0;
}
.c-author-box__info__head {
  margin: 0;
  text-align: center;
}
.c-author-box__info__head a {
  color: #333;
  text-decoration: none;
}
.c-author-box__info__head a:hover {
  text-decoration: underline;
}
.c-author-box__info__desc {
  margin: 15px 0 0;
}
.c-author-box__info__desc p {
  margin: 0 0 1em;
}
.c-author-box__info__sns {
  margin: 20px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-author-box__info__sns li:not(:last-of-type) {
  margin: 0 10px 0 0;
}
.c-author-box__info__sns li a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  width: 40px;
  height: 40px;
  color: #fff;
  border-radius: 50%;
  padding: 7px;
  text-decoration: none;
}
.c-author-box__info__sns li.c-author-box__info__sns__twi a {
  background: #000000;
}
.c-author-box__info__sns li.c-author-box__info__sns__fb a {
  background: #4267B2;
}
.c-author-box__info__sns li.c-author-box__info__sns__insta a {
  background: linear-gradient(-135deg, #1400c8, #b900b4, #f50000);
}
.p-author-archive .c-author-box {
  margin: 0 0 50px;
}


/*animation*/
[data-aos^=fade][data-aos^=fade][data-aos-easing=ease], 
body[data-aos-easing=ease] [data-aos^=fade] {
  transition-duration: .8s;
}

/*c-imgblock*/
.c-imgblock {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px solid #203c74;
  background: #fff;
  padding: 25px;
  margin: 20px 0 0;
}
.c-imgblock:first-of-type {
  margin-top: 30px;
}
.c-imgblock:nth-of-type(2n) {
  flex-direction: row-reverse;
}
.c-imgblock__img {
  width: 48%;
  text-align: center;
}
.c-imgblock__txt {
  width: 50%;
}
.c-imgblock__title {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.4;
}
.c-imgblock__txt p {
  margin: 1em 0 0;
}
@media screen and (max-width: 768px) {
  .c-imgblock {
    display: block;
    padding: 20px;
    margin: 15px 0 0;
  }
  .c-imgblock:first-of-type {
    margin-top: 20px;
  }
  .c-imgblock__img {
    width: 100%;
  }
  .c-imgblock__txt {
    width: 100%;
  }
  .c-imgblock__img + .c-imgblock__txt {
    margin: 15px 0 0;
  }
  .c-imgblock__txt + .c-imgblock__img {
    margin: 15px 0 0;
  }
  .c-imgblock__title {
    font-size: 18px;
  }
}

.c-col2 {
  display: flex;
  justify-content: space-between
}
.c-col2-item {
  width: 48%;
}
@media screen and (max-width: 768px) {
  .c-col2 {
    display: block;
  }
  .c-col2-item {
    width: 100%;
    margin: 15px 0 0;
  }
  .c-col2-item:first-of-type {
    margin: 0;
  }
}

/* Project
----------------------------------------------------------------- */

/*--------------------
aside
--------------------*/

.p-side {
  font-size: 14px;
  line-height: 1.5;
}

.p-side__item {
  background: #fff;
}

.p-side__item:not(:first-child) {
  margin-top: 20px;
}

.p-side__tit {
  background: #23A5C2;
  color: #fff;
  padding: 10px;
  font-weight: bold;
  text-align: center;
  font-size: 16px;
}

.p-side__list__item > a {
  display: block;
  padding: 10px;
  position: relative;
  color: #333;
  text-decoration: none;
}

.p-side__list .p-side__list__item > a {
  display: flex;
  align-items: center;
}
.p-side__list .p-side__list__item > a:hover {
  opacity: .8;
}
.p-side-wpp-no-data {
  padding: 10px;
}

.p-entry-thumb--side {
  flex-shrink: 0;
  width: 75px;
  height: 75px;
  margin-right: 10px;
}

.p-side__item--tags {
  /*order: 3;*/
}
.p-side__tit--tags {
  width: 100%;
}
.p-side__list--tags {
  display: flex;
  flex-wrap: wrap;
  padding: 20px 10px;
}
.p-side__list--tags .p-side__list__item:not(:last-child) {
  margin: 0 1rem 1rem 0;
}
.p-side__item--tags a {
  position: relative;
  width: auto;
  background: none;
  border: 1px dotted #09c;
  padding: 8px 14px 8px 20px;
  font-size: 14px;
  color: #09c;
}
.p-side__item--tags a::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 4px;
  height: 4px;
  border-top: 1px solid #09c;
  border-right: 1px solid #09c;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

aside.l-content-area__side--post {
  flex-direction: column;
  flex-wrap: nowrap;
}
.p-side__item:not(.p-side__item--tags) {
  width: 100%;
}
.p-side__item:last-child,
.p-side__item--tags {
}
.p-entry-thumb {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: all .5s;
}




.p-site-title {
  display: block;
  margin: 0;
  padding: 0;
}
.p-site-title__link {
  display: block;
  margin: 0;
  padding: 0;
}
.p-site-title__link__img {
  display: block;
  width: 76px;
}
.p-site-description {
  display: none;
}

.p-site-menu {
  background-color: #f2f7f9;
  display: none;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 15px 15px;
  position: fixed;
  top: 60px;
  left: 0;
  bottom: 0;
  width: 100%;
}
.p-site-menu.active {
  display: block;
}
.p-site-menu__list {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
.p-site-menu__list__item {}
.p-site-menu__list__item:nth-last-child(1),
.p-site-menu__list__item:nth-last-child(2) {
  margin-top: 10px;
}
.p-site-menu__list__item:nth-last-child(3) {
  margin-top: 20px;
}
.p-site-menu__list__item__link {
  position: relative;
  color: #000;
  display: block;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 15px;
  text-decoration: none;
  border-bottom: solid 1px #ccc;
}
.p-site-menu__list__item__link::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 4px;
  height: 4px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
}
.p-site-menu__tel {
  border-top: 1px solid #eee;
  margin-top: 20px;
  padding: 20px 0;
  box-shadow: 0px 1px 7px 0px rgba(174, 167, 180, 0.21);
  background: #fff;
}
.p-site-menu__tel__text {
  font-size: 16px;
  line-height: 1.4;
  text-align: center;
  font-weight: bold;
  color: #0f2f62;
}
.p-site-menu__tel__link {
  display: block;
  margin-top: 15px;
}
.p-site-menu__tel__link__img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 80%;
  max-width: 295px;
}

.p-site-menu__sns {
  margin: 20px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 20px;
}
.p-site-menu__sns li {
  width: 40px;
  margin: 0 8px;
}

/*slick*/
.p-home--mv {
  display: block;
}
.p-home--mv a,
.p-home--mv span {
  display: block;
}
.p-home--mv .slick-slide img {
  display: inline;
}
.p-home--mv .slick-dotted.slick-slider {
  margin-bottom: 0;
}
.p-home--mv .slick-dots {
  bottom: 5px;
}
.p-home--mv .slick-dots li {
  margin: 0 2px;
}
.p-home--mv .slick-dots li button:before {
  opacity: 1;
  color: #b6b8bc;
  font-size: 12px;
}
.p-home--mv .slick-dots li.slick-active button:before {
  opacity: 1;
  color: #0a3874;
}

.p-news-wrap {
  background-color: #0a3874;
  width: 100%;
}
.p-news-title {
  color: #fff;
  padding: 15px;
  text-align: center;
  display: none;
}
.p-news {
  align-items: flex-start;
  background: linear-gradient(90deg,#28b5bc,#24a5c2);
  color: #fff;
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 15px;
  text-decoration: none;
}
.p-news a {
  color: #fff;
  text-decoration: none;
}
.p-news__date {
  font-size: 12px;
}
.p-news__title {
  font-size: 14px;
  margin-top: 5px;
}
.p-news__more {
  background-image: url(img/icon-arrow--1.png);
  background-repeat: no-repeat;
  background-position: right center;
  font-size: 12px;
  margin: 5px 0 0 auto;
  padding-right: 14px;
}

.p-service-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-service-list__item {
  margin-top: 15px;
  width: 100%;
}
.home .p-service-list--1 .p-service-list__item:nth-last-of-type(-n+19) {
  display: none;
}
.home .p-service-list--2 .p-service-list__item:nth-last-of-type(-n+2) {
  display: none;
}
.p-service-list__item__link {
  margin-top: 30px;
  width: 100%;
}
@media screen and (max-width: 589px) {
  .p-service-list__item__link {
    margin-bottom: 15px;
  }
}
.p-service-list__item__link .p-home--service-btn {
  margin: 0 auto;
  max-width: 370px;
}

.p-service-list__3item {
  width: 48.333%;
}
.p-service-list__3item .c-btn--2 {
  height: 100%;
}
.p-service-list__3item .c-btn--2--row__title {
  font-size: .9rem;
  line-height: 1.5;
}

.c-btn--2--col .p-service-btn__txt .c-btn--2--col__title {
  text-align: center;
}


.p-home--beyond__item:last-child {
  margin-top: 20px;
}
.p-home--beyond__item__img {
  display: block;
  width: 100%;
}
.p-home--beyond__item__subtitle {
  margin-top: 15px;
}
.p-home--beyond__item__text {
  margin-top: 10px;
  line-height: 1.8;
}
.p-home--beyond__item__btn {
  margin-top: 20px;
}


.p-home-reason-list__item {
  background-color: #fff;
  margin-top: 15px;
  padding: 25px 15px;
}
.p-home-reason-list__item__maintitle {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}
.p-home-reason-list__item__start,
.p-home-reason-list__item__end {
  align-items: flex-end;
  color: #313543;
  display: flex;
  font-size: 14px;
  font-weight: 700;
  margin-top: 5px;
}
.p-home-reason-list__item__end {
  margin-top: 15px;
}

.p-home-reason-list__item__start::after {
  background-color: #313543;
  content: '';
  display: block;
  height: 1px;
  margin: 0 0 5px 5px;
  width: 100%;
}

.p-home-reason-list__item__end::before {
  background-color: #313543;
  content: '';
  display: block;
  height: 1px;
  margin: 0 5px 5px 0;
  width: 100%;
}

.p-home-reason-list__item__subtitle {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 15px;
}
.p-home-reason-list__item__text {
  font-size: 14px;
  line-height: 1.8;
  margin-top: 10px;
}

.p-home--works {
  margin-top: 20px;
}
.p-home--works-btn {
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  max-width: 370px;
}
.p-home--works .c-post-list__item__link__img {
  background-size: contain;
}
.p-home--works .c-post-list__item {
  background: transparent;

}
.c-bg--1 .p-home--works .c-post-list__item {
  /* padding: 10px; */
}

.p-home--news {
  margin-top: 20px;
}
.p-home--news-btn {
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  max-width: 370px;
}
.p-home--news-txtlink {
  margin: 40px auto 0;
  text-align: center;
}
.p-home--news-txtlink a {
  margin: 5px 10px;
  display: inline-block;
  color: #fff;
  text-decoration: none;
  background-color: #24a4c1;
  padding: .5em 2em;
  line-height: 1.4;
  min-width: 15em;
  font-size: 14px;
}
.p-home--news-txtlink a:hover {
  background-color: #4bc6e2;
}

@media screen and (max-width: 769px) {
  .p-home--news-txtlink {
    margin-top: 20px;
  }
  .p-home--news-txtlink a {
    margin: 5px 0;
    text-align: left;
    display: block;
    font-size: 13px;
    padding: .6em 1em;
    background-size: 6px;
  }
  .p-home--news-txtlink a br {
    display: none;
  }
}

.p-home-partner-list {
  margin-top: 20px;
}
.p-home-partner-btn {
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  max-width: 370px;
}
.p-home-partner-list {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
}
.p-home-partner-list__item {
  width: 49%;
}
.c-bg--2 .p-home-partner-list__item {
  border: solid 1px #d7e0e4;
}
.p-home-partner-list__item:nth-child(odd) {
  margin-right: 2%;
}
.p-home-partner-list__item:nth-child(n + 3){
  margin-top: 10px;
}
.p-home-partner-list__item__link {
  display: block;
  padding: 10px 20px;
  background: #fff;
  position: relative;
}
.p-home-partner-list__item__link:hover {
  /*opacity: .8;*/
}
.p-home-partner-list__item__link__img {
  background-size: contain;
}

.p-home-partner-list__item__link__title {
  display: table;
  width: 100%;
  height: 100%;
  background: rgba(32, 156, 255, 0.7);
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px;
  opacity: 0;
}
.p-home-partner-list__item__link__title span {
  display: table-cell;
  text-align: center;
  vertical-align: bottom;
  line-height: 1.3;
}
.p-home-partner-list__item__link:hover .p-home-partner-list__item__link__title {
  opacity: 1;
  transition: all .5s;
}

@media screen and (max-width: 769px) {
  .p-home-partner-list__item__link__title {
    display: none;
  }
}

.p-home--blog {
  display: flex;
  flex-direction: column-reverse;
}
.p-home--blog__item {}
.p-home--blog__item:first-child {
  margin-top: 20px;
}
.p-home--blog__item__img-wrap {}
.p-home--blog__item__img {
  display: block;
  width: 100%;
}
.p-home--blog-list {
  margin-top: 15px;
}
.p-home--blog-list__item {
  font-size: 14px;
}
.p-home--blog-list__item:not(:first-child) {
  border-top: 1px solid #dcdcdc;
  margin-top: 10px;
  padding-top: 10px;
}
.p-home--blog-list__item__link {
  color: #313543;
  display: block;
  line-height: 2;
  text-decoration: none;
}
.p-home--blog-btn {
  margin-top: 20px;
}
.p-banner-list-wrap {
  border-top: 1px solid #dcdcdc;
  margin-top: 20px;
  padding-top: 20px;
}
.p-banner-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.p-banner-list__item {
  width: 48.3333%;
}
.p-banner-list__item:nth-child(n + 3) {
  margin-top: 5px;
}

.p-banner-list__item__link {
  display: block;
}
a.p-banner-list__item__link:hover img{
  opacity: .8;
}

.p-banner-list__item__link__img {
  display: block;
  width: 100%;
}

.p-footer-navi-wrap {
  display: flex;
  flex-direction: column;
}
.p-footer-navi {}

.p-footer-logo-wrap {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-top: 30px;
}
.p-footer-logo {}
.p-footer-logo__img {
  display: block;
  width: 84px;
}
.p-footer-sns {
  display: flex;
  margin-left: 10px;
}
.p-footer-sns__item {
  display: block;
  margin-left: 5px;
}
.p-footer-sns__item__img {
  display: block;
  width: 18px;
}

.p-footer-menu {}
.p-footer-menu::after {
  content: '';
  clear: both;
  display: block;
}
.p-footer-menu-list {}
.p-footer-menu-list__item {
  float: left;
  width: 50%;
}
.p-footer-menu-list__item__link {
  color: #fff;
  display: block;
  font-size: 12px;
  padding: 10px 0;
  text-decoration: none;
}
.p-footer-submenu-list {
  display: none;
}
.p-footer-submenu-list__item {}
.p-footer-submenu-list__item__link {
  color: #fff;
  display: block;
  font-size: 12px;
  padding: 10px 5px;
  text-decoration: none;
}
.p-footer-submenu-list__item__link::before {
  content: '-';
}

.p-footer-address {
  border-top: 1px solid #fff;
  margin-top: 10px;
  padding-top: 10px;
}
.p-footer-address__item {
  color: #fff;
  font-size: 12px;
  line-height: 1.6;
  margin-top: 10px;
}
.p-footer-address__item__title {
  font-weight: 700;
}

.p-copyright {
  color: #fff;
  font-size: 12px;
  text-align: center;
}

.p-pagetop {
  position: fixed;
  bottom: 10px;
  right: 10px;
  display: none;
}
.p-pagetop__img {
  display: block;
  width: 30px;
}


.p-company-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 15px;
  padding-right: 5px;
}
.p-company-list__item {
  width: 100%;
  height: 45vw;
  margin: 10px auto;
}
/* .p-company-list__item:nth-child(n + 3) {
  margin-top: 25px
} */
.p-company-list__item__link {
  color: #fff;
  display: block;
  position: relative;
  height: 100%;
}
.p-company-list__item__link__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-company-list__item:first-of-type .p-company-list__item__link__img {
  width: 100%;
}
.p-company-list__item__link__text {
  align-items: center;
  background-color: rgba(19,129,191,.6);
  display: flex;
  justify-content: center;
  position: absolute;
  top: 10px;
  bottom: -10px;
  left: 10px;
  right: -10px;
}
.p-company-list__item:first-of-type .p-company-list__item__link__text {
  width: 100%;
}

.p-company-info-table,
.p-company-group {
  margin-top: 15px;
}

.p-access__item__address {
  font-size: 14px;
  line-height: 1.8;
}
.p-access__item__route {
  font-size: 14px;
  line-height: 1.8;
  margin-top: 10px;
}
.p-access__item__map {
  margin-top: 10px;
}

.p-company-headbox--in {
  margin: 40px 0 0;
  color: #313543;
  line-height: 2.5;
  font-size: 14px;
}
.p-company-group {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.p-company-group > * {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  padding: 15px;
  margin: 0 0 22px;
  background: #fff;
  align-items: center;
}
.p-company-group a {
  color: #000;
  text-decoration: none;
}

.p-company-group__txt h3 {
  margin: 0 0 1rem;
  font-size: 20px;
}
.p-company-group__img {
  width: 100%;
  text-align: center;
}
.p-company-group__txt {
  width: 100%;
  line-height: 1.8;
  text-align: center;
  font-size: 14px;
  margin: 15px 0 0;
}
.p-company-group.col3 .p-company-group__img {
  padding: 10px 0 15px;
  border-bottom: 1px solid #ccc;
}
.p-company-group.col3 .p-company-group__img img {
  max-height: 80px;
}

.p-philosophy-headbox {
  background: url(img/philosophy-bg--1.jpg?2105) no-repeat center center;
  background-size: cover;
}
.p-philosophy-headbox--inner {
  padding: 30px 15px;
}
.p-philosophy-headbox--in {
  margin: 40px 0 0;
  color: #313543;
  line-height: 2.5;
  font-size: 14px;
}
.p-philosophy-btn__inner {
  line-height: 1.2;
}
.p-philosophy-mission {
  background: url(img/philosophy-bg--mission.jpg) no-repeat center center;
  background-size: cover;
}

.p-philosophy-block {
  margin: 45px 0 0;
}
.p-philosophy-block-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin: 40px 0 0;
}
.p-philosophy-block-inner > * {
  width: 100%;
}
.p-philosophy-block__txt {
  line-height: 1.5;
  margin: 0 0 20px;
  order: 1;
}
.p-philosophy-block__txt h3 {
  margin: 0 0 10px;
  font-weight: bold;
  font-size: 18px;
}
.p-philosophy-block__img {
  display: flex;
  justify-content: center;
  order: 2;
}
.p-philosophy-block__img p:not(:first-of-type) {
  margin: 0 0 0 10px;
}
.p-philosophy-box {
  box-shadow: 0px 2px 5.39px 1.61px rgba(73, 73, 80, 0.02);
  background: #fff;
  padding: 5px;
  margin: 40px auto 0;
  max-width: 620px;
}
.p-philosophy-box__in {
  border: solid 2px #0a3874;
  padding: 2px;
}
.p-philosophy-box__grandin {
  border: solid 1px #0a3874;
  padding: 0 1.5rem;
}
.p-philosophy-box__top {
  border-bottom: solid 1px #e5e5e5;
  padding: 2.5rem 1rem 1.5rem;
}
.p-philosophy-box__bottom {
  padding: 1.5rem 1rem .5rem;
}

.p-messeage-block {
  margin: 15px 0 0;
}
.p-messeage-block__txt {
  margin: 0 0 40px;
  line-height: 1.8;
}
.p-messeage-block__txt h2 {
  margin: 0 0 20px;
  font-size: 20px;
  font-weight: bold;
}
.p-messeage-block__txt h3 {
  margin: 30px 0 0;
  font-size: 18px;
  font-weight: bold;
}
.p-messeage-block__img {
  text-align: center;
}
.p-messeage-block__img__in img {
  max-width: 70%;
}

.p-mind-block--1 {
  background: #f2f7f9;
}
.p-mind-block--2 {
  background: #fff;
}
.p-mind-block--3 {
  background: #f2f7f9;
}
.p-mind-block--1 .p-mind-box {
  margin: 30px 0 0;
}
.p-mind-box h2 {
  margin: 0 0 20px;
  font-size: 20px;
  font-weight: bold;
}
.p-mind-box h3 {
  margin: 0 0 15px;
  font-size: 18px;
  font-weight: bold;
}
.p-mind-box p {
  margin: 0 0 20px;
  line-height: 1.8;
}

.p-history-headbox--in {
  margin: 40px 0 0;
  color: #313543;
  line-height: 2.5;
  font-size: 14px;
}

.p-construction-txt p:not(:last-of-type) {
  margin: 0 0 1.5rem;
}
.p-construction-bal {
  background: url(img/sp_construction-bg--2.jpg) no-repeat center bottom;
  background-size: cover;
  padding: 30px 0 /* calc(50px + 2%) */;
  color: #fff;
}
.p-construction-bal__head {
  margin: 0 0 1.5rem;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
  line-height: 1.3;
  letter-spacing: .1rem;
}
.p-construction-bal__head span {
  font-size: 24px;
  font-weight: bold;
}
.p-construction-bal__box {
  background: rgba(255,255,255,.3);
  padding: 15px;
}
.p-construction-bal__box li {
  background: url(img/construction-ico--1.png) no-repeat left center;
  background-size: 14px;
  padding: 0 0 0 20px;
}
.p-construction-bal__box li:not(:last-of-type) {
  margin: 0 0 1rem;
}

.p-construction-plus {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-construction-plus__box1 {
  width: 100%;
  background: #fff;
}
.p-construction-plus__box1__head {
  background: #313543;
  width: 100%;
  text-align: center;
  padding: .5rem 1rem;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
}
.p-construction-plus__box1__in {
  padding: 1rem .5rem;
  line-height: 1.5;
}
.p-construction-plus__box1__in p:not(:last-of-type) {
  margin: 0 0 1em;
}
.p-construction-plus__icon__wrap {
  width: 100%;
  text-align: center;
}
.p-construction-plus__icon {
  display: inline-block;
  position: relative;
  margin: 10px auto;
  padding: 0;
  width: 4px;
  height: 20px;
  background: #313543;
}
.p-construction-plus__icon::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: -8px;
  width: 20px;
  height: 4px;
  margin-top: -2px;
  background: #313543;
}
.p-construction-plus__box2 {
  width: 100%;
  background: #fff;
}
.p-construction-plus__box2__head {
  background: #23a5c2;
  width: 100%;
  text-align: center;
  padding: .5rem 1rem;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
}
.p-construction-plus__box2__subhead {
  margin: 0 0 .5rem;
  font-weight: bold;
}
.p-support-bal__box {
  display: flex;
  flex-wrap: wrap;
  line-height: 1.5;
}
.p-support-bal__box li {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: rgba(255,255,255,.3);
  width: 49%;
  padding: 10px;
  margin: 0 2% 2% 0;
}
.p-support-bal__box li:nth-of-type(even) {
  margin: 0 0 2%;
}
.p-support-strength {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.p-support-strength__child {
  background: #f2f7f9;
  padding: 2rem 1.5rem;
  margin: 0 0 15px;
  line-height: 1.8;
  width: 100%;
}
.p-support-strength__img {
  margin: 0 0 20px;
  text-align: center;
}
.p-support-strength__info {
  width: 100%;
  background-color: rgba(255,255,255,.2);
  margin-top: 15px;
  padding: 10px;
  font-size: 90%;
}
.p-loadtest-list {
  display: flex;
  flex-wrap: wrap;
}
.p-loadtest-list li {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  background: #EFF8FB;
  padding: 1rem .5rem;
  text-align: center;
  font-weight: bold;
  line-height: 1.5;
}
.p-loadtest-list.fukamill li {
  background: #FFFFDD;
  border-image: linear-gradient(
    45deg
    , #FFCC00 0%,#B8860B 100%) 1/3px;
  border-style: solid;
}
.p-loadtest-list.vulnerability-list li {
  background: #fcfff9;
  border-image: linear-gradient(
    45deg
    , #00CED1 0%,#009900 100%) 1/3px;
  border-style: solid;
}
.p-loadtest-list li.p-loadtest-list__arrow {
  background: transparent;
  padding: 0;
  margin: .5rem auto;
  width: 8px;
  height: 10px;
}
.p-loadtest-list.fukamill li.p-loadtest-list__arrow,
.p-loadtest-list.vulnerability-list li.p-loadtest-list__arrow {
  background: transparent;
  padding: 0;
  margin: .5rem auto;
  width: 8px;
  height: 10px;
  border: none;
}
.p-loadtest-list li.p-loadtest-list__arrow::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: #313543 transparent transparent transparent;
}
.p-loadtest-list li p {
  width: 100%;
}
.p-loadtest-list li span {
  font-weight: normal;
  font-size: 14px;
}
.p-loadtest-list__info {
  margin: .5rem 0 0;
  padding: .5rem 0 0;
  border-top: solid 1px #3b4653;
  font-weight: normal;
  font-size: 14px;
  text-align: left;
}
.p-loadtest-list__info p {
  padding: 0 0 0 2em;
  text-indent: -2em;
}
.p-loadtest-list.fukamill li .p-loadtest-list__tit,
.p-loadtest-list.vulnerability-list li .p-loadtest-list__tit {
  width: 100%;
  font-size: 18px;
}
.p-loadtest-list.fukamill li .p-loadtest-list__body,
.p-loadtest-list.vulnerability-list li .p-loadtest-list__body {
  border-top: 2px solid #808080;
  padding-top: 10px;
  margin-top: 10px;
  width: 100%;
  font-weight: normal;
  font-size: 15px;
  text-align: left;
}
.p-loadtest-list.vulnerability-list li {
  color: #000;
}
.p-loadtest-list.vulnerability-list li .p-loadtest-list__body {
  border-color: #BBB;
}

/*青バージョン*/
.p-loadtest-list.blue-list li {
  background: #f2f7f9;
  border-image: linear-gradient( 45deg , #24a5c2 0%,#105b92 100%) 1/3px;
  border-style: solid;
}



.p-cdn-bg {
  background: url(img/cdn-bg--1.jpg) no-repeat center center;
  background-size: cover;
}
.p-cdn-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.p-cdn-list li {
  width: 100%;
  background: #fff;
  padding: 1rem;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  color: #106196;
}
.p-cdn-list li:not(:last-of-type) {
  margin: 0 0 1rem;
}
.p-cdn-list li span {
  display: block;
  width: 100%;
  margin: .5em 0 0;
  font-size: .85em;
}
.p-cdn-list .p-cdn-list--txt {
  font-weight: normal;
  font-size: 90%;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #24a5c2;
  text-align: left;
}
.p-cdn-banner {
  max-width: 1000px;
  margin: 0 auto;
}


.p-security-bg {
  background: url(img/security-bg--1.jpg) no-repeat right center;
  background-size: cover;
}
.p-security-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.p-security-list__child {
  width: 100%;
  margin: 0 0 30px;
  padding: 0 0 30px;
}
.p-security-list__child:not(:last-of-type) {
  border-bottom: solid 1px #dcdcdc;
}
.p-security-list__img {
  background: #fff;
  margin: 0 0 15px;
  box-shadow: 0px 5px 15px 0px rgba(14, 46, 95, 0.05);
}
.p-security-list__img a {
  display: block;
  width: 100%;
  padding: 1em;
  text-align: center;
}
.p-security-list__img a img {
  max-width: 80%;
}
.p-security-list__txt a {
  display: block;
  width: 100%;
  text-align: center;
  line-height: 1.3;
  font-size: 18px;
  font-weight: bold;
  color: #313543;
  text-decoration: none;
}
.p-security-list__txt a span {
  display: block;
  text-align: center;
  font-size: 13px;
}
.p-consulting-list-wrap {
  padding: 15px;
  margin: 0 0 1em;
}
.p-consulting-list {
  margin: 0 0 1em;
}
.p-consulting-list li {
  position: relative;
  padding: 0 0 0 1.5em;
  font-weight: bold;
}
.p-consulting-list li:not(:last-of-type) {
  margin: 0 0 1em;
}
.p-consulting-list li::before {
  display: block;
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 12px;
  height: 5px;
  margin: auto;
  border-left: 3px solid #313543;
  border-bottom: 3px solid #313543;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.p-ssl-bg {
  background: url(img/ssl-bg--1.jpg) no-repeat center center;
  background-size: cover;
}
.p-api-info__head {
  background: #1a4478;
  text-align: center;
  padding: 1em;
  font-size: 20px;
  font-weight: bold;
  color: #fff;
}
.p-api-info__txt {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background: #EFF8FB;
  padding: 1.5rem;
}
.p-api-info__txt li {
  width: 100%;
  text-indent: -1em;
  padding: 0 0 0 1em;
  font-weight: bold;
  text-align: left;
}
.p-api-info__txt li:not(:last-of-type) {
  margin: 0 0 1em;
}
.p-api-block__img {
  margin: 0 0 40px;
}
.p-api-block__txt {
  margin: 0;
}


.c-cat-tab__list {
  display: none;
}
.c-cat-tab__child:not(#openTab1) {
  display: none;
}
.c-cat-select__list {
  width: 100%;
  background: #09c url(img/icon-arrow--5.png) right 1.2rem center/8px no-repeat;
  border: none;
  padding: .7rem 1.2rem .7rem .5rem;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  margin: 0 0 1.5rem;
}
.p-faq-tabs {
  display: none;
}
.p-faq-selects {
  width: 100%;
  background: #09c url(img/icon-arrow--5.png) right 1.2rem center/8px no-repeat;
  border: none;
  padding: .7rem 1.2rem .7rem .5rem;
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  margin: 0 0 1.5rem;
}
.p-faq-desc {
  margin: 0 0 30px;
  padding: 0 0 25px;
  border-bottom: 1px solid #23a5c2;
}
.p-faq__post-field {
  padding: 0 1rem;
  background: #fff;
  box-shadow: 0px 2px 5.39px 1.61px rgba(73, 73, 80, 0.1);
}
.p-faq__post-field:not(:last-of-type) {
  border-bottom: none;
}
.p-faq__post-field:not(:first-of-type) {
  margin: 1rem 0 0;
}
.p-faq__post-field__item {
  padding: 2rem 2rem 2rem 3.5rem;
  background-position: 0 center;
  background-repeat: no-repeat;
  background-size: 44px;
  min-height: 44px;
}
.p-faq__q {
  position: relative;
  background-image: url(img/faq_q@2x.png);
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 16px;
  font-weight: normal;
  cursor: pointer;
}
h1.p-faq__q {
  font-weight: bold;
  font-weight: bold;
  font-size: 22px;
  line-height: 1.4;
}
.p-faq__q::after {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  right: 3px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #23A5C2;
  border-right: 2px solid #23A5C2;
  transform: rotate(135deg);
  transition: .5s all;
}
.p-faq__q.is-active::after {
  transform: rotate(-45deg);
}
.p-faq__a {
  display: none;
  background-image: url(img/faq_a@2x.png);
  background-position: 0 1.5rem;
  border-top: 1px solid #ccc;
}

.p-faq__post-field,
.p-faq__post-field .c-single-content p {
  line-height: 1.8;
}
.p-faq__post-field .c-single-content p:last-of-type {
  margin-bottom: 0;
}
.p-faq__post-field .wp_social_bookmarking_light,
.p-faq__post-field .wp_social_bookmarking_light_clear {
  display: none;
}



.p-contact__form,
.p-contact__form__btn {
  margin-top: 2em;
}
.p-contact__form {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #23a5c2;
  border-bottom: 1px solid #23a5c2;
  flex-direction: column;
  margin-bottom: 1em;
}
.p-contact__form > * {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  padding: .5em 1em;
}
.p-contact__form dt,
.p-contact__form dd {
  width: 100%;
  margin: 0;
}
.p-contact__form dt {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  border-right: none;
  padding: 1em 1em .5em 1em;
}
.p-contact__form dd {
  padding: .5em 1em 1em 1em;
}
.p-contact__form dd:not(:last-of-type) {
  border-bottom: 1px solid #23a5c2;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  width: 100%;
  border: 1px solid #ccc;
  padding: .5rem;
}
.wpcf7-radio span.wpcf7-list-item {
  margin: 0 1em 0 0;
}
input[type="submit"],
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
.wpcf7 input[type="submit"][disabled] {
  background-color: #999;
  color: #fff;
  border-color: #999;
}
div.wpcf7 .wpcf7-submit:disabled {
  cursor: not-allowed;
}
.wpcf7 span.wpcf7-not-valid-tip {
  display: inline-block;
  position: relative;
  background: #B20000;
  margin: 1em 0.5em 0 0;
  padding: 0.3em 1em;
  border-radius: 5px;
  color: #fff;
  font-size: 16px;
}
.wpcf7 span.wpcf7-not-valid-tip:after {
  position: absolute;
  bottom: 100%;
  left: 1.5em;
  content: " ";
  width: 0;
  height: 0;
  margin-left: -6px;
  border: solid transparent;
  border-width: 6px;
  border-color: rgba(0, 0, 0, 0);
  border-bottom-color: #B20000;
}
.p-contact-form__accept > .wpcf7-list-item {
  display: block;
}
.wpcf7 .wpcf7-validation-errors,
.wpcf7 .wpcf7-mail-sent-ng {
  border: 2px solid #B20000;
  color: #B20000;
  font-weight: bold;
  text-align: center;
}
.wpcf7-mail-sent-ok {
  display: none !important;
}

.p-contact-wrap .c-btn--3,
.p-works-archive-wrap .c-btn--3 {
  position: relative;
  max-width: 370px;
  margin: 30px auto;
}
.p-contact-wrap div.wpcf7 .ajax-loader {
  position: absolute;
  bottom: -15px;
  left: 0;
  right: 0;
  display: block;
  margin: 10px auto 0;
}

span.wpcf7-spinner {
  display: none;
}

.p-contact-wrap input[type="submit"] {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  color: #fff;
  width: 100%;
}


/*archive*/
.p-archive-block {
  margin: 0 0 30px;
}
.p-archive-cat-head {
  margin: 20px 0 0;
}
.p-archive-block__link {
  display: block;
  padding: 15px;
  background: #fff;
  color: #333;
  text-decoration: none;
  box-shadow: 0px 5px 15px 0px rgba(14, 46, 95, 0.05);
}
.p-archive-block__link:hover {
  background-color: #d7e7ff;
}
.p-archive-block__thumb {
  overflow: hidden;
  margin: 0 0 30px;
}
.p-archive-block__thumb__img {
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  transition: all .5s;
  width: 80%;
  height: 150px;
  margin: 0 auto;
}
.p-archive-block__link:hover .p-archive-block__thumb__img {
  transform: scale(1.1,1.1);
}
.p-archive-block__txt__excerpt {
  margin: 0 0 10px;
  font-size: 14px;
}
.p-archive-block__txt__add {
  display: flex;
  flex-wrap: wrap;
}
.p-archive-block__txt__add > * {
  width: 100%;
}
.p-archive-block__txt__cat {
  margin: 0 0 .5em;
}
.p-archive-block__txt__date {
  margin-top: auto;
  text-align: right;
  font-size: 12px;
}
.p-archive-block__txt__data {
  display: flex;
  align-items: center;
}
.p-archive-block__txt__data__rating .c-rating {
  line-height: 16px;
  font-size: 12px;
}
.p-archive-block__txt__data__view {
  font-weight: bold;
  background: url(img/post-view.svg?v2) no-repeat center left;
  background-size: 16px;
  padding: 0 0 0 20px;
  margin: 0 0 0 10px;
  font-size: 12px;
  line-height: 16px;
  color: #339966;
}

.p-archive-block--full--works__wrap {
  background: #fff;
  padding: 10px;
}
.p-archive-block--full--works__wrap .js-works-posts-list:not(:first-of-type) {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: all 0.6s;
}
.p-archive-block--full--works {
  display: flex;
  flex-wrap: wrap;
}
.p-archive-block-work.p-archive-block__link{
  background: #F2F7F9;
  box-shadow: none;
}
.p-archive-block-work .p-archive-block__thumb__img {
  background-color: #fff;
}
.p-archive-block-work .p-archive-block__txt__date {
  margin: 0 0 10px;
  font-size: 11px;
  color: #aaa;
  text-align: left;
}
.p-works-archive-wrap .c-btn--3 {
  cursor: pointer;
}
.p-works-list-loading {
  text-align: center;
}
.p-archive-block__txt__author {
  display: flex;
  align-items: center;
  margin: 10px 0 0;
}
.p-archive-block__txt__author__img img {
  display: block;
}
.p-archive-block__txt__author__info {
  font-size: 11px;
  text-align: right;
  margin: 0 0 0 5px;
  line-height: 1.2;
}
.p-archive-block__txt__author__date {
  font-size: 11px;
  flex: 1;
  text-align: right;
  margin: 0 0 0 5px;
}


.p-event-block {
  border: 1px solid #23a5c2;
  padding: 15px;
  margin: 0 0 2rem;
}
.p-event-block__info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.p-event-block__info > p {
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0 0 .5em;
}
.p-event-block__info__icon {
  display: inline-block;
  margin: 0 .5em 0 0;
  border: 1px solid #23a5c2;
  border-radius: 3px;
  padding: 0 1em;
  min-width: 6.5em;
  color: #23a5c2;
  font-weight: bold;
  font-size: 14px;
  text-align: center;
}
.p-event-block__place {
  background: url(img/ico_place.png) no-repeat left center;
  padding: 0 0 0 18px;
  margin: 0 0 1em;
}
.p-event-block__place > p {
  margin: 0;
}
.p-event-block__btn {
  margin-top: 20px;
}
.p-event-block__map {
  position: relative;
  padding-bottom: 70%;
  height: 0;
  overflow: hidden;
  margin: 0;
}
.p-event-block__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


/*pager*/
.p-pagination {
  display: flex;
  justify-content: center;
  font-size: 14px;
}
.p-pagination__item:not(:first-child) {
  margin-left: 15px;
}
.p-pagination__item a {
  display: inline-block;
  color: #23A5C2;
  text-decoration: none;
}
.p-pager {
  margin-top: 50px;
  line-height: 1.4;
  color: #23A5C2;
  font-weight: bold;
}
.p-pagination > *,
.p-entry-nav__item > a {
  border: 1px solid #23A5C2;
  background: #fff;
}
.p-pagination__item a:hover,
.p-pagination__item--active {
  background-color: #23A5C2;
  color: #fff;
}
.p-pager__item a,
.p-pagination__item--active,
.p-pagination__item--spot {
  padding: 10px 15px;
}


.p-related-service .c-btn--2--row__title {
  font-size: 16px;
}
.p-related-service .c-btn--2--row__icon__img {
  max-width: 70px;
}


/*yarpp*/
.yarpp-related {
  margin: 0!important;
}
.p-related-wrap {
  margin: 4em 0 0;
}
.p-related-child {
  margin: 30px 0 0;
}
.p-related-child .p-archive-block__link {
  background: #fff;
  box-shadow: 0px 5px 15px 0px rgba(14, 46, 95, 0.05);
  flex-wrap: wrap;
  margin: 0 0 30px;
}


.js-pagetop__show {
  display: block;
}
/* Utility
----------------------------------------------------------------- */
.u-sp-none { display: none; }
.u-sp769-none { display: none; }
.u-sp769-block { display: block; }
.u-pc1025-block { display: none; }
.u-pt--0 {
  padding-top: 0!important;
}
.u-pb--0 {
  padding-bottom: 0!important;
}
.u-mt--0 {
  margin-top: 0!important;
}
.u-mt--10 {
  margin-top: 10px!important;
}
.u-mt--20 {
  margin-top: 20px!important;
}
.u-mt--30 {
  margin-top: 30px!important;
}
.u-mb--0 {
  margin-bottom: 0!important;
}
.u-mb--10 {
  margin-bottom: 10px!important;
}
.u-mb--15 {
  margin-bottom: 15px!important;
}
.u-mb--20 {
  margin-bottom: 20px!important;
}
.u-mb--25 {
  margin-bottom: 25px!important;
}
.u-mb--30 {
  margin-bottom: 30px!important;
}
.u-ta--c {
  text-align: center;
}
.u-ta--r {
  text-align: right;
}
.u-lh--13 {
  line-height: 1.3;
}
.u-lh--15 {
  line-height: 1.5;
}
.u-lh--18 {
  line-height: 1.8;
}
.u-fw--bold {
  font-weight: bold;
}
.u-fs--12em {
  font-size: 1.2em;
}
.u-fs--9em {
  font-size: .9em;
}
.u-indent {
  text-indent: -1em;
  padding: 0 0 0 1em;
}
.u-indent--2 {
  text-indent: -1.7em;
  padding: 0 0 0 1.7em;
}
.u-indent--2__2 {
  text-indent: -2.2em;
  padding: 0 0 0 1.7em;
}
.u-jc--center {
  justify-content: center;
}


@media screen and (min-width: 481px) {
  /* ==========================================================================
  Layout
  ========================================================================== */

  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */

  /* Project
  ----------------------------------------------------------------- */

  .p-banner-list {
    justify-content: flex-start;
    width: 80%;
    margin-left: auto;
    margin-right:auto;
  }
  .p-banner-list__item {
    width: 24%;
    margin-right: calc(4% / 3);
  }
  .p-banner-list__item:nth-of-type(4n) {
    margin-right: 0;
  }
  .p-banner-list__item:nth-child(n + 3) {
    margin-top: 0;
  }
  .p-banner-list__item:nth-child(n + 5) {
    margin-top: 10px;
  }
  .p-site-menu__tel__text {
    font-size: 16px;
  }

  /* Utility
  ----------------------------------------------------------------- */
}

@media screen and (min-width: 590px) {
  /* ==========================================================================
  Layout
  ========================================================================== */

  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */
  .c-content-width--3 {
    max-width: none;
  }
  .c-content-width--4 {
    max-width: none;
  }
  .c-content-break-line {
    padding-top: 100px;
  }

  .c-content-child {
    margin-top: 20px;
  }

  /* Project
  ----------------------------------------------------------------- */
  .p-service-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    /*    max-width: 100%;*/
  }
  .p-service-list--1 {}
  .p-service-list__item {
    display: flex;
    margin-top: 30px;
    width: 48.3333%;
  }
  .p-service-list__3item {
    width: 32%;
  }
  .p-service-list__3item .c-btn--2--row__title {
    font-size: 1rem;
    line-height: 1.5;
  }
  .p-service-list__full,
  .p-service-list__1col {
    width: 100%;
  }

  .p-home--beyond {
    align-items: center;
    display: flex;
    justify-content: space-between;
    max-width: 100%;
  }
  .p-home--beyond__item {
    width: 40.8094572%;
  }
  .p-home--beyond__item:last-child {
    margin-top: 0;
    width: 52.8571428%;
  }
  .p-home--beyond__item__img {
    max-width: 534px;
  }
  .p-home--beyond__item__maintitle {
    justify-content: flex-start;
  }

  .p-home--blog {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
    max-width: 100%;
  }
  .p-home--blog__item {
    width: 43.8094572%;
  }
  .p-home--blog__item:first-child {
    margin-top: 0;
    width: 52.8571428%;
  }
  .p-home--blog__item__img {
    /* max-width: 534px; */
  }
  .p-home--blog__item__maintitle {
    justify-content: flex-start;
  }

  .p-home-reason-list {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    max-width: 100%;
  }

  .p-home-reason-list__item{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin-top: 0;
    width: 31.7142857%;
  }

  .p-home-reason-list__item__end {
    margin-top: auto;
  }

  .p-footer-menu {
    display: flex;
    justify-content: space-between;
  }
  .p-footer-menu::after {
    display: none;
  }
  .p-footer-menu-list__item {
    float: none;
    width: auto;
  }
  .p-footer-submenu-list {
    display: block;
  }

  .p-footer-address {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .p-footer-address__item {
    margin-top: 0;
    width: 50%;
    padding-left: 10px;
  }
  .p-footer-address__item:nth-child(odd) {
    padding-left: 0;
    padding-right: 10px;
    text-align: right;
  }

  /*animation*/
  .p-service-list [data-aos].aos_delay_400,
  .p-home-reason-list [data-aos]:nth-of-type(2) {
    transition-delay: .4s;
  }
  .p-service-list [data-aos].aos_delay_800,
  .p-home-reason-list [data-aos]:nth-of-type(3) {
    transition-delay: .8s;
  }


  .p-company-list {
    margin-top: 20px;
    padding-right: 0;
  }
  .p-company-list__item {
    /* width: 45%; */
    width: 48%;
    height: 292px;
    /* max-width: 520px; */
    /* margin-bottom: 60px; */
    margin-bottom: 10px;
  }
  .p-company-list__item:first-of-type {
    width: 100%;
    margin-left: 10px;
  }
  /* .p-company-list__item:nth-child(n + 3) {
    margin: 0;
  } */
  .p-company-list__item__link {
    max-width: 100%;
    padding-bottom: 20px;
    height: 100%;
  }
  .p-company-list__item__link__img {
    width: 93%;
    height: 100%;
    object-fit: cover;
  }
  .p-company-list__item:first-of-type .p-company-list__item__link__img {
    width: 95.5%;
  }
  .p-company-list__item__link__text {
    font-weight: 700;
    top: 20px;
    bottom: 0;
    left: 20px;
    right: 0;
    width: 93%;
  }
  .p-company-list__item:first-of-type .p-company-list__item__link__text {
    width: 95.5%;
  }

  .p-company-info-table {
    margin-top: 20px;
  }
  .p-company-group {
    margin-top: 30px;
  }

  .p-messeage-block__img__in img {
    max-width: 50%;
  }

  .c-single-content img.alignleft {
    float: left;
    margin-top: 0;
    margin-right: 1em;
    max-width: 40%;
  }
  .c-single-content img.alignright {
    float: right;
    margin-top: 0;
    margin-left: 1em;
    max-width: 40%;
  }


  /*archive*/
  .p-archive-block--full--works__wrap {
    padding: 20px;
  }
  .p-archive-block__link {
    display: flex;
    justify-content: space-between;
  }
  .p-archive-block-work.p-archive-block__link {
    flex-wrap: wrap;
  }
  .p-archive-block__thumb {
    display: flex;
    align-items: center;
    width: 25%;
    min-width: 115px;
    height: auto;
    margin: 0;
  }
  .p-archive-block__thumb__img {
    width: 100%;
    height: auto;
    padding: 60% 0 0;
  }
  .p-archive-block-work .p-archive-block__thumb__img {
    width: 70%;
    height: 150px;
    padding: 0;
  }
  .p-archive-block__txt {
    width: 72%;
    display: flex;
    flex-direction: column;
  }
  .p-archive-block-work .p-archive-block__thumb {
    margin: 0 0 10px;
  }
  .p-archive-block-work .p-archive-block__thumb,
  .p-archive-block-work .p-archive-block__txt {
    width: 100%;
  }

  /*yarpp*/
  .p-related-child {
    display: flex;
    justify-content: space-between;
  }
  .p-related-child .p-archive-block__link {
    width: 49%;
    margin: 0;
    background: #fff;
    box-shadow: 0px 5px 15px 0px rgba(14, 46, 95, 0.05);
  }
  .p-related-child .p-archive-block__link:hover {
    background: #d7e7ff;
  }
  .p-related-child .p-archive-block__thumb,
  .p-related-child .p-archive-block__txt {
    width: 100%;
  }
  .p-related-child .p-archive-block__thumb {
    margin: 0 0 30px;
  }
  .p-related-child .p-archive-block__thumb__img {
    width: 80%;
    height: 150px;
    padding: 0;
  }



  /* Utility
  ----------------------------------------------------------------- */
  .u-tablet-none { display: none; }
  .u-tablet-block { display: block; }
}
@media screen and (min-width: 769px) {
  /* ==========================================================================
  Layout
  ========================================================================== */
  aside.l-content-area__side--post {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .l-site-footer {
    padding: 70px 5% 40px;
  }

  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */
  .c-hamburger__inner,
  .c-hamburger__inner:before,
  .c-hamburger__inner:after {
    height: 4px;
  }

  .c-post-list__item,
  .c-post-list__item:nth-child(n + 3) {
    margin-top: 0;
  }
  .c-post-list__item {
    width: 24%;
    margin-right: calc(4% / 3);
  }
  .c-post-list__item:nth-child(odd) {
    margin-right: calc(4% / 3);
  }
  .c-post-list__item:nth-child(4n) {
    margin-right: 0;
  }

  .c-table {
    align-items: stretch;
    display: flex;
    flex-wrap: wrap;
  }
  .c-table__th {
    align-items: center;
    background-color: transparent;
    border-bottom-style: solid;
    display: flex;
    flex-direction: column;
    padding: 20px 0;
    width: 22.5%;
  }
  .c-table__td {
    padding: 20px 38px;
    width: 77.5%;
  }

  .c-list--2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .c-list--2 > .c-list__item {
    min-width: 50%;
  }
  .c-hoverimg:hover img {
    opacity: .8;
  }

  .c-single-content .c-article-info {
    margin: 0 0 15px;
  }
  .c-single-content p.p-event-date,
  .c-single-content .c-article-info .p-archive-block__txt__cat {
    width: auto;
  }
  .c-single-content p.p-event-date {
    margin: 0 10px 6px 0;
  }
  .c-single-content .c-article-info .p-archive-block__txt__cat,
  .c-single-content .c-article-info .p-archive-block__txt__cat ul {
    margin: 0;
  }

  .c-single-content {
    padding-top: 45px;
    padding-bottom: 45px;
  }

  .c-page-nav > a {
    width: 48%;
    margin: 0;
  }
  .c-single-content table,
  .c-table--1 {
    min-width: auto;
  }
  .c-scrollable-table {
    overflow-x: visible;
    white-space: normal;
  }

  .c-cat-tab__list {
    display: flex;
    justify-content: space-between;
    margin-bottom: 2.5rem;
  }
  .c-cat-tab__list__item {
    width: calc((100% / 4) - 4px);
    text-align: center;
  }
  .c-cat-tab__list__item a {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 12px;
    background: #fff;
    border-radius: 3px;
    color: #333;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
    text-decoration: none;
    box-shadow: 0px 3px 3px -3px rgba(0,0,0,0.2);
  }
  .c-cat-tab__list__item a::before,
  .c-cat-tab__list__item a::after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
  }
  .c-cat-tab__list__item a::before {
    border-color: rgba(0, 0, 0, 0);
    border-top-color: #fff;
    border-width: 8px;
    margin-left: -8px;
    z-index: 2;
  }
  .c-cat-tab__list__item a::after {
    border-color: rgba(0, 0, 0, 0);
    border-top-color: #eee;
    border-width: 12px;
    margin-left: -12px;
    z-index: 1;
  }
  .c-cat-tab__list__item a:hover,
  .c-cat-tab__list__item.js-select a {
    background: #09c;
    color: #fff;
    transition: initial;
  }
  .c-cat-tab__list__item a:hover::before,
  .c-cat-tab__list__item.js-select a::before {
    border-top-color: #09c;
  }
  .c-cat-select__list {
    display: none;
  }

  .c-author-box__info {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .c-author-box__info__img {
    width: 20%;
    max-width: 300px;
    margin: 0;
  }
  .c-author-box__info__txt {
    width: 76%;
    margin: 0;
  }
  .c-author-box__info__head {
    text-align: left;
  }
  .c-author-box__info__sns {
    justify-content: flex-end;
  }
  .c-author-box__info__sns li a:hover {
    opacity: .8;
  }

  .c-content-block--1 {
    padding: 50px 0;
  }
  .c-content-block--2 {
    padding: 30px 0;
  }

  /* Project
  ----------------------------------------------------------------- */

  /*aside*/
  .p-side__item:not(:first-child) {
    margin-top: 30px;
  }
  .p-side__item:not(.p-side__item--tags) {
    width: 49%;
    margin-bottom: 30px;
  }
  .p-entry-thumb--side {
    width: 30%;
  }


  .p-home--beyond__item__btn {
    max-width: 370px;
    margin-left: auto;
    margin-right: auto;
  }
  .p-home--blog-btn {
    max-width: 370px;
    margin-left: auto;
    margin-right: 0;
  }
  .p-banner-list-wrap {
    margin-top: 60px;
    padding-top: 40px;
  }
  .home .p-banner-list-wrap {
    margin-top: 120px;
  }
  .u-pb--0 + div .p-banner-list-wrap {
    margin-top: 120px;
  }

  .c-bg--1 .p-home--works .c-post-list__item {
    /* padding: 20px; */
  }

  .p-messeage-block {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .p-messeage-block__txt {
    width: 47%;
  }
  .p-messeage-block__img {
    width: 47%;
  }
  .p-messeage-block__img__in {
    display: inline-block;
    position: relative;
  }

  /* .p-messeage-block__img__in::before {
  border: 3px solid #1572a1;
  content: '';
  display: block;
  height: 100%;
  max-height: 682px;
  position: absolute;
  top: 4.3604651%;
  left: -5.6179775%;
  width: 100%;
  max-width: 528px;
} */
  .p-messeage-block__img__in img {
    max-width: 100%;
  }
  .p-philosophy-box {
    padding: 10px;
  }
  .p-philosophy-box__in {
    border: solid 4px #0a3874;
    padding: 4px;
  }
  .p-philosophy-box__grandin {
    border: solid 2px #0a3874;
    padding: 0 3rem;
  }
  .p-philosophy-box__top {
    border-bottom: solid 2px #e5e5e5;
    padding: 3rem 1rem 2.5rem;
  }
  .p-philosophy-box__bottom {
    padding: 2.5rem 1rem 1rem;
  }


  .p-mind-box {
    width: 65%;
  }
  .p-mind-block--1 {
    background: url(img/pc_mind-bg--1_2023.jpg) no-repeat center center #f2f7f9;
    background-size: cover;
  }
  .p-mind-block--2 {
    background: url(img/pc_mind-bg--2_2023.jpg) no-repeat center center #fff;
    background-size: cover;
  }
  .p-mind-block--3 {
    background: url(img/pc_mind-bg--3_2023.jpg) no-repeat center center #f2f7f9;
    background-size: cover;
  }
  .p-mind-block--2 .p-mind-box {
    margin: 0 0 0 auto;
  }
  .p-servicepage-list .p-servicepage-list-child {
    width: 100%;
  }
  .p-service-btn__icon,
  .p-service-list__1col .c-btn--2--col__icon {
    width: 20%;
    padding: 0 2%;
    text-align: center;
  }
  .p-service-btn__txt {
    width: 80%;
    padding: 0 2%;
    border-left: solid 1px #37cdd3;
  }
  .p-servicepage-list .p-service-list__item .c-btn--2--col,
  .p-service-list__item.p-service-list__1col .c-btn--2--col {
    flex-direction: inherit;
  }
  .c-btn--2--col .p-service-btn__txt .c-btn--2--col__title {
    text-align: left;
  }

  .p-support-strength__child {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
  }
  .p-support-strength__img {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26.2%;
    margin: 0;
  }
  .p-support-strength__txt {
    width: 69.4%;
  }

  .p-security-bg {
    background: url(img/security-bg--1.jpg) no-repeat center center;
    background-size: cover;
  }

  .p-security-list__child {
    width: 49%;
    margin: 0 0 30px;
    padding: 0;
  }
  .p-security-list__img a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 160px;
    padding: 1em 2em;
  }
  .p-security-list__img a img {
    max-width: 100%;
  }
  .p-security-list__child:not(:last-of-type) {
    border-bottom: none;
  }

  .p-construction-bal {
    background: url(img/sp_construction-bg--2.jpg) no-repeat center bottom;
    background-size: cover;
    padding: 30px 0 /* calc(70px + 2%) */;
  }

  .p-consulting-list-wrap {
    background: url(img/consulting-bg--1.jpg) no-repeat right bottom;
    background-size: cover;
    padding: 20px;
  }
  .p-consulting-list {
    margin: 0;
  }
  .p-consulting-list li:not(:last-of-type) {
    margin: 0 0 1.5em;
  }

  .p-domain-block .p-messeage-block__txt {
    width: 51%;
  }
  .p-domain-block .p-messeage-block__img {
    width: 45%;
  }

  .p-faq-desc {
    margin: 0 0 40px;
    padding: 0 0 50px;
  }

  .p-archive-block--full--works__wrap {
    padding: 30px;
  }
  .p-archive-block-work {
    width: 31%;
    margin: 0 3.5% 3.5% 0;
  }
  .p-archive-block-work:nth-of-type(3n) {
    margin: 0 0 3.5%;
  }
  .p-archive-block-work .p-archive-block__thumb__img {
    width: 100%;
    height: auto;
    padding: 60% 0 0;
  }
  .p-archive-block-work.p-archive-block__link {
    flex-direction: column;
  }
  .p-archive-block-work .c-tax-list {
    margin-top: auto;
  }
  .p-event-block__info > p {
    width: auto;
  }
  .p-event-block__info > p:first-of-type {
    margin: 0 1em .5em 0;
  }
  .p-event-block__info__icon {
    min-width: auto;
  }

  .p-event-block__map {
    padding-bottom: 40%;
  }





  /* Utility
  ----------------------------------------------------------------- */
  .u-sp769-none { display: block; }
  .u-sp769-block { display: none; }
  .u-indent--2 {
    text-indent: -1.6em;
    padding: 0 0 0 1.6em;
  }
  .u-indent--2__2 {
    text-indent: -2.1em;
    padding: 0 0 0 1.6em;
  }
}
@media screen and (min-width: 1025px) {
  /* ==========================================================================
  Layout
  ========================================================================== */
  .l-lang {
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 998;
    background: #eee;
    padding: 10px;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
  }
  .l-lang__list li a {
    font-size: 14px;
  }

  .l-lang--sp {
    display: none;
  }
  
  .l-site {
  }
  .l-site__navi {
    display: block;
    height: 100%;
    min-height: 100vh;
    overflow-y: scroll;
    -ms-overflow-style: none;
    padding: 62px 15px;
    top: 0px;
    left: 0;
    width: 260px;
  }
  .l-site__navi::-webkit-scrollbar{
    background:transparent
  }
  .l-site__content-contain {
    margin-top: 0px;
    margin-left: 260px;
    width: calc(100% - 260px);
  }


  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */
  .c-breadcrumb-wrap {
    font-size: 14px;
  }
  .c-breadcrumb {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding: 10px 20px;
  }
  .c-breadcrumb__item {
    padding: 7px 0;
  }
  .c-breadcrumb__item:not(:last-child)::after {
    margin: 0 15px;
  }
  .c-breadcrumb__item__link:hover {
    text-decoration: underline;
  }


  .c-content-block--1 {
    padding: 120px 0;
  }
  .c-content-block--2 {
    padding: 60px 0;
  }

  .c-content-child {
    margin-top: 90px;
  }
  .c-content-child--2 {
    margin-top: 45px;
  }

  .c-content-width--1 {
    max-width: 1240px;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  .c-content-width--2 {
    max-width: 1440px;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  .c-content-width--3 {
    max-width: 1240px;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  .c-content-width--4 {
    max-width: 1440px;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto;
  }
  .c-content-width--5 {
    max-width: 960px;
    padding-left: 30px;
    padding-right: 30px;
    margin-left: auto;
    margin-right: auto;
  }

  .c-title-1__main {
    font-size: 34px;
  }
  .c-title-1__main__l {
    font-size: 54px;
  }
  .c-title-1__main__s {
    font-size: 30px;
  }
  .c-title-1__sub {
    font-size: 16px;
  }

  .c-title-2 {
    align-items: flex-end;
    flex-direction: row;
    margin-top: 50px;
    max-width: 100%;
  }
  .c-title-2__main {
    font-size: 30px;
  }
  .c-title-2__sub {
    font-size: 16px;
    margin-left: 16px;
  }

  .c-title-3 {
    font-size: 26px;
  }

  .c-title-4 {
    margin: 0 0 40px;
    font-size: 36px;
  }
  .c-title-5 {
    font-size: 26px;
    margin: 0 0 40px;
  }

  .c-title-7 {
    font-size: 28px;
  }
  .c-title-8 {
    margin: 0 0 20px;
    font-size: 24px;
  }
  .c-title-9 {
    font-size: 24px;
  }
  .c-title-10 {
    font-size: 18px;
  }

  .c-btn--1 {
    font-size: 17px;
    padding: 15px 18px;
  }
  .c-btn--1:hover {
    opacity: .7;
  }

  .c-btn--2:hover {
    background-color: #d7e7ff;
  }

  .c-btn--2--col {
    padding: 40px 12.0689655%;
  }
  .c-btn--2--col__icon__img {
    max-width: 130px;
  }
  .c-btn--2--col__icon__img--2 {
    max-width: 194px;
  }
  .c-btn--2--col__title {
    font-size: 24px;
    margin: 22px 0 0;
  }
  .c-btn--2--col__text {
    font-size: 18px;
    margin-top: 26px;
  }
  .c-btn--2--row__icon {
    margin-right: 5%;
  }
  .c-btn--2--row {
    padding: 22px 7.8947368%;
  }
  .c-btn--2--row__icon__img {
    max-width: 94px;
  }
  .c-btn--2--row__title {
    font-size: 22px;
  }
  .c-btn--2--row-2__icon__img {
    max-width: 186px;
  }
  .c-btn--2--row-2__text {
    font-size: 18px;
  }

  .c-btn--3 {
    font-size: 18px;
  }
  .c-btn--3:hover {
    /* background-image: linear-gradient(-90deg,#105b92,#24a5c2); */
  }
  .c-btn--3--white:hover {
    background: #d7e7ff;
  }
  .c-btn--3__inner {
    background-position: right 15px center;
    padding: 25px 30px 25px 25px;
  }

  .c-btn--1--contact-us,
  .c-btn--1--download,
  .c-btn--1--faq {
    width: 100%;
    justify-content: flex-start;
    font-size: 15px;
  }
  .c-btn--1--contact-us,
  .c-btn--1--faq {
    text-indent: 1em;
  }

  .c-content-break-line {
    padding-top: 200px;
  }

  .c-post-list__item__link__date {
    font-size: 16px;
  }

  .c-post-list__item__link__tag {
    font-size: 14px;
    margin-top: 10px;
  }
  .c-post-list__item__link__title {
    font-size: 18px;
    margin-top: 10px;
  }
  .c-post-list__item__link__name {
    margin-top: 20px;
  }
  .c-post-list__item__link:hover {
    opacity: .7;
  }

  .c-table__th,
  .c-table__td {
    font-size: 16px;
  }
  .c-table__th__notice {
    font-size: 14px;
  }

  .c-table__td p + p {
    margin-top: 30px;
  }

  .c-wrap--1 {
    margin: 90px 0 0;
  }
  .c-wrap--2 {
    margin: 45px 0 0;
  }

  .c-bg--img__txt p {
    font-size: 16px;
  }

  .c-single-content .c-article-info .p-archive-block__txt__cat ul li {
    margin: 0 .5em 1em 0;
  }
  .c-single-content p.p-event-date {
    margin: 0 10px 12px 0;
    color: #23a5c2;
    font-size: 16px;
    font-weight: bold;
  }
  .c-single-content img,
  .c-single-content .thumb {
    margin: 1.5em 0;
  }
  .c-single-content h1 {
    margin: 0 0 40px;
    font-size: 34px;
  }
  .c-single-content .c-single-content__ttl {
    margin: 0 0 30px;
  }
  .c-single-content h2 {
    font-size: 28px;
  }
  .c-single-content h3 {
    font-size: 24px;
  }
  .c-single-content h4 {
    font-size: 22px;
  }
  .c-single-content hr {
    margin: 2em 0;
  }
  .c-single-content table {
    margin: 0 0 2em;
  }
  .c-single-content ul,
  .c-single-content ol,
  .c-single-content blockquote {
    margin: 0 0 1.5em;
  }
  .c-single-content ol li,
  .c-single-content ul li {
    margin: 0 0 1em;
  }
  .c-single-content blockquote {
    padding: 2em 1.5em;
  }
  .c-single-content blockquote::before {
    top: .5em;
    left: .5em;
  }
  .c-single-content blockquote::after {
    bottom: .5em;
    right: .5em;
  }
  .c-single-content a.c-single-btn {
    font-size: 18px;
    margin: 2.5em auto 0;
  }
  .c-single-content a.c-single-btn:hover {
    background: linear-gradient(-90deg,#105b92,#24a5c2);
  }

  .c-slide-arrow:hover {
    opacity: .8;
  }

  .c-author-box {
    padding: 30px;
  }
  .c-author-box__info {
    margin: 35px 0 0;
  }
  .c-author-box__info__head {
    margin: 0;
  }

  /*animation*/
  .c-animate-box {
    position: relative;
  }
  .aos-animate .c-animate-box__wrap {
    width: 100%;
    height: 100%;
    position: absolute;
    -webkit-animation-delay: 2.6s;
    animation-delay: 2.6s;
    top: 0;
    left: 0;
    opacity: 1;
    z-index: 1;
    -webkit-transition: .5s;
    transition: .5s;
    -webkit-animation-duration: .5s;
    animation-duration: .5s;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-name: sheftBorderOne;
    animation-name: sheftBorderOne;
  }
  .aos-animate .c-animate-box__wrap--1 {
    -webkit-animation-name: sheftBorderTwo;
    animation-name: sheftBorderTwo;
  }
  .aos-animate .c-animate-box-border {
    -webkit-transition: .5s;
    transition: .5s;
    -webkit-transition-property: top left;
    transition-property: top left;
  }
  .aos-animate .c-animate-box-border::before,
  .aos-animate .c-animate-box-border::after {
    content: '';
    display: block;
    position: absolute;
    z-index: 100;
    opacity: 0;
    background-color: #1572a1;
    -webkit-transition: .5s;
    transition: .5s;
    -webkit-animation-duration: .2s;
    animation-duration: .2s;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
  }
  .aos-animate .c-animate-box-border.border-color-green::before,
  .aos-animate .c-animate-box-border.border-color-green::after {
    background-color: #008080;
  }
  .aos-animate .c-animate-box-border::before {
    width: 100%;
    height: 3px;
    -webkit-animation-name: drawBorderX;
    animation-name: drawBorderX;
  }
  .aos-animate .c-animate-box-border::after {
    width: 3px;
    height: 100%;
    -webkit-animation-name: drawBorderY;
    animation-name: drawBorderY;
  }
  .aos-animate .c-animate-box-border--1::before,
  .aos-animate .c-animate-box-border--1::after {
    top: 0;
    right: 0;
  }
  .aos-animate .c-animate-box-border--1::before {
    -webkit-animation-delay: 1.8s;
    animation-delay: 1.8s;
    -webkit-transform-origin: left;
    transform-origin: left;
  }
  .aos-animate .c-animate-box-border--1::after {
    -webkit-animation-delay: 2s;
    animation-delay: 2s;
    -webkit-transform-origin: top;
    transform-origin: top;
  }
  .aos-animate .c-animate-box-border--2::before,
  .aos-animate .c-animate-box-border--2::after {
    bottom: 0;
    left: 0;
  }
  .aos-animate .c-animate-box-border--2::before {
    -webkit-animation-delay: 2.2s;
    animation-delay: 2.2s;
    -webkit-transform-origin: right;
    transform-origin: right;
  }
  .aos-animate .c-animate-box-border--2::after {
    -webkit-animation-delay: 2.4s;
    animation-delay: 2.4s;
    -webkit-transform-origin: bottom;
    transform-origin: bottom;
  }
  @-webkit-keyframes drawBorderX {
    0% {
      -webkit-transform: scaleX(0) translate3d(0, 0, 0);
      transform: scaleX(0) translate3d(0, 0, 0);
      opacity: 0
    }
    1% {
      -webkit-transform: scaleX(0) translate3d(0, 0, 0);
      transform: scaleX(0) translate3d(0, 0, 0);
      opacity: 1
    }
    100% {
      -webkit-transform: scaleX(100%) translate3d(0, 0, 0);
      transform: scaleX(100%) translate3d(0, 0, 0);
      opacity: 1
    }
  }
  @keyframes drawBorderX {
    0% {
      -webkit-transform: scaleX(0) translate3d(0, 0, 0);
      transform: scaleX(0) translate3d(0, 0, 0);
      opacity: 0
    }
    1% {
      -webkit-transform: scaleX(0) translate3d(0, 0, 0);
      transform: scaleX(0) translate3d(0, 0, 0);
      opacity: 1
    }
    100% {
      -webkit-transform: scaleX(100%) translate3d(0, 0, 0);
      transform: scaleX(100%) translate3d(0, 0, 0);
      opacity: 1
    }
  }
  @-webkit-keyframes drawBorderY {
    0% {
      -webkit-transform: scaleY(0) translate3d(0, 0, 0);
      transform: scaleY(0) translate3d(0, 0, 0);
      opacity: 0
    }
    1% {
      -webkit-transform: scaleY(0) translate3d(0, 0, 0);
      transform: scaleY(0) translate3d(0, 0, 0);
      opacity: 1
    }
    100% {
      -webkit-transform: scaleY(100%) translate3d(0, 0, 0);
      transform: scaleY(100%) translate3d(0, 0, 0);
      opacity: 1
    }
  }
  @keyframes drawBorderY {
    0% {
      -webkit-transform: scaleY(0) translate3d(0, 0, 0);
      transform: scaleY(0) translate3d(0, 0, 0);
      opacity: 0
    }
    1% {
      -webkit-transform: scaleY(0) translate3d(0, 0, 0);
      transform: scaleY(0) translate3d(0, 0, 0);
      opacity: 1
    }
    100% {
      -webkit-transform: scaleY(100%) translate3d(0, 0, 0);
      transform: scaleY(100%) translate3d(0, 0, 0);
      opacity: 1
    }
  }
  @-webkit-keyframes sheftBorderOne {
    0% {
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0)
    }
    100% {
      -webkit-transform: translate(4.3604651%, 5.6179775%);
      transform: translate(4.3604651%, 5.6179775%)
    }
  }
  @keyframes sheftBorderOne {
    0% {
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0)
    }
    100% {
      -webkit-transform: translate(4.3604651%, 5.6179775%);
      transform: translate(4.3604651%, 5.6179775%)
    }
  }
  @-webkit-keyframes sheftBorderTwo {
    0% {
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0)
    }
    100% {
      -webkit-transform: translate(-4.3604651%, 5.6179775%);
      transform: translate(-4.3604651%, 5.6179775%)
    }
  }
  @keyframes sheftBorderTwo {
    0% {
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0)
    }
    100% {
      -webkit-transform: translate(-4.3604651%, 5.6179775%);
      transform: translate(-4.3604651%, 5.6179775%)
    }
  }


  /* Project
  ----------------------------------------------------------------- */
  .p-site-title {
    width: 230px;
  }
  .p-site-title__link:hover {
    opacity: .7;
  }
  .p-site-title__link__img {
    width: 152px;
    margin: 0 auto;
  }
  .p-header-hamburger {
    display: none;
  }
  .p-site-description {
    display: block;
    font-size: 12px;
    margin: 4px auto 0;
    text-align: center;
    width: 230px;
  }
  .p-site-menu {
    display: block;
    margin-top: 34px;
    padding: 0;
    position: static;
    text-align: center;
    width: 230px;
    background: #fff;
  }
  .p-site-menu__list {
    margin-left: 0;
    width: 100%;
  }
  .p-site-menu__list__item__link {
    font-size: 17px;
    padding: 17px 0;
    border-bottom: none;
  }
  .p-site-menu__list__item__link::after {
    width: 0;
    height: 0;
    border-top: none;
    border-right: none;
  }
  .p-site-menu__list__item__link:hover {
    background: #f2f7f9;
  }
  .p-site-menu__list__item:nth-last-child(1),
  .p-site-menu__list__item:nth-last-child(2),
  .p-site-menu__list__item:nth-last-child(3) {
    margin-top: 30px;
    padding: 0 10px;
  }
  .p-site-menu__list__item:nth-last-child(1),
  .p-site-menu__list__item:nth-last-child(2) {
    margin-top: 18px;
  }
  .p-site-menu__tel {
    margin-top: 33px;
    padding-top: 20px;
    box-shadow: none;
  }
  .p-site-menu__tel__text {
    font-size: 16px;
  }
  .p-site-menu__tel__link {
    margin-top: 22px;
  }
  .p-site-menu__tel__link__img {
    width: 100%;
  }
  .p-site-menu__sns li {
    width: 36px;
  }
  .p-site-menu__sns a:hover {
    opacity: .7;
  }



  .p-news a:hover {
    text-decoration: underline;
  }

  .p-news-wrap {
    display: flex;
    justify-content: space-between;
  }
  .p-news-title {
    align-items: center;
    display: none;
    justify-content: center;
    width: 13.9759036%;
  }
  .p-news {
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    padding-left: 3.1%;
    /* width: calc(100% - 13.9759036%); */
    width: 100%;
  }
  .p-news__date {
    font-size: 16px;
    margin-right: 2%;
  }
  .p-news__title {
    letter-spacing: .04em;
    margin-top: 0;
    margin-right: 2%;
    text-align: left;
  }
  .p-news__more {
    font-size: 16px;
    margin-top: 0;
  }

  .p-home--beyond__item__img-wrap {
    position: relative;
  }
  /* .p-home--beyond__item__img-wrap::before {
  border: 3px solid #1572a1;
  content: '';
  display: block;
  height: 100%;
  max-height: 682px;
  position: absolute;
  top: 4.3604651%;
  left: 5.6179775%;
  width: 100%;
  max-width: 528px;
} */
  .p-home--beyond__item__subtitle {
    margin-top: 70px;
  }
  .p-home--beyond__item__text {
    font-size: 18px;
    line-height: 2;
    margin-top: 50px;
  }
  .p-home--beyond__item__btn {
    margin-top: 30px;
  }


  .p-home--blog__item:first-child {
    width: 49.8571428%;
  }

  .p-home--blog__item__img-wrap {
    position: relative;
  }
  /* .p-home--blog__item__img-wrap::before {
  border: 3px solid #1572a1;
  content: '';
  display: block;
  height: 100%;
  max-height: 682px;
  position: absolute;
  top: 4.3604651%;
  left: -5.6179775%;
  width: 100%;
  max-width: 528px;
} */
  .p-home--blog-list {
    margin-top: 70px;
  }
  .p-home--blog-list__item {
    font-size: 18px;
  }
  .p-home--blog-list__item__link:hover {
    text-decoration: underline;
  }
  .p-home--blog-btn {
    margin-top: 70px;
  }

  .p-home-reason-list {
    align-items: flex-start;
    margin-top: 40px;
  }
  .p-home-reason-list__item {
    padding: 60px 35px 40px;
  }
  .p-home-reason-list__item:nth-child(2) {
    margin-top: 60px;
  }
  .p-home-reason-list__item:nth-child(3) {
    margin-top: 120px;
  }
  .p-home-reason-list__item__maintitle {
    font-size: 28px;
    text-align: right;
    line-height: 1.4;
  }
  .p-home-reason-list__item__maintitle span {
    display: inline-block;
  }
  .p-home-reason-list__item__start,
  .p-home-reason-list__item__end {
    font-size: 20px;
  }
  .p-home-reason-list__item__subtitle {
    font-size: 20px;
    line-height: 1.7;
  }
  .p-home-reason-list__item__text {
    font-size: 18px;
    line-height: 1.7;
  }



  .p-home-partner-list__item {
    width: 24%;
  }
  .p-home-partner-list__item:not(:nth-child(4n)) {
    margin-right: calc(4% / 3);
  }

  .p-home-partner-list__item:nth-child(3),
  .p-home-partner-list__item:nth-child(4) {
    margin-top: 0;
  }

  .p-home--works {
    margin-top: 70px;
  }
  .p-home--works .c-post-list__item {
    margin-bottom: 20px;
  }
  .p-home--works-btn {
    margin-left: auto;
    margin-right: auto;
    margin-top: 50px;
    max-width: 370px;
  }

  .p-home--news {
    margin-top: 70px;
  }
  .p-home--news-btn {
    margin-left: auto;
    margin-right: auto;
    margin-top: 70px;
    max-width: 370px;
  }

  .p-home-partner-list {
    margin-top: 70px;
  }
  .p-home-partner-btn {
    margin-left: auto;
    margin-right: auto;
    margin-top: 70px;
    max-width: 370px;
  }

  .p-footer-navi-wrap {
    flex-direction: column-reverse;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
  }

  .p-footer-logo-wrap {
    justify-content: flex-start;
  }

  .p-footer-logo:hover {
    opacity: .7;
  }

  .p-footer-logo__img {
    width: 168px;
  }

  .p-footer-sns__item:hover {
    opacity: .7;
  }

  .p-footer-sns__item__img {
    width: 36px;
  }

  .p-footer-sns {
    margin-left: 20px;
  }
  .p-footer-sns__item {
    margin-left: 20px;
  }
  .p-footer-navi {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    margin-top: 20px;
  }
  .p-footer-menu-list {
    margin-left: 10px;
  }
  .p-footer-address {
    border: none;
    flex-direction: column;
    justify-content: flex-start;
    margin-top: 0;
    padding-top: 0;
  }
  .p-footer-address__item:nth-child(odd),
  .p-footer-address__item {
    padding: 0;
    margin: 0;
    text-align: left;
    width: 100%;
  }
  .p-footer-address__item:not(:first-child) {
    margin-top: 10px;
  }

  .p-footer-menu-list__item__link:hover,
  .p-footer-submenu-list__item__link:hover {
    text-decoration: underline;
  }

  .p-pagetop__img {
    width: 60px;
  }


  .p-company-list {
    margin-top: 50px;
  }
  .p-company-list__item__link__text {
    font-size: 28px;
    transition: top .2s, bottom .2s, left .2s, right .2s, background-color .2s;
  }
  .p-company-list__item__link:hover .p-company-list__item__link__text {
    background-color: rgba(19,129,191,.6);
    top: 0;
    bottom: 20px;
    left: 0;
    right: 20px;
  }

  .p-company-info-table,
  .p-company-group {
    margin-top: 90px;
  }

  .p-access {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 20px;
  }
  .p-access__item {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 48.3333%;
  }
  .p-access__item .c-title-2 {
    margin-top: 60px;
  }

  .p-access__item__address {
    font-size: 16px;
    margin-top: 40px;
  }
  .p-access__item__route {
    font-size: 16px;
    margin-top: 40px;
    margin-bottom: auto;
  }
  .p-access__item__map {
    margin-top: 30px;
  }

  .p-company-headbox--in {
    margin: 60px 0 0;
    font-size: 16px;
  }
  .p-company-group > * {
    width: 49.1666%;
    padding: 30px;
  }

  .p-company-group.col3 {
    margin-top: 50px;
    justify-content: flex-start;
  }
  .p-company-group.col3 > * {
    width: 32%;
    margin-right: 2%;
    display: block;
  }
  .p-company-group.col3 > *:nth-of-type(3n) {
    margin-right: 0;
  }
  .p-company-group.col3 .p-company-group__img {
    text-align: center;
    width: 100%;
    margin: 0 0 10px;
    padding: 0 0 15px;
    border-bottom: 1px solid #ccc;
  }
  .p-company-group.col3 .p-company-group__img img {
    max-height: 70px;
  }
  .p-company-group.col3 .p-company-group__txt {
    width: 100%;
  }

  .p-company-group a:hover {
    opacity: .8;
  }
  .p-company-group__txt {
    font-size: 16px;
  }
  .p-philosophy-headbox--inner {
    padding: 90px;
  }
  .p-philosophy-headbox--in {
    margin: 60px 0 0;
    font-size: 16px;
  }
  .p-philosophy-block-inner {
    margin: 20px 0 0;
  }
  .p-philosophy-block-inner > * {
    width: 49%;
  }
  .p-philosophy-block__txt {
    padding: 0 25px;
    margin: 0;
    order: 0;
  }
  .p-philosophy-block__txt h3 {
    font-size: 20px;
  }
  .p-philosophy-block__img {
    order: 0;
  }
  .p-philosophy-box {
    margin: 60px auto 0;
  }

  .p-messeage-block {
    margin: 90px 0 0;
  }

  .p-mind-block--1 .p-mind-box {
    margin: 90px 0 0;
  }
  .p-mind-box h2 {
    margin: 0 0 30px;
    font-size: 30px;
  }
  .p-mind-box h3 {
    margin: 0 0 25px;
    font-size: 24px;
  }

  .p-history-headbox--in {
    margin: 60px 0 0;
    font-size: 16px;
  }

  .p-service-list__item .c-btn--2--col {
    padding: 22px;
  }
  .p-service-btn__icon .c-btn--2--col__icon__img,
  .p-service-btn__icon .c-btn--2--row-2__icon__img,
  .p-service-list__1col .c-btn--2--col__icon__img,
  .p-service-list__1col .c-btn--2--col__icon__img--2 {
    max-width: 100%;
  }
  .p-service-btn__icon,
  .p-service-btn__txt,
  .p-service-list__1col .c-btn--2--col__icon {
    padding: 0 2%;
  }
  .p-service-btn__txt .c-btn--2--col__text {
    margin-top: 20px;
  }
  .p-service-btn__txt .c-btn--2--col__title {
    margin-top: 15px;
  }
  .p-servicepage-list .c-btn--2--row-2__text {
    margin-top: 20px;
  }

  .p-construction-bal {
    padding: 70px 0 /* calc(90px + 2%) */;
  }
  .p-construction-bal__head {
    font-size: 24px;
    margin: 0 0 2rem;
  }
  .p-construction-bal__head span {
    font-size: 28px;
  }
  .p-construction-bal__box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .p-construction-bal__box li {
    width: 49%;
    display: flex;
    align-items: center;
  }
  .p-construction-bal__box li:nth-last-of-type(2) {
    margin: 0;
  }

  .p-construction-plus__box1 {
    width: 32%;
  }
  .p-construction-plus__box1__in {
    padding: 1.5rem 1rem;
  }
  .p-construction-plus__icon__wrap {
    display: flex;
    align-items: center;
    width: 4%;
  }
  .p-construction-plus__box2 {
    width: 64%;
  }

  .p-support-plus__box1 {
    width: 40%;
  }
  .p-support-plus__box2 {
    width: 56%;
  }
  .p-support-bal__box li,
  .p-support-bal__box li:nth-of-type(even) {
    width: 18.4%;
    margin: 0 2% 2% 0;
    padding: 40px 20px;
  }
  .p-support-bal__box li:nth-of-type(5n) {
    margin: 0 0 2%;
  }
  .p-support-strength__child {
    width: 49%;
    margin: 0 2% 2% 0;
    padding: 1.5rem 2rem;
  }
  .p-support-strength .p-support-strength__child:nth-of-type(even) {
    margin: 0 0 2%;
  }


  .p-loadtest-list li {
    width: calc((100% - 40px - 5rem) / 5);
    margin: 0 0 calc(1rem + 8px);
  }
  .p-loadtest-list.fukamill li,
  .p-loadtest-list.vulnerability-list li {
    width: calc((100% - 5rem) / 3);
  }
  .p-loadtest-list li.p-loadtest-list__arrow {
    margin: auto .5rem;
    padding: 0 0 calc(1rem + 8px);
  }
  .p-loadtest-list.fukamill li.p-loadtest-list__arrow,
  .p-loadtest-list.vulnerability-list li.p-loadtest-list__arrow {
    margin: auto .5rem;
    padding: 0 0 calc(1rem + 8px);
  }
  .p-loadtest-list li.p-loadtest-list__arrow::before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 8px;
    border-color: transparent transparent transparent #313543;
  }
  .p-loadtest-list li.p-loadtest-list__info__wrap {
    width: calc((78% - 8px - 1rem));
    padding: 1rem 1.5rem;
  }
  .p-loadtest-list li.p-loadtest-list__info__wrap--2 {
    width: 22%;
  }
  .p-loadtest-list__info {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 1rem 0 0;
  }
  .p-loadtest-list__info p {
    width: 42%;
  }

  .p-cdn-list li {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    width: 32%;
    padding: 2rem;
    line-height: 1.5;
  }
  .p-cdn-list li:last-of-type {
    margin: 0 0 1rem;
  }
  .p-cdn-reason__child {
    width: 100%;
    margin: 0 0 20px;
    padding: 2rem;
  }
  .p-cdn-reason__child .p-support-strength__img {
    width: 17%;
  }
  .p-cdn-reason__child .p-support-strength__txt {
    width: 80%;
  }

  .p-consulting-block {
    margin: 50px 0 0;
  }
  .p-consulting-list-wrap {
    padding: 30px;
    margin: 0 0 2em;
  }

  .p-ssl-bg {
    padding: 90px 0;
  }
  .p-ssl-list {
    justify-content: center;
  }
  .p-ssl-list li:not(:last-of-type),
  .p-ssl-list li:last-of-type {
    margin: 0 2% 1rem 0;
  }
  .p-ssl-list li:nth-of-type(3n) {
    margin: 0 0 1rem;
  }

  .p-faq__post-field {
    padding: 1rem 1.5rem;
  }
  .p-faq__post-field:not(:first-of-type) {
    margin-top: 2.5rem;
  }
  .c-content-faq_list .p-faq__post-field:not(:first-of-type) {
    margin-top: 1rem;
  }

  .c-cat-tab__child .p-faq__q::after {
    width: 0;
    height: 0;
    border-top: none;
    border-right: none;
  }
  .c-cat-tab__child .p-faq__a {
    display: block!important;
  }
  .p-faq__q {
    cursor: auto;
  }
  a.p-faq__q {
    text-decoration: none;
    color: inherit;
    height: 100%;
    cursor: pointer;
  }
  a.p-faq__q:hover {
    background-color: #d7e7ff;
  }
  h1.p-faq__q {
    font-size: 32px;
  }
  .c-content-faq_list .p-faq__q {
    cursor: pointer;
  }
  .p-faq__a {
    padding: 1.5rem 2rem 1.5rem 3.5rem;
  }


  .p-faq-tabs {
    display: flex;
    justify-content: center;
    margin-bottom: 2.5rem;
  }
  .p-faq-tabs__item {
    text-align: center;
    margin: 0 4px;
    flex: 1;
  }
  .p-faq-tabs__item a {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 12px;
    background: #fff;
    border-radius: 3px;
    color: #333;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
    text-decoration: none;
    box-shadow: 0px 3px 3px -3px rgba(0,0,0,0.2);
  }
  .p-faq-tabs__item a::before,
  .p-faq-tabs__item a::after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
  }
  .p-faq-tabs__item a::before {
    border-color: rgba(0, 0, 0, 0);
    border-top-color: #fff;
    border-width: 8px;
    margin-left: -8px;
    z-index: 2;
  }
  .p-faq-tabs__item a::after {
    border-color: rgba(0, 0, 0, 0);
    border-top-color: #eee;
    border-width: 12px;
    margin-left: -12px;
    z-index: 1;
  }
  .p-faq-tabs__item a:hover,
  .p-faq-tabs__item.js-select a {
    background: #09c;
    color: #fff;
    transition: initial;
  }
  .p-faq-tabs__item a:hover::before,
  .p-faq-tabs__item.js-select a::before {
    border-top-color: #09c;
  }
  .p-faq-selects {
    display: none;
  }



  .p-contact-wrap__child {
    text-align: center;
  }
  .p-contact__form {
    flex-direction: row;
    margin: 3em 0;
  }
  .p-contact__form dt {
    width: 25%;
    border-bottom: 1px solid #23a5c2;
    padding: 25px 20px;
  }
  .p-contact__form dt:last-of-type {
    border-bottom: none;
  }
  .p-contact__form dd {
    width: calc(100% - 25%);
    padding: 25px 20px;
  }

  .p-archive-cat-head {
    margin: 40px 0 0;
  }
  .p-archive-block--full--works__wrap {
    padding: 60px 50px;
  }
  .p-archive-block__txt__excerpt {
    margin: 0 0 20px;
  }
  .p-archive-block__txt__add {
    /* flex-wrap: nowrap;
    align-items: flex-end; */
  }
  .p-archive-block__txt__cat {
    margin: 0 0 5px;
  }
  .p-archive-block__txt__date {
    width: 12em;
    margin-top: 0;
    font-size: 13px;
  }
  .p-archive-block__txt__author__info {
    font-size: 13px;
  }
  .p-archive-block__txt__author__date {
    font-size: 13px;
  }


  .p-event-block__btn {
    margin-top: 30px;
  }

  .p-related-service {
    margin: 10px 0 0;
  }
  .p-related-service .c-btn--2--row__title {
    font-size: 18px;
  }

  .p-related-service .c-btn--2--row__icon__img {
    max-width: 94px;
  }

  /*yarpp*/
  .p-related-child {
    margin: 40px 0 0;
  }







  /* Utility
  ----------------------------------------------------------------- */
  .u-pc-none { display: none }
  .u-pc-block { display: block }
  .u-pc1025-block { display: block; }
}

@media screen and (min-width: 1200px) {
  /* ==========================================================================
  Layout
  ========================================================================== */

  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */
  .c-slide-arrow {
    width: 60px;
    height: 60px;
  }
  .c-prev-arrow {
    left: 40px;
  }
  .c-next-arrow {
    right: 40px;
  }
  .p-home--mv .slick-dots li {
    margin: 0 5px;
  }

  /* Project
  ----------------------------------------------------------------- */
  .p-footer-navi {
    margin-top: 50px;
  }
  .p-footer-menu-list {
    margin-left: 30px;
  }
  .p-footer-menu-list__item__link {
    font-size: 14px;
    font-weight: 700;
  }
  .p-footer-submenu-list__item__link {
    font-size: 14px;
  }
  .p-footer-address__item {
    font-size: 14px;
    line-height: 1.4;
  }
  .p-footer-address__item:not(:first-child) {
    margin-top: 40px;
  }
  .p-copyright {
    margin-top: 60px;
  }



  .p-home--mv .slick-dots {
    bottom: 15px;
  }

  .p-company-group__img {
    width: 28%;
  }
  .p-company-group__txt {
    width: 67%;
    margin: 0;
    text-align: left;
  }
  .p-messeage-block__txt h2 {
    font-size: 24px;
  }

  .p-service-btn__icon,
  .p-service-btn__txt {
    padding: 0 2%;
  }

  .p-construction-bal__box {
    padding: 35px;
  }
  .p-security-list::after {
    content: "";
    width: 32%;
  
  }
  .p-security-list__child,
  .p-security-list .p-security-list__child:nth-of-type(odd) {
    width: 32%;
    margin: 0 0 40px;
  }
  .p-security-list__img {
    margin: 0 0 20px;
  }
  .p-api-info__txt li {
    width: 49%;
    text-align: left;
  }
  .p-development-info__txt li {
    width: 100%;
  }
  .p-api-block__img {
    width: 41%;
  }
  .p-api-block__txt {
    width: 54%;
  }

  .p-archive-block--full--works__wrap {
    padding: 60px;
  }

  .p-related-child .p-archive-block__link {
    display: flex;
    justify-content: space-between;
    flex-direction: row;
  }
  .p-related-child .p-archive-block__thumb {
    width: 37%;
    margin: 0;
  }
  .p-related-child .p-archive-block__thumb__img {
    width: 100%;
  }
  .p-related-child .p-archive-block__txt {
    width: 58%;
  }
  .p-related-child .p-archive-block__txt__ttl {
    margin: 0;
  }



  /* Utility
  ----------------------------------------------------------------- */
}

@media screen and (min-width: 1300px) {
  /* ==========================================================================
  Layout
  ========================================================================== */

  .c-content-area--post {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: calc(980px + (300px + 2%));
    margin-right: auto;
    margin-left: auto;
    padding-right: 10px;
    padding-left: 10px;
  }
  .l-content-area__main--post {
    width: calc(100% - 300px - 20px - 2%);
    margin: 50px 0 0;
  }
  .l-content-area__side--post {
    display: block;
    width: 300px;
    margin-left: 2%;
  }
  .l-single-post .l-content-area__side--post {
    padding: 0 0 20px;
  }
  .p-side__item:not(.p-side__item--tags) {
    width: 100%;
  }
  .p-side__item:not(:first-child) {
    margin-top: 30px;
  }
  .p-side__item--tags {
    margin-top: 0;
    width: 100%;
  }
  .p-side__list--tags {
    padding: 0;
  }
  .p-side__item--tags a {
    width: 100%;
    padding: 10px 15px;
    font-size: 16px;
    line-height: 1.4;
    color: #333;
    text-decoration: none;
    border: none;
  }
  .p-side__item--tags a:hover {
    background: #f2f7f9;
  }
  .p-side__list--tags .p-side__list__item {
    width: 100%;
  }
  .p-side__list--tags .p-side__list__item:not(:last-child) {
    margin: 0;
  }
  .p-side__item--tags a::before {
    width: 0;
    height: 0;
    border: none;
  }

  /* Utility
  ----------------------------------------------------------------- */
}

@media screen and (min-width: 1460px) {
  /* ==========================================================================
  Layout
  ========================================================================== */

  /* ==========================================================================
  Object
  ========================================================================== */

  /* Component
  ----------------------------------------------------------------- */

  /* Project
  ----------------------------------------------------------------- */

  .p-footer-navi {
    margin-top: 50px;
  }
  .p-footer-menu-list {
    margin-left: 60px;
  }
  .p-footer-menu-list__item__link {
    font-size: 18px;
    font-weight: 700;
  }
  .p-footer-submenu-list__item__link {
    font-size: 18px;
  }
  .p-footer-address__item {
    font-size: 18px;
    line-height: 1.4;
  }
  .p-footer-address__item:last-child {
    margin-top: 40px;
  }
  .p-copyright {
    margin-top: 60px;
  }

  .p-philosophy-block__txt h3 {
    font-size: 24px;
  }
  .p-mind-box {
    width: 55%;
  }

  .p-contact__form dt {
    width: 25%;
  }
  .p-contact__form dd {
    width: calc(100% - 25%);
  }



  /* Utility
  ----------------------------------------------------------------- */
}

/*ナビ調整*/

@media screen and (min-width: 1025px) and (max-height: 840px) , screen and (min-width: 1025px) and (max-width: 1370px){
  .l-site__content-contain {
    margin-left: 230px;
    width: calc(100% - 230px);
  }
  .l-site__navi {
    width: 230px;
    padding: 35px 10px 0;
  }

  .p-site-title,
  .p-site-description{
    width: 200px;
  }
  .p-site-title__link__img {
    width: 140px;
  }
  .p-site-menu {
    margin-top: 10px;
    width: 200px;
  }
  .p-site-menu__list__item__link {
    padding: 12px 0;
    font-size: .9em;
  }
  .p-site-menu__list__item:nth-last-child(1),
  .p-site-menu__list__item:nth-last-child(2),
  .p-site-menu__list__item:nth-last-child(3) {
    margin-top: 15px;
  }
  .p-site-menu__list__item:nth-last-child(1),
  .p-site-menu__list__item:nth-last-child(2) {
    margin-top: 10px;
  }
  .p-site-menu__tel {
    margin-top: 25px;
    padding-top: 15px;
    padding-bottom: 0;
  }
  .p-site-menu__tel__text{
    font-size: .9em;
  }
  .c-btn--1--contact-us, .c-btn--1--download, .c-btn--1--faq {
    font-size: .9em;
    padding: 10px 18px;
  }


}

/*検索BOX*/

.searchform {
  position: relative;
  width: 100%;
}
 
.searchfield {
  font-size: 16px;
  width: 100%;
  padding: 10px 35px 10px 10px;
  border: solid 1px #23a5c2;
  background-color: #fff;
}
.searchfield:focus {
  outline: none;
  background-color: #fffcd9;
}
 
.searchsubmit {
  position: absolute;
  top: 0;
  right: 10px;
  margin-top: 10px;
  padding: 0;
  cursor: pointer;
  border: none;
  display: block;
  width: 20px;
  height: 20px;
  background: url(img/ico_search.svg) no-repeat center;
  background-size: contain;
}

.searchform.faq-search {
  margin: 30px auto 20px;
}
.faq-search .searchfield {
  padding: 12px 80px 12px 35px;
  border: solid 2px #0f2f62;
  background: url(img/ico_search_g.svg) no-repeat 10px center;
  background-color: #fff;
  background-size: 20px;
}
.faq-search .searchfield:focus {
  background-color: #fffcd9;
}
.faq-search .searchsubmit {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  padding: 0;
  display: block;
  width: 70px;
  height: 100%;
  background: #0f2f62;
  color: #fff;
  letter-spacing: .3em;
  text-indent: .3em;
  font-family: inherit;
}

.search_val {
  margin: 0 0 15px;
}

@media screen and (min-width: 1025px) {
  .searchform.faq-search {
    width: calc(100% - 8px);
    margin: 50px auto 40px;
  }
  .faq-search .searchfield {
    padding: 12px 110px 12px 35px;
  }
  .faq-search .searchsubmit {
    width: 100px;
    letter-spacing: .5em;
    text-indent: .5em;
    font-size: 18px;
    transition: all .3s;
  }
  .faq-search .searchsubmit:hover {
    background-color: #0A3874;
  }
}
.u-dis-ib {
  display: inline-block;
}

/* ==========================================================================
Test
==========================================================================
.test-sketch--top--mv {
display: block;
width: 100%;
}



/*202103 blog edit*/

.p-blog-headbnr {
  margin: 50px 10px 0 !important;
  /*display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;*/
}
.p-blog-single .p-blog-headbnr {
  margin: -80px 10px 50px !important;
}
.p-blog-headbnr__item {
  /*width: calc((100% - 60px) / 4);*/
  padding: 0 10px;
}
.p-blog-headbnr__item img {
  width: 100%;
  display: block;
}
.p-blog-headbnr__item a {
  background: #fff;
}
.p-blog-headbnr__item a:hover img {
  opacity: .6;
  transition: all .3s;
}
.p-blog-headbnr__item p {
  padding: 5px 10px;
  line-height: 1.4;
  font-size: 14px;
  display: flex;
  align-items: center;
  background: #fff;
}

.p-blog-headbnr .slick-dots,
.p-blog-sidebnr .slick-dots {
  bottom: -30px;
}
.p-blog-headbnr .c-prev-arrow ,
.p-blog-sidebnr .c-prev-arrow ,
.p-blog-headbnr .c-next-arrow ,
.p-blog-sidebnr .c-next-arrow {
  height: 30px;
  width: 30px;
  border: 1px solid #23A5C2;
  border-radius: 100%;
  background-color: rgba(255,255,255,.8);
}

.p-blog-headbnr .c-prev-arrow ,
.p-blog-sidebnr .c-prev-arrow {
  left: -10px;
}
.p-blog-headbnr .c-next-arrow ,
.p-blog-sidebnr .c-next-arrow {
  right: -10px;  
}
@media screen and (max-width: 1299px) {
  .p-blog-headbnr {
    margin: 25px 0 50px !important;
  }
}
@media screen and (max-width: 1023px) {
  .p-blog-single .p-blog-headbnr {
    margin: -20px 0 50px !important;
  }
  .p-blog-headbnr__item {
    padding: 0 5px;
  }
  .p-blog-headbnr__item p {
    font-size: 12px;
  }
}
@media screen and (max-width: 589px) {
  .p-blog-headbnr {
    margin: 25px 0 40px !important;
  }
  .p-blog-single .p-blog-headbnr {
    margin: -20px 0 40px !important;
  }
  .p-blog-headbnr__item {
    padding: 0;
  }
}

.p-blog-sidebnr {
}
.p-blog-sidebnr__item {
  margin: 20px 0 0;
  background: #fff;
}
.p-blog-sidebnr__item img {
  width: 100%;
  display: block;
}
.p-blog-sidebnr__item a:hover img {
  opacity: .6;
  transition: all .3s;
}
.p-blog-sidebnr__item p {
  padding: 8px 10px;
  font-size: 14px;
  border-top: 1px solid #eee;
}
@media screen and (max-width: 1299px) {
  .p-blog-sidebnr .p-side__tit {
    width: 100%;
  }
  .p-side__tit + div {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .p-blog-sidebnr__item {
    width: 49%;
    background: #fff;
  }
}
@media screen and (max-width: 768px) {
  .p-blog-sidebnr {
    display: block;
    margin: 20px 0 0;
  }
  .p-blog-sidebnr__item p {
    background: #fff;
    padding: 8px 10px;
    font-size: 14px;
    border-top: 1px solid #eee;
  }
}
@media screen and (max-width: 589px) {
  .p-side__tit + div {
    display: block;
  }
  .p-blog-sidebnr__item {
    width: 100%;
    margin: 10px 0 0;
  }
}

.p-blog-bottombnr {
  margin: 30px 0 0;
  text-align: center;
}
.p-blog-bottombnr__item {
  background: #fff;
  padding: 20px;
}
.p-blog-bottombnr__item:not(:first-of-type) {
  margin: 15px 0 0;
}
.p-blog-bottombnr__item a:hover {
  opacity: .6;
}
.p-blog-bottombnr__item p {
  text-align: center;
  margin: 10px 0 0;
  font-weight: bold;
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  .p-blog-bottombnr__item {
    padding: 15px;
  }
  .p-blog-bottombnr__item p br {
    display: none;
  }
}

/*blogarchive*/
.p-blog-archive {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-blog-archive .p-archive-block {
  width: 49%;
  margin: 0 0 3%;
}
.p-blog-archive .p-archive-block__link {
  padding: 10px;
  height: 100%;
  display: block;
}
.p-blog-archive .p-archive-block__thumb {
  margin: 0 0 15px;
  width: 100%;
}
.p-blog-archive .p-archive-block__thumb__img {
  width: 100%;
  height: auto;
  padding-top: 62.25%;
}
.p-archive-block__txt {
  width: 100%;
}
.p-blog-archive .p-archive-block__txt__ttl {
  line-height: 1.4;
  font-size: 14px;
  margin: 0 0 10px;
}
.p-blog-archive .p-archive-block__txt__excerpt {
  margin: 0 0 10px;
  font-size: 12px;
  line-height: 1.5;
}
.p-blog-archive .p-archive-block__txt__cat .c-tax-list__item {
  font-size: 11px;
  line-height: 1;
}

@media screen and (min-width: 590px) {
  .p-blog-archive .p-archive-block__link {
    padding: 15px;
  }
  .p-blog-archive .p-archive-block__txt__ttl {
    font-size: 16px;
    margin: 0 0 10px;
  }
  .p-blog-archive .p-archive-block__txt__excerpt {
    margin: 0 0 10px;
    font-size: 14px;
  }
  .p-blog-archive .p-archive-block__txt__cat .c-tax-list__item {
    font-size: 12px;
    line-height: 1;
  }
  
}



.p-archive-tab {
  margin: 50px auto -20px;
  text-align: center;
  z-index: 1;
  position: relative;
}
.p-archive-tab a {
  margin: 5px;
  display: inline-block;
  font-weight: bold;
  text-decoration: none;
  color: #999;
  font-size: 14px;
  background: #fff;
  width: 11em;
  padding: .2em 0;
  border-radius: 3px;
  text-align: center;
}
.p-archive-tab a.active {
  background: #23A5C2;
  color: #fff;
}

@media screen and (max-width: 1299px) {
  .p-archive-tab {
    margin: 40px 0 20px;
  }
}


@media screen and (max-width: 590px) {
  .p-archive-tab {
    margin: 20px 0 20px;
  }
  .p-archive-tab a {
    margin: 2px;
    font-size: 13px;
    width: 5.5em;
  }
  .p-archive-tab span {
    display: none;
  }
}
@media screen and (max-width: 420px) {
  .p-archive-tab {
    display: flex;
    justify-content: space-between;
    margin: 20px 0 -10px;
  }
  .p-archive-tab a {
    margin: 0;
    width: calc((100% - 15px) / 4);
  }
}


/*downloadlist*/
.p-doc-tab {
  margin: -40px auto 40px;
  z-index: 1;
  position: relative;
  text-align: center;
}
.p-doc-tab a {
  margin: 5px;
  display: inline-block;
  font-weight: bold;
  text-decoration: none;
  color: #23A5C2;
  border: 1px solid #23A5C2;
  font-size: 14px;
  background: #fff;
  padding: .2em .5em;
  border-radius: 3px;
  text-align: center;
}
.p-doc-tab a:hover {
  background: #23A5C2;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .p-doc-tab {
    margin: 30px 0;
  }
}


@media screen and (max-width: 590px) {
  .p-doc-tab {
    margin: 20px 0 20px;
  }
  .p-doc-tab a {
    margin: 2px;
    font-size: 12px;
  }
  .p-doc-tab span {
    display: none;
  }
}


.p-doc-title {
  text-align: center;
  font-weight: bold;
  font-size: 22px;
  margin: 20px;
}
.p-doc-title::before {
  content: '◇ ';
}
.p-doc-title::after {
  content: ' ◇';
}
.p-doc-list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 60px;
}
.p-doc-item {
  background: #fff;
  padding: 20px 20px 90px 20px;
  text-decoration: none;
  box-shadow: 0px 5px 15px 0px rgb(14 46 95 / 5%);
  width: 32%;
  margin: 0 0 2%;
  color: #333;
  position: relative;
}
.p-doc-item:nth-of-type(3n - 1) {
  margin: 0 2% 2%;
}
.p-doc-item__thumb {
  overflow: hidden;
  margin: 0 0 10px;
}
.p-doc-item__img {
  background: no-repeat center;
  background-size: contain;
  padding-top: 62.5%;
  transition: all .5s;
}
.p-doc-item:hover .p-doc-item__img {
  transform: scale(1.1,1.1); 
}
.p-doc-item__txt {

}
.p-doc-item__txt__ttl {
  font-size: 18px;
  line-height: 1.4;
  margin: 0 0 10px;
}
.p-doc-item__txt__body {
  font-size: 15px;
  line-height: 1.5;
}
.p-doc-item__btn {
  text-align: center;
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
}
.p-doc-dlbtn {
  border-radius: 30px;
  padding: 15px 20px;
  display: inline-block;
  line-height: 1;
  font-size: 16px;
}
.p-doc-contact p {
  text-align: center;
  margin: 0 0 30px;
}
.p-doc-contact .c-btn--3 {
  max-width: 270px;
  margin: 0 auto;
}
.p-doc-contact .c-btn--3__inner {
  padding: 15px 30px 15px 25px;
}

.p-doc-dl {
  text-align: center;
  margin: 2.5em 0 0;
}
.p-doc-dl .p-doc-dlbtn {
  padding: 20px 40px;
  display: inline-block;
  line-height: 1;
  font-size: 20px;
}


@media screen and (max-width: 767px) {
  .p-doc-list {
    margin: 0 0 40px;
    justify-content: space-between
  }
  .p-doc-item {
    padding: 20px 20px 90px 20px;
    width: 49%;
  }
  .p-doc-item:nth-of-type(3n - 1) {
    margin: 0 0 2%;
  }
  
  .p-doc-dl {
    margin: 2em 0;
  }
  .p-doc-dl .p-doc-dlbtn {
    padding: 15px 30px;
    font-size: 16px;
  }
}

@media screen and (max-width: 480px) {
  .p-doc-title {
    font-size: 18px;
    margin: 30px 0 15px;
    line-height: 1.4;
  }
  .p-doc-list {
    margin: 0 0 30px;
  }
  .p-doc-item {
    padding: 10px 10px 60px 10px;
    width: 100%;
    margin: 0 0 15px !important;
  }
  .p-doc-item__txt__ttl {
    font-size: 16px;
  }
  .p-doc-item__txt__body {
    font-size: 14px;
  }
  .p-doc-item__btn {
    bottom: 15px;
  }
  .p-doc-dlbtn {
    padding: 10px 20px;
    font-size: 14px;
  }
  .p-doc-contact p {
    font-size: 14px;
    text-align: left;
    line-height: 1.6;
    margin: 0 0 15px;
  }
  .p-doc-contact .c-btn--3 {
    max-width: inherit;
    width: 100%;
  }
}

/*partner*/
.p-partner-desc {
  margin: 25px 0;
}
@media screen and (min-width: 1025px) {
  .p-partner-desc {
    margin: 50px 0 -20px;
  }
}

/*p-top--result*/

.p-top--result {
  background: #E6F2FF;
  padding: 40px 0;
}     
.p-top--result__tit {
  text-align: center;
  margin-bottom: 30px;
  padding: 0 15px;
  line-height: 1.4;
  color: #0f2f62;
}
.p-top--result__tit span {
  display: inline-block;
}
.p-top--result a {
  display: flex;
  align-items: center;
  overflow: hidden;
}
.p-top--result__list{
  display: flex;
  animation: loop-slide 50s infinite linear 1s both;
}
.p-top--result__list li{
  width: 210px;
  height: 140px;
  background: #fff;
  margin: 0 8px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-top--result__list li span {
  width: 80%;
  height: 80%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-top--result__list li span img {
  max-width: 100%;
  max-height: 100%;
  display: block;
}

@keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}


@media screen and (min-width: 1025px) {
  .p-top--result + .c-content-block--1 {
    padding-top: 40px;
  }
}
@media screen and (max-width: 1024px) {
  .p-top--result__tit {
    font-size: 18px;
  }
  .p-top--result + .c-content-block--1 {
    padding-top: 30px;
  }
}
@media screen and (max-width: 768px) {
  .p-top--result {
    padding: 20px 0;
  }
  .p-top--result__tit {
    font-size: 16px;
    margin: 0 0 15px;
  }
  .p-top--result__list li{
    width: 120px;
    height: 80px;
    margin: 0 5px;
  }
  .p-top--result + .c-content-block--1 {
    padding-top: 20px;
  }
}
@media screen and (max-width: 480px) {
  .p-top--result__tit {
    font-size: 14px;
  }
}


/*目次調整*/
div#toc_container {
  border-width: 2px !important;
}
#toc_container p.toc_title+ul.toc_list {
  margin-top: 0 !important;
}
ul.toc_list li {
  text-indent: 0;
  margin-bottom: 4px !important;
}
ul.toc_list li::before {
  display: none;
}
.toc_number.toc_depth_1 {
  display: inline-block;
  border: 1px solid #103c74;
 /*  background: #103c74;
  color: #fff; */
  border-radius: 100%;
  line-height: 16px;
  width: 18px;
  text-align: center;
  font-size: 11px;
  position: relative;
  top: -1px;
}
.toc_number.toc_depth_2 {
  font-size: 12px;
}


/*thanks*/
.p-thanks__sns {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 30px;
}
.p-thanks__sns li {
  width: 50px;
  margin: 0 10px;
}
@media screen and (min-width: 768px) {
  .p-thanks__sns {
    margin: 30px 0 0;
  }
  .p-thanks__sns li {
    width: 72px;
    margin: 0 20px;
  }
}
@media screen and (min-width: 1025px) {
  .p-thanks__sns a:hover {
      opacity: .7;
  }
}

/*.p-other-achievement*/
.p-other-achievement {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-other-achievement::after,
.p-other-achievement::before {
  content: '';
  width: 32%;
  order: 1;
}
.p-other-achievement__child {
  width: 32%;
  margin: 0 0 2%;
  border: 1px solid #444;
  background: #fff;
}
.p-other-achievement__tit {
  background: #444;
  color: #fff;
  padding: 5px;
  text-align: center;
}
.p-other-achievement__body {
  padding: 15px;
  display: flex;
}
.p-other-achievement__img {
  width: 100%;
  text-align: center;
  padding: 10px 0 15px;
}
.p-other-achievement__body.has-info {
  flex-wrap: wrap;
}
.p-other-achievement__body.has-info .p-support-strength__info {
  margin-top: 10px;
}
.p-other-achievement__list {
  text-align: center;
}
.p-other-achievement__list:nth-of-type(1) {
  flex: 1;
} 
.p-other-achievement__list:nth-of-type(2) {
  width: 49%;
  margin-left: 1%;
  border-left: 1px solid #444;
  padding-left: 1%;
}
@media screen and (max-width: 768px) {
  .p-other-achievement::after,
  .p-other-achievement::before {
    display: none;
  }
  .p-other-achievement__child {
    width: 100%;
    margin: 0 0 20px;
  }

  .p-other-achievement__body {
    border: 1px solid #444;
  }
}

/*feature_tbl*/
.feature_tbl {
  margin: 30px 0;
}
.feature_tbl_tit {
  text-align: center;
  font-size: 22px;
  font-weight: bold;
  margin: 0 0 20px;
}
.feature_tbl table {
  width: 100%;
  background: #222;
  border: 3px solid #999;
  border-collapse: collapse;
}
.feature_tbl table th,
.feature_tbl table td {
  text-align: center;
  vertical-align: middle;
  color: #fff;
  padding: 15px 10px;
  line-height: 1.4;
  border: 1px solid #999;
}

.feature_tbl table th {
  color: #FFC600;
  font-weight: bold;
}
.feature_tbl table .head {
  width: 45%;
}
@media screen and (max-width: 768px) {
  .feature_tbl {
    margin: 20px 0;
  }
  .feature_tbl_tit {
    font-size: 18px;
    margin: 0 0 10px;
  }
  .feature_tbl table th,
  .feature_tbl table td {
    padding: 10px 5px;
  }
  .feature_tbl table th {
    font-size: 14px;
  }
  .feature_tbl table .head {
    width: 45%;
    font-size: 14px;
  }
}

/*p-diversity*/
.p-diversity-block {
  display: grid;
  grid-template-columns: 48% 50%;
  place-content: space-between;
  gap: 21px 0;
  background: #fff;
  padding: 25px;
  margin: 20px 0 0;
}
.p-diversity-block:first-of-type {
  margin-top: 30px;
}
.p-diversity-block:nth-of-type(even) {
  grid-template-columns: 50% 48%;
}
.p-diversity-block.p-diversity-block--col1 {
  grid-template-columns: minmax(0, 1fr);
}
.p-diversity-block__title {
  font-weight: bold;
  line-height: 1.4;
  grid-area: 1/1/2/3;
  width: fit-content;
  position: relative;
}
.p-diversity-block__title::before {
  content: "";
  display: inline-block;
  background: #23a6c4;
  position: absolute;
  left: 0;
  bottom: -15px;
  height: 1px;
  width: 100%;
}
.p-diversity-block:not(.p-diversity-block.p-diversity-block--col1) .p-diversity-block__title {
  order: 1;
}
.p-diversity-block.p-diversity-block--col1 .p-diversity-block__title {
  grid-area: unset;
}
.p-diversity-block__img {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-diversity-block:nth-of-type(even):not(.p-diversity-block.p-diversity-block--col1) .p-diversity-block__img {
  order: 1;
}

.p-diversity-item + .p-diversity-item {
  margin: 21px 0 0;
}
.p-diversity-item__title {
  font-size: 20px;
  font-weight: bold;
  border-bottom: 1px solid #000;
  margin: 0 0 15px;
}
.p-diversity-item__imgs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(0, 105px));
  gap: 3%;
  margin: 0 0 21px;
}
.p-diversity-item__imgs li img {
  width: 100%;
}
.p-diversity-message {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 21px 0 0;
}
.p-diversity-message__img {
  width: 200px;
  flex-shrink: 0;
  margin: 0 21px 0 0;
}
@media screen and (max-width: 1024px) {
  .p-diversity-item__imgs {
    grid-template-columns: repeat(auto-fill, minmax(0, 100px));
  }
}
@media screen and (max-width: 768px) {
  .p-diversity-block {
    grid-template-columns: minmax(0, 1fr);
    padding: 20px;
    margin: 15px 0 0;
  }
  .p-diversity-block:nth-of-type(even) {
    grid-template-columns: minmax(0, 1fr);
  }
  .p-diversity-block:first-of-type {
    margin-top: 20px;
  }
  .p-diversity-block__title {
    grid-area: unset;
    margin: 0 auto;
  }
  .p-diversity-block__title::before {
    bottom: -5px;
  }
  .p-diversity-block:not(.p-diversity-block.p-diversity-block--col1) .p-diversity-block__title {
    order: unset;
  }
  .p-diversity-block:nth-of-type(even):not(.p-diversity-block.p-diversity-block--col1) .p-diversity-block__img {
    order: unset;
  }
  .p-diversity-item__title {
    font-size: 18px;
  }
  .p-diversity-item__imgs {
    grid-template-columns: repeat(auto-fill, minmax(0, 90px));
  }
  .p-diversity-message {
    flex-direction: column;
  }
  .p-diversity-message__img {
    margin: 0 0 21px;
  }
  @media screen and (max-width: 480px) {
    .p-diversity-item__imgs {
      place-content: center;
      grid-template-columns: repeat(2, minmax(0, 110px));
      gap: 20px;
    }
  }
  @media screen and (max-width: 375px) {
    .p-diversity-item__imgs {
      grid-template-columns: minmax(0, 110px);
    }
  }
}

/*p-sim-group*/
.p-sim-group .p-company-group__img {
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.p-sim-group .p-company-group__img + h3 {
  text-align: center;
  border-bottom: 1px solid #ccc;
  margin: 5px 0 8px;
  padding-bottom: 10px;
  width: 100%;
}
.p-sim-group .p-support-strength__info {
  background: #fff0bc;
}
.p-sim-group .p-company-group__txt {
  text-align: left;
}


/*linguise button*/
@media screen and (min-width: 1025px) {
  #linguise_floating_wrapper .linguise_switcher {
    bottom: inherit !important;
    left: inherit !important;
    top: 10px;
    right: 10px;
  }
}

/*日本語ページでは、英・中非表示*/
#lang-ja .c-en,
#lang-ja .c-zh {display:none;}

/*英語ページでは、日・中非表示*/
#lang-en .c-ja,
#lang-en .c-zh {display:none;}

/*中国語ページでは、日・英非表示*/
#lang-zh .c-ja,
#lang-zh .c-en {display:none;}
