@charset "utf-8";
/*
Theme Name: Lightning Child
Theme URI:
Template: lightning
Description:
Author:アートフレア株式会社
Tags: 
Version: 1.1
*/
/* 標準データ最終更新日：2024/11/22  */
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  general　全体的な設定
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* :root設定、@import、フォント読み込み、bodyへの上書き、カラー変数設定など */
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&display=swap');
:root {
  --min: 'Shippori Mincho', "Noto Serif JP", serif;
  --gothic: "Noto Sans JP", sans-serif;
  --vk-line-height: 2em !important;
}
body, html {
  font-family: 'Shippori Mincho', "Noto Serif JP", serif !important;
  letter-spacing: 0.05em;
  font-feature-settings: 'palt';
}
a:not([class]) {
  text-decoration: underline;
  -webkit-text-decoration-style: solid;
  text-decoration-style: solid;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
a:not([class]):hover {
  color: var(--vk-color-custom-1);
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  common 汎用パーツ系
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 繰り返しボタン・見出し、余白設計など */
/*縦書き*/
.vertical-item{
  padding: 0;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  letter-spacing: 0.3em;
}
/*ゴシックフォント*/
.sunserif{
  font-family: var(--gothic);
}
/*タグ風テキスト*/
.tag-text{
  font-size: .7rem;
  margin: 0;
}
.tag-text mark{
  border: 1px solid #ccc;
  padding: .2em .5em;
  background: none !important;
}
.tag-text-l{
  font-size: 1rem;
  margin: 0;
}
.tag-text-l mark{
  padding: .2em .5em;
  background: var(--vk-color-custom-1);
  color: #fff;
}
/*斜め線の中央見出し*/
/*中央寄せ*/
.is-style-vkp-heading-diagonal-line{
 display: flex;
 flex-wrap: nowrap;
 justify-content: center; 
 align-items: center;
 border:0;
}
/*短い左右線*/
.is-style-vkp-heading-diagonal-line::before,
.is-style-vkp-heading-diagonal-line::after {
 content: '';
 width: 30px;
 height: 1px;
 background-color:currentColor !important;
 /*Lightning見出しデザイン設定のCSS対策*/
 position: unset;
 border: unset;
 margin-left: unset;
 margin-right:unset;
	margin-bottom: 1em;
 flex-grow: unset;
}
.is-style-vkp-heading-diagonal-line::before{
 margin-right:14px;
 transform: rotate(60deg);
}
.is-style-vkp-heading-diagonal-line::after {
 margin-left:14px;   
 transform: rotate(-60deg);
}
/*見出し線*/
.heading-border-left{
  position: relative !important;
  padding-left: 70px;
}
.heading-border-left::before{
  content: "";
  display: inline-block;
  width: 50px;
  height: 1px;
  background-color: currentColor;
  position: absolute;
  left: 0;
  top:.8em; 
}
/*グリッドカードの見出し調整*/
.vk_gridcolcard h2, .vk_gridcolcard h3, .vk_gridcolcard h4, .vk_gridcolcard h5{
  margin-left: 0;
  margin-right: 0;
}
/*ボタン*/
.vk_button_link-type-text::after{
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url("../../../wp-content/uploads/btn_icon.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  position: relative;
  bottom: -.3em;
  margin-left: .5em;
  transition: all .8s;
}
.vk_button_link-type-text{
  border-bottom: 1px solid currentColor;
  padding: .5em !important;
  transition: all .8s;
}
.vk_button_link-type-text:hover{
  border-color: var(--vk-color-custom-1);
}
.vk_button_link-type-text:hover:after{
  transform: scale(1.2);
  transition: all .8s;
}
.vk_button .has-text-color.vk_button_link-type-text:hover .vk_button_link_txt, .vk_button .has-text-color.vk_button_link-type-text:hover .vk_button_link_subCaption, .editor-styles-wrapper .vk_button .has-text-color.vk_button_link-type-text:hover .vk_button_link_txt, .editor-styles-wrapper .vk_button .has-text-color.vk_button_link-type-text:hover .vk_button_link_subCaption{
  text-decoration: none !important;
  color: var(--vk-color-custom-1);
  transition: all .3s;	
}
/*アイコン付きボタン*/
.btn-has-icon .vk_button_link-type-text::after{
  display: none;
}
.btn-has-icon i{
  transition: all .8s;
}
.btn-has-icon:hover i{
  transform: scale(1.2);
  transition: all .8s;
  color: var(--vk-color-custom-1);
}
/* リンクエリア拡大 */
.stretched-linkitem {
  position: relative !important;
  transition: all .8s;
}
.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;
}
.stretched-linkitem a:hover {
  color: unset !important;
}
.stretched-linkitem:hover{
  transform: translate(0, -8px);
  transition: all .8s;
  opacity: .8;
}
/*画像ホバーズームイン*/
figure.hover-move, .hover-move figure, .wp-block-cover.hover-move {
  overflow: hidden;
}
.hover-move:hover img {
  transform: scale(1.2);
  transition: 1s;
}
.hover-move img {
  transition: 1s;
}
/*余白調整*/
.gap-large {
  gap: 4em !important;
}
.gap-none {
  gap: 0 !important;
}
.gap-mini {
  gap: 2em !important;
}
.padding-reset {
  padding: 0;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  header ヘッダーまわり
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ヘッダーウィジェット・グローバルナビ */
/* ヘッダー固定 */
body {
  overflow-x: unset !important;
  display: flex;
  flex-direction: column;
}
.device-pc #site-header {
  position: sticky;
  top: 0;
}
.logged-in #site-header {
  top: 32px;
}
/*ヘッダーレイアウト*/
.site-header .container {
  max-width: 100%;
  width: 100%;
  padding: 1em;
}
#site-header{
  box-shadow: none !important;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  background-color:rgba(255,255,255,0.8) !important;
}
/* HOMEだけFVに透過にする */
.home header#site-header {
  position: fixed;
  transition: .5s;
  background-color: #fff;
}
.home:not(.device-pc.scrolled) header#site-header {
  background-color: transparent;
  box-shadow: none;
  background: none !important;
}
body:not(.home) .site-header {
  background-color: #fff;
}
/*ロゴの配置*/
.site-header-logo img {
  margin-left: .5em !important;
}
/* topのみスクロールしていない時は透過で文字反転 */
.home header#site-header {
  position: fixed !important;
  top: 0;
  transition:.3s;
}
.home.scrolled header#site-header {
  background: #fff;
}
.logged-in:not(.home) #site-header {
  top: 32px;
}
.home:not(.scrolled) #site-header{
  background:#fff;
  border:none;
}
.home:not(.scrolled) .global-nav-name,
.home:not(.scrolled) .site-header-logo span,
.home:not(.scrolled) .header-top-description{
  color:#fff;
  transition:.3s;
}
.home:not(.scrolled) h1.site-header-logo img {
  filter: contrast(0) brightness(3);
}
.home:not(.scrolled) .global-nav-list > li.current-menu-item > a {
  border-bottom: 1px solid #fff;
}
/* グローバルナビ */
.global-nav-list > li > a {
  transition: .3s;
  border-bottom: 1px solid transparent;
}
.global-nav-list > li > a:hover, .global-nav-list > li.current-menu-item > a {
  color: var(--vk-color-custom-1);
  border-bottom: 1px solid var(--vk-color-custom-1);
}
/*言語ボタン*/
.header_nav_search_container {
  min-width: 80px !important;
}
.lang{
	padding-right: 10px;
	position: relative;
  margin: 0;
  font-size: .9rem;
}
.lang a:hover{
	color: var(--vk-color-primary) !important;
}
.lang mark{
	background: none;
	position: relative;
}
.lang a{
    text-decoration: none;
}
.lang mark::before{
	content: "";
	display: inline-block;
	width: 5px;
	height: 5px;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: -6px;
	background-color: #111;
	border-radius: 50px;
}
.home:not(.scrolled) .lang, .home:not(.scrolled) mark{
  color: #fff;
}
.home:not(.scrolled) mark::before{
  background-color: #fff;
}

.device-pc.scrolled .lang mark{
color: #333!important;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  footer フッターまわり
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* フッターウィジェット、フッターロゴ、コピーライト */
.site-footer {
  border-top: 1px solid #ddd;
  margin-top: 2em;
}
.site-footer {
  --vk-size-text-sm: .9rem!important;
}
.site-footer a{
  text-decoration: none !important;
}
.foot-sitemap ul{
  margin: 0 !important;
  padding: 0 !important;
}
.foot-sitemap ul li{
  padding-left: 1em;
  list-style: none;
  position: relative;
}
.foot-sitemap ul li::before{
  content: "";
  display: inline-block;
  width: 10px;
  height: 1px;
  background-color: currentColor;
  position: absolute;
  left: 0;
  top: .8em;
}
.site-footer-copyright{
    display: none;
  }
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  pageheader,breadcrumb 下層ページヘッダー
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 下層ページのページヘッダー、パンクズ設定 */
.breadcrumb-list li a{
  text-decoration: none;
  color: #999;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Toppage トップページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ページごと、パーツごとにコメントアウトで注釈を入れてください。 */
/*FVスクロール*/
.scroll {
  display: inline-block;
  padding: 0 0 55px 0;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: 0.6em;
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100vh - 150px);
  margin: 0 auto;
  z-index: 1;
  width: 22px;
  letter-spacing: 0.3em;
}
.scroll::before {
  animation: scroll-act 1.5s cubic-bezier(.77, 0, .175, 1) .3s both infinite;
  background-color: #fff;
  content: "";
  display: inline-block;
  margin: auto;
  position: absolute;
  bottom: 0;
  left: 10px;
  width: 1px;
  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
  }
}
/*コンセプト縦書き設定*/
.concept .vk_outer_container {
  padding: 0;
/*   -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-orientation: upright; */
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.concept .vk_outer_container h1{
  line-height: 3em;
  letter-spacing: 0.3em;
  margin-left: 2em;
}
.concept .vk_outer_container p {
  line-height: 3em;
  letter-spacing: 0.2em;
  margin-left: 5em;
}
.concept .vk_button_link-type-text{
  border: medium none;
}
.concept .vk_button_link-type-text::after{
  margin-top: .4em;
  bottom: 0;
  margin-left: 0;
}
/*強み・背景にロゴ*/
.strengths{
  position: relative;
}
.strengths::before{
  content:"";
  display: inline-block;
  width: 100%;
  height: 98%;
  background-image: url("../../../wp-content/uploads/logo.png");
  background-position: left top;
  background-size: auto 100%;
  background-repeat: no-repeat;
  position: absolute;
  left: -30%;
  top: 0;
  opacity: .1;
}
/*商品一覧ホバー*/
.product-item a.vk_gridcolcard_item_container:hover {
  opacity: 1;
}
.product-item figure {
  overflow: hidden;
}
.product-item .wp-block-image img{
  transition: .8s;
}
.product-item a:hover img {
  transform: scale(1.1);
  transition: .8s;
}
.product-item p, .product-item h3, .product-item mark{
  transition: .8s;
}
.product-item a:hover p, .product-item a:hover h3, .product-item a:hover mark{
  color: var(--vk-color-custom-1);
  transition: .8s;
}

/* TOP動画：少しスクロールしたらblurをかける */
body.home .fv {
  overflow: hidden;
  clip-path: inset(0);
  position: relative;
}

body.home .fv-text {
  display: flex;
  justify-content: center;
  margin-top: 30vh;
  height: 70vh;
}

body.home .fv video {
  position: fixed;
  top: 0;
  height: 100vh;
}

body.home .fv video.pl-scrolled {
  transition: .3s;
  filter: blur(15px);
  margin-left: -20px;
  width: calc(100% + 30px);
  height: calc(100vh + 30px);
}

/* オープニングアニメーション関連 */
.pl-opening-animation {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  width: 100%;
  text-align: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background-image: url('../../../wp-content/uploads/bg.jpg');
  background-position: left top;
  background-size: auto;
  background-repeat: repeat;
  background-attachment: fixed;
}

.pl-opening-animation__logo {
  display: none;
  opacity: 0;
  height: 30vh;
}

.pl-opening-animation__logo.fadein {
  display: block;
  animation: 1000ms fadein ease-in-out forwards;
}

.pl-opening-animation__logo.fadeout {
  display: block;
  animation: 500ms fadeout ease-in-out forwards;
}

.pl-opening-animation__text {
  display: none;
  opacity: 0;
}

.pl-opening-animation__text span {
  display: none;
  opacity: 0;
  font-size: 2.2rem;
  line-height: 1.8;
}

.pl-opening-animation__text span br {
  display: none;
}

.pl-opening-animation__text.fadein {
  display: block;
  animation: 1200ms fadeup ease-in-out forwards;
}

.pl-opening-animation__text span.fadein {
  display: block;
  animation: 1200ms fadeup ease-in-out forwards;
}

.pl-opening-animation__text.fadeout {
  display: block;
  animation: 500ms fadeout ease-in-out forwards;
}

@keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
    filter: blur(5px);
  }

  100% {
    opacity: 1;
    filter: blur(0);
  }
}

@keyframes fadeout {
  0% {
    opacity: 1;
    filter: blur(0);
  }

  100% {
    opacity: 0;
    filter: blur(5px);
    display: none;
  }
}

.pl-opening .site-header,
.pl-opening .site-body,
.pl-opening .site-footer {
  opacity: 0;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  page 下層ページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ページごと、パーツごとにコメントアウトで注釈を入れてください。 */
/*お問い合わせの余白*/
.smf-form--simple-table .wp-block-snow-monkey-forms-item {
  padding: 2rem 1rem;
}
/*画像をかぶせるレイアウト*/
.offset-img{
  position: relative;
  padding-bottom: 2em;
}
.offset-img .over-img{
  width: 30%;
  position: absolute;
  left: -10%;
  bottom: 0;
  margin: 0;
}
/*Q&Aテキストサイズ*/
 .vk_faq .vk_faq_title {
    font-size: 1rem;
    font-weight: 500;
  }
/*Q&A アイコンの背景色*/
.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-custom-2) !important;
}
/*タブ調整*/
.is-style-vk_tab_labels-line .vk_tab_labels .vk_tab_labels_label.vk_tab_labels_label-state-active {
  color:var(--vk-color-custom-2) !important;
}
.is-style-vk_tab_labels-line .vk_tab_labels .vk_tab_labels_label > div {
  padding: 1em 1em 1.2em 1em  !important;
}
.vk_tab_bodys>div>div{
  padding: 3em !important;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  Archive / Single ブログ一覧ページ、ブログ詳細ページ
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* パーツごとにコメントアウトで注釈を入れてください。 */
/*投稿リスト*/
.postListText {
  padding: .6rem 0 .7rem;
  border-bottom: 1px solid #666 !important;
}
.postListText_title a{
	text-decoration: none !important;
}
/*お知らせサイドメニュー*/
.sub-section .sub-section-title, .site-body-bottom .sub-section-title {
  color: #474747 !important;
  border-bottom: 1px solid #ddd !important;
  padding: .5em 0 !important;
  text-align: left !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: 0;
}
.localNavi li::before {
  position: absolute;
  content: '\f105';
  font-family: 'Font Awesome 5 Free';
  font-weight: 600;
  padding-right: .2em;
  left: 10px;
  top: 18px;
  font-size: .9rem;
  color: var(--vk-color-primary);
}
.localNavi li a {
  padding-left: 25px !important;
  ;
}
.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: 2px;
  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: 2px;
  position: absolute;
  left: 30px;
  top: 0;
  background-color: var(--vk-color-custom-1);
}
.sub-section .widget_archive > ul li a:hover, .sub-section .widget_nav_menu > ul li a:hover {
  color: var(--vk-color-primary) !important;
  background-color: #f5f5f5 !important;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  商品紹介
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* 匠美 */
.takumi-column-item02 p{
margin-bottom: 0;
}
.wp-block-group.miraisetakumi_tab_item02{
    height: 164px!important;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
 *  メモ用
 * ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* 成分テーブル */
.seibun-table tr td{
    padding: 2em 0 2em 2em!important;
}