@charset "utf-8";
/*
Theme Name: Lightning Child
Template: lightning
Author:アートフレア株式会社
Version: 1.2
*/
/* 標準データ最終更新日：2025/04/14  */
/*
 * WEBフォントの読み込み（@import url('https://fonts～'); ）はHeader.phpで行う
*/
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  General　全体的な設定
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* :root設定、bodyへの上書き、カラー変数設定など */ :root {
  --vk-color-text-link-hover: #004dff;
  --vk-line-height: 2em;
  --vk-color-text-body: #111111;
}
body, html, h1, h2, h3, h4, h5, h6, .page-header-title {
  font-family: YakuHanJP, 'Barlow', "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif !important;
  letter-spacing: 0.05em;
  font-feature-settings: 'palt';
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Common 汎用パーツ系
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 繰り返しボタン・見出し、余白設計など 汎用パーツへの上書き */
/*見出し > サブテキスト逆順*/
.is-style-af-heading-reverse .vk_heading_subtext {
  line-height: 1.2em;
  margin-bottom: 0 !important;
  font-weight: 600;
  text-transform: uppercase;
}
.vk_heading_subtext{
  text-transform: uppercase;
  font-weight: 600;
}
/*見出し > 中央下線*/
.title-underline-center {
  position: relative;
  padding-bottom: .5em;
}
.title-underline-center::before {
  content: "";
  display: inline-block;
  width: 80px;
  height: 3px;
  background-color: var(--vk-color-primary);
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 0;
}
/*見出し > 左に線*/
.title-bar-left {
  border-left: 5px solid var(--vk-color-primary);
  padding-left: 10px;
  line-height: 1em;
}
/*両サイドに斜線*/
.slash-decor {
  position: relative;
  padding: 0 2em;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.slash-decor::before,
.slash-decor::after {
  content: "／";
  position: absolute;
  top: 0;
}
.slash-decor::before {
  content: "＼";
  left: 0;
}
.slash-decor::after {
  right: 0;
}
/*ボタン*/
.btn {
  border-radius: 0 !important;
  padding: .6em 4em .6em 1em !important;
}
.vk_button .is-style-outline {
  border-width: 2px !important;
  font-weight: 500;
}
/*ボタン・ホバーの動き*/
.vk_button .btn {
  transition: .3s;
  position: relative;
  z-index: 0;
}
.vk_button .btn a:hover {
  box-shadow: none;
}
.vk_button .btn::before {
  content: '';
  position: absolute;
  bottom: 46%;
  right: 1em;
  width: 40px;
  height: 2px;
  background: currentColor;
  transition: all .3s;
}
.vk_button .btn::after {
  content: '';
  position: absolute;
  bottom: 52%;
  right: 1em;
  width: 8px;
  height: 2px;
  background: currentColor;
  transform: rotate(40deg);
  transition: all .3s;
}
.vk_button .has-white-color::before, .vk_button .has-white-color::after {
  background: #fff !important;
}
.vk_button .btn:hover::before {
  right: .6em;
  background: #fff;
}
.vk_button .btn:hover::after {
  right: .6em;
  background: #fff;
}
.vk_button .btn.has-background:hover {
  background-color: var(--vk-color-primary) !important;
  border-color: var(--vk-color-primary) !important;
}
.vk_button-color-custom a:hover {
  box-shadow: none !important;
  background-color: var(--vk-color-primary) !important;
  border-color: var(--vk-color-primary) !important;
}
.vk_button .has-text-color.is-style-outline:hover.has-white-color {
  background-color: var(--vk-color-custom-2) !important;
}
.vk_button .has-text-color.is-style-outline:hover.has-white-color .vk_button_link_before, .vk_button .has-text-color.is-style-outline:hover.has-white-color .vk_button_link_txt {
  color: #fff !important;
}
.vk_button .has-text-color.vk_button_link-type-text:hover .vk_button_link_txt {
  text-decoration-style: solid !important;
}
/*ボタンホバー透過を消す*/
.vk_button-color-custom a:hover, .editor-styles-wrapper .vk_button-color-custom a:hover {
  opacity: 1 !important;
}
/*アイコン付与ボタン*/
.btn-has-icon .btn {
  padding: .6em 1em .6em 1em !important;
}
.btn-has-icon .btn::before, .btn-has-icon .btn::after {
  display: none;
}
/*画像ホバーズームイン*/
figure.hover-move, .hover-move figure, .wp-block-cover.hover-move {
  overflow: visible;
}
.hover-move:hover img {
  transform: scale(1.1);
  transition: transform .6s;
}
.hover-move img {
  transition: transform .6s;
}
/* リンクエリア拡大 */
.stretched-linkitem {
  position: relative !important;
}
.stretched-linkitem a::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: rgba(0, 0, 0, 0);
}
.stretched-linkitem h2, h3, h4, h5, h6 {
  position: unset !important;
}
.stretched-linkitem a {
  text-decoration: none;
  color: #111;
}
.stretched-linkitem img {
  transition: transform .3s;
}
.stretched-linkitem:hover img {
  transform: scale(1.1);
  transition: transform .3s;
}
.stretched-linkitem a:hover {
  color: var(--vk-color-primary);
}
/*テーブルのフォントサイズリセット*/ :where(:not(.wp-block-table)) > table :is(th, td) {
  font-size: unset !important;
}
/*余白調整*/
.gap-none {
  gap: 0;
}
.gap-4em {
  gap: 4em;
}
.gap-3em {
  gap: 3em;
}
.gap-2em {
  gap: 2em;
}
.gap-1em {
  gap: 1em;
}
.padding-none {
  padding: 0 !important;
}
/* Mediaとテキスト */
.wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__content {
  padding-right: 0;
}
.wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
  padding-left: 0;
}
@media (max-width: 768px) {
  .wp-block-media-text .wp-block-media-text__content {
    padding: 0;
    margin-top: 1em;
  }
}
/*横幅コンテンツに応じて中央揃え*/
.fit-content {
  width: fit-content;
  margin-inline: auto;
}
/*画像白反転*/
.img-white img {
  filter: contrast(0) brightness(3);
}
/*区切り線の太さ*/
.wp-block-separator {
  border-top: 1px solid;
}
/*グリッドカード > 見出し*/
.vk_gridcolcard .wp-block-heading {
  margin-left: 0;
  margin-right: 0;
}
/*PCでは非表示*/
.pc-hidden{
	display: none;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Header ヘッダーまわり
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ヘッダー固定 */
body {
  overflow-x: unset !important;
  display: flex;
  flex-direction: column;
}
.device-pc #site-header {
  position: sticky;
  top: 0;
}
.logged-in.device-pc #site-header {
  top: 32px;
}
/*ヘッダー*/
#site-header-container {
  width: 100%;
  max-width: 100%;
  padding: 0 !important;
}
.site-header {
  background-color: var(--vk-color-primary);
}
#site-header-container .site-header-logo {
  background-color: #fff;
  padding: 0.8em 1em !important;
}
/*ヘッダーお問い合わせボタン*/
.header_nav_search_container {
  position: unset;
  min-width: 200px;
  margin-left: 0;
}
.head-contact {
  position: absolute;
  right: 0;
  top: 0;
}
.head-contact .btn {
  padding: 2em 1em !important;
}
.head-contact .btn::before, .head-contact .btn:after {
  display: none;
}
.head-contact .btn.has-background:hover {
  background-color: var(--vk-color-custom-2) !important;
}
.head-contact .btn .vk_button_link_caption {
  display: flex !important;
  justify-content: center;
  flex-wrap: wrap;
}
.head-contact .btn .vk_button_link_caption i {
  width: 100%;
  margin: 0;
}
/* グローバルナビ */
.global-nav-list > li > a {
  transition: .3s;
  border-bottom: 3px solid transparent;
  color: #fff;
}
.global-nav-list > li .global-nav-name {
  font-size: 1rem !important;
}
.global-nav-list > li > a:hover, .global-nav-list > li.current-menu-item > a {
  color: #ddd;
  border-bottom: 3px solid #ddd;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Footer フッターまわり
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* フッターウィジェット、フッターロゴ、コピーライト */
.tel a {
  text-decoration: none;
}
.foot-sitemap {
  margin: 0;
  padding: 0;
  color: #fff;
}
.foot-sitemap p {
  font-size: .9rem;
  line-height: 2em;
  margin: 0;
}
.foot-sitemap ul {
  margin: 0 !important;
  padding: 0 !important;
}
.foot-sitemap li {
  display: flex;
  align-items: center;
  list-style: none;
  font-size: .8rem;
  line-height: 1.4em;
  margin: 5px 0 !important;
  gap: 0.5em;
}
.foot-sitemap li::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 1px;
  background-color: currentColor;
}
.foot-sitemap a {
  text-decoration: none !important;
  color: #fff;
}
.foot-sitemap a:hover {
  text-decoration: underline !important;
  color: #fff;
}
/*コピーライトを消す*/
.site-footer-copyright {
  display: none;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Toppage トップページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パーツごとにコメントアウトで注釈を入れてください。 */
/*FV*/
.fv {
  position: relative;
  z-index: 0;
}
.fv::after {
  content: "";
  display: inline-block;
  width: 50%;
  height: 100%;
  position: absolute;
  right: 0;
  bottom: 160px;
  background-color: var(--vk-color-primary);
  z-index: -1;
}
/*スクロールアニメーション*/
.scroll {
  display: inline-block;
  padding: 0 0 55px 0;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  z-index: 1;
  margin: 0;
  position: relative;
  font-weight: 700;
}
.scroll::before {
  animation: scroll-act 1.5s cubic-bezier(.77, 0, .175, 1) .3s both infinite;
  background-color: #111;
  content: "";
  display: inline-block;
  margin: auto;
  position: absolute;
  bottom: 0;
  left: 15px;
  width: 2px;
  height: 50px;
}
.scroll-text {
  display: inline-block;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-lr;
  font-size: 0.8em;
  position: absolute;
  bottom: 64px;
  left: 54px;
  font-weight: normal;
  transform: rotate(180deg);
  color: #fff;
  z-index: 1;
}
@-webkit-keyframes scroll-act {
  0% {
    transform: scaleY(0);
    transform-origin: top center
  }
  50% {
    transform: scaleY(1);
    transform-origin: top center
  }
  51% {
    transform: scaleY(1);
    transform-origin: bottom center
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom center
  }
}
@keyframes scroll-act {
  0% {
    transform: scaleY(0);
    transform-origin: top center
  }
  50% {
    transform: scaleY(1);
    transform-origin: top center
  }
  51% {
    transform: scaleY(1);
    transform-origin: bottom center
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom center
  }
}
/*TOP > 背景テキスト*/
.hidden-text {
  font-size: 10rem;
  font-weight: 700;
  position: absolute;
  top: -.4em;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: -1;
}
/*TOP > 事業内容*/
.top-service::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 40%;
  background-color: var(--vk-color-primary);
  position: absolute;
  left: 0;
  top: 0;
}
.top-service .vk_button .is-style-outline {
  background: none !important;
  border-color: #fff;
  color: #fff !important;
}
.top-service .vk_button .is-style-outline:hover {
  background-color: var(--vk-color-custom-2) !important;
}
/*重ねるレイアウト*/
.top-service .wp-block-columns {
  position: relative;
}
.top-service .content-item h2, .top-service .content-item p {
  color: #fff;
}
.over-item {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 50%;
}
/*はみ出すスライダー*/
.work-slider {
  width: calc((100% + (100vw - 100%) / 2) - 10px);
}
.vk_slider_item-paddingLR-use {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 0 !important;
}
.swiper-pagination-bullet {
  width: 10px !important;
  height: 10px !important;
  border-radius: 50px !important;
}
.vk_slider .swiper-button-next, .vk_slider .swiper-button-prev {
  background-color: #111 !important;
  border-radius: 50px !important;
}
.vk_slider .swiper-button-next {
  left: 63% !important;
}
.swiper-button-next::after, .swiper-button-prev::after {
  color: #fff !important;
  font-size: .8rem !important;
}
/*施工事例カテゴリーリスト*/
.work-list{
  padding-left: 24px !important;
}
.work-list li{
  margin: 0 0 5px 0 !important;
  padding: 0 !important;
  font-size: .9rem;
}
.work-list li a{
  color: #111;
  text-decoration: none;
}
/*グリッドカラムカード リンク装飾*/
.grid-link-item .wp-block-cover {
  padding: 2em;
}
.grid-link-item .vk_heading_title {
  position: relative;
  padding-right: 40px;
  width: fit-content;
  margin: 0;
}
.grid-link-item .vk_heading_title::before {
  content: '';
  position: absolute;
  bottom: 42%;
  right: 1px;
  width: 30px;
  height: 2px;
  background: #fff;
  transition: all .3s;
}
.grid-link-item .vk_heading_title::after {
  content: '';
  position: absolute;
  bottom: 52%;
  right: 0;
  width: 8px;
  height: 2px;
  background: #fff;
  transform: rotate(40deg);
  transition: all .3s;
}
.grid-link-item .vk_gridcolcard_item:hover .vk_heading_title::before, .grid-link-item .vk_gridcolcard_item:hover .vk_heading_title::after {
  right: -.5em;
  transition: all .3s;
}
/*CTA*/
.cta-item {
  gap: 0 !important;
}
.cta-item .wp-block-column {
  padding-left: 2.5em;
  padding-right: 2.5em;
  border-right: 2px solid #fff;
}
.cta-item .wp-block-column:last-child {
  border-right: medium none;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Pageheader, Breadcrumb 下層ページヘッダー・パンくずリスト
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 下層ページのページヘッダー、パンクズ設定 */
.page-header .page-header-inner {
  max-width: 100%;
  position: unset;
  margin: 0 auto;
  padding: 0 3em !important;
}
.page-header .page-header-inner .page-header-subtext {
  font-size: 6rem;
  margin: 0 auto;
  font-weight: 600;
  color: var(--vk-color-primary);
  letter-spacing: 0;
  position: absolute;
  left: .5em;
  top: 50%;
  transform: translateY(-50%);
  bottom: 0;
  text-transform: uppercase;
  opacity: .1;
}
.page-header .page-header-inner .page-header-title {
  font-size: 2.4rem;
}
.breadcrumb .container {
  max-width: 100%;
  padding: 1em 0 1em 4.8em;
  border-bottom: 1px solid #eee;
  border-top: 1px solid #eee;
  margin-bottom: 0;
}
.breadcrumb-list {
  margin: 0;
  padding: 15px 0 !important;
}
.breadcrumb-list a {
  color: var(--vk-color-primary);
  text-decoration: none;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Page 下層ページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ページごと、パーツごとにコメントアウトで注釈を入れてください。 */
/* 会社概要　＞　テーブル */
.profile-table table {
  border: medium none !important;
  border-collapse: collapse;
  border-bottom: 1px solid #ccc !important;
}
.profile-table th {
  border-top: 1px solid var(--vk-color-primary);
  border-left: medium none !important;
  border-right: medium none !important;
  border-bottom: medium none !important;
  padding: 2em 0 !important;
  vertical-align: top !important;
}
.profile-table td {
  border-top: 1px solid #ccc;
  border-left: medium none !important;
  border-right: medium none !important;
  border-bottom: medium none !important;
  padding: 2em !important;
}
/*会社概要 > 沿革*/
.vk_timeline .vk_timeline_item_caption {
  margin-bottom: 0.5em !important;
  color: #999 !important;
  font-size: 1.4rem !important;
  line-height: 1em;
}
/* タイムライン2カラム */
.timeline-2column {
  --time-width: 300px;
}
.timeline-2column.vk_timeline .vk_timeline_item {
  padding-left: calc(var(--time-width) + 40px);
}
.timeline-2column.vk_timeline .vk_timeline_item_lineStyle-default::before {
  left: var(--time-width);
  top: 20px;
  height: 100%;
}
.timeline-2column.vk_timeline .vk_timeline_item_style {
  left: calc(var(--time-width) - 5px);
  top: 12px;
}
.timeline-2column.vk_timeline .vk_timeline_item_caption {
  position: absolute;
  left: 0;
  top: 5px;
  width: calc(var(--time-width) - 20px);
  text-align: left;
}
/*納入実績 > カテゴリーリスト*/
.tag-list {
  margin: 1em 0;
  padding: 1em;
  display: flex;
  gap: 20px 0;
  justify-content: center;
  flex-wrap: wrap;
  background-color: var(--vk-color-custom-4);
}
.tag-list li {
  list-style: none;
  padding: 0 1em;
  margin: 0;
  line-height: 1em;
  position: relative;
}
.tag-list li::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 100%;
  background-color: #ccc;
  position: absolute;
  right: 0;
  top: 0;
}
.tag-list li:last-child::after {
  display: none;
}
.tag-list li a {
  text-decoration: none;
  color: var(--vk-color-primary);
  transition: color 0.6s;
}
.tag-list li a::after {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f13a";
  margin-left: 5px;
  display: inline-block;
  transition: transform 0.6s;
}
.tag-list li a:hover::after {
  transform: scale(1.2);
}
/*施工事例 > テーブル*/
.product-table {}
.product-table th {
  border: 1px solid #ddd;
  padding: 1em !important;
  background-color: #f9f9f9;
  vertical-align: top !important;
}
.product-table td {
  border: 1px solid #ddd;
  padding: 1em !important;
}
/* スクロール固定Column */
.position-sticky-wrap {
  overflow: visible !important;
}
.device-pc .wp-block-column.position-sticky-column {
  position: sticky;
  top: 130px;
  align-self: flex-start;
}
.side-title{
  font-size: 1.2rem;
  padding: .8em 1em;
  margin: 0;
  background-color: var(--vk-color-custom-3);
  border-radius: 10px 10px 0 0;
  text-align: center;
}
ul.side-menu{
  margin: 0 0 30px 0;
  padding: 0 .5em .5em .5em;
  background-color: var(--vk-color-custom-3);
  border-radius: 0 0 10px 10px;
}
ul.side-menu li{
  list-style: none;
  transition: transform 0.6s ease;
  color: #333;
  padding: 0;
  margin: 0 0 5px 0;
  background-color: #fff;
}
ul.side-menu li a{
  color: #333;
  text-decoration: none;
  padding:.5em 0 .5em 1.8em;
  display: block;
  position: relative;
}
ul.side-menu li a::before{
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f105";
  position: absolute;
  left:10px;
  top: 50%;
  transform: translateY(-50%);
  color: #ccc;
}
ul.side-menu li a:hover{
  color: var(--vk-color-primary);
  transition: transform 0.6s ease;
}
ul.side-menu li a:hover::before{
  color: var(--vk-color-primary);
}
/*おすすめ*/
.osusume .title {
  display: flex;
  justify-content: center;
  align-items: center;
}
/*よくあるご質問*/
.is-style-vk_faq-bgfill-circle .vk_faq_title::before, .is-style-vk_faq-bgfill-square .vk_faq_title::before, .is-style-vk_faq-bgfill-rounded .vk_faq_title::before {
  background-color: var(--vk-color-custom-1) !important;
}
.is-style-vk_faq-bgfill-circle .vk_faq_content::before, .is-style-vk_faq-bgfill-square .vk_faq_content::before, .is-style-vk_faq-bgfill-rounded .vk_faq_content::before {
   background-color: var(--vk-color-primary) !important;
}
/*お問い合わせ*/
.scroll-box {
  padding: 0 2em;
  height: 300px;
  overflow: auto;
  text-align: left;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Archive　ブログ一覧ページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パーツごとにコメントアウトで注釈を入れてください。 */
/*アーカイブ > テキスト一行*/
.postListText_singleTermLabel {
  min-width: 100px !important;
}
.postListText_singleTermLabel_inner {
  border-radius: 0 !important;
}
/*投稿リスト > 枠あり*/
.card {
  border-radius: 0 !important;
}
.card-body {
  padding: 1rem 0 0 0 !important;
}
.vk_post {
  margin-left: 10px !important;
  margin-right: 10px !important;
  padding: 1rem 15px !important;
}
.vk_posts .vk_post-col-xl-4 {
    width: calc(33.3% - 20px);
  }
.vk_post.card {
  padding: 0;
  margin-bottom: 20px;
}
/*投稿サイドメニュー*/
.sub-section .sub-section-title, .site-body-bottom .sub-section-title {
  color: #fff !important;
  background-color: var(--vk-color-custom-2) !important;
  padding: .5em !important;
}
.veu_postList .postList_title {
  font-size: .9rem;
}
.sub-section .widget_archive > ul li a, .sub-section .widget_nav_menu > ul li a {
  border: none;
  padding: 1em 0;
  color: unset;
}
.sub-section .widget_archive > ul li:not(:last-child), .sub-section .widget_nav_menu > ul li:not(:last-child) {
  border-bottom: 1px solid var(--vk-color-border-hr);
}
.localNavi {
  border-bottom: 1px solid var(--vk-color-border-hr);
}
.localNavi > li {
  position: relative;
  padding-left: 25px;
}
.localNavi li::before {
  position: absolute;
  content: '\f0da';
  font-family: 'Font Awesome 5 Free';
  font-weight: 600;
  padding-right: .2em;
  left: 10px;
  top: 18px;
  font-size: .9rem;
  color: #999;
}
.localNavi li:hover {
  background-color: #f5f5f5;
}
.sub-section .widget_archive > ul li a:hover, .sub-section .widget_nav_menu > ul li a:hover {
  text-decoration: underline;
  background: none;
}
.sub-section .widget_nav_menu ul.children {
  border-top: 1px solid var(--vk-color-border-hr);
}
.sub-section .widget_nav_menu ul.children a {
  padding-left: 1em;
}
.sub-section ul li.current-cat a {
  background-color: transparent !important;
}
.entry-header .entry-title, .archive-header-title {
  margin-bottom: var(--vk-margin-meta);
  font-size: 1.6rem;
  position: relative;
  z-index: 0;
  padding: .8em 0;
}
.entry-header .entry-title::before, .archive-header-title::before {
  content: "";
  display: inline-block;
  width: 30px;
  height: 5px;
  position: absolute;
  left: 0;
  top: 0;
  background-color: var(--vk-color-primary);
}
.entry-header .entry-title::after, .archive-header-title::after {
  content: "";
  display: inline-block;
  width: 30px;
  height: 5px;
  position: absolute;
  left: 30px;
  top: 0;
  background-color: var(--vk-color-custom-1);
}
.entry-meta-data-list {
  display: none;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Single　ブログ詳細ページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パーツごとにコメントアウトで注釈を入れてください。 */
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  その他・追加機能
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パーツごとにコメントアウトで注釈を入れてください。 */


/* Professional */
/* カード本体 */
.card_wrap {
	min-height: 100px;
    aspect-ratio: 2 / 3;
	position: relative;
	cursor: pointer;
	perspective: 1200px;
	    margin: 2rem 0;
}
.card_wrap .vk_slider_item_container.container {
    display: contents;
}
.card_wrap .vk_slider_item-background-area {
    display: none;
    pointer-events: none;
}
/* 擬似要素とpadding-topでカードの高さを指定 */
.card_wrap::before {
  content: "";
  display: block;
/*   padding-top: 200%; */
	aspect-ratio: 2 / 3;
}
/* カード内の画像 */
.card_wrap img {
  width: 100%;
	padding-inline: 1rem;
}
/* カード共通スタイル */
.card_wrap .card_back,
.card_wrap .card_front {
	min-height: 100px;
  transition: all 0.9s;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  backface-visibility: hidden;
	aspect-ratio: 2 / 3;
	overflow: hidden;
}
/* ウラ面のスタイル */
.card_wrap .card_back {
  transform: rotateY(-180deg);
}
/* ホバー時のオモテ面 */
.card_wrap:hover .card_front {
  transform: rotateY(180deg);
}
/* ホバー時のウラ面 */
.card_wrap:hover .card_back {
  transform: rotateY(0);
}

/* オモテ面 */
card_front .wp-block-group__inner-container {
    position: relative;
}
.card_front_profile {
    background: var(--vk-color-custom-2);
/*     background: red; */
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 1rem;
}
p.card_subject {
    margin-bottom: .5em;
}
p.card_name {
    font-size: 1.25rem;
    display: inline;
}
p.card_en {
    display: inline;
    margin-inline-start: 1.5em;
}

/* ウラ面 */
.card_back .wp-block-group__inner-container {
    position: relative;
}
.card_back figure.wp-block-image {
    margin:0;
}
.card_wrap .card_back img {
    aspect-ratio: 2 / 3;
    object-fit: cover;
}
.card_back p {
    position: absolute;
    bottom: 0px;
    margin: 0 1rem;
    padding: 4rem 1rem 1rem;
    background: linear-gradient(0deg, rgb(0 0 0 / 80%), transparent);
	font-size:0.875rem;
}

