@charset "UTF-8";
/* -------- 下層・トップビジュアル ---------*/
@media screen and (max-width: 960px) {
  .pageHead {
    display: flex;
    flex-direction: column-reverse;
  }
  .pageHead__ttlWrapper {
    display: block;
    width: 100%;
    height: auto;
    padding: 26px 24px 24px;
  }
  .pageHead__ttl {
    text-align: left;
  }
  .pageHead__mainTtl {
    font-size: 1.625em;
    margin-bottom: 8px;
  }
  .pageHead__subTtl {
    font-size: 1.125em;
  }
  .pageHead__imgWrapper {
    height: 300px;
  }
}
/* -------- 下層・パンくずリスト ---------*/
@media screen and (max-width: 960px) {
  .crumbs {
    margin-bottom: 48px;
  }
}
/* -------- 下層・カテゴリー用グリッドタブパーツ ---------*/
@media screen and (max-width: 960px) {
  .gridTab {
    grid-template-columns: calc(50% - 4px) calc(50% - 4px);
    gap: 8px 8px;
    margin-bottom: 40px;
  }
  .gridTab__item:first-child {
    grid-column-start: 1;
    grid-column-end: 3;
  }
}
/* -------- 下層・見出しパーツ ---------*/
@media screen and (max-width: 960px) {
  .lineHeadingLv2 {
    font-size: 1.75em;
    margin-bottom: 32px;
  }
  .lineHeadingLv2::before {
    width: 25px;
    height: 10px;
  }
}
/* -------- 下層・シェアボタンリスト ---------*/
@media screen and (max-width: 960px) {
  .shareList {
    margin-bottom: 30px;
  }
  .shareList__link {
    width: 35px;
    height: 35px;
    justify-content: center;
    border-radius: 8px;
  }
  .shareList__link span {
    display: none;
  }
  .shareList__link.shareList__link--Line {
    padding: 0;
  }
  .shareList__link.shareList__link--Line img {
    width: 35px;
  }
  .shareList__link.shareList__link--Twitter {
    padding: 0;
  }
  .shareList__link.shareList__link--Twitter img {
    width: 20px;
  }
  .shareList__link.shareList__link--Facebook {
    padding: 0;
    border-radius: 50%;
  }
  .shareList__link.shareList__link--Facebook img {
    width: 35px;
  }
  
  .dateList {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-center;
    -moz-column-gap: 5px;
    column-gap: 5px;
    margin-bottom: 10px;
    font-size: 0.6em;
  }
}
/* -------- 下層・カテゴリー付き投稿パーツ ---------*/
@media screen and (max-width: 960px) {
  .vertPosts {
    row-gap: 20px;
  }
  .vertPosts__header {
    -moz-column-gap: 20px;
    column-gap: 20px;
    margin-bottom: 20px;
    flex-wrap: wrap;
  }
  .vertPosts__labels {
    margin-bottom: 10px;
  }
  .vertPosts__date {
	display: block;
    width: 100%;
    margin-bottom: 10px;
  }
}
/* -------- 下層・ページネーション ---------*/
@media screen and (max-width: 960px) {
  .pagination {
    margin: 72px auto 80px;
  }
  .pagination .page:nth-of-type(n+6) {
    display: none;
  }
}
/* -------- 下層・投稿ページパーツ群 ---------*/
@media screen and (max-width: 960px) {
  .pagePost section {
    margin-bottom: 60px;
  }
  .pagePost h1 {
    font-size: 2em;
  }
  .pagePost h2 {
    font-size: 1.75em;
    margin-bottom: 27px;
  }
  .pagePost h2::before {
    width: 28px;
    height: 8px;
    margin-right: 16px;
  }
  .pagePost h3 {
    font-size: 1.4375em;
  }
  .pagePost h4 {
    font-size: 1.25em;
  }
  
  .pagePost p img {
    display: block;
    float: none !important;
    margin: 10px auto;
  }
  
  .pagePost ul.shareList {
    margin-bottom: 30px;
  }
  .pagePost ol.pagePost__outLine {
    padding: 32px;
    margin-bottom: 64px;
  }
  .pagePost ol.pagePost__outLine > li:not(:last-child) {
    margin-bottom: 16px;
  }
  .pagePost ol.pagePost__outLine > li:first-child {
    font-size: 1.25em;
    margin-bottom: 20px;
  }
  .pagePost ol.pagePost__outLine > li:not(:first-child) {
    padding-left: 25px;
  }
  .pagePost ol.pagePost__outLine > li a {
    font-size: 1em;
  }
  .pagePost dl > div {
    flex-direction: column;
  }
  .pagePost dl > div:not(:last-child) {
    margin-bottom: 0px;
  }
  .pagePost dl > div > dt {
    width: 100%;
  }
  .pagePost dl > div > dd {
    width: 100%;
    padding: 24px 20px;
  }
  .pagePost .tbl_wrap {
    width: 100%;
    overflow: auto;
    white-space: nowrap;
    margin-bottom: 80px;
  }
  .pagePost table {
    width: 850px;
    margin-bottom: 0;
  }
  .pagePost__media {
    flex-direction: column;
  }
  .pagePost__mediaThumb {
    width: 100%;
  }
  .pagePost__media.pagePost__media--reverse {
    flex-direction: column;
  }
  .pagePost__col2Image {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  }
  .pagePost__col3Image {
    margin-bottom: 80px;
  }
  .pagePost__supportTag {
    padding: 24px 20px 20px;
    width: 90%;
  }
  .pagePost__supportTag > span {
    text-align: left;
  }
  .pagePost__supportTagTtl {
    margin-bottom: 16px;
    font-size: 2.4em;
  }
  .pagePost .categories h2 {
    font-size: 1.4375em;
  }
  .pagePost .categories .nodes ul {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
  .pagePost .contact {
    margin-bottom: 120px;
    padding: 0;
  }
  .pagePost .contact h2 {
    font-size: 1.4375em;
  }
  .pagePost .contact .group {
    font-size: 1.125em;
  }
  .pagePost .contact .tel, .pagePost .contact .fax {
    display: inline-block;
  }
  .pagePost .contact .tel {
    margin-bottom: 8px;
    margin-right: 12px;
  }
  .pagePost .contact .fax {
    margin-left: 0;
  }
}
/* -------- 下層・サムネイル付スワイパー ---------*/
@media screen and (max-width: 960px) {
  .underSwiper {
    max-height: 650px;
    min-height: 260px;
  }
  .underSwiper__thumb {
    grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
    gap: 16px;
  }
}
/* -------- 下層・アコーディオン ---------*/
@media screen and (max-width: 960px) {
  .accordion__btn {
    font-size: 1.375em;
    padding: 20px 0 20px 20px;
  }
  .accordion__btnIcon {
    width: 45px;
    height: 45px;
    right: 25px;
    border: 3px solid #fff;
  }
  .accordion__btnIcon::before, .accordion__btnIcon::after {
    width: 22px;
    height: 4px;
    right: 9px;
  }
  .accordion__panel {
    padding: 30px 0 30px 15px;
  }
  .accordion__list {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: 15px;
    column-gap: 15px;
  }
  .accordion__ttl {
    font-size: 1em;
  }
}

/* -------- 下層・アコーディオン ---------*/
@media screen and (max-width: 768px) {
  .pagePost__video,
  .pagePost__video iframe{
    max-width: 100% !important;
  }
  
  
}