/* =============================
   styles.css（ブログ1ページ＋ヘッダー右上に検索）
   初心者向けコメント付き
   ============================= */

/* === 1) リセット＆基本設定 ====================== */
/* すべての要素のボックスサイズを「枠線込み」に統一（レイアウト崩れを防ぐ） */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* 基本の文字設定と行間。日本語では少し広めの行間が読みやすい */
body {
  margin: 0;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;

  /* 1. 画面いっぱいの最小高さを確保（dvhはモバイルのバーを考慮した単位） */
  min-height: 100dvh;
  /* 2. 縦方向のFlexボックスにする */
  display: flex;
  flex-direction: column;
}

main {
  /* 3. 余ったスペースをすべて埋める */
  flex: 1;
}

/* 画像は親の幅を超えないようにする */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* === 2) カラーテーマ（変数） ==================== */
/* ライトモードの色。あとからここを変えるだけで配色を一括調整可能 */
:root {
  --bg: #f4f4f2;
  /* 背景色 */
  --fg: #222;
  /* 文字色 */
  --muted: #7d7b83;
  /* 補助文字色（薄め） */
  --border: #aaa;
  /* 罫線色 */
  --surface: #f7f6fb;
  /* カードなどの面の色 */
  --primary: #52415c;
  /* アクセント色（リンク・ボタン等） */

  /* 検索結果がある場合のスタイル */
  --bg-searched: #1e1e1c;
  /* 背景色 */
  --fg-searched: #f4f4f2;
  /* 文字色 */
  --surface-searched: #7d7b83;
  /* カードなどの面の色 */
  --primary-searched: #7d7b83;
  /* アクセント色（リンク・ボタン等） */

  --maxw: 920px;
  /* コンテンツ最大幅 */
  --radius: 8px;
  /* 角丸 */
  --shadow: 0 8px 24px rgba(2, 6, 23, .08);
  /* 影 */
}


/* ページ全体の背景色と文字色 */
html {
  overflow-x: hidden;
}

body {
  background: var(--bg);
  color: var(--fg);
}

body.searched {
  background: var(--bg-searched);
  color: var(--fg-searched);
}

/* リンクの色（アクセント色を使用） */
a {
  color: var(--primary);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* アクセシビリティ用：画面には見せないがスクリーンリーダーには読ませる */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* === 3) レイアウト共通 =========================== */
/* 中央寄せの共通コンテナ。左右の余白は画面幅に応じて可変 */
.container {
  min-width: 50%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: clamp(16px, 2vw, 24px);
}

/* === 4) ヘッダー（上部固定＆半透明背景） ======== */
.site-header {
  position: sticky;
  /* スクロールしても上に張り付く */
  top: 0;
  z-index: 40;
  /* 背景をぼかしてガラス風に (pseudo-elementへ移動) */
  border-bottom: 1px solid var(--border);
}

.site-header::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: color-mix(in oklab, var(--bg) 90%, transparent);
  backdrop-filter: blur(8px);
}

body.searched .site-header {
  background: transparent;
}

body.searched .site-header::before {
  background: color-mix(in oklab, var(--bg-searched) 90%, transparent);
}

/* ヘッダー内の左右配置（ロゴ・検索・メニュー） */
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-block: 10px;
}

/* サイト名＆ロゴ */
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
}

.logo {
  inline-size: 28px;
  block-size: 28px;
  border-radius: 8px;
  background: radial-gradient(100% 100% at 30% 30%, var(--primary), #22d3ee);
  box-shadow: var(--shadow);
}

.brand-name {
  font-size: 17px;
  white-space: nowrap;
  /* 折り返し防止 */
}

/* === 5) ヘッダー右側（検索とナビボタン） ========= */
/* 検索フォームとメニュー開閉ボタンを横並び */
.header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  /* 狭い画面でのオーバーフロー防止 */
  margin-left: auto;
}

/* 検索テキストボックス */
.search-input {
  width: clamp(140px, 24vw, 400px);
  /* 画面幅に応じて自動で伸び縮み */
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  color: var(--fg);
  outline: none;
}

.search-input:focus {
  border-color: color-mix(in oklab, var(--primary) 60%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 25%, transparent);
}

/* 検索ボタン */
.search-btn {
  padding: 7px 10px;
  border: 1px solid color-mix(in oklab, var(--primary) 60%, var(--border));
  border-radius: 10px;
  background: var(--primary);
  color: #fff;
  cursor: pointer;
}

.search-btn:hover {
  filter: brightness(1.05);
}

/* ハンバーガー（モバイル） */
.nav-toggle {
  display: none;
  /* PCでは非表示 */
  appearance: none;
  border: none;
  background: color-mix(in oklab, var(--bg) 90%, transparent);
  color: var(--fg);
  padding: 12px 14px;
  cursor: pointer;
  font-size: 20px;
}

.nav-toggle .bars {
  display: inline-block;
  inline-size: 24px;
  block-size: 3px;
  background: currentColor;
  box-shadow: 0 7px 0 0 currentColor, 0 14px 0 0 currentColor;
  /* 3本線に見せる */
  transform: translateY(-6px);
  transition: all 0.3s ease;
}

/* === 6) グローバルナビ（PC/モバイル） ========== */
/* === 6) グローバルナビ（共通ベース） ========== */
.primary-nav {
  /* PC/モバイル共通の基本設定があればここに書く */
}

/* リスト自体のリセット（共通） */
.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-list a {
  text-decoration: none;
}

/* 画面幅が狭いときのナビ表示（右からスライドイン） */
@media (max-width: 880px) {
  .nav-toggle {
    display: inline-flex;
  }

  /* モバイルで表示 */

  /* ヘッダーレイアウトをflexに変更 */
  .header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .primary-nav {
    position: fixed;
    right: 0;
    top: 0;
    height: 100vh;
    width: 280px;
    background: var(--surface);
    border-left: 1px solid var(--border);
    box-shadow: -4px 0 12px rgba(0, 0, 0, 0.15);
    display: none;
    /* 初期状態は非表示 */
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s ease-out;
    z-index: 1000;
    overflow-y: auto;
    padding-top: 60px;
  }

  .primary-nav.open {
    transform: translateX(0);
    visibility: visible;
    /* 追加: 開いたときだけ表示 */
  }

  .nav-list {
    flex-direction: column;
    padding: 16px 12px;
    gap: 8px;
    margin: 0;
    width: 100%;
  }

  .nav-list a {
    display: block;
    padding: 12px 16px;
    color: #708090;
  }

  /* ブランド名を隠してスペース確保 */
  .brand-name {
    display: none;
  }

  /* 検索欄の幅調整 */
  .search-input {
    width: clamp(80px, 35vw, 200px);
    font-size: 14px;
    /* モバイルでは文字サイズを少し下げる */
  }

  /* 検索ボタン復活（少しパディング詰める） */
  .search-btn {
    display: inline-block;
    padding: 7px 8px;
    font-size: 14px;
    white-space: nowrap;
  }

  /* モバイルで表がはみ出さないようにする */
  table {
    min-width: unset;
    width: 100%;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  /* オーバーレイ（メニュー開いてるときの背景を暗くする） */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0);
    pointer-events: none;
    transition: background 0.3s ease;
    z-index: 999;
  }

  body.menu-open::before {
    background: rgba(0, 0, 0, 0.5);
    pointer-events: auto;
  }
}

/* === 7) 記事ヘッダー（タイトルなど） ============ */
.layout {
  padding-block: 20px;
}

.article-header {
  background: #1e1e1c;
  margin-block: 10px 18px;
  text-align: center;
}

.eyebrow {
  font-size: 12px;
  color: var(--muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.title {
  color: #e8e6e1;
  font-size: clamp(22px, 4.6vw, 40px);
  line-height: 1.15;
  margin: .2em 0;
}

.test {
  color: #e8e6e1;
  font-size: 14px;
}

.meta {
  color: var(--muted);
  font-size: 14px;
}

.hero {
  margin: 14px 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
}

.hero figcaption {
  padding: 8px 12px;
  color: var(--muted);
  font-size: 13px;
}

/* === 8) 本文（読みやすさ重視） ================== */
.prose {
  font-size: clamp(16px, 2.1vw, 18.5px);
  line-height: 1.9;
}

.prose h2 {
  font-size: clamp(20px, 2.8vw, 28px);
  line-height: 1.25;
  margin: 1.6em 0 .6em;
}

.prose h3 {
  font-size: clamp(18px, 2.5vw, 22px);
  margin: 1.2em 0 .4em;
}

.prose p {
  margin: .9em 0;
}

.prose ul,
.prose ol {
  padding-left: 1.2em;
  margin: .8em 0;
}

.prose li {
  margin: .3em 0;
}

.prose blockquote {
  margin: 1em 0;
  padding: .6em 1em;
  border-left: 3px solid color-mix(in oklab, var(--primary) 40%, transparent);
  background: color-mix(in oklab, var(--primary) 6%, transparent);
}

.prose code {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: .95em;
  padding: .1em .3em;
  border-radius: 3px;
  background: color-mix(in oklab, var(--fg) 10%, transparent);
}

.prose pre {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  padding: 12px 14px;
  border-radius: 12px;
  background: color-mix(in oklab, var(--fg) 12%, transparent);
  overflow: auto;
}

figure {
  margin: 1em 0;
}

figcaption {
  color: var(--muted);
  font-size: .9em;
  margin-top: .4em;
}

section {
  margin-bottom: 3rem;
}

/* === 9) 表（横スクロール対応） ================== */
.table-wrap {
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg);
}

table {
  border-collapse: collapse;
  min-width: 560px;
  width: 100%;
}

th,
td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}

thead th {
  position: sticky;
  top: 0;
  background: var(--surface);
}

/* 注意枠（メモなど） */
.note {
  margin: 1em 0;
  padding: 10px 12px;
  border: 1px dashed var(--border);
  border-radius: 10px;
  background: color-mix(in oklab, var(--primary) 5%, transparent);
}

/* === 10) 記事フッター（著者情報） ============== */
.article-footer {
  margin-top: 26px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.author {
  display: flex;
  align-items: center;
  gap: 12px;
}

.avatar {
  inline-size: 48px;
  block-size: 48px;
  border-radius: 50%;
  border: 1px solid var(--border);
}

.author-name {
  font-weight: 600;
  margin: 0;
}

.author-bio {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 14px;
}

/* === 11) サイト全体フッター ====================== */
.site-footer {
  background: #1e1e1c;
  margin-top: 28px;
  border-top: 1px solid var(--border);
}

body.searched .site-footer {
  background: #f4f4f2;
}

.footer-inner {
  padding: 5px 0;
  color: var(--muted);
  font-size: 14px;
}

/* === 12) 検索結果オーバーレイ ==================== */
/* 画面全体を覆う黒半透明のレイヤー（最初は非表示） */
#searchOverlay {
  display: none;
  /* JSで block に切り替え */
  position: fixed;
  inset: 0;
  /* top/right/bottom/left を一括指定 */
  background: rgba(0, 0, 0, 0.6);
  z-index: 9999;
  overflow-y: auto;
  /* 結果が長い場合はスクロール */
}

/* オーバーレイ中央の白いカード */
#searchResults {
  background: #fff;
  color: #111;
  margin: 5% auto;
  padding: 20px;
  width: 80%;
  max-width: 600px;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

/* 閉じるボタン（右上） */
#closeBtn {
  float: right;
  cursor: pointer;
  background: #7d7b83;
  color: white;
  border: none;
  padding: 6px 10px;
  border-radius: 6px;
}

#closeBtn:hover {
  filter: brightness(1.05);
}

/* ダークモードで結果カードの文字色を読みやすく */
@media (prefers-color-scheme: dark) {
  #searchResults {
    background: #111827;
    color: #e5e7eb;
  }
}

/* ヘッダーを3カラムに（左：ブランド / 中央：ナビ / 右：検索） - PC画面のみ */
@media (min-width: 881px) {

  /* PC用ナビゲーションスタイル（ここへ移動） */
  .primary-nav {
    display: flex;
    position: relative;
  }

  .nav-list {
    display: flex;
    gap: 6px;
    width: max-content;
  }

  .nav-list a {
    color: #708090;
    display: inline-block;
    padding: 8px 12px;
    border-radius: 10px;
  }

  .nav-list a:hover {
    background: color-mix(in oklab, var(--primary) 12%, transparent);
    text-decoration: none;
  }

  /* ヘッダーレイアウト */
  .header-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
  }

  /* ナビは中央、検索は右端 */
  .primary-nav {
    justify-self: center;
  }

  .header-actions {
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 8px;
  }
}


/* 検索結果のデザイン */
div.result-list>ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

div.result-list>ul>li {
  border-bottom: 1px solid var(--border);
  padding: 10px;
  font-size: clamp(16px, 2.8vw, 24px);
}

div.result-list>ul>li>a {
  color: #80bfff;
}

/* === 13) お問い合わせフォーム ==================== */
/* フォームコンテナ */
.contact-container {
  max-width: 600px;
  margin: 2rem auto;
}

.contact-form {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: var(--shadow);
}

/* フォームグループ（各入力欄の親） */
.form-group {
  margin-bottom: 20px;
}

.form-group:last-of-type {
  margin-bottom: 24px;
}

/* フォームラベル */
.form-label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--fg);
  margin-bottom: 6px;
  letter-spacing: 0.3px;
}

/* テキスト入力欄（ヘッダーの検索ボックスと同じスタイル） */
.form-input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  color: var(--fg);
  font-family: inherit;
  font-size: 16px;
  outline: none;
  transition: all 0.2s ease;
}

.form-input:focus {
  border-color: color-mix(in oklab, var(--primary) 60%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 25%, transparent);
}

.form-input::placeholder {
  color: var(--muted);
}

/* テキストエリア（メッセージ用） */
.form-textarea {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  color: var(--fg);
  font-family: inherit;
  font-size: 16px;
  outline: none;
  resize: vertical;
  min-height: 160px;
  transition: all 0.2s ease;
}

.form-textarea:focus {
  border-color: color-mix(in oklab, var(--primary) 60%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 25%, transparent);
}

.form-textarea::placeholder {
  color: var(--muted);
}

/* ボタンエリア */
.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 8px;
}

/* 送信ボタン（ヘッダーの検索ボタンと同じスタイル） */
.submit-btn {
  padding: 7px 20px;
  border: 1px solid color-mix(in oklab, var(--primary) 60%, var(--border));
  border-radius: 10px;
  background: var(--primary);
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.submit-btn:hover {
  filter: brightness(1.05);
}

.submit-btn:active {
  transform: translateY(0);
}

/* 送信完了メッセージ */
.success-message {
  background: color-mix(in oklab, #4caf50 10%, transparent);
  border: 2px solid #4caf50;
  border-radius: var(--radius);
  padding: 20px;
  margin-top: 24px;
  color: #2e7d32;
  text-align: center;
  font-weight: 600;
}

.success-message p {
  margin: 0;
  line-height: 1.6;
}

/* レスポンシブ対応 */
@media (max-width: 600px) {
  .contact-form {
    padding: 24px 20px;
  }

  .form-group {
    margin-bottom: 16px;
  }

  .form-actions {
    flex-direction: column;
  }

  .submit-btn {
    width: 100%;
  }
}

/* ダークモード対応 */
@media (prefers-color-scheme: dark) {
  .success-message {
    background: color-mix(in oklab, #4caf50 15%, transparent);
    color: #81c784;
  }
}