/*
Theme Name:   Cocoon Child - Video SEO
Theme URI:    https://example.com
Description:  Cocoon の子テーマ。MP4動画対応SEOメディアサイト用。黒×金 高級感デザイン。
Author:        mime.inc
Template:     cocoon-master
Version:      2.0.0
*/

/* ============================================
   FOUC防止：CocoonデフォルトヘッダーをCSSで即時非表示
   ============================================ */
#header { display: none !important; }

/* ============================================
   CSS カスタムプロパティ（黒×金テーマ）
   ============================================ */
:root {
  --bg-primary:    #0a0a0a;
  --bg-secondary:  #141414;
  --bg-card:       #1a1a1a;
  --bg-hover:      #222222;
  --gold:          #c9a84c;
  --gold-light:    #e8c97a;
  --gold-dark:     #9a7a30;
  --text-primary:  #f0f0f0;
  --text-muted:    #888888;
  --text-gold:     #c9a84c;
  --border-gold:   #c9a84c;
  --border-dark:   #2a2a2a;
  --accent-red:    #e63946;
  --font-stack:    "Helvetica Neue", Helvetica, Arial, YuGothic, "游ゴシック", sans-serif;
}

/* ============================================
   ベース設定
   ============================================ */
body {
  background-color: var(--bg-primary) !important;
  color: var(--text-primary) !important;
  font-family: var(--font-stack) !important;
  font-size: 14px;
  line-height: 1.7;
}

/* 白背景を黒に統一 */
#container,
#main,
#content,
.site-content,
.content-area,
.wrap,
#wrapper,
.entry-card-wrap,
.a-wrap,
#sidebar,
.sidebar,
.sidebar-wrap,
.sidebar-scroll {
  background-color: var(--bg-primary) !important;
}

/* Cocoonのカード・ラッパーの白背景を除去 */
.card-wrap,
.a-wrap,
.entry-card,
.entry-card-wrap {
  background: var(--bg-card) !important;
  border-color: var(--border-dark) !important;
}

/* 右サイドバーを非表示 */
#sidebar,
.sidebar,
.sidebar-wrap {
  display: none !important;
}

/* CocoonのナビゲーションバーとパンくずをSPで非表示（黒い四角の原因） */
#navi,
.global-navi,
#navi-in,
.navi-in,
#header-container,
#header-container-in,
#breadcrumb,
.breadcrumb {
  display: none !important;
}

/* コンテンツエリアを全幅に */
#main,
.main,
#content,
.content {
  width: 100% !important;
  max-width: 100% !important;
}

/* ヘッダー下の余白を詰める（body padding-topのみで対応） */
#container,
.wrap,
#wrapper,
.site-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Cocoonのメインラッパー余白をリセット */
#main-wrap,
.main-wrap,
.entry-content-wrap {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

a {
  color: var(--text-primary);
  text-decoration: none;
  transition: color 0.2s;
}

a:hover {
  color: var(--gold-light);
}

/* ============================================
   ヘッダー（左タイトル＋右検索）
   ============================================ */
#header,
.site-header,
.header-container {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  height: 56px !important;
  background: var(--bg-secondary) !important;
  border-bottom: 1px solid var(--border-gold) !important;
  z-index: 1000;
  display: flex !important;
  align-items: center;
  justify-content: space-between !important;
  padding: 0 20px;
  box-shadow: 0 2px 12px rgba(201,168,76,0.15) !important;
}

/* Cocoonのヘッダー内の不要な要素を非表示 */
#header .header-logo-image,
#header .site-name-text,
.header-logo,
.site-name,
#site-name {
  display: none !important;
}

/* ロゴ + ••• ラッパー */
.logo-dots-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* カスタムヘッダーロゴ（functions.phpで注入） */
.custom-header-logo {
  font-size: 1.3rem;
  font-weight: bold;
  color: var(--gold) !important;
  letter-spacing: 0.05em;
  white-space: nowrap;
  text-decoration: none;
  flex-shrink: 0;
}

.custom-header-logo:hover {
  color: var(--gold-light) !important;
}

/* カスタムヘッダー検索フォーム */
.custom-header-search {
  display: flex;
  align-items: center;
  border: 1px solid var(--border-gold);
  overflow: hidden;
  background: var(--bg-card);
  height: 34px;
  flex: 1;
  max-width: 480px;
  margin: 0 20px;
}

.custom-header-search input[type="search"] {
  border: none !important;
  background: transparent !important;
  color: var(--text-primary) !important;
  padding: 0 12px;
  height: 100%;
  flex: 1;
  outline: none;
  font-size: 0.85rem;
}

.custom-header-search input[type="search"]::placeholder {
  color: var(--text-muted);
}

.custom-header-search button {
  background: var(--gold) !important;
  color: #000 !important;
  border: none !important;
  padding: 0 14px;
  height: 100%;
  cursor: pointer;
  font-size: 0.9rem;
}

#container, .wrap, #wrapper {
  margin-top: 0 !important;
}

#site-logo, .site-name, .header-logo {
  font-size: 1.3rem;
  font-weight: bold;
  color: var(--gold) !important;
  letter-spacing: 0.05em;
}

/* ============================================
   ナビゲーション
   ============================================ */
#navi, .global-navi {
  background: var(--bg-secondary) !important;
  border-bottom: 1px solid var(--border-dark);
}

#navi ul li a,
.global-navi ul li a {
  color: var(--text-primary) !important;
  font-size: 0.85rem;
  padding: 10px 14px;
}

#navi ul li a:hover,
.global-navi ul li a:hover {
  color: var(--gold) !important;
  background: transparent !important;
}

/* カテゴリタグナビ */
.cat-menu, .tag-menu {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 16px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border-dark);
}

.cat-menu a, .tag-menu a {
  font-size: 0.75rem;
  padding: 3px 12px;
  border: 1px solid var(--border-gold);
  border-radius: 2px;
  color: var(--gold);
  background: transparent;
  transition: all 0.2s;
}

.cat-menu a:hover, .tag-menu a:hover {
  background: var(--gold);
  color: #000;
}

/* ============================================
   単記事ページ（動画ページ）
   ============================================ */

/* ============================================
   投稿ページ 2カラムレイアウト
   ============================================ */
.single-layout-wrap {
  overflow: hidden;
  padding: 0 12px;
}
.single-related-col {
  float: right;
  width: 240px;
  margin-left: 16px;
  overflow-y: visible;
}
.single-main-col {
  overflow: hidden;
}

.related-col-heading {
  font-size: 0.85rem;
  font-weight: bold;
  color: var(--gold);
  padding: 10px 0 8px;
  border-bottom: 1px solid var(--border-gold);
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}
.related-col-heading { display: none; }
.related-col-list { display: flex; flex-direction: column; gap: 12px; }

.related-col-item {
  display: block;
  border-radius: 2px;
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  transition: border-color 0.15s;
}
.related-col-item:hover { border-color: var(--border-gold); }

.related-col-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #111;
}
.related-col-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.related-col-info {
  padding: 6px 8px 8px;
}
.related-col-title {
  font-size: 0.78rem;
  color: var(--text-primary);
  line-height: 1.4;
}
.related-col-item:hover .related-col-title { color: var(--gold); }
.related-col-date { font-size: 0.65rem; color: var(--text-muted); margin-top: 3px; }

/* PC：サイドバー関連動画は5件まで表示 */
@media (min-width: 768px) {
  .related-col-item:nth-child(n+6) { display: none; }
}

/* SP：右カラム非表示、SP用関連動画を表示 */
.related-videos-sp { display: none; }

@media (max-width: 900px) {
  .single-related-col { display: none !important; }
  .single-main-col { width: 100%; }
  .related-videos-sp { display: block; }
}

/* ============================================
   本文下 メーカー・シリーズ関連動画
   ============================================ */
.below-related-section {
  clear: both;
  margin: 40px 0 24px;
  border-top: 1px solid var(--border-gold);
  padding-top: 16px;
}
.below-related-heading {
  font-size: 0.95rem;
  font-weight: bold;
  color: var(--gold);
  margin-bottom: 12px;
}
.below-related-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.below-related-card {
  display: block;
  text-decoration: none;
  color: var(--text-primary);
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
}
.below-related-card:hover {
  border-color: var(--gold-dark);
  transform: translateY(-2px);
}
.below-related-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #111;
}
.below-related-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s;
}
.below-related-card:hover .below-related-thumb img {
  transform: scale(1.04);
}
.below-related-title {
  font-size: 0.75rem;
  font-weight: bold;
  padding: 6px 8px 8px;
  line-height: 1.4;
}
@media (max-width: 767px) {
  .below-related-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  /* SP：横2×縦3=6件に制限 */
  .below-related-grid .below-related-card:nth-child(n+7) {
    display: none;
  }
}

/* 動画プレイヤーラッパー */
.fav-video-outer-wrap,
.video-wrap {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 0 auto 0;
  background: #000;
  border: 1px solid var(--border-gold);
  box-shadow: 0 0 24px rgba(201,168,76,0.2);
}

.fav-video-outer-wrap video,
.video-wrap video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

/* 動画下のメタ情報エリア */
.pp-movie-info {
  max-width: 900px;
  margin: 0 auto;
  padding: 16px 0;
}

/* 動画タイトル */
.pp-movie-info__title,
.entry-title,
h1.entry-title {
  font-size: 1.2rem !important;
  font-weight: bold !important;
  color: var(--text-primary) !important;
  text-align: left !important;
  line-height: 1.5;
  margin: 14px 0 10px !important;
  padding: 0 0 10px 0 !important;
  border-bottom: 1px solid var(--border-gold) !important;
}

/* タイトル先頭のカテゴリーバッジ */
.title-category-badge {
  color: var(--gold);
  font-size: inherit;
  font-weight: inherit;
  margin-right: 2px;
}

/* タグ一覧 */
.post-tags,
.entry-tags,
.movie-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 12px 0;
}

.post-tags a,
.entry-tags a,
.movie-tags a {
  display: inline-block;
  font-size: 0.75rem;
  padding: 3px 10px;
  border: 1px solid var(--border-gold);
  border-radius: 2px;
  color: var(--gold);
  background: transparent;
  transition: all 0.2s;
}

.post-tags a:hover,
.entry-tags a:hover,
.movie-tags a:hover {
  background: var(--gold);
  color: #000;
}

/* アクションボタン（いいね等） */
.movie-button,
.action-buttons {
  display: flex;
  gap: 10px;
  margin: 14px 0;
  flex-wrap: wrap;
}

.movie-button a,
.action-buttons a,
.btn-like {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  border: 1px solid var(--border-gold);
  background: transparent;
  color: var(--gold);
  font-size: 0.85rem;
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s;
}

.movie-button a:hover,
.action-buttons a:hover,
.btn-like:hover {
  background: var(--gold);
  color: #000;
}

/* 説明文エリア */
.entry-content,
.movie-description {
  max-width: 900px;
  margin: 0 auto;
  padding: 16px 0;
  color: var(--text-primary);
  font-size: 0.9rem;
  line-height: 1.8;
  border-top: 1px solid var(--border-dark);
}

/* ============================================
   関連動画グリッド
   ============================================ */
.related-videos,
.posts-list,
.card-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin: 20px 0;
}

.related-video-card,
.card-wrap,
.a-wrap {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-dark) !important;
  border-radius: 2px;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.related-video-card:hover,
.card-wrap:hover,
.a-wrap:hover {
  border-color: var(--border-gold) !important;
  box-shadow: 0 4px 16px rgba(201,168,76,0.15);
  transform: translateY(-2px);
}

/* カードサムネイル */
.card-thumb,
.a-wrap .eye-catch {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #000;
}

.card-thumb img,
.a-wrap .eye-catch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s;
}

.card-wrap:hover .card-thumb img,
.a-wrap:hover .eye-catch img {
  transform: scale(1.04);
}

/* 再生時間バッジ */
.card-duration {
  position: absolute;
  bottom: 5px;
  right: 5px;
  background: rgba(0,0,0,0.8);
  color: var(--gold);
  font-size: 0.7rem;
  padding: 2px 6px;
  border: 1px solid var(--gold-dark);
  font-weight: bold;
}

/* カードタイトル */
.a-wrap .entry-title,
.card-title {
  font-size: 0.8rem !important;
  font-weight: bold;
  color: var(--text-primary) !important;

  padding: 8px 10px !important;
  border-bottom: none !important;
  margin: 0 !important;
  line-height: 1.4;
}

.card-meta {
  padding: 4px 10px 8px;
  font-size: 0.7rem;
  color: var(--text-muted);
}

/* セクションタイトル */
.section-title,
.related-title {
  font-size: 0.9rem;
  font-weight: bold;
  color: var(--gold);
  border-left: 3px solid var(--gold);
  padding-left: 10px;
  margin: 24px 0 12px;
}

/* ============================================
   記事一覧ページ（トップ・アーカイブ）
   ============================================ */
#cardlayout-wrap,
.home-card-list,
.archive-list {
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px;
  padding: 16px;
  background: var(--bg-primary);
}

/* ============================================
   サイドバー
   ============================================ */
#sidebar, .sidebar {
  background: var(--bg-secondary) !important;
  border-left: 1px solid var(--border-dark);
}

.widget-title, .sidebar-title {
  font-size: 0.85rem;
  font-weight: bold;
  color: var(--gold);
  border-left: 3px solid var(--gold);
  padding-left: 8px;
  margin-bottom: 12px;
}

/* ============================================
   ページネーション
   ============================================ */
.pagination, .pager {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin: 24px 0;
  flex-wrap: wrap;
}

.pagination a,
.pagination span,
.pager a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border: 1px solid var(--border-dark);
  font-size: 0.85rem;
  background: var(--bg-card);
  color: var(--text-primary);
  transition: all 0.2s;
}

.pagination .current,
.pagination a:hover,
.pager a:hover {
  background: var(--gold) !important;
  color: #000 !important;
  border-color: var(--gold) !important;
}

/* ============================================
   検索ボックス
   ============================================ */
.search-form, #search-form {
  display: flex;
  border: 1px solid var(--border-gold);
  overflow: hidden;
  background: var(--bg-card);
}

.search-form input[type="search"],
#search-form input[type="search"] {
  border: none !important;
  background: transparent !important;
  color: var(--text-primary) !important;
  padding: 8px 12px;
  flex: 1;
  outline: none;
}

.search-form button,
#search-form button {
  background: var(--gold) !important;
  color: #000 !important;
  border: none;
  padding: 8px 16px;
  cursor: pointer;
  font-weight: bold;
}

/* ============================================
   コメント欄
   ============================================ */
#comments, .comments-area {
  max-width: 900px;
  margin: 24px auto 0;
  padding-top: 20px;
  border-top: 1px solid var(--border-gold);
}

.comment-list .comment-body {
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  padding: 12px 16px;
  margin-bottom: 10px;
}

.comment-form input,
.comment-form textarea {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-dark) !important;
  color: var(--text-primary) !important;
  padding: 8px 12px;
  width: 100%;
  box-sizing: border-box;
}

.comment-form input:focus,
.comment-form textarea:focus {
  border-color: var(--border-gold) !important;
  outline: none;
}

.comment-form .submit {
  background: var(--gold) !important;
  color: #000 !important;
  border: none !important;
  padding: 10px 24px;
  font-weight: bold;
  cursor: pointer;
}

/* ============================================
   フッターナビゲーション（サイトマップ型）
   ============================================ */
.site-footer-nav {
  background: #141414;
  border-top: 1px solid var(--border-gold);
  margin-top: 0;
  width: 100%;
}

.site-footer-nav-inner {
  display: flex;
  gap: 0;
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 24px 24px;
  flex-wrap: wrap;
}

.sfn-col {
  flex: 1;
  min-width: 130px;
  padding-right: 20px;
  border-right: 1px solid var(--border-dark);
  margin-right: 20px;
}
.sfn-col:last-child {
  border-right: none;
  margin-right: 0;
  padding-right: 0;
}

.sfn-heading {
  font-size: 0.9rem;
  font-weight: bold;
  color: var(--gold);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-dark);
  letter-spacing: 0.05em;
}

.sfn-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sfn-col ul li {
  margin-bottom: 6px;
}

.sfn-col ul li a {
  font-size: 0.8rem;
  color: #aaaaaa;
  transition: color 0.15s;
  display: flex;
  align-items: center;
  gap: 5px;
}

.sfn-col ul li a::before {
  content: "›";
  color: var(--gold-dark);
  font-size: 0.9rem;
}

.sfn-col ul li a:hover {
  color: var(--gold);
}

.site-footer-copy {
  text-align: center;
  padding: 16px 24px;
  font-size: 0.75rem;
  color: var(--text-muted);
  border-top: 1px solid var(--border-dark);
}

@media (max-width: 767px) {
  .site-footer-nav-inner {
    padding: 20px 16px 16px;
    gap: 16px;
  }
  .sfn-col {
    flex: 1 1 calc(50% - 16px);
    border-right: none;
    margin-right: 0;
    padding-right: 0;
    border-bottom: 1px solid var(--border-dark);
    padding-bottom: 12px;
  }
  .sfn-col:last-child { border-bottom: none; }
}

/* ============================================
   フッター（Cocoon標準を非表示、カスタムフッターのみ使用）
   ============================================ */
#footer, .site-footer, #footer-widget-area, .footer-widget-area {
  display: none !important;
}

/* ============================================
   スクロールトップボタン
   ============================================ */
#scroll-top-btn,
.wpfront-scroll-top-container {
  background: var(--gold) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 2px !important;
}

/* ============================================
   動画キャプション・メタ
   ============================================ */
.video-caption {
  font-size: 0.78rem;
  color: var(--text-muted);
  text-align: center;
  margin: 6px 0 16px;
}

/* メーカー・シリーズ アーカイブヘッダー */
.maker-archive-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0 12px;
  border-bottom: 1px solid var(--border-gold);
  margin-bottom: 16px;
}
.maker-archive-name {
  font-size: 1.2rem;
  font-weight: bold;
  color: var(--text-primary);
  margin: 0;
  padding: 0;
  line-height: 1.4;
}
.maker-archive-sub {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: 4px;
}
.video-info-main { text-decoration: none; }
.video-info-main:hover .video-info-name { color: var(--gold); }

/* 視聴数・日付バー */
.video-stats-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 0;
  font-size: 0.82rem;
  color: var(--text-muted);
}
.stats-views { color: var(--text-primary); }

/* アクションボタンバー */
.video-action-bar {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 6px;
  padding: 10px 0;
  border-top: 1px solid var(--border-dark);
  border-bottom: 1px solid var(--border-dark);
  margin-bottom: 10px;
  overflow-x: auto;
}
.action-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  font-size: 0.78rem;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  color: var(--text-muted);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.action-btn:hover { border-color: var(--gold); color: var(--gold); }
.action-btn.disliked { color: #e63946; border-color: #e63946; }
.action-btn.faved { color: #e63946; border-color: #e63946; }

/* WP ULike を完全非表示 */
.wpulike, .wp_ulike_general_class, div[id^="wpulike-"] { display: none !important; }


/* WP ULike ボタンを👍スタイルに統一 */
.action-like-wrap .wp_ulike_btn_is_active,
.action-like-wrap .wp_ulike_btn_is_not_active { display: inline-flex !important; }
.action-like-wrap .wp_ulike_btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 6px 12px !important;
  font-size: 0.78rem !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border-dark) !important;
  color: var(--text-muted) !important;
  border-radius: 2px !important;
  cursor: pointer !important;
  transition: all 0.15s !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
.action-like-wrap .wp_ulike_btn:hover {
  border-color: var(--gold) !important;
  color: var(--gold) !important;
}
.action-like-wrap .wp_ulike_btn.wp_ulike_btn_active {
  border-color: var(--gold) !important;
  color: var(--gold) !important;
}
/* デフォルトアイコン画像を非表示 → 👍絵文字に置換 */
.action-like-wrap .wp_ulike_btn .wp_ulike_put_image,
.action-like-wrap .wp_ulike_btn img,
.action-like-wrap .wp_ulike_btn i,
.action-like-wrap .wp_ulike_btn svg { display: none !important; }
.action-like-wrap .wp_ulike_btn::before {
  content: "👍";
  font-size: 1rem;
}

/* 共有ドロップダウン */
.share-wrap { position: relative; }
.share-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: 2px;
  z-index: 100;
  overflow: hidden;
  min-width: 100px;
}
.share-dropdown.open { display: block; }
.share-item {
  display: block;
  padding: 8px 16px;
  font-size: 0.8rem;
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-dark);
  transition: background 0.15s;
}
.share-item:last-child { border-bottom: none; }
.share-item:hover { background: var(--bg-hover); color: var(--gold); }
.share-x { font-weight: bold; }
.share-line { color: #06c755; }

/* メーカー・シリーズ情報 */
.video-info-section {
  margin: 12px 0;
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  overflow: hidden;
}
.video-info-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-dark);
}
.video-info-item:last-child { border-bottom: none; }
.video-info-main { display: flex; flex-direction: column; gap: 2px; }
.video-info-name { font-size: 0.9rem; font-weight: bold; color: var(--text-primary); }
.video-info-sub { font-size: 0.72rem; color: var(--text-muted); }
.video-info-btn {
  padding: 6px 14px;
  font-size: 0.75rem;
  background: var(--gold);
  color: #111;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  font-weight: bold;
  transition: background 0.15s;
  white-space: nowrap;
}
.video-info-btn:hover { background: var(--gold-light); }

/* SP：タイトル左揃え */
@media (max-width: 767px) {
  .pp-movie-info__title,
  .entry-title,
  h1.entry-title {
    text-align: left !important;
  }
  .video-action-bar { gap: 4px; }
}

.video-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 10px 0;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.video-meta .video-duration {
  background: var(--bg-card);
  color: var(--gold);
  border: 1px solid var(--gold-dark);
  padding: 2px 8px;
  font-weight: bold;
  font-size: 0.75rem;
}

/* ============================================
   レスポンシブ
   ============================================ */
@media (max-width: 991px) {
  .related-videos,
  .posts-list,
  .card-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 767px) {
  .related-videos,
  .posts-list,
  .card-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .fav-video-outer-wrap,
  .video-wrap {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    margin-top: 12px;
    border-left: none;
    border-right: none;
    border-radius: 0;
  }
  .single-layout-wrap {
    padding: 0;
  }
  .single-main-col {
    padding: 0 12px;
  }

  .pp-movie-info__title,
  .entry-title,
  h1.entry-title {
    font-size: 1rem !important;
  }
}

/* ============================================
   ユーティリティ
   ============================================ */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* 金色区切り線 */
.gold-divider {
  border: none;
  border-top: 1px solid var(--border-gold);
  margin: 20px 0;
}

/* ============================================
   トップページ：左サイドバー + メインの2カラム
   ============================================ */

/* 全体ラッパー */
.fav-layout-wrap {
  display: flex;
  align-items: flex-start;
  background: var(--bg-primary);
}

/* ---- 左サイドバー ---- */
.fav-left-sidebar {
  width: 180px;
  min-width: 180px;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border-dark);
  min-height: 100vh;
  position: sticky;
  top: 56px;
  max-height: calc(100vh - 56px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--gold-dark) var(--bg-secondary);
  padding-bottom: 40px;
}

.fav-left-sidebar::-webkit-scrollbar { width: 4px; }
.fav-left-sidebar::-webkit-scrollbar-track { background: var(--bg-secondary); }
.fav-left-sidebar::-webkit-scrollbar-thumb { background: var(--gold-dark); }

/* サイドバーセクション */
.fav-sidebar-section {
  border-bottom: 1px solid var(--border-dark);
  padding-bottom: 8px;
  margin-bottom: 0;
}

/* セクション見出し */
.fav-sidebar-heading {
  font-size: 0.78rem;
  font-weight: bold;
  color: var(--gold);
  padding: 12px 14px 8px;
  letter-spacing: 0.03em;
  border-bottom: 1px solid var(--border-dark);
  display: flex;
  align-items: center;
  gap: 6px;
}

.fav-sidebar-icon { font-size: 0.85rem; }

/* カテゴリリスト */
.fav-cat-list {
  list-style: none;
  margin: 0;
  padding: 4px 0;
}

.fav-cat-list li a {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  font-size: 0.8rem;
  color: var(--text-primary);
  transition: background 0.15s, color 0.15s;
}

.fav-cat-list li a:hover {
  background: var(--bg-hover);
  color: var(--gold);
}

.fav-cat-icon { color: var(--gold-dark); font-size: 0.7rem; }

.fav-cat-count {
  margin-left: auto;
  font-size: 0.7rem;
  color: var(--text-muted);
}

/* タグリスト */
.fav-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 10px 12px;
}

.fav-tag-link {
  font-size: 0.72rem;
  padding: 3px 8px;
  border: 1px solid var(--border-dark);
  color: var(--text-muted);
  border-radius: 2px;
  transition: all 0.15s;
}

.fav-tag-link:hover {
  border-color: var(--gold);
  color: var(--gold);
}

/* お問い合わせ */
.fav-contact-link {
  display: block;
  padding: 12px 14px;
  font-size: 0.78rem;
  color: var(--text-muted);
  transition: color 0.2s;
}

.fav-contact-link:hover { color: var(--gold); }

/* ---- メインコンテンツ ---- */
.fav-main-content {
  flex: 1;
  min-width: 0;
  padding: 16px;
  background: var(--bg-primary);
}

/* タブ */
.fav-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border-gold);
  margin-bottom: 0;
  margin-left: 0;
}

/* 期間サブタブ */
.fav-period-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border-dark);
  margin-bottom: 16px;
  background: var(--bg-secondary);
}
.fav-period-tab {
  padding: 7px 18px;
  font-size: 0.8rem;
  color: var(--text-muted);
  border-bottom: 2px solid transparent;
  transition: color 0.2s;
  text-decoration: none;
}
.fav-period-tab.active,
.fav-period-tab:hover {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

.fav-tab {
  padding: 9px 20px;
  font-size: 0.85rem;
  color: var(--text-muted);
  border: 1px solid transparent;
  border-bottom: none;
  margin-bottom: -1px;
  transition: color 0.2s;
}

.fav-tab:hover { color: var(--gold); }

.fav-tab.active {
  color: var(--gold);
  border-color: var(--border-gold);
  border-bottom-color: var(--bg-primary);
  background: var(--bg-primary);
}

/* カードグリッド（PC: 4列） */
.fav-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 16px;
  margin-bottom: 24px;
}

/* カード */
.fav-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
  color: var(--text-primary);
}

.fav-card:hover {
  border-color: var(--border-gold);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(201,168,76,0.15);
  color: var(--gold-light);
}
/* タッチデバイスではhoverのtransformを無効化（タップ時の誤動作防止） */
@media (hover: none) {
  .fav-card:hover {
    transform: none;
    box-shadow: none;
  }
  .fav-card:hover .fav-thumb-img { transform: none; }
  .below-related-card:hover { transform: none; }
}

/* サムネイル */
.fav-card-thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
}

.fav-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s;
}

.fav-card:hover .fav-thumb-img { transform: scale(1.05); }

.fav-no-image {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  color: var(--text-muted);
  background: #111;
}

/* 再生時間バッジ */
.fav-duration {
  position: absolute;
  bottom: 4px;
  right: 4px;
  background: rgba(0,0,0,0.85);
  color: var(--gold);
  font-size: 0.68rem;
  padding: 2px 5px;
  font-weight: bold;
  border: 1px solid var(--gold-dark);
}

/* 再生ボタンアイコン */
.fav-play-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: rgba(255,255,255,0.0);
  font-size: 2rem;
  transition: color 0.2s;
  pointer-events: none;
}

.fav-card:hover .fav-play-icon { color: rgba(255,255,255,0.8); }

/* カードのカテゴリーバッジ */
.card-cat-badge {
  color: var(--gold);
  font-size: inherit;
  font-weight: inherit;
}

/* カードタイトル */
.fav-card-title {
  padding: 6px 8px 2px;
  font-size: 0.75rem;
  font-weight: bold;
  line-height: 1.4;
}

/* カード日付 */
.fav-card-date {
  padding: 2px 8px 7px;
  font-size: 0.68rem;
  color: var(--text-muted);
}

/* 投稿なし */
.fav-no-posts {
  grid-column: 1 / -1;
  text-align: center;
  padding: 60px 0;
  color: var(--text-muted);
  font-size: 0.9rem;
}

/* ページネーション */
.fav-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin: 20px 0 40px;
  flex-wrap: wrap;
}

.fav-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--border-dark);
  background: var(--bg-card);
  color: var(--text-primary);
  font-size: 0.85rem;
  white-space: nowrap;
  text-decoration: none;
  border-radius: 4px;
  transition: all 0.2s;
}

/* ... はボタンスタイルなし */
.fav-pagination .page-numbers.dots {
  background: none;
  border-color: transparent;
  color: var(--text-muted);
  pointer-events: none;
  padding: 0 4px;
}

/* 前へ・次へ は金色ボーダーで目立たせる */
.fav-pagination .page-numbers.prev,
.fav-pagination .page-numbers.next {
  border-color: var(--gold);
  color: var(--gold);
  font-weight: bold;
}

.fav-pagination .page-numbers.current,
.fav-pagination .page-numbers:hover {
  background: var(--gold);
  color: #000;
  border-color: var(--gold);
}

@media (max-width: 767px) {
  .fav-pagination .page-numbers { padding: 0 10px; font-size: 0.82rem; }
}

/* ============================================
   レスポンシブ（左サイドバーあり）
   ============================================ */
@media (max-width: 1199px) {
  .fav-card-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 991px) {
  .fav-card-grid { grid-template-columns: repeat(3, 1fr); }
  .fav-left-sidebar { width: 150px; min-width: 150px; }
}

@media (max-width: 767px) {
  /* SPレイアウト: 縦並び */
  .fav-layout-wrap { flex-direction: column; }

  /* SP: 左サイドバーを非表示（タブに移動） */
  .fav-left-sidebar { display: none !important; }

  /* SP: メインコンテンツ全幅 */
  .fav-main-content { padding: 0 8px 8px; width: 100%; }

  /* SP: タブを上部に固定 */
  .fav-tabs {
    position: sticky;
    top: 46px;
    z-index: 100;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-gold);
    overflow-x: auto;
    white-space: nowrap;
    display: flex;
    scrollbar-width: none;
  }
  .fav-tabs::-webkit-scrollbar { display: none; }
  .fav-tab { padding: 10px 14px; font-size: 0.8rem; flex-shrink: 0; }

  /* SP: カードグリッド 2列 */
  .fav-card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }


  /* SP: SPメニュータブバー */
  .sp-menu-bar {
    display: flex !important;
    position: sticky;
    top: 0;
    z-index: 200;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-gold);
    overflow-x: auto;
    scrollbar-width: none;
  }
  .sp-menu-bar::-webkit-scrollbar { display: none; }

  .sp-menu-tab {
    flex-shrink: 0;
    padding: 9px 14px;
    font-size: 0.75rem;
    color: var(--text-muted);
    border-right: 1px solid var(--border-dark);
    white-space: nowrap;
  }
  .sp-menu-tab.active,
  .sp-menu-tab:hover {
    color: var(--gold);
    background: var(--bg-hover);
  }

  /* SP: ヘッダーを小さく */
  .custom-site-title-wrap {
    height: 46px !important;
    padding: 0 10px !important;
    overflow: hidden;
  }
  .custom-header-logo { font-size: 0.95rem !important; }
  .site-logo-img { height: 36px !important; }

  /* SP: ヘッダー内検索を非表示（ページ内に移動） */
  .custom-header-search { display: none !important; }
}

/* PCとSP共通: ヘッダーとコンテンツの隙間を詰める */
body { padding-top: 0 !important; }
.custom-site-title-wrap + * { margin-top: 0 !important; }

/* Cocoonのスマホ底ナビ（ホーム・検索・トップ）を非表示 */
#the-sp-menu,
.the-sp-menu,
#sp-menu-box,
.sp-menu-box,
#the-return-to-top,
.return-to-top-btn,
#go-to-top-button,
.go-to-top-button,
.sp-navi-bar,
#sp-navi-bar,
[class*="sp-btn-"],
[id*="sp-btn-"] {
  display: none !important;
}

/* CookieAdminの青いボタンを非表示 */
.cookie-notice-container,
.cn-button,
#cookie-notice,
.cookie-consent,
[class*="cookie-admin"],
[id*="cookie-admin"],
.ca-button,
#ca-notice {
  display: none !important;
}

/* 左下の青いアイコン（CookieAdmin）を非表示 */
body > div[style*="position: fixed"][style*="bottom"],
body > div[style*="position:fixed"][style*="bottom"] {
  display: none !important;
}

/* PC: ヘッダー下の隙間を最小化 */
@media (min-width: 768px) {
  .fav-layout-wrap { margin-top: 0 !important; padding-top: 0 !important; }
  .sp-menu-bar { display: none; }
}

/* SP: ヘッダー下の黒い隙間を消す */
@media (max-width: 767px) {
  body { padding-top: 46px !important; }
  #wrapper,
  #container,
  .wrap,
  .site-content,
  #main,
  .main,
  #content,
  .content,
  #primary,
  .primary,
  #main-wrap,
  .main-wrap,
  #contents,
  .contents,
  .entry-content-wrap,
  .fav-layout-wrap {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
}

/* ============================================
   カスタムページ共通
   ============================================ */
.custom-page-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 16px 48px;
}
.custom-page-title {
  font-size: 1.2rem !important;
  color: var(--gold) !important;
  border-left: 3px solid var(--gold);
  padding-left: 12px !important;
  margin-bottom: 24px !important;
  border-bottom: none !important;
}

/* ジャンル一覧 */
.genre-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
}
.genre-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 8px;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: 4px;
  transition: all 0.2s;
  text-align: center;
  gap: 4px;
}
.genre-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.genre-name { font-size: 0.85rem; color: var(--text-primary); }
.genre-count { font-size: 0.7rem; color: var(--gold); }
@media (max-width: 767px) { .genre-grid { grid-template-columns: repeat(3, 1fr); } }

/* ランキング：期間タブ */
.ranking-period-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border-dark);
  margin-bottom: 20px;
}
.ranking-period-tab {
  padding: 8px 24px;
  font-size: 0.9rem;
  color: var(--text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color 0.2s;
}
.ranking-period-tab.active,
.ranking-period-tab:hover {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* ランキング：グリッドレイアウト */
.ranking-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.ranking-card {
  display: block;
  text-decoration: none;
  color: var(--text-primary);
  transition: opacity 0.2s;
}
.ranking-card:hover { opacity: 0.85; }
.ranking-card-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #111;
  border-radius: 3px;
}
.ranking-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* 順位バッジ */
.ranking-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  font-size: 1rem;
  font-weight: 900;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  background: rgba(0,0,0,0.7);
  color: #fff;
}
.rank-top-1 { background: #c9a84c; color: #000; }
.rank-top-2 { background: #aaaaaa; color: #000; }
.rank-top-3 { background: #cd7f32; color: #000; }
.ranking-card-info { padding: 6px 0; }
.ranking-card-title {
  font-size: 0.8rem;
  font-weight: bold;
  line-height: 1.4;
  margin-bottom: 4px;
}
.ranking-card-meta {
  font-size: 0.72rem;
  color: var(--text-muted);
  display: flex;
  gap: 10px;
}
.ranking-views { color: var(--gold-dark); }
@media (max-width: 991px) { .ranking-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .ranking-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; } }

/* ランキング（旧リスト形式 - 残存CSSのみ） */
.ranking-list { display: flex; flex-direction: column; gap: 8px; }
.ranking-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  padding: 10px 14px;
  border-radius: 4px;
  transition: border-color 0.2s;
}
.ranking-item:hover { border-color: var(--gold); }
.rank-num {
  font-size: 1.4rem;
  font-weight: 900;
  color: var(--text-muted);
  min-width: 36px;
  text-align: center;
}
.rank-num.rank-top { color: var(--gold); }
.rank-thumb { width: 80px; height: 56px; overflow: hidden; flex-shrink: 0; background: #111; }
.rank-thumb img { width: 100%; height: 100%; object-fit: cover; }
.rank-no-image { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 0.65rem; color: var(--text-muted); }
.rank-info { flex: 1; min-width: 0; }
.rank-title { font-size: 0.85rem; color: var(--text-primary); line-height: 1.4; margin-bottom: 4px; }
.rank-meta { font-size: 0.72rem; color: var(--text-muted); display: flex; gap: 12px; }
.rank-views { color: var(--gold-dark); }
@media (max-width: 767px) { .rank-thumb { width: 64px; height: 44px; } .rank-num { font-size: 1.1rem; min-width: 28px; } }

/* ページネーション（Cocoon標準を非表示） */
.home .pagination,
.home .nav-links,
.home .wp-pagenavi { display: none !important; }

/* カスタムページネーション */
.home-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 28px 0;
  flex-wrap: wrap;
}
.home-pager-arrow {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  background: var(--bg-card);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-size: 0.9rem;
  font-weight: bold;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}
.home-pager-arrow:hover { background: var(--gold); color: #000; }
.home-pager-arrow.disabled { opacity: 0.35; pointer-events: none; border-color: var(--border-dark); color: var(--text-muted); }
.home-pager-nums {
  display: flex;
  align-items: center;
  gap: 6px;
}
.home-pager-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  color: var(--text-primary);
  font-size: 0.9rem;
  border-radius: 4px;
  text-decoration: none;
  transition: border-color 0.2s, color 0.2s;
}
.home-pager-num:hover { border-color: var(--gold); color: var(--gold); }
.home-pager-ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 0.85rem;
  padding: 0 2px;
}
.home-pager-num.current {
  background: var(--gold);
  border-color: var(--gold);
  color: #000;
  font-weight: bold;
  pointer-events: none;
}
@media (max-width: 767px) {
  .home-pager-arrow { padding: 8px 12px; font-size: 0.85rem; }
  .home-pager-num { width: 34px; height: 34px; }
}

/* ホーム カテゴリーセクション */
.home-cat-section {
  margin-top: 32px;
  border-top: 1px solid var(--border-gold);
  padding-top: 16px;
}
.home-cat-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.home-cat-section-title {
  font-size: 1rem;
  font-weight: bold;
  color: var(--gold);
}
.home-cat-section-more {
  font-size: 0.8rem;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
}
.home-cat-section-more:hover { color: var(--gold); }
.home-cat-section-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 767px) {
  .home-cat-section-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}

/* 検索結果ヘッダー */
.search-result-header {
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-gold);
}
.search-result-query {
  font-size: 1.1rem;
  font-weight: bold;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.search-result-count {
  font-size: 0.8rem;
  color: var(--text-muted);
}
.search-no-result {
  padding: 40px 20px;
  text-align: center;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 2;
}

/* カレンダー */
.cal-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  gap: 12px;
}
.cal-current { font-size: 1rem; font-weight: bold; color: var(--gold); }
.cal-nav-btn {
  font-size: 0.8rem;
  color: var(--text-muted);
  padding: 6px 14px;
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  transition: all 0.2s;
  white-space: nowrap;
}
.cal-nav-btn:hover { color: var(--gold); border-color: var(--gold); }
.cal-nav-disabled { opacity: 0; pointer-events: none; }
.cal-grid-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  text-align: center;
  font-size: 0.75rem;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border-dark);
  padding-bottom: 6px;
  margin-bottom: 4px;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.cal-cell {
  min-height: 80px;
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  padding: 4px;
}
.cal-cell.cal-empty { background: transparent; border-color: transparent; }
.cal-cell.cal-has-posts { border-color: var(--gold-dark); }
.cal-day-num { font-size: 0.72rem; color: var(--text-muted); margin-bottom: 3px; }
.cal-day-posts { display: flex; flex-direction: column; gap: 3px; }
.cal-post-link { display: flex; gap: 4px; align-items: flex-start; }
.cal-post-link img { width: 36px; height: 24px; object-fit: cover; flex-shrink: 0; }
.cal-post-title { font-size: 0.65rem; color: var(--text-primary); line-height: 1.3; }
.cal-post-title:hover { color: var(--gold); }
@media (max-width: 767px) {
  .cal-cell { min-height: 50px; }
  .cal-post-link img { display: none; }
  .cal-post-title { font-size: 0.6rem; }
}

/* ============================================
   お問い合わせページ
   ============================================ */
.contact-wrap { max-width: 800px; margin: 0 auto; }

.contact-lead {
  background: var(--bg-card);
  border-left: 3px solid var(--gold);
  padding: 12px 16px;
  margin-bottom: 32px;
  font-size: 0.9rem;
  color: var(--text-primary);
}
.contact-lead p { margin: 0; }

.contact-form-box {
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: 4px;
  padding: 32px;
}

/* CF7 フィールドグループ */
.cf7-field-group {
  margin-bottom: 24px;
}
.cf7-field-group label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  font-weight: bold;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.cf7-required {
  background: var(--gold);
  color: #111;
  font-size: 0.65rem;
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 2px;
}

/* CF7 入力フィールド */
.contact-form-box .wpcf7-form-control.wpcf7-text,
.contact-form-box .wpcf7-form-control.wpcf7-email {
  width: 100%;
  background: var(--bg-secondary);
  border: 1px solid var(--border-dark);
  color: var(--text-primary);
  padding: 12px 14px;
  font-size: 0.9rem;
  border-radius: 2px;
  box-sizing: border-box;
  transition: border-color 0.2s;
}
.contact-form-box .wpcf7-form-control.wpcf7-text:focus,
.contact-form-box .wpcf7-form-control.wpcf7-email:focus {
  border-color: var(--gold);
  outline: none;
}
.contact-form-box .wpcf7-form-control.wpcf7-textarea {
  width: 100%;
  background: var(--bg-secondary);
  border: 1px solid var(--border-dark);
  color: var(--text-primary);
  padding: 12px 14px;
  font-size: 0.9rem;
  border-radius: 2px;
  box-sizing: border-box;
  min-height: 180px;
  resize: vertical;
  transition: border-color 0.2s;
}
.contact-form-box .wpcf7-form-control.wpcf7-textarea:focus {
  border-color: var(--gold);
  outline: none;
}

/* プレースホルダー */
.contact-form-box input::placeholder,
.contact-form-box textarea::placeholder { color: var(--text-muted); }

/* チェックボックス */
.cf7-acceptance {
  margin-bottom: 28px;
  font-size: 0.85rem;
  color: var(--text-muted);
}
.cf7-acceptance .wpcf7-list-item { margin: 0; }
.cf7-acceptance input[type="checkbox"] { accent-color: var(--gold); margin-right: 8px; }

/* 送信ボタン */
.contact-form-box .wpcf7-submit {
  display: block;
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
  background: var(--gold);
  color: #111;
  border: none;
  padding: 16px;
  font-size: 1rem;
  font-weight: bold;
  border-radius: 2px;
  cursor: pointer;
  transition: background 0.2s;
  letter-spacing: 0.05em;
}
.contact-form-box .wpcf7-submit:hover { background: var(--gold-light); }

/* バリデーションメッセージ */
.contact-form-box .wpcf7-not-valid-tip { color: #e63946; font-size: 0.75rem; margin-top: 4px; }
.contact-form-box .wpcf7-response-output {
  border: 1px solid var(--gold) !important;
  color: var(--gold) !important;
  background: rgba(201,168,76,0.1);
  padding: 12px 16px !important;
  margin-top: 16px !important;
  border-radius: 2px;
  font-size: 0.85rem;
}

@media (max-width: 767px) {
  .contact-form-box { padding: 20px 16px; }
}

/* ============================================
   SPドロワーメニュー
   ============================================ */
.sp-drawer-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.65);
  z-index: 9990;
}
.sp-drawer-overlay.open { display: block; }

.sp-drawer {
  position: fixed;
  top: 0;
  right: -100%;
  width: 100%;
  height: 100vh;
  background: var(--bg-secondary);
  z-index: 9995;
  overflow-y: auto;
  transition: right 0.3s ease;
}
.sp-drawer.open { right: 0; }

.sp-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid rgba(201,168,76,0.3);
}
.sp-drawer-logo {
  height: 30px;
  width: auto;
}
.sp-drawer-close {
  background: none;
  border: none;
  color: #ffffff;
  font-size: 1.4rem;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
}

.sp-drawer-nav {
  display: flex;
  flex-direction: column;
}
.sp-drawer-nav-item {
  display: block;
  text-align: center;
  padding: 22px 20px;
  font-size: 1.05rem;
  font-weight: 600;
  color: #ffffff !important;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  transition: background 0.15s, color 0.15s;
  letter-spacing: 0.05em;
}
.sp-drawer-nav-item:hover {
  background: rgba(201,168,76,0.2);
  color: var(--gold) !important;
}

/* トップページH1（SEO用・視覚的に非表示） */
.home-h1-seo {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ページ内検索バー（PC非表示、SP表示） */
.fav-page-search {
  display: none;
}
@media (max-width: 767px) {
  .fav-page-search {
    display: block;
    padding: 24px 0 24px;
  }
  .fav-page-search form {
    display: flex;
    border: 1px solid var(--border-gold);
    overflow: hidden;
    background: var(--bg-card);
    height: 32px;
  }
  .fav-page-search input[type="search"] {
    border: none !important;
    background: transparent !important;
    color: var(--text-primary) !important;
    padding: 0 12px;
    height: 100%;
    flex: 1;
    outline: none;
    font-size: 0.85rem;
  }
  .fav-page-search input[type="search"]::placeholder { color: var(--text-muted); }
  .fav-page-search button {
    background: var(--gold) !important;
    color: #000 !important;
    border: none !important;
    padding: 0 14px;
    height: 100%;
    cursor: pointer;
    font-size: 0.9rem;
  }
}

/* ヘッダー右側ナビリンク（PC） */
.header-nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
  margin-left: auto;
}

/* PC時はSP用ボタングループを非表示（margin-left:autoによる右端占有を防ぐ） */
@media (min-width: 768px) {
  .header-right-btns {
    display: none;
  }
  /* ナビ右端を画面端ギリギリに寄せる（コンテナpadding 20px を相殺） */
  .header-nav-links {
    margin-right: -20px;
  }
  .header-nav-links .hnl-item:last-child {
    border-radius: 2px;
  }
}
.hnl-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  color: var(--text-muted);
  padding: 5px 10px;
  border: 1px solid var(--border-dark);
  border-radius: 2px;
  white-space: nowrap;
  transition: all 0.2s;
  text-align: center;
}
.hnl-item:hover {
  color: var(--gold);
  border-color: var(--gold);
  background: rgba(201,168,76,0.08);
}
@media (max-width: 767px) {
  .header-nav-links { display: none; }
}

/* SP: ••• ボタン（デフォルト非表示） */
.sp-dots-btn {
  display: none;
}

/* SP: ハンバーガーボタン表示 */
@media (max-width: 767px) {
  .sp-hamburger {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: none;
    border: 1px solid var(--gold);
    color: var(--gold);
    font-size: 1.1rem;
    width: 36px;
    height: 36px;
    cursor: pointer;
    flex-shrink: 0;
    border-radius: 2px;
    margin-left: auto;
  }

  /* ••• ボタン */
  .sp-dots-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.2rem;
    letter-spacing: 1px;
    cursor: pointer;
    padding: 4px 2px;
    flex-shrink: 0;
    margin-left: 0;
  }
  .sp-dots-btn:hover { color: var(--gold); }
}

/* •••パネル オーバーレイ */
.sp-dots-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.6);
  z-index: 9980;
}
.sp-dots-overlay.open { display: block; }

/* •••パネル本体 */
.sp-dots-panel {
  position: fixed;
  top: 46px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-secondary);
  z-index: 9985;
  overflow-y: auto;
  transform: translateY(-110%);
  transition: transform 0.3s ease;
}
.sp-dots-panel.open { transform: translateY(0); }

.sp-dots-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-gold);
  position: sticky;
  top: 0;
  background: var(--bg-secondary);
  z-index: 1;
}
.sp-dots-panel-title {
  font-size: 0.85rem;
  font-weight: bold;
  color: var(--gold);
}
.sp-dots-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 4px 8px;
}
.sp-dots-close:hover { color: var(--gold); }

.sp-dots-section {
  border-bottom: 1px solid var(--border-dark);
  padding: 12px 16px;
}
.sp-dots-heading {
  font-size: 0.75rem;
  font-weight: bold;
  color: var(--gold);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sp-dots-cat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sp-dots-cat-list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 4px;
  font-size: 0.85rem;
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-dark);
  transition: color 0.15s;
}
.sp-dots-cat-list li:last-child a { border-bottom: none; }
.sp-dots-cat-list li a:hover { color: var(--gold); }
.sp-dots-count {
  font-size: 0.7rem;
  color: var(--text-muted);
}
.sp-dots-tag-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sp-dots-tag {
  font-size: 0.72rem;
  padding: 4px 10px;
  border: 1px solid var(--border-dark);
  color: var(--text-muted);
  border-radius: 20px;
  transition: all 0.15s;
}
.sp-dots-tag:hover {
  border-color: var(--gold);
  color: var(--gold);
}
