html,
body {
  height: 100%;
}

body {
  display: flex;
  /* align-items: center; */
  padding-top: 40px;
  padding-bottom: 40px;
  background-color: #f5f5f5;
  font-family: 'Poppins', sans-serif;
}

.form-signin {
  max-width: 330px;
  padding: 15px;
}

.form-signin .form-floating:focus-within {
  z-index: 2;
  font-family: 'Poppins', sans-serif;
}

.form-signin input[type="email"] {
  margin-bottom: -1px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.form-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.container-footer {
  background-color: #303030;
  z-index: 900;
  height: 50px;
  width: 100%;
  clear: both;
  position: fixed;
  bottom: 0;
  font-size: 0.8rem;
  font-weight: 300;
}
.container-footer p {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform : translate(-50%,-50%);
  transform : translate(-50%,-50%);
  width: 100%;
  text-align: center;
  color: #ffffff;
}

#translucent {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  justify-content: space-around;
  opacity: 1;
  z-index: 2000;
  background-color: rgba(55, 55, 55, 0.6);
}

#translucent > #spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-right: -50%;
  transform: translate(-50%, -50%);
  opacity: 1;
  font-size: 4em;
  color: white;
}

.nav-link {
  font-weight: 100;
  color: #ffffff;
}

/* ナビゲーションバー */
.navbar {
  background-color: #404040;
}

.navbar-nav .nav-link.active {
  font-weight: 700;
  color: #ffffff;
}

.navbar-nav .nav-link.disabled {
  font-weight: 100;
  color: #3cb371;
}
.bg-green {
  background-color:#2e8b57;
}
.btn-green {
  background-color:#2e8b57;
}
.btn-blue {
  background-color:#0275d8;
}
/* disabled時の色*/
.nav-link:disabled {
  color: #a9a9a9;
  background-color: #404040;
  border-color: #404040;
}
/* hover時（マウスカーソルを重ねた時）の色*/
.nav-link:hover:not(:disabled) {
  color: #ffffff;
  background-color: #808080;
  border-color: #808080;
}
/* focus時の色 */
.nav-link:focus:not(:disabled) {
  color: #ffffff;
  background-color: #404040;
  border-color: #808080;
}
.btn-link-active:not(:disabled) {
  color: #ffffff;
  background-color: #0275d8;
  border-color: #0275d8;
}

/* サイドメニュー */
.sidemenu-nav {
  top: 64px;
  z-index: 920;
  padding-left: 5px;
  padding-right: 5px;
}
.sidemenu-nav.sidemenu-nav-vertical {
  position: absolute;
  float: right;
  width: 204px;
  left: calc(100vw - 84px);
  font: white;
  box-sizing: border-box;
  color: #ffffff;
}
.sidemenu-nav.sidemenu-nav-vertical.sidemenu-nav-fixed {
  position: fixed;
}

.sidemenu-btn {
  position: fixed;
  width: 204px;
  height: 64px;
  color: #ffffff;
  background-color: #0275d8;
  font-size: 2.0em;
  padding: 0;
  padding-left: 8px;
  padding-right: 8px;
  margin: auto;
}
.sidemenu-btn-selected {
  position: fixed;
  width: 204px;
  height: 64px;
  color: #ffffff;
  background-color: #f98526;
  font-size: 2.0em;
  padding: 0;
  padding-left: 8px;
  padding-right: 8px;
  margin: auto;
}
/* hover時（マウスカーソルを重ねた時）の色 [未選択ボタン]*/
.sidemenu-btn:hover:not(:disabled) {
  color: #000;
  background-color: #ffc680;
  border-color: #ffc680;
}
/* disable時の色 [未選択ボタン]*/
.sidemenu-btn:disabled {
  color: #a9a9a9;
  background-color: #ffffff;
  border-color: #ffffff;
}
/* hover時（マウスカーソルを重ねた時）の色 [選択済みボタン]*/
.sidemenu-btn-selected:hover:not(:disabled) {
  color: #000;
  background-color: #f98526;
  border-color: #f98526;
}
/* focus時の色（hover時と同等かさらに濃いor暗めの色を指定） */
.sidemenu-btn-selected:focus:not(:disabled) {
  color: #ffffff;
  background-color: #f98526;
  border-color: #f98526;
}
/* disable時の色 [選択済みボタン]*/
.sidemenu-btn-selected:disabled {
  color: #a9a9a9;
  background-color: #ffffff;
  border-color: #ffffff;
}

.custom-tooltip {
  --bs-tooltip-bg: #c0c0c0;
  --bs-tooltip-color: #000000;
  --bs-tooltip-max-width: 300px;
  padding: 5px;
  text-align: left;
}

.pagetitle {
  position: absolute;
  width: calc(100vw - 115px);
  top: 64px;
  left: 10px;
  font-size: 1.6rem;
}

.sectiontitle {
  left: 20px;
  font-size: 1.4rem;
}

/* .container {
  margin-left: 10px;
  padding-left: 0px;
  width: 100vw;
} */

.dashcontainer {
  /* margin-left: 10px;
  margin-right: 10px; */
  padding-left: 30px;
  padding-right: 30px;
  width: 100vw;
}

.dashsubcontainer {
  padding: 0px;
  margin-left: 10px;
  z-index: 500;
}

.maincontainer {
  position: absolute;
  width: calc(100vw - 100px);
  padding: 0px;
  margin-top: 32px;
  margin-left: 10px;
  z-index: 500;
}

.subcontainer {
  padding: 0px;
  margin-left: 10px;
  z-index: 500;
}

table {
  width: 100%;
}
table tbody td {
  vertical-align: middle;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/*　スクロールバーの実装 */
.table_sticky {
  display: block;
  overflow-y: scroll;
  height: 230px;
  width: 100%;
}
.table_sticky thead th {
  position: sticky;
  top: 0;
  z-index: 1;
}
.table_sticky tbody td {
  height: 1rem;
}
.table_sticky tfoot td {
  position: sticky;
  top: 0;
  z-index: 1;
}
