@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/


/* ============================================
   M-DEN カスタムテーマ CSS
   Cocoon テーマ用 追加CSS
   コンセプト: 白ベース × 上品 = 大人のセレクトショップ
   ============================================ */
:root {
  --mden-bg-primary: #ffffff;
  --mden-bg-secondary: #f7f7f8;
  --mden-bg-card: #ffffff;
  --mden-bg-card-hover: #fafafa;
  --mden-accent-red: #c0392b;
  --mden-accent-wine: #8e2430;
  --mden-accent-gold: #b8860b;
  --mden-text-primary: #2c2c2c;
  --mden-text-secondary: #555555;
  --mden-text-muted: #999999;
  --mden-border: #e0e0e0;
  --mden-shadow: rgba(0, 0, 0, 0.08);
}
body {
  background-color: var(--mden-bg-primary);
  color: var(--mden-text-primary);
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
}
.header, #header, .site-header-logo, #header-in {
  background-color: var(--mden-bg-secondary);
  border-bottom: 1px solid var(--mden-border);
}
.site-name-text, .header-in .site-name-text a {
  color: var(--mden-text-primary);
  font-weight: 700;
  letter-spacing: 2px;
}
.site-name-text::first-letter { color: var(--mden-accent-red); }
#navi, .navi-in, .mobile-menu-buttons {
  background-color: var(--mden-bg-secondary);
  border-bottom: 2px solid var(--mden-accent-red);
}
#navi a, .navi-in a { color: var(--mden-text-primary); transition: color 0.3s ease; }
#navi a:hover, .navi-in a:hover { color: var(--mden-accent-red); }
#content, .content-in, #main { background-color: transparent; }
.entry-card, .entry-card-wrap, .post-list .entry-card-wrap {
  background-color: var(--mden-bg-card);
  border: 1px solid var(--mden-border);
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.entry-card:hover, .entry-card-wrap:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px var(--mden-shadow);
  border-color: var(--mden-accent-red);
}
.entry-card-title, .entry-card-title a { color: var(--mden-text-primary); font-weight: 700; }
.entry-card-snippet { color: var(--mden-text-secondary); }
.entry-card-meta, .entry-card-info { color: var(--mden-text-muted); }

.article, .article-header, .article-body {
  background-color: var(--mden-bg-card); color: var(--mden-text-primary);
  border-radius: 8px; padding: 30px;
}
.article h1, .article h2, .article h3, .article h4 { color: var(--mden-text-primary); }
.article h2 { border-bottom: 3px solid var(--mden-accent-red); padding-bottom: 10px; margin-top: 40px; }
.article h3 { border-left: 4px solid var(--mden-accent-gold); padding-left: 12px; }
.article a { color: var(--mden-accent-red); text-decoration: none; transition: color 0.3s ease; }
.article a:hover { color: var(--mden-accent-wine); text-decoration: underline; }
#sidebar, .sidebar { background-color: transparent; }
.widget, #sidebar .widget {
  background-color: var(--mden-bg-card); border: 1px solid var(--mden-border);
  border-radius: 8px; padding: 20px; margin-bottom: 20px;
}
.widget-title, .widget_title {
  color: var(--mden-accent-wine); font-weight: 700;
  border-bottom: 2px solid var(--mden-border); padding-bottom: 8px; margin-bottom: 15px;
}
.widget a { color: var(--mden-text-secondary); transition: color 0.3s ease; }
.widget a:hover { color: var(--mden-accent-red); }
.cat-label, .category-label {
  background-color: var(--mden-accent-red); color: #fff;
  border-radius: 3px; font-size: 11px; padding: 2px 8px;
}
.tag-link, .tagcloud a {
  background-color: var(--mden-bg-secondary); color: var(--mden-text-secondary);
  border: 1px solid var(--mden-border); border-radius: 15px;
  padding: 4px 12px; font-size: 12px; transition: all 0.3s ease;
}
.tag-link:hover, .tagcloud a:hover {
  background-color: var(--mden-accent-red); color: #fff; border-color: var(--mden-accent-red);
}
.btn, .btn-red, .ranking-item-link-buttons a, .blogcard-readmore {
  background: var(--mden-accent-red); color: #fff; border: none;
  border-radius: 5px; padding: 10px 25px; font-weight: 700;
  transition: all 0.3s ease; text-decoration: none;
}
.btn:hover, .btn-red:hover, .ranking-item-link-buttons a:hover, .blogcard-readmore:hover {
  background: var(--mden-accent-wine); transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(192, 57, 43, 0.2);
}
.btn-gold, .fanza-link {
  background: var(--mden-accent-red); color: #fff; font-weight: 700;
  border-radius: 5px; padding: 12px 30px; display: inline-block;
  text-align: center; transition: all 0.3s ease; text-decoration: none;
}
.btn-gold:hover, .fanza-link:hover {
  background: var(--mden-accent-wine); transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(192, 57, 43, 0.2);
}
.star-rating { color: var(--mden-accent-gold); }

.pagination, .page-numbers {
  background-color: var(--mden-bg-card); color: var(--mden-text-primary);
  border: 1px solid var(--mden-border);
}
.page-numbers.current { background-color: var(--mden-accent-red); color: #fff; border-color: var(--mden-accent-red); }
#footer, .footer, .footer-in {
  background-color: var(--mden-bg-secondary); color: var(--mden-text-muted);
  border-top: 2px solid var(--mden-border);
}
#footer a, .footer a { color: var(--mden-text-secondary); }
.search-box, .search-edit {
  background-color: var(--mden-bg-card); color: var(--mden-text-primary);
  border: 1px solid var(--mden-border); border-radius: 5px;
}
.search-submit { background-color: var(--mden-accent-red); color: #fff; border: none; }
.toc, .toc-content {
  background-color: var(--mden-bg-secondary); border: 1px solid var(--mden-border); border-radius: 8px;
}
.toc-title { color: var(--mden-accent-wine); }
.toc a { color: var(--mden-text-secondary); }
.blogcard { background-color: var(--mden-bg-card); border: 1px solid var(--mden-border); border-radius: 8px; }
.blogcard:hover { border-color: var(--mden-accent-red); }
.related-entries { background-color: transparent; }
.related-entry-card { background-color: var(--mden-bg-card); border: 1px solid var(--mden-border); border-radius: 8px; }
.comment-area { background-color: var(--mden-bg-card); border-radius: 8px; padding: 20px; }
.comment-body { border-bottom: 1px solid var(--mden-border); }
@media (max-width: 768px) {
  .article { padding: 15px; }
  .widget { padding: 15px; }
  .fanza-link { width: 100%; text-align: center; }
}
.ranking-item {
  background-color: var(--mden-bg-card); border: 1px solid var(--mden-border);
  border-radius: 8px; margin-bottom: 20px; padding: 20px;
}
.ranking-item-name { color: var(--mden-accent-wine); font-size: 1.2em; font-weight: 700; }
.ranking-item-img-desc { color: var(--mden-text-secondary); }
.ranking-item-link-buttons { text-align: center; margin-top: 15px; }
.favorite-btn { color: var(--mden-text-muted); cursor: pointer; font-size: 1.5em; transition: color 0.3s ease; }
.favorite-btn:hover, .favorite-btn.active { color: var(--mden-accent-red); }

/* ============================================
   記事テンプレート共通スタイル
   ============================================ */
.mden-table { width: 100%; border-collapse: collapse; background: var(--mden-bg-secondary); border-radius: 8px; overflow: hidden; margin: 15px 0; }
.mden-table tr { border-bottom: 1px solid var(--mden-border); }
.mden-table tr:last-child { border-bottom: none; }
.mden-table td { padding: 10px 14px; color: var(--mden-text-primary); }
.mden-table-label { width: 25%; color: var(--mden-text-muted); font-size: 13px; }
.mden-table-rating { color: var(--mden-accent-gold); font-weight: 700; }
.mden-note { background: var(--mden-bg-secondary); border-left: 4px solid var(--mden-accent-gold); padding: 15px 20px; margin: 20px 0; border-radius: 0 8px 8px 0; }
.mden-note strong { color: var(--mden-accent-wine); }
.mden-note-red { border-left-color: var(--mden-accent-red); }
.mden-note-red strong { color: var(--mden-accent-red); }
.mden-cta { background: var(--mden-bg-secondary); border: 1px solid var(--mden-border); border-radius: 8px; padding: 25px; text-align: center; margin: 20px 0; }
.mden-cta-title { font-size: 1.1em; margin-bottom: 15px; }
.mden-caption { font-size: 12px; color: var(--mden-text-muted); }
.mden-caption a { color: var(--mden-accent-red); }
.mden-video { position: relative; width: 100%; padding-bottom: 56.25%; margin: 20px 0 5px; border-radius: 8px; overflow: hidden; background: #000; }
.mden-video iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* ============================================
   作品一覧グリッド
   ============================================ */
.mden-list-header { text-align: center; margin-bottom: 30px; color: var(--mden-text-secondary); }
.mden-search { position: relative; width: 260px; }
.mden-search-input { width: 100%; padding: 8px 36px 8px 14px; border: 1px solid var(--mden-border); border-radius: 20px; background: var(--mden-bg-card); color: var(--mden-text-primary); font-size: 13px; font-family: inherit; outline: none; transition: border-color 0.3s ease, box-shadow 0.3s ease; }
.mden-search-input::placeholder { color: var(--mden-text-muted); }
.mden-search-input:focus { border-color: var(--mden-accent-red); box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.1); }
.mden-search-btn { position: absolute; right: 4px; top: 50%; transform: translateY(-50%); background: none; border: none; padding: 6px 8px; cursor: pointer; color: var(--mden-text-muted); transition: color 0.3s ease; display: flex; align-items: center; }
.mden-search-btn:hover { color: var(--mden-accent-red); }
.mden-search-btn svg { width: 16px; height: 16px; }
.mden-toolbar { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 40px; }
.mden-filter { display: flex; flex-wrap: wrap; gap: 8px; flex: 1; }
.mden-sort { flex-shrink: 0; padding-top: 2px; }
.mden-sort-select { appearance: none; color: var(--mden-text-secondary); border: 1px solid var(--mden-border); border-radius: 6px; padding: 7px 32px 7px 14px; font-size: 13px; font-family: inherit; cursor: pointer; transition: border-color 0.3s ease; }
.mden-sort-select:hover, .mden-sort-select:focus { border-color: var(--mden-accent-red); outline: none; }
.mden-filter-btn { background: var(--mden-bg-card); color: var(--mden-text-secondary); border: 1px solid var(--mden-border); border-radius: 20px; padding: 6px 18px; font-size: 13px; cursor: pointer; transition: all 0.3s ease; }
.mden-filter-btn:hover, .mden-filter-btn.active { background: var(--mden-accent-red); color: #fff; border-color: var(--mden-accent-red); }
.mden-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-bottom: 50px; }
.mden-card { display: block; text-decoration: none; color: inherit; transition: transform 0.3s ease; }
.mden-card:hover { transform: translateY(-4px); }
.mden-card-img { width: 100%; aspect-ratio: 7 / 10; overflow: hidden; border-radius: 8px; background: var(--mden-bg-secondary); }
.mden-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.mden-card:hover .mden-card-img img { transform: scale(1.03); }
.mden-card-body { padding: 12px 2px 0; }
.mden-card-title { font-size: 14px; font-weight: 700; color: var(--mden-text-primary); margin: 0 0 6px; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mden-card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; font-size: 12px; }
.mden-card-actress { color: var(--mden-text-secondary); }
.mden-card-rating { color: var(--mden-accent-gold); font-weight: 700; }
.mden-card-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.mden-tag { background: var(--mden-bg-secondary); color: var(--mden-text-muted); font-size: 11px; padding: 2px 8px; border-radius: 10px; cursor: pointer; transition: all 0.3s ease; text-decoration: none; }
.mden-tag:hover { background: var(--mden-accent-red); color: #fff; }
.mden-pagination { display: flex; justify-content: center; gap: 8px; margin: 40px 0; }
.mden-page { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; border: 1px solid var(--mden-border); border-radius: 6px; font-size: 14px; color: var(--mden-text-secondary); text-decoration: none; transition: all 0.3s ease; }
.mden-page:hover { border-color: var(--mden-accent-red); color: var(--mden-accent-red); }
.mden-page.current { background: var(--mden-accent-red); color: #fff; border-color: var(--mden-accent-red); }
@media (max-width: 768px) {
  .mden-search { width: 100%; order: -1; }
  .mden-toolbar { flex-direction: column; align-items: stretch; }
  .mden-sort { align-self: flex-end; }
  .mden-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .mden-card-title { font-size: 13px; }
}
@media (max-width: 480px) {
  .mden-grid { gap: 12px; }
  .mden-card-body { padding: 8px 0 0; }
  .mden-card-title { font-size: 12px; }
  .mden-card-meta { font-size: 11px; }
  .mden-filter { gap: 6px; margin-bottom: 25px; }
  .mden-filter-btn { padding: 5px 12px; font-size: 12px; }
}
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--mden-bg-secondary); }
::-webkit-scrollbar-thumb { background: var(--mden-border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--mden-text-muted); }


/* ==========================================
   サイドバー ダークテーマ CSS
   ========================================== */

/* サイドバー全体 */
#sidebar, .sidebar {
  color: #ccc;
}

/* サイドバーウィジェットの背景・ボーダー */
.sidebar .widget-sidebar,
#sidebar .widget {
  background: #1a1a1a !important;
  border: 1px solid #333 !important;
  border-radius: 8px;
  padding: 20px !important;
  margin-bottom: 20px;
}

/* ウィジェット見出し h4 */
.sidebar .widget-sidebar h4,
.sidebar .widget h4,
#sidebar .wp-block-heading {
  color: #c9a84c !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border-bottom: 2px solid #8B0000 !important;
  padding-bottom: 10px !important;
  margin-bottom: 15px !important;
  background: none !important;
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
}

/* サイドバー本文テキスト */
#sidebar p,
.sidebar .widget p {
  color: #ccc !important;
}

/* サイドバーのリンク */
#sidebar a,
.sidebar .widget a {
  color: #e0e0e0 !important;
  text-decoration: none !important;
  transition: color 0.3s ease;
}
#sidebar a:hover,
.sidebar .widget a:hover {
  color: #c9a84c !important;
}

/* おすすめ記事リスト */
#sidebar .wp-block-list li {
  padding: 8px 0;
  border-bottom: 1px solid #333;
}
#sidebar .wp-block-list li:last-child {
  border-bottom: none;
}

/* 人気記事ランキング（Latest Posts with thumbnails） */
#sidebar .wp-block-latest-posts {
  list-style: none !important;
  padding: 0 !important;
}
#sidebar .wp-block-latest-posts li {
  padding: 12px 0 !important;
  border-bottom: 1px solid #333 !important;
  margin-bottom: 0 !important;
}
#sidebar .wp-block-latest-posts li:last-child {
  border-bottom: none !important;
}
#sidebar .wp-block-latest-posts__post-title {
  color: #e0e0e0 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
}
#sidebar .wp-block-latest-posts__post-date {
  color: #888 !important;
  font-size: 12px !important;
}
#sidebar .wp-block-latest-posts__featured-image img {
  border-radius: 4px;
}

/* カテゴリーウィジェット */
#sidebar .wp-block-categories li {
  padding: 6px 0;
  border-bottom: 1px solid #333;
}
#sidebar .wp-block-categories li:last-child {
  border-bottom: none;
}

/* 検索ボックス */
#sidebar .wp-block-search__input {
  background: #2a2a2a !important;
  border: 1px solid #444 !important;
  color: #fff !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
}
#sidebar .wp-block-search__input::placeholder {
  color: #888 !important;
}
#sidebar .wp-block-search__button {
  background: #8B0000 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 10px 18px !important;
  cursor: pointer;
  transition: background 0.3s ease;
}
#sidebar .wp-block-search__button:hover {
  background: #a50000 !important;
}

/* FANZAボタン */
#sidebar .wp-block-button__link {
  background: #8B0000 !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  padding: 14px 20px !important;
  border-radius: 8px !important;
  transition: all 0.3s ease;
}
#sidebar .wp-block-button__link:hover {
  background: #a50000 !important;
  transform: translateY(-1px);
}

/* スクロール追従エリア */
.sidebar-scroll .widget,
#sidebar-scroll .widget {
  background: #1a1a1a !important;
  border: 1px solid #333 !important;
  border-radius: 8px;
  padding: 20px !important;
}
.sidebar-scroll h4,
#sidebar-scroll .wp-block-heading {
  color: #c9a84c !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border-bottom: 2px solid #8B0000 !important;
  padding-bottom: 10px !important;
  margin-bottom: 15px !important;
  background: none !important;
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
}
#sidebar-scroll .wp-block-button__link {
  background: #8B0000 !important;
  color: #fff !important;
  font-weight: 700 !important;
}
#sidebar-scroll .wp-block-button__link:hover {
  background: #a50000 !important;
}

/* プロフィールウィジェット 中央揃え */
#sidebar .widget:first-child {
  text-align: center;
}
#sidebar .widget:first-child strong {
  color: #fff !important;
  font-size: 16px;
}

/* スマホ対応: サイドバーの余白調整 */
@media (max-width: 834px) {
  .sidebar .widget-sidebar,
  #sidebar .widget {
    padding: 15px !important;
    margin-bottom: 15px;
  }
}

/* 目次（TOC）ダークテーマ - サイドバー内 */
#sidebar .toc,
.sidebar-scroll .toc,
#sidebar-scroll .toc {
  background: #2a2a2a !important;
  border: 1px solid #444 !important;
  border-radius: 6px !important;
  color: #ccc !important;
}
#sidebar .toc-title,
.sidebar-scroll .toc-title,
#sidebar-scroll .toc-title {
  color: #fff !important;
}
#sidebar .toc a,
.sidebar-scroll .toc a,
#sidebar-scroll .toc a {
  color: #bbb !important;
}
#sidebar .toc a:hover,
.sidebar-scroll .toc a:hover,
#sidebar-scroll .toc a:hover {
  color: #c9a84c !important;
}
#sidebar .toc-content li,
.sidebar-scroll .toc-content li,
#sidebar-scroll .toc-content li {
  color: #bbb !important;
}

/* ============================================================
   一覧ページ サムネイル表示調整
   ============================================================ */
/* エントリーカードのサムネイル - 枠内に中央寄せで表示 */
.entry-card-thumb {
  overflow: hidden !important;
}
.entry-card-thumb img {
  object-fit: cover !important;
  object-position: center top !important;
  width: 100% !important;
  height: 100% !important;
}

/* 記事詳細ページのメイン画像 */
.mden-detail img {
  max-width: 100%;
  height: auto;
}
