:root {
  /* 青色ベースの主要な色 */
  --primary-color: #0066FF; /* 主要な青（ボタン、リンク、強調色） */
  --primary-light-color: #66b3ff; /* 明るめの青（ホバー、アクセント） */
  --primary-dark-color: #004085; /* 暗めの青（ヘッダー、見出し、強調） */
  /* テキスト色 */
  --text-color: #333; /* 標準テキスト色 - 濃いグレー */
  --light-text-color: #666; /* 薄いテキスト色 - 中程度のグレー */
  /* 背景色 */
  --background-color: #e6f7ff; /* 全体の背景色（ごく薄い水色） */
  --header-bg: #ffffff; /* ヘッダーの背景色 - 白 */
  --sidebar-bg: #ffffff; /* 目次の背景色 - 白 */
  --section-bg: #ffffff; /* 各コンテンツセクションの背景色（白） */
  /* 境界線と影 */
  --border-color: #9cd4ed; /* 境界線の色（青みがかったグレー） */
  --shadow-color: rgba(0, 0, 0, 0.05); /* 影の色 */
  /* 注記ボックスの色 */
  --note-bg: #e1f5fe; /* 注意書きボックスの背景色 */
  --note-border: #03a9f4; /* 注意書きボックスの枠線色 */
  --note-text: #01579b; /* 注意書きボックスのテキスト色 */

  --warning-bg: #fff3cd; /* 警告ボックスの背景色（薄い黄色） */
  --warning-border: #ffc107; /* 警告ボックスの枠線色（オレンジ黄色系） */
  --warning-text: #856404; /* 警告ボックスのテキスト色（濃い黄色） */
}
ol li {
  margin-top:10px;
  list-style:decimal;
  margin-left:20px;
}
ol ul li {
  list-style: circle;
}

.ManualTop h2{
  margin-top:40px;
}

#r-bodyarea #r-wrapper {
  width: 1000px;
  height: auto;
  margin: 0 auto;
  margin-bottom: 20px;
}
#r-bodyarea #r-wrapper #r-left {
  margin-top: 15px;
  FLOAT: left;
  WIDTH: 235px;
  position: relative;
  MARGIN-RIGHT: 20px;
  MARGIN-LEFT: 10px;
  margin-bottom: 20px;
}
#r-bodyarea #r-wrapper #r-right {
  margin-top: 15px;
  FLOAT: left;
  width: 725px;
  margin-bottom: 50px;
}
/* サイドメニュー ここから */
.sideSlider {
  font-size: 1.15em;
  border: none;
  height: auto;
}
.sideSlider .dic_title {
  padding: 11px 10px;
  color: #FFF;
  font-weight: bold;
}
.sideSlider ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.sideSlider ul.IndexList {
  height: auto !important;
}
.sideSlider ul.IndexList li {
  padding-bottom: 3px;
}
.sideSlider ul li a {
  color: var(--primary-color);
  padding: 5px 5px;
  display: block;
  font-weight: bold;
}
.sideSlider ul li a:hover {
  text-decoration: none;
}
.sideSlider ul ul {
  margin-left: 10px;
}
.sideSlider ul ul li a {
  padding: 3px 5px;
}
.sideSlider ul ul li a:hover {
  background: #c8e4ff;
}
/* サイドバーアイコンのスタイル */
.sideSlider ul li a .iconimg {
  height: 0; /* アイコンのサイズを統一 */
  width: 0; /* アイコンのサイズを統一 */
  object-fit: contain; /* アイコンのアスペクト比を維持して収める */
  margin-right: 5px;
  visibility:hidden;
}
/* トグルアイコンのスタイル */
.sideSlider .toggle-icon {
  font-size: 1.2em; /* サイズ調整 */
  font-weight: bold; /* 必要に応じて */
  cursor: pointer; /* カーソルを表示 */
  user-select: none; /* テキスト選択を無効化 */
}
/* サブメニューが開いた時のアイコン (追加) */
.sideSlider .has-submenu.open .toggle-icon::before {
  content: "▶";
}
.sideSlider .has-submenu:not(.open) .toggle-icon::before {
  content: "▼";
}
.sideSlider ul.submenu {
  height: auto !important;
  max-height: 0px;
  overflow: hidden;
  transition: max-height 0.3s ease-out; /* アニメーション */
  padding-left: 15px; /* 親からのインデント */
}
.sideSlider ul.submenu li {
  border: none;
  font-weight: normal;
}
.sideSlider ul.submenu li a {
  font-weight: normal;
  text-align: left;
}
/* サブメニューが開いた時のスタイル */
.sideSlider ul.submenu.is-open {
  max-height: 500px; /* 十分な高さを設定（コンテンツに合わせて調整） */
}
/* sidebar ul li a に flex を適用している場合 */
.sidebar ul li a {
  display: flex; /* アイコンとテキストを横並びにする */
  align-items: center; /* 垂直方向中央揃え */
  justify-content: flex-start; /* テキストとアイコンを左右に寄せる */
}
/* トグルアイコンのスタイル（単体） */
.sidebar .toggle-icon1 {
  margin-left: 195px;
  font-size: 1.2em; /* サイズ調整 */
  font-weight: bold; /* 必要に応じて */
  cursor: pointer; /* カーソルを表示 */
  user-select: none; /* テキスト選択を無効化 */
}
/* サイドメニュー ここまで */


/* 検索フォーム ここから */
.SearchFrm{
  display:flex;
  vertical-align:top;
}

.SearchBtn {
  margin-left:2px;
  width: 150px;
  height: 43px;
  background: #008bdd;
  color: #fff;
  border: none;
  font-size: 16px;
}
.SearchBtn:hover {
  background: #50a9dd;
}
div#faqsearchkeyword {
  background-color: var(--background-color); /* 背景色 */
  text-align: center;
  padding: 20px;
  margin: 10px 0;
  font-weight: 600;
}
div#faqsearchkeyword a {
  color: #555;
  font-size: 15px;
  margin-right: 20px;
}
div#faqsearchkeyword a:hover {
  color: #0065CB;
  text-decoration: none;
}
/* 検索フォーム ここまで */

/* メインコンテンツ */
.manual-content {
    flex-grow: 1;
    margin-bottom: 20px;
}

/* フロー詳細など、リスト内の説明文のスタイル調整 */
.manual-content ol li p,
.manual-content ul li p {
    font-weight: normal; /* 太字を解除 */
    margin-top: 5px; /* 上部の余白を調整 */
    margin-bottom: 0; /* 下部の余白を調整（必要に応じて） */
    color: var(--text-color); /* 標準のテキスト色を適用 */
}
/* リストスタイル */
.manual-content ol,
.manual-content ul {
    margin-bottom: 15px;
}
.manual-content ol li,
.manual-content ul li {
    margin-bottom: 8px;
    line-height: 1.5;
}
.manual-content strong {
    color: #555;
    font-weight:700;
}

/* 注記ボックス (note/warning) */
.note, .warning {
    padding: 15px;
    border-left: 5px solid;
    margin: 20px 0;
    border-radius: 4px;
    display: flex; /* これにより子要素が横並びになります */
    align-items: flex-start; /* これにより子要素の先頭が揃います */
    gap: 10px; /* アイコンとテキストの間に余白を設けます */
}

.note {
    background-color: var(--note-bg);
    border-color: var(--note-border);
    color: var(--note-text);
}
.note i {
  color: var(--note-border);
  font-size: 1.2em;
  transform: translateY(6px);
}

.warning {
    background-color: var(--warning-bg);
    border-color: var(--warning-border);
    color: var(--warning-text);
}
.warning i {
  color: var(--warning-border);
  font-size: 1.2em;
  transform: translateY(6px);
}

.note1 {
    padding: 15px;
    border-left: 5px solid;
    margin: 20px 0;
    border-radius: 4px;
    display: flex; /* これにより子要素が横並びになります */
    align-items: flex-start; /* これにより子要素の先頭が揃います */
    gap: 0px; /* アイコンとテキストの間に余白を設けます */
}

.note1 {
    background-color: var(--note-bg);
    border-color: var(--note-border);
    color: var(--note-text);
}
.note1 i {
    color: var(--note-border);
    font-size: 1.2em;
    /* padding-top を削除し、transform で調整 */
    /* padding-top: 2px; */
    transform: translateY(19px); /* 下に2px移動。数値は調整してください */
}

.note2 {
  padding: 15px;
  border-left: 5px solid;
  margin: 20px 0;
  border-radius: 4px;
  display: flex; /* これにより子要素が横並びになります */
  align-items: flex-start; /* これにより子要素の先頭が揃います */
  gap: 10px; /* アイコンとテキストの間に余白を設けます */
}

.note2 {
    background-color: var(--note-bg);
    border-color: var(--note-border);
    color: var(--note-text);
}
.note2 i {
    color: var(--note-border);
    font-size: 1.2em;
    /* padding-top を削除し、transform で調整 */
    /* padding-top: 2px; */ 
    transform: translateY(6px); /* 下に2px移動。数値は調整してください */
}

/* 画像トグル関連のスタイル */
.screenshot-toggle-wrapper {
    margin: 25px 0;
    text-align: left;
}

.image-toggle-button {
    background: none;
    border: none;
    color: var(--primary-color);
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    display: flex;
    align-items: center;
    padding: 5px 0;
    transition: color 0.2s ease;
}

.image-toggle-button:hover {
    color: var(--primary-color);
}

.image-toggle-button i {
    margin-right: 8px;
    transition: transform 0.3s ease;
    color: var(--primary-color);
}

.image-toggle-button[aria-expanded="true"] i {
    transform: rotate(90deg);
    color: var(--primary-color);
}

.image-toggle-content {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: max-height 0.5s ease-out, opacity 0.3s ease-out, visibility 0.3s ease-out;
}

.image-toggle-content.is-expanded {
    max-height: 1000px;
    opacity: 1;
    visibility: visible;
}

.image-toggle-content .screenshot {
    max-width: 100%;
    height: auto;
    display: block;
    margin-top: 15px;
    border: 0px solid var(--border-color);
    /* border: 1px solid var(--border-color); */
    border-radius: 5px;
    box-shadow: 0 2px 5px var(--shadow-color);
}

.image-toggle-content .caption {
    font-size: 14px;
    color: var(--light-text-color);
    margin-top: 8px;
    text-align: center;
}
/* ==========================================
通常のテーブル表（基本）
===========================================*/
table.manual-table1 {
  width: 100%;
  border: 0;
  border-collapse: collapse;
  font-size: 1.0em;
}

table.manual-table1 thead th.TitleA { /*薄い水色*/
  background: #c8e4ff;
}

table.manual-table1 thead th.TitleB { /*明るい水色*/
  background: #99cdff;
}

table.manual-table1 thead th.TitleC { /*濃い青*/
  background: #008bdd;
  color: #fff;
}

table.manual-table1 thead th.TitleGreen { /*グリーン*/
  background: #baef00;
}

table.manual-table1 thead th.TitleBlue { /*ブルー*/
  background: #79faff;
}

table.manual-table1 th,
table.manual-table1 td {
  border:1px solid #b9cadf;
  padding: 10px;
  vertical-align: top;
  line-height:1.8em;
}

table.manual-table1 th {
  font-weight: bold;
  text-align: center;
  background: #e9eef4;
  font-weight: bold;
}

table.manual-table1 tr.Center th {
  text-align: center;
}

table.manual-table1 .Middle th,
table.manual-table1 .Middle td {
  vertical-align: middle;
}

table.manual-table1 td.White { /*白セル*/
  background: #fff;
}

table.manual-table1 td.BlueGray { /*ブルーグレーセル*/
  background: #f5f6f9;
}

table.manual-table1 tfoot th {
  background: #c8e4ff;
}

table.manual-table1.Details tr:nth-child(2n+1) { /*ストライプ（白）*/
  background: #fff;
}

table.manual-table1.Details tr:nth-child(2n+0) { /*ストライプ（グレー）*/
  background: #f5f6f9;
}

/* テーブルのスタイル */
/*.manual-table1 {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
}

.manual-table1 th,
.manual-table1 td {
  border: 1px solid #b9cadf;
  padding: 10px 15px;
  text-align: left;
  vertical-align:top;
}

.manual-table1 thead th {
  background-color: #008bdd;
  font-weight: bold;
  color: #fff;
  text-align: center;*/ /* 項目名は中央寄せ */
/*}*/

/* 偶数行の背景色（ストライプ効果） */
/*.manual-table1 tbody tr:nth-child(even) {
  background-color: #f5f6f9;*/ /* 薄い水色系 */
/*}*/

/* ホバー時の行の背景色 */
.manual-table tbody tr:hover {
    background-color: #e6f7ff; /* より薄い水色系 */
}
/* レスポンシブデザイン */
.manual-layout {
    display: flex;
    gap: 20px;
    padding-top: 20px;
    flex: 1;
    min-height: 0; /* フレックスアイテムの縮小を許可 */
    overflow: hidden; /* レイアウト内でのスクロール制御 */
}


/* ハイライトスタイル */
.manual-content p.highlight {
    width: 800px;
    background-color: var(--note-bg); /* 変数を利用して統一感を出す */
    padding: 30px 15px;
    border-radius: 5px;
    font-weight: bold;
    color: var(--note-text); /* 変数を利用して統一感を出す */
    margin-top: 20px; /* 上部に少し余白を追加して他のテキストと区別 */
    text-align: center; /* テキストを中央寄せにする場合 */
}

/* キャンセル依頼の注意書きの文字色 */
.cancel-note-text {
    color: #FF0000; /* 例: 赤色に設定 */
    /* 必要に応じて、フォントの太さなども調整できます */
    /* font-weight: bold; */
}

/* 親の目次リストのスタイル (既存の場合があります) */
.table-of-contents {
    list-style: none; /* デフォルトのリストマーカーを非表示 */
    padding: 0;
    margin: 0;
}

.table-of-contents li {
    margin-bottom: 5px; /* 各項目間のスペース */
}

/* 新しく追加したサブメニューのスタイル */
.sub-menu {
    list-style: none; /* サブメニューのデフォルトマーカーも非表示に */
    padding-left: 20px; /* 親項目からのインデント */
    margin-top: 5px; /* 親項目との上部のスペース */
    margin-bottom: 5px; /* 親項目との下部のスペース */
}

/* サブメニュー内の項目 */
.sub-menu li {
    color: #555; /* 親項目と異なる色にする場合 */
}
.sub-menu li a {
  padding-left: 3px;
}

/* ホバー時のスタイル (任意) */
.table-of-contents li a:hover,
.sub-menu li a:hover {
    color: #007bff; /* ホバー時の色 */
    text-decoration: underline; /* ホバー時に下線 */
}

/* 画像拡大 */
  .image-container {
    /*display: inline-block;*/
    overflow: hidden;
  }
  .image-container img {
    transition: transform 0.5s ease;
    cursor: pointer;
  }
  .image-container img:hover {
    transform: scale(1.5); /* 拡大率 */
  }



/* 目次第二から遷移時に使用 */
.content-sub {
  display: flex; /* Flexboxコンテナにする */
  align-items: center; /* 縦方向の中央寄せ */
  justify-content: space-between; /* 子要素を両端に配置 */
  border-bottom: 1px solid #ccc; /* 下の線を追加 */
  padding: 20px 15px; /* 上下の余白を確保 */
}
.link {
  text-decoration: none;
  color: #333;
  color: var(--primary-dark-color);
  /* 疑似要素は子要素の後に配置される */
}

.content-sub::after {
  content: ">"; /* 疑似要素として ">" を挿入 */
  font-weight: bold;
  
}

/* すべての <li> 要素の文字サイズを1.2emに設定 */
.my-list li {
  font-size: 1.2em; /* 親要素の文字サイズを基準に1.2倍に */
}

/* クラスが "large-text" の <li> 要素だけ文字サイズを20pxに設定 */
.large-text {
  font-size: 18px;
}

/* 囲み線 */
.box18{
    margin:2em 0;
    position: relative;
    padding: 0.5em 1em;
    border: solid 2px #ffcb8a;
    border-radius: 3px 0 3px 0;
}
.box18:before,.box18:after
{
    content: '';
    position: absolute;
    width:10px;
    height: 10px;
    border: solid 2px #ffcb8a;
    border-radius: 50%;
}
.box18:after {
    top:-12px;
    left:-12px;
}
.box18:before {
    bottom:-12px;
    right:-12px;
}
.box18 p {
    margin: 5; 
    padding: 5;
}

/* 囲み線 */
.box1 {
    padding: 0.2em 0.9em;
    /* 修正前: margin: 2em 0; */
    /* margin: 1em auto; 上下2em、左右autoで中央寄せ */
    font-weight: bold;
    color: #6091d3;/*文字色*/
    background: #FFF;
    border: solid 1.5px #6091d3;/*線*/
    border-radius: 10px;/*角の丸み*/
    width: 350px;
}

.box2 {
  padding: 0.9em 1em;
  /* 修正前: margin: 2em 0; */
  margin: 0px auto; /* 上下2em、左右autoで中央寄せ */
  font-weight: bold;
  color: #6091d3; /*文字色*/
  background: #FFF;
  border: solid 1.5px #ccc; /*線*/
  width: 300px;
  font-size:13px;
}
.box2 p {
    margin: 0; 
    padding: 0;
}

.box3 {
    padding: 0.5em 1em;
    margin: 2em 0;
    color: #474747;
    background: whitesmoke;/*背景色*/
    border-left: double 7px #4ec4d3;/*左線*/
    border-right: double 7px #4ec4d3;/*右線*/
    text-align: center;
    width: 350px;
}

/* パンくず ここから */
nav#breadcrumb {
  margin-top:0;
  margin-bottom: 20px;
  color: var(--light-text-color);
  border:none;
  font-size:16px;
}
nav#breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap; /* Allow wrapping on small screens */
}
nav#breadcrumb ol li {
  color: var(--primary-dark-color);
  display: flex;
  align-items: center;
  margin: 0;
}
nav#breadcrumb li:not(:last-child)::after {
  content: '>';
  margin: 0 8px;
  color: var(--border-color);
}
nav#breadcrumb ol li:last-child span {
  font-weight: bold !important;
  text-decoration: none;
}
/* パンくず ここまで */

/* 横並び */
.wrap{
    display:flex;
}
.wrap_arr150{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 160px;
    height: 50px;
    margin-top: 20px;
    margin-bottom: 40px;
    margin-left: 45px;
    background-color: #f5f5f5;
    border-radius: 10px;/*角の丸み*/
}
.wrap_arr350 {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  /*color: #6091d3;文字色*/
}

.manual-content h5 {
    font-size: 1.6em; /* 少し大きく */
    padding-bottom: 12px; /* 下線との距離を広げる */
    margin-bottom: 25px; /* 次のコンテンツとの距離を広げる */
    color: var(--primary-dark-color); /* 強調色 */
    text-align: center; /* 中央寄せ */
    border-bottom: 2px solid var(--primary-light-color); /* より目立つ下線 */
}

/* 画像ボタン */
.btn01 {
  width: 170px; 
  height: 60px;
  border-radius: 10px;/*角の丸み*/
  /* object-fit: cover;  画像を要素のサイズに合わせてトリミング */
  object-fit: contain; /* アイコンのアスペクト比を維持して収める */
  border: 1px solid #D3D3D3; 
}

/* --- ライトボックス/モーダル関連のCSS --- */
/* オーバーレイ（背景の暗い部分）*/
#lightbox-overlay {
    position: fixed; /* 画面に固定 */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8); /* 半透明の黒色 */
    z-index: 9999; /* 他の要素より前面に表示 */
    display: flex; /* Flexboxでコンテンツを中央に配置 */
    justify-content: center;
    align-items: center;
    opacity: 0; /* 最初は透明（非表示） */
    visibility: hidden; /* 最初は非表示（クリック不可） */
    transition: opacity 0.3s ease, visibility 0.3s ease; /* フェードイン/アウトのアニメーション */
    cursor: pointer; /* オーバーレイクリックで閉じることを示唆 */
}

/* オーバーレイが表示される時の状態 */
#lightbox-overlay.active {
    opacity: 1; /* 不透明にして表示 */
    visibility: visible; /* 表示 */
}

/* ライトボックスのコンテンツ（拡大画像と閉じるボタンを囲む部分）*/
#lightbox-content {
    position: relative; /* 閉じるボタンの配置基準 */
    max-width: 90%; /* 最大幅 */
    max-height: 90%; /* 最大高さ */
    background-color: #fff; /* 背景色 */
    padding: 15px; /* 内側の余白 */
    box-shadow: 0 0 25px rgba(0, 0, 0, 0.6); /* 影 */
    border-radius: 8px; /* 角を丸くする */
    box-sizing: border-box; /* パディングを幅に含める */
    text-align: center; /* 画像を中央に配置 */
    transform: scale(0.9); /* 最初は少し縮小 */
    transition: transform 0.3s ease; /* スケールアニメーション */
}

/* オーバーレイが表示される時にコンテンツを元のサイズに戻す */
#lightbox-overlay.active #lightbox-content {
    transform: scale(1);
}

/* 拡大画像 */
#lightbox-image {
    max-width: 100%; /* コンテナに収まるように調整 */
    max-height: 80vh; /* ビューポートの高さの80%まで（画面に収まるように）*/
    display: block; /* 余白を削除 */
    margin: 0 auto; /* 中央寄せ */
    border-radius: 4px; /* 角を丸くする */
}

/* 閉じるボタン */
#lightbox-close {
    position: absolute;
    top: -15px; /* コンテンツの少し外側 */
    right: -15px;
    background-color: #333; /* ボタンの背景色 */
    color: #fff; /* ボタンの文字色 */
    width: 35px;
    height: 35px;
    border-radius: 50%; /* 円形 */
    text-align: center;
    line-height: 35px; /* 中央揃え */
    font-size: 24px; /* 文字サイズ */
    font-weight: bold;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    transition: background-color 0.2s ease, transform 0.2s ease;
    z-index: 10000; /* オーバーレイより前面 */
}

#lightbox-close:hover {
    background-color: #f00; /* ホバー時の色 */
    transform: scale(1.1); /* ホバー時に少し拡大 */
}

/* --- メール営業時間カード --- */
.email-hours-card {
    background-color: var(--background-color); /* 背景色 */
    /* border: 1px solid var(--border-color);  *//* 枠線 */
    padding: 15px;
    margin-bottom: 25px;
    /* box-shadow: 0 4px 8px var(--shadow-color); */ /* 軽い影 */
    /*text-align: center;*/
    padding-left: 235px;
}

.email-hours-card .card-item {
    /* display: flex; アイコンとテキストを横並びにする */
    align-items: flex-start; /* アイコンとテキストの先頭を揃える */
    margin-bottom: 15px; /* 各項目間の余白 */
    line-height: 1.6; /* 行の高さ */
}

.email-hours-card .card-item:last-child {
    margin-bottom: 0; /* 最後の項目の下マージンを削除 */
}

.card-icon {
  font-size: 1.3em; /* アイコンサイズ */
  color: #008bdd; /* アイコン色 */
  margin-right: 10px;
  flex-shrink: 0; /* アイコンが縮まないようにする */
  width: 30px; /* アイコンの固定幅 */
}

