/* assets/css/page.css */
/* the_content 用：/shiryo-template.php の .prose を整形 */

.prose {
  color: #2b1d13;
  line-height: 1.9;
  font-size: 16px;
}

/* 余白の基準 */
.prose>*+* {
  margin-top: 1rem;
}

/* 見出し（■付き） */
.prose h2,
.prose h3 {
  position: relative;
  margin-top: 1.6rem;
  margin-bottom: 0.6rem;
  padding-left: 1.1rem;
  font-weight: 800;
  color: #2b1d13;
  line-height: 1.4;
}

.prose h2 {
  font-size: 1.25rem;
}

/* 20px */
.prose h3 {
  font-size: 1.12rem;
}

/* 18px */

.prose h2::before,
.prose h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.55rem;
  height: 0.55rem;
  background: #7a3a20;
  /* こげ茶〜赤茶（■） */
  border-radius: 2px;
}

/* 段落 */
.prose p {
  margin: 0.4rem 0;
}

/* 連絡先みたいな「項目: 値」の並びが読みやすいように */
.prose p strong,
.prose p b {
  font-weight: 800;
}

/* リスト */
.prose ul,
.prose ol {
  padding-left: 1.25rem;
  margin: 0.6rem 0 0.6rem;
}

.prose li {
  margin: 0.25rem 0;
}

/* リンク（メールアドレスが青になる） */
.prose a {
  color: #1d4ed8;
  text-decoration: underline;
  text-underline-offset: 2px;
  word-break: break-word;
}

.prose a:hover {
  color: #1e40af;
}

/* 画像が入っても崩れないように */
.prose img {
  max-width: 100%;
  height: auto;
}

/* 表があるページ用（必要なら） */
.prose table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1rem;
  font-size: 0.95rem;
}

.prose th,
.prose td {
  border: 1px solid #d8c7a6;
  padding: 0.6rem 0.75rem;
  vertical-align: top;
}

.prose th {
  background: #fff8ea;
  font-weight: 800;
}

/* 区切り線 */
.prose hr {
  border: none;
  border-top: 1px solid #e6d7bd;
  margin: 1.25rem 0;
}

/* 小さい注記（※〜） */
.prose .note,
.prose small {
  color: #5b463b;
  font-size: 0.92rem;
}

/* モバイルでの可読性 */
@media (max-width: 640px) {
  .prose {
    font-size: 15px;
  }

  .prose h2 {
    font-size: 1.15rem;
  }

  .prose h3 {
    font-size: 1.05rem;
  }
}

/* =========================================
   Gutenberg ハイライト → 文字色として使用
========================================= */

/* markタグの背景を消す */
.prose mark {
  background: transparent !important;
  padding: 0;
}

/* 各カラーを文字色として適用 */
.prose .has-black-color {
  color: #000 !important;
}

.prose .has-cyan-bluish-gray-color {
  color: #abb8c3 !important;
}

.prose .has-white-color {
  color: #ffffff !important;
}

.prose .has-vivid-red-color {
  color: #CF2E2E !important;
}

.prose .has-luminous-vivid-orange-color {
  color: #ff6900 !important;
}

.prose .has-luminous-vivid-amber-color {
  color: #fcb900 !important;
}

.prose .has-light-green-cyan-color {
  color: #7bdcb5 !important;
}

.prose .has-vivid-green-cyan-color {
  color: #00d084 !important;
}

.prose .has-pale-cyan-blue-color {
  color: #8ed1fc !important;
}

.prose .has-vivid-cyan-blue-color {
  color: #0693e3 !important;
}

.prose .has-vivid-purple-color {
  color: #9b51e0 !important;
}


/* Gutenberg Columns を確実に有効化 */
.prose .wp-block-columns {
  display: flex !important;
  gap: 2rem;
  align-items: flex-start;
}

.prose .wp-block-column {
  flex: 1 1 0;
  min-width: 0;
  /* 画像や長文で崩れない */
}

/* SPは縦積みに */
@media (max-width: 782px) {
  .prose .wp-block-columns {
    flex-direction: column !important;
  }
}

/* =========================================
   インライン画像（文章中の a > img）が改行されないようにする
   - 文章中だけ inline に戻す
   - 画像ブロック（figure）は従来どおり
========================================= */

/* テーマ側の img{display:block} 等を上書き */
.prose p img,
.prose li img,
.prose p a img,
.prose li a img {
  display: inline-block !important;
  vertical-align: middle;
  margin: 0 0.35em;
  max-width: none;
  /* アイコンが勝手に縮むのを防ぐ（不要なら消してOK） */
  height: auto;
}

/* a が block だと画像が別行に落ちるので、文章中リンクは inline に戻す */
.prose p a,
.prose li a {
  display: inline;
}

/* Gutenbergの画像ブロックはこれまで通り（インライン化しない） */
.prose figure img,
.prose .wp-block-image img {
  display: block !important;
  max-width: 100%;
}

/* =========================
   リスト（ul/ol）を整える
   ========================= */

/* マーカーを強制的に出す（テーマのリセット対策） */
.prose ul {
  list-style: disc !important;
  list-style-position: outside;
  padding-left: 1.5rem;
  margin: 0.75rem 0;
}

.prose ol {
  list-style: decimal !important;
  list-style-position: outside;
  padding-left: 1.6rem;
  margin: 0.75rem 0;
}

/* li の間延びを抑える */
.prose li {
  margin: 0.35rem 0;
  line-height: 1.85;
}

/* li 内で Gutenberg が <p> を入れてくることがあるので余白を殺す */
.prose li>p {
  margin: 0.15rem 0;
}

/* ネストしたリストの余白 */
.prose li>ul,
.prose li>ol {
  margin-top: 0.35rem;
  margin-bottom: 0.35rem;
}

/* マーカーの色をサイトに馴染ませる（対応ブラウザのみ） */
.prose li::marker {
  color: #7a3a20;
  font-weight: 700;
}

/* 念のため：テーマが li を display:flex 等にしている場合の崩れ対策 */
.prose ul li,
.prose ol li {
  display: list-item !important;
}

/* ===== probe header layout ===== */
.probe__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  /* 画面が狭い時は折り返す */
}

.probe__title {
  margin: 0;
  min-width: 14rem;
}

/* ===== OPAC form ===== */
.opac-form {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}

.opac-form .search-form {
  height: 40px;
  padding: 0 12px;
  border: 1px solid #cbb892;
  border-radius: 8px;
  background: #fff;
  min-width: 260px;
  max-width: 420px;
  width: min(42vw, 420px);
}

.opac-form .search-button {
  height: 40px;
  padding: 0 14px;
  border: 1px solid #7a5a2c;
  border-radius: 8px;
  background: #7a5a2c;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.opac-form .search-button:hover {
  filter: brightness(0.95);
}

/* スマホは縦積み */
@media (max-width: 640px) {
  .opac-form {
    width: 100%;
  }

  .opac-form .search-form {
    width: 100%;
    min-width: 0;
  }
}