@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Template: cocoon-master
Version: 1.0.0
*/

/* ===================================================
   TCG RATE - 子テーマ CSS (クリーン版)
=================================================== */

/* CSS変数 */
:root {
  --tcg-bg: #0F172A;
  --tcg-card-bg: #1E293B;
  --tcg-card-bg-alt: #111827;
  --tcg-accent: #F97316;
  --tcg-accent-sub: #22C55E;
  --tcg-text: #F8FAFC;
  --tcg-text-sub: #94A3B8;
  --tcg-border: #334155;
  --tcg-up: #22C55E;
  --tcg-down: #EF4444;
}

/* ===== サイト全体 ===== */
body {
  background-color: var(--tcg-bg) !important;
  color: var(--tcg-text);
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;
}

#content, .content, .content-in, .main {
  background-color: var(--tcg-bg) !important;
}

a { color: var(--tcg-accent); }

/* ===== ヘッダー：ロゴ左端 ===== */
#header,
#header-container {
  background-color: var(--tcg-card-bg-alt) !important;
  border-bottom: 1px solid var(--tcg-border) !important;
  padding: 0 !important;
}

/* Cocoon親テーマの .header-in { justify-content: center; text-align: center; } を上書き */
.header-in,
#header-in,
.header .header-in {
  justify-content: flex-start !important;
  align-items: center !important;
  text-align: left !important;
  padding: 10px 32px !important;
  min-height: unset !important;
  height: auto !important;
  box-sizing: border-box !important;
}

.logo,
.logo.logo-header {
  text-align: left !important;
  margin: 0 !important;
}

.tagline { display: none !important; }

/* ロゴ画像サイズ */
.site-logo-image,
.header-site-logo-image {
  width: 500px !important;
  max-width: 500px !important;
  height: auto !important;
  display: block !important;
}

/* ===== ナビ ===== */
#navi {
  background-color: var(--tcg-card-bg-alt) !important;
  border-bottom: 1px solid var(--tcg-border) !important;
}

#navi-in.wrap {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 32px !important;
}

.navi a, .menu-top a {
  color: var(--tcg-text) !important;
}

.navi a:hover, .menu-top a:hover {
  color: var(--tcg-accent) !important;
}

/* ===== フッター ===== */
.footer, #footer, .footer-container, .copyright, .copyright-box {
  background-color: var(--tcg-bg) !important;
  color: var(--tcg-text-sub) !important;
  border-top: 1px solid var(--tcg-border) !important;
}

.footer-meta, .author-info, .author-link { display: none !important; }
.edit-link, .post-edit-link { display: none !important; }

/* ===== コンテンツ幅上限（レスポンシブ対応） ===== */
/* 親テーマの .wrap { width: 1256px } を上書き */
.wrap,
.content-in.wrap,
.navi-in.wrap,
#container,
#contents,
.footer-in.wrap {
  width: 100% !important;
  max-width: 1280px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: clamp(16px, 3vw, 40px) !important;
  padding-right: clamp(16px, 3vw, 40px) !important;
  box-sizing: border-box !important;
}

/* ナビ内ラッパー別途調整 */
#navi-in.wrap {
  padding-left: clamp(16px, 3vw, 40px) !important;
  padding-right: clamp(16px, 3vw, 40px) !important;
}

/* 1280px超の大画面でも中央揃え */
@media screen and (min-width: 1280px) {
  .wrap,
  .content-in.wrap,
  #container,
  #contents {
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* 768px以下：モバイル余白 */
@media screen and (max-width: 768px) {
  .wrap,
  .content-in.wrap,
  #container,
  #contents {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* ===== page-id-23 専用：Cocoon記事要素の除去 ===== */
.page-id-23 .sidebar,
.page-id-23 #sidebar,
.page-id-23 .widget-area,
.page-id-23 .sns-share-buttons,
.page-id-23 .sns-share,
.page-id-23 .sns-share-message,
.page-id-23 .article-bottom-area,
.page-id-23 .article-author-box,
.page-id-23 .related-entry-card-area,
.page-id-23 .toc,
.page-id-23 #toc,
.page-id-23 .ez-toc-container {
  display: none !important;
}

.page-id-23 #content,
.page-id-23 .content,
.page-id-23 .content-in,
.page-id-23 .main {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
}

.page-id-23 .entry-title,
.page-id-23 .entry-header,
.page-id-23 .entry-date,
.page-id-23 .byline { display: none !important; }

.page-id-23 section {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.page-id-23 .entry-content h2,
.page-id-23 .entry-content h3,
.page-id-23 .entry-content h4 {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: inherit !important;
}

/* ===== 検索ヒーロー ===== */
.tcg-search-hero {
  padding: 64px 16px 40px;
  text-align: center;
}

.tcg-search-box-xl {
  max-width: 680px;
  margin: 0 auto 20px;
  display: flex;
  gap: 10px;
}

.tcg-search-box-xl input[type="text"] {
  flex: 1;
  padding: 22px 26px;
  border-radius: 14px;
  border: 1px solid var(--tcg-border);
  background-color: var(--tcg-card-bg);
  color: var(--tcg-text);
  font-size: 16px;
  outline: none;
  box-sizing: border-box;
}

.tcg-search-box-xl input::placeholder { color: var(--tcg-text-sub); }

.tcg-search-box-xl input:focus {
  border-color: var(--tcg-accent);
  box-shadow: 0 0 0 3px rgba(249,115,22,0.18);
}

.tcg-search-btn {
  padding: 0 36px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(135deg, var(--tcg-accent), #fb923c);
  color: #0F172A;
  font-weight: 800;
  font-size: 15px;
  cursor: pointer;
}

.tcg-search-btn:hover { opacity: 0.9; }

@media screen and (max-width: 600px) {
  .tcg-search-hero { padding: 40px 16px 28px; }
  .tcg-search-box-xl { flex-direction: column; }
  .tcg-search-btn { padding: 16px; }
}

/* ===== セクション見出し ===== */
.tcg-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 800;
  color: var(--tcg-text);
  margin: 48px 0 20px;
}

.tcg-section-title .bar {
  display: inline-block;
  width: 5px;
  height: 20px;
  border-radius: 3px;
  background: linear-gradient(180deg, var(--tcg-accent), var(--tcg-accent-sub));
}

/* ===== トレカ別ブロック ===== */
.tcg-tcg-block {
  margin-bottom: 16px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--tcg-border);
}

.tcg-tcg-block-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--tcg-text);
  margin: 56px 0 24px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--tcg-accent);
  display: inline-block;
}

.tcg-sub-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--tcg-text-sub);
  margin: 24px 0 14px;
  padding-left: 10px;
  border-left: 3px solid var(--tcg-accent-sub);
}

/* ===== 発売情報カードグリッド ===== */
.tcg-release-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 32px;
}

.tcg-release-card {
  display: block;
  background-color: var(--tcg-card-bg);
  border: 1px solid var(--tcg-border);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none !important;
  transition: border-color 0.15s ease, transform 0.15s ease;
}

.tcg-release-card:hover {
  border-color: var(--tcg-accent);
  transform: translateY(-2px);
}

.tcg-release-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-color: var(--tcg-card-bg-alt);
  background-size: cover;
  background-position: center;
}

.tcg-release-date {
  font-size: 12px;
  color: var(--tcg-text-sub);
  padding: 14px 16px 0;
}

.tcg-release-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--tcg-text) !important;
  padding: 4px 16px 16px;
  line-height: 1.5;
}

/* ===== 抽選情報カード ===== */
.tcg-lottery-row-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
  margin-bottom: 32px;
}

.tcg-lottery-card {
  background-color: var(--tcg-card-bg);
  border: 1px solid var(--tcg-border);
  border-radius: 14px;
  padding: 18px 20px;
}

.tcg-list-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--tcg-text);
  margin-bottom: 6px;
  line-height: 1.5;
}

.tcg-list-meta {
  font-size: 12px;
  color: var(--tcg-text-sub);
  margin-bottom: 2px;
}

.tcg-tag {
  display: inline-block;
  margin-top: 12px;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 16px;
  border-radius: 999px;
  background-color: rgba(148,163,184,0.14);
  color: var(--tcg-text-sub);
  white-space: nowrap;
}

.tcg-tag-accent {
  background: rgba(249,115,22,0.14);
  color: var(--tcg-accent);
}

/* ===== フォローエリア ===== */
.tcg-follow-area {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 56px;
}

.tcg-follow-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 12px;
  border: 1px solid var(--tcg-border);
  background-color: var(--tcg-card-bg);
  color: var(--tcg-text) !important;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none !important;
  transition: border-color 0.15s ease, transform 0.15s ease;
}

.tcg-follow-btn:hover { transform: translateY(-2px); }

.tcg-follow-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  font-weight: 800;
  font-size: 15px;
}

.tcg-follow-x .tcg-follow-icon { background-color: #0F172A; color: var(--tcg-text); }
.tcg-follow-x:hover { border-color: var(--tcg-text); }
.tcg-follow-line .tcg-follow-icon { background-color: #06C755; color: #fff; }
.tcg-follow-line:hover { border-color: #06C755; }
.tcg-follow-rss .tcg-follow-icon { background-color: var(--tcg-accent); color: #0F172A; }
.tcg-follow-rss:hover { border-color: var(--tcg-accent); }

@media screen and (max-width: 600px) {
  .tcg-follow-btn { flex: 1 1 100%; }
  .site-logo-image { width: 180px !important; }
}

/* ロゴサイズ強制（Cocoon上書き） */
.site-logo-image,
.header-site-logo-image {
  width: 500px !important;
  max-width: 500px !important;
  height: auto !important;
}

