/* スタイル */
:root {
  --primary-color: #28a745; /* 優しい緑 */
  --primary-hover-color: #218838;
  --secondary-color: #6c757d; /* グレー */
  --secondary-hover-color: #5a6268;
  --danger-color: #dc3545; /* 赤 */
  --danger-hover-color: #c82333;
  --warning-color: #ffc107; /* 黄色 */
  --warning-hover-color: #e0a800;
  --info-color: #17a2b8; /* 水色 */
  --info-hover-color: #138496;
  --success-color: var(--primary-color); /* primaryと同じに */
  --success-hover-color: var(--primary-hover-color);

  /* 背景・境界線 */
  --light-bg: #f8f9fa; /* 明るいグレー */
  --white-bg: #ffffff;
  --border-color: #dee2e6;
  --input-border-color: #ced4da;
  --input-focus-border-color: #80bdff; /* フォーカス時は青系 */
  --input-focus-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.25);

  /* テキスト */
  --text-dark: #343a40;
  --text-muted: #6c757d;

  /* その他 */
  --toast-success-bg: #d1e7dd;
  --toast-success-text: #0f5132;
  --toast-error-bg: #f8d7da;
  --toast-error-text: #842029;
  --toast-info-bg: #cff4fc;
  --toast-info-text: #055160;
  --required-color: var(--danger-color);
  --optional-color: var(--text-muted);
  --favorite-color: #ffc107; /* お気に入り（黄色） */
  --link-color: #0d6efd;
  --link-hover-color: #0a58ca;

  /* 要素の丸み */
  --border-radius: 0.375rem; /* 6px */
  --border-radius-sm: 0.25rem; /* 4px */
}

/* ダークモード用変数 */
body.dark-mode {
  --primary-color: #34c759; /* ダークモード用の緑 */
  --primary-hover-color: #2fab4d;
  --secondary-color: #8e8e93;
  --secondary-hover-color: #787880;
  --danger-color: #ff453a;
  --danger-hover-color: #ff6b61;
  --warning-color: #ffd60a;
  --warning-hover-color: #ffe03d;
  --info-color: #64d2ff;
  --info-hover-color: #87ddff;
  --success-color: var(--primary-color);
  --success-hover-color: var(--primary-hover-color);

  /* 背景・境界線 */
  --light-bg: #1c1c1e; /* 暗い背景 */
  --white-bg: #2c2c2e; /* 要素の背景 */
  --border-color: #48484a;
  --input-border-color: #545456;
  --input-focus-border-color: #0a84ff;
  --input-focus-shadow: 0 0 0 0.2rem rgba(10, 132, 255, 0.25);

  /* テキスト */
  --text-dark: #f2f2f7;
  --text-muted: #8e8e93;

  /* その他 */
  --toast-success-bg: #28573a;
  --toast-success-text: #a3e6be;
  --toast-error-bg: #8b2c26;
  --toast-error-text: #f8d7da;
  --toast-info-bg: #005a7f;
  --toast-info-text: #cff4fc;
  --favorite-color: #ffd60a;
  --link-color: #0a84ff;
  --link-hover-color: #3b9dff;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji",
    "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* よりモダンなフォントスタック */
  padding: 20px; /* 全体のパディングを少し増やす */
  background-color: var(--light-bg);
  line-height: 1.6;
  color: var(--text-dark);
  margin: 0;
  transition: background-color 0.3s, color 0.3s;
}

/* ヘッダー */
.header-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--border-color); /* 少し細く */
  padding-bottom: 15px; /* パディング調整 */
  margin-bottom: 25px; /* 下マージン調整 */
}

/* 見出し */
h1 {
  color: var(--text-dark); /* CSS変数使用 */
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.8em;
  border: none;
  padding: 0;
  font-weight: 600; /* 少し太く */
}

h2 {
  color: var(--text-dark);
  border-bottom: 1px solid var(--border-color); /* 少し細く */
  padding-bottom: 10px;
  margin-top: 30px; /* セクション間のマージン */
  margin-bottom: 20px;
  font-size: 1.5em;
  font-weight: 600;
}

h3 {
  font-size: 1.25em;
  margin-top: 20px;
  margin-bottom: 12px;
  color: var(--text-dark);
  font-weight: 600;
}

h4 {
  font-size: 1.1em;
  margin-top: 15px;
  margin-bottom: 10px;
  color: var(--text-dark);
  font-weight: 600;
}

/* ラベル */
label {
  display: block;
  margin-bottom: 8px;
  font-weight: 500; /* 少し細く */
  color: var(--text-muted); /* 少し薄く */
}

.required-mark,
.optional-mark {
  font-size: 0.9em;
  margin-left: 4px;
}
.required-mark {
  color: var(--required-color);
  font-weight: 500;
}
.optional-mark {
  color: var(--optional-color);
}

/* 入力要素 */
input[type="text"],
textarea,
select {
  width: 100%;
  padding: 10px 15px; /* パディング調整 */
  margin-bottom: 15px; /* マージン調整 */
  border: 1px solid var(--input-border-color);
  border-radius: var(--border-radius); /* 角丸 */
  box-sizing: border-box;
  font-size: 1rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  background-color: var(--white-bg);
  color: var(--text-dark);
}

input[type="text"]:focus,
textarea:focus,
select:focus {
  border-color: var(--input-focus-border-color);
  outline: 0;
  box-shadow: var(--input-focus-shadow);
}

textarea {
  min-height: 120px; /* 少し高く */
  resize: vertical;
  font-family: inherit;
}

/* ボタン共通スタイル */
button,
.button-like /* labelをボタン風に見せるクラス */ {
  display: inline-block; /* labelにも適用 */
  background-color: var(--primary-color);
  color: white;
  padding: 10px 20px; /* 少し横長に */
  border: none;
  border-radius: var(--border-radius); /* 角丸 */
  cursor: pointer;
  margin-right: 10px; /* マージン調整 */
  margin-bottom: 10px;
  font-size: 1rem;
  font-weight: 500;
  text-align: center; /* label用 */
  transition: background-color 0.2s ease-in-out, transform 0.1s ease,
    box-shadow 0.1s ease;
  vertical-align: middle;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); /* 軽い影 */
}
button:hover:not(:disabled),
.button-like:hover {
  background-color: var(--primary-hover-color);
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* ホバー時の影 */
}
button:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}
button:disabled {
  background-color: #adb5bd;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  opacity: 0.65;
}

/* セクション */
.section {
  margin-top: 30px;
  margin-bottom: 30px;
  border: 1px solid var(--border-color);
  padding: 25px; /* パディング調整 */
  background-color: var(--white-bg);
  border-radius: var(--border-radius); /* 角丸 */
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}
body.dark-mode .section {
  background-color: var(--white-bg);
  border-color: var(--border-color);
  box-shadow: 0 2px 5px rgba(255, 255, 255, 0.05);
}

/* 生成プロンプトエリア */
.generated-prompt-area textarea#generatedPromptText {
  width: 100%;
  min-height: 180px; /* 少し高く */
  background-color: var(--light-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-sm);
  font-family: "Menlo", "Monaco", "Consolas", "Courier New", monospace;
  line-height: 1.5;
  font-size: 0.95em;
  color: var(--text-dark);
  padding: 12px; /* パディング追加 */
  box-sizing: border-box;
}
body.dark-mode .generated-prompt-area textarea#generatedPromptText {
  background-color: #3a3a3c; /* ダークモード用背景 */
  color: var(--text-dark);
  border-color: var(--border-color);
  border-top: 1px solid var(--border-color);
}

.generated-prompt-area textarea#aiOutputText {
  width: 100%;
  min-height: 140px;
  font-family: inherit;
  margin-top: 10px;
  border-radius: var(--border-radius-sm);
}

.char-counter {
  text-align: right;
  font-size: 0.85em;
  color: var(--text-muted);
  margin-bottom: 6px;
}

/* --- テンプレート管理 --- */
.template-actions {
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px; /* 間隔調整 */
  align-items: center;
}

/* .button-like はボタン共通スタイルへ */

.template-search-input {
  margin-bottom: 0;
  max-width: 350px; /* 少し広げる */
}

.template-edit-actions {
  display: inline-block;
  margin-left: 15px; /* 間隔調整 */
  vertical-align: middle;
}

/* テンプレート説明表示 */
.template-description-display {
  margin-top: 12px;
  margin-bottom: 15px; /* ボタンとの間隔 */
  padding: 10px 15px;
  background-color: var(--light-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-sm);
  font-size: 0.9em;
  color: var(--text-muted);
}
body.dark-mode .template-description-display {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: var(--border-color);
}

/* タグ表示エリア共通 */
.tags-display-area {
  margin-top: 8px;
  margin-bottom: 15px;
}
.tags-display-area strong {
  margin-right: 8px;
  font-weight: 600;
  color: var(--text-muted);
  font-size: 0.9em;
}

/* クリックできない静的なタグピル */
.static-tag {
  cursor: default;
  margin-right: 6px;
  margin-bottom: 6px;
}
.static-tag:hover {
  /* ホバー効果不要 */
  background-color: var(
    --light-bg
  ); /* チェックボックスラベルのホバー効果を打ち消す */
  border-color: var(--border-color);
}
body.dark-mode .static-tag:hover {
  background-color: #3a3a3c;
  border-color: #545456;
}
/* お気に入りタグのスタイル */
.static-tag:is(._favorite, [value="お気に入り"]) {
  /* セレクタ調整 */
  background-color: var(--favorite-color);
  border-color: var(--favorite-color);
  color: var(--text-dark); /* お気に入りタグの文字色 */
}
body.dark-mode .static-tag:is(._favorite, [value="お気に入り"]) {
  color: var(--text-dark);
}

/* テンプレートお気に入りアクションボタンコンテナ */
.template-favorite-actions {
  margin-top: 10px; /* タグ表示エリアからの間隔 */
  margin-bottom: 15px;
}

/* ボタンサイズ小 */
button.small,
.button-like.small /* labelにも適用 */ {
  padding: 6px 12px;
  font-size: 0.9em;
  margin-bottom: 0;
  margin-right: 6px;
}

/* 各種ボタンの色 */
.button-edit {
  background-color: var(--info-color);
}
.button-edit:hover:not(:disabled) {
  background-color: var(--info-hover-color);
}
.button-add {
  background-color: var(--success-color);
}
.button-add:hover:not(:disabled) {
  background-color: var(--success-hover-color);
}
.button-delete {
  background-color: var(--danger-color);
}
.button-delete:hover:not(:disabled) {
  background-color: var(--danger-hover-color);
}
.button-secondary {
  background-color: var(--secondary-color);
}
.button-secondary:hover:not(:disabled) {
  background-color: var(--secondary-hover-color);
}
.button-warning {
  background-color: var(--warning-color);
  color: var(--text-dark); /* 黄色背景に黒文字 */
}
.button-warning:hover:not(:disabled) {
  background-color: var(--warning-hover-color);
}
body.dark-mode .button-warning {
  color: var(--text-dark); /* ダークモードでも黒文字 */
}

/* --- 履歴エリア --- */
.history-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 12px; /* 間隔調整 */
  margin-bottom: 25px;
  align-items: center;
}
.history-search-input {
  flex-grow: 1;
  min-width: 220px;
  margin-bottom: 0;
}
.history-filter-select {
  width: auto;
  min-width: 160px;
  margin-bottom: 0;
}
.history-favorite-filter {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 0;
  font-weight: normal;
  cursor: pointer;
}
.history-favorite-filter input[type="checkbox"] {
  width: auto;
  margin-bottom: 0;
  accent-color: var(--primary-color); /* チェックボックスの色 */
}

/* Export button is now .button-secondary */
/* Clear history button is now .button-delete */

/* 履歴リスト */
.history-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.history-item {
  border-bottom: 1px solid var(--border-color);
  padding: 18px 0; /* パディング調整 */
  margin-bottom: 12px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
}
.history-item:last-child {
  border-bottom: none;
}
.history-content {
  flex-grow: 1;
  min-width: 250px; /* 少し広く */
}
.history-prompt-short {
  /* white-space: nowrap; */ /* 折り返すように変更 */
  overflow: hidden;
  text-overflow: ellipsis;
  /* max-width: 400px; */ /* 幅制限解除 */
  color: var(--text-muted);
  font-size: 0.9em;
  margin-top: 5px;
  display: -webkit-box; /* 2行まで表示 */
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-height: 1.4;
}
.history-header {
  display: flex;
  align-items: center; /* タイトル、バナー、日時を垂直中央揃え */
  gap: 8px; /* 要素間のスペース */
  flex-wrap: wrap; /* 折り返し */
  margin-bottom: 6px;
}
.history-title {
  font-weight: 600;
  margin-bottom: 0; /* headerで制御するので削除 */
  margin-right: auto; /* タイトルを左に、他を右に */
  color: var(--text-dark);
}
.history-title.clickable {
  cursor: pointer;
}
.history-title.clickable:hover {
  color: var(--primary-color);
  text-decoration: underline;
}
.history-ai-tool-wrapper {
  font-size: 0.8em;
  color: var(--text-muted);
  padding: 3px 6px;
  border-radius: var(--border-radius-sm);
  vertical-align: middle;
  display: inline-block;
}
.history-ai-service-link {
  display: inline-block; /* バナー画像をリンクにする */
  line-height: 0; /* 画像下の余白対策 */
}
.history-ai-service-link:hover {
  opacity: 0.8;
}
.history-banner {
  /* .ai-service-banner スタイルを継承しつつ調整 */
  max-height: 20px; /* ★ 履歴内ではさらに小さく */
  max-width: 80px; /* ★ 履歴内ではさらに小さく */
}
.history-ai-tool-name {
  /* リンクがない場合のテキストスタイル */
  background-color: var(--light-bg);
  border: 1px solid var(--border-color);
  padding: 2px 5px;
  border-radius: var(--border-radius-sm);
  font-size: 0.9em;
}
body.dark-mode .history-ai-tool-name {
  background-color: #3a3a3c;
  color: var(--text-muted);
  border-color: #545456;
}
.history-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px; /* 間隔調整 */
  align-items: center;
  margin-top: 8px;
}
/* History action buttons use common button styles + sizes */
.button-favorite {
  background: none;
  border: none;
  color: #cccccc; /* 通常時の色 */
  font-size: 1.6em; /* 少し大きく */
  cursor: pointer;
  padding: 0 8px;
  line-height: 1;
  order: -1; /* 左端に */
  transition: color 0.2s ease, transform 0.1s ease;
}
.button-favorite:hover {
  transform: scale(1.1);
}
.button-favorite.is-favorite {
  color: var(--favorite-color);
}

/* テンプレート化ボタン */
.button-template {
  background-color: var(--success-color);
}
.button-template:hover:not(:disabled) {
  background-color: var(--success-hover-color);
}
/* 詳細ボタン */
/* .button-detail は .button-secondary に */
/* コピーボタン */
.button-copy-hist {
  background-color: var(--warning-color);
  color: var(--text-dark);
}
.button-copy-hist:hover:not(:disabled) {
  background-color: var(--warning-hover-color);
}

/* エラーメッセージ */
.error-message {
  color: var(--danger-color);
  text-align: center;
  padding: 12px 15px;
  margin-top: 15px;
  background-color: var(--toast-error-bg);
  border: 1px solid rgba(220, 53, 69, 0.3);
  border-radius: var(--border-radius);
}
body.dark-mode .error-message {
  background-color: var(--toast-error-bg);
  color: var(--toast-error-text);
  border-color: rgba(255, 69, 58, 0.4);
}

/* 読み込み中 */
.loading-template {
  color: var(--text-muted);
  font-style: italic;
  padding: 10px 0;
}

/* 初期テンプレート更新ボタン */
/* .reload-button は .button-secondary に */

/* 履歴全削除ボタン */
/* .clear-history-button は .button-delete に */

.clearfix::after {
  content: "";
  clear: both;
  display: table;
}

/* --- モーダル --- */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 少し薄く */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  padding: 20px;
  box-sizing: border-box;
}
.modal-content {
  background-color: var(--white-bg);
  padding: 35px; /* パディング増やす */
  border-radius: var(--border-radius); /* 角丸 */
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
  max-width: 95%;
  width: 80vw; /* デフォルト幅 */
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
}
.template-modal-content {
  width: 850px; /* テンプレート編集は広く */
}
.manual-modal-content {
  width: 80vw; /* マニュアルはさらに広く */
}
.modal-close-button {
  position: absolute;
  top: 15px;
  right: 20px;
  background: none;
  border: none;
  font-size: 2rem;
  color: var(--secondary-color);
  cursor: pointer;
  line-height: 1;
  padding: 5px;
  opacity: 0.7;
  transition: opacity 0.2s;
}
.modal-close-button:hover {
  color: var(--text-dark);
  opacity: 1;
}
body.dark-mode .modal-close-button {
  color: var(--text-muted);
}
body.dark-mode .modal-close-button:hover {
  color: var(--text-dark);
}
.modal-sticky-header .modal-title {
  margin-top: 0;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 15px;
  margin-bottom: 25px;
  font-size: 1.6em;
  font-weight: 600;
}

/* モーダル上部固定ヘッダー */
.modal-sticky-header {
  position: sticky;
  top: -35px; /* モーダルコンテンツのpadding分を考慮 */
  background-color: var(--white-bg);
  z-index: 1;
  padding: 35px 35px 15px 35px; /* 上左右はモーダルコンテンツに合わせ、下は少し狭く */
  margin: -35px -35px 0 -35px; /* モーダルコンテンツのpadding分を打ち消す */
  border-bottom: 1px solid var(--border-color); /* 下部にも区切り線 */
}
body.dark-mode .modal-sticky-header {
  background-color: var(--white-bg);
}
.modal-header-info {
  display: flex;
  justify-content: space-between; /* 各項目を均等配置 */
  gap: 20px; /* 項目間のスペース */
  flex-wrap: wrap; /* 折り返し */
  margin-bottom: 0; /* ヘッダー内の最後の要素なので下マージン不要 */
}
.modal-header-info .info-item {
  flex: 1 1 auto; /* 基本的に均等に広がる */
  min-width: 150px; /* 最低幅 */
}
.modal-header-info .info-item h3 {
  margin-top: 0;
  margin-bottom: 5px;
  font-size: 1em;
  border-bottom: none;
  color: var(--text-muted);
}
.modal-header-info .info-item p,
.modal-header-info .info-item span {
  margin-bottom: 0;
  font-size: 1em;
}
.modal-header-info .modal-ai-tool {
  margin-top: 0; /* 上マージンリセット */
}

/* モーダルスクロール可能コンテンツ */
.modal-scrollable-content {
  /* ヘッダー分のパディングは不要かも (stickyがうまく効けば) */
  /* padding-top: 20px; */
}

.modal-section {
  margin-bottom: 25px;
}
.modal-section h3 {
  margin-top: 0;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 8px;
  color: var(--text-dark);
  font-size: 1.15em;
  font-weight: 600;
}
.modal-text-area {
  width: 100%;
  min-height: 120px;
  background-color: var(--light-bg);
  border: 1px solid var(--border-color);
  padding: 12px;
  border-radius: var(--border-radius-sm);
  font-family: "Menlo", "Monaco", "Consolas", "Courier New", monospace;
  white-space: pre-wrap;
  word-wrap: break-word;
  font-size: 0.9em;
  margin-top: 8px;
  box-sizing: border-box;
  color: var(--text-dark);
}
body.dark-mode .modal-text-area {
  background-color: #3a3a3c;
  color: var(--text-dark);
  border-color: var(--border-color);
}
.modal-content p {
  margin-top: 8px;
  color: var(--text-dark);
  line-height: 1.6;
}
.modal-actions {
  margin-top: 30px;
  text-align: right;
  border-top: 1px solid var(--border-color);
  padding-top: 20px;
}
.button-cancel {
  background-color: var(--secondary-color);
}
.button-cancel:hover:not(:disabled) {
  background-color: var(--secondary-hover-color);
}

/* テンプレート入力項目定義 */
.template-input-item {
  border: 1px dashed var(--border-color);
  padding: 20px;
  margin-bottom: 20px;
  border-radius: var(--border-radius);
  background-color: rgba(0, 0, 0, 0.02);
}
body.dark-mode .template-input-item {
  border-color: #48484a;
  background-color: rgba(255, 255, 255, 0.03);
}
.input-row {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-bottom: 15px;
}
.input-row input[type="text"],
.input-row select {
  margin-bottom: 0;
  flex: 1 1 150px; /* 伸縮と基本幅 */
}
.input-row select {
  flex-grow: 0; /* select は伸びない */
}
.options-row {
  align-items: center;
}
.checkbox-label {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-right: 20px;
  font-weight: normal;
  margin-bottom: 0;
  cursor: pointer;
  color: var(--text-dark);
}
.checkbox-label input[type="checkbox"] {
  width: auto;
  margin-bottom: 0;
  accent-color: var(--primary-color);
}
/* .button-add は共通スタイルへ */

/* 履歴編集モーダルのFavorite */
.favorite-edit-label {
  font-weight: normal;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  color: var(--text-dark);
}
.favorite-edit-label input[type="checkbox"] {
  width: auto;
  margin-right: 5px;
  accent-color: var(--primary-color);
}

/* --- マニュアルモーダル本文 --- */
.manual-body {
  line-height: 1.7;
  font-size: 1rem;
  color: var(--text-dark);
}
.manual-body h1,
.manual-body h2,
.manual-body h3,
.manual-body h4 {
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 8px;
  margin-top: 1.8em;
  margin-bottom: 1.2em;
  color: var(--text-dark);
  font-weight: 600;
}
.manual-body h1 {
  font-size: 1.8em;
}
.manual-body h2 {
  font-size: 1.5em;
}
.manual-body h3 {
  font-size: 1.25em;
}
.manual-body h4 {
  font-size: 1.1em;
}
.manual-body p {
  margin-bottom: 1.2em;
}
.manual-body ul,
.manual-body ol {
  margin-left: 2em;
  margin-bottom: 1.2em;
}
.manual-body li {
  margin-bottom: 0.6em;
}
.manual-body code {
  background-color: rgba(0, 0, 0, 0.06);
  padding: 0.25em 0.5em;
  border-radius: var(--border-radius-sm);
  font-family: "Menlo", "Monaco", "Consolas", "Courier New", monospace;
  font-size: 0.9em;
  color: #d63384; /* コードの色 */
}
body.dark-mode .manual-body code {
  background-color: rgba(255, 255, 255, 0.1);
  color: #ff84ad;
}
.manual-body strong {
  font-weight: 600;
}
.manual-body a {
  color: var(--link-color);
  text-decoration: none;
  font-weight: 500;
}
.manual-body a:hover {
  text-decoration: underline;
  color: var(--link-hover-color);
}

/* --- トースト通知 --- */
.toast-container {
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 1050;
  max-width: 380px;
  width: calc(100% - 50px);
}
.toast {
  background-color: var(--white-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius);
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1);
  margin-bottom: 12px;
  padding: 1rem 1.5rem;
  opacity: 0;
  transition: opacity 0.3s linear, transform 0.3s ease-out;
  display: flex;
  justify-content: space-between;
  align-items: center;
  word-wrap: break-word;
  transform: translateX(100%);
  pointer-events: none;
}
body.dark-mode .toast {
  background-color: #3a3a3c;
  border-color: #545456;
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.3);
}
.toast:not(.fade-out) {
  opacity: 0.98; /* 少し濃く */
  transform: translateX(0);
  pointer-events: auto;
}
.toast.fade-out {
  opacity: 0;
  transform: translateX(100%);
}
.toast-message {
  padding-right: 20px;
  flex-grow: 1;
}
.toast-close-button {
  background: none;
  border: none;
  font-size: 1.5rem;
  color: inherit;
  opacity: 0.6;
  cursor: pointer;
  padding: 0 0.5rem;
  margin-left: 15px;
  line-height: 1;
  flex-shrink: 0;
}
.toast-close-button:hover {
  opacity: 1;
}
/* Toast colors use variables */
.toast-info {
  background-color: var(--toast-info-bg);
  color: var(--toast-info-text);
  border-left: 5px solid var(--info-color);
}
.toast-success {
  background-color: var(--toast-success-bg);
  color: var(--toast-success-text);
  border-left: 5px solid var(--success-color);
}
.toast-error {
  background-color: var(--toast-error-bg);
  color: var(--toast-error-text);
  border-left: 5px solid var(--danger-color);
}
body.dark-mode .toast-close-button {
  filter: none; /* Invert不要に */
  color: var(--text-muted);
}
body.dark-mode .toast-close-button:hover {
  color: var(--text-dark);
}
body.dark-mode .toast-info {
  background-color: var(--toast-info-bg);
  color: var(--toast-info-text);
  border-left-color: var(--info-color);
}
body.dark-mode .toast-success {
  background-color: var(--toast-success-bg);
  color: var(--toast-success-text);
  border-left-color: var(--success-color);
}
body.dark-mode .toast-error {
  background-color: var(--toast-error-bg);
  color: var(--toast-error-text);
  border-left-color: var(--danger-color);
}

/* --- テーマ切り替えボタン --- */
.theme-toggle-button {
  background: none;
  border: 1px solid var(--border-color);
  color: var(--text-muted);
  font-size: 1.3rem; /* 少し大きく */
  padding: 8px 12px;
  border-radius: var(--border-radius);
  cursor: pointer;
  margin-bottom: 0;
  margin-right: 0;
  line-height: 1;
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
}
.theme-toggle-button:hover {
  background-color: var(--light-bg);
  color: var(--text-dark);
  border-color: var(--input-border-color);
}
body.dark-mode .theme-toggle-button {
  border-color: var(--secondary-color);
  color: var(--text-muted);
}
body.dark-mode .theme-toggle-button:hover {
  background-color: var(--secondary-color);
  color: var(--text-dark);
  border-color: var(--secondary-hover-color);
}

/* --- マニュアルボタン --- */
/* .manual-button は共通ボタンスタイル + .button-secondary を使用 */
.manual-button .manual-icon {
  font-size: 1.2em; /* アイコンサイズ */
  margin-right: 5px; /* テキストとの間隔 */
}

/* --- レスポンシブ --- */
@media (max-width: 992px) {
  .template-modal-content,
  .manual-modal-content {
    width: 80vw;
    max-width: 95%;
  }
  .input-row {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
}
@media (max-width: 768px) {
  body {
    padding: 15px;
  }
  .header-controls {
    flex-direction: column; /* 縦積みに変更 */
    align-items: flex-start; /* 左揃え */
    gap: 15px;
  }
  .header-controls h1 {
    text-align: left; /* 左揃えに戻す */
    width: auto;
    margin-bottom: 0;
  }
  .header-controls .button-group {
    /* ボタンをグループ化する場合 */
    display: flex;
    gap: 10px;
    width: 100%;
    justify-content: flex-end; /* 右寄せ */
  }

  .history-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 15px;
  }
  .history-search-input,
  .history-filter-select {
    width: 100%;
    min-width: unset;
  }
  .history-controls .button-secondary, /* エクスポート */
  .history-controls .button-delete /* 全削除 */ {
    width: 100%;
    margin-left: 0;
    text-align: center;
  }

  .history-item {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .history-actions {
    justify-content: flex-start;
    margin-top: 12px;
  }
  .button-favorite {
    order: 0; /* 順序リセット */
    margin-left: -8px; /* 左に少しずらす */
  }

  .modal-content {
    padding: 25px;
  }
  .modal-title {
    font-size: 1.4em;
  }
}

@media (max-width: 600px) {
  body {
    padding: 10px;
  }
  h1 {
    font-size: 1.6em;
  }
  h2 {
    font-size: 1.3em;
  }
  .section {
    padding: 20px;
  }
  .modal-content {
    padding: 20px;
    width: 98%;
    max-width: 98%;
  }
  .toast-container {
    width: calc(100% - 20px);
    right: 10px;
    top: 10px;
  }

  .template-input-item {
    padding: 15px;
  }
  .input-row {
    gap: 10px;
  }
}

/* --- その他微調整 --- */
/* 選択中のテンプレートを目立たせる（任意） */
#template-select option:checked {
  font-weight: bold;
}

/* Datalist スタイル */
input[list]::-webkit-calendar-picker-indicator {
  opacity: 0.6;
  cursor: pointer;
}
input[list]::-webkit-calendar-picker-indicator:hover {
  opacity: 0.8;
}

/* ステップ表示用スタイル */
.step-indicator {
  font-size: 0.9em;
  color: var(--text-muted);
  margin-bottom: 12px;
  display: inline-block; /* h2と同じ行に表示したい場合など */
  /* background-color: var(--primary-color); */
  /* color: white; */
  /* padding: 3px 8px; */
  /* border-radius: var(--border-radius-sm); */
  font-weight: 600;
  margin-right: 10px; /* 見出しとの間隔 */
}

/* --- フッター --- */
.app-footer {
  margin-top: 40px; /* 上部とのマージン */
  padding: 20px 0;
  text-align: center;
  font-size: 0.9em;
  color: var(--text-muted);
  border-top: 1px solid var(--border-color);
}

/* AIサービスへのリンク */
.ai-service-links {
  margin-top: 20px;
  padding-top: 15px;
  border-top: 1px dashed var(--border-color);
}
.ai-service-links p {
  font-size: 0.9em;
  color: var(--text-muted);
  margin-bottom: 10px;
}
.ai-service-link {
  margin-right: 8px;
  margin-bottom: 8px;
  text-decoration: none;
  display: inline-flex; /* アイコンとテキストの整列 */
  align-items: center;
  gap: 4px;
  border: 1px solid transparent; /* ホバー/フォーカス時の枠線用 */
  border-radius: var(--border-radius-sm);
  transition: background-color 0.2s, border-color 0.2s, opacity 0.2s;
  padding: 5px 8px; /* 少しパディングを追加 */
}
.ai-service-link:hover {
  background-color: rgba(0, 0, 0, 0.05);
  border-color: var(--border-color);
  opacity: 1; /* ホバー時は不透明に */
}
.ai-service-link:focus {
  outline: none;
  border-color: var(--input-focus-border-color);
  box-shadow: 0 0 0 0.1rem rgba(38, 143, 255, 0.25); /* フォーカス表示 */
}
.ai-icon {
  font-size: 1.1em; /* アイコンサイズ調整 */
  display: inline-block;
}

/* フッターAIリンク */
.footer-ai-links {
  margin-top: 20px;
  padding-top: 20px;
  text-align: center;
  border-top: 1px dashed var(--border-color); /* 区切り線 */
}
.footer-ai-links p {
  margin-bottom: 10px;
  font-size: 0.9em;
  color: var(--text-muted);
}
.footer-ai-links nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
}
.footer-ai-link {
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.9em;
  transition: color 0.2s;
  display: inline-flex;
  align-items: center;
}
.footer-ai-link:hover {
  /* ホバー時のスタイル（任意） */
  opacity: 0.8;
}
body.dark-mode .footer-ai-link {
  color: var(--text-muted);
}
body.dark-mode .footer-ai-link:hover {
  color: var(--link-hover-color);
}

/* AIサービスバナー画像 */
.ai-service-banner {
  display: block; /* imgの下の余白対策 */
  max-height: 30px; /* ★プロンプト下は少し小さめに */
  max-width: 110px; /* ★プロンプト下は少し小さめに */
  height: auto; /* 縦横比維持 */
  width: auto; /* 縦横比維持 */
  object-fit: contain; /* 画像がはみ出さないように */
}

/* モーダル内のAIツール表示調整 */
.modal-ai-tool {
  display: inline-block; /* 他のテキストと高さを合わせる */
  margin-top: 5px;
}

/* Markdownプレビュー スタイル */
.markdown-preview {
  /* 基本スタイルは .modal-text-area を継承 */
  /* 必要に応じて Markdown 要素のスタイルを追加 */
  line-height: 1.7;
}
.markdown-preview p {
  margin-bottom: 1em;
}
.markdown-preview h1,
.markdown-preview h2,
.markdown-preview h3,
.markdown-preview h4,
.markdown-preview h5,
.markdown-preview h6 {
  margin-top: 1.5em;
  margin-bottom: 0.8em;
  font-weight: 600;
  line-height: 1.3;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 0.3em;
}
.markdown-preview h1 {
  font-size: 1.6em;
}
.markdown-preview h2 {
  font-size: 1.4em;
}
.markdown-preview h3 {
  font-size: 1.2em;
}
.markdown-preview ul,
.markdown-preview ol {
  margin-left: 1.5em;
  margin-bottom: 1em;
  padding-left: 1em;
}
.markdown-preview li {
  margin-bottom: 0.5em;
}
.markdown-preview blockquote {
  border-left: 4px solid var(--border-color);
  padding-left: 1em;
  margin-left: 0;
  margin-right: 0;
  color: var(--text-muted);
}
body.dark-mode .markdown-preview blockquote {
  border-left-color: #545456;
  color: var(--text-muted);
}
.markdown-preview pre {
  background-color: rgba(0, 0, 0, 0.05);
  padding: 1em;
  border-radius: var(--border-radius-sm);
  overflow-x: auto;
  font-family: "Menlo", "Monaco", "Consolas", "Courier New", monospace;
  font-size: 0.9em;
}
body.dark-mode .markdown-preview pre {
  background-color: rgba(255, 255, 255, 0.08);
}
.markdown-preview code {
  /* インラインコード */
  background-color: rgba(0, 0, 0, 0.05);
  padding: 0.2em 0.4em;
  border-radius: 3px;
  font-size: 0.9em;
}
body.dark-mode .markdown-preview code {
  background-color: rgba(255, 255, 255, 0.1);
}
.markdown-preview pre code {
  /* pre内のcodeは背景・パディング不要 */
  background-color: transparent;
  padding: 0;
  border-radius: 0;
  font-size: inherit;
}
.markdown-preview table {
  border-collapse: collapse;
  margin-bottom: 1em;
  width: auto;
}
.markdown-preview th,
.markdown-preview td {
  border: 1px solid var(--border-color);
  padding: 0.5em 0.8em;
}
.markdown-preview th {
  font-weight: 600;
  background-color: var(--light-bg);
}
body.dark-mode .markdown-preview th {
  background-color: #3a3a3c;
}

/* --- 履歴タグフィルター --- */
.history-tag-filter {
  /* width: 100%; */ /* 必要に応じて全幅に */
  margin-top: 10px;
  margin-bottom: 5px;
}
.history-tag-filter .filter-label {
  font-size: 0.9em;
  color: var(--text-muted);
  margin-right: 10px;
  display: inline-block;
  margin-bottom: 5px;
}
.tag-checkbox-group {
  display: inline-flex; /* 横並び */
  flex-wrap: wrap; /* 折り返し */
  gap: 8px;
}
.tag-checkbox-label {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  margin-bottom: 0; /* labelデフォルトのmb削除 */
}
.tag-checkbox-label input[type="checkbox"] {
  display: none; /* チェックボックス自体は隠す */
}
/* タグ表示用のスタイル (タグピル) */
.tag-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 15px; /* 楕円形 */
  background-color: var(--light-bg);
  border: 1px solid var(--border-color);
  color: var(--text-muted);
  font-size: 0.85em;
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
}
.tag-checkbox-label input[type="checkbox"]:checked + .tag-pill {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: white;
}
.tag-checkbox-label:hover .tag-pill {
  border-color: var(--primary-hover-color);
  background-color: rgba(40, 167, 69, 0.1);
}
.tag-checkbox-label input[type="checkbox"]:checked:hover + .tag-pill {
  background-color: var(--primary-hover-color);
  border-color: var(--primary-hover-color);
}
body.dark-mode .tag-pill {
  background-color: #3a3a3c;
  border-color: #545456;
  color: var(--text-muted);
}
body.dark-mode .tag-checkbox-label input[type="checkbox"]:checked + .tag-pill {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #1c1c1e; /* ダークモードの選択済みタグ文字色 */
}
body.dark-mode .tag-checkbox-label:hover .tag-pill {
  border-color: var(--primary-hover-color);
  background-color: rgba(52, 199, 89, 0.15);
}
body.dark-mode
  .tag-checkbox-label
  input[type="checkbox"]:checked:hover
  + .tag-pill {
  background-color: var(--primary-hover-color);
  border-color: var(--primary-hover-color);
}
