/* auth */
.invalid-feedback-new {
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.857rem;
  color: #ea5455;
}

.invalid-icon {
  border: 1px red solid !important;
}

/* start */
.bs-stepper .bs-stepper-content .content {
  margin-left: 0;
}

#p-header-modal {
  padding: 1.4rem !important;
  background-color: transparent;
}

.modal-header .btn-close {
  margin: -0.4rem 1.3rem -1.4rem auto !important;
}

.size-25 {
  width: 25px;
  height: 25px;
}

.size-18 {
  width: 18px;
  height: 18px;
}

.size-1-5 {
  width: 1.5rem;
  height: 1.5rem;
}

.avatar-dashboard {
  width: 4rem;
  height: 4rem;
}

.avatar-announcement {
  width: 3rem;
  height: 3rem;
}

.avatar-center {
  object-fit: cover;
  object-position: center;
}

.kop-perusahaan {
  width: 100%;
  object-fit: contain;
  object-position: center;
}

.z-100 {
  z-index: 1;
}

/* select style */
select:required:invalid {
  color: gray;
}

option[value=""][disabled] {
  display: none;
}

option {
  color: #8898aa;
}

.padding-button {
  padding-right: 0.6rem !important;
  padding-left: 0.6rem !important;
}

.select2-container--default .select2-selection--single {
  height: 38px;
  border: 1px solid #dee2e6;
  border-radius: 5px;
}

.select2-container--default .select2-selection--single:before {
  content: " ";
  display: block;
  position: absolute;
  border-color: #888 transparent transparent transparent;
  border-style: solid;
  border-width: 5px 4px 0 4px;
  height: 0;
  right: 6px;
  margin-left: -4px;
  margin-top: -2px;
  top: 50%;
  width: 0;
  cursor: pointer;
}

.select2-container--open .select2-selection--single:before {
  content: " ";
  display: block;
  position: absolute;
  border-color: transparent transparent #888 transparent;
  border-width: 0 4px 5px 4px;
  height: 0;
  right: 6px;
  margin-left: -4px;
  margin-top: -2px;
  top: 50%;
  width: 0;
  cursor: pointer;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #8898aa;
}

.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
  display: none;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
  display: none;
}

.mb-select {
  margin-bottom: 1.5rem;
}

.dataTables_length {
  margin-left: 20px;
}

.dataTables_filter {
  margin-right: 20px;
}

/* margin */
.m-3-px {
  margin: 3px !important;
}
.mb-2rem {
  margin-bottom: 2rem !important;
}
.m-x-2 {
  margin-left: 2rem !important;
  margin-right: 2rem !important;
}
.mb-5px {
  margin-bottom: 5px !important;
}
.mb-3 {
  margin-bottom: 3rem !important;
}
.mb-2-px {
  margin-bottom: 2px !important;
}
.me-0-2 {
  margin-right: 0.2rem !important;
}
.me-0-5 {
  margin-right: 0.5rem !important;
}
.mb-0-5 {
  margin-bottom: 0.5rem !important;
}
.mb-1-5 {
  margin-bottom: 1.5rem !important;
}
.mt-0-5 {
  margin-top: 0.5rem !important;
}
.mt-0-2 {
  margin-top: 0.2rem !important;
}
.mt-1-r {
  margin-top: 1rem !important;
}
.mt-1-2 {
  margin-top: 1.2rem !important;
}
.mt--0-5 {
  margin-top: -0.5rem !important;
}
.mt--1-3 {
  margin-top: -1.3rem !important;
}
.me--1-5 {
  margin-right: -1.5rem !important;
}
.me--5-px {
  margin-right: -5px !important;
}
.ms-0-5 {
  margin-left: 0.5rem !important;
}
.ms-1-5 {
  margin-left: 1.5rem !important;
}
.ms--0-5 {
  margin-left: -0.5rem !important;
}
.h5 {
  font-size: 1.2rem !important;
}

/* width */
.w-100 {
  width: 100% !important;
}
.w-1 {
  width: 1% !important;
}
.w-10 {
  width: 10% !important;
}
.w-15 {
  width: 15% !important;
}
.w-20 {
  width: 20% !important;
}
.w-30 {
  width: 30% !important;
}
.w-40 {
  width: 40% !important;
}
.w-60 {
  width: 60% !important;
}
.w-70 {
  width: 70% !important;
}
.w-90 {
  width: 90% !important;
}
.modal-slide-lg {
  width: 50% !important;
}
.flatpickr-wrapper {
  width: 100%;
}
.w-200-px {
  width: 200px !important;
}

/* font */
.fs-1 {
  font-size: 13px !important;
}
.fs-15 {
  font-size: 15px !important;
}
.fs-16 {
  font-size: 16px !important;
}
.fs-17 {
  font-size: 17px !important;
}
.fs-18 {
  font-size: 18px !important;
}
.fs-20 {
  font-size: 20px !important;
}
.fs-35 {
  font-size: 35px !important;
}
.fw-bold {
  font-weight: bold !important;
}
.fc-black {
  color: black !important;
}
.fc-grey {
  color: #6e6b7b !important;
}
.text-reset {
  color: #b9b9c3 !important;
}
.fs-small {
  font-size: smaller !important;
}

/* custom */
.p--0-8 {
  padding: 0.8rem !important;
}
.p-0-5 {
  padding: 0.5rem !important;
}
.p-x-3 {
  padding: 0px 3rem !important;
}
.p-y-0 {
  padding: 0px 1.5rem !important;
}
.p-y-0-5 {
  padding: 0px 0.5rem !important;
}
.p-b-0 {
  padding-bottom: 0px !important;
}
.pt-1-5 {
  padding-top: 1.5rem !important;
}
.p-header {
  padding: 0.5rem 0.5rem 0.5rem 1.5rem !important;
}
.profile-image {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #d6d8ff;
  font-size: 15px;
  color: #3a42f3;
  text-align: center;
}
.profile-image-icon {
  width: 35px !important;
  height: 35px !important;
}
.profile-image-budget {
  width: 70px !important;
  height: 70px !important;
}
.wh-feather {
  width: 1rem !important;
  height: 1rem !important;
}
.fs-time {
  font-size: 1.5rem !important;
}
.s-time {
  margin: 0rem 6rem 1rem 6rem !important;
}

.swal2-styled.swal2-cancel {
  background-color: #ebe9e9 !important;
  color: #a7a7a7 !important;
}

.swal2-actions:not(.swal2-loading) .swal2-styled.swal2-cancel:hover {
  background-color: #b1afaf !important;
  color: #737373 !important;
}
.btn_batal {
  border: none !important;
  background-color: #ebe9e9 !important;
  color: #747373 !important;
}

.btn_batal:hover {
  border: none !important;
  background-color: #d3d3d3 !important;
  color: #737373 !important;
}
.btn-export {
  color: #3a42f3 !important;
  background-color: rgba(115, 103, 240, 0.2) !important;
  border: none !important;
}
.btn-del {
  color: #ea5455 !important;
  background-color: rgba(234, 84, 85, 0.2) !important;
  border: none !important;
}
.second-header {
  padding: 0rem 1.5rem 1rem 1.5rem !important;
}
.second-header .flatpickr-wrapper {
  position: relative;
  display: inline-block;
  width: 100% !important;
}
.third-header {
  padding: 0.5rem !important;
  margin: 0rem !important;
  border-bottom: 1px solid #dbdade !important;
}
.badge-custom {
  font-size: small;
  width: fit-content;
  padding: 0.3rem 0.5rem;
  border-radius: 5px;
  font-weight: bold !important;
}
.badge-primary {
  background-color: #6c73f0;
}
.avatar-employee {
  border: none;
  width: 30px !important;
  height: 30px !important;
  background-color: #3a42f3 !important;
  color: white !important;
}
.avatar-employee-icon {
  margin-top: 0.5rem;
  height: 1rem;
  width: 1rem;
}

.avatar-content-square {
  width: 48px;
  height: 48px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  font-size: 0.857rem;
}

.tab_bar {
  color: #b9b9c3 !important;
  background-color: transparent !important;
  border: none !important;
}
.tab_bar:hover {
  border-bottom: solid 2px #3a42f3 !important;
}
.nav-active {
  border-radius: 5px !important;
  border-color: #3a42f3 !important;
  background-color: #3a42f3 !important;
  color: #fff !important;
}
.modal .modal-header .mt--1-3 .btn-close {
  padding: 10px !important;
  background-color: #ededed !important;
  color: #babfc7 !important;
}
.modal .btn-close {
  background-color: #ededed !important;
  color: #babfc7 !important;
}
/* rotate */
.tr-180 {
  transform: rotate(180deg) !important;
}

/* image */
.ob-cover {
  object-fit: cover;
}

.pickadate {
  border-left: 1px solid #d8d6de !important;
  padding-left: 1rem !important;
  border-right: none !important;
  border-radius: 5px 0px 0px 5px !important;
}

.pickadate:focus {
  border-left: 1px solid blue !important;
  padding-left: 1rem !important;
  border-right: none !important;
  border-radius: 5px 0px 0px 5px !important;
}

.pickadate:hover,
.pickadate:active {
  cursor: pointer;
}

.flex-wi {
  flex-wrap: inherit !important;
}

.second-header .input-group-text {
  border-radius: 0px 5px 5px 0px !important;
}

.second-header .input-group-text:focus {
  border-radius: 0px 5px 5px 0px !important;
  border-left: 1px solid blue !important;
  border-top: 1px solid blue !important;
  border-bottom: 1px solid blue !important;
  border-right: 1px solid blue !important;
}

.h-6 {
  margin-bottom: 0 !important;
}

/* about multiple upload */
#files-area {
  margin: 0px -3px !important;
}
.file-block {
  border: 1px solid #d8d6de !important;
  border-radius: 5px;
  margin: 5px;
  color: initial;
  display: inline-flex;
  padding: 0.3rem 0rem 0.3rem 0.8rem !important;
}
.file-block-disable {
  border: 1px solid #d8d6de !important;
  border-radius: 5px;
  margin: 5px;
  color: initial;
  display: inline-flex;
  padding: 0.3rem 0.8rem 0.3rem 0.8rem !important;
}
.file-block .name-file {
  font-size: 12px !important;
}
.file-delete {
  margin-top: 0.2rem;
  display: flex;
  width: 40px;
  color: initial;
  background-color: #6eb4ff00;
  font-size: large;
  justify-content: center;
  cursor: pointer;
}
.row-gap-5 {
  row-gap: 5px;
}
.column-gap-5 {
  column-gap: 5px;
}
.a-hover:hover {
  color: #6e6b7b !important;
}
.white-space-nowrap {
  white-space: nowrap;
}

.resizing {
  font: unset;
  overflow-wrap: break-word;
  font-weight: bold;
}

.card-shadow-inner {
  margin-bottom: 1rem !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 24px 0 rgb(34 41 47 / 10%) !important;
}

.br-right-0-5 {
  border-radius: 0px 5px 5px 0px !important;
}

.bc-trans {
  border-color: transparent !important;
}

.pb-0-7 {
  padding-bottom: 0.7rem !important;
}

.pb-2-2 {
  padding-bottom: 2.2rem !important;
}

.new-item-hover {
  border-top: 1px solid #d8d6de;
  color: #3a42f3;
  background-color: transparent;
}

.new-item-hover:hover {
  background-color: rgba(115, 103, 240, 0.12);
}

.btn-success-custom {
  background-color: #ddfbeb;
  color: #28c76f;
}
.btn-success-custom:hover {
  color: #28c76f;
  box-shadow: 0px 7px 15px #a1dbbb;
}

.btn-warning-custom {
  background-color: #ffe7d1;
  color: #ff9f43;
}

.btn-warning-custom:hover {
  color: #ff9f43;
  box-shadow: 0px 7px 15px #ffddbd;
}

.pointer {
  cursor: pointer;
}

/* absensi */
.bg-red {
  --bs-table-accent-bg: #ffb8b8 !important;
}
.bg-red :hover {
  --bs-table-accent-bg: #ffb8b8 !important;
}

.is-invalid .select2-container--default .select2-selection--single {
  border: 1px solid #dc3545 !important;
}

.ul-disc {
  list-style-type: disc;
}

.ol-disc {
  list-style-type: decimal;
}

.jstree-default .jstree-node {
  min-height: 40px;
  line-height: 46px;
  margin-left: 24px;
  min-width: 24px;
}

/* ————————————————————–
  Tree core styles
*/
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

.tree {
  margin: 1em;
}

/* ————————————————————–
  Tree rows
*/
.tree li {
  line-height: 1.2;
  position: relative;
  padding: 0 0 1em 1em;
}

.tree ul li {
  padding: 1em 0 0 1em;
}

.tree > li:last-child {
  padding-bottom: 0;
}

/* ————————————————————–
  Tree labels
*/
.tree_label {
  position: relative;
  display: inline-block;
}

label.tree_label {
  cursor: pointer;
}

label.tree_label:hover {
  color: #666;
}

/* ————————————————————–
  Tree expanded icon
*/
label.tree_label:before {
  background: #ededed;
  color: #fff;
  position: relative;
  z-index: 1;
  float: left;
  margin: 0 1em 0 -2em;
  width: 1em;
  height: 1em;
  border-radius: 1em;
  content: "";
  text-align: center;
  line-height: 0.9em;
}

:checked ~ label.tree_label:before {
  content: "–";
}

/* ————————————————————–
  Tree branches
*/
.tree li:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: -0.5em;
  display: block;
  width: 0;
  border-left: 1px solid #ededed;
  content: "";
}

.tree_label:after {
  position: absolute;
  top: 0;
  left: -1.5em;
  display: block;
  height: 0.5em;
  width: 1em;
  border-bottom: 1px solid #ededed;
  border-left: 1px solid #ededed;
  border-radius: 0 0 0 0.3em;
  content: "";
}

label.tree_label:after {
  border-bottom: 0;
}

:checked ~ label.tree_label:after {
  border-radius: 0 0.3em 0 0;
  border-top: 1px solid #ededed;
  border-right: 1px solid #ededed;
  border-bottom: 0;
  border-left: 0;
  bottom: 0;
  top: 0.5em;
  height: auto;
}

.tree li:last-child:before {
  height: 1em;
  bottom: auto;
}

.tree > li:last-child:before {
  display: none;
}

.tree_custom {
  display: block;
  background: #eee;
  padding: 1em;
  border-radius: 0.3em;
}

.w-head-repeat {
  width: 91.96666% !important;
}

div.scrollmenu {
  overflow: auto;
  white-space: nowrap;
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
}

td.z-index-3 {
  z-index: 3 !important;
}

.text-transparent {
  color: transparent !important;
}

.icon-required {
  color: red;
}
