@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/* ==================================================
   COM≠PASS Wiki Style
   Cocoon Child
   目的：
   - Wikipedia風の3カラム構成
   - 左：目次
   - 中央：本文
   - 右：プロフィール表
================================================== */

/* ==================================================
   Base
================================================== */

html {
  scroll-behavior: smooth;
}

body {
  background: #ffffff;
  color: #202122;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  font-size: 14px;
  line-height: 1.78;
}

#container {
  background: #ffffff;
}

a {
  color: #0645ad;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* Cocoon装飾リセット */
.main,
.content,
.content-in,
.article,
.entry-content,
.sidebar,
.widget,
.entry-card,
.related-entry-card,
.a-wrap {
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* ==================================================
   Character Page Layout
   3カラム：左目次 / 中央本文 / 右プロフィール表
================================================== */

body.single-character .content-in {
  width: 100% !important;
  max-width: 1380px !important;
  margin: 0 auto !important;
  position: relative !important;
  display: block !important;
}

/* Cocoon標準サイドバーは使わない */
body.single-character .sidebar,
body.single-character #sidebar {
  display: none !important;
}

/* 中央本文カラム */
body.single-character .main {
  width: auto !important;
  max-width: none !important;
  margin-left: 250px !important;
  margin-right: 330px !important;
  padding: 24px 28px 56px !important;
  background: #ffffff !important;
  border: none !important;
}

/* 本文エリア */
body.single-character .article,
body.single-character .entry-content {
  position: static !important;
  color: #202122;
  font-size: 14px;
  line-height: 1.78;
}

/* 通常投稿・固定ページは最低限 */
body:not(.single-character) .content-in {
  max-width: 1180px;
  margin: 0 auto;
}

body:not(.single-character) .main {
  background: #ffffff;
  border: none;
  padding: 28px 36px;
}

/* ==================================================
   Left Table of Contents
================================================== */

body.single-character .toc,
body.single-character #toc {
  position: fixed !important;
  top: 88px !important;
  left: max(24px, calc((100vw - 1380px) / 2 + 24px)) !important;
  width: 210px !important;
  max-height: calc(100vh - 120px) !important;
  overflow-y: auto !important;
  z-index: 20 !important;

  background: #ffffff !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 12px 12px 0 !important;
  margin: 0 !important;

  font-size: 13px !important;
  line-height: 1.45 !important;
}

/* 目次タイトル */
body.single-character .toc-title,
body.single-character .toc .toc-title,
body.single-character #toc .toc-title {
  display: block !important;
  color: #202122 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  border-bottom: 1px solid #a2a9b1 !important;
  padding: 0 0 7px !important;
  margin: 0 0 8px !important;
  text-align: left !important;
}

body.single-character .toc-title::before,
body.single-character .toc-title::after {
  content: none !important;
  display: none !important;
}

/* 目次リスト */
body.single-character .toc ul,
body.single-character .toc ol,
body.single-character #toc ul,
body.single-character #toc ol,
body.single-character .toc-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.single-character .toc li,
body.single-character #toc li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.single-character .toc a,
body.single-character #toc a {
  display: block !important;
  color: #202122 !important;
  text-decoration: none !important;
  padding: 4px 4px 4px 10px !important;
  border-left: 2px solid transparent !important;
}

body.single-character .toc a:hover,
body.single-character #toc a:hover {
  color: #0645ad !important;
  background: #f8f9fa !important;
  border-left-color: #a2a9b1 !important;
  text-decoration: none !important;
}

/* H3階層 */
body.single-character .toc ul ul a,
body.single-character .toc ol ol a,
body.single-character #toc ul ul a,
body.single-character #toc ol ol a {
  padding-left: 22px !important;
  font-size: 12px !important;
  color: #54595d !important;
}

body.single-character .toc-number {
  color: #54595d !important;
  margin-right: 4px !important;
}

/* ==================================================
   Right Infobox
   PHPから自動出力される .wiki-infobox を右カラム化
================================================== */

body.single-character .entry-content table.wiki-infobox,
body.single-character .article table.wiki-infobox {
  float: none !important;
  clear: none !important;
  position: absolute !important;

  top: 24px !important;
  right: max(24px, calc((100vw - 1380px) / 2 + 24px)) !important;

  width: 290px !important;
  margin: 0 !important;

  border-collapse: collapse !important;
  border-spacing: 0 !important;
  background: #f8f9fa !important;
  border: 1px solid #a2a9b1 !important;

  font-size: 12.5px !important;
  line-height: 1.5 !important;
  z-index: 15 !important;
}

/* 表セル */
body.single-character .entry-content table.wiki-infobox th,
body.single-character .entry-content table.wiki-infobox td,
body.single-character .article table.wiki-infobox th,
body.single-character .article table.wiki-infobox td {
  border: 1px solid #a2a9b1 !important;
  padding: 7px 9px !important;
  vertical-align: top !important;
}

/* 表見出し */
body.single-character .entry-content table.wiki-infobox th,
body.single-character .article table.wiki-infobox th {
  background: #eaecf0 !important;
  color: #202122 !important;
  font-weight: 700 !important;
  text-align: center !important;
  width: 38% !important;
}

/* 一番上の名前行 */
body.single-character .entry-content table.wiki-infobox th[colspan="2"],
body.single-character .article table.wiki-infobox th[colspan="2"] {
  background: #eaecf0 !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

/* 画像セル */
body.single-character .entry-content table.wiki-infobox .wiki-infobox-image,
body.single-character .article table.wiki-infobox .wiki-infobox-image {
  background: #ffffff !important;
  text-align: center !important;
  padding: 8px !important;
}

/* 画像 */
body.single-character .entry-content table.wiki-infobox .wiki-infobox-image img,
body.single-character .article table.wiki-infobox .wiki-infobox-image img {
  display: block !important;
  width: 100% !important;
  max-width: 260px !important;
  height: auto !important;
  margin: 0 auto !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* ==================================================
   Article Text
================================================== */

.article p,
.entry-content p {
  margin: 0 0 1em !important;
}

.article ul,
.article ol,
.entry-content ul,
.entry-content ol {
  margin-top: 0.3em !important;
  margin-bottom: 1em !important;
  padding-left: 1.6em !important;
}

.article li,
.entry-content li {
  margin-bottom: 0.2em !important;
}

/* ==================================================
   Title
================================================== */

.entry-title,
.article h1 {
  background: transparent !important;
  color: #202122 !important;
  border: none !important;
  border-bottom: 1px solid #a2a9b1 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 0 8px !important;
  margin: 0 0 18px !important;
  font-size: 30px !important;
  font-weight: 400 !important;
  line-height: 1.35 !important;
  letter-spacing: 0 !important;
}

.entry-header {
  margin-bottom: 12px !important;
}

/* ==================================================
   Headings
================================================== */

.article h2,
.entry-content h2,
.article h2.wp-block-heading,
.entry-content h2.wp-block-heading,
body.single-character h2,
body.single-character .entry-content h2,
body.single-character .article h2,
body.single-character .wp-block-heading {
  background: transparent !important;
  color: #202122 !important;
  border: none !important;
  border-bottom: 1px solid #a2a9b1 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 0 4px !important;
  margin: 32px 0 12px !important;
  font-size: 21px !important;
  font-weight: 400 !important;
  line-height: 1.45 !important;
}

.article h2::before,
.article h2::after,
.entry-content h2::before,
.entry-content h2::after,
.article h2.wp-block-heading::before,
.article h2.wp-block-heading::after,
.entry-content h2.wp-block-heading::before,
.entry-content h2.wp-block-heading::after,
body.single-character h2::before,
body.single-character h2::after {
  content: none !important;
  display: none !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

.article h3,
.entry-content h3,
.article h3.wp-block-heading,
.entry-content h3.wp-block-heading,
body.single-character h3,
body.single-character .entry-content h3,
body.single-character .article h3 {
  background: transparent !important;
  color: #202122 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 24px 0 8px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
}

.article h3::before,
.article h3::after,
.entry-content h3::before,
.entry-content h3::after,
body.single-character h3::before,
body.single-character h3::after {
  content: none !important;
  display: none !important;
}

.article h4,
.entry-content h4,
body.single-character h4,
body.single-character .entry-content h4 {
  background: transparent !important;
  color: #202122 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 18px 0 6px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
}

/* ==================================================
   Normal Tables
   wiki-infobox以外の本文表
================================================== */

.article table:not(.wiki-infobox),
.entry-content table:not(.wiki-infobox) {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  margin: 18px 0;
  font-size: 13px;
  line-height: 1.55;
  background: #ffffff;
}

.article table:not(.wiki-infobox) th,
.article table:not(.wiki-infobox) td,
.entry-content table:not(.wiki-infobox) th,
.entry-content table:not(.wiki-infobox) td {
  border: 1px solid #a2a9b1;
  padding: 7px 9px;
  vertical-align: top;
}

.article table:not(.wiki-infobox) th,
.entry-content table:not(.wiki-infobox) th {
  background: #eaecf0;
  color: #202122;
  font-weight: 700;
  width: 28%;
}

/* ==================================================
   Images
================================================== */

.eye-catch-wrap {
  margin-bottom: 18px;
}

.eye-catch-wrap img,
.entry-content img,
.article img {
  border-radius: 0;
  box-shadow: none;
}

/* ==================================================
   Blog-like Parts Hide
================================================== */

.date-tags,
.post-date,
.post-update,
.author-info,
.footer-meta,
.sns-share,
.sns-follow,
.sns-share-buttons,
.sns-follow-buttons,
.related-entry-heading,
.related-list,
.pager-post-navi,
.comment-area,
#comment-area,
.cat-link,
.tag-link {
  display: none !important;
}

/* ==================================================
   Archive / List
================================================== */

.archive-title {
  background: transparent !important;
  border-bottom: 1px solid #a2a9b1 !important;
  padding-bottom: 6px !important;
  font-size: 24px !important;
  font-weight: 400 !important;
}

.entry-card-title {
  font-size: 15px;
  font-weight: 600;
}

/* ==================================================
   Responsive
================================================== */

@media screen and (max-width: 1180px) {
  body.single-character .content-in {
    max-width: none !important;
    margin: 0 !important;
  }

  body.single-character .main {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 24px 28px 42px !important;
  }

  body.single-character .toc,
  body.single-character #toc {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    max-height: none !important;
    overflow: visible !important;
    background: #f8f9fa !important;
    border: 1px solid #a2a9b1 !important;
    padding: 12px 14px !important;
    margin: 0 0 22px !important;
  }

  body.single-character .entry-content table.wiki-infobox,
  body.single-character .article table.wiki-infobox {
    position: static !important;
    float: none !important;
    width: 100% !important;
    margin: 0 0 20px !important;
  }
}

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

  body.single-character .main,
  body:not(.single-character) .main {
    padding: 20px 16px 36px !important;
    border: none !important;
  }

  .entry-title,
  .article h1 {
    font-size: 25px !important;
  }

  .article h2,
  .entry-content h2,
  body.single-character h2 {
    font-size: 19px !important;
  }

  .article h3,
  .entry-content h3,
  body.single-character h3 {
    font-size: 16px !important;
  }
}

@media screen and (max-width: 480px) {
  body.single-character .main,
  body:not(.single-character) .main {
    padding: 18px 12px 32px !important;
  }

  .entry-title,
  .article h1 {
    font-size: 23px !important;
    margin-bottom: 16px !important;
  }

  .article table,
  .entry-content table {
    font-size: 12.5px !important;
  }

  .article th,
  .article td,
  .entry-content th,
  .entry-content td {
    padding: 6px 7px !important;
  }
}

/* ==================================================
   COM≠PASS Wiki Layout Final Fix
   左：目次 / 中央：本文 / 右：プロフィール表
   ※ absolute配置をやめて、本文内をグリッド化する
================================================== */

/* キャラクターページ全体 */
body.single-character .content-in {
  width: 100% !important;
  max-width: 1380px !important;
  margin: 0 auto !important;
  position: relative !important;
}

/* Cocoon標準サイドバーは使わない */
body.single-character .sidebar,
body.single-character #sidebar {
  display: none !important;
}

/* 左目次分だけ本文全体を右へ */
body.single-character .main {
  max-width: none !important;
  width: auto !important;
  margin-left: 250px !important;
  margin-right: 24px !important;
  padding: 24px 28px 56px !important;
  background: #ffffff !important;
  border: none !important;
}

/* 左目次 */
body.single-character .toc,
body.single-character #toc {
  position: fixed !important;
  top: 88px !important;
  left: max(24px, calc((100vw - 1380px) / 2 + 24px)) !important;
  width: 210px !important;
  max-height: calc(100vh - 120px) !important;
  overflow-y: auto !important;
  z-index: 20 !important;
  background: #ffffff !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 12px 12px 0 !important;
  margin: 0 !important;
}

/* 本文 + 右プロフィール表 */
body.single-character .compass-character-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 290px !important;
  column-gap: 28px !important;
  align-items: start !important;
  width: 100% !important;
}

/* 中央本文 */
body.single-character .compass-character-body {
  min-width: 0 !important;
}

/* 右プロフィール表カラム */
body.single-character .compass-character-side {
  width: 290px !important;
}

/* 以前のabsolute / float指定を完全解除 */
body.single-character .entry-content table.wiki-infobox,
body.single-character .article table.wiki-infobox,
body.single-character .compass-character-side table.wiki-infobox {
  position: static !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  float: none !important;
  clear: none !important;
  width: 100% !important;
  margin: 0 !important;
  z-index: auto !important;

  border-collapse: collapse !important;
  border-spacing: 0 !important;
  background: #f8f9fa !important;
  border: 1px solid #a2a9b1 !important;
  font-size: 12.5px !important;
  line-height: 1.5 !important;
}

/* 表セル */
body.single-character table.wiki-infobox th,
body.single-character table.wiki-infobox td {
  border: 1px solid #a2a9b1 !important;
  padding: 7px 9px !important;
  vertical-align: top !important;
}

/* 項目名 */
body.single-character table.wiki-infobox th {
  background: #eaecf0 !important;
  color: #202122 !important;
  font-weight: 700 !important;
  text-align: center !important;
  width: 38% !important;
}

/* 名前行 */
body.single-character table.wiki-infobox th[colspan="2"] {
  background: #eaecf0 !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

/* 画像 */
body.single-character table.wiki-infobox .wiki-infobox-image {
  background: #ffffff !important;
  text-align: center !important;
  padding: 8px !important;
}

body.single-character table.wiki-infobox .wiki-infobox-image img {
  display: block !important;
  width: 100% !important;
  max-width: 260px !important;
  height: auto !important;
  margin: 0 auto !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* 狭い画面では1カラムに戻す */
@media screen and (max-width: 1180px) {
  body.single-character .main {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 24px 28px 42px !important;
  }

  body.single-character .toc,
  body.single-character #toc {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    max-height: none !important;
    overflow: visible !important;
    background: #f8f9fa !important;
    border: 1px solid #a2a9b1 !important;
    padding: 12px 14px !important;
    margin: 0 0 22px !important;
  }

  body.single-character .compass-character-layout {
    display: block !important;
  }

  body.single-character .compass-character-side {
    width: 100% !important;
    margin-bottom: 20px !important;
  }

  body.single-character table.wiki-infobox {
    width: 100% !important;
    margin: 0 0 20px !important;
  }
}

/* ==================================================
   COM≠PASS Wiki B Layout
   左：目次 / 中央：本文 / 右：プロフィールカード
   プロフィールカードはタイトル下線の下＝本文開始位置に揃える
================================================== */

body.single-character .content-in {
  width: 100% !important;
  max-width: 1380px !important;
  margin: 0 auto !important;
  position: relative !important;
}

/* Cocoon標準サイドバーは使わない */
body.single-character .sidebar,
body.single-character #sidebar {
  display: none !important;
}

/* ページ本文全体：左に目次領域を確保 */
body.single-character .main {
  max-width: none !important;
  width: auto !important;
  margin-left: 250px !important;
  margin-right: 24px !important;
  padding: 24px 28px 56px !important;
  background: #ffffff !important;
  border: none !important;
}

/* 左目次：記事エリア上端に寄せる */
body.single-character .toc,
body.single-character #toc {
  position: fixed !important;
  top: 145px !important;
  left: max(24px, calc((100vw - 1380px) / 2 + 24px)) !important;
  width: 210px !important;
  max-height: calc(100vh - 170px) !important;
  overflow-y: auto !important;
  z-index: 20 !important;

  background: #ffffff !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 12px 12px 0 !important;
  margin: 0 !important;
}

/* 記事タイトル：中央本文カラム幅だけに制限 */
body.single-character .entry-title,
body.single-character .article h1 {
  max-width: calc(100% - 318px) !important;
  margin-right: 318px !important;

  background: transparent !important;
  color: #202122 !important;
  border: none !important;
  border-bottom: 1px solid #a2a9b1 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 0 8px !important;
  margin-top: 0 !important;
  margin-bottom: 18px !important;

  font-size: 30px !important;
  font-weight: 400 !important;
  line-height: 1.35 !important;
}

/* 本文 + 右プロフィールカード */
body.single-character .compass-character-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 290px !important;
  column-gap: 28px !important;
  align-items: start !important;
  width: 100% !important;
}

/* 中央本文 */
body.single-character .compass-character-body {
  min-width: 0 !important;
}

/* 右プロフィールカード */
body.single-character .compass-character-side {
  width: 290px !important;
  align-self: start !important;
}

/* プロフィール表：absolute / float を完全解除 */
body.single-character .compass-character-side table.wiki-infobox,
body.single-character .entry-content table.wiki-infobox,
body.single-character .article table.wiki-infobox {
  position: static !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  float: none !important;
  clear: none !important;

  width: 100% !important;
  margin: 0 !important;
  z-index: auto !important;

  border-collapse: collapse !important;
  border-spacing: 0 !important;
  background: #f8f9fa !important;
  border: 1px solid #a2a9b1 !important;

  font-size: 12.5px !important;
  line-height: 1.5 !important;
}

/* プロフィール表セル */
body.single-character table.wiki-infobox th,
body.single-character table.wiki-infobox td {
  border: 1px solid #a2a9b1 !important;
  padding: 7px 9px !important;
  vertical-align: top !important;
}

/* プロフィール表：項目名 */
body.single-character table.wiki-infobox th {
  background: #eaecf0 !important;
  color: #202122 !important;
  font-weight: 700 !important;
  text-align: center !important;
  width: 38% !important;
}

/* プロフィール表：名前行 */
body.single-character table.wiki-infobox th[colspan="2"] {
  background: #eaecf0 !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

/* プロフィール画像 */
body.single-character table.wiki-infobox .wiki-infobox-image {
  background: #ffffff !important;
  text-align: center !important;
  padding: 8px !important;
}

body.single-character table.wiki-infobox .wiki-infobox-image img {
  display: block !important;
  width: 100% !important;
  max-width: 260px !important;
  height: auto !important;
  margin: 0 auto !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* 狭い画面では1カラムに戻す */
@media screen and (max-width: 1180px) {
  body.single-character .main {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 24px 28px 42px !important;
  }

  body.single-character .entry-title,
  body.single-character .article h1 {
    max-width: none !important;
    margin-right: 0 !important;
  }

  body.single-character .toc,
  body.single-character #toc {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    max-height: none !important;
    overflow: visible !important;
    background: #f8f9fa !important;
    border: 1px solid #a2a9b1 !important;
    padding: 12px 14px !important;
    margin: 0 0 22px !important;
  }

  body.single-character .compass-character-layout {
    display: block !important;
  }

  body.single-character .compass-character-side {
    width: 100% !important;
    margin-bottom: 20px !important;
  }

  body.single-character table.wiki-infobox {
    width: 100% !important;
    margin: 0 0 20px !important;
  }
}

/* ==================================================
   COM≠PASS Wiki TOC Position Adjust
   目次の上端を記事タイトルに合わせる
================================================== */

body.single-character .toc,
body.single-character #toc {
  top: 210px !important;
  max-height: calc(100vh - 280px) !important;
}