/*
Theme Name:  SWELL Child - Bio-sign
Theme URI:   https://bio-sign.jp/
Description: Bio-sign | 12星座の生存戦略を科学的に翻訳する - 子テーマ（SWELLベース）
Author:      Bio-sign
Author URI:  https://bio-sign.jp/
Template:    swell
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: swell-child
*/

/* ============================================================
   0. Google Fonts import
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&family=Space+Mono&display=swap');

/* ============================================================
   1. CSS カスタムプロパティ（デザイントークン）
   ============================================================ */
:root {
  /* ── カラー（ライトモード） ── */
  --bio-bg-deep:       #ffffff;      /* ベース：白 */
  --bio-bg-base:       #f8f9fc;      /* ページ背景：極薄グレー */
  --bio-bg-surface:    #f0f3f8;      /* カード・セクション背景 */
  --bio-bg-elevated:   #e6eaf3;      /* ホバー・アクセント面 */

  --bio-accent-cyan:   #1aab94;      /* 生体蛍光：シアン（白背景用に濃く） */
  --bio-accent-gold:   #b8880e;      /* 星図の金：アンバー（白背景用に濃く） */
  --bio-accent-violet: #6b58d3;      /* 星雲パープル */
  --bio-accent-coral:  #c84f3a;      /* 火サイン */

  --bio-text-primary:  #0f1a2e;      /* メインテキスト：ネイビーブラック */
  --bio-text-secondary:#3d4f6b;      /* サブテキスト */
  --bio-text-muted:    #7a8ea8;      /* ミュートテキスト */

  --bio-border:        rgba(26, 171, 148, 0.18);
  --bio-border-gold:   rgba(184, 136, 14, 0.25);
  --bio-glow-cyan:     0 4px 20px rgba(26, 171, 148, 0.15);
  --bio-glow-gold:     0 4px 16px rgba(184, 136, 14, 0.12);

  /* ── タイポグラフィ ── */
  --font-display:  'Cormorant Garamond', 'Noto Serif JP', Georgia, serif;
  --font-body:     'DM Sans', 'Noto Sans JP', sans-serif;
  --font-mono:     'Space Mono', 'Courier New', monospace;

  /* ── スペーシング ── */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;

  /* ── トランジション ── */
  --transition-base: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   2. グローバルリセット & ベース
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--bio-bg-base);
  color: var(--bio-text-primary);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.8;
  letter-spacing: 0.01em;
}

/* 極細グリッド背景（疑似要素） */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(26, 171, 148, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 171, 148, 0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   3. タイポグラフィ
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 0.05em;
  color: var(--bio-text-primary);
}

h1 { font-size: clamp(2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.8rem); }

p {
  color: var(--bio-text-secondary);
  font-size: 0.97rem;
  line-height: 1.95;
}

a {
  color: var(--bio-accent-cyan);
  text-decoration: none;
  transition: color var(--transition-base), opacity var(--transition-base);
}
a:hover {
  color: #ffffff;
  opacity: 0.9;
}

/* 学術的強調テキスト */
strong, b { color: var(--bio-text-primary); font-weight: 500; }
em, i { color: var(--bio-accent-gold); font-style: italic; }

code, kbd, pre, .wp-block-code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: var(--bio-bg-elevated);
  color: var(--bio-accent-cyan);
  border: 1px solid var(--bio-border);
  border-radius: var(--radius-sm);
}
code { padding: 0.1em 0.4em; }
pre  { padding: 1.2em 1.5em; overflow-x: auto; }

/* ============================================================
   4. SWELLヘッダー上書き
   ============================================================ */
#header,
.p-header {
  background: rgba(255, 255, 255, 0.94) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid rgba(26, 171, 148, 0.15) !important;
  box-shadow: 0 1px 0 rgba(0,0,0,0.04) !important;
}

/* サイトタイトル */
.p-header__logo,
.p-siteName,
#header .logo a,
.p-header .site-title a {
  font-family: var(--font-display) !important;
  font-size: 1.35rem !important;
  font-weight: 300 !important;
  color: var(--bio-text-primary) !important;
  letter-spacing: 0.12em !important;
}

/* "Bio-sign" 部分のアクセント */
.p-header .site-title a::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--bio-accent-cyan);
  border-radius: 50%;
  margin-right: 8px;
  box-shadow: var(--bio-glow-cyan);
  vertical-align: middle;
}

/* グローバルナビ */
#g-nav .menu-item a,
.p-nav .menu-item > a {
  font-family: var(--font-body) !important;
  font-size: 0.82rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.1em !important;
  color: var(--bio-text-secondary) !important;
  text-transform: uppercase;
  padding: 0.5em 0.8em !important;
  transition: color var(--transition-base) !important;
}
#g-nav .menu-item a:hover,
.p-nav .menu-item > a:hover {
  color: var(--bio-accent-cyan) !important;
}

/* モバイルハンバーガー */
.p-header-burger__btn span {
  background: var(--bio-accent-cyan) !important;
}

/* ============================================================
   5. ヒーロー & ファーストビュー
   ============================================================ */
.p-top-mv,
.p-blogTop__mv,
.c-mv {
  background: var(--bio-bg-deep) !important;
  position: relative;
  overflow: hidden;
}

/* 星座グリッド背景（CSS のみ） */
.p-top-mv::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(26, 171, 148, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 171, 148, 0.08) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
}

.p-top-mv__title,
.c-mv__title {
  font-family: var(--font-display) !important;
  font-size: clamp(2.2rem, 6vw, 4rem) !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  color: var(--bio-text-primary) !important;
  text-shadow: 0 0 40px rgba(61, 216, 192, 0.2) !important;
}

/* ============================================================
   6. ブログカード（記事一覧）
   ============================================================ */
.p-articleCard,
.c-card,
.p-postList__item {
  background: var(--bio-bg-surface) !important;
  border: 1px solid var(--bio-border) !important;
  border-radius: var(--radius-md) !important;
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              border-color var(--transition-base) !important;
  overflow: hidden;
}

.p-articleCard:hover,
.c-card:hover,
.p-postList__item:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5),
              var(--bio-glow-cyan) !important;
  border-color: rgba(61, 216, 192, 0.3) !important;
}

/* カードタイトル */
.p-articleCard__title,
.c-card__title {
  font-family: var(--font-display) !important;
  font-size: 1.15rem !important;
  font-weight: 400 !important;
  color: var(--bio-text-primary) !important;
  line-height: 1.4 !important;
}

/* カードのアイキャッチオーバーレイ */
.p-articleCard__thumb::after,
.c-card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 50%,
    rgba(4, 9, 26, 0.8) 100%
  );
}

/* ============================================================
   7. カテゴリバッジ（星座エレメント）
   ============================================================ */
.c-cat,
.c-label,
.cat-label {
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  padding: 3px 10px !important;
  border-radius: 2px !important;
  border: 1px solid !important;
}

/* 火のサイン */
.cat-fire .c-cat,
[class*="cat-id-fire"] .c-label,
.cat-aries .c-cat,
.cat-leo .c-cat,
.cat-sagittarius .c-cat {
  background: rgba(224, 112, 96, 0.12) !important;
  color: var(--bio-accent-coral) !important;
  border-color: rgba(224, 112, 96, 0.3) !important;
}

/* 地のサイン */
.cat-earth .c-cat,
.cat-taurus .c-cat,
.cat-virgo .c-cat,
.cat-capricorn .c-cat {
  background: rgba(212, 168, 71, 0.12) !important;
  color: var(--bio-accent-gold) !important;
  border-color: var(--bio-border-gold) !important;
}

/* 風のサイン */
.cat-air .c-cat,
.cat-gemini .c-cat,
.cat-libra .c-cat,
.cat-aquarius .c-cat {
  background: rgba(61, 216, 192, 0.10) !important;
  color: var(--bio-accent-cyan) !important;
  border-color: var(--bio-border) !important;
}

/* 水のサイン */
.cat-water .c-cat,
.cat-cancer .c-cat,
.cat-scorpio .c-cat,
.cat-pisces .c-cat {
  background: rgba(139, 120, 230, 0.12) !important;
  color: var(--bio-accent-violet) !important;
  border-color: rgba(139, 120, 230, 0.25) !important;
}

/* ============================================================
   8. 記事詳細ページ（シングルポスト）
   ============================================================ */
.p-article,
.l-article {
  background: transparent;
}

/* 記事ヘッダー */
.p-article__header,
.p-entryHeader {
  border-bottom: 1px solid var(--bio-border);
  padding-bottom: 2rem;
  margin-bottom: 3rem;
}

/* 記事本文 */
.p-article__body,
.l-article .e-content {
  color: var(--bio-text-secondary);
}

/* 記事内見出し装飾 */
.e-content h2,
.p-article__body h2 {
  position: relative;
  padding-left: 1.2em;
  margin-top: 3em;
}
.e-content h2::before,
.p-article__body h2::before {
  content: '//';
  position: absolute;
  left: 0;
  color: var(--bio-accent-cyan);
  font-family: var(--font-mono);
  font-size: 0.7em;
  opacity: 0.7;
  top: 0.35em;
}

.e-content h3,
.p-article__body h3 {
  border-left: 2px solid var(--bio-accent-gold);
  padding-left: 0.8em;
  color: var(--bio-text-primary);
}

/* 引用（科学的根拠・参考文献） */
blockquote,
.wp-block-quote {
  border-left: 3px solid var(--bio-accent-cyan) !important;
  background: var(--bio-bg-surface) !important;
  padding: 1.2em 1.5em !important;
  margin: 2em 0 !important;
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
  position: relative;
}
blockquote::before {
  content: 'SOURCE';
  position: absolute;
  top: -0.7em;
  left: 1em;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--bio-accent-cyan);
  background: var(--bio-bg-surface);
  padding: 0 0.5em;
}

/* 区切り線 */
hr, .wp-block-separator {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(
    to right,
    transparent,
    var(--bio-accent-cyan) 30%,
    var(--bio-accent-gold) 70%,
    transparent
  ) !important;
  margin: 3em auto !important;
  opacity: 0.3;
}

/* ============================================================
   9. サイドバー
   ============================================================ */
.p-sidebar,
#sidebar {
  background: transparent;
}

/* サイドバーウィジェット */
.p-sidebar .widget,
#sidebar .widget {
  background: var(--bio-bg-surface);
  border: 1px solid var(--bio-border);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.p-sidebar .widget-title,
#sidebar .widget-title {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bio-accent-cyan);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--bio-border);
}

/* ============================================================
   10. フッター
   ============================================================ */
#footer,
.p-footer {
  background: #ffffff !important;
  border-top: 1px solid rgba(26, 171, 148, 0.15) !important;
  color: var(--bio-text-muted) !important;
}

.p-footer a {
  color: var(--bio-text-muted) !important;
  transition: color var(--transition-base);
}
.p-footer a:hover {
  color: var(--bio-accent-cyan) !important;
}

.p-footer__copy {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  color: var(--bio-text-muted) !important;
}

/* ============================================================
   11. ボタン & CTA
   ============================================================ */
.wp-block-button__link,
.c-btn,
.btn {
  background: transparent !important;
  border: 1px solid var(--bio-accent-cyan) !important;
  color: var(--bio-accent-cyan) !important;
  font-family: var(--font-mono) !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  padding: 0.75em 2em !important;
  border-radius: var(--radius-sm) !important;
  transition: all var(--transition-base) !important;
  position: relative;
  overflow: hidden;
}
.wp-block-button__link:hover,
.c-btn:hover,
.btn:hover {
  background: var(--bio-accent-cyan) !important;
  color: var(--bio-bg-deep) !important;
  box-shadow: var(--bio-glow-cyan) !important;
}

/* メインCTAボタン（金色） */
.wp-block-button.is-style-fill .wp-block-button__link,
.c-btn--primary {
  background: var(--bio-accent-gold) !important;
  border-color: var(--bio-accent-gold) !important;
  color: var(--bio-bg-deep) !important;
}
.wp-block-button.is-style-fill .wp-block-button__link:hover,
.c-btn--primary:hover {
  box-shadow: var(--bio-glow-gold) !important;
  opacity: 0.9 !important;
}

/* ============================================================
   12. カスタムウィジェット：星座ナビゲーション
   ============================================================ */
.bio-zodiac-nav {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin: 2rem 0;
}

.bio-zodiac-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 8px;
  background: var(--bio-bg-surface);
  border: 1px solid var(--bio-border);
  border-radius: var(--radius-md);
  color: var(--bio-text-secondary);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  text-align: center;
  transition: all var(--transition-base);
}

.bio-zodiac-nav a:hover {
  background: var(--bio-bg-elevated);
  border-color: rgba(61, 216, 192, 0.3);
  color: var(--bio-text-primary);
  transform: translateY(-2px);
  box-shadow: var(--bio-glow-cyan);
}

.bio-zodiac-nav .sign-symbol {
  font-size: 1.4rem;
  margin-bottom: 4px;
}

/* ============================================================
   13. スクロールバー
   ============================================================ */
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: var(--bio-bg-surface);
}
::-webkit-scrollbar-thumb {
  background: var(--bio-bg-elevated);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--bio-accent-cyan);
}

/* ============================================================
   14. テキスト選択
   ============================================================ */
::selection {
  background: rgba(26, 171, 148, 0.2);
  color: var(--bio-text-primary);
}

/* ============================================================
   15. フォーム
   ============================================================ */
input, textarea, select {
  background: var(--bio-bg-surface) !important;
  border: 1px solid var(--bio-border) !important;
  color: var(--bio-text-primary) !important;
  border-radius: var(--radius-sm) !important;
  padding: 0.6em 0.9em !important;
  font-family: var(--font-body) !important;
  transition: border-color var(--transition-base) !important;
}
input:focus, textarea:focus {
  border-color: var(--bio-accent-cyan) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(61, 216, 192, 0.15) !important;
}

/* ============================================================
   16. ページネーション
   ============================================================ */
.c-pagination a,
.nav-links a {
  background: var(--bio-bg-surface) !important;
  border: 1px solid var(--bio-border) !important;
  color: var(--bio-text-secondary) !important;
  border-radius: var(--radius-sm) !important;
}
.c-pagination .current,
.nav-links .current {
  background: var(--bio-accent-cyan) !important;
  border-color: var(--bio-accent-cyan) !important;
  color: var(--bio-bg-deep) !important;
}

/* ============================================================
   17. テーブル（論文・データ表示）
   ============================================================ */
table {
  border-collapse: collapse;
  width: 100%;
  font-size: 0.9rem;
}
th {
  background: var(--bio-bg-elevated) !important;
  color: var(--bio-accent-cyan) !important;
  font-family: var(--font-mono) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 0.8em 1em !important;
  border-bottom: 1px solid var(--bio-border) !important;
}
td {
  border-bottom: 1px solid rgba(61, 216, 192, 0.06) !important;
  padding: 0.75em 1em !important;
  color: var(--bio-text-secondary) !important;
}
tr:hover td {
  background: rgba(61, 216, 192, 0.03) !important;
}

/* ============================================================
   18. レスポンシブ調整
   ============================================================ */
@media (max-width: 768px) {
  .bio-zodiac-nav {
    grid-template-columns: repeat(3, 1fr);
  }

  .p-top-mv__title,
  .c-mv__title {
    font-size: clamp(1.7rem, 7vw, 2.5rem) !important;
  }
}

@media (max-width: 480px) {
  .bio-zodiac-nav {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================================
   19. アニメーション
   ============================================================ */
@keyframes bio-fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes bio-glow-pulse {
  0%, 100% { box-shadow: 0 0 8px rgba(61, 216, 192, 0.15); }
  50%       { box-shadow: 0 0 24px rgba(61, 216, 192, 0.35); }
}

.p-articleCard,
.c-card {
  animation: bio-fade-in 0.5s ease-out both;
}

/* ============================================================
   20. ユーティリティクラス（Gutenbergブロック内で使用可能）
   ============================================================ */

/* 科学的注釈ボックス */
.bio-note {
  background: #fffbf0;
  border: 1px solid var(--bio-border-gold);
  border-radius: var(--radius-md);
  padding: 1.2em 1.5em;
  font-size: 0.88rem;
  position: relative;
  margin: 1.5em 0;
}
.bio-note::before {
  content: 'SCIENCE NOTE';
  display: block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--bio-accent-gold);
  margin-bottom: 0.5em;
}

/* 星座データパネル */
.bio-sign-data {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  background: var(--bio-bg-surface);
  border: 1px solid var(--bio-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 2rem 0;
}
.bio-sign-data dt {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  color: var(--bio-text-muted);
  text-transform: uppercase;
}
.bio-sign-data dd {
  color: var(--bio-text-primary);
  font-weight: 400;
  margin: 0 0 1rem;
}