/*
Theme Name:   Owl de Base Child
Template:     lightning
Version:      1.0.0
Description:  owl-de-base.com 専用カスタム子テーマ
Author:       owl de base
Text Domain:  owl-de-base-child
*/

/* ================================================================
   A. デザインシステム定義
   Lightning G3 の CSS 変数を上書き + 独自変数を定義
   ================================================================ */

:root {
  /* ── カラーパレット ── */
  --color-primary:      #8B6347;   /* チョコレートブラウン */
  --color-secondary:    #F5ECD7;   /* クリームベージュ */
  --color-accent:       #C8956C;   /* テラコッタ（CTA・強調） */
  --color-green:        #4A7C59;   /* フォレストグリーン */
  --color-dark:         #3D2B1F;   /* 本文・見出し */
  --color-light:        #FDF8F0;   /* ページ背景 */
  --color-muted:        #7A6859;   /* サブテキスト */
  --color-border:       rgba(139, 99, 71, 0.18);

  /* ── Lightning G3 変数を上書き ── */
  --vk-color-primary:           #8B6347;
  --vk-color-primary-dark:      #6B4A33;
  --vk-color-primary-vivid:     #C8956C;
  --vk-color-secondary:         #F5ECD7;
  --vk-color-accent:            #C8956C;
  --vk-color-text-body:         #3D2B1F;
  --vk-color-text-header:       #ffffff;
  --vk-color-bg-body:           #FDF8F0;
  --vk-color-bg-header:         #3D2B1F;
  --vk-color-bg-footer:         #1E1008;
  --vk-font-size-base:          15px;
  --vk-line-height-base:        1.85;

  /* ── フォント ── */
  --font-base:    'Zen Maru Gothic', 'Noto Sans JP', sans-serif;
  --font-heading: 'Zen Maru Gothic', sans-serif;
  --font-accent:  'Cormorant Garamond', serif;  /* 英字アクセント */

  /* ── 形状 ── */
  --radius-sm:   8px;
  --radius-md:   16px;
  --radius-lg:   24px;
  --radius-pill: 50px;

  /* ── シャドウ ── */
  --shadow-sm:  0 2px 8px  rgba(61, 43, 31, 0.07);
  --shadow-md:  0 4px 20px rgba(61, 43, 31, 0.11);
  --shadow-lg:  0 8px 32px rgba(61, 43, 31, 0.16);

  /* ── トランジション ── */
  --ease: 0.25s ease;
}

/* ── ベース ── */
body {
  font-family: var(--font-base);
  color: var(--color-dark);
  background-color: var(--color-light);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--color-dark);
  line-height: 1.5;
}

/* Lightning G3 の見出し色上書き */
.vk-block-heading,
.wp-block-heading {
  font-family: var(--font-heading);
}


/* ================================================================
   B. ヘッダー・フローティングナビゲーション
   ================================================================ */

/* ── PC ヘッダー ── */
#site-header,
.site-header {
  background-color: #fff;
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 1px 12px rgba(61, 43, 31, 0.08);
}

/* Lightning G3 のヘッダーロゴ */
.site-header .custom-logo-link img,
.site-branding img {
  max-height: 48px;
  width: auto;
}

/* PC グローバルナビ */
.global-nav .menu-item a,
#global-nav .menu-item > a {
  font-family: var(--font-heading);
  font-size: 13.5px;
  color: var(--color-dark);
  letter-spacing: 0.04em;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  transition: color var(--ease), background var(--ease);
}
.global-nav .menu-item a:hover,
#global-nav .menu-item > a:hover {
  color: var(--color-accent);
  background: var(--color-secondary);
  text-decoration: none;
}

/* ヘッダー CTA ボタン（電話番号） */
.header-cta-tel {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-primary);
  color: #fff !important;
  padding: 8px 20px;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 13.5px;
  text-decoration: none !important;
  transition: background var(--ease), transform var(--ease);
  white-space: nowrap;
}
.header-cta-tel:hover {
  background: var(--color-dark);
  transform: translateY(-1px);
}

/* ── スマホ用フローティングナビゲーション ── */
/*
  使い方：
  footer.php の </body> 直前に以下のHTMLを追加（B-2参照）
  または ExUnit カスタムHTML ブロックで固定フッター化
*/
#floating-nav {
  display: none; /* PC では非表示 */
}

@media (max-width: 767px) {
  /* ページ下部に余白を確保（コンテンツがナビに隠れないように） */
  body {
    padding-bottom: 68px;
  }

  #floating-nav {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9999;
    background: #fff;
    border-top: 1px solid var(--color-border);
    box-shadow: 0 -4px 20px rgba(61, 43, 31, 0.14);
    height: 62px;
    align-items: stretch;
  }

  .fnav-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    text-decoration: none;
    font-size: 11px;
    font-weight: 700;
    font-family: var(--font-heading);
    color: var(--color-muted);
    transition: color var(--ease), background var(--ease);
    letter-spacing: 0.03em;
    padding: 6px 4px;
    border-right: 1px solid var(--color-border);
  }
  .fnav-item:last-child {
    border-right: none;
  }
  .fnav-item .fnav-icon {
    font-size: 20px;
    line-height: 1;
  }
  .fnav-item:hover {
    color: var(--color-accent);
    background: var(--color-secondary);
  }

  /* 来店CTAは強調 */
  .fnav-item--primary {
    background: var(--color-accent);
    color: #fff;
  }
  .fnav-item--primary:hover {
    background: var(--color-primary);
    color: #fff;
  }

  /* 販売CTAは緑 */
  .fnav-item--secondary {
    background: var(--color-green);
    color: #fff;
  }
  .fnav-item--secondary:hover {
    background: #3A6449;
    color: #fff;
  }

  /* スマホ時に既存ヘッダーのモバイルナビを非表示（フローティングで代替） */
  .vk-mobile-nav-button {
    display: none;
  }
}


/* ================================================================
   C. フクロウ在庫カード（VK Blocks カード上書き）
   ================================================================ */

/*
  VK Blocks の「カード」ブロックを使用する場合、
  以下のクラスが自動付与されるため、それを上書きします。
  カスタム投稿タイプ「owl_inventory」のアーカイブ・シングルページでも使用可。
*/

/* ── カード外枠 ── */
.vk_card,
.owl-card {
  background: #fff;
  border: none !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--ease), box-shadow var(--ease);
  position: relative;
}
.vk_card:hover,
.owl-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}

/* ── カード画像エリア ── */
.vk_card .vk_card__image-area,
.vk_card__image,
.owl-card__image {
  height: 220px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
}
.vk_card .vk_card__image-area img,
.owl-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.vk_card:hover .vk_card__image-area img,
.owl-card:hover .owl-card__image img {
  transform: scale(1.04);
}

/* ── ステータスバッジ（販売中 / 売約済み） ── */
.owl-card__badge {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  z-index: 2;
}
.owl-card__badge--available {
  background: var(--color-green);
  color: #fff;
}
.owl-card__badge--sold {
  background: #999;
  color: #fff;
}
.owl-card__badge--reserved {
  background: var(--color-accent);
  color: #fff;
}

/* ── カードボディ ── */
.vk_card .vk_card__body,
.owl-card__body {
  padding: 20px 22px 24px;
}

/* ── フクロウ名（カードタイトル） ── */
.vk_card .vk_card__title,
.owl-card__name {
  font-family: var(--font-heading);
  font-size: 20px;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 4px;
  line-height: 1.3;
}

/* ── 種類ラベル ── */
.owl-card__species {
  font-size: 11.5px;
  color: var(--color-accent);
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

/* ── 一言コメント ── */
.vk_card .vk_card__content,
.owl-card__comment {
  font-size: 13px;
  color: var(--color-muted);
  line-height: 1.8;
  font-style: italic;
  margin-bottom: 14px;
}

/* ── スペック行（年齢・性別） ── */
.owl-card__specs {
  display: flex;
  gap: 16px;
  font-size: 12px;
  color: var(--color-muted);
  margin-bottom: 14px;
}
.owl-card__specs span {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── 価格 ── */
.owl-card__price {
  font-family: var(--font-accent);
  font-size: 22px;
  color: var(--color-dark);
  font-weight: 700;
  letter-spacing: 0.04em;
}
.owl-card__price-note {
  font-size: 11px;
  color: var(--color-muted);
  margin-left: 4px;
  font-style: normal;
  font-family: var(--font-base);
  font-weight: 400;
}

/* ── カードのグリッドコンテナ（3列） ── */
.owl-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) {
  .owl-cards-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .owl-cards-grid { grid-template-columns: 1fr; }
}

/* ── VK Blocks グリッドの列幅調整 ── */
.vk_gridCard-col-md-4 {
  flex: 0 0 33.333% !important;
  max-width: 33.333% !important;
}
@media (max-width: 768px) {
  .vk_gridCard-col-md-4 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}
@media (max-width: 480px) {
  .vk_gridCard-col-md-4 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}


/* ================================================================
   D. その他のUI上書き
   ================================================================ */

/* ── ボタン全般 ── */
.wp-block-button__link,
.btn,
.vk_button .btn {
  border-radius: var(--radius-pill) !important;
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.06em;
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
  padding: 14px 36px;
}
.wp-block-button__link:hover,
.btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* ── プライマリボタン ── */
.wp-block-button.is-style-fill .wp-block-button__link,
.vk_button-color--primary .btn {
  background: var(--color-accent) !important;
  border-color: var(--color-accent) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(200, 149, 108, 0.4);
}
.wp-block-button.is-style-fill .wp-block-button__link:hover {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  box-shadow: 0 6px 24px rgba(139, 99, 71, 0.45);
}

/* ── アウトラインボタン ── */
.wp-block-button.is-style-outline .wp-block-button__link {
  border: 2px solid var(--color-primary) !important;
  color: var(--color-primary) !important;
  background: transparent !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* ── セクション背景 ── */
.section-bg-cream { background-color: var(--color-secondary) !important; }
.section-bg-dark  { background-color: var(--color-dark) !important; }
.section-bg-light { background-color: var(--color-light) !important; }

/* ── VK Blocks FAQ（アコーディオン） ── */
.vk_faq .vk_faq__title {
  font-family: var(--font-heading);
  background: var(--color-secondary);
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--color-accent);
  padding: 14px 16px;
  margin-bottom: 2px;
  font-size: 14px;
  color: var(--color-dark);
}
.vk_faq .vk_faq__title:hover {
  background: var(--color-accent);
  color: #fff;
}
.vk_faq .vk_faq__content {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  padding: 16px 20px;
  font-size: 13.5px;
  color: var(--color-muted);
  line-height: 1.85;
}

/* ── VK Blocks ステップ ── */
.vk_step .vk_step__item {
  border-left: 3px solid var(--color-accent);
  padding-left: 20px;
  margin-bottom: 28px;
}
.vk_step .vk_step__number {
  background: var(--color-accent);
  color: #fff;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-family: var(--font-accent);
  font-size: 18px;
}

/* ── インスタグラムフィード（Smash Balloon） ── */
#sb_instagram {
  border-radius: var(--radius-md);
  overflow: hidden;
}
#sb_instagram .sbi_photo_wrap {
  border-radius: var(--radius-sm) !important;
  overflow: hidden;
}

/* ── フッター ── */
.site-footer,
#site-footer {
  background-color: #1E1008;
  color: rgba(255, 255, 255, 0.6);
}
.site-footer a { color: rgba(255, 255, 255, 0.5); }
.site-footer a:hover { color: rgba(255, 255, 255, 0.85); }
.site-footer .footer-logo img {
  filter: brightness(0) invert(0.75);
  max-height: 38px;
}

/* ── パンくずリスト ── */
.vk_breadCrumb {
  font-size: 12px;
  color: var(--color-muted);
  background: var(--color-secondary);
  padding: 10px 20px;
  border-radius: var(--radius-sm);
}

/* ── ページャー ── */
.pagination .page-numbers {
  border-radius: var(--radius-sm);
  color: var(--color-primary);
}
.pagination .page-numbers.current {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

/* ── スクロールバー（Webkitのみ） ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--color-secondary); }
::-webkit-scrollbar-thumb { background: var(--color-accent); border-radius: 3px; }
