@charset "UTF-8";
@font-face {
  font-family: 'NotoSansJP';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../font/NotoSansCJKjp-Regular.woff") format("woff");
}
@font-face {
  font-family: 'NotoSansJP';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../font/NotoSansCJKjp-Bold.woff") format("woff");
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../font/Roboto-Regular.woff") format("woff");
}
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../font/Roboto-Bold.woff") format("woff");
}

/**
 * common.css
 *
 * #base
 *  #reset.............リセット用
 *  #default...........要素用
 *
 * #layout
 *
 * #common module
 *  #全ページ共通ヘッダー
 *  #全ページ共通フッター
 *
 * #utility.........ヘルパークラス
 *  #Margin
 *  #Padding
 *  #font
 *  #position
 *  #other.............clearfix等
*/


/* ==========================================================================
   #base
   ========================================================================== */
/* #reset
   ----------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, p, ul, li {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6, th { font-weight: bold; }

ul { list-style: none; }

strong { font-weight: inherit; }


/* #default
   ----------------------------------------------------------------- */
:root {
  --sr-bg-color: #f6f6f6;
  --sr-black: #333;
  --sr-grey: #A6A6A6;
  --sr-light-grey: #E7E7E7;
}

body {
  min-width: 1440px;
  font-family: NotoSansJP, sans-serif;
  font-size: 14px;
  line-height: 1.87;
  font-weight: 400;
  color: var(--sr-black);
  background-color: var(--sr-bg-color);
}

a { color: #4a9ded; }

a:hover { opacity: 0.8; }

img { vertical-align: bottom; }

*, *:before, *:after {
  box-sizing: border-box;
}

/* フラッシュメッセージ */
.message {
  margin: 12px 0;
  padding: 12px;
  background: #eff8ff;
  color: #2779bd;
  border-color: #6cb2eb;
  border-width: 1px;
  border-style: solid;
  border-radius: 4px;
}

.message.hidden {
  display: none;
}

.message.success {
  background: #e3fcec;
  color: #1f9d55;
  border-color: #51d88a;
}

.message.warning {
  background: #fffabc;
  color: #8d7b00;
  border-color: #d3b800;
}

.message.error {
  background: #fcebea;
  color: #cc1f1a;
  border-color: #ef5753;
}

/* ==========================================================================
   #header
   ========================================================================== */
/* ==========================================================================
   #header (改善案)
   ========================================================================== */

/* ヘッダー全体に影と下ボーダーを追加 */
.l-header {
  height: 60px; /* ★高さを少し広げる */
  background-color: #fff;
  border-bottom: 1px solid #e9ecef; /* ★薄い下線を追加 */
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04); /* ★ subtleな影 */
  position: sticky; /* ★スクロールに追従させる（任意） */
  top: 0;
  z-index: 1020; /* Bootstrapの標準的なz-indexに合わせる */
  margin-bottom: 30px; /* ★下のマージンを調整 */
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center; /* ★中央揃えを徹底 */
  height: 100%;
  max-width: 1400px; /* ★コンテンツ幅を少し広げる（任意） */
  margin: 0 auto;
  padding: 0 24px;
}

.header-logo {
  display: flex;
  align-items: center;
  padding-left: 0; /* ★余白をリセット */
}

.header-nav-wrapper {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 16px; /* ★gapを調整 */
}

.header-nav {
  display: flex;
  height: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ナビゲーション項目 */
.header-nav li {
  display: flex; /* ★gridからflexに変更 */
  align-items: center;
  padding: 0; /* ★paddingをリセット */
  border: none; /* ★区切り線を削除 */
}

.header-nav li a {
  display: flex;
  align-items: center;
  gap: 8px; /* アイコンとテキストの間の隙間 */
  padding: 0 20px;
  height: 100%;
  color: #495057; /* ★少し柔らかい黒に */
  text-decoration: none;
  font-weight: 500; /* ★少し太く */
  border-bottom: 3px solid transparent; /* ★ホバー/アクティブ時の下線のための準備 */
  transition: color 0.2s, border-color 0.2s;
}

/* ホバー時のスタイル */
.header-nav li a:hover {
  color: #000;
  background-color: #f8f9fa; /* ★背景色を少し変える */
}

/* アクティブな項目のスタイル */
.header-nav li.active a {
  color: #0d6efd; /* ★ブランドカラー（Bootstrapの青）に変更 */
  border-bottom-color: #0d6efd; /* ★下線を表示 */
  background-color: transparent; /* ★背景色はリセット */
}

/* --- ユーザーメニュー --- */
.header-user-menu {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
}

.user-profile {
  display: flex; /* ★gridからflexに変更 */
  align-items: center;
  height: 100%;
  padding: 0 16px;
  cursor: pointer;
  border: none; /* ★区切り線を削除 */
  transition: background-color 0.2s;
}
.user-profile:hover {
  background-color: #f8f9fa;
}

.user-profile-inner {
  display: flex;
  align-items: center;
  gap: 10px;
}

.user-profile .user-icon {
  width: 36px; /* ★少し大きく */
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
}
.user-profile .default-icon {
  font-size: 36px;
  color: #adb5bd; /* ★少し濃く */
}
.user-profile .user-name {
  font-weight: 600;
  font-size: 0.95rem;
  color: #343a40;
}
.dropdown-caret {
  font-size: 0.8em;
  color: #868e96;
  transition: transform 0.2s;
}
/* ドロップダウンが開いている時に▼を▲にする */
.user-dropdown-menu.show + .user-profile .dropdown-caret {
  transform: rotate(180deg);
}

/* --- ドロップダウンメニュー --- */
.user-dropdown-menu {
  display: block; /* ★常にblockにしておく */
  position: absolute;
  top: 65px; /* ★ヘッダーからの距離を少し空ける */
  right: 0;
  background-color: #fff;
  border: 1px solid #dee2e6;
  border-radius: 10px; /* ★角丸を大きく */
  box-shadow: 0 8px 16px rgba(0,0,0,0.1);
  min-width: 220px;
  z-index: 1000;
  overflow: hidden;

  /* ★アニメーションのための設定 */
  opacity: 0;
  transform: translateY(-10px);
  visibility: hidden;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}

/* ★表示状態のスタイル */
.user-dropdown-menu.show {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}

/* ドロップダウンのヘッダー部分 */
.dropdown-header {
  padding: 12px 16px;
  border-bottom: 1px solid #e9ecef;
}
.dropdown-header .user-name {
  font-weight: 600;
  color: #212529;
}
.dropdown-header .user-email {
  font-size: 0.8rem;
  color: #6c757d;
}

/* ドロップダウンの項目 */
.user-dropdown-menu .dropdown-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  color: #495057;
  text-decoration: none;
  font-size: 0.9rem;
  transition: background-color 0.2s;
}
.user-dropdown-menu .dropdown-item:hover {
  background-color: #f8f9fa;
  color: #212529;
}
.user-dropdown-menu .dropdown-item i {
  width: 16px;
  text-align: center;
  color: #868e96;
}

/* ==========================================================================
   #utility
   ========================================================================== */

/* #Margin
   ----------------------------------------------------------------- */
.m0{ margin:0!important; }

.mr0 { margin-right: 0!important; }
.mr5 { margin-right: 5px!important; }
.mr10 { margin-right: 10px!important; }
.mr15 { margin-right: 15px!important; }
.mr20 { margin-right: 20px!important; }
.mr25 { margin-right: 25px!important; }
.mr30 { margin-right: 30px!important; }
.mr35 { margin-right: 35px!important; }
.mr40 { margin-right: 40px!important; }
.mr45 { margin-right: 45px!important; }
.mr50 { margin-right: 50px!important; }

.ml0 { margin-left: 0!important; }
.ml5 { margin-left: 5px!important; }
.ml10 { margin-left: 10px!important; }
.ml15 { margin-left: 15px!important; }
.ml20 { margin-left: 20px!important; }
.ml25 { margin-left: 25px!important; }
.ml30 { margin-left: 30px!important; }
.ml35 { margin-left: 35px!important; }
.ml40 { margin-left: 40px!important; }
.ml45 { margin-left: 45px!important; }
.ml50 { margin-left: 50px!important; }

.mt0 { margin-top: 0!important; }
.mt5 { margin-top: 5px!important; }
.mt10 { margin-top: 10px!important; }
.mt15 { margin-top: 15px!important; }
.mt20 { margin-top: 20px!important; }
.mt25 { margin-top: 25px!important; }
.mt30 { margin-top: 30px!important; }
.mt35 { margin-top: 35px!important; }
.mt40 { margin-top: 40px!important; }
.mt45 { margin-top: 45px!important; }
.mt50 { margin-top: 50px!important; }

.mb0 { margin-bottom: 0!important; }
.mb1 { margin-bottom: 1px!important }
.mb2 { margin-bottom: 2px!important }
.mb3 { margin-bottom: 3px!important }
.mb4 { margin-bottom: 4px!important }
.mb5 { margin-bottom: 5px!important }
.mb10 { margin-bottom: 10px!important; }
.mb15 { margin-bottom: 15px!important; }
.mb20 { margin-bottom: 20px!important; }
.mb25 { margin-bottom: 25px!important; }
.mb30 { margin-bottom: 30px!important; }
.mb35 { margin-bottom: 35px!important; }
.mb40 { margin-bottom: 40px!important; }
.mb45 { margin-bottom: 45px!important; }
.mb50 { margin-bottom: 50px!important; }


/* #Padding
   ----------------------------------------------------------------- */
.p0{ padding: 0!important; }

.pr0 { padding-right: 0!important; }
.pr5 { padding-right: 5px!important; }
.pr10 { padding-right: 10px!important; }
.pr15 { padding-right: 15px!important; }
.pr20 { padding-right: 20px!important; }
.pr25 { padding-right: 25px!important; }
.pr30 { padding-right: 30px!important; }
.pr35 { padding-right: 35px!important; }
.pr40 { padding-right: 40px!important; }
.pr45 { padding-right: 45px!important; }
.pr50 { padding-right: 50px!important; }

.pl0 { padding-left: 0!important; }
.pl5 { padding-left: 5px!important; }
.pl10 { padding-left: 10px!important; }
.pl15 { padding-left: 15px!important; }
.pl20 { padding-left: 20px!important; }
.pl25 { padding-left: 25px!important; }
.pl30 { padding-left: 30px!important; }
.pl35 { padding-left: 35px!important; }
.pl40 { padding-left: 40px!important; }
.pl45 { padding-left: 45px!important; }
.pl50 { padding-left: 50px!important; }

.pt0 { padding-top: 0!important; }
.pt1 { padding-top: 1px!important; }
.pt2 { padding-top: 2px!important; }
.pt3 { padding-top: 3px!important; }
.pt4 { padding-top: 4px!important; }
.pt5 { padding-top: 5px!important; }
.pt10 { padding-top: 10px!important; }
.pt15 { padding-top: 15px!important; }
.pt20 { padding-top: 20px!important; }
.pt25 { padding-top: 25px!important; }
.pt30 { padding-top: 30px!important; }
.pt35 { padding-top: 35px!important; }
.pt40 { padding-top: 40px!important; }
.pt45 { padding-top: 45px!important; }
.pt50 { padding-top: 50px!important; }

.pb0 { padding-bottom: 0!important; }
.pb1 { padding-bottom: 1px!important; }
.pb2 { padding-bottom: 2px!important; }
.pb3 { padding-bottom: 3px!important; }
.pb4 { padding-bottom: 4px!important; }
.pb5 { padding-bottom: 5px!important; }
.pb10 { padding-bottom: 10px!important; }
.pb15 { padding-bottom: 15px!important; }
.pb20 { padding-bottom: 20px!important; }
.pb25 { padding-bottom: 25px!important; }
.pb30 { padding-bottom: 30px!important; }
.pb35 { padding-bottom: 35px!important; }
.pb40 { padding-bottom: 40px!important; }
.pb45 { padding-bottom: 45px!important; }
.pb50 { padding-bottom: 50px!important; }





/* #font
   ----------------------------------------------------------------- */
.tc { text-align: center; }
.tl { text-align: left; }
.tr { text-align: right; }

.tdu { text-decoration: underline; }

.lh10 { line-height: 1em; }
.lh15 { line-height: 1.5em; }
.lh2 { line-height: 2em; }
.lh3 { line-height: 3em; }

.vm { vertical-align: middle; }
.vt { vertical-align: top; }

.fs08 { font-size: 0.8em; }
.fs09 { font-size: 0.9em; }
.fs1 { font-size: 1em; }
.fs11 { font-size: 1.1em; }
.fs12 { font-size: 1.2em; }
.fs13 { font-size: 1.3em; }

.bn { border:none; }
.bbn { border-bottom: none; }
.bol {
  font-weight: bold;
}





/* #position
   ----------------------------------------------------------------- */
.relative { position: relative; }
.absolute { position: absolute; }

/* float解除 */
.cb { clear:both; }

/* float */
.fl-left { float: left; }
.fl-right { float: right; }





/* #other
   ----------------------------------------------------------------- */
.oh { overflow: hidden; }
.di { display: inline; }
.db { display: block; }

.clearfix:before, .clearfix:after {
  content:"";
  display:table;
}

.clearfix:after { clear:both; }
