/*
  Skin Name: 春風 -Haru Breeze-
  Description: 日本の春をイメージした、桜色と若草色を基調とした和モダンなスキンです。アニメ感想ブログにぴったりの落ち着いた春の雰囲気を演出します。
  Skin URI: https://wp-cocoon.com/
  Author: Haru Breeze
  Author URI: https://wp-cocoon.com/
  Screenshot URI: https://im-cocoon.net/wp-content/uploads/skin-template.png
  Version: 1.0.0
  Priority: 9999000000
*/

/* ============================================
   春風スキン - CSS変数（カラーパレット）
   ============================================ */
:root {
  --haru-sakura:        #F4A7B9;   /* 桜色 */
  --haru-sakura-pale:   #FDE8EE;   /* 淡桜色 */
  --haru-sakura-deep:   #C85A8A;   /* 濃桜色 */
  --haru-wakakusa:      #7EC8A4;   /* 若草色 */
  --haru-wakakusa-pale: #C9EAD9;   /* 淡若草 */
  --haru-white:         #FDFAF8;   /* 和白 */
  --haru-text:          #3D2B1F;   /* 墨色（本文） */
  --haru-text-light:    #7A5C50;   /* 薄墨色（サブテキスト） */
  --haru-gold:          #C9A84C;   /* 金色（アクセント） */
  --haru-shadow:        rgba(200, 90, 138, 0.12);
  --haru-border:        rgba(244, 167, 185, 0.45);
  --haru-radius:        10px;
  --haru-radius-lg:     18px;
}

/* ============================================
   ベース・全体
   ============================================ */
body {
  background-color: #FBF3F5;
  background-image:
    radial-gradient(ellipse at 12% 0%,   rgba(244,167,185,0.18) 0%, transparent 48%),
    radial-gradient(ellipse at 88% 100%, rgba(126,200,164,0.15) 0%, transparent 48%);
  color: var(--haru-text);
  line-height: 1.9;
  letter-spacing: 0.02em;
}

html {
  scroll-behavior: smooth;
}

a {
  color: var(--haru-sakura-deep);
  transition: color 0.2s ease, opacity 0.2s ease;
}
a:hover {
  color: var(--haru-wakakusa);
  opacity: 0.85;
  text-decoration: none;
}

/* スクロールバー */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #fde8ee; }
::-webkit-scrollbar-thumb { background: var(--haru-sakura); border-radius: 3px; }

/* ============================================
   桜の花びら（JS生成要素のスタイル）
   ============================================ */
.sakura-petal {
  position: fixed;
  top: -30px;
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  animation: sakura-fall linear forwards;
  will-change: transform, opacity;
}

.sakura-petal::before {
  content: '';
  display: block;
  width: 12px;
  height: 10px;
  background: radial-gradient(ellipse at 40% 35%, #FFDDE6 0%, #F4A7B9 55%, #E87A98 100%);
  border-radius: 50% 0 50% 0;
  box-shadow: 0 1px 3px rgba(212,96,122,0.2);
}

/* ============================================
   ヘッダー
   ============================================ */
#header,
.header-container,
.header-container-in {
  background: transparent !important;
}

.header-container {
  background: linear-gradient(160deg, #FDEEF2 0%, #FDF5E8 50%, #EDFAF3 100%) !important;
  border-bottom: 2px solid var(--haru-border);
  box-shadow: 0 2px 12px var(--haru-shadow);
  position: relative;
  overflow: hidden;
}

/* ヘッダー下部のグラデーションライン */
.header-container::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--haru-sakura-pale) 10%,
    var(--haru-sakura) 30%,
    var(--haru-gold) 50%,
    var(--haru-sakura) 70%,
    var(--haru-sakura-pale) 90%,
    transparent 100%
  );
}

/* サイトタイトル */
.site-name-text,
.site-name-text a {
  color: var(--haru-sakura-deep) !important;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-shadow: 0 1px 4px rgba(200,90,138,0.15);
}

/* サイトディスクリプション */
.site-description {
  color: var(--haru-text-light) !important;
  font-size: 0.82em;
  letter-spacing: 0.05em;
}

/* ============================================
   グローバルナビ
   ============================================ */
.navi-in > ul > li > a {
  color: var(--haru-text);
  font-size: 0.9em;
  letter-spacing: 0.05em;
  padding: 8px 14px;
  position: relative;
  transition: color 0.2s ease;
}

.navi-in > ul > li > a::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--haru-sakura);
  transition: width 0.3s ease, left 0.3s ease;
  border-radius: 1px;
}

.navi-in > ul > li > a:hover,
.navi-in > ul > li.current-menu-item > a {
  color: var(--haru-sakura-deep);
}

.navi-in > ul > li > a:hover::after,
.navi-in > ul > li.current-menu-item > a::after {
  width: 80%;
  left: 10%;
}

/* ドロップダウン */
.navi-in > ul > li > ul {
  background: var(--haru-white);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius);
  box-shadow: 0 6px 20px var(--haru-shadow);
}

.navi-in > ul > li > ul > li > a {
  color: var(--haru-text);
  font-size: 0.85em;
}

.navi-in > ul > li > ul > li > a:hover {
  background: var(--haru-sakura-pale);
  color: var(--haru-sakura-deep);
}

/* ============================================
   メインコンテンツ
   ============================================ */
#content {
  padding-top: 28px;
}

.content-wrap {
  max-width: 1140px;
  margin: 0 auto;
}

/* ============================================
   記事カード（一覧ページ）
   ============================================ */
.entry-card,
.related-entry-card,
.recommend-entry-card {
  background: var(--haru-white);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius-lg);
  box-shadow: 0 3px 14px var(--haru-shadow);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  overflow: hidden;
}

.entry-card:hover,
.related-entry-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(200,90,138,0.18);
}

.entry-card-title,
.related-entry-card-title {
  color: var(--haru-text);

  font-size: 1.0em;
  line-height: 1.6;
  letter-spacing: 0.03em;
}

.entry-card:hover .entry-card-title,
.related-entry-card:hover .related-entry-card-title {
  color: var(--haru-sakura-deep);
}

/* カテゴリラベル */
.card-cat-label,
.entry-card-category {
  background: var(--haru-sakura) !important;
  color: #fff !important;
  border-radius: 20px;
  font-size: 0.72em;
  padding: 2px 10px;
  letter-spacing: 0.04em;
}

/* サムネイル */
.entry-card-thumb img,
.related-entry-card-thumb img {
  transition: transform 0.4s ease;
}

.entry-card:hover .entry-card-thumb img,
.related-entry-card:hover .related-entry-card-thumb img {
  transform: scale(1.04);
}

/* ============================================
   記事本文
   ============================================ */
.article {
  background: var(--haru-white);
  border-radius: var(--haru-radius-lg);
  padding: 36px 40px;
  box-shadow: 0 2px 16px var(--haru-shadow);
  border: 1px solid var(--haru-border);
}

/* 記事タイトル */
.entry-title,
h1.entry-title {
  color: var(--haru-sakura-deep);

  font-size: 1.8em;
  line-height: 1.5;
  letter-spacing: 0.05em;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--haru-border);
  margin-bottom: 24px;
}

/* h2 見出し */
.article h2 {
  color: var(--haru-text);

  font-size: 1.28em;
  padding: 10px 16px 10px 20px;
  margin: 2em 0 1em;
  background: linear-gradient(135deg, var(--haru-sakura-pale) 0%, #FFF9FA 100%);
  border-left: 4px solid var(--haru-sakura);
  border-radius: 0 var(--haru-radius) var(--haru-radius) 0;
  letter-spacing: 0.04em;
}

/* h3 見出し */
.article h3 {
  color: var(--haru-sakura-deep);

  font-size: 1.1em;
  padding: 6px 0 6px 14px;
  margin: 1.8em 0 0.9em;
  border-left: 3px solid var(--haru-wakakusa);
  letter-spacing: 0.04em;
}

/* h4 見出し */
.article h4 {
  color: var(--haru-text);
  font-size: 1.0em;
  font-weight: 700;
  padding: 4px 0 4px 10px;
  margin: 1.5em 0 0.8em;
  border-bottom: 1px dashed var(--haru-border);
}

/* 段落 */
.article p {
  color: var(--haru-text);
  margin-bottom: 1.4em;
}

/* リスト */
.article ul li::marker { color: var(--haru-sakura); }
.article ol li::marker { color: var(--haru-sakura-deep); font-weight: bold; }

/* 引用 */
.article blockquote {
  background: linear-gradient(135deg, var(--haru-sakura-pale), #FFFEF9);
  border-left: 4px solid var(--haru-sakura);
  border-radius: 0 var(--haru-radius) var(--haru-radius) 0;
  padding: 16px 20px;
  margin: 1.5em 0;
  color: var(--haru-text-light);
  font-style: italic;
}

.article blockquote::before {
  content: '\275D';
  color: var(--haru-sakura);
  font-size: 1.5em;
  line-height: 1;
  display: block;
  margin-bottom: 4px;
  font-style: normal;
}

/* テーブル */
.article table {
  border-collapse: collapse;
  width: 100%;
  border-radius: var(--haru-radius);
  overflow: hidden;
  box-shadow: 0 2px 8px var(--haru-shadow);
}

.article table th {
  background: linear-gradient(135deg, var(--haru-sakura), var(--haru-sakura-deep));
  color: #fff;
  padding: 10px 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  font-size: 0.9em;
}

.article table td {
  padding: 9px 14px;
  border-bottom: 1px solid var(--haru-border);
  font-size: 0.9em;
}

.article table tr:nth-child(even) td {
  background: var(--haru-sakura-pale);
}

.article table tr:hover td {
  background: rgba(244,167,185,0.15);
}

/* インラインコード */
.article code {
  background: #FDF0F3;
  border: 1px solid var(--haru-border);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 0.88em;
  color: var(--haru-sakura-deep);
  font-family: "Courier New", Courier, monospace;
}

/* コードブロック */
.article pre {
  background: #2D1B25;
  border-radius: var(--haru-radius);
  padding: 18px 20px;
  overflow-x: auto;
  border-left: 4px solid var(--haru-sakura);
  box-shadow: 0 3px 12px rgba(45,27,37,0.2);
}

.article pre code {
  background: transparent;
  border: none;
  color: #F9D0D8;
  font-size: 0.88em;
  padding: 0;
}

/* ============================================
   ボタン
   ============================================ */
.btn,
.wp-block-button__link,
.cocoon-block-button__link {
  background: linear-gradient(135deg, var(--haru-sakura) 0%, var(--haru-sakura-deep) 100%);
  color: #fff !important;
  border: none;
  border-radius: 30px;
  padding: 10px 28px;
  font-size: 0.9em;
  letter-spacing: 0.08em;
  box-shadow: 0 4px 12px var(--haru-shadow);
  transition: all 0.25s ease;
  text-decoration: none !important;
  display: inline-block;
}

.btn:hover,
.wp-block-button__link:hover,
.cocoon-block-button__link:hover {
  background: linear-gradient(135deg, var(--haru-sakura-deep) 0%, #9E3460 100%);
  box-shadow: 0 6px 18px rgba(200,90,138,0.32);
  transform: translateY(-2px);
  color: #fff !important;
}

/* ============================================
   サイドバー
   ============================================ */
#sidebar .widget {
  background: var(--haru-white);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius-lg);
  padding: 20px 18px;
  margin-bottom: 20px;
  box-shadow: 0 2px 10px var(--haru-shadow);
}

#sidebar .widget-title {
  color: var(--haru-sakura-deep);

  font-size: 1.0em;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0 0 8px 12px;
  border-left: 3px solid var(--haru-sakura);
  border-bottom: 1px dashed var(--haru-border);
  margin-bottom: 14px;
}

#sidebar .widget ul li {
  border-bottom: 1px dashed var(--haru-border);
  padding: 6px 0;
  font-size: 0.88em;
}

#sidebar .widget ul li:last-child {
  border-bottom: none;
}

#sidebar .widget ul li a {
  color: var(--haru-text);
  transition: color 0.2s, padding-left 0.2s;
}

#sidebar .widget ul li a:hover {
  color: var(--haru-sakura-deep);
  padding-left: 4px;
}

/* 検索ウィジェット */
#sidebar .search-form input[type="search"] {
  border: 1px solid var(--haru-border);
  border-radius: 20px 0 0 20px;
  padding: 8px 14px;
  font-size: 0.88em;
  background: var(--haru-white);
  color: var(--haru-text);
  outline: none;
}

#sidebar .search-form input[type="search"]:focus {
  border-color: var(--haru-sakura);
  box-shadow: 0 0 6px rgba(244,167,185,0.4);
}

#sidebar .search-form button[type="submit"] {
  background: var(--haru-sakura);
  border: none;
  border-radius: 0 20px 20px 0;
  padding: 8px 14px;
  cursor: pointer;
  color: #fff;
  transition: background 0.2s;
}

#sidebar .search-form button[type="submit"]:hover {
  background: var(--haru-sakura-deep);
}

/* ============================================
   タグクラウド
   ============================================ */
.tagcloud a {
  background: var(--haru-sakura-pale) !important;
  color: var(--haru-sakura-deep) !important;
  border: 1px solid var(--haru-border) !important;
  border-radius: 20px !important;
  padding: 3px 12px !important;
  font-size: 0.82em !important;
  transition: all 0.2s ease !important;
  display: inline-block;
  margin: 3px 2px;
  text-decoration: none !important;
}

.tagcloud a:hover {
  background: var(--haru-sakura) !important;
  color: #fff !important;
  border-color: var(--haru-sakura) !important;
  transform: scale(1.05);
  opacity: 1 !important;
}

/* ============================================
   パンくずリスト
   ============================================ */
.breadcrumb {
  background: rgba(253,238,242,0.7);
  border-radius: var(--haru-radius);
  padding: 8px 16px;
  font-size: 0.8em;
  color: var(--haru-text-light);
  margin-bottom: 16px;
  border: 1px solid var(--haru-border);
}

.breadcrumb a {
  color: var(--haru-text-light);
}

.breadcrumb a:hover {
  color: var(--haru-sakura-deep);
}

/* ============================================
   ページネーション
   ============================================ */
.pagination .page-numbers {
  color: var(--haru-text);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius);
  padding: 6px 12px;
  font-size: 0.9em;
  transition: all 0.2s ease;
  background: var(--haru-white);
}

.pagination .page-numbers:hover {
  background: var(--haru-sakura-pale);
  border-color: var(--haru-sakura);
  color: var(--haru-sakura-deep);
}

.pagination .page-numbers.current {
  background: linear-gradient(135deg, var(--haru-sakura), var(--haru-sakura-deep));
  color: #fff;
  border-color: var(--haru-sakura-deep);
}

/* ============================================
   目次（toc）
   ============================================ */
.toc {
  background: linear-gradient(135deg, var(--haru-sakura-pale) 0%, #FEFCF0 100%);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius-lg);
  padding: 20px 24px;
  margin: 1.8em 0;
}

.toc-title {
  color: var(--haru-sakura-deep);

  font-size: 1.0em;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 12px;
}

.toc ol, .toc ul { padding-left: 1.4em; }

.toc li {
  margin: 5px 0;
  font-size: 0.9em;
}

.toc a {
  color: var(--haru-text);
  text-decoration: none;
}

.toc a:hover {
  color: var(--haru-sakura-deep);
  opacity: 1;
}

/* ============================================
   「続きを読む」リンク
   ============================================ */
.more-link {
  display: inline-block;
  background: linear-gradient(135deg, var(--haru-sakura-pale), var(--haru-white));
  color: var(--haru-sakura-deep) !important;
  border: 1px solid var(--haru-border);
  border-radius: 20px;
  padding: 6px 20px;
  font-size: 0.85em;
  letter-spacing: 0.05em;
  transition: all 0.2s ease;
  text-decoration: none !important;
}

.more-link:hover {
  background: var(--haru-sakura-pale);
  border-color: var(--haru-sakura);
  transform: translateY(-1px);
  opacity: 1;
}

/* ============================================
   著者プロフィール
   ============================================ */
.author-box {
  background: linear-gradient(135deg, var(--haru-sakura-pale) 0%, var(--haru-wakakusa-pale) 100%);
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius-lg);
  padding: 24px;
  margin: 2em 0;
}

.author-box .author-name {
  color: var(--haru-sakura-deep);
  font-weight: 700;

}

.author-box .author-description {
  color: var(--haru-text-light);
  font-size: 0.9em;
}

/* ============================================
   コメント欄
   ============================================ */
.comment-list .comment-body {
  border-bottom: 1px dashed var(--haru-border);
  padding: 16px 0;
}

.comment-list .comment-meta {
  color: var(--haru-text-light);
  font-size: 0.82em;
}

.comment-list .comment-author .fn {
  color: var(--haru-sakura-deep);
  font-weight: 700;
}

#respond .comment-form-comment textarea,
#respond input[type="text"],
#respond input[type="email"],
#respond input[type="url"] {
  border: 1px solid var(--haru-border);
  border-radius: var(--haru-radius);
  padding: 10px 14px;
  width: 100%;
  background: var(--haru-white);
  color: var(--haru-text);
  font-family: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
  box-sizing: border-box;
}

#respond .comment-form-comment textarea:focus,
#respond input[type="text"]:focus,
#respond input[type="email"]:focus {
  border-color: var(--haru-sakura);
  outline: none;
  box-shadow: 0 0 8px rgba(244,167,185,0.3);
}

#respond #submit {
  background: linear-gradient(135deg, var(--haru-sakura), var(--haru-sakura-deep));
  color: #fff;
  border: none;
  border-radius: 20px;
  padding: 10px 28px;
  cursor: pointer;
  font-size: 0.9em;
  letter-spacing: 0.06em;
  transition: all 0.25s ease;
}

#respond #submit:hover {
  background: linear-gradient(135deg, var(--haru-sakura-deep), #9E3460);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px var(--haru-shadow);
}

/* ============================================
   フッター
   ============================================ */
#footer {
  background: linear-gradient(160deg, #3D2B1F 0%, #2A1A14 100%);
  color: rgba(253,238,242,0.8);
  padding: 40px 0 20px;
  margin-top: 40px;
  border-top: 3px solid var(--haru-sakura);
}

#footer a {
  color: rgba(244,167,185,0.85);
}

#footer a:hover {
  color: var(--haru-sakura);
  opacity: 1;
}

#footer .footer-copyright {
  color: rgba(253,238,242,0.45);
  font-size: 0.78em;
  text-align: center;
  padding-top: 20px;
  border-top: 1px solid rgba(244,167,185,0.2);
  margin-top: 20px;
}

#footer .widget-title {
  color: var(--haru-sakura);

  font-size: 0.95em;
  letter-spacing: 0.06em;
  border-bottom: 1px solid rgba(244,167,185,0.3);
  padding-bottom: 8px;
  margin-bottom: 12px;
}

/* ============================================
   アーカイブタイトル
   ============================================ */
.archive-title {
  color: var(--haru-sakura-deep);

  font-size: 1.4em;
  border-bottom: 2px solid var(--haru-border);
  padding-bottom: 10px;
  margin-bottom: 24px;
  letter-spacing: 0.06em;
}

.archive-title::before {
  content: '\301C';
  color: var(--haru-sakura);
  margin-right: 6px;
}

.archive-title::after {
  content: '\301C';
  color: var(--haru-sakura);
  margin-left: 6px;
}

/* ============================================
   SNSシェアボタン
   ============================================ */
.sns-buttons .sns-button {
  border-radius: 8px !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}

.sns-buttons .sns-button:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 5px 14px rgba(0,0,0,0.15) !important;
}

/* ============================================
   「ページトップへ」ボタン
   ============================================ */
#go-to-top {
  background: var(--haru-sakura) !important;
  color: #fff !important;
  border-radius: 50% !important;
  box-shadow: 0 4px 14px var(--haru-shadow) !important;
  transition: background 0.2s, transform 0.2s !important;
}

#go-to-top:hover {
  background: var(--haru-sakura-deep) !important;
  transform: translateY(-3px) !important;
}

/* ============================================
   インフォメーションボックス
   ============================================ */
.information-box {
  background: linear-gradient(135deg, var(--haru-sakura-pale), #FEFEF5);
  border: 1px solid var(--haru-border);
  border-left: 4px solid var(--haru-sakura);
  border-radius: 0 var(--haru-radius) var(--haru-radius) 0;
  padding: 14px 18px;
  margin: 1.4em 0;
  font-size: 0.92em;
}

/* ============================================
   レスポンシブ
   ============================================ */
@media screen and (max-width: 768px) {
  .article {
    padding: 20px 18px;
    border-radius: var(--haru-radius);
  }

  .entry-title,
  h1.entry-title {
    font-size: 1.4em;
  }

  .article h2 {
    font-size: 1.15em;
    padding: 8px 12px 8px 16px;
  }

  .header-container::after {
    height: 2px;
  }

  #footer {
    padding: 28px 0 16px;
  }
}

@media screen and (max-width: 480px) {
  body {
    font-size: 15px;
  }

  .article {
    padding: 16px 14px;
  }

  .toc {
    padding: 14px 16px;
  }
}
