/* --- 【カスタム変数定義】 --- */
:root {
  --header-height: 40px;
  --navbar-bg: #006400;
  --navbar-text: #fff;
  --navbar-hover-text: #ffcc00;
  --sidebar-bg: #E8F3E8;
  --sidebar-width: 210px;
}

/* ---【ヘッダーメニュー（トップナビ）】--- */
.navbar {
  --bs-navbar-padding-y: .125rem;
  min-height: var(--header-height);
  padding-top: var(--bs-navbar-padding-y);
  padding-bottom: var(--bs-navbar-padding-y);
  background-color: var(--navbar-bg); 
}
.navbar .nav-link { color: var(--navbar-text); }
.navbar .nav-link:hover { color: var(--navbar-hover-text); }
.navbar .d-flex { align-items: center; }

.form-control {
  height: 1.75rem;
  padding: .125rem .5rem;
  font-size: .875rem;
}
.btn {
  padding: .125rem .5rem;
  font-size: .875rem;
  writing-mode: horizontal-tb;
  white-space: nowrap;
}

/* ---【サイドバー】--- */
.sidebar {
  /* --- 固定位置 --- */
  position: fixed; 
  top: var(--header-height);
  bottom: 0;
  left: 0;
  z-index: 100;
  width: var(--sidebar-width);
  padding: 1rem;
  overflow-y: auto;
  background-color: var(--sidebar-bg);
  border-right: 1px solid rgba(0,0,0,.1);
}
.sidebar .fs-5 {
  color: #333;
  padding: .25rem .5rem;
}
.sidebar .btn-toggle-nav a {
  color: var(--bs-body-color);
}
.sidebar .btn-toggle-nav a:hover {
  color: var(--bs-body-color-emphasis);
}

/* ---【メインコンテンツ】--- */
.content {
  /* --- サイドバーの右側に配置するマージン設定 (PC時) --- */
  margin-top: var(--header-height);
  margin-left: var(--sidebar-width); 
  padding: 1rem;
}

/* ---【折りたたみボタン (アコーディオンの親項目)】--- */
.btn-toggle {
  padding: .25rem .5rem;
  font-weight: 600;
  color: #333;
  background-color: transparent;
  width: 100%;
  text-align: left;
}
.btn-toggle:hover {
  color: #000;
  background-color: rgba(0,0,0,.05);
}
.btn-toggle::before {
  /* ---　【SVGアイコンのdata-URI (省略)】--- */
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-chevron-right' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: .5rem;
  transition: transform .2s ease-in-out;
  transform: rotate(90deg);
}
.btn-toggle.collapsed::before {
  transform: rotate(0deg);
}
.btn-toggle-nav a {
  padding: .125rem .5rem;
  margin-left: 1.5rem;
}

/* ---【サイドバーオーバーレイ】--- */
.sidebar-backdrop {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 99; 
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
}

/* ---【レスポンシブ対応】--- */
/* --- Bootstrap 標準の 991.98px（lg）から変更して狭くした --- */
@media (max-width: 767.98px) {
  .sidebar {
    left: calc(-1 * var(--sidebar-width));
    width: var(--sidebar-width);
    transition: left .2s ease;
  }
  .sidebar.show { left: 0; }
  
  /* --- 【モバイルではマージンを解除】 --- */
  .content { margin-left: 0; }
  
  .sidebar-backdrop.show {
    display: block;
  }

  body.sidebar-open {
    overflow: hidden;
  }
}

/* 画像をウィンドウサイズに合わせて伸縮させ、最大幅を1000pxに制限する */
img.fullscreen {
  width: 100%;        /* 横幅いっぱいに広げる */
  max-width: 1000px;  /* ただし1000pxを超えない */
  height: auto;       /* 縦横比を保持する */
  display: block;     /* 余計な隙間をなくす */
}
  /* --- 【画像をウィンドウ幅に合わせて伸縮させる】 --- */

/* 画像をウィンドウサイズに合わせて伸縮させ、最大幅を1000pxに制限し中央揃え */
img.responsive-limit {
  width: 100%; /* 縮小時に親要素の幅いっぱいに広がる */
  max-width: 1000px; /* 画像が1000pxを超えて拡大されるのを防ぐ */
  height: auto;/* 縦横比を保つ */
  display: block;    /* 他の要素との配置を整理するためにブロック要素にする */
  margin: 0 auto;    /* ページ中央に配置する（任意） */
}
/* 例: キャプションのテキストを中央揃えにする */
.photo-container figcaption {
  text-align: center;
  margin-top: 5px;   /* 画像との間に少しスペースを空ける */
}
/* --- 【インデントによる本文の記述用】 --- */
.indent {
  margin-left: 2em;   /* 全角2文字分のインデント */
}
.indent2 {
  margin-left: 4em;   /* 全角4文字分のインデント */
}
.indent3 {
  margin-left: 6em;   /* 全角6文字分のインデント */
}

/* --- 【水平の点線を引く】 --- */
.dotted-line {
  width: 95%;
  height: 0;
  border-top: 1px dotted #aaa;
  margin: 1rem auto;
}


