/*
Theme Name: Cocoon Child
Template: cocoon-master
Version: 1.0.0
Description: fanzw.com カスタム子テーマ（ライト系）
*/

/* ===================================
   カラー変数
   =================================== */
:root {
  --color-bg: #f8f8f8;
  --color-surface: #ffffff;
  --color-surface2: #f2f2f2;
  --color-border: #e0e0e0;
  --color-text: #333333;
  --color-text-muted: #888888;
  --color-accent: #e8003d;
  --color-accent-dark: #a50029;
  --color-blue: #0066cc;
  --color-blue-dark: #004a99;
  --color-orange: #ff6600;
}

/* ===================================
   ベース
   =================================== */
body {
  background: var(--color-bg) !important;
  color: var(--color-text) !important;
}

#wrapper, .site-content-inner, .content-in {
  background: var(--color-bg) !important;
}

/* ===================================
   ヘッダー
   =================================== */
#header-container, #header-container-in, #header-in,
#header {
  background: #fff !important;
  border-bottom: 2px solid var(--color-accent) !important;
  color: var(--color-text) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08) !important;
}

#header a, #header .site-name-text {
  color: var(--color-text) !important;
}

#header .tagline {
  color: var(--color-text-muted) !important;
  font-size: 0.8em;
}

/* ===================================
   グローバルナビ
   =================================== */
#navi, .navi-in {
  background: #fff !important;
  border-bottom: 1px solid var(--color-border) !important;
}

#navi a {
  color: var(--color-text) !important;
}

#navi a:hover {
  color: var(--color-accent) !important;
  background: var(--color-surface2) !important;
}

/* ===================================
   メインコンテンツエリア
   =================================== */
#main, .main-section, .entry-content {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
}

.entry-content h2,
.article h2, .article h3, .article h4,
h2.wp-block-heading, h3.wp-block-heading {
  background: var(--color-surface2) !important;
  color: var(--color-text) !important;
}

.entry-content h2 {
  border-left: 4px solid var(--color-accent);
  padding-left: 12px;
  color: var(--color-text);
}

.entry-content h3 {
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: 6px;
  color: var(--color-text);
  background: transparent !important;
}

.entry-content a {
  color: var(--color-blue);
}

.entry-content p {
  line-height: 1.9;
}

/* ===================================
   サイドバー
   =================================== */
#sidebar, .sidebar-in {
  background: var(--color-bg) !important;
}

.widget_title, .widget-title {
  background: var(--color-surface2) !important;
  color: var(--color-text) !important;
  border-left: 3px solid var(--color-accent) !important;
  padding: 8px 12px !important;
}

/* ===================================
   カード・記事一覧
   =================================== */
.post-list-item, .card-wrap, .card-meta {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
}

.post-list-item:hover {
  border-color: var(--color-accent) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
}

.card-title a, .entry-title a {
  color: var(--color-text) !important;
}

/* ===================================
   モバイル底部ナビ
   =================================== */
.mobile-footer-menu-buttons, .mobile-menu-buttons,
#mobile-footer-menu {
  background: #fff !important;
  border-top: 1px solid var(--color-border) !important;
}

.mobile-footer-menu-buttons a, .mobile-menu-buttons a,
.mobile-footer-menu-buttons button, .mobile-menu-buttons button {
  color: var(--color-text) !important;
}

/* サイドバースライドメニュー */
#sidebar-menu-content, .sidebar-menu-content {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
}

/* 検索フォーム */
.wp-block-search__input, .search-edit {
  background: var(--color-surface2) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

/* ===================================
   フッター
   =================================== */
#footer {
  background: #f0f0f0 !important;
  border-top: 1px solid var(--color-border) !important;
  color: var(--color-text-muted) !important;
}

#footer a {
  color: var(--color-text-muted) !important;
}

#footer a:hover {
  color: var(--color-accent) !important;
}

/* ===================================
   CTAボタン
   =================================== */
.cta-primary {
  display: block;
  background: var(--color-accent);
  color: #fff !important;
  text-align: center;
  padding: 16px 20px;
  border-radius: 6px;
  font-size: 1.1em;
  font-weight: bold;
  text-decoration: none;
  margin: 20px 0;
  border-bottom: 4px solid var(--color-accent-dark);
  transition: opacity 0.2s;
}
.cta-primary:hover { opacity: 0.85; text-decoration: none; }

.cta-secondary {
  display: block;
  background: var(--color-blue);
  color: #fff !important;
  text-align: center;
  padding: 14px 20px;
  border-radius: 6px;
  font-size: 1em;
  font-weight: bold;
  text-decoration: none;
  margin: 16px 0;
  border-bottom: 4px solid var(--color-blue-dark);
  transition: opacity 0.2s;
}
.cta-secondary:hover { opacity: 0.85; text-decoration: none; }

.cta-btn.is-pending {
  display: block;
  background: #e8e8e8;
  color: #aaa !important;
  text-align: center;
  padding: 14px 20px;
  border-radius: 6px;
  font-size: 1em;
  font-weight: bold;
  margin: 16px 0;
  border-bottom: 4px solid #d0d0d0;
  cursor: not-allowed;
  user-select: none;
}

.cta-sub {
  display: block;
  background: var(--color-orange);
  color: #fff !important;
  text-align: center;
  padding: 12px 20px;
  border-radius: 6px;
  font-size: 0.95em;
  font-weight: bold;
  text-decoration: none;
  margin: 12px 0;
  border-bottom: 4px solid #cc5200;
  transition: opacity 0.2s;
}
.cta-sub:hover { opacity: 0.85; text-decoration: none; }

/* 18禁注記 */
.notice-18 {
  font-size: 0.78em;
  color: var(--color-text-muted);
  text-align: center;
  margin-top: 4px;
}

/* 広告表記 */
.ad-disclosure {
  font-size: 0.75em;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  padding: 3px 8px;
  border-radius: 3px;
  display: inline-block;
  margin-bottom: 8px;
  background: var(--color-surface2);
}

/* ===================================
   比較テーブル
   =================================== */
.compare-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 0.95em;
  background: var(--color-surface);
}
.compare-table th {
  background: var(--color-accent);
  color: #fff;
  padding: 12px 10px;
  text-align: center;
  border: 1px solid var(--color-border);
}
.compare-table td {
  padding: 10px;
  border: 1px solid var(--color-border);
  text-align: center;
  vertical-align: middle;
  color: var(--color-text);
}
.compare-table tr.rank-1 td {
  background: #fff5f7;
  border-color: var(--color-accent);
}
.compare-table tr:hover td {
  background: var(--color-surface2);
}

/* ===================================
   CTAボックス（blockquote変換）
   =================================== */
.cta-box {
  border: 1px solid var(--color-border) !important;
  background: var(--color-surface2) !important;
  border-radius: 6px;
  padding: 14px 16px;
  margin: 16px 0;
  line-height: 1.8;
  color: var(--color-text) !important;
}

/* ===================================
   年齢認証ゲート（Age Gate 3.7.x）
   =================================== */
.age-gate__wrapper {
  background: rgba(0, 0, 0, 0.7) !important;
  z-index: 99999;
}

.age-gate__background-color {
  background: transparent !important;
}

.age-gate {
  background: #fff !important;
  border: 1px solid var(--color-border) !important;
  border-top: 3px solid var(--color-accent) !important;
  border-radius: 12px !important;
  padding: 48px 40px !important;
  max-width: 420px !important;
  width: 90% !important;
  text-align: center !important;
  box-shadow: 0 8px 40px rgba(0,0,0,0.2) !important;
  color: var(--color-text) !important;
}

.age-gate__heading-title {
  font-size: 1.6em !important;
  font-weight: bold !important;
  color: var(--color-text) !important;
  margin-bottom: 8px !important;
}

.age-gate__subheadline {
  color: var(--color-text-muted) !important;
  margin-bottom: 8px !important;
}

.age-gate__challenge {
  font-size: 1em !important;
  color: var(--color-text) !important;
  margin-bottom: 24px !important;
}

.age-gate__buttons {
  display: flex !important;
  gap: 14px !important;
  justify-content: center !important;
  margin-top: 8px !important;
}

.age-gate__submit {
  flex: 1 !important;
  max-width: 160px !important;
  padding: 14px 0 !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 1em !important;
  font-weight: bold !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
}

.age-gate__submit--yes {
  background: var(--color-accent) !important;
  color: #fff !important;
  border-bottom: 3px solid var(--color-accent-dark) !important;
}

.age-gate__submit--no {
  background: var(--color-surface2) !important;
  color: var(--color-text-muted) !important;
  border: 1px solid var(--color-border) !important;
}

.age-gate__submit:hover { opacity: 0.82 !important; }

.age-gate__remember-wrapper {
  margin-top: 20px !important;
  font-size: 0.82em !important;
  color: var(--color-text-muted) !important;
}

/* ===================================
   非表示要素
   =================================== */
.sns-follow { display: none !important; }
/* 著者情報（鉛筆アイコン・バイライン・著者ボックス）を非表示 */
.author-info, .author-box, .author-widget-area,
.author-name, .author-link { display: none !important; }

/* ===================================
   固定ページ用テーブル
   =================================== */
.page-info-table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
}
.page-info-table th,
.page-info-table td {
  padding: 12px 16px;
  border: 1px solid var(--color-border);
  text-align: left;
  vertical-align: top;
}
.page-info-table th {
  background: var(--color-surface2);
  color: var(--color-text-muted);
  width: 30%;
  font-weight: normal;
}
.page-info-table td {
  background: var(--color-surface);
  color: var(--color-text);
}
