@charset "UTF-8";
.wrapper-shadow {
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
}

body {
  margin: 0;
}

@media (min-width: 1920px) {
  body {
    overflow-x: hidden;
  }
  body.open {
    overflow-x: auto;
  }
}
main {
  min-width: 1920px;
}

html {
  color: #101010;
}

input {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-style: normal;
}

input[type=file]::-webkit-file-upload-button {
  display: none;
}

input[type=file] {
  display: none;
}

input[type=date]::-webkit-calendar-picker-indicator {
  display: block;
}

textarea {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-style: normal;
}

input[type=time]::-webkit-calendar-picker-indicator {
  display: none;
}

.labal_asterisk {
  color: #db2e2e;
}

.Safearea {
  padding-top: env(safe-area-inset-top);
  padding-right: env(safe-area-inset-right);
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
}

.ml-10 {
  margin-left: 10px;
}

.ml-15 {
  margin-left: 15px;
}

.ml-20 {
  margin-left: 20px;
}

.ml-30 {
  margin-left: 30px;
}

.ml-90 {
  margin-left: 90px;
}

.mr-5 {
  margin-right: 5px;
}

.mr-10 {
  margin-right: 10px;
}

.mr-20 {
  margin-right: 20px;
}

.mb-10 {
  margin-bottom: 10px;
}

.mb-50 {
  margin-bottom: 50px;
}

.mr-10 {
  margin-right: 10px;
}

.mr-20 {
  margin-right: 20px;
}

.mt-5 {
  margin-top: 5px !important;
}

.mt-6 {
  margin-top: 6px !important;
}

.mt-10 {
  margin-top: 10px;
}

.mt-30 {
  margin-top: 30px;
}

.mt-40 {
  margin-top: 40px;
}

.pr-20 {
  padding-right: 30px !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.fs-14 {
  font-size: 14px;
}

.text_Ellipsis {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.max-w100 {
  max-width: 100px;
}

.max-w450 {
  max-width: 450px;
}

.max-w500 {
  max-width: 500px;
}

.red-text {
  color: #db2e2e;
}

.fs-14 {
  font-size: 0.875rem;
}

.LoginPage {
  background-color: #f6f6f6;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  margin: 0;
}

.Login {
  width: 600px;
  height: 500px;
  background-color: #fff;
  position: relative;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  border-radius: 20px;
  display: flex;
  flex-direction: column;
}

.Login__logo_img {
  text-align: center;
  padding: 93px 0 10px 0;
}

.Login__form {
  width: 58%;
  margin-top: 45px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
}

.Login__form_wrapper {
  font-size: 0.875rem;
}

.Login__form_item {
  display: flex;
  flex-direction: column;
}
.Login__form_item._login {
  margin-bottom: 28px;
}

.Login__form_label {
  margin-bottom: 8px;
}

.LoginBtn {
  width: 170px !important;
  height: 40px !important;
  border: 2px solid #fff;
  border-radius: 100px;
  margin-top: 44px;
}

.Header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  height: 36px;
  width: 100%;
  min-width: 1880px;
  left: 0;
  padding: 0 20px;
  padding-top: 9px;
  padding-bottom: 5px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  position: relative;
  z-index: 2000;
}

/*  ロゴのマージンを削除し、ヘッダーのパディングに任せる */
.Header__logo {
  margin: 0; /* 20px を削除 */
}

.Header__logo_img {
  display: block;
  top: -12px;
}

.Header__right {
  display: flex;
  align-items: center;
  /* アイコン群とドロップダウンの間に間隔を設定 */
  gap: 22px;
  margin-right: 60px;
}

/* Header__icons__wrapper には d-flex が適用されているので、gap で間隔を設定 */
.Header__icons__wrapper {
  gap: 22px;
}

.Header__icons {
  position: relative;
  fill: #348be5;
  padding: 4px 8px 0px;
}

.Header__icons:hover {
  cursor: pointer;
  background-color: #dde9fc;
  border-radius: 30px;
  padding: 4px 8px 0px;
  transition: background-color 0.1s ease;
}

.Header__badge {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 10px;
  height: 10px;
  background-color: orange;
  border-radius: 50%;
  content: "";
  display: inline-block;
}
.Header__badge._notification {
  right: 3px;
}

.Header__dropdown {
  position: relative;
  display: inline-block;
  border-radius: 100px; /* 普段は丸い形 */
  background-color: #fff;
  cursor: pointer;
  overflow: visible;
  width: 150px;
  box-sizing: border-box;
  height: 36px;
  z-index: 2;
  margin-left: 0; /* 22px を削除 (Flexboxで制御) */
  margin-right: 0; /* 20px を削除 */
}

.Header__dropdown::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: solid 1px #9f9f9f;
  border-radius: 100px;
  pointer-events: none;
  box-sizing: border-box;
}

/* 開いたとき */
.Header__dropdown.open {
  border-radius: 100px; /* 枠を少し丸みを抑える */
  /* height は変えない → ボタン部分は固定 */
}

.Header__dropdown.open.Header__dropdown::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 200%;
  border: solid 1px #9f9f9f;
  border-radius: 12px;
  pointer-events: none;
  box-sizing: border-box;
  z-index: 100;
}

/* ボタン部分 */
.Header__dropbtn {
  all: unset;
  color: #000;
  font-size: 14px;
  padding: 0 14px;
  height: 36px;
  line-height: 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* 矢印 */
.Header__dropbtn_arrow {
  font-size: 12px;
  transition: transform 0.3s ease;
  color: #9f9f9f;
  position: absolute;
  right: 14px;
}

.Header__dropdown.open .Header__dropbtn_arrow {
  transform: rotate(180deg);
}

.Header__dropbtn_nameJp {
  font-weight: bold;
}

/* ドロップダウンの中身 */
.Header__dropdown_content {
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  border-radius: 0 0 12px 12px;
  border-top: none;
  max-width: 190px;
  box-sizing: border-box;
  min-width: 140px;
  transform: scaleY(0);
  transform-origin: top;
  opacity: 0;
  transition: transform 0.25s ease, opacity 0.25s ease;
  padding: 8px 14px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  z-index: 10;
  overflow: hidden;
}

/* 開いたとき */
.Header__dropdown.open .Header__dropdown_content {
  transform: scaleY(1);
  opacity: 1;
  max-width: 190px;
}

/* リンク */
.Header__dropdown_content a {
  display: block;
  color: black;
  text-decoration: none;
  font-size: 14px;
  text-align: right;
  width: 120px;
}

@font-face {
  font-family: "LINE Seed JP";
  src: url("../../fonts/LINESeedJP_OTF_Bd.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "LINE Seed JP";
  src: url("../../fonts/LINESeedJP_OTF_Bd.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: noto-sans-cjk-jp, sans-serif;
  font-style: normal;
  font-weight: 100;
}
.SearchArea__wrapper {
  background-color: #fff;
  padding: 1.5rem;
  border-radius: 0 0 20px 20px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  position: relative;
  padding-top: 0px;
  margin-right: 10px;
  min-width: 1850px;
  box-sizing: border-box;
}

.SearchArea__wrapper_button {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.SearchArea__title {
  display: flex;
  align-items: center;
}

.SearchArea__title_logo {
  margin-right: 0.3125rem;
  fill: #348be5;
}

.SearchArea__title_text {
  font-family: "LINE Seed JP", sans-serif;
  font-size: 1.125rem;
}

.SearchArea__items {
  display: flex;
}

.SearchArea__group {
  display: flex;
  margin-right: 20px;
}
.SearchArea__group._notice {
  margin-right: 110px;
}
.SearchArea__group._userList {
  margin-right: 52px;
}
.SearchArea__group._RoleAndStatus {
  width: 500px;
}

.SearchArea__group_title {
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 126px;
  box-sizing: border-box;
}
.SearchArea__group_title._twoline {
  height: 88px;
  box-sizing: border-box;
}

.SearchArea__group_input {
  padding: 16px 10px;
  display: flex;
  flex-direction: column;
  gap: 26px;
}
.SearchArea__group_input._noticeList {
  gap: 12px;
}
.SearchArea__group_input._userList {
  gap: 12px;
  padding: 10px 10px;
}
.SearchArea__group_input._userList_twoline {
  gap: 12px;
}
.SearchArea__group_input._twoline {
  gap: 12px;
}

.SearchArea__titles_detail {
  width: 70px;
  height: 28px;
  display: block;
  font-size: 0.875rem;
}
.SearchArea__titles_detail._longtitle {
  width: 120px;
}

.SearchArea__input_checkbox {
  margin-top: 0.15rem;
  font-size: 0.875rem;
}

.SearchArea__input_checkbox_after {
  margin-left: 32px;
}

.SearchArea__btn_under {
  position: absolute;
  right: 24px;
  bottom: 20px;
}

.SearchArea__btn_clear {
  font-size: 0.9375rem;
}

.SearchArea__btn_search {
  margin-left: 16px;
}

/* 基本スタイル */
/* リセット・基本 */
/* サイドメニュー */
.SideMenu {
  position: fixed;
  top: 0;
  left: 0;
  width: 39px;
  height: 100vh;
  background-color: #f6f6f6;
  color: #101010;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 80px 10px 0;
  z-index: 1000;
  transform-origin: left center;
  transform: none;
  transition: width 0.3s ease, transform 0.3s ease;
}

.SideMenu.expanded {
  width: 200px;
  height: 100%;
  align-items: flex-start;
  padding-top: 80px;
  padding-left: 10px;
  padding-right: 20px;
  border-radius: 0 20px 20px 0;
  box-shadow: 3px 0px 6px rgba(0, 0, 0, 0.16);
  transform: none;
}

.SideMenu.expanded + .OutsideSideMenu .HomeNotice__wrapper {
  min-width: 800px;
}
.SideMenu.expanded + .OutsideSideMenu .List__wrapper {
  max-width: 1600px;
}

.SideMenu__toggleBtn {
  cursor: pointer;
  transition: transform 0.2s ease;
  width: 20px;
  height: 20px;
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #348be5;
  border-radius: 50%;
  box-sizing: border-box;
  transition: all 0.3s ease;
}

.SideMenu__toggleBtn:hover {
  background-color: #ff8000;
}

.SideMenu.expanded .SideMenu__toggleBtn:hover .SideMenu__text {
  color: #ff8000;
}

.SideMenu.expanded .SideMenu__toggleBtn {
  background-color: transparent;
}

/* 閉じる← テキストは最初非表示 */
.SideMenu__text {
  display: none;
  font-size: 14px;
  color: white;
  margin-left: 6px;
}

/* expanded のとき：閉じる← 表示、アイコン非表示 */
.SideMenu.expanded .SideMenu__text {
  display: block;
  min-width: 60px;
  margin: 0 0 0 -90px;
  font-size: 0.75rem;
  color: #348be5;
}

/* メニューリスト */
.SideMenu__items {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.SideMenu__items li {
  width: 100%;
  padding: 15px 0;
  text-align: center;
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: padding-left 0.3s ease;
}

.SideMenu__icon {
  fill: #348be5;
  width: 24px;
  height: 24px;
  will-change: transform, opacity;
  display: inline-block;
}
.SideMenu__icon._staffsearch {
  position: relative;
  left: -2px;
}
.SideMenu__icon._projectsearch {
  position: relative;
  left: -2px;
}

.SideMenu__icon:hover {
  fill: #ff8000 !important;
}

/* ホバーでメニューをオレンジに */
.SideMenu.expanded .SideMenu__items a:hover .SideMenu__icon {
  fill: #ff8000;
}
.SideMenu.expanded .SideMenu__items a:hover .SideMenu__label {
  color: #ff8000;
}

/* 吹き出し基本設定 */
.SideMenu.collapsed .SideMenu__items li::after {
  content: attr(data-label);
  position: absolute;
  left: 60px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #348be5;
  color: #fff;
  padding: 5px 10px;
  white-space: nowrap;
  border-radius: 5px;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
  z-index: 999;
}

/* ホバーで吹き出し表示 */
.SideMenu.collapsed .SideMenu__items li:hover::after {
  opacity: 1;
}

/* 展開時は吹き出し非表示 */
.SideMenu.expanded .SideMenu__items li::after {
  display: none;
}

/* 展開時：アイコンを右へ移動 */
.SideMenu.expanded .SideMenu__items li {
  justify-content: flex-start;
  padding-left: 20px;
}

.SideMenu.collapsed .SideMenu__items li::before {
  content: "";
  position: absolute;
  left: 49px; /* 吹き出しの左端より少し内側 */
  top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent; /* 三角形の土台 */
  border-right-color: #348be5; /* 吹き出しの背景色に合わせる */
  z-index: 1000;
  opacity: 0; /* 最初は透明に */
  transition: opacity 0.2s ease;
  pointer-events: none;
}

/* ホバーで吹き出し表示時に矢印も表示 */
.SideMenu.collapsed .SideMenu__items li:hover::before {
  opacity: 1;
}

/* 展開時はラベル表示＆配置調整 */
.SideMenu.expanded .SideMenu__items li {
  text-align: left;
  padding-left: 20px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

.SideMenu__sets {
  display: flex;
  align-items: center;
}
.SideMenu__sets._patition {
  border-bottom: solid 1px rgba(0, 0, 0, 0.1);
}

.SideMenu.expanded .SideMenu__sets {
  display: flex;
  align-items: center;
}
.SideMenu.expanded .SideMenu__sets._patition {
  border-bottom: solid 1px rgba(0, 0, 0, 0.1);
}

.SideMenu.expanded .SideMenu__items li img {
  margin-right: 10px;
}

.SideMenu__label {
  display: none;
  font-size: 0.875rem;
  color: #101010;
  white-space: nowrap;
  min-width: 120px;
  margin-left: 14px;
  /* 文字アニメーション追加 */
  opacity: 0;
  transform: translateX(-10px);
  transition: opacity 0.2s ease 0.25s, transform 0.2s ease 0.25s;
}

.SideMenu.expanded .SideMenu__label {
  display: inline-block;
  opacity: 1;
  transform: translateX(0);
}

.SideMenu__burger {
  width: 0.75rem;
  height: 2px;
  background: #fff;
  display: block;
  transition: all 0.3s ease;
  position: absolute;
  border-radius: 10px;
}

.button:hover {
  background: darkblue;
}

.SideMenu__burger._top {
  left: 4px;
  top: 4px;
}

.SideMenu__burger._center {
  left: 4px;
  top: 9px;
}

.SideMenu__burger._bottom {
  left: 4px;
  top: 14px;
}

.SideMenu__toggleBtn:hover .SideMenu__burger._top {
  transform: rotate(45deg);
  transform-origin: left center;
  left: 10px;
  top: 4px;
  width: 0.35rem;
}

.SideMenu__toggleBtn:hover .SideMenu__burger._center {
  left: 4px;
  top: 9px;
  width: 0.75rem;
}

.SideMenu__toggleBtn:hover .SideMenu__burger._bottom {
  transform: rotate(-45deg);
  transform-origin: left center;
  left: 10px;
  top: 14px;
  width: 0.35rem;
}

/* expand */
.SideMenu.expanded {
  /* アイコンのスライド（背景と同時） */
}
.SideMenu.expanded .SideMenuBtn {
  margin-top: 50px;
}
.SideMenu.expanded .SideMenuBtn__contents {
  display: flex;
  margin-left: auto;
  align-items: center;
  margin-bottom: 20px;
}
.SideMenu.expanded .SideMenu__toggleBtn {
  content: "";
  width: 20px;
  height: 20px;
  margin-bottom: 0;
  text-align: end;
  background-color: #348be5;
  border-radius: 50%;
  z-index: 0;
  transition: padding-left 0.3s ease;
}
.SideMenu.expanded .SideMenu__toggleBtn + .SideMenu__toggleBtn {
  margin-top: 1rem;
}
.SideMenu.expanded .SideMenu__toggleBtn:hover {
  background: #ff8000;
}
.SideMenu.expanded .SideMenu__toggleBtn:hover .SideMenu__burger._top {
  transform: rotate(-45deg);
  transform-origin: right center;
  left: 4px;
  top: 4px;
  width: 0.35rem;
}
.SideMenu.expanded .SideMenu__toggleBtn:hover .SideMenu__burger._center {
  left: 5px;
  top: 9px;
  width: 0.75rem;
}
.SideMenu.expanded .SideMenu__toggleBtn:hover .SideMenu__burger._bottom {
  transform: rotate(45deg);
  transform-origin: right center;
  left: 4px;
  top: 14px;
  width: 0.35rem;
}
.SideMenu.expanded .SideMenu.expanded .SideMenu__items li {
  justify-content: flex-start;
  padding-left: 20px;
  transition: padding-left 0.3s ease;
}

/* アイコンのスライド（背景と同時） */
.SideMenu.expanded .SideMenu__items a {
  display: flex;
  align-items: center;
  text-decoration: none; /* 下線を消す */
}

.SideMenu.collapsed .SideMenuBtn__contents {
  margin-bottom: 10px;
}

.OutsideSideMenu {
  margin-left: 54px;
  display: flow-root;
}

.SideMenu.expanded ~ .OutsideSideMenu {
  margin-left: 244px;
  max-width: calc(100% - 240px);
}

/* モーダル全体 */
.Modal__wrapper {
  display: none; /* 最初は非表示 */
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 半透明背景 */
}

.Modal__wrapper.is-active {
  display: block; /* モーダル表示 */
}

/* モーダルの中身 */
.Modal__flame {
  background: #fff;
  padding: 20px 30px;
  border-radius: 8px;
  width: 100%;
  max-width: 90%;
  margin: 100px auto;
  position: relative;
  box-sizing: border-box;
  /* 💡 追加: 内部をFlexコンテナにし、中身の領域分割を制御する */
  display: flex; /* これを追加 */
  flex-direction: column; /* 縦方向に並べる */
  /* 💡 追加: 小さな画面で画面の高さを超えないようにする */
}
.Modal__flame._result {
  padding: 0;
}
.Modal__flame._result._xl {
  width: 1200px;
}
.Modal__flame._lg {
  width: 800px;
}
.Modal__flame._md {
  width: 632px;
}
@media (max-width: 1200px) {
  .Modal__flame {
    /* _xl の幅より小さければ適用 */
    max-width: calc(100% - 40px); /* 画面幅から余白を引いた最大幅 */
    max-height: calc(100vh - 40px); /* ビューポートの高さから上下の余白(40px)を引いた最大高さを設定 */
    margin: 20px auto; /* 上下のmarginを小さくする */
  }
}

/* 閉じるボタン */
.Modal__closeBtn {
  position: absolute;
  right: 10px;
  top: 10px;
  font-size: 24px;
  cursor: pointer;
}

.Modal__title {
  font-family: "LINE Seed JP", sans-serif;
  margin-bottom: 17px;
  width: 50%;
}

.Modal__contents {
  overflow-x: scroll;
}

.Modal__contents_title {
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 136px;
}

.Modal__contents_title_detail {
  width: 100px;
  height: 28px;
  display: block;
  font-size: 0.875rem;
}

.Modal__contents_input {
  padding: 12px 0px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.Modal__btn {
  text-align: end;
  margin: 38px 0 10px;
}

.Modal__btn_right {
  text-align: end;
}
.Modal__btn_right._Modal__result_top {
  position: absolute;
  right: 25px;
  bottom: 25px;
}
@media screen and (max-width: 900px) {
  .Modal__btn_right._Modal__result_top {
    bottom: 0;
  }
}

.Dialog__btn {
  text-align: end;
  margin: 38px 0 10px;
  display: flex;
  justify-content: flex-end;
  gap: 20px;
}

.Error__text {
  color: #ff4343;
  background-color: #ffebeb;
  padding: 10px;
  border-radius: 10px;
  margin: 0;
}

.Error__flame {
  background: #fff;
  padding: 4px;
  border-radius: 8px;
  width: 100%;
  max-width: 30%;
  margin: 100px auto;
  position: relative;
}

.Modal__table {
  width: 100%;
  margin-bottom: 20px;
}

.Modal__table_head {
  background-color: #eaf6fc;
}
.Modal__table_head._searchConditionsList {
  position: static; /* ← fixedを打ち消す */
}

.Modal__result_top {
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  padding: 20px;
  position: relative;
}

.Modal__result_top_title {
  display: flex;
  align-items: center;
  font-size: 1.125rem;
  margin-bottom: 12px;
}

.Modal__result_under {
  padding: 20px;
  /* 💡 追加: Flexコンテナの残りの高さを占有し、コンテンツがはみ出したらスクロールする */
  flex-grow: 1; /* 残りのスペースを全て占有 */
  overflow-y: auto; /* 縦スクロールを有効にする */
  /* 💡 重要: iOSのバグ回避のため、最小高さを0に設定 */
  min-height: 0;
}

.Modal__table_title_flex {
  display: flex;
  justify-content: space-between;
}

.Modal__table_flex {
  display: flex;
  align-items: center;
  gap: 15px;
}

.Modal__table_result {
  width: 100%;
  height: 456px;
  overflow-y: scroll;
  background-color: #f6f6f6;
  /* スクロールバーを非表示 */
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE, Edge(旧) */
}

.Modal__table_result::-webkit-scrollbar {
  display: none; /* Chrome, Safari */
}

.Modal__table_background {
  background-color: #fff;
  padding-top: 32px;
  display: block;
}

.Modal__table__result_head {
  width: 260px;
  height: 32px;
  border-spacing: 0;
  box-sizing: border-box;
}

.Modal__table {
  border-collapse: collapse; /* ← これが必須！ */
}

.Modal__table__result_row {
  border-bottom: 1px dotted rgba(112, 112, 112, 0.5);
}

.Modal__table__result_row:hover {
  background-color: #dde9fc !important;
  cursor: pointer;
}

tbody > tr > *.Modal__table__result_body {
  padding: 0;
  height: 37px;
  padding-left: 10px;
}

.Modal__table__result_body {
  width: 260px;
  padding-left: 10px;
  box-sizing: border-box;
  border-spacing: 0;
}

.Modal__InputSearchResults_icon {
  margin-right: 0.3125rem;
}

.long_text {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  max-width: 260px;
}

.Modal__list_result {
  height: 300px;
  overflow-x: scroll;
  width: -webkit-fill-available;
  width: -moz-available;
  width: stretch;
}

.Modal__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
  height: 100%;
}

.Modal__list_item {
  border-right: 1px dashed rgba(112, 112, 112, 0.5);
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
  padding: 0.5rem 1rem;
  font-size: 14px;
  width: 20%;
  cursor: pointer;
}
.Modal__list_item._active {
  background: #dde9fc;
}

.select__wrapper._width_xxs {
  width: 80px;
}

.select__wrapper._width_xs {
  width: 120px;
}

.Modal__table_result._company {
  height: 350px;
}

.Modal__table_flex {
  display: flex;
}

.Modal__table_company {
  border-collapse: collapse;
  width: 100%;
}

.Modal__table_company_thead {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: #eaf6fc;
  height: 32px;
  font-size: 0.875rem;
  white-space: nowrap;
}

.Modal__table_company_th {
  text-align: left;
  padding: 0 0.5rem;
}

.Modal__table_company_row {
  background: #fff;
}

.Modal__table_company_row._active {
  background: #dde9fc;
}

.Modal__table_company_td {
  border-right: none;
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
}

.Modal__table_company_tbody::after {
  content: "";
  height: 1rem;
  width: 100%;
  display: block;
}

.select__wrapper._width_xxs {
  width: 80px;
}

.select__wrapper._width_xs {
  width: 120px;
}

.Modal__table_result._company {
  height: 350px;
}

.Modal__table_flex {
  display: flex;
}

.Modal__table_company {
  border-collapse: collapse;
  width: 100%;
}

.Modal__table_company_thead {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: #eaf6fc;
  height: 32px;
  font-size: 0.875rem;
  white-space: nowrap;
}

.Modal__table_company_th {
  text-align: left;
  padding: 0 0.5rem;
}

.Modal__table_company_row {
  background: #fff;
}

.Modal__table_company_row._active {
  background: #dde9fc;
}

.Modal__table_company_td {
  border-right: none;
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
}

.Modal__table_company_tbody::after {
  content: "";
  height: 1rem;
  width: 100%;
  display: block;
}

:root {
  --companyWidth: 507px;
}

.select__wrapper._width_xxs {
  width: 80px;
}

.select__wrapper._width_xs {
  width: 120px;
}

.Modal__table_result._company {
  height: 350px;
  scrollbar-width: thin;
}

.Modal__table_flex {
  display: grid;
  grid-template-columns: var(--companyWidth) auto var(--companyWidth);
}

.Modal__table_company {
  border-collapse: collapse;
}

.Modal__table_company_thead {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: #eaf6fc;
  height: 32px;
  font-size: 0.875rem;
  white-space: nowrap;
}

.Modal__table_company_th {
  text-align: left;
  padding: 0 0.5rem;
}

.Modal__table_company_td {
  border-right: none;
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
}

.Modal__table_company_tbody::after {
  content: "";
  height: 1rem;
  width: 100%;
  display: block;
}

.Modal__selectbox_flex {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}

.Modal__selectbox {
  border: dashed 1px rgba(51, 51, 51, 0.5);
  width: 500px;
  height: 300px;
}
.Modal__selectbox option {
  font-size: 16px;
}

.Modal__selectbox_title {
  background-color: #eaf6fc;
  height: 32px;
  padding-left: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
}

.Modal__selectbox_option {
  height: 37px;
  display: flex;
  align-items: center;
  border-bottom: dashed 1px rgba(51, 51, 51, 0.5);
}

.Modal__selectbox {
  background-color: #eeeeee;
}
.Modal__selectbox option:nth-of-type(odd) {
  background-color: #fff;
  padding-left: 10px;
}
.Modal__selectbox option:nth-of-type(even) {
  background-color: #dde9fc;
  padding-left: 10px;
}

.Modal__table_row:nth-child(odd) {
  background-color: #fff;
}

.Modal__table_row:nth-child(even) {
  background-color: #f4f8f9;
}

.Modal__table_head_title {
  font-weight: bold;
  font-size: 14px;
  height: 50px;
}

.Notice__management_wrapper {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 20px;
  margin-right: 10px;
}

.Notice__management_category {
  display: inline-flex;
  align-items: center; /* 縦中央 */
  justify-content: center; /* 横中央 */
  text-align: center;
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  width: 100px;
  height: 24px;
  border-radius: 100px;
}
.Notice__management_category._important {
  background-color: #ff9d2e;
}
.Notice__management_category._maintenance {
  background-color: #5fd467;
}
.Notice__management_category._release {
  background-color: #55b0dd;
}

.Notice__wrapper {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 30px;
  margin-right: 32px;
  padding: 20px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  min-width: 1317px;
}

.Notice__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 20px;
}

.Notice__title {
  font-family: "LINE Seed JP", sans-serif;
  font-size: 1.125rem;
  margin-left: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 0 20px;
}

.Notice__category {
  display: inline-flex;
  align-items: center; /* 縦中央 */
  justify-content: center; /* 横中央 */
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  width: 100px;
  height: 24px;
  border-radius: 100px;
  margin: 10 20px;
}
.Notice__category._important {
  background-color: #ff9d2e;
}
.Notice__category._maintenance {
  background-color: #5fd467;
}
.Notice__category._release {
  background-color: #55b0dd;
}
.Notice__category._modalNoticeDetail {
  margin: 0px;
}

.Notice__details {
  display: flex;
  align-items: center;
  gap: 30px;
  border-bottom: dotted 1px rgba(112, 112, 112, 0.5);
  padding: 0 20px;
  height: 44px;
  box-sizing: border-box;
}

.Notice__details:hover {
  background-color: #fffaf0;
}

.Notice__date {
  display: flex;
  max-width: 140px;
  gap: 20px;
}

.Notice__date_table {
  display: flex;
  gap: 10px;
  max-width: 140px;
}

.Notice__date_time {
  min-width: 40px;
  margin: 0 auto;
}

.Notice__heading {
  margin: 10px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 1000px;
  font-weight: normal;
  font-size: 16px;
}

.Notice__heading:hover {
  color: #348be5;
  cursor: pointer;
}

.Home__contents {
  display: flex;
  margin-right: 32px;
  gap: 24px;
}

.HomeNotice__wrapper {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 30px;
  max-width: 45%;
  min-width: 906px;
  padding: 20px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  box-sizing: border-box;
  height: 100%;
}

.HomeNotice__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 20px;
}

.HomeNotice__title {
  font-family: "LINE Seed JP", sans-serif;
  font-size: 1.125rem;
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 0 20px;
}

.HomeNotice__title_icon {
  margin-right: 0.3125rem;
  fill: #348be5;
}

.HomeNotice__category {
  display: inline-flex;
  align-items: center; /* 縦中央 */
  justify-content: center; /* 横中央 */
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  min-width: 100px;
  height: 24px;
  border-radius: 100px;
  margin-left: 10px;
}
.HomeNotice__category._important {
  background-color: #ff9d2e;
}
.HomeNotice__category._maintenance {
  background-color: #5fd467;
}
.HomeNotice__category._release {
  background-color: #55b0dd;
}
.HomeNotice__category._modalNoticeDetail {
  margin: 0px;
}

.HomeNotice__details {
  display: flex;
  align-items: center;
  gap: 30px;
  border-bottom: dotted 1px #707070;
  padding: 0 20px;
  height: 44px;
  cursor: pointer;
}

.HomeNotice__details:hover {
  background-color: #fffaf0;
}

.HomeNotice__date {
  font-size: 16px;
}

.HomeNotice__time {
  font-size: 16px;
  width: 30px;
  text-align: right;
  flex-shrink: 0;
}

.HomeNotice__heading {
  font-size: 16px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 1000px;
  font-weight: normal;
}

.HomeNotice__heading:hover {
  color: #348be5;
}

.accordion__wrapper {
  margin-right: 32px;
  padding: 20px 35px 20px 25px;
  background-color: #fff;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  border-radius: 20px;
  box-sizing: border-box;
  min-width: 1850px;
}
.accordion__wrapper._MapPages {
  margin-right: 0;
  min-width: 620px;
  box-shadow: none;
  padding-right: 16px;
}

.accordion__alwaysVisible {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0px;
  margin: 22px 0;
}

.accordion__btn_group {
  display: flex;
  gap: 24px;
  align-items: center;
}

.accordion__toggleBtn {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  color: #3491e5;
  background-color: #fff;
  position: relative;
  min-width: 60px;
}
.accordion__toggleBtn::after {
  content: "";
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 6px;
  height: 6px;
  border-right: 3px solid #3491e5;
  border-bottom: 3px solid #3491e5;
  pointer-events: none;
}
.accordion__toggleBtn .accordion__toggleText {
  font-size: 16px;
}
.accordion__toggleBtn.open::after {
  transform: translateY(-50%) rotate(-135deg);
}

.tab__contents {
  display: flex;
  flex-wrap: wrap;
  margin-right: 32px;
  position: relative;
}
.tab__contents._MapPages {
  margin-right: 0px;
}
.tab__contents._SendPages {
  width: 740px;
}

.tab__contents.is-hidden {
  display: none;
}

.accordion____searchConditions_text {
  display: block;
}

.accordion__searchConditions_btn {
  display: flex;
  gap: 10px;
  font: 0.8125rem;
}

.accordion__searchConditions_title {
  font-weight: bold;
  color: #3491e5;
  margin-right: 10px;
}

.tab__title {
  flex: 1 1;
  order: -1;
  max-width: 310px;
  height: 36px;
  border-radius: 20px 20px 0 0;
  background-color: #d4d4d4;
  color: #666666;
  font-size: 1.125rem;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
  position: relative;
}

.tab__title:hover {
  opacity: 0.8;
}

.tab__title_input {
  display: none;
}

.tab__title_text {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-margin-before: 1em;
  margin-block-start: 1em;
  -webkit-margin-after: 1em;
  margin-block-end: 1em;
}

.tab__items {
  display: none;
  width: 100%;
  padding: 1.5em 1em 0;
  background-color: #fff;
  border-top: solid 6px #3491e5;
}
.tab__items._SendPages {
  max-height: 630px;
  overflow-y: scroll;
}

.tab__title:has(:checked) {
  background-color: #3491e5;
  color: #fff;
}

.tab__title:has(:checked) + .tab__items {
  display: block;
}

.tabBtn {
  display: flex;
  gap: 16px;
  justify-content: flex-end;
}

.Tab__selectbox {
  border: solid 1px rgba(51, 51, 51, 0.5);
  width: 200px;
  height: 90px;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
}
.Tab__selectbox option {
  font-size: 16px;
}

.Tab__selectbox_option {
  height: 30px;
  display: flex;
  align-items: center;
  border-bottom: dashed 1px rgba(51, 51, 51, 0.5);
}

.Tab__selectbox {
  background-color: #eeeeee;
}
.Tab__selectbox option:nth-of-type(odd) {
  background-color: #fff;
  padding-left: 10px;
}
.Tab__selectbox option:nth-of-type(even) {
  background-color: #dde9fc;
  padding-left: 10px;
}

.TableList__label {
  color: #fff;
  background-color: #ff8000;
  padding: 0 10px;
  border-radius: 2px;
  margin-left: 11px;
}

.caseSearch__filter_wrapper {
  display: none; /* 初期は閉じる */
}

.caseSearch__filter_wrapper.is-active {
  display: block; /* ボタン押下で表示 */
}

.caseSearch__filterBtn {
  position: fixed;
  bottom: 130px;
  right: 30px;
  z-index: 3000;
}

.caseSearch__filter_wrapper {
  position: fixed;
  bottom: 120px;
  right: -2px;
  border-radius: 16px 0 0 16px;
  background-image: linear-gradient(90deg, #ebf7fc, #deebf9);
  border: solid 1px rgba(52, 145, 229, 0.5);
  width: 460px;
}

.caseSearch__filter_contents {
  padding: 20px 20px 24px 17px;
}

.caseSearch__filter_element {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.caseSearch__filter_title {
  color: #3491e5;
}

.caseSearch__filter_input,
.caseSearch__filter_select {
  box-sizing: border-box;
}
.caseSearch__filter_input._lg,
.caseSearch__filter_select._lg {
  width: 270px;
}
.caseSearch__filter_input._md,
.caseSearch__filter_select._md {
  width: 185px;
}
.caseSearch__filter_input._sm,
.caseSearch__filter_select._sm {
  width: 137px;
}
.caseSearch__filter_input._xs,
.caseSearch__filter_select._xs {
  width: 74px;
}

.caseSearch__filter_radioGender {
  display: flex;
  gap: 20px;
}

.caseSearch__filter_selectSort {
  display: flex;
  gap: 8px;
  position: relative;
  z-index: 4000;
}

.caseSearch__filter_contents_details {
  display: grid;
  grid-template-columns: 160px 1fr;
}

/* テキスト部分は非表示 */
.caseSearch__filter_input::-webkit-datetime-edit,
.caseSearch__filter_input::-webkit-datetime-edit-text,
.caseSearch__filter_input::-webkit-datetime-edit-year-field,
.caseSearch__filter_input::-webkit-datetime-edit-month-field,
.caseSearch__filter_input::-webkit-datetime-edit-day-field {
  display: none;
}

.caseSearch__filter_input._date {
  position: relative;
}

/* カレンダーアイコン */
.caseSearch__filter_input._date::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0;
  position: absolute; /* inputの中で右端に配置 */
  right: 8px;
  width: 20px; /* アイコンと同じくらいの範囲 */
  height: 100%;
}

.inputDate__wrapper {
  position: relative;
  display: inline-block;
}

.inputDate__icon {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  pointer-events: none; /* 入力操作に干渉しない */
}
.inputDate__icon._filterBtn {
  right: 140px;
}

.caseSearch__filter_underText {
  color: #1b5f97;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 25px;
}

.caseSearch__filter_wrapper {
  display: none;
}

.caseSearch__filter_wrapper.is-active {
  display: block;
}

/* 外側のボタン（初期表示） */
.js-filter-trigger {
  position: fixed;
  bottom: 130px;
  right: 30px;
  z-index: 3000;
}

/* 外側ボタンを隠すためのユーティリティ */
.js-filter-trigger.is-hidden {
  display: none;
}

/* パネル（初期は閉） */
.caseSearch__filter_wrapper {
  display: none;
  position: fixed;
  bottom: 120px;
  right: -2px;
  border-radius: 16px 0 0 16px;
  background-image: linear-gradient(90deg, #ebf7fc, #deebf9);
  border: solid 1px rgba(52, 145, 229, 0.5);
  width: 460px;
  z-index: 3500;
}

/* 開いたら表示 */
.caseSearch__filter_wrapper.is-active {
  display: block;
  aria-hidden: false;
}

/* パネル内のボタン（最初は非表示） */
.js-filter-panel-btn {
  display: none;
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3600; /* パネル内で最前 */
}
.js-filter-panel-btn button {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* パネルが開いたら内ボタンを表示 */
.caseSearch__filter_wrapper.is-active .js-filter-panel-btn {
  display: inline-block;
}

/* ドロップダウン（選択肢）がパネルやボタンの後ろに隠れないように大きめに */
.select__options {
  z-index: 99999;
  position: absolute;
}

/* もし必要ならパネル内コンテンツのパディングを調整 */
.caseSearch__filter_contents {
  padding: 20px;
}

.btnFilter__image_open {
  position: fixed;
  bottom: 130px;
  right: 30px;
  width: 46px;
  height: 46px;
  box-shadow: 0px 3px 6px rgba(1, 1, 1, 0.25);
  border-radius: 50%;
}

.dt-search {
  display: none;
}

.Details__title_icon {
  fill: #348be5;
}

.Details__bold {
  color: #3495e5;
  font-weight: bold;
}

.Details__bold_red {
  color: #ee402c;
  font-weight: bold;
}

.Details__label_red {
  background-color: #ffe8e6;
  color: #ee402c;
  font-weight: bold;
  font-size: 0.75rem;
  padding: 0 10px;
}

.Details__point_red {
  color: #ee402c;
}

.Details__point_blue {
  color: #5c83a3;
}

.Details__title {
  margin: 14px 0;
}

.Details__label_C2 {
  color: #fff;
  background-color: #c53a3f;
  padding: 3px 33px;
  margin-left: 10px;
  border-radius: 2px;
}

.Details__label_BMW {
  color: #fff;
  background-color: #44af35;
  padding: 3px 33px;
  margin-left: 10px;
  border-radius: 2px;
}

.Details__title {
  margin: 13px 0 !important;
}

.Details__RecruitmentTime {
  display: grid;
  gap: 10px;
}

.Details__text {
  margin: 0;
  font-size: 0.875rem;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  padding-bottom: 10px;
}

.Details__checkbox {
  margin: 0;
  font-size: 0.875rem;
}

.Details__text_half {
  width: 163px;
  display: flex;
  gap: 22px;
}

.Details__text_row {
  display: flex;
  gap: 24px;
}

.Detail__text_center {
  margin: 0 auto;
  max-width: 460px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.Detail__text_tel {
  width: 61px;
}

.Detail__text_period {
  width: 61px;
}

.Detail__attachment {
  background-color: #eef3fd;
  font-size: 18px;
  padding: 12px 10px;
  width: 579px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.Details__closeBtn {
  margin-top: 20px;
}

.Details__table_icon {
  margin-right: 9px;
}

.Details__link {
  display: flex;
  align-items: center;
  gap: 20px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-style: normal;
  position: fixed;
  right: 80px;
  background-color: #fff;
  padding: 10px;
  z-index: 3000;
}
@media screen and (max-width: 900px) {
  .Details__link {
    flex-direction: column;
    top: 160px;
    right: 80px;
  }
}

.Details__link_word {
  color: #3491e5;
  text-decoration: underline;
  -webkit-text-decoration-color: #3491e5;
  text-decoration-color: #3491e5; /* 下線の色を変える */
  text-underline-offset: 3px; /* テキストと下線の間隔 */
  cursor: pointer;
  font-size: 14px;
}

.Details__majorHeading {
  position: relative;
  left: 10px;
  margin: 20px 0 5px;
  scroll-margin-top: 80px; /* 固定ヘッダーの高さに合わせる */
  font-weight: bold;
}

@supports (-webkit-touch-callout: none) {
  .Details__link {
    position: static !important;
    height: auto;
    z-index: auto;
  }
}
.List__wrapper {
  background-color: #fff;
  padding: 12px 24px 30px;
  margin-top: 30px;
  margin-right: 32px;
  max-width: 100%;
  border-radius: 20px;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  box-sizing: border-box;
  min-width: 1800px;
}

.List__title_icon {
  fill: #348be5;
}

.List__title_container {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
}

.List__title_ruby {
  font-size: 13px;
}

.List__title {
  font-family: "LINE Seed JP", sans-serif;
  width: 50%;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
  font-size: 16px;
}
.List__title._details {
  width: 100%;
}

.List__contents {
  display: grid;
  grid-template-columns: 140px 1fr;
  position: relative;
  gap: 20px;
  padding: 10px 0;
}
.List__contents._modalNoticeDetail {
  justify-content: start;
  width: 100%;
}
.List__contents._searchStaffandCase {
  gap: 8px;
}

.List__contents::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 140px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.List__contents_title {
  z-index: 1;
}

.List__contents_title {
  padding: 18px 12px;
  z-index: 3;
}
.List__contents_title._lg {
  width: 130px;
  box-sizing: border-box;
}
.List__contents_title._sm {
  width: 111px;
  box-sizing: border-box;
}
.List__contents_title._userNewRegistration {
  gap: 20px;
  box-sizing: border-box;
}

.List__contents_title_detail {
  display: block;
  font-size: 0.875rem;
  z-index: 2;
  padding: 0 10px;
}
.List__contents_title_detail._column_three {
  min-height: 134px;
}
.List__contents_title_detail._Details__underLine {
  position: relative;
}
.List__contents_title_detail._Details__underLine + div {
  padding-bottom: 6px;
}
.List__contents_title_detail._Details__underLine::after {
  content: "";
  height: 1px;
  width: 1200px;
  display: block;
  position: absolute;
  bottom: -1px;
  left: -2px;
  border-bottom: dashed 1px rgba(112, 112, 112, 0.5);
}

.List__contents_input {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 13px;
}
.List__contents_input._modalNoticeDetail {
  padding: 0 12px;
  gap: 0;
}

.List__btn {
  margin-top: 30px;
  display: flex;
  gap: 16px;
  justify-content: space-between;
}
.List__btn._one {
  justify-content: flex-end;
}

.List__btn_three {
  margin-top: 30px;
  display: flex;
  gap: 16px;
  justify-content: space-between;
}

.List__radioBtn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  font-size: 0.875rem;
}

/* ラジオ本体を消す */
.List__radioBtn_choice {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  margin: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #cccccc; /* 縁の色 */
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.16);
  border-radius: 50%; /* 丸にする */
  display: inline-block;
  position: relative;
  cursor: pointer;
  background-color: #fff;
}
.List__radioBtn_choice._after {
  margin-left: 40px;
}

/* 選択されたときの中の丸 */
.List__radioBtn_choice:checked {
  background-color: #3491e5;
  box-shadow: inset 0 0 0 2px #fff; /* 中に白丸を作る */
}

.List__text_caveat {
  color: #ff0000;
  background-color: #eef3fd;
  padding: 3px 13px 8px;
}

.List__fileSelectionBtn {
  color: #3997e7;
  background-color: #dde9fc;
  border-radius: 100px;
  border: solid 1px #3997e7;
  padding: 0px 13px 3px;
}

.inputPassword {
  position: relative;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.inputPassword__icon {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}

.List__btn_two {
  display: flex;
  gap: 16px;
}

.List__contents_inputAfter {
  display: grid;
  margin-left: 13px;
  row-gap: 16px;
  padding: 16px 0px;
}
.List__contents_inputAfter._projectDetails {
  row-gap: 20px;
  padding: 18px 0px;
}

.List__contents_inputAfter_text {
  margin: 0;
  font-size: 0.875rem;
}

.List__contents_text {
  margin: 0;
  font-size: 0.875rem;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.List__contents_text_row {
  display: flex;
  align-items: center;
}
.List__contents_text_row._gap_lg {
  gap: 40px;
}
.List__contents_text_row._gap_sm {
  gap: 12px;
}

.List__contents_inputAfter_link {
  color: #3491e5;
}

.List__contents_projectSearch {
  display: grid;
  grid-template-columns: 140px 1fr;
  position: relative;
  gap: 24px;
  padding: 16px 0;
}

.List__contents_projectSearch::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 140px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 15px 0;
  box-sizing: border-box;
}

.List__contents_MapPages_case {
  display: grid;
  grid-template-columns: 160px 1fr;
  position: relative;
  gap: 8px;
  padding: 16px 0;
  margin-top: 20px;
}

.List__contents_MapPages_case::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 160px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 15px 0;
  box-sizing: border-box;
}

.List__contents_MapPages_staff {
  display: grid;
  grid-template-columns: 200px 1fr;
  position: relative;
  gap: 8px;
  padding: 16px 0;
  margin-top: 20px;
}

.List__contents_MapPages_staff::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 200px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 15px 0;
  box-sizing: border-box;
}

.taglabel {
  color: #fff;
  width: 34px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.taglabel._orange {
  background-color: #ff8000;
}

.List__contents_projectSearch_table {
  display: grid;
  grid-template-columns: 111px 1fr;
  position: relative;
  gap: 5px;
  padding: 10px 0;
}

.List__contents_projectSearch_table::before {
  content: "";
  background-color: #eaf6fc;
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 111px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 15px 0;
  box-sizing: border-box;
}

.List__title_Details {
  font-family: "LINE Seed JP", sans-serif;
  width: 50%;
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-size: 16px;
  padding-top: 6px;
}

.List__contents_Details {
  display: grid;
  grid-template-columns: 320px 1fr;
  position: relative;
  row-gap: 4px;
  padding: 15px 20px;
}
.List__contents_Details._modalNoticeDetail {
  justify-content: start;
  width: 100%;
}

.List__contents_Details::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 320px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
}

.List__contents_modal {
  display: grid;
  grid-template-columns: 90px 1fr;
  position: relative;
  gap: 20px;
  padding: 10px 0;
}
.List__contents_modal._modalNoticeDetail {
  justify-content: start;
  width: 100%;
}

.List__contents_modal::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 90px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.List__contents_title_detail_modal {
  display: flex;
  align-items: center;
  gap: 30px;
  font-size: 0.875rem;
}

.List__title_link {
  display: flex;
}

.ListTable {
  background-color: #fff;
  border-radius: 20px;
  position: relative;
  height: 100%;
  margin: 1.25rem 0;
  margin-right: 10px;
  box-sizing: border-box;
  min-width: 1850px;
  padding: 1.25rem 1.5rem 1.75rem;
}
.ListTable._MapPages {
  min-width: 620px;
  overflow-y: scroll;
  margin: 0;
  padding: 0rem 1.5rem 5rem;
}
.ListTable._MapPages._staff {
  max-height: 520px;
}
.ListTable._MapPages._case {
  max-height: 520px;
}
.ListTable._MapDetails {
  min-width: 400px;
  padding: 0.5rem;
  box-shadow: 0px 3px 6px rgba(51, 51, 51, 0.15);
  margin: 0;
}

.ListTable__top {
  display: flex;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.ListTable__top._MapPages {
  background-color: #fff;
  width: 620px;
  top: 450px;
  margin-left: 1.5rem;
  margin-top: 10px;
}

.ListTable__title {
  font-family: "LINE Seed JP", sans-serif;
  display: flex;
  font-size: 18px;
  gap: 2px;
  align-items: center;
}

.ListTable__title_icon {
  margin-top: 4px;
  fill: #3491e5;
}

.ListTable__body {
  border-spacing: 0;
  width: 100%;
}

.ListTable__row:hover {
  background-color: #fffaf0 !important;
}

.ListTable__caption {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.ListTable__column {
  padding: 0;
  border: none;
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
}
.ListTable__column._heading {
  padding: 0;
}
.ListTable__column._borderRight {
  border-right: 1px dashed rgba(112, 112, 112, 0.5);
}
.ListTable__column._borderLeft {
  border-left: 1px dashed rgba(112, 112, 112, 0.5);
}

.ListTable__header {
  background-color: #eaf6fc;
}

.ListTable__header_text {
  text-align: center;
  padding: 0.75rem 1.25rem;
  width: 25%;
  font-family: "noto-sans-cjk-jp", sans-serif;
}
.ListTable__header_text._MapPages {
  width: 2%;
  padding: 0 0.5rem;
}

.ListTable__item {
  font-size: 0.8125rem;
  padding: 0.75rem;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  min-height: 192px;
  height: 100%;
  position: relative;
  box-sizing: border-box;
}
.ListTable__item._border::before {
  content: "";
  position: absolute;
  top: 0.75rem;
  left: 0;
  width: 1px;
  height: calc(100% - 1.5rem);
  border-left: 1px dashed rgba(112, 112, 112, 0.5);
}
.ListTable__item._MapPages {
  cursor: pointer;
  min-height: 0px;
}
.ListTable__item._MapPages:hover {
  background-color: #fffaf0 !important;
}
.ListTable__item._MapPages.is-active {
  background-color: #fff1d5 !important;
}
.ListTable__item._MapPages.is-active:hover {
  background-color: #fff1d5;
}
.ListTable__item._MapPages_checkbox {
  min-height: 0px;
}

.ListTable .ListTable__item_container {
  position: relative;
  height: 100%;
  flex: 1;
}
.ListTable .ListTable__item_container._table_bg::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 103px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.ListTable .ListTable__item_container._table_bg._max7::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 116px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.ListTable .ListTable__item_container._table_bg._max3::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 62px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.ListTable .ListTable__item_container._table_bg._max5::before {
  content: "";
  background: linear-gradient(180deg, rgb(235, 247, 252), rgb(222, 235, 249));
  border-radius: 8px 0 0 8px;
  display: flex;
  flex-direction: column;
  width: 88px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.ListTable .ListTable__item_wrapper {
  padding: 10px 0;
}
.ListTable .ListTable__item_wrapper._table {
  position: relative;
  display: grid;
  grid-template-columns: 103px 1fr;
  gap: 8px;
}
.ListTable .ListTable__item_wrapper._table._max7 {
  position: relative;
  display: grid;
  grid-template-columns: 116px 1fr;
  gap: 8px;
}
.ListTable .ListTable__item_wrapper._table._max3 {
  position: relative;
  display: grid;
  grid-template-columns: 62px 1fr;
  gap: 8px;
}
.ListTable .ListTable__item_wrapper._table._max5 {
  position: relative;
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 8px;
}
.ListTable .ListTable__title_container {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
}
.ListTable .ListTable__title_ruby {
  font-size: 13px;
}
.ListTable .ListTable__title {
  font-family: "LINE Seed JP", sans-serif;
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 10px 0 0;
  font-size: 16px;
  white-space: normal; /* 折り返しを許可 */
  word-wrap: break-word; /* 単語が長い場合も強制的に折り返す */
  overflow-wrap: break-word; /* こちらも推奨（新しい書き方） */
}
.ListTable .ListTable__title_status {
  text-align: right;
}
.ListTable .ListTable__tag {
  font-size: 11px;
  border-radius: 4px;
  padding: 0 7px;
  color: #fff;
}
.ListTable .ListTable__tag._orange {
  background-color: #ff8000;
}
.ListTable .ListTable__title_profile {
  display: flex;
  gap: 12px;
  font-size: 13px;
}
.ListTable .ListTable__contents_title_detail {
  display: block;
  font-size: 0.875rem;
  z-index: 2;
  padding: 0 10px;
}
.ListTable .ListTable__contents_title_detail._column_three {
  min-height: 134px;
}
.ListTable .ListTable__contents_text {
  margin: 0;
  font-size: 0.875rem;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ListTable .ListTable__contents_text_row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  white-space: normal;
}
.ListTable .ListTable__contents_text_row._gap_lg {
  -moz-column-gap: 40px;
  column-gap: 40px;
  row-gap: 12px;
}
.ListTable .ListTable__contents_text_row._gap_sm {
  -moz-column-gap: 12px;
  column-gap: 12px;
  row-gap: 12px;
}
.ListTable .ListTable__contents_text_row._MapDetails {
  margin-top: 10px;
}

.ListTable__btn {
  position: absolute;
  bottom: 28px;
  right: 20px;
}
.ListTable__btn._twoBtn {
  position: absolute;
  display: flex;
  gap: 80px;
  max-width: 160px;
  right: 0px;
  bottom: -16px;
}
.ListTable__btn._twoBtn_same {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 160px;
  right: 20px;
  bottom: 20px;
}
.ListTable__btn._twoBtn_same a {
  text-decoration: none;
}

.ListTable__btn_front {
  background-color: #fff;
  width: 628px;
  height: 60px;
  position: absolute;
  z-index: 3;
}
.ListTable__btn_front._staff {
  top: 860px;
}
.ListTable__btn_front._case {
  top: 860px;
}

.ListTable__btn_front_map {
  position: absolute;
  right: 0px;
  top: 10px;
}

.MasterManagement__wrapper {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 20px;
  margin-right: 10px;
}

.MasterManagement__category {
  display: inline-flex;
  align-items: center; /* 縦中央 */
  justify-content: center; /* 横中央 */
  text-align: center;
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  width: 100px;
  height: 24px;
  border-radius: 100px;
}
.MasterManagement__category._mail {
  background-color: #f174d4;
}
.MasterManagement__category._SMS {
  background-color: #3ccba0;
}

.masterManagement__heading {
  margin: 10px 0;
  max-width: 1000px;
  font-weight: normal;
  font-size: 16px;
}

.masterManagement__heading:hover {
  color: #348be5;
  cursor: pointer;
}

.SendPages__contents {
  display: flex;
  align-items: start;
  gap: 80px;
}

.SendPages__contents_right_table {
  width: 740px;
}

.SendPages__table_result {
  border-collapse: collapse;
  width: 100%;
}

.SendPages__table_result_thead {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: #eaf6fc;
  height: 32px;
  font-size: 0.875rem;
  white-space: nowrap;
}

.SendPages__table_result_th {
  text-align: left;
  padding: 0 0.5rem;
}

.SendPages__table_result_row {
  background: #fff;
}

.SendPages__table_result_row._active {
  background: #dde9fc;
}

.SendPages__table_result_td {
  border-right: none;
  border-bottom: 1px dashed rgba(112, 112, 112, 0.5);
  border-left: 1px dashed rgba(112, 112, 112, 0.5);
}

.SendPages__table_result_tbody::after {
  content: "";
  height: 1rem;
  width: 100%;
  display: block;
}

.SendPages__table_title_flex {
  display: flex;
  justify-content: space-between;
}

.SendPagesList_checkbox {
  position: absolute;
  top: 50%;
  left: 45%;
  transform: translate(-50%, 0%);
}

.SendPages__confirmButton {
  text-align: end;
}

.page-description h1 {
  margin: 0 0 8px;
  font-size: 17px;
}

.calendar-area {
  min-height: 500px;
}

.schedule h3 {
  margin-top: 0;
  font-size: 13px;
}

.schedule ul {
  margin: 0;
  padding-left: 16px;
}

.schedule li {
  margin-bottom: 8px;
}

button {
  padding: 4px 10px;
  cursor: pointer;
}

.datatable-pager {
  display: flex;
  align-items: center;
  justify-content: right;
  gap: 8px;
}

.ShiftMatching__contents_calendar_title {
  display: flex;
  justify-content: space-between;
}

.ShiftMatching__contents_calendar_title_details {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
}

.ShiftMatching__contents_calendar_title_details_pager {
  display: flex;
}

.paginate_button._next._shiftMatching {
  margin-left: 0;
}

.datatable__header {
  z-index: 50;
}

.table__shiftMatching_toptitle {
  font-family: "LINE Seed JP", sans-serif;
  width: 50%;
  text-align: start;
  margin-bottom: 14px;
}

.ShiftMatching__wrapper {
  background-color: #fff;
  border-radius: 20px;
  position: relative;
  height: 100%;
  margin: 20px 0;
  margin-right: 10px;
  box-sizing: border-box;
  min-width: 1850px;
  padding: 15px 20px 30px;
}

.ShiftMatching__contents {
  display: flex;
  gap: 55px;
}

.calendar-area {
  width: 770px;
}

.fc-daygrid-day-number {
  font-size: 14px;
}

.fc-daygrid-day-number::after {
  content: "";
}

/* 日付数字を基準にする */
.fc-day.fc-day-today .fc-daygrid-day-number {
  position: relative;
  color: #fff;
  font-weight: bold;
}

/* オレンジの四角背景 */
.fc-day.fc-day-today .fc-daygrid-day-number::before {
  content: "";
  position: absolute;
  top: 15px;
  transform: translateY(-50%);
  right: 0px;
  width: 30px;
  height: 30px;
  background-color: #ff8000;
  border-radius: 0 0 0 6px;
  z-index: -10; /* 数字の下に */
}

.fc-non-business {
  background-color: transparent !important;
}

/* カレンダー全体の罫線色を統一 */
.fc-theme-standard table,
.fc-theme-standard th,
.fc-theme-standard td {
  border-color: rgba(112, 112, 112, 0.5);
}

/* 土曜日セル */
.fc-day-sat .fc-daygrid-day-frame {
  position: relative;
}

/* 右側の線 */
.fc-day-sat .fc-daygrid-day-frame::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background-color: rgba(112, 112, 112, 0.5);
}

.fc-h-event .fc-event-title-container {
  text-align: center;
}

/* 稼働あり */
.fc-event.event-working {
  background-color: #ff4500;
  border-color: #ff4500;
}

/* 稼働予定あり */
.fc-event.event-scheduled {
  background-color: #ff4500;
  border-color: #ff4500;
}

/* 無断欠勤（危険・警告系） */
.fc-event.event-absent {
  background-color: #a62ab9;
  border-color: #a62ab9;
}

/* 稼働キャンセル */
.fc-event.event-cancel {
  background-color: #8b8b8b;
  border-color: #8b8b8b;
}

/* 全てのカレンダー日セルの最小高さを指定 */
.fc-daygrid-day {
  min-height: 80px; /* お好みの高さに調整 */
}

.fc-daygrid-day.past-day .day-mark {
  display: none;
}

.fc-daygrid-day.past-day {
  background-color: #f7f7f7;
}

.fc-daygrid-day.fc-day-today .day-mark {
  display: none;
}

/* マークを中央に大きく表示 */
.day-mark {
  position: absolute;
  top: 130%;
  left: -130%;
  transform: translate(-50%, -50%);
  font-size: 40px;
  z-index: 2;
  pointer-events: none;
  white-space: nowrap;
}
.day-mark.is-single {
  left: -220%;
}

/* マークの種類ごとの色や形 */
.day-mark.circle {
  color: #44ad17;
}

.day-mark.triangle {
  color: #1b8ae6;
  font-weight: 900;
}

.day-mark.double {
  color: #ff4500;
  font-weight: 900;
}

.fc-theme-standard th {
  background-color: #eaf6fc;
  height: 42px;
  vertical-align: middle;
}

/* 曜日ヘッダー（日〜土）の線を消す */
.fc-theme-standard thead th {
  border: none;
}

/* 土曜日（最後の列）だけ右線を復活 */
.fc-theme-standard thead th:last-child {
  border-right: 1px solid #ddd;
}

/* カレンダー一番上の線（外枠）を消す */
.fc-theme-standard .fc-scrollgrid {
  border-top: none;
}

.fc-day.fc-day-today {
  box-shadow: inset 0 0 0 2px #ff8000;
  background-color: #fff;
}

/* workingDays を含む日付セルが薄いオレンジに */
.fc-daygrid-day.is-working .fc-daygrid-day-frame {
  background-color: #fff1d5;
}

.fc .fc-toolbar-title {
  font-size: 1.25rem;
}

.fc-today-button.fc-button-primary {
  background-color: #dde9fc;
  border: solid 1px #3f9ae9;
  color: #3f9ae9;
  border-radius: 100px;
  width: 62px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 700px;
  z-index: 10;
}

/* hover */
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):hover,
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
  background-color: #dde9fc;
  border: solid 1px #3f9ae9;
  color: #3f9ae9;
  z-index: 10;
}

.fc-today-button.fc-button-primary:disabled {
  background-color: #dde9fc;
  border: solid 1px #3f9ae9;
  color: #3f9ae9;
  border-radius: 100px;
  width: 62px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 700px;
  opacity: 1;
}

.fc-prev-button.fc-button.fc-button-primary {
  background-color: #fff;
  color: #348be5;
  border: solid 1px #348be5;
  width: 20px;
  height: 20px;
  padding: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fc-direction-ltr .fc-button-group > .fc-button:not(:last-child) {
  border-bottom-right-radius: 50%;
  border-top-right-radius: 50%;
}

.fc-next-button.fc-button.fc-button-primary {
  background-color: #fff;
  color: #348be5;
  border: solid 1px #348be5;
  width: 20px;
  height: 20px;
  padding: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fc-direction-ltr .fc-button-group > .fc-button:not(:first-child) {
  border-bottom-left-radius: 50%;
  border-top-left-radius: 50%;
}

.fc .fc-button-group {
  gap: 80px;
}

.fc .fc-button .fc-icon {
  font-size: 0.875rem;
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.calendar-title {
  display: none;
}

.fc.fc-toolbar.fc-header-toolbar {
  position: relative;
}

.calendar-move {
  display: flex;
  align-items: center;
  gap: 8px;
  position: absolute;
  left: 150px;
  top: 30px;
}

.calendar-move-btn {
  height: 28px;
  padding: 0 12px;
  border-radius: 100px;
  border: 1px solid #3f9ae9;
  background: #dde9fc;
  color: #3f9ae9;
  cursor: pointer;
}

.shiftMatching_checkbox {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.ShiftMatching__contents_calendar_explanation {
  margin-top: 10px;
}

.ShiftMatching__contents_calendar_explanation_details {
  display: inline-block;
  padding: 2px 4px;
  border-radius: 4px;
  margin-bottom: 4px;
}

.highColor {
  color: #ff4500;
  font-weight: bold;
}

.midiumColor {
  color: #44ad17;
  font-weight: bold;
}

.lowColor {
  color: #1b8ae6;
  font-weight: bold;
}

.shiftMatching__contents_right {
  position: relative;
  padding-bottom: 3rem;
}

.table__shiftMatching_btn {
  position: absolute;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  padding-top: 20px;
  background-color: #fff;
}

.table__wrapper {
  background-color: #fff;
  border-radius: 20px;
  position: relative;
  height: 100%;
  margin: 20px 0;
  margin-right: 10px;
  box-sizing: border-box;
  min-width: 1850px;
  padding: 15px 20px 30px;
}

.table {
  width: 100% !important;
  border-collapse: collapse;
}
.table .table__header {
  background-color: #eaf6fc;
}
.table._fixed {
  left: 0;
  right: 0;
  position: fixed;
  margin: 0 1.5rem;
}
.table._zindex {
  z-index: 2;
}

.table__caption {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.table__header_record {
  padding: 0.75rem 1.25rem;
  text-align: left;
  white-space: nowrap;
}
.table__header_record._width_button {
  width: 36px;
}
.table__header_record._border {
  border: 1px solid #9f9f9f;
}
.table__header_record._width {
  width: 10%;
}
.table__header_record._p_md {
  padding: 1rem;
}
.table__header_record._text_right {
  text-align: right;
}
.table__header_record .table__move {
  cursor: pointer;
}

.dataTable {
  margin: 0 !important; /* 上書き */
}

.dataTable > thead > tr > th,
.dataTable > thead > tr > td {
  font-size: 14px;
}

.table.stripe tbody tr.odd {
  background-color: #fff !important;
}

.table.stripe tbody tr.even {
  background-color: #f4f8f9 !important;
}

/* DataTables v2 系対応 */
#myTable.dataTable.stripe tbody tr:nth-child(odd) {
  background-color: #fff !important;
}

#myTable.dataTable.stripe tbody tr:nth-child(even) {
  background-color: #f4f8f9 !important;
}

.table__noStripe .table.stripe tbody tr.even {
  background-color: transparent !important;
  border-top: dotted 1px #707070;
  border-bottom: dotted 1px #707070;
}

.dataTable.stripe > tbody > tr.odd > *,
.dataTable.display > tbody > tr.odd > * {
  box-shadow: none !important;
}

tbody > tr > * {
  padding: 0.75rem 1.25rem;
  border-right: 1px dashed rgba(112, 112, 112, 0.5);
  white-space: nowrap;
}

tbody > tr > *:last-child {
  border-right: none;
}

.dataTable.no-footer {
  border-bottom: none;
}

.dataTables_wrapper.dataTables_paginate {
  display: flex;
  flex-wrap: nowrap; /* ← 折り返し禁止 */
  justify-content: center;
  align-items: center;
  gap: 4px;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  color: #a5a5a5 !important;
  display: flex;
  align-items: center; /* ← 中のテキストも中央揃え */
  justify-content: center;
  height: 24px; /* 丸背景の高さに合わせる */
  min-width: 24px; /* 数字の幅を統一（任意） */
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button:focus {
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  color: #348be5 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:focus {
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  color: #348be5 !important;
  font-weight: bold;
}

.table.dataTable > thead > tr > th,
.dataTable > thead > tr > td {
  border-bottom: none;
  box-sizing: border-box;
}

.dataTables_paginate {
  display: flex;
  justify-content: center; /* 中央寄せ */
  gap: 4px; /* ← ボタンの間に余白を追加 */
  align-items: center;
}

.dataTables_paginate.paging_simple_numbers {
  position: absolute;
  top: 10px;
  right: 100px;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  color: #348be5 !important;
  background: none !important;
  border: none !important;
  font-weight: bold;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:not(.previous):not(.next) {
  font-size: 0.8125rem !important;
}

.dataTables_wrapper .dataTables_paginate span {
  display: flex; /* ← 横並び強制 */
  gap: 4px; /* 数字ボタンの間隔 */
  align-items: center; /* 縦位置も揃える */
}

.paginate_button.previous,
.paginate_button.next {
  font-size: 0;
  line-height: 0;
}

/* 親ボタン（←）に position を設定 */
.paginate_button.previous {
  position: relative;
  color: transparent !important; /* テキストを隠す（"前へ" など） */
}

.dataTables_wrapper .dataTables_paginate .paginate_button.previous:not(.disabled) {
  margin-right: -24px;
}

/* 丸背景 */
.paginate_button.previous::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 6px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #348be5;
  border-radius: 50%;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

/* くの字矢印 */
.paginate_button.previous::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 15px;
  transform: translateY(-50%) rotate(315deg);
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
}

/* 親ボタン（←）に position を設定 */
.paginate_button.next {
  position: relative;
  color: transparent !important; /* テキストを隠す（"前へ" など） */
}

/* 丸背景 */
.paginate_button.next::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #348be5;
  border-radius: 50%;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

/* くの字矢印 */
.paginate_button.next::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 8px;
  transform: translateY(-50%) rotate(135deg);
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover {
  color: #a5a5a5 !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.previous::before,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.next::before {
  border-color: #a5a5a5 !important;
  background: #fff !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.previous::after,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.next::after {
  border-top-color: #a5a5a5 !important;
  border-left-color: #a5a5a5 !important;
}

/* 無効時の色変更 */
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.first::before,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.last::before {
  border-color: #a5a5a5 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.first::after,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.last::after {
  border-top-color: #a5a5a5 !important;
  border-left-color: #a5a5a5 !important;
  box-shadow: none;
}

/* 最初へ（二重←） */
/* 最初へボタン（二重←） */
.paginate_button.first {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  padding: 0 !important;
  color: transparent !important;
}

/* 大きな丸背景 */
.paginate_button.first::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #348be5;
  z-index: 0;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

/* 矢印1本目 */
.paginate_button.first::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 40%;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(315deg);
}

/* 矢印2本目 */
.paginate_button.first > span {
  position: absolute;
  top: 50%;
  left: 40%;
  width: 10px;
  height: 10px;
  background: #fff;
  transform: translateY(-50%);
  z-index: 0;
}

.paginate_button.first > span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(315deg);
}

/* 最後へボタン（二重→） */
.paginate_button.last {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  padding: 0 !important;
  color: transparent !important;
}

/* 大きな丸背景 */
.paginate_button.last::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #348be5;
  z-index: 0;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

/* 矢印1本目 */
.paginate_button.last::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 50%;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(135deg);
}

/* 矢印2本目 */
.paginate_button.last > span {
  position: absolute;
  top: 50%;
  left: 40%;
  width: 6px;
  background: #fff;
  transform: translateY(-50%);
  z-index: 0;
}

.paginate_button.last > span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 40%;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(135deg);
  z-index: 1;
}

/* 無効時の色変更 */
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.first::before,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.last::before {
  border-color: #a5a5a5 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.first::after,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.last::after,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.first > span::after,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled.last > span::after {
  border-top-color: #a5a5a5 !important;
  border-left-color: #a5a5a5 !important;
  box-shadow: none;
}

.datatable__total-count {
  margin-left: 1rem;
  font-size: 1.125rem;
  font-weight: bold;
  color: #101010;
  display: inline-block;
  vertical-align: middle;
}

/* 全件とページャーを横並びに */
.datatable__header {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
  flex-direction: row-reverse;
}

.datatable__total-count {
  margin-right: 24px; /* ページャーとの距離を固定 */
}

.dataTables_wrapper .dataTables_paginate {
  margin-top: 0px;
}

.datatable__total-count {
  font-size: 1rem;
  font-weight: bold;
  color: #101010;
}

.datatable__header {
  display: flex;
  align-items: center;
  margin-bottom: 8px; /* テーブルとの余白 */
}

.dt-container.dt-paging {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
}

.dt-container .dt-paging .dt-paging-button {
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  color: #a5a5a5 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 24px; /* 丸背景の高さに合わせる */
  min-width: 24px; /* 数字の幅を統一（任意） */
}

.dt-container .dt-paging .dt-paging-button:hover,
.dt-container .dt-paging .dt-paging-button:focus {
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  color: #348be5 !important;
}

.dt-container .dt-paging .dt-paging-button.current,
.dt-container .dt-paging .dt-paging-button.current:hover,
.dt-container .dt-paging .dt-paging-button.current:focus {
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #348be5 !important;
  font-weight: bold;
}

.table.dataTable > thead > tr > th,
.dataTable > thead > tr > td {
  border-bottom: none;
  box-sizing: border-box;
}

.dt-container .dt-paging nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.dt-container .dt-paging.paging_simple_numbers {
  position: absolute;
  top: 10px;
  right: 100px;
}

.dt-container .dt-paging .dt-paging-button.current {
  color: #348be5 !important;
  background: none !important;
  border: none !important;
  font-weight: bold;
}

.dt-container .dt-paging .dt-paging-button:not(.previous):not(.next) {
  font-size: 0.8125rem !important;
}

.dt-container .dt-paging span {
  display: flex; /* ← 横並び強制 */
  gap: 4px;
  align-items: center;
}

.dt-paging-button.previous,
.dt-paging-button.next {
  font-size: 0;
  line-height: 0;
}

/* ← 前へ */
.dt-paging-button.previous {
  position: relative;
  color: transparent !important;
}

.dt-paging-button.previous::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 6px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #348be5;
  border-radius: 50%;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.dt-paging-button.previous::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 15px;
  transform: translateY(-50%) rotate(315deg);
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
}

/* → 次へ */
.dt-paging-button.next {
  position: relative;
  color: transparent !important;
}

.dt-paging-button.next::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #348be5;
  border-radius: 50%;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.dt-paging-button.next::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 8px;
  transform: translateY(-50%) rotate(135deg);
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
}

.dt-container .dt-paging .dt-paging-button.disabled,
.dt-container .dt-paging .dt-paging-button.disabled:hover {
  color: #a5a5a5 !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

.dt-container .dt-paging .dt-paging-button.disabled.previous::before,
.dt-container .dt-paging .dt-paging-button.disabled.next::before {
  border-color: #a5a5a5 !important;
  background: #fff !important;
}

.dt-container .dt-paging .dt-paging-button.disabled.previous::after,
.dt-container .dt-paging .dt-paging-button.disabled.next::after {
  border-top-color: #a5a5a5 !important;
  border-left-color: #a5a5a5 !important;
}

/* 最初へ（二重←） */
.dt-paging-button.first {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  padding: 0 !important;
  color: transparent !important;
}

.dt-paging-button.first::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #348be5;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.dt-paging-button.first::after {
  content: "<<";
  position: absolute;
  font-weight: bold;
  font-size: 8px;
  top: 25%;
  right: 55%;
  width: 3px;
  height: 3px;
  color: #348be5;
  transform: scale(1, 1.5);
}

/* 非活性時 */
.dt-paging-button.first.disabled::after {
  color: #a5a5a5;
}

.dt-paging-button.first > span {
  position: absolute;
  top: 50%;
  left: 40%;
  width: 10px;
  height: 10px;
  background: #fff;
  transform: translateY(-50%);
}

.dt-paging-button.first > span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(315deg);
}

/* 最後へ（二重→） */
.dt-paging-button.last {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  padding: 0 !important;
  color: transparent !important;
}

.dt-paging-button.last::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #348be5;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.dt-paging-button.last::after {
  content: ">>";
  position: absolute;
  font-weight: bold;
  font-size: 8px;
  top: 25%;
  right: 55%;
  width: 3px;
  height: 3px;
  color: #348be5;
  transform: scale(1, 1.5);
}

/* 非活性時 */
.dt-paging-button.last.disabled::after {
  color: #a5a5a5;
}

.dt-paging-button.last > span {
  position: absolute;
  top: 50%;
  left: 40%;
  width: 6px;
  background: #fff;
  transform: translateY(-50%);
}

.dt-paging-button.last > span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 40%;
  width: 3px;
  height: 3px;
  border-top: 2px solid #348be5;
  border-left: 2px solid #348be5;
  transform: translateY(-50%) rotate(135deg);
}

.dt-container .dt-paging .dt-paging-button.disabled.first::before,
.dt-container .dt-paging .dt-paging-button.disabled.last::before {
  border-color: #a5a5a5 !important;
}

.dt-container .dt-paging .dt-paging-button.disabled.first::after,
.dt-container .dt-paging .dt-paging-button.disabled.last::after,
.dt-container .dt-paging .dt-paging-button.disabled.first > span::after,
.dt-container .dt-paging .dt-paging-button.disabled.last > span::after {
  border-top-color: #a5a5a5 !important;
  border-left-color: #a5a5a5 !important;
}

.table__userListTitle._loginID {
  width: 145px !important;
}
.table__userListTitle._employeeNumber {
  width: 102px !important;
}
.table__userListTitle._Name {
  width: 189px !important;
}
.table__userListTitle._corporateCode {
  width: 143px !important;
}
.table__userListTitle._corporateName {
  width: 360px !important;
}
.table__userListTitle._departmenCode {
  width: 152px !important;
}
.table__userListTitle._departmenName {
  width: 176px !important;
}
.table__userListTitle._role {
  width: 191px !important;
}

.table__userListTitle_loginID {
  margin: 0;
  border-bottom: solid 1px #101010;
}

.table__userListTitle_loginID:hover {
  color: #3491e5;
  cursor: pointer;
}

.table.stripe.tableUserList tbody tr:hover {
  background-color: #fffaf0 !important;
}

.table__noticeTitle._category {
  width: 120px !important;
}
.table__noticeTitle._priority {
  width: 74px !important;
}
.table__noticeTitle._situation {
  width: 66px !important;
}
.table__noticeTitle._startDateAndTime {
  width: 160px !important;
}
.table__noticeTitle._endDateAndTime {
  width: 160px !important;
}

.table.stripe.tableNotice tbody tr:hover {
  background-color: #fffaf0 !important;
}

.table__notice_heading {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 723px;
}

.table__notice_textPosition._priority {
  text-align: center !important;
}
.table__notice_textPosition._situation {
  text-align: center !important;
}
.table__notice_textPosition._endDateAndTime {
  text-align: center !important;
}

.Notice__date_table {
  display: flex;
  margin: 0 auto;
  box-sizing: border-box;
}

#myTable.dataTable.stripe tbody tr.table__masterManagement_row:not(:hover):nth-child(odd) {
  background-color: #fff !important;
}

#myTable.dataTable.stripe tbody tr.table__masterManagement_row:hover:nth-child(odd) {
  background-color: #fffaf0 !important;
}

#myTable.dataTable.stripe tbody tr.table__masterManagement_row:nth-child(even) {
  background-color: #fff !important;
}

#myTable.dataTable.stripe tbody tr.table__masterManagement_row:hover:nth-child(even) {
  background-color: #fffaf0 !important;
}

.table__masterManagement_row {
  border-bottom: dotted 1px #707070;
}

.table__masterManagement_title._category {
  width: 120px !important;
}
.table__masterManagement_title._range {
  width: 40px !important;
}
.table__masterManagement_title._template {
  width: 120px !important;
}
.table__masterManagement_title._subject {
  width: 330px !important;
}
.table__masterManagement_title._sort {
  width: 40px !important;
}
.table__masterManagement_title._situation {
  width: 40px !important;
}

.table.stripe.tableMasterManagement tbody tr:hover {
  background-color: #fffaf0 !important;
}

.table__masterManagement_heading {
  vertical-align: top;
  /* 全ての列に共通する「5行制限」 */
}
.table__masterManagement_heading .clamp-wrapper {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5; /* 5行でカット */
  overflow: hidden;
  line-height: 1.6;
  max-height: 8em; /* 5行分の高さ */
  min-height: 8em; /* 5行分の高さ */
  white-space: normal;
  word-break: break-all;
}
.table__masterManagement_heading._template {
  white-space: normal;
  cursor: pointer;
}
.table__masterManagement_heading._template .clamp-wrapper {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6;
}
.table__masterManagement_heading._subject {
  max-width: 200px;
  cursor: pointer;
  white-space: normal;
}
.table__masterManagement_heading._subject .clamp-wrapper {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6;
}
.table__masterManagement_heading._text {
  position: relative;
  line-height: 1.6;
  /* 閉じた状態 */
  max-height: 8em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
}
.table__masterManagement_heading._text.is-open {
  display: block;
  -webkit-line-clamp: unset;
  max-height: none;
  overflow: visible;
  padding-bottom: 50px;
}

/* フェードの消去（本文セルにis-openがついた時） */
.table__masterManagement_heading._text.is-open::after {
  content: none !important;
}

.table__masterManagement_textopen {
  position: absolute;
  bottom: 10px;
  z-index: 4;
  left: 50%;
  transform: translateX(-50%);
}

/* デフォルトではフェードなし */
.table__masterManagement_heading._text::after {
  content: none;
}

/* 6行以上のときだけフェード */
.table__masterManagement_heading._text.is-overflow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2.5em;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgb(255, 255, 255));
}

.table__masterManagement_heading._text.is-open::after {
  display: none;
}

.table__masterManagement_textPosition._situation {
  text-align: center !important;
}

.Notice__date_table {
  display: flex;
  margin: 0 auto;
  box-sizing: border-box;
}

.TableList__contents_businessContent {
  position: relative;
}

.TableList__contents_businessContent_text {
  position: absolute;
  top: 10px;
}

.table__userListTitle._companyInformation {
  width: 600px !important;
  text-align: center;
}
.table__userListTitle._projectInformation {
  width: 600px !important;
  text-align: center;
}
.table__userListTitle._businessContente {
  text-align: center;
}

.table__details_search {
  border-bottom: 1px dotted #707070;
}

.table__projectPriority_contents {
  width: 950px;
}

.table__projectPriority {
  width: 950px;
}

.table__projectPriority_head {
  background-color: #eaf6fc;
}

.table__projectPriority_headDetails {
  font-weight: bold;
  font-size: 14px;
  height: 50px;
  box-sizing: border-box;
}
.table__projectPriority_headDetails._delete {
  width: 100px;
  text-align: left;
}
.table__projectPriority_headDetails._delete:has(input) {
  padding-left: 0.5rem;
}
.table__projectPriority_headDetails._code {
  width: 600px;
}

.table__projectPriority tbody tr:nth-child(odd) {
  background-color: #fff;
}

.table__projectPriority tbody tr:nth-child(even) {
  background-color: #f4f8f9;
}

.table__projectPriority_excelBtn {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
}

.table__projectPriority_addrowBtn {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

.table__projectPriority_radiogroup {
  display: flex;
  gap: 1rem;
}

.table__shiftMatching {
  width: 970px !important;
  max-height: 650px;
  margin-top: 34px !important;
  overflow-y: scroll;
  position: relative;
}
.table__shiftMatching.modalver {
  width: 1110px !important;
  margin-top: 0 !important;
  max-height: 500px;
  overflow-y: scroll;
  border-left: dashed 1px rgba(112, 112, 112, 0.5);
  border-right: dashed 1px rgba(112, 112, 112, 0.5);
}

.table__shiftMatching {
  position: relative;
}
.table__shiftMatching .datatable__total-count {
  position: relative;
  width: auto;
  display: inline-block;
}
.table__shiftMatching position:-moz-read-only .datatable__total-count {
  width: auto;
  display: inline-block;
  position: absolute;
  z-index: 100;
}
.table__shiftMatching position:read-only .datatable__total-count {
  width: auto;
  display: inline-block;
  position: absolute;
  z-index: 100;
}
.table__shiftMatching .dt-paging.paging_full_numbers {
  display: none;
}

.table__shiftMatching_row {
  height: 90px;
  border-bottom: dashed 1px #707070;
}

#myTable.dataTable.stripe tbody tr.table__shiftMatching_row:nth-child(even) {
  background-color: #fff !important;
}

#myTable.dataTable.stripe tbody tr.table__shiftMatching_row:hover > td {
  background-color: #fffaf0 !important;
}

.table__shiftMatching_row:hover {
  background-color: #fffaf0 !important;
}

.table__shiftMatching_row.is-selected {
  background-color: #fff1d5 !important;
}

.table__header_record.table__shiftMatching_title._category {
  padding: 0.75rem;
}

.table__shiftMatching_title._category {
  width: 40px !important;
}
.table__shiftMatching_title._code {
  width: 120px !important;
}
.table__shiftMatching_title._workingDays {
  width: 100px;
}
.table__shiftMatching_title._workingTime {
  width: 100px;
}
.table__shiftMatching_title._matchDegree {
  width: 80px;
}

.table__shiftMatching_details._category {
  position: relative;
  border-left: 1px dashed rgba(112, 112, 112, 0.5);
}
.table__shiftMatching_details._matchDegree {
  border-right: 1px dashed rgba(112, 112, 112, 0.5);
}

.table__shiftMatching_details_matchNumber {
  font-size: 30px;
  font-weight: bold;
}

.table__shiftMatching #myTable tbody .table__spacer td {
  padding: 10px 0;
  border: none;
  background: transparent; /* 好きな値 */
}

.table__shiftMatching_details._businessContents {
  position: relative;
  line-height: 1.6;
  /* 閉じた状態 */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
.table__shiftMatching_details._businessContents.is-open {
  display: block;
  -webkit-line-clamp: unset;
  overflow: visible;
  padding-bottom: 50px;
}

/* フェードの消去（本文セルにis-openがついた時） */
.table__shiftMatching_details._businessContents.is-open::after {
  content: none !important;
}

.table__shiftMatching_details_textopen {
  position: absolute;
  bottom: 10px;
  z-index: 4;
  left: 50%;
  transform: translateX(-50%);
}

/* デフォルトではフェードなし */
.table__shiftMatching_details._businessContents::after {
  content: none;
}

/* 6行以上のときだけフェード */
.table__shiftMatching_details._businessContents.is-overflow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2.5em;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgb(255, 255, 255));
}

.table__shiftMatching_details._businessContents.is-open::after {
  display: none;
}

.inputText {
  border: 1px solid #cccccc;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  border-radius: 8px;
  height: 28px;
  padding-inline: 0;
  padding-block: 0;
  padding-left: 13px;
  font-size: 0.875rem;
  vertical-align: middle;
  box-sizing: border-box;
  color: #101010;
}
.inputText._height_xxl {
  height: 500px;
}
.inputText._height_xl {
  height: 200px;
}
.inputText._height_lg {
  height: 120px;
}
.inputText._width_xl {
  width: 800px;
}
.inputText._width_lg {
  width: 420px;
}
.inputText._width_md {
  width: 320px;
}
.inputText._width_modal_md {
  width: 320px;
}
.inputText._width_sm {
  width: 170px;
}
.inputText._width_xs {
  width: 80px;
}

.inputText:focus {
  border: #3491e5 solid 2px;
  outline: none;
}

.inputText.is-disabled:focus {
  border: 1px solid #cccccc;
  outline: none;
}

.inputTextarea {
  padding-top: 13px;
}

.inputTextarea.is-disabled:focus {
  border: 1px solid #cccccc;
  outline: none;
}

.inputDate {
  border: 1px solid #cccccc;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  border-radius: 8px;
  height: 28px;
  padding-inline: 0;
  padding-block: 0;
  padding-left: 13px;
  font-size: 0.875rem;
  vertical-align: middle;
  box-sizing: border-box;
  color: #101010;
}
.inputDate._height_xxl {
  height: 500px;
}
.inputDate._height_xl {
  height: 200px;
}
.inputDate._height_lg {
  height: 120px;
}
.inputDate._width_xl {
  width: 800px;
}
.inputDate._width_lg {
  width: 420px;
}
.inputDate._width_md {
  width: 320px;
}
.inputDate._width_modal_md {
  width: 320px;
}
.inputDate._width_sm {
  width: 170px;
}
.inputDate._width_xs {
  width: 80px;
}

.inputDate:focus {
  border: #3491e5 solid 2px;
  outline: none;
}

.inputperopd__wrapper {
  display: flex;
}

/* カレンダーアイコン */
.inputDate::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0;
  position: absolute; /* inputの中で右端に配置 */
  right: 8px;
  width: 20px; /* アイコンと同じくらいの範囲 */
  height: 100%;
}

.inputDate__wrapper {
  position: relative;
  display: inline-block;
}

.inputDate__icon {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  pointer-events: none; /* 入力操作に干渉しない */
}
.inputDate__icon._filterBtn {
  right: 140px;
}

.inputTime {
  border: 1px solid #cccccc;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  border-radius: 8px;
  height: 28px;
  padding-inline: 0;
  padding-block: 0;
  padding-left: 13px;
  font-size: 0.875rem;
  vertical-align: middle;
  box-sizing: border-box;
  color: #101010;
}
.inputTime._height_xxl {
  height: 500px;
}
.inputTime._height_xl {
  height: 200px;
}
.inputTime._height_lg {
  height: 120px;
}
.inputTime._width_xl {
  width: 800px;
}
.inputTime._width_lg {
  width: 420px;
}
.inputTime._width_md {
  width: 320px;
}
.inputTime._width_modal_md {
  width: 320px;
}
.inputTime._width_sm {
  width: 170px;
}
.inputTime._width_xs {
  width: 80px;
}

.inputTime:focus {
  border: #3491e5 solid 2px;
  outline: none;
}

.Choice__margin {
  display: flex;
  gap: 20px;
  align-items: center;
}

.inputText.is-disabled {
  background-color: #eaeaea;
  border: 1px solid #cccccc;
}

.select__wrapper {
  position: relative;
  display: inline-block;
}
.select__wrapper._width_lg {
  width: 420px;
}
.select__wrapper._width_sm {
  width: 170px;
}
.select__wrapper .selected {
  color: #101010;
  border: 1px solid #cccccc;
  background-color: #fff;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  border-radius: 8px;
  height: 28px;
  line-height: 28px;
  font-size: 0.875rem;
  padding: 0 24px 0 13px;
  position: relative;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.select__wrapper .selected._width_lg {
  width: 420px;
}
.select__wrapper .selected._width_sm {
  width: 170px;
}
.select__wrapper.active .selected, .select__wrapper.open .selected {
  border: 1px solid #3491e5;
  box-shadow: 0 0 0 1px #3491e5 inset;
}
.select__wrapper::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 6px;
  height: 6px;
  border-right: 2px solid #101010;
  border-bottom: 2px solid #101010;
  pointer-events: none;
  transition: transform 0.2s, border-color 0.2s;
}
.select__wrapper.open::after {
  transform: translateY(-50%) rotate(-135deg);
  border-right-color: #3491e5;
  border-bottom-color: #3491e5;
}
.select__wrapper.selected::after {
  border-right-color: #3491e5;
  border-bottom-color: #3491e5;
}
.select__wrapper .select__options {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  border: 2px solid #3491e5;
  border-radius: 8px;
  background-color: #fff;
  margin: 4px 0 0 0;
  padding: 0;
  list-style: none;
  z-index: 5000;
  max-height: 300px;
  overflow-y: auto;
}
.select__wrapper .select__options li {
  padding: 5px 10px;
  cursor: pointer;
}
.select__wrapper .select__options li:hover {
  background-color: #dde9fc;
}
.select__wrapper.open .select__options {
  display: block;
  font-size: 0.875rem;
}

.selected.is-disabled {
  pointer-events: none;
  background-color: #EAEAEA;
  border: 1px solid #CCCCCC;
}

.btnPrimary {
  color: #fff;
  background-color: #3491e5;
  border: 2px solid #fff;
  box-shadow: 0px 1px 1px rgba(1, 1, 1, 0.25);
  width: 9.8125rem;
  height: 1.875rem;
  border-radius: 100px;
  font-size: 14px;
}

.btnPrimary:hover {
  background-color: #0063bd;
  cursor: pointer;
}

.btnSecondary {
  color: #3997e7;
  background-color: #dde9fc;
  border-radius: 100px;
  border: solid 1px #3997e7;
  padding: 0px 13px 3px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
  width: 9.8125rem;
  height: 1.875rem;
  font-size: 14px;
}
.btnSecondary.HomeNoticeBtn {
  background-color: #dde9fc;
  position: relative;
  margin-right: 12px;
}
.btnSecondary.HomeNoticeBtn::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.75rem; /* 1つ目の矢印の左側 */
  transform: translateY(-50%) rotate(-45deg);
  width: 0.25rem;
  height: 0.25rem;
  border-right: 2px solid #3f9ae9;
  border-bottom: 2px solid #3f9ae9;
  box-sizing: border-box;
  /* 2つ目の矢印 */
}
.btnSecondary.HomeNoticeBtn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2rem; /* 右端からの距離 */
  transform: translateY(-50%) rotate(-45deg);
  width: 0.25rem;
  height: 0.25rem;
  border-right: 2px solid #3f9ae9;
  border-bottom: 2px solid #3f9ae9;
  box-sizing: border-box;
  /* 1つ目の矢印 */
}
.btnSecondary.ListTable__btn {
  width: 62px;
}
.btnSecondary._width_sm {
  width: 102px;
}
.btnSecondary._width_xs {
  width: 62px;
}

.btnSecondary:hover {
  color: #2d7ec4;
  background-color: #b0ccf8;
  border: solid 1px #2d7ec4;
}

.btnTertiary {
  color: #3f9ae9;
  background-color: #fff;
  border: 1px solid #3f9ae9;
  width: 9.8125rem;
  height: 1.875rem;
  border-radius: 100px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
  font-size: 14px;
}

.btnTertiary:hover {
  background-color: #dde9fc;
  cursor: pointer;
}

.btnDanger {
  color: #fff;
  background-color: #ff4343;
  border: 1px solid #fff;
  box-shadow: 0px 1px 2px rgba(52, 181, 229, 0.15);
  width: 9.8125rem;
  height: 1.875rem;
  border-radius: 100px;
  display: inline-block;
  text-align: center;
  font-size: 14px;
}

.btnDanger:hover {
  background-color: #d83838;
  cursor: pointer;
}

.btnFilter {
  border: none;
  background-color: transparent;
  box-shadow: 0px 3px 6px rgba(1, 1, 1, 0.25);
  width: 46px;
  height: 46px;
  border-radius: 50%;
  position: relative;
}

.btnFilter__image {
  width: 46px;
  height: 46px;
  position: absolute;
  top: 0;
  right: 0;
}

.btn__toTop {
  border: none;
  background-color: transparent;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.15);
  border-radius: 50%;
  cursor: pointer;
}

.SelectDeselect__btn_flex {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.SelectDeselect__btn_flex._station {
  position: relative;
  top: 150px;
}

.SelectDeselect__btn {
  width: 75px;
}

.SelectDeselect__btn:hover {
  cursor: pointer;
}

.SelectDeselect__btn_icon._blue {
  stroke: #3491e5;
  transform: scaleX(-1);
}
.SelectDeselect__btn_icon._white {
  stroke: #fff;
}

.Modal__btn_right_result {
  margin-top: 24px;
}

.projectPriority__radioBtn {
  margin: 20px 0 10px;
}

.csvOutputBtn {
  position: absolute;
  right: 300px;
}

.accordion__searchConditions_btn a {
  text-decoration: none;
  color: #3491e5;
}

.textopenBtn {
  background-color: #fff;
  border: 1px solid #cccccc;
  color: #737373;
  width: 84px;
  height: 28px;
  border-radius: 100px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.textopenBtn::after {
  content: "";
  position: relative;
  width: 6px;
  height: 6px;
  border-right: 2px solid #939393;
  border-bottom: 2px solid #939393;
  transform: rotate(45deg); /* 下向き */
}

.textopenBtn.is-open::after {
  transform: rotate(-135deg); /* 上向き */
  top: 4px;
}

body,
html {
  height: 100%;
  margin: 0;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
}

footer {
  flex-shrink: 0;
  text-align: center;
  padding: 1em 0;
}

.Footer__copyright {
  color: #a5a5a5;
  margin: 0;
  min-width: 1920px;
}

.inputCheckBox {
  appearance: none; /* ブラウザ標準の見た目を消す */
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid #cccccc; /* 外枠色 */
  border-radius: 50%; /* 丸にする */
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  position: relative;
  background-color: #fff; /* 背景 */
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  margin-right: 6px;
}
.inputCheckBox._table {
  border-radius: 6px;
}

/* チェックマーク*/
.inputCheckBox::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 6px;
  border: solid #cccccc;
  border-width: 0 3px 3px 0;
  transform: translate(-50%, -60%) rotate(45deg);
}

/* チェックが入った時 */
.inputCheckBox:checked {
  background-image: linear-gradient(180deg, #3495e5, #5fa9f2); /* 丸の中の色 */
  border-color: #348be5;
}

.inputCheckBox:checked::after {
  border-color: #fff; /* チェック時は白い✓ */
}

.checkbox__group {
  margin-right: 46px;
}
.checkbox__group._last {
  margin: 0;
}

.datatable-pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.paginate_button {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #fff;
  border: 1px solid #007bff;
  color: #007bff;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  font-size: 0.75rem;
}
.paginate_button:hover:not(.disabled) {
  background-color: #e0e0e0;
}
.paginate_button.disabled {
  cursor: default;
  pointer-events: none;
  color: #cccccc;
  border: 1px solid #a5a5a5;
}
.paginate_button._first, .paginate_button._previous {
  margin-right: 8px;
}
.paginate_button._next, .paginate_button._last {
  margin-left: 8px;
}

.paginate_button._first span {
  left: 6px;
  margin-top: -2px;
}

.paginate_button._last span {
  left: 6px;
  margin-top: -2px;
}

.page-numbers {
  display: flex;
  gap: 4px;
}
.page-numbers button {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  font-size: 0.75rem;
  color: #a5a5a5;
  background-color: #fff;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-numbers button.active {
  color: #007bff;
}

.paginate_button._first,
.paginate_button._previous {
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.paginate_button._next,
.paginate_button._last {
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.16);
}

.combobox {
  position: relative;
  display: inline-block;
}
.combobox._width_lg {
  width: 420px;
}
.combobox._width_sm {
  width: 170px;
}
.combobox._width_lg {
  width: 420px;
}
.combobox._width_sm {
  width: 170px;
}
.combobox .combo__input {
  width: 100%;
  border: 1px solid #cccccc;
  border-radius: 8px;
  box-sizing: border-box;
  padding: 0 24px 0 13px;
  height: 28px;
  line-height: 28px;
  font-size: 0.875rem;
  box-shadow: 0px 1px 1px rgba(51, 51, 51, 0.15);
  outline: none;
  color: #101010;
  background-color: #fff;
  cursor: text;
}
.combobox .combo__input:focus {
  border: 1px solid #3491e5;
  box-shadow: 0 0 0 1px #3491e5 inset;
}
.combobox::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 6px;
  height: 6px;
  border-right: 2px solid #101010;
  border-bottom: 2px solid #101010;
  pointer-events: none;
  transition: transform 0.2s, border-color 0.2s;
}
.combobox.open::after {
  transform: translateY(-50%) rotate(-135deg);
  border-right-color: #3491e5;
  border-bottom-color: #3491e5;
}
.combobox.selected::after {
  border-right-color: #3491e5;
  border-bottom-color: #3491e5;
}
.combobox .combo__options {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  border: 2px solid #3491e5;
  border-radius: 8px;
  background-color: #fff;
  margin: 4px 0 0 0;
  padding: 0;
  list-style: none;
  z-index: 1000;
  font-size: 0.875rem;
  max-height: 300px;
  overflow-y: auto;
}
.combobox .combo__options li {
  padding: 5px 10px;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.combobox .combo__options li:hover {
  background-color: #dde9fc;
}
.combobox.open .combo__options {
  display: block;
}

body {
  background-color: #f6f6f6;
}

.UserPages__text_caveat {
  color: #ff0000;
  background-color: #eef3fd;
  padding: 3px 13px 8px;
}

.UserPages__BulkUserRegistrationBtn {
  text-align: end;
}

.MapPages__contents {
  min-height: 1080px;
}

.MapMenu {
  max-width: 660px;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 3px 0px 6px rgba(51, 51, 51, 0.15);
}

.MapImage {
  background-repeat: no-repeat;
  background-size: 1200px;
  background-position: left 660px top 16px;
  min-height: 800px;
}
.MapImage._case {
  background-image: url(../../images/sample/案件軸画像.png);
}
.MapImage._staff {
  background-image: url(../../images/sample/スタッフ軸画像.png);
}

.MapList_checkbox {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.MapDetails {
  position: absolute;
  left: 750px;
  border-radius: 20px;
  max-height: 180px;
  display: none;
}
.MapDetails._case {
  top: 410px;
}
.MapDetails._staff {
  top: 460px;
}

.MapDetails.is-active {
  display: block;
}

.MapDetails__point {
  position: absolute;
  top: 300px;
  left: 1100px;
}

.u_bg_white {
  background-color: #fff;
}

.u_bg_gray {
  background-color: hsl(215, 5%, 50%);
}

.u_bg_black {
  background-color: #000;
}

.u_bg_red {
  background-color: hsl(355, 80%, 50%);
}

.u_bg_orange {
  background-color: hsl(25, 90%, 50%);
}

.u_bg_amber {
  background-color: hsl(44, 90%, 50%);
}

.u_bg_yellow {
  background-color: hsl(55, 100%, 50%);
}

.u_bg_lime {
  background-color: hsl(75, 95%, 45%);
}

.u_bg_green {
  background-color: hsl(140, 95%, 35%);
}

.u_bg_teal {
  background-color: hsl(165, 95%, 35%);
}

.u_bg_cyan {
  background-color: hsl(180, 80%, 50%);
}

.u_bg_sky {
  background-color: hsl(194, 100%, 44%);
}

.u_bg_blue {
  background-color: hsl(212, 78%, 44%);
}

.u_bg_indigo {
  background-color: hsl(207, 70%, 35%);
}

.u_bg_violet {
  background-color: hsl(260, 60%, 50%);
}

.u_bg_purple {
  background-color: hsl(280, 60%, 50%);
}

.u_bg_magenta {
  background-color: hsl(305, 85%, 55%);
}

.u_bg_pink {
  background-color: hsl(335, 90%, 55%);
}

.u_txt_white {
  color: #fff;
}

.u_txt_gray {
  color: hsl(215, 5%, 50%);
}

.u_txt_black {
  color: #000;
}

.u_txt_red {
  color: hsl(355, 80%, 50%);
}

.u_txt_orange {
  color: hsl(25, 90%, 50%);
}

.u_txt_amber {
  color: hsl(44, 90%, 50%);
}

.u_txt_yellow {
  color: hsl(55, 100%, 50%);
}

.u_txt_lime {
  color: hsl(75, 95%, 45%);
}

.u_txt_green {
  color: hsl(140, 95%, 35%);
}

.u_txt_teal {
  color: hsl(165, 95%, 35%);
}

.u_txt_cyan {
  color: hsl(180, 80%, 50%);
}

.u_txt_sky {
  color: hsl(194, 100%, 44%);
}

.u_txt_blue {
  color: hsl(212, 78%, 44%);
}

.u_txt_indigo {
  color: hsl(207, 70%, 35%);
}

.u_txt_violet {
  color: hsl(260, 60%, 50%);
}

.u_txt_purple {
  color: hsl(280, 60%, 50%);
}

.u_txt_magenta {
  color: hsl(305, 85%, 55%);
}

.u_txt_pink {
  color: hsl(335, 90%, 55%);
}

.u_font_size_10 {
  font-size: calc(10 / 16 * 1rem);
}

.u_font_size_11 {
  font-size: calc(11 / 16 * 1rem);
}

.u_font_size_12 {
  font-size: calc(12 / 16 * 1rem);
}

.u_font_size_13 {
  font-size: calc(13 / 16 * 1rem);
}

.u_font_size_14 {
  font-size: calc(14 / 16 * 1rem);
}

.u_font_size_15 {
  font-size: calc(15 / 16 * 1rem);
}

.u_font_size_16 {
  font-size: calc(16 / 16 * 1rem);
}

.u_font_size_17 {
  font-size: calc(17 / 16 * 1rem);
}

.u_font_size_18 {
  font-size: calc(18 / 16 * 1rem);
}

.u_font_size_19 {
  font-size: calc(19 / 16 * 1rem);
}

.u_font_size_20 {
  font-size: calc(20 / 16 * 1rem);
}

.u_font_size_21 {
  font-size: calc(21 / 16 * 1rem);
}

.u_font_size_22 {
  font-size: calc(22 / 16 * 1rem);
}

.u_font_size_23 {
  font-size: calc(23 / 16 * 1rem);
}

.u_font_size_24 {
  font-size: calc(24 / 16 * 1rem);
}

.u_font_size_25 {
  font-size: calc(25 / 16 * 1rem);
}

.u_font_size_26 {
  font-size: calc(26 / 16 * 1rem);
}

.u_font_size_27 {
  font-size: calc(27 / 16 * 1rem);
}

.u_font_size_28 {
  font-size: calc(28 / 16 * 1rem);
}

.u_font_size_29 {
  font-size: calc(29 / 16 * 1rem);
}

.u_font_size_30 {
  font-size: calc(30 / 16 * 1rem);
}

.u_font_size_31 {
  font-size: calc(31 / 16 * 1rem);
}

.u_font_size_32 {
  font-size: calc(32 / 16 * 1rem);
}

/*# sourceMappingURL=styles.css.map */
