@charset "UTF-8";
:root,
[data-bs-theme=light] {
  --bs-blue: #0d6efd;
  --bs-indigo: #6610f2;
  --bs-purple: #6f42c1;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #198754;
  --bs-teal: #20c997;
  --bs-cyan: #0dcaf0;
  --bs-black: #000;
  --bs-white: #fff;
  --bs-gray: #6c757d;
  --bs-gray-dark: #343a40;
  --bs-gray-100: #f8f9fa;
  --bs-gray-200: #e9ecef;
  --bs-gray-300: #dee2e6;
  --bs-gray-400: #ced4da;
  --bs-gray-500: #adb5bd;
  --bs-gray-600: #6c757d;
  --bs-gray-700: #495057;
  --bs-gray-800: #343a40;
  --bs-gray-900: #212529;
  --bs-primary: #0d6efd;
  --bs-secondary: #6c757d;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529;
  --bs-primary-rgb: 13, 110, 253;
  --bs-secondary-rgb: 108, 117, 125;
  --bs-success-rgb: 25, 135, 84;
  --bs-info-rgb: 13, 202, 240;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger-rgb: 220, 53, 69;
  --bs-light-rgb: 250, 250, 250;
  --bs-dark-rgb: 33, 37, 41;
  --bs-primary-text-emphasis: #052c65;
  --bs-secondary-text-emphasis: #2b2f32;
  --bs-success-text-emphasis: #0a3622;
  --bs-info-text-emphasis: #055160;
  --bs-warning-text-emphasis: #664d03;
  --bs-danger-text-emphasis: #58151c;
  --bs-light-text-emphasis: #495057;
  --bs-dark-text-emphasis: #495057;
  --bs-primary-bg-subtle: #cfe2ff;
  --bs-secondary-bg-subtle: #e2e3e5;
  --bs-success-bg-subtle: #d1e7dd;
  --bs-info-bg-subtle: #cff4fc;
  --bs-warning-bg-subtle: #fff3cd;
  --bs-danger-bg-subtle: #f8d7da;
  --bs-light-bg-subtle: #fcfcfd;
  --bs-dark-bg-subtle: #ced4da;
  --bs-primary-border-subtle: #9ec5fe;
  --bs-secondary-border-subtle: #c4c8cb;
  --bs-success-border-subtle: #a3cfbb;
  --bs-info-border-subtle: #9eeaf9;
  --bs-warning-border-subtle: #ffe69c;
  --bs-danger-border-subtle: #f1aeb5;
  --bs-light-border-subtle: #e9ecef;
  --bs-dark-border-subtle: #adb5bd;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  --bs-body-font-family: var(--bs-font-sans-serif);
  --bs-body-font-size: 1rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.5;
  --bs-body-color: #212529;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg: #fff;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-emphasis-color: #000;
  --bs-emphasis-color-rgb: 0, 0, 0;
  --bs-secondary-color: rgba(33, 37, 41, 0.75);
  --bs-secondary-color-rgb: 33, 37, 41;
  --bs-secondary-bg: #e9ecef;
  --bs-secondary-bg-rgb: 233, 236, 239;
  --bs-tertiary-color: rgba(33, 37, 41, 0.5);
  --bs-tertiary-color-rgb: 33, 37, 41;
  --bs-tertiary-bg: #f8f9fa;
  --bs-tertiary-bg-rgb: 248, 249, 250;
  --bs-heading-color: inherit;
  --bs-link-color: #0d6efd;
  --bs-link-color-rgb: 13, 110, 253;
  --bs-link-decoration: underline;
  --bs-link-hover-color: #0a58ca;
  --bs-link-hover-color-rgb: 10, 88, 202;
  --bs-code-color: #d63384;
  --bs-highlight-color: #212529;
  --bs-highlight-bg: #fff3cd;
  --bs-border-width: 1px;
  --bs-border-style: solid;
  --bs-border-color: #dee2e6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  --bs-border-radius: 0.375rem;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-xl: 1rem;
  --bs-border-radius-xxl: 2rem;
  --bs-border-radius-2xl: var(--bs-border-radius-xxl);
  --bs-border-radius-pill: 50rem;
  --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --bs-focus-ring-width: 0.25rem;
  --bs-focus-ring-opacity: 0.25;
  --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
  --bs-form-valid-color: #198754;
  --bs-form-valid-border-color: #198754;
  --bs-form-invalid-color: #dc3545;
  --bs-form-invalid-border-color: #dc3545;
}

[data-bs-theme=dark] {
  color-scheme: dark;
  --bs-body-color: #dee2e6;
  --bs-body-color-rgb: 222, 226, 230;
  --bs-body-bg: #212529;
  --bs-body-bg-rgb: 33, 37, 41;
  --bs-emphasis-color: #fff;
  --bs-emphasis-color-rgb: 255, 255, 255;
  --bs-secondary-color: rgba(222, 226, 230, 0.75);
  --bs-secondary-color-rgb: 222, 226, 230;
  --bs-secondary-bg: #343a40;
  --bs-secondary-bg-rgb: 52, 58, 64;
  --bs-tertiary-color: rgba(222, 226, 230, 0.5);
  --bs-tertiary-color-rgb: 222, 226, 230;
  --bs-tertiary-bg: #2b3035;
  --bs-tertiary-bg-rgb: 43, 48, 53;
  --bs-primary-text-emphasis: #6ea8fe;
  --bs-secondary-text-emphasis: #a7acb1;
  --bs-success-text-emphasis: #75b798;
  --bs-info-text-emphasis: #6edff6;
  --bs-warning-text-emphasis: #ffda6a;
  --bs-danger-text-emphasis: #ea868f;
  --bs-light-text-emphasis: #f8f9fa;
  --bs-dark-text-emphasis: #dee2e6;
  --bs-primary-bg-subtle: #031633;
  --bs-secondary-bg-subtle: #161719;
  --bs-success-bg-subtle: #051b11;
  --bs-info-bg-subtle: #032830;
  --bs-warning-bg-subtle: #332701;
  --bs-danger-bg-subtle: #2c0b0e;
  --bs-light-bg-subtle: #343a40;
  --bs-dark-bg-subtle: #1a1d20;
  --bs-primary-border-subtle: #084298;
  --bs-secondary-border-subtle: #41464b;
  --bs-success-border-subtle: #0f5132;
  --bs-info-border-subtle: #087990;
  --bs-warning-border-subtle: #997404;
  --bs-danger-border-subtle: #842029;
  --bs-light-border-subtle: #495057;
  --bs-dark-border-subtle: #343a40;
  --bs-heading-color: inherit;
  --bs-link-color: #6ea8fe;
  --bs-link-hover-color: #8bb9fe;
  --bs-link-color-rgb: 110, 168, 254;
  --bs-link-hover-color-rgb: 139, 185, 254;
  --bs-code-color: #e685b5;
  --bs-highlight-color: #dee2e6;
  --bs-highlight-bg: #664d03;
  --bs-border-color: #495057;
  --bs-border-color-translucent: rgba(255, 255, 255, 0.15);
  --bs-form-valid-color: #75b798;
  --bs-form-valid-border-color: #75b798;
  --bs-form-invalid-color: #ea868f;
  --bs-form-invalid-border-color: #ea868f;
}

/*
* 最小のモバイル端末用の設定
*/
.margin-001 {
  padding-top: 1.5rem;
  padding-bottom: 0.75rem;
}

.margin-002 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.margin-002002 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.margin-003 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.margin-last {
  padding-top: 0.75rem;
  padding-bottom: 1.5rem;
}

.margin-icon {
  padding-top: 3rem;
  padding-bottom: 0rem;
}

.margin-lead {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}

.line-height-lead {
  line-height: 1.75rem;
}

.line-height-lead-about {
  line-height: 2rem;
}

.padding-001 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.keyVisualSp {
  border-radius: 0 !important;
  margin-top: 56px;
  margin-bottom: 0;
}

.mainVisualOfPrivacy-policy {
  margin-top: 2rem;
}

.mainVisualOfAbout {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

/* div.content-end {
  position: relative;
  z-index: 0;
  padding-bottom: 3rem;
}

footer div.container {
  position: absolute;
  background-color: white;
  z-index: 9999;
} */

@media (min-width: 576px) {
  .margin-001, .margin-002, .margin-003 {
  margin-top: 2rem;
  margin-bottom: 2rem;
  }

  .margin-last {
  margin-top: 2rem;
  margin-bottom: 2.5rem;
  }

  .padding-001 {
  padding-top: 1rem;
  padding-bottom: 1rem;
  }
}

@media (min-width: 768px) {
  .margin-001 {
    padding-top: 1.5rem;
    padding-bottom: 0.75rem;
  }

  .margin-002 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-002002 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-003 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-last {
    padding-top: 0.75rem;
    padding-bottom: 1.5rem;
  }

  .margin-icon {
    padding-top: 3rem;
    padding-bottom: 0rem;
  }

  .margin-lead {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }

  .line-height-lead {
    line-height: 1.6rem;
  }

  .line-height-lead-about {
    line-height: 2rem;
  }

  .padding-001 {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  .mainVisual {
  margin-top: 56px;
  margin-bottom: 5rem;
  }

  .mainVisualOfPrivacy-policy {
    margin-top: 3.5rem;
  }

  .mainVisualOfAbout {
    margin-top: 10rem;
    margin-bottom: 10rem;
  }
}


@media (min-width: 992px) {
  /* Navbarのカスタムスタイル */
  .navbar {
      box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
      background-color: #ffffff;
      font-family: 'Inter', sans-serif;
  }

  /* ナビゲーションリンクのスタイル */
  .navbar-nav .nav-link {
      position: relative; /* 下線の基準にするため */
      /* font-weight: 600; */
      color: #4b5563; /* ダークグレーのテキスト */
      padding: 0.3rem 1.2rem;
      transition: color 0.3s ease;
      overflow: hidden; /* 下線がはみ出さないように */
  }

  .navbar-nav .nav-link:hover,
  .navbar-nav .nav-link.active {
      color: #0d6efd; /* ホバー時の色 (紫) */
  }

  /* 下線の<span>要素のスタイル */
  .navbar-nav .nav-link .underline {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 1px;
      background-color: #0d6efd;
      border-radius: 2px;
      /* アニメーションの設定 */
      transform: scaleX(0); /* 初期状態では非表示 */
      transform-origin: right; /* 縮小・拡大の起点を右に設定 */
      transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }

  /* ホバー時の下線アニメーション */
  .navbar-nav .nav-link:hover .underline {
      transform: scaleX(1); /* ホバー時に元のサイズに戻す（左から右に拡大） */
      transform-origin: left; /* 拡大の起点を左に設定 */
  }

  /* Bootstrapのドロップダウン矢印を非表示に */
  .navbar-nav .nav-link.dropdown-toggle::after {
      content: none;
  }
  
  /* ドロップダウンメニューの位置を調整 */
  .dropdown-menu {
      margin-top: 0px; /* ドロップダウンメニューの上の余白を設定 */
      border: none;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
      border-radius: 0.5rem;
  }
  
  /* ドロップダウンメニュー内のリンクのスタイルを調整 */
  .navbar-nav .dropdown-menu .dropdown-item {
      color: #4b5563;
      /* font-weight: 400; */
      transition: background-color 0.2s ease, color 0.2s ease;
  }

  .navbar-nav .dropdown-menu .dropdown-item:hover {
      background-color: #f1f5f9;
      color: #0d6efd;
  }


  .nav {
    --bs-nav-link-padding-x: 0rem !important;
    --bs-nav-link-padding-y: 0.5rem;
    --bs-nav-link-font-weight: ;
    --bs-nav-link-color: var(--bs-link-color);
    --bs-nav-link-hover-color: var(--bs-link-hover-color);
    --bs-nav-link-disabled-color: var(--bs-secondary-color);
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
  }

  .nav-link {
    display: block;
    padding: 0.3rem 0 !important;
    margin: 0 .75rem !important;
    font-size: var(--bs-nav-link-font-size);
    font-weight: var(--bs-nav-link-font-weight);
    color: var(--bs-nav-link-color);
    text-decoration: none;
    background: none;
    border: 0;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
  }

  .margin-001 {
    padding-top: 1.5rem;
    padding-bottom: 0.75rem;
  }

  .margin-002 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-002002 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-003 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .margin-last {
    padding-top: 0.75rem;
    padding-bottom: 1.5rem;
  }

  .margin-icon {
    padding-top: 3rem;
    padding-bottom: 0rem;
  }

  .margin-lead {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }

  .line-height-lead {
    line-height: 1.6rem;
  }

  .line-height-lead-about {
    line-height: 2rem;
  }

  .padding-001 {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  .mainVisual {
  margin-top: 56px;
  margin-bottom: 5rem;
  }

  .mainVisualOfPrivacy-policy {
    margin-top: 3.5rem;
  }

  .mainVisualOfAbout {
    margin-top: 10rem;
    margin-bottom: 10rem;
  }
}

/*
* 全体に影響する設定
*/

/* ナビゲーションバーの transition を設定 */
#navbar {
    transition: transform 0.4s ease-out;
}

/* ナビゲーションバーを隠すためのクラス */
#navbar.navbar--hidden {
    /* Y軸方向に自身の高さ分だけ上に移動させる */
    transform: translateY(-100%);
}

.navbar-brand {
  color: orangered !important;
}

/* a {
  color: orangered !important;
} */

body {
  color: #222;
}

.navbar-nav {
  font-weight: 400;
  font-size: normal;
}

.active {
  color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration: none !important;
}

/*
* Navbarの項目の下の下線
*/



.px-lg-mainPic {
  padding: 1.5rem;
}

.bg-light002 {
  /* background-color: #f0f0f0; */
  background-color: #ffeee8;
}

body, .noto-sans-jp {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-serif-jp {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.fw-semibold {
  font-weight: 500;
}

/*
 * 画像のフィルターのCSS
 */
.image-container {
    position: relative; /* 重ね合わせの基準点 */
    display: inline-block; /* 複数の画像を横に並べる場合など */
    margin: 0; /* 画像間の余白 */
    overflow: hidden; /* 必要に応じて、はみ出した部分を隠す */
}

.grayscale-image {
    display: block; /* インライン要素の余白問題を解消 */
    width: 100%; /* 画像の幅（適宜変更） */
    height: auto; /* 高さ自動調整 */
    filter: grayscale(100%); /* モノクロ表示 */
    transition: filter 0.3s ease-in-out; /* モノクロ効果のアニメーション */
}

.grayscale-image:hover {
    filter: grayscale(0%); /* ホバー時にモノクロ効果を解除（任意） */
}

.color-image {
    position: absolute; /* 重ねて配置 */
    top: 0;
    left: 0;
    width: 100%; /* 親要素と同じ幅 */
    height: auto; /* 高さ自動調整 */
    opacity: 0; /* 初期状態では非表示 */
    transition: opacity 0.3s ease-in-out; /* 透明度のアニメーション */
}

.image-container:hover .color-image {
    opacity: 1; /* ホバー時に表示 */
}

/*
 * 画像のフィルターその2のCSS
 */
.image-container {
    position: relative; /* 重ね合わせの基準点 */
    display: inline-block; /* 複数の画像を横に並べる場合など */
    margin: 0; /* 画像間の余白 */
    overflow: hidden; /* 必要に応じて、はみ出した部分を隠す */
}

.color-image002 {
    display: block; /* インライン要素の余白問題を解消 */
    width: 100%; /* 画像の幅（適宜変更） */
    height: auto; /* 高さ自動調整 */
    filter: grayscale(0%); /* モノクロ表示 */
    transition: filter 0.3s ease-in-out; /* モノクロ効果のアニメーション */
}

.color-image002:hover {
    filter: grayscale(100%); /* ホバー時にモノクロ効果を解除（任意） */
}

.grayscale-image002 {
    position: absolute; /* 重ねて配置 */
    top: 0;
    left: 0;
    width: 100%; /* 親要素と同じ幅 */
    height: auto; /* 高さ自動調整 */
    opacity: 0; /* 初期状態では非表示 */
    transition: opacity 0.3s ease-in-out; /* 透明度のアニメーション */
}

.image-container:hover .grayscale-image002 {
    opacity: 1; /* ホバー時に表示 */
}

/*
 * ふわっと表示させるアニメーション
 */
/* --- ふわっと表示させるためのCSS --- */

/* アニメーションさせたい要素の初期状態 */
.fade-in-element-001 {
    opacity: 0; /* 最初は透明 */
    transform: translateY(100px); /* 少し下に移動 */
    transition: opacity 0.8s ease-out, transform 0.8s ease-out; /* アニメーションの指定 */
}

/* 画面内に入ったときに付与するクラス */
.fade-in-element-001.is-visible {
    opacity: 1; /* 不透明にする */
    transform: translateY(0); /* 元の位置に戻す */
}

.fade-in-element-002 {
    opacity: 0; /* 最初は透明 */
    transform: translateY(150px); /* 少し下に移動 */
    transition: opacity 0.8s ease-out, transform 0.8s ease-out; /* アニメーションの指定 */
}

/* 画面内に入ったときに付与するクラス */
.fade-in-element-002.is-visible {
    opacity: 1; /* 不透明にする */
    transform: translateY(0); /* 元の位置に戻す */
}

.fade-in-element-003 {
    opacity: 0; /* 最初は透明 */
    transform: translateY(200px); /* 少し下に移動 */
    transition: opacity 0.8s ease-out, transform 1.6s ease-out; /* アニメーションの指定 */
}

/* 画面内に入ったときに付与するクラス */
.fade-in-element-003.is-visible {
    opacity: 1; /* 不透明にする */
    transform: translateY(0); /* 元の位置に戻す */
}

.fade-in-element-004 {
    opacity: 0; /* 最初は透明 */
    transform: translateY(300px); /* 少し下に移動 */
    transition: opacity 0.8s ease-out, transform 1.6s ease-out; /* アニメーションの指定 */
}

/* 画面内に入ったときに付与するクラス */
.fade-in-element-004.is-visible {
    opacity: 1; /* 不透明にする */
    transform: translateY(0); /* 元の位置に戻す */
}