.text-center {
    text-align: center;
}
#toc_container.no_bullets {
  margin: 0 auto;
  display: block;
  width: fit-content;
}
/* 全体的なスタイル */
body {
    font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
  margin: 0;
  padding: 0;
}
#headerIn{
  display: flex;
  align-items: center;
      width: auto;
    justify-content: center;
    gap: 0;
}
h3{
  text-align: left;
}
aside{
  width: 35%;
}
#mobileHeader{
  padding: 12px 0 9px;
}
.p-post__header #headerIn{

}
.p-post__header #gNav{
  padding-top: 0;
  max-width: 78rem;
  width: 100%;
}
figure.wp-block-image{
  margin-block: 20px 25px;
}
/* single.php のメインコンテンツ */
.single-content {
  width: 80%;
  margin: 20px auto;
}
h1#titleLogo{
        height: 56px;
}
#titleLogo img{
    height: 45px;
}
.p-post__header h1#titleLogo{
    top:0;
}
.p-post__header h1#titleLogo a{
    display: inline-block;
    width: 100%;
    height: auto;
}
/* タイトル */
.single-title {
  font-size: 2em;
  margin-bottom: 10px;
}

/* 本文 */
.single-post {
  line-height: 1.6;
}

/* メタ情報 */
.single-meta {
  font-size: 0.8em;
  color: #777;
  margin-bottom: 20px;
}
.p-article_flex{
    margin-top:40px;
}
.single_page .column-btn{
      margin: 30px 0;
}
.single_page .btn{
      display: inline-block;
      position: relative;
    display: inline-block;
    transition: all 0.3s 
ease;
    white-space: wrap;
}
.single_page .btn-view {
width: 100%;
    max-width: 30rem;
    padding: 24px 24px 24px;
    margin-inline: auto;
    border-radius: 100px;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 120%;
    border: 2px solid transparent;
    letter-spacing: 1.6px;
    transition: 0.5s 
ease;
    position: relative;
    overflow: hidden;
}
.single_page .btn-view::before {
    content: "";
    position: absolute;
    opacity: 1;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    transition: 0.5s 
ease;
    z-index: 1;
}
.single_page .btn-view-strong span,
.single_page .btn-view-strong a {
    color: var(--color-natural-white, #FFF);
        position: relative;
    z-index: 1;
}

.single_page .btn-view span {
    font-size: 20px;
    font-weight: 700;
    transition: 0.5s 
ease;
    line-height: 120%;
    letter-spacing: 1.6px;
    text-shadow: 0px 2px 0px rgba(0, 0, 0, 0.25);
    position: relative;
    z-index: 1;
}
.single_page .btn-view-strong::before {
background: var(--gradation-primary, linear-gradient(282deg, #14b6ea 20.82%, #0f91be 106.08%));
}

.single_page a.btn:hover {
    color: #3ba9b8a8;
}
.single_page .btn-view-strong:hover {
    border: 2px solid var(--gradation-primary, #14b6ea);
    background: linear-gradient(0deg, #E5D6FF 0%, #E5D6FF 100%), linear-gradient(126deg, #FEFEFE 20.82%, #E5D6FF 104.08%);
}
.single_page .btn-view:hover::before {
    opacity: 0;
}
.single_page .btn-view-strong:hover span {
    background: var(--gradation-primary, linear-gradient(126deg, #14b6ea 20.82%, #0f91be 104.08%));
    text-shadow: none;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
/*H2見出し*/
main h2.wp-block-heading:not(:has(img)) {
    color: #fff;/*文字色（白）*/
    font-size: 23px;/*文字サイズ*/
    padding: 14px 20px;/*文字回りの余白（上下左右）*/
    display: block;
    position: relative;
    margin-block: 15px;
        border-left: solid 6px #00abe3;
}
main h2.wp-block-heading:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #007ba5;/*背景色*/
    z-index: -1;
    
}
/* main h2.wp-block-heading:after {
    content: '';
    position: absolute;
    border-left: 15px double #fff;/*左線（太さ 二重線 色）
    height: 100%;
    top: 0;
    right: 20px;
} 
/*
/*H3見出し*/
main h3.wp-block-heading:not(:has(img)) {
    color: #616371;/*文字色*/
    font-size: 20px;/*文字サイズ*/
    padding: 10px 20px;/*文字回りの余白（上下 左右）*/
    display: block;
    border-left: 6px solid #007ba5;/*二重線左側（太さ 実線 色）*/
    position: relative;
    margin-block: 17px;
}
main h3.wp-block-heading:before {
    content: "";
    display: block;
    position: absolute;
    left: 3px;
    top: 0;
    width: 2px;/*二重線右側の太さ（幅）*/
    height: 100%;
    background: #12B5EA;/*二重線右側の色*/
}
/*H4見出し*/
main h4.wp-block-heading {
    color: #616371;/*文字色*/
    font-size: 1.85rem;/*文字サイズ*/
    display: block;
    position: relative;
    padding: 6px 0;/*文字回りの余白（上下 左右）*/
    margin-block: 1.45rem;
    font-weight: 600;
    border-bottom: 2px solid #00abe3;
}
main h5.wp-block-heading {
    color: #616371;/*文字色*/
    font-size: 1.6rem;/*文字サイズ*/
    display: block;
    position: relative;
    padding: 6px 32px;/*文字回りの余白（上下 左右）*/
    margin-block: 1.3rem;
        font-weight: 600;
}

main h6.wp-block-heading {
    font-size: 1.4rem;/*文字サイズ*/
    margin-block: 1rem;
    font-weight: 600;
}
main h5.wp-block-heading:before {
    font-family: FontAwesome;
    font-weight: 900;/*矢印部の太さ*/
    font-size: 25px;/*矢印部のサイズ*/
    color: #007ba5;/*矢印部の色（青）*/
    left: 0;
    top: 0;
    content:"\f0a9";
    position: absolute;
}
article.article-content {
max-width: 70rem;
    margin-inline: 0;
    display: block;
    margin-block: 4rem;
    width: 65%;
}
article + aside{
      margin-block: 6rem;
}

@media screen and (max-width: 767px) {
    aside{
        width: calc(100% - 0rem);
        margin-inline: auto;
        max-width: 100%;
    }
      article + aside{
        margin-bottom: 0;
      }
    article + aside,.sidebar-related-posts{
        margin-top: 0;
    }
    .p-article_flex{
 flex-direction: column;
}
article.article-content{
        display: block;
    margin-block: 6rem 0rem;
    width: calc(100% - 0rem);
    margin-inline: auto;
}
main h2.wp-block-heading:not(:has(img)){
        font-size: 21px;
        padding: 9px 16px;
    margin-block: 13px;
}
main h3.wp-block-heading:not(:has(img)){
         font-size: 19px;
    border-left: 4px solid #007ba5;
    padding: 2px 15px;
    margin-block: 14px;
}
main h4.wp-block-heading:not(:has(img)){
         font-size: 16px;
             padding: 0px 0;
                 margin-block: 1.25rem;

}main h5.wp-block-heading:not(:has(img)){
         font-size: 14.5px;
}
main h6.wp-block-heading:not(:has(img)){
         font-size: 13px;
}
p {
        font-size: 1.2rem;
    margin-bottom: 13px;
}
li,strong,a{
  font-size: 1.22rem;;
}
  #mobileHeader{
        padding: 10px 0 9px;
  }
}

/* collumn Quicktag------------------------------------*/



.single_page .under-yellow {
  background: linear-gradient(transparent 70%, rgba(255,240,0, .45) 70%);
  font-weight: bold;
}


.single_page .font-red {
    color: #EF454A;
}

.single_page .under-red {
    background: linear-gradient(transparent 70%, #e98698 70%);
    font-weight: bold;
}

.single_page .marker-yellow {
    background: #fffab5;
    font-weight: bold;
}

.single_page blockquote {
    position: relative;
    margin: 16px auto;
    padding: 40px 10px 10px 10px;
    box-sizing: border-box;
    background: #efefef;
    color: #555;
}

.single_page .p-column__single blockquote  p{
    background: #efefef !important;
	font-style: italic;
}

blockquote:before{
    display: inline-block;
    position: absolute;
    top: 5px;
    left: 3px;
    content: "“";
    font-family: sans-serif;
    color: #00b1ee;
    font-size: 90px;
    line-height: 1;
}

.single_page .point_box {
    padding: 20px 25px;
    border: 1px solid #00b1ee;
    position: relative;
    margin: 50px 0 20px;
    border-radius: 0 5px 5px 5px;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
}

.single_page .point_box:before {
    content: "Point";
    letter-spacing: 2px;
    position: absolute;
    top: -2.5em;
    left: -1px;
    background: #00b1ee;
    padding: 0px 14px;
    color: #ffffff;
    font-weight: bold;
    font-size: 12px;
    line-height: 2.5;
    border-radius: 5px 5px 0 0;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
}

.single_page .detail_box {
    padding: 20px 25px;
    border: 1px solid #00b1ee;
    position: relative;
    margin: 20px 0;
    border-radius: 5px;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
}

.single_page .free-box {
    padding: 20px 25px;
    border: 1px solid #00b1ee;
    position: relative;
    margin: 50px 0 20px;
    border-radius: 5px;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
}

.single_page .free-box p{
	margin-bottom: 0.1em;
}

.single_page .free-box-title {
    letter-spacing: 2px;
    position: absolute;
    top: -2.5em;
    left: -1px;
    background: #00b1ee;
    padding: 0px 14px;
    color: #ffffff;
    font-weight: bold;
    font-size: 12px;
    line-height: 2.5;
    border-radius: 5px 5px 0 0;
    background-clip: padding-box;
    -webkit-background-clip: padding-box;
}

.single_page .memo-box {
    margin: 32px 0;
    background-color: #f5f5f5;
    padding: 16px;
}

.single_page .memo-box-title {
    font-size: 18px;
    font-weight: bold;
    color: #00b1ee;
}

.single_page .memo-box p {
    background-color:#f5f5f5 !important;
}

.wysiwyg tbody tr>*:first-child, .wysiwyg tbody tr th {
    background: #ededed;
    padding: 5px 0;
    text-align: left;
    border: solid 3px #ffffff;
    padding: 14px;
}

.wysiwyg tbody tr>*:first-child, .wysiwyg tbody tr th {
    background: #00b1ee;
    padding: 5px 0;
    text-align: left;
    border: solid 3px #ffffff;
    padding: 14px;
    color: #fff;
}

.single_page code.file-name-bg {
    background: #000000;
    border-radius: 3px;
    padding: 10px 10px 10px;
    white-space: pre-wrap;
    word-wrap: break-word;
    font-size: 17px;
    color: #ffffff;
}

.single_page .badge-black div {
    display: inline-block;
    margin-right: 5px;
    margin-bottom: 8px;
    font-size: 14px;
    color: #fff;
    padding: 2px 14px;
    border-radius: 15px;
    text-align: center;
    background: #00b1ee;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.single_page .blog-card {
    border: 1px solid  #00b1ee;
    word-wrap: break-word;
    max-width: 100%;
    border-radius: 3px;
    margin: 40px auto;
    box-shadow: 4px 4px 0px #c8c8c8;
    transition: 0.1s ease;
    position: relative;
}

.single_page .blog-card a {
    width: 100%;
    color: #333;
    background: #fff;
    display: inline-block;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    text-decoration: none;
    font-weight: bold;
    border-radius: 0px;
    padding: 8px;
}

.single_page .blog-card-label {
    display: inline !important;
    margin-left: .5em;
    position: absolute;
    top: -18px;
    font-size: 14px;
    padding: 3px .6em;
    background-color: #00b1ee;
    color: #fff;
    border-radius: 3px;
    letter-spacing: .7px;
    display: none;
}

.single_page .blog-card-title::before {
    content: '続きを読む';
    font-size: 0.7em;
    font-weight: bold;
    color: #fff;
    background: #00b1ee;
    display: inline-block;
    position: absolute;
    text-align: center;
    margin-right: 1em;
    border-radius: 4px;
    bottom: 10px;
    right: 0px;
    padding: 4px 8px;
}

.single_page article.article-content{
  padding-top: 0;
}

.article-cat{
font-size: 1.1rem;
    background: #12B5EA;
    color: #fff !important;
    padding: 3px 5px;
    display: block;
    max-width: fit-content;
border:1.5px solid #12B5EA
}

.article-cat:hover{
    background: transparent;
}
.article-cat a{
        color: #fff !important;
        transition:.3s;
}
.article-cat:hover a{
     color: #000!important;;
}
.article-date{
    font-size: 1.3rem;
    color: #13b5ea;
}
.article-head .article-info{
    font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;

}
.article-head .article-info:has(.article-date){
  margin-bottom: 2.2rem;
  padding-bottom: 1.2rem;
    font-size: 1.6rem;
}

.article-head .article-info + h1{
    font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
  margin-bottom: 2.4rem;
  margin-top: 2.4rem;
      font-size: 22px;
      font-weight: 600;
}
@media screen and (max-width: 767px) {
  .article-head .article-info + h1{
    font-size: 3.2rem;
      margin-bottom: 2.6rem;
  }
.article-cat{
  margin-bottom: 0rem;
}
.article-date{
    font-size: 1.7rem;
    color: #13b5ea;
}
.article-head .article-info{
  font-size: 1.6rem;
}
.article-head .article-info:has(.article-date){
 border-bottom: .7px solid #b1acac;
}
}

.archive_article {
    max-width: 117rem;
        padding-left: 1.5rem;
    padding-right: 1.5rem;
  margin-inline:auto;
  margin-block: 8.125rem 3.525rem;
}
@media screen and (max-width: 767px) {
.archive_article {
      margin-block: 3.5rem 3.525rem;
}
}
.archive_article-items{
  display: grid;
  flex-wrap: wrap;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 1.6rem;
}
.archive-post__thumb{
  width: 100%;
  display: block;
}
.archive-post__thumb img{
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  display: block;
  height: auto;
  border-radius: 10px 0 0 10px;
}
.archive_article-item{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  flex-direction: column;
  justify-content: flex-start;
  border: 1px solid #007ba5;
  width: 100%;
  border-radius: 4px;
      overflow: hidden;
    background: var(--color-natural-white, #FFF);
    box-shadow: 0px 8px 16px 4px rgba(87, 140, 156, 0.24);
}

.archive-post__excerpt,.archive-post__excerpt p {
  color: #000;
}
.archive_article-contents{
  padding: 2rem 0.875rem 1.25rem;
}
.archive_article-date{
  display: inline-block;
      margin-top: 1rem;
    color: #858585;
        font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
 .single .archive_article-date{
  margin-top: 0;
}
}

.archive_article-title{
  margin-left: 0;
  margin-left: 0;
  padding: 5px 0 3px 0;
  text-align: left;
  /* border-bottom: 1px solid #eee; */
  margin-bottom: 7px;
  text-align: left;
  color: #1d224b;
  font-weight: 700;
  font-size: 1.7rem;
  transition: .3s;
  font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
.archive_article-title a{
    color: #333;
}
.archive_article-title{
  color: #1d224b;
}
.archive_article-title:hover{
  color: #1d224b;
  transition: .3s;
  transform: scale(1.01);
}
aside .archive_article-title{
  font-size: 1.35rem;
}
aside .archive_article-item{
  border: .3px solid #000;
}
/******************************************************
* header css
******************************************************/
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 53px 45px 52px;
}
.l-posts__header{
padding: 0px 45px 0px;
    margin-top: 0;
}
.l-posts__header + main.category_page{
      margin-top: 10.4rem;
}
@media screen and (max-width: 767px) {
  .l-posts__header{
    padding-block: 5px;
  }
.l-posts__header + main.category_page{
    margin-top: 7.5rem;
}
}
.header__wrap {
  display: flex;
  justify-content: space-between;
}

.logo-wrap img {
  display: inline-block;
}

.logo-group {
  width: 174px;
}

.logo-vietnam {
  width: 127px;
  padding-left: 10px;
}

.header__nav {
  padding-right: 50px;
  max-width: 65%;
  width: 100%;
}
.header__nav__list{
  display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
}
.header__nav__list li {
  display: inline-block;
}

/* .header__nav__list li:nth-child(2) {
  margin-left: 34px;
}

.header__nav__list li:nth-child(3) {
  margin-left: 39px;
}

.header__nav__list li:nth-child(4) {
  margin-left: 42px;
} */

.header__nav__list__link a {
  color: #fff;
  font-size: 25px;
  font-weight: 400;
  letter-spacing: 0.02em;
}
.p-404__inner{
  max-width: 67.5rem;
 display: flex;
  justify-content: center;
  align-items: center;
  flex-direction:column;
  margin-inline: auto;
  margin-block: 6.25rem;;
}
.p-404__inner h1{
  font-size: 5rem;
  margin-bottom: .625rem;
}
.p-404__inner div{
  font-size: 1.5rem;
  font-weight: 600;
}
.p-404__inner a{
  text-decoration: underline;
}
.article-img img{
      border-radius: 10px;
-o-object-fit: contain;
   object-fit: contain;
height: auto;
-o-object-position: center;
   object-position: center;
width: 100%;
display: block;
}

.article-head .article-img img{
  margin-bottom: 2rem;
}
aside .sidebar-related-posts{
  max-width: 62.5rem;
  margin-inline: auto;
  display: block;
  width: 100%;
  margin-block: 3rem;
}
aside .sidebar-related-posts h3{
background: #12B5EA;
color: #fff;
padding: 15px 18px;
font-size: 1.5rem;
margin-bottom: 1.6rem;
}
@media screen and (max-width: 767px) {
aside .sidebar-related-posts h3{
    font-size: 2.3rem;
  }
}
aside .archive_article-item + .archive_article-item{
  margin-top: 1.1rem;
}
/******************************************************
* main css
******************************************************/
main {
  margin-top: 142px;
}

.kv-wrap {
  position: relative;;
}

.kv-pc {
  width: 100vw;
  aspect-ratio: 1920 / 1018;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
     height: auto;
}
.kv-sp {
    width: 100vw;
  aspect-ratio: 767/ 1364;
    -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
     height: auto;
}
.kv-copy-wrap {
  position: absolute;
  /* top: 100px;
  left: 60px; */
  top: 5vw;
  left: 3vw;
  color: #fff;
}

.kv-copy {
  font-size: 60px;
  font-weight: 300;
  letter-spacing: 0.02em;
  line-height: 70px;
}

.kv-message {
  margin-top: 10px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 32px;
}

.section-wrap {
  margin-top: 96px;
  padding-bottom: 96px;
}

.section-title-wrap {
  margin-left: 54px;
}

.section-title-wrap h2 {
  display: inline-block;
  font-size: 45px;
  font-weight: 400;
  line-height: 59.77px;
  letter-spacing: 0.02em;
}

.section-title-wrap#sns h2 {
  font-size: 45px;
  font-weight: 400;
  line-height: 59.77px;
  letter-spacing: 0.05em;
}

.section-title-wrap p {
  display: inline-block;
  margin-left: 20px;
  font-size: 25px;
  font-weight: 600;
  line-height: 37.5px;
}

.section-contents-wrap {
  padding: 0 64px;
}

#service .section-contents-wrap {
  margin-top: 64px;
  padding: 0 12px;
}


/** service */
.service-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
  gap: 76px 13px;
}

.service-list__item {
  background: #E6E6E6;
  box-shadow: 0px 4px 8px 0px #00000040;
}

.service-list__img {
  padding: 32px 20px;
  background-color: #fff;
}

.service-list__img img {
  margin: 0 auto;
  width: auto;
  height: 200px;
}

.service-list__value {
  padding: 32px 24px 40px;
}

.service-list__title {
  font-size: 20px;
  font-weight: 700;
  line-height: 25px;
  text-align: left;
}

.service-list__description {
  margin-top: 16px;
  font-size: 20px;
  font-weight: 400;
  line-height: 25px;
  text-align: left;
}


/** company */
#company .section-contents-wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 100px;
  margin-top: 60px;
}

.information-img {
  margin-top: 80px;
  width: 400px;
}

.information-record {
  padding: 30px 15px 24px 24px;
  display: flex;
  justify-content: stretch;
  border-bottom: 1px solid #3F3D56;
}

.information-record:last-child {
  border-bottom: none;
}

.information-record__item {
  display: inline-block;
  color: #626262;
  min-width: 174px;
  font-size: 25px;
  font-weight: 700;
  line-height: 31.25px;
  text-align: left;  
}

.information-record__value {
  position: relative;
  display: inline-block;
  font-size: 25px;
  font-weight: 700;
  line-height: 31.25px;
  letter-spacing: 0.03em;
  text-align: left;
}

.information-record__value a {
  color: #000;
}

.information-record__value a::after {
  content: "";
  position: absolute;
  top: -10px;
  right: -34px;
  width: 20px;
  height: 20px;
  background-image: url('../images/external-icon.png');
}


/** Contact */
#contact .section-contents-wrap {
  margin: 0 auto;
  margin-top: 32px;
}


/** sns */
#sns .section-contents-wrap {
  margin: 0 auto;
  margin-top: 64px;
  width: 928px;
  height: 468px;
}



.line_contact-btn {
  position: fixed;
  /* bottom: 50px;
  right: 110px; */
  bottom: 4vw;
  right: 8vw;
}
.line_contact-btn.is-unmeved {
  position: absolute;
}

.line_contact-img {
  width: 230px;
}



/******************************************************
* footer css
******************************************************/
footer {
  padding: 0;
}
.footer__nav__list{
  display: flex;
  justify-content: flex-start;
  gap: 1.875rem;
}
.footer__nav__list li {
  display: inline-block;
}

/* .footer__nav__list li:nth-child(2) {
  margin-left: 32px;
}

.footer__nav__list li:nth-child(3) {
  margin-left: 31px;
}

.footer__nav__list li:nth-child(4) {
  margin-left: 43px;
} */

.footer__nav__list__link a {
  color: #fff;
  font-size: 25px;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.footer__sns__list li {
  display: inline-block;
  margin-top: 86px;
}

.footer__sns__list li:nth-child(1) {
  width: 59px;
}

.footer__sns__list li:nth-child(2) {
  width: 134px;
  margin-left: 20px;
}

.footer__sns__list li:nth-child(3) {
  width: 40px;
  margin-left: 39px;
}

.footer__sns__list li:nth-child(4) {
  width: 51px;
  margin-left: 39px;
}

.footer__sns__list li:nth-child(5) {
  width: 50px;
  margin-left: 28px;
}

.footer-logo-wrap {
  margin-top: 227px;
  text-align: right;
}

.footer-logo-wrap img {
  display: inline-block;
}

.footer-logo-group {
  width: 276px;
}

.footer-logo-vietnam {
  width: 200px;
  padding-left: 18px;
}

.p-article_flex{
  display: flex;
      gap: 3.5rem;
      justify-content: space-evenly;
      margin-bottom: 5rem;
          max-width: 100%;
    margin-inline: auto;
 
}
.single_page .p-article_flex{
   padding-left: 1.5rem;
    padding-right: 1.5rem;
}
@media screen and (max-width: 767px) {
.single_page .p-article_flex{
margin-top: 3rem;
}
}
.p-archive_article_flex{
	      flex-direction: column;

}
.sidebar-column-archive li a{
  display: inline-flex;
      align-items: center;
      font-size: 1rem;
      color: #000;
}
aside .sidebar-column-archive h3{
      font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
  background: #12B5EA;
  color: #fff;
     padding: 10px 14px;
    font-size: 1.8rem;

  margin-bottom: .4rem;
}
.sidebar-column-archive li .date-badge{
  background: #12B5EA;
  color: #fff;
    padding: .4rem .25rem;
    font-size: 1.4rem;
  margin-right: .4rem;
  margin-bottom: .5rem;
}
aside .sidebar-column-archive li{
  padding-block: 10px;

}
.sidebar-archive_thumbnail img{
	-o-object-fit:cover;
	   object-fit:cover;
	    aspect-ratio: 5 / 3;
    height: auto;
    object-fit: cover;
    max-width: 100%;
}
aside .sidebar-column-archive li + li{
      border-top: 1px solid #eee;
      padding-top: 2.5rem;
}
aside .sidebar-column-archive li a{
    align-items: flex-start;
    font-size: 1.9rem;
    color: #000;
    flex-direction: column;
    justify-content: flex-start;
    text-align: left;
        font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
@media screen and (max-width: 767px) {
  aside .sidebar-column-archive li + li{
    padding-top: 2rem;
  }
  .sidebar-column-archive li .date-badge{
      font-size: 1.1rem;
  }
aside .sidebar-column-archive li a{
    font-size: 1.5rem;
}
}
.sidebar-column-archive{
  margin-top:1.8rem;
}

/* pagenavi */

.wp-pagenavi {
	margin: 6rem auto 4rem;
	font-size: 14px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #333;
}
.wp-pagenavi span{
font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
.wp-pagenavi a {
    color: #333;
    font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;

}
.wp-pagenavi a:hover {
	color: #77a0d1;
}
.wp-pagenavi span.pages{
   border: none;
   display: none;
}
.wp-pagenavi span.current,
.wp-pagenavi a.page {
	margin: 0 16px;
	line-height: 2;
	padding: 0 12px;
	transition: .03s;
	display: block;
  font-size: 20px;
      border: none;
	border-bottom: 4px solid transparent;
}
.wp-pagenavi span.current {
	border:none;
  font-weight: 700;
  color: #fff;
background: linear-gradient(311deg, #2b3c4c 22.94%, #77a0d1 82.51%);
  border-radius: 50%;
  width: 5rem;
  height: auto;
  aspect-ratio: 1  / 1;
  display: inline-flex;
  justify-content: center;
  align-items:center;
  
}
.wp-pagenavi a.page {
	background: none;
}
.wp-pagenavi a.page:hover {
	border-bottom: 4px solid #77a0d1;
}
.wp-pagenavi .first,
.wp-pagenavi .extend {
	margin-right: 15px;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	border: none;
    font-size: 25px;
    padding-block: 0;
    transform: translateY(-4px);
}
.wp-pagenavi .previouspostslink{
  margin-right: 16px;
}
.wp-pagenavi .nextpostslink{
  margin-left: 16px;
}
#toc_container {
      font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
    background: #f9f9f9;
    border: 1px solid #aaa;
    padding: 10px;
    margin-bottom: 1em;
    width: auto;
    display: table;
    font-size: 95%;
}
/* ボタン位置調整 */
#toc_container .toc_title {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.2rem;
}

#toc_container.no_bullets {
        width: 100%!important;
    margin: 0 auto 4rem;
    display: block;
    width: fit-content;
}
.toc-toggle {
  cursor: pointer;
  font-size: 0.9em;
  color: #12B5EA;
  margin-left: 1em;
  cursor: pointer;
  transition: .1s;
    margin-left: 1em;
  display: inline-block;
  transition: color 0.3s ease;
  position: relative;
}
.toc-toggle:hover{
  color:   #0d00a0;
}
#toc_container a{
  color: #000747;
  text-decoration: none!important;
    position: relative;
  display: inline-block;
  font-weight: 600;
  text-decoration: none; /* デフォルトの下線は消す */
    padding-bottom: 2px;   /* 下線との余白 */
}
#toc_container a:hover{
  color: #0d00a0;
}
.wp-block-buttons{
  margin-bottom: 10px;;
}
.wp-block-buttons .wp-block-button__link{
  background: #12B5EA;
  transition: .3s;;
  border: 1px solid #12B5EA;
  font-weight: 600;
}
.wp-block-buttons .wp-block-button__link:hover{
  background: transparent;
    transition: .3s;;
    border-color:#0d00a0 ;
    color:#0d00a0;
}

/* 疑似要素で下線を用意 */
#toc_container a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.5px; /* 線の太さ */
  background-color: #0d00a0;
  transform: scaleX(0);          /* 初期状態は幅ゼロ */
  transform-origin: right center;/* 右端から変化する */
  transition: transform 0.5s ease;
}

#toc_container a:hover::after {
  transform: scaleX(1);          /* フル幅に */
  transform-origin: left center; /* 左方向に伸びる */
}
.toc-toggle::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 100%;
  background-color: #3305c5;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.toc_list ul li + li{
  margin-top:.5rem;
}
.toc-toggle:hover::after {
  transform: scaleX(1);
}
#toc_container{
  background: #fbfbfb;
  border:.6px solid #aaa;
}
#toc_container li,#toc_container ul {
    margin: 0;
    padding: 0
}

#toc_container {
    background: #f9f9f9;
    border: 1px solid #aaa;
    padding: 10px;
    margin-bottom: 1em;
    width: auto;
    display: table;
    font-size: 95%
}
@media screen and (max-width: 767px) {
#toc_container {
    padding: 1rem 1.2rem 1rem 1.2rem;
}
#toc_container a{
  font-size: 1.3rem;;
}
#toc_container .toc_list a{
      font-size: 1.15rem;
      padding: 0;
}
}
#toc_container.toc_light_blue {
    background: #edf6ff
}

#toc_container.toc_white {
    background: #fff
}

#toc_container.toc_black {
    background: #000
}

#toc_container.toc_transparent {
    background: none transparent
}

#toc_container p.toc_title {
    text-align: center;
    font-weight: 700;
    margin: 0;
    padding: 0
}

#toc_container.toc_black p.toc_title {
    color: #aaa
}

#toc_container span.toc_toggle {
    font-weight: 400;
    font-size: 90%
}

#toc_container p.toc_title+ul.toc_list {
    margin-top: 1em
}

.toc_wrap_left {
    float: left;
    margin-right: 10px
}

.toc_wrap_right {
    float: right;
    margin-left: 10px
}

#toc_container a {
    text-decoration: none;
    text-shadow: none
}

#toc_container a:hover {
    text-decoration: underline
}

.toc_sitemap_posts_letter {
    font-size: 1.5em;
    font-style: italic
}

#toc_container.no_bullets li,#toc_container.no_bullets ul,#toc_container.no_bullets ul li,.toc_widget_list.no_bullets,.toc_widget_list.no_bullets li {
    background: 0 0;
    list-style-type: none;
    list-style: none
}

#toc_container.have_bullets li {
    padding-left: 12px
}

#toc_container ul ul {
    margin-left: 1.5em
}
#toc_container .toc_list ul Li {
    margin-block: 0rem !important;
}
.p-article_banners{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  max-width: 1140px;
   margin-inline: auto;

}
@media screen and (max-width:768px){
  #toc_container .toc_list ul li{
line-height: 1.7;
  }
  #toc_container .toc_title{
    font-size: 1.6rem;
  }
  #toc_container p.toc_title+ul.toc_list{
        margin-top: .3rem;
  }
.archive_article-items{
      gap: 1.6rem;
          grid-template-columns: 1fr ;
}
.archive_article-contents {
    padding: 1rem 2rem;
}
.p-article_banners{
flex-direction: column;
}
.archive_article-columns {
    margin-top: .3rem;
}
.archive_article-title{
  font-size: 1.6rem;
  margin-bottom: 0;
}
.archive_article-date {
    padding:  0rem;
    font-size: 1.4rem;
}
.column-tax-list .column-tax-item{
      padding: 0rem .5rem;
    font-size: 1rem;
}

}
.p-article_banner{
   width: 100%;
}
.p-single_article_banners{
	flex-direction: column;
}
/* Sponsor Slider */
section#sponsor{
  margin-top: 36px;
  padding-bottom: 15px;
}

.sponsor-slider {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 50px 0 0;
}

.sponsor-track {
  display: flex;
  align-items: center;
  /* 中身に応じた幅にしておく */
  width: max-content;
  animation: scroll 25s linear infinite;
}

.sponsor-item {
  flex: 0 0 auto;
    width: 200px;
    margin: 0 18px;

}
.sponser-item_link{
  position: relative;
}
.sponser-item_link:hover{
      opacity: 0.9;
    filter: brightness(1.2);
}
.sponsor-item img {
    transition: .3s;
  width: 100%;
  height: auto;
  object-fit: contain;
  max-height: 100px;
  object-position: center;
}
.sponser-item_link:hover img{
  transition: .3s;
  transform: scale(1.1);
}
/* アニメーション */
@keyframes scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
table {
 border-collapse: collapse; /*隣接する枠線を重ねて表示*/
 border-spacing: 0; /*枠線を間隔をなしに*/
 width: 100%;
 text-align: center;
}
table th {
  padding: 10px;
 background: #c8ced5;
 border: solid 1px #778ca3;
}
table td {
 border: solid 1px #666666;
 padding: 10px;
 border: solid 1px #778ca3;
}
#footerIn,#footerContactIn{
    max-width: 100%;
}
.p-archive_article_flex .archive-title{
      padding: 1.65rem 0 2.25rem;
      font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
@media screen and (max-width: 767px) {
.p-archive_article_flex .archive-title{
padding: 3.8rem 0 4rem;
}
}

.single_page h1 span,.p-archive_article_flex .archive-title span{
      border-bottom: 1px solid #fff;
}
.archive-title{
    font-size: 2.7rem;
    font-weight: 600;
     padding: 1.65rem 0 2.25rem;
    background-color: #13b5ea;
    text-align: center; display: flex;
    justify-content: center;
    align-items: center;;
    color: #fff;;

}
.column-tax-list{
  display: flex;
  flex-wrap: wrap;
  gap: 3px 5px;;
}
.column-tax-list .column-tax-item{
    background: #007ba5;
    border: 1.5px solid #007ba5;
    display: inline-block;
    padding: 1px 7px;
        transition: .3s;
        line-height: 1.75;
}
.column-tax-list .column-tax-item:hover{
    transition: .3s;;
       background: transparent;
}
.column-tax-list .column-tax-item a{
     color: #fff;
         transition: .3s;
 font-weight: 600;
     font-size: 1.35rem;
     font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
.column-tax-list .column-tax-item:hover a{
      color: #007ba5;
         transition: .3s;;
         
}
.archive_article-columns{
  margin-top:.7rem;;
  font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}
.column-tax-list > a{
  display: none;
}
.header__container__contacts{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}
.header__container__contact{
  background: #212548;
  border-top: 1px solid #fff;;
  border-bottom: 1px solid #fff;;
  width: calc(50% - .5px);
}
@media screen and (max-width: 767px) {
 .header__container__contacts{
flex-direction: column;
}
.header__container__contact{
  width: 100%;
}
}
@media screen and (min-width: 768px) {
.header__contact_tel{
  border-left: 1px solid #fff;;
}

}

.header__container__contact img{
-o-object-fit: contain;
   object-fit: contain;
-o-object-position: center;
   object-position: center;
width: 32px;
height: auto;
aspect-ratio: 1 / 1;
margin-right: 7px;
}
main.category_page{
    margin-top:10rem;
}
main.single_page{
  margin-top: 9.2rem;
}



.p-404{
  padding-block: 10rem;
}
.p-404__wrapper{
  margin-inline: auto;
  max-width: 768px;
  width: 100%;
}
.p-404__wrapper h2{
      font-size: 6rem;
      font-weight: 600;
      text-align: center;
}
.p-404__wrapper .p-404__attention{
     font-size: 3.6rem;
      font-weight: 600;
      text-align: center;
}
.p-404__wrapper a{
    color: #000;
    font-size: 3rem;
    text-align: center;
    margin-top: 2.2rem;
    display: inline-block;
    margin-inline: auto;
    width: 100%;
}
.p-404__wrapper a span{
  transition: .3s;
  display: inline-block;
}
.p-404__wrapper a:hover span{
  transform: translateX(.4em);
  transition: .3s;
    display: inline-block;
}
@media screen and (max-width: 767px) {
.single_page article.article-content{
  padding-bottom: 0;
}
}
#gNav{
      font-family: Avenir, "ヒラギノ角ゴシック", 'Hiragino Sans', "Hiragino Kaku Gothic Pro W3", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}@media screen and (max-width:768px){
  main.single_page {
    margin-top: 7.3rem;
}

