/*
Theme Name:   Sango Child
Description:  Sango 子テーマ - エレガントモダンデザイン
Template:     sango-theme
Version:      2.0.0
Text Domain:  sango-child
*/

/* ============================================================
   デザイントークン
   ============================================================ */
:root {
  /* ベースカラー */
  --c-bg:          #fafaf8;
  --c-bg-alt:      #f5f3f0;
  --c-bg-deep:     #ede9e5;
  --c-white:       #ffffff;

  /* モーブ系 */
  --c-mauve:       #9f6679;
  --c-mauve-dk:    #7f4f60;
  --c-mauve-lt:    #edd9e2;
  --c-mauve-mid:   #d4b0be;

  /* ゴールドアクセント */
  --c-gold:        #c9a96e;
  --c-gold-dk:     #a0804a;
  --c-gold-lt:     #f0e6d6;

  /* セージ */
  --c-sage:        #7e9e8d;
  --c-sage-lt:     #cfe0d8;

  /* テキスト */
  --c-text:        #38312e;
  --c-text-sub:    #7a706d;
  --c-text-muted:  #a89e9b;

  /* ボーダー */
  --c-border:      #e8e0db;
  --c-border-lt:   #f0ebe7;

  /* グラデーション */
  --grad-gold:     linear-gradient(135deg, #c9a96e 0%, #e8c99a 50%, #c9a96e 100%);
  --grad-mauve:    linear-gradient(135deg, #9f6679 0%, #d4b0be 100%);
  --grad-hero:     linear-gradient(135deg, #7f4f60 0%, #9f6679 40%, #c9a96e 100%);

  /* タイポグラフィ */
  --font-serif:    'Noto Serif JP', serif;
  --font-sans:     'Jost', 'Noto Sans JP', sans-serif;
  --fw-light:      300;
  --fw-regular:    400;

  /* スペーシング */
  --sp-xs:  0.5rem;
  --sp-sm:  1rem;
  --sp-md:  2rem;
  --sp-lg:  3.5rem;
  --sp-xl:  5rem;

  /* アニメーション */
  --ease:      0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --ease-slow: 0.6s cubic-bezier(0.4, 0, 0.2, 1);

  /* シャドウ */
  --shadow-sm:  0 2px 12px rgba(140, 96, 112, 0.08);
  --shadow-md:  0 8px 32px rgba(140, 96, 112, 0.12);
  --shadow-lg:  0 16px 48px rgba(140, 96, 112, 0.16);

  /* SANGOテーマ内部カラー変数を上書き（デフォルト青 #009EF3 を排除） */
  --sgb-main-color:           #9f6679;
  --sgb-accent-color:         #c9a96e;
  --sgb-pastel-color:         #edd9e2;
  --sgb-widget-title-color:   #7f4f60;
  --sgb-widget-title-bg-color:#f0e6d6;
}

/* ============================================================
   Google Fonts追加読み込み（Noto Serif JP + Jost）
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400&family=Jost:wght@300;400&display=swap');

/* ============================================================
   ベース
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  background-color: var(--c-bg);
  color: var(--c-text);
  font-family: var(--font-sans);
  font-weight: var(--fw-light);
  font-size: 16px;
  line-height: 2;
  letter-spacing: 0.04em;
}

::selection {
  background: var(--c-mauve-lt);
  color: var(--c-mauve-dk);
}

/* リンク（カスタマイザーの青を上書き） */
a {
  color: var(--c-mauve) !important;
  text-decoration: none;
  transition: color var(--ease);
}
a:hover { color: var(--c-gold-dk) !important; }

hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--c-border), transparent);
  margin: var(--sp-lg) 0;
}

img {
  max-width: 100%;
  height: auto;
}

/* ============================================================
   見出し
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  line-height: 1.6;
  letter-spacing: 0.06em;
}

h1 { font-size: 2.2rem; }
h2 { font-size: 1.7rem; }
h3 { font-size: 1.3rem; }

/* ============================================================
   ヘッダー（カスタマイザーの青を!importantで上書き）
   ============================================================ */
.header,
#header,
.header-inner,
.site-header,
.drawer__title {
  background-color: var(--c-bg) !important;
  border-bottom: 1px solid var(--c-border-lt) !important;
  padding: var(--sp-sm) 0;
  box-shadow: 0 1px 20px rgba(56, 49, 46, 0.05) !important;
}

/* サイトタイトル - グラデーションテキスト */
#logo a,
.site-title a,
.header-logo a,
#site-title a {
  font-family: var(--font-serif) !important;
  font-weight: var(--fw-light) !important;
  font-size: 1.6rem !important;
  letter-spacing: 0.25em !important;
  background: var(--grad-hero) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  color: transparent !important;
}

.site-description,
#site-description {
  font-size: 0.75rem;
  color: var(--c-text-muted);
  letter-spacing: 0.18em;
}

/* ============================================================
   グローバルナビ
   ============================================================ */
.nav-menu,
.global-nav,
#nav,
#global-nav {
  background: transparent;
  box-shadow: none;
}

.nav-menu a,
.global-nav a,
#nav a,
#global-nav a {
  font-family: var(--font-sans);
  font-weight: var(--fw-light);
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  color: var(--c-text-sub);
  padding: var(--sp-xs) var(--sp-sm);
  transition: color var(--ease);
  background: transparent;
  position: relative;
}

.nav-menu a::after,
.global-nav a::after,
#nav a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 1px;
  background: var(--grad-gold);
  transition: width var(--ease), left var(--ease);
}

.nav-menu a:hover::after,
.global-nav a:hover::after,
#nav a:hover::after {
  width: 100%;
  left: 0;
}

/* ナビリンク・ハンバーガー・検索アイコンの色（カスタマイザーの白を上書き） */
.desktop-nav li a,
.mobile-nav li a,
#drawer__open,
.header-search__open {
  color: var(--c-text-sub) !important;
}

.nav-menu a:hover,
.global-nav a:hover,
#nav a:hover,
.desktop-nav li a:hover { color: var(--c-gold-dk) !important; }

/* ============================================================
   メインレイアウト
   ============================================================ */
#main,
.l-main,
.main-content {
  /* padding-rightは親テーマがサイドバーgap用に設定するため上書きしない */
  padding-top: var(--sp-lg);
  padding-bottom: var(--sp-lg);
  padding-left: 0;
}

/* ============================================================
   記事コンテンツ
   ============================================================ */
.entry-content,
.the-content {
  font-family: var(--font-sans);
  font-weight: var(--fw-light);
  line-height: 2.1;
  letter-spacing: 0.04em;
}

.entry-content p,
.the-content p {
  margin-bottom: var(--sp-md);
  color: var(--c-text);
}

/* h2 - ゴールドグラデーションのボトムライン */
.entry-content h2,
.the-content h2 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: var(--fw-light);
  color: var(--c-text);
  border: none;
  padding: var(--sp-sm) 0 0.6rem;
  margin: var(--sp-lg) 0 var(--sp-md);
  background: transparent;
  position: relative;
}

.entry-content h2::after,
.the-content h2::after {
  content: '';
  display: block;
  width: 3rem;
  height: 2px;
  background: var(--grad-gold);
  margin-top: 0.5rem;
  border-radius: 2px;
}

/* h3 - ゴールドドットアクセント */
.entry-content h3,
.the-content h3 {
  font-size: 1.1rem;
  font-weight: var(--fw-light);
  color: var(--c-mauve-dk);
  border: none;
  padding: 0 0 0 1.2rem;
  margin: var(--sp-md) 0 var(--sp-sm);
  background: transparent;
  position: relative;
}

.entry-content h3::before,
.the-content h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-gold);
}

/* 引用 */
.entry-content blockquote,
.the-content blockquote {
  border-left: none;
  border: none;
  background: linear-gradient(135deg, var(--c-gold-lt) 0%, var(--c-bg-alt) 100%);
  padding: var(--sp-md) var(--sp-lg);
  color: var(--c-text-sub);
  font-style: italic;
  letter-spacing: 0.06em;
  line-height: 2;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}

.entry-content blockquote::before,
.the-content blockquote::before {
  content: '"';
  position: absolute;
  top: -0.5rem;
  left: 1rem;
  font-family: var(--font-serif);
  font-size: 5rem;
  color: var(--c-gold);
  opacity: 0.25;
  line-height: 1;
  font-style: normal;
}

/* ============================================================
   記事カード
   ============================================================ */
.article-card,
.post-card,
.sng-article,
.card-type-a,
.card-type-b {
  background: var(--c-white);
  border: 1px solid var(--c-border-lt);
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow var(--ease), transform var(--ease);
  box-shadow: var(--shadow-sm);
}

.article-card:hover,
.post-card:hover,
.sng-article:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-5px);
  border-color: var(--c-mauve-lt);
}

.article-card .entry-title,
.post-card .entry-title,
.sng-article .entry-title {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  color: var(--c-text);
  line-height: 1.6;
}

/* サムネイル - オーバーレイエフェクト */
.article-card .post-thumbnail img,
.post-card .post-thumbnail img,
.sng-article .post-thumbnail img {
  transition: transform var(--ease-slow);
}

.article-card:hover .post-thumbnail img,
.post-card:hover .post-thumbnail img,
.sng-article:hover .post-thumbnail img {
  transform: scale(1.04);
}

/* ============================================================
   ボタン（searchform__submit は除外して位置崩れを防止）
   ============================================================ */
.btn,
.sango-btn,
.wp-block-button__link,
.more-link {
  background: var(--grad-mauve);
  color: var(--c-white) !important;
  border: none;
  border-radius: 50px;
  padding: 0.8em 2.4em;
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  font-size: 0.82rem;
  letter-spacing: 0.2em;
  cursor: pointer;
  transition: all var(--ease);
  display: inline-block;
  box-shadow: 0 4px 16px rgba(184, 137, 154, 0.3);
  position: relative;
  overflow: hidden;
}

.btn::before,
.sango-btn::before,
.wp-block-button__link::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--grad-gold);
  opacity: 0;
  transition: opacity var(--ease);
}

.btn:hover,
.sango-btn:hover,
.wp-block-button__link:hover {
  color: var(--c-white) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(184, 137, 154, 0.4);
}

.btn:hover::before,
.sango-btn:hover::before,
.wp-block-button__link:hover::before {
  opacity: 1;
}

/* 検索フォームのsubmitボタン - 位置・サイズは親テーマに任せ、色だけ変更 */
.searchform__submit,
.sidebar .wp-block-search .wp-block-search__button {
  background: var(--c-mauve) !important;
  background-image: none !important;
  border-radius: 0 6px 6px 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  transform: none !important;
  display: block !important;
  transition: background-color var(--ease) !important;
}

.searchform__submit:hover,
.sidebar .wp-block-search .wp-block-search__button:hover {
  background: var(--c-mauve-dk) !important;
  transform: none !important;
}

/* テキストリンク型CTA */
.text-link-cta {
  color: var(--c-gold-dk);
  font-size: 0.84rem;
  letter-spacing: 0.12em;
  position: relative;
  padding-bottom: 2px;
  transition: color var(--ease);
}

.text-link-cta::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--grad-gold);
  transform: scaleX(0.4);
  transform-origin: left;
  transition: transform var(--ease);
}

.text-link-cta:hover { color: var(--c-gold-dk); }
.text-link-cta:hover::after { transform: scaleX(1); }

/* ============================================================
   カテゴリ・タグ
   ============================================================ */
.cat-label,
.tag-label,
.cat-name {
  background: transparent;
  color: var(--c-mauve-dk);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  border-radius: 3px;
  padding: 0.3em 0.8em;
  border: 1px solid var(--c-mauve-mid);
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

/* アイキャッチ左上カテゴリーラベル - 黒系で視認性を確保 */
.cat-name {
  background: rgba(255, 255, 255, 0.82) !important;
  color: #2d2926 !important;
  border-color: rgba(45, 41, 38, 0.18) !important;
}

.tag-label {
  color: var(--c-gold-dk);
  border-color: var(--c-gold);
  background: var(--c-gold-lt);
}

/* ============================================================
   サイドバー — グラスモーフィズム
   ============================================================ */
.sidebar,
#sidebar,
.l-sidebar {
  font-size: 0.9rem;
}

/* ── ウィジェット共通（すりガラスカード） ── */
.widget {
  background: rgba(255, 255, 255, 0.62) !important;
  backdrop-filter: blur(14px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.4) !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  border-radius: 18px !important;
  padding: 1.6rem 1.5rem !important;
  margin-bottom: 1.4rem !important;
  box-shadow:
    0 4px 20px rgba(159, 102, 121, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  position: relative;
  overflow: hidden;
  transition: box-shadow var(--ease), transform var(--ease);
}

.widget:hover {
  box-shadow:
    0 8px 32px rgba(159, 102, 121, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  transform: translateY(-2px);
}

/* ゴールドの細いトップアクセントライン */
.widget::before {
  content: '';
  position: absolute;
  top: 0; left: 1.5rem; right: 1.5rem;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--c-gold), transparent);
  border-radius: 0 0 2px 2px;
}

/* ── ウィジェットタイトル ── */
.widget-title,
.widgettitle,
.sidebar .wp-block-group h2,
.drawer .wp-block-group h2 {
  font-family: var(--font-serif) !important;
  font-weight: var(--fw-light) !important;
  font-size: 0.82rem !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  color: var(--c-text-sub) !important;
  background: transparent !important;
  border: none !important;
  padding: 0 0 0.9rem !important;
  margin-bottom: 1rem !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
}

/* タイトル左のゴールドドット */
.widget-title::before,
.widgettitle::before {
  content: '';
  display: inline-block !important;
  width: 5px !important;
  height: 5px !important;
  border-radius: 50% !important;
  background: var(--c-gold) !important;
  flex-shrink: 0 !important;
}

/* タイトル下のグラデーションライン */
.widget-title::after,
.widgettitle::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, var(--c-gold) 0%, var(--c-mauve-lt) 60%, transparent 100%) !important;
  border-radius: 0 !important;
  width: auto !important;
}

/* ── 記事リスト（人気・最新） ── */
.sidebar .widget ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sidebar .widget ul li {
  border-bottom: 1px solid rgba(232, 224, 219, 0.55);
  padding: 0;
}
.sidebar .widget ul li:last-child { border-bottom: none; }

.sidebar .widget ul li a {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.55rem !important;
  padding: 0.65rem 0.1rem !important;
  font-size: 0.83rem !important;
  font-weight: var(--fw-light) !important;
  line-height: 1.65 !important;
  color: var(--c-text) !important;
  text-decoration: none !important;
  transition: color var(--ease), padding-left var(--ease) !important;
}

.sidebar .widget ul li a::before {
  content: '›' !important;
  color: var(--c-gold) !important;
  font-size: 1rem !important;
  line-height: 1.5 !important;
  flex-shrink: 0 !important;
  transition: transform var(--ease) !important;
}

.sidebar .widget ul li a:hover {
  color: var(--c-mauve-dk) !important;
  padding-left: 0.35rem !important;
}
.sidebar .widget ul li a:hover::before {
  transform: translateX(3px) !important;
}

/* ── カテゴリーウィジェット ── */
.widget_categories ul li a {
  justify-content: flex-start !important;
}

.widget_categories ul li .post-count,
.widget_categories ul li a .count {
  font-family: var(--font-sans) !important;
  font-size: 0.72rem !important;
  color: var(--c-text-muted) !important;
  background: var(--c-bg-alt) !important;
  border-radius: 20px !important;
  padding: 1px 7px !important;
  margin-left: auto !important;
  flex-shrink: 0 !important;
}

/* ── 検索ウィジェット ── */
.widget_search,
.widget.widget_search {
  background: rgba(255, 255, 255, 0.62) !important;
  backdrop-filter: blur(14px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.4) !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  border-radius: 18px !important;
  padding: 1.4rem 1.5rem !important;
  box-shadow:
    0 4px 20px rgba(159, 102, 121, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

/* 検索フォームのラッパー */
.searchform div {
  overflow: hidden !important;
  border-radius: 10px !important;
  border: 1px solid rgba(201, 169, 110, 0.35) !important;
  box-shadow:
    0 2px 10px rgba(159, 102, 121, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.8) !important;
  background: rgba(255,255,255,0.7) !important;
}

input.searchform__input {
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  color: var(--c-text) !important;
  padding: 0.75rem 1rem !important;
}

input.searchform__input::placeholder {
  color: var(--c-text-muted) !important;
  font-weight: var(--fw-light) !important;
  letter-spacing: 0.06em !important;
}

/* ── タグクラウド ── */
.sidebar .tagcloud a {
  display: inline-block !important;
  padding: 0.3em 0.9em !important;
  margin: 0.2rem !important;
  font-size: 0.75rem !important;
  font-weight: var(--fw-light) !important;
  letter-spacing: 0.08em !important;
  border-radius: 20px !important;
  border: 1px solid rgba(201, 169, 110, 0.4) !important;
  color: var(--c-text-sub) !important;
  background: rgba(240, 230, 214, 0.45) !important;
  transition: all var(--ease) !important;
  text-decoration: none !important;
}
.sidebar .tagcloud a:hover {
  background: var(--c-gold-lt) !important;
  border-color: var(--c-gold) !important;
  color: var(--c-gold-dk) !important;
  transform: translateY(-1px) !important;
}

/* ── アーカイブ ── */
.widget_archive select {
  width: 100% !important;
  padding: 0.6rem 1rem !important;
  border: 1px solid rgba(201, 169, 110, 0.35) !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,0.7) !important;
  font-family: var(--font-sans) !important;
  font-size: 0.83rem !important;
  color: var(--c-text-sub) !important;
  appearance: auto !important;
}

/* ============================================================
   著者プロフィール
   ============================================================ */
.profile-card,
.author-box,
.sng-profile {
  background: linear-gradient(135deg, var(--c-white) 0%, var(--c-gold-lt) 100%);
  border: 1px solid var(--c-border-lt);
  border-radius: 16px;
  padding: var(--sp-md) var(--sp-lg);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}

.profile-card::before,
.author-box::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: var(--grad-gold);
  border-radius: 4px 0 0 4px;
}

.profile-card .name,
.author-box .author-name {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  font-size: 1.15rem;
  color: var(--c-text);
  letter-spacing: 0.12em;
}

.profile-card .description,
.author-box .author-description {
  font-size: 0.88rem;
  line-height: 1.9;
  color: var(--c-text-sub);
}

/* ============================================================
   関連記事
   ============================================================ */
.related-posts,
.sng-related,
.related-entry-section {
  background: var(--c-bg-alt);
  border-radius: 16px;
  padding: var(--sp-md) var(--sp-lg);
  border: none;
}

.related-posts-title,
.sng-related-title {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  font-size: 0.82rem;
  letter-spacing: 0.3em;
  color: var(--c-text-muted);
  margin-bottom: var(--sp-md);
  text-transform: uppercase;
}

/* ============================================================
   SANGOボックス
   ============================================================ */
.sng-box,
.sango-box,
[class*="sng-box"] {
  border-color: var(--c-border) !important;
  border-radius: 12px !important;
  background: var(--c-white) !important;
  box-shadow: var(--shadow-sm) !important;
}

.sng-box-title,
.sango-box-title,
[class*="sng-box"] > .title {
  background: linear-gradient(135deg, var(--c-mauve-lt), var(--c-gold-lt)) !important;
  color: var(--c-text) !important;
  font-family: var(--font-serif) !important;
  font-weight: var(--fw-light) !important;
  letter-spacing: 0.1em;
  border-radius: 10px 10px 0 0 !important;
}

.sng-box-sage {
  border-color: var(--c-sage-lt) !important;
}
.sng-box-sage > .title {
  background: linear-gradient(135deg, var(--c-sage-lt), var(--c-bg-alt)) !important;
  color: var(--c-sage) !important;
}

/* ============================================================
   目次
   ============================================================ */
.toc,
.sng-toc,
#toc {
  background: linear-gradient(135deg, var(--c-gold-lt) 0%, var(--c-bg-alt) 100%);
  border: 1px solid rgba(201, 169, 110, 0.3);
  border-radius: 12px;
  padding: var(--sp-md);
}

.toc-title,
.sng-toc-title {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  color: var(--c-gold-dk);
  letter-spacing: 0.15em;
  font-size: 0.9rem;
}

/* ============================================================
   フッター（カスタマイザーの青を!importantで上書き）
   ============================================================ */
#footer,
.footer,
.site-footer,
.l-footer {
  background: linear-gradient(180deg, var(--c-bg-alt) 0%, var(--c-bg-deep) 100%) !important;
  background-color: var(--c-bg-deep) !important;
  border-top: 1px solid var(--c-border);
  padding: var(--sp-xl) 0 var(--sp-md);
  color: var(--c-text-sub) !important;
  font-size: 0.85rem;
  position: relative;
}

/* フッターメニューバー（カスタマイザーが header_bc と同色で出力するため） */
#footer-menu {
  background-color: var(--c-bg-deep) !important;
}

#footer-menu a,
.copyright {
  color: var(--c-text-muted) !important;
  letter-spacing: 0.15em;
}

#footer-menu a:hover {
  color: var(--c-gold) !important;
}

.footer,
.footer a,
.footer .widget ul li a {
  color: var(--c-text-sub) !important;
}

.footer-title,
.footer-logo {
  font-family: var(--font-serif);
  font-weight: var(--fw-light);
  color: var(--c-text) !important;
  letter-spacing: 0.2em;
  font-size: 1.1rem;
}

.footer-copy,
.copyright {
  font-size: 0.7rem;
  color: var(--c-text-muted) !important;
  letter-spacing: 0.15em;
}

/* ============================================================
   スクロールトップボタン
   ============================================================ */
.to-top,
#to-top,
.totop,
.scroll-top {
  background: var(--grad-mauve) !important;
  border-radius: 50% !important;
  box-shadow: var(--shadow-md) !important;
  transition: all var(--ease) !important;
}

.to-top:hover,
#to-top:hover,
.totop:hover {
  background: var(--grad-gold) !important;
  transform: translateY(-3px) !important;
}

/* ============================================================
   フェードインアニメーション（custom.js と連携）
   ============================================================ */
.fade-elem {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-elem.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* スクロール防止・JS無効時はすべて表示 */
@media (prefers-reduced-motion: reduce) {
  .fade-elem {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 768px) {
  body { font-size: 15px; }
  h1 { font-size: 1.7rem; }
  h2 { font-size: 1.4rem; }
  h3 { font-size: 1.15rem; }
  #main, .l-main { padding: var(--sp-md) 0; }
  .entry-content h2, .the-content h2 { font-size: 1.2rem; }
  .profile-card, .author-box { padding: var(--sp-md); }
  .related-posts, .sng-related { padding: var(--sp-md); }
}

