@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Black.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Black.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-ExtraBoldItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-ExtraBoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-MediumItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-MediumItalic.woff") format("woff");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Light.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Italic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-ExtraLight.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-ExtraLight.woff") format("woff");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-ExtraLightItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-ExtraLightItalic.woff") format("woff");
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-BlackItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-BlackItalic.woff") format("woff");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-ExtraBold.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-ExtraBold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Medium.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Bold.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-BoldItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-BoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-LightItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-LightItalic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-SemiBold.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Regular.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-ThinItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-ThinItalic.woff") format("woff");
  font-weight: 100;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-SemiBoldItalic.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-SemiBoldItalic.woff") format("woff");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src:
    url("/api/assets/mays/fonts/Montserrat-Thin.woff2") format("woff2"),
    url("/api/assets/mays/fonts/Montserrat-Thin.woff") format("woff");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: element-icons;
  src:
    url(/mays/assets/element-icons.ab40a589.woff) format("woff"),
    url(/mays/assets/element-icons.a30f5b3b.ttf) format("truetype");
  font-weight: 400;
  font-display: "auto";
  font-style: normal;
}

@font-face {
  font-family: icomoon;
  src: url(/mays/assets/icomoon.618e2252.eot?srd7ee);
  src:
    url(/mays/assets/icomoon.618e2252.eot?srd7ee#iefix) format("embedded-opentype"),
    url(/mays/assets/icomoon.d4022ef8.ttf?srd7ee) format("truetype"),
    url(/mays/assets/icomoon.6c60debb.woff?srd7ee) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: block;
}

* {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  font-family: "Montserrat", "Arial", "sans-serif";
  color: #555;
  -webkit-tap-highlight-color: transparent;
}

html {
  font-size: 62.5%;
  @media screen and (max-width: 1020px) {
    font-size: 60%;
  }

  @media screen and (max-width: 767px) {
    font-size: 56%;
  }

  overflow-y: hidden;
}

html.scrollable {
  overflow-y: auto;
}

:root {
  --primary-color: #f05200;
  --brand-color: #333333;
  --brand-color-lighten: #09a8aa;
  --brand-color-darken: #0ccdcf;
  --brand-color-low-opacity: rgba(11, 187, 189, 0.1);
  --brand-color-high-opacity: rgba(11, 187, 189, 0.9);
  --brand-color-login-background: #68cecf;
  --brand-color-background-ui-opacity: 0.9;
  --login-circular-opacity: 0;
  --font-family: "Montserrat", "Arial", "sans-serif";
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

select::-ms-expand {
  display: none;
}

body.fullmode {
  padding-top: 190px;
  padding-left: 61px;
  padding-right: 61px;
}

@media screen and (max-width: 1131px) {
  body.fullmode {
    padding-top: 165px;
    padding-left: 31px;
    padding-right: 31px;
  }
}

@media screen and (max-width: 811px) {
  body.fullmode {
    padding-top: 146px;
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media screen and (max-width: 559px) {
  body.fullmode {
    padding-top: 146px;
  }
}

@media screen and (max-width: 1285px) {
  body.fullmode.menuclosed {
    padding-top: 185px;
    padding-left: 31px;
    padding-right: 31px;
  }
}

@media screen and (max-width: 966px) {
  body.fullmode.menuclosed {
    padding-top: 183px;
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media screen and (max-width: 714px) {
  body.fullmode.menuclosed {
    padding-top: 168px;
  }
}

.fields-group {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -2%;
}

.field-wrap {
  width: 100%;
  padding: 0 2%;
  white-space: nowrap;
}

.field-wrap.fourth-thrice {
  width: 75%;
}

.field-wrap.half {
  width: 50%;
}

.field-wrap.third {
  width: 33.3%;
}

.field-wrap.fourth {
  width: 25%;
}

.field-wrap.fifth {
  width: 20%;
}

.field-wrap.sixth {
  width: 16.66%;
}

.field-wrap.tenth {
  width: 10%;
}

.field-wrap.fifth-twice {
  width: 40%;
}

.field {
  margin-bottom: 25px;
  position: relative;
}
/* .field:last-child {
  margin-bottom: 0;
} */
.field .label:empty {
  display: none;
}

.field .label {
  font-weight: 700;
  padding: 0 0 10px 15px;
  font-size: 1.1rem;
  text-transform: uppercase;
  display: block;
}

.field-wrap .button {
  margin-top: 25px;
}

.combobox-container {
  position: relative;
}

.combobox-container.small {
  max-width: 160px;
}

.combobox-container::after {
  font-family: element-icons !important;
  content: "\e6e1";
  position: absolute;
  top: 13px;
  right: 10px;
  color: #c0c4cc;
  font-size: 14px;
  transform: rotate(180deg);
}

.default-input {
  border: 1px solid #e7e7e7;
  height: 40px;
  width: 100%;
  border-radius: 6px !important;
  padding: 0 15px;
  background-color: #fff;
  font-family: var(--font-family);
  font-weight: 300;
  font-size: 1.3rem;
  color: #555;
  -webkit-transition: border-color 0.3s linear;
  transition: border-color 0.3s linear;
}

.default-input:hover,
.default-input:focus,
.default-input:focus-visible {
  border-color: var(--brand-color);
  outline: 0;
}

.json-input {
  font-family: monospace;
  /* min-height: ; */
  min-height: 150px;
  padding: 15px;
}

.column > json-input {
  margin-block: 10px;
}

.default-input.disabled {
  background-color: #f7f7f7;
  color: #b8b8b8;
  pointer-events: none;
  cursor: auto;
}

span.default-input {
  display: block;
  height: auto;
  min-height: 40px;
  padding: 10px 15px;
}

.combobox-container .default-input {
  padding: 0 30px 0 15px;
}

.button {
  padding: 0 15px;
  margin: 0 2% 0 0;
  cursor: pointer;
  text-align: center;
  border-radius: 6px;
  font-size: 1rem !important;
  text-transform: uppercase;
  display: inline-block;
  height: 40px;
  line-height: 38px;
  font-family: var(--font-family);
  font-weight: 700;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  overflow: hidden;
  white-space: nowrap;
  background-color: #f05200;
  border: 1px solid #f05200;
  color: #fff;
  text-decoration: none;
}

.button:hover,
.button.hover {
  background-color: #fff;
  border-color: #f05200;
  color: #f05200;
}

.button.neutral {
  border-color: #b8b8b8;
  background-color: #b8b8b8;
}

.button.neutral:hover,
.button.neutral.hover {
  background-color: #fff;
  border-color: #b8b8b8;
  color: #b8b8b8;
}

.button.disabled {
  background-color: #f0f0f0;
  border-color: #f0f0f0;
  color: #b8b8b8;
  cursor: not-allowed;
  pointer-events: none;
}

.container {
  display: none;
}

.container.full-hidden {
  height: 0;
  overflow: hidden;
}

.container.active {
  display: block;
  padding-bottom: 10px;
  width: 100%;
  height: auto;
  overflow: hidden;
}

.container.active.bottom-bar {
  padding-bottom: 100px;
}

.container.align-label {
  padding-top: 0;
  padding-left: 15px;
  padding-right: 0;
}

.scroll-container {
  width: 100%;
  height: calc(100% - 100px);
  overflow-y: auto;
}

.basic-config {
  overflow: hidden;
}

.list-header {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
}

.list-header h2 {
  margin-top: 0;
}

.default-table {
  display: table;
  width: 100%;
  -webkit-box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.03);
  -moz-box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.03);
  box-shadow: 0 0 6px 1px #00000008;
  border-radius: 10px;
  --action-column-width: 20%;
  font-size: 1.4rem;
}

.default-table.fixed {
  table-layout: fixed;
}

.default-table .row.header {
  font-weight: 700;
  height: 64px;
}

.default-table.light .row.header {
  height: 40px;
}

.default-table .row {
  display: table-row;
  height: 74px;
}

.default-table .row.hide {
  display: none;
}

.default-table .row.inactive {
  pointer-events: none;
  opacity: 0.5;
}

.default-table.light .row {
  height: 32px;
}

.default-table.light .row .column {
  padding: 5px 10px;
  font-size: 1.2rem;
}

.default-table.light .row .column:first-child,
.default-table.light .row.header .column:first-child {
  padding-left: 20px;
}

.default-table.fixed .row .column.break-text {
  word-wrap: break-word;
  word-break: break-all;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}
.default-table .row.header .column:first-child {
  border-top-left-radius: 10px;
  border-left: solid 1px #e7e7e7;
  padding-left: 25px;
}
.default-table .row.header .column:last-child {
  border-top-right-radius: 10px;
  border-right: solid 1px #e7e7e7;
}
.default-table .row .column:last-child {
  border-right: solid 1px #e7e7e7;
}
.default-table .row:last-child .column:last-child {
  border-bottom-right-radius: 10px;
}
.default-table .row.header .column {
  text-transform: uppercase;
  font-size: 1.1rem;
  border-top: solid 1px #e7e7e7;
  border-bottom: solid 1px #e7e7e7;
  background-color: #ededed;
  vertical-align: middle;
}
.default-table .row .column:first-child {
  border-left: solid 1px #e7e7e7;
  padding-left: 25px;
}
.default-table .row:last-child .column {
  border-bottom: solid 1px #e7e7e7;
}
.default-table .row.item:last-child .column:first-child {
  border-bottom-left-radius: 10px;
}
.default-table .row .column {
  display: table-cell;
  vertical-align: middle;
  background: #ffffff;
  border-bottom: dashed 1px #e7e7e7;
  position: relative;
  padding-right: 5px;
}
.default-table .row.header .column.sortable {
  cursor: pointer;
}
.default-table .row.selected .column {
  background-color: #eee;
}
.default-table .row.header .column .cell-value {
  display: inline-block;
  vertical-align: middle;
  padding-right: 5px;
  transition: all 0.3s ease;
}
.default-table .row .cell-value.small {
  font-size: 1rem;
}
.default-table .row .cell-value.date-special {
  line-height: 1.1em;
}
.default-table .row .cell-value.no-wrap {
  word-wrap: normal;
  white-space: nowrap;
}
.default-table .row.header .column .orderby {
  vertical-align: middle;
  display: none;
}
.default-table .row.header .column .orderby .asc,
.default-table .row.header .column .orderby .desc {
  display: block;
  font-size: 18px;
  display: none;
}
.default-table .row.header .column .orderby .icon-up,
.default-table .row.header .column .orderby .icon-down {
  font-family: icomoon !important;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.default-table .row.header .column .orderby .icon-up::before {
  content: "\e94e";
}
.default-table .row.header .column .orderby .icon-down::before {
  content: "\e94f";
}
.default-table .row.header .column.sortable.sort-desc .orderby,
.default-table .row.header .column.sortable.sort-asc .orderby {
  display: inline-block;
}
.default-table .row.header .column.sortable.sort-desc .orderby .desc {
  display: block;
}
.default-table .row.header .column.sortable.sort-asc .orderby .asc {
  display: block;
}
.default-table .action.icon-edit {
  color: var(--brand-color);
}

.column input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  display: flex;
  align-content: center;
  justify-content: center;
  font-size: 2rem;
  padding: 0.1rem;
  border: 0.25rem solid #888888;
  border-radius: 0.5rem;
}
.column input[type="checkbox"]::before {
  content: "\2714";
  width: 14px;
  height: 14px;
  text-align: center;
  font-size: 12px;
  line-height: 14px;
  opacity: 0;
  color: #555;
}
.column input[type="checkbox"]:checked::before {
  opacity: 1;
}

.column .action {
  display: inline-block;
  height: 24px;
  width: 24px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.default-table .action {
  cursor: pointer;
  margin: 0 10px;
  font-size: 24px;
  transition: all 0.3s ease;
}
.default-table .action.disabled {
  opacity: 0.3;
  pointer-events: none;
}
.default-table .row .action-column {
  width: 20%;
  text-align: center;
  white-space: nowrap;
}

.default-table.calendar {
  width: auto;
}

table.default-table.calendar {
  border-collapse: collapse;
  border-spacing: 0;
  border: none;
  overflow: visible;
}

.default-table.calendar thead .row th {
  position: sticky;
  top: 0;
  background: #f2f2f2;
  z-index: 5;
}

.default-table.calendar .row.item {
  height: 35px;
}

.default-table.calendar .row.header .column .cell-value {
  width: 30px;
  text-align: center;
  padding: 0;
}

.default-table.calendar .row.header .column {
  display: table-cell;
  vertical-align: middle;
  padding-left: 5px;
  padding-right: 5px;
}

.default-table.calendar .row.item .column {
  display: table-cell;
  vertical-align: middle;
  background: #ffffff;
  border-bottom: dashed 1px #e7e7e7;
  border-right: dashed 1px #e7e7e7;
  padding-left: 5px;
  padding-right: 5px;
  font-size: 1.2rem;
}

.default-table.calendar .row .column.holiday {
  background-color: #aee6e6 !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column.vacation {
  background-color: #c7e9c0 !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column.vacation-preapproved {
  background-color: #ffffb3 !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column.vacation-waiting {
  background-color: rgba(255, 255, 179, 0.25) !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column.deadline {
  background-color: #74c476 !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column.selected {
  font-weight: bold !important;
  border-top: 1px solid #000 !important;
  border-bottom: 1px solid #000 !important;
}

.default-table.calendar .row .column.weekend {
  background-color: #f1f1f1 !important;
  font-size: 0.9rem;
}

.default-table.calendar .row .column:first-child {
  padding-left: 10px;
  padding-right: 10px;
}

.default-table.calendar .row .column:last-child {
  border-right: none;
}

.text-left {
  text-align: left !important;
}
.text-center {
  text-align: center;
}
.icon-view {
  background-image: url("../images/icon-view.png");
}
.icon-approve {
  background-image: url("../images/icon-approve.png");
}
.icon-reject {
  background-image: url("../images/icon-reject.png");
}
.icon-translate {
  background-image: url("../images/icon-translate.png");
}
.icon-clear {
  background-image: url("../images/icon-clear.png");
}
.icon-delete {
  position: relative;
}
.icon-delete::after {
  font-family: icomoon !important;
  content: "\e952";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  color: rgb(136, 136, 136);
  font-size: 24px;
}

.popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: center;
  display: none;
}

.popup.active {
  display: flex;
  z-index: 10;
}

.popup-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
}

.popup-container {
  position: relative;
  width: 80%;
  max-height: 80%;
  padding: 30px;
  border-radius: 10px;
  background-color: #fff;
}

.popup-close {
  position: absolute;
  top: 30px;
  right: 30px;
  width: 24px;
  height: 24px;
  background-image: url("../images/icon-close.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  cursor: pointer;
}

.popup .list-container {
  height: calc(80% - 100px);
  overflow-y: auto;
}

#notification-popup {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 330px;
  padding: 14px 26px 14px 13px;
  border-radius: 8px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid #ebeef5;
  position: fixed;
  background-color: #fff;
  -webkit-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 12px #0000001a;
  -webkit-transition:
    opacity 0.3s,
    left 0.3s,
    right 0.3s,
    -webkit-transform 0.3s;
  transition:
    opacity 0.3s,
    left 0.3s,
    right 0.3s,
    -webkit-transform 0.3s;
  transition:
    opacity 0.3s,
    transform 0.3s,
    left 0.3s,
    right 0.3s;
  transition:
    opacity 0.3s,
    transform 0.3s,
    left 0.3s,
    right 0.3s,
    -webkit-transform 0.3s;
  overflow: hidden;
  right: -350px;
  top: 16px;
  z-index: 2014;
}

#notification-popup.right {
  right: 36px;
}

#notification-popup.no-padding.right {
  right: 0;
}

#notification-popup.hide {
  opacity: 0;
}

#notification-popup .notification-icon {
  height: 24px;
  width: 24px;
  font-size: 24px;
  font-family: element-icons !important;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  vertical-align: baseline;
  display: inline-block;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#notification-popup .icon-success {
  color: #67c23a;
}

#notification-popup .icon-success::before {
  content: "\e79c";
}

#notification-popup .icon-error {
  color: #f56c6c;
}

#notification-popup .icon-error::before {
  content: "\e79d";
}

#notification-popup .notification-group {
  margin-left: 13px;
  margin-right: 8px;
}

#notification-popup .notification-title {
  font-weight: 700;
  font-size: 16px;
  color: #303133;
  margin: 0;
}

#notification-popup .notification-content {
  font-size: 14px;
  line-height: 21px;
  margin: 6px 0 0;
  color: #606266;
  text-align: left;
}

#notification-popup .notification-close {
  position: absolute;
  top: 18px;
  right: 15px;
  cursor: pointer;
  color: #909399;
  font-size: 16px;
  font-family: element-icons !important;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  vertical-align: baseline;
  display: inline-block;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#notification-popup .icon-close {
  color: #909399;
}

#notification-popup .icon-close::before {
  content: "\e6db";
}

.button-group {
  display: flex;
  gap: 15px;
}

.button-group .button {
  margin: 0;
}

.upload-button {
  position: relative;
}

.upload-button input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.upload-button .button {
  cursor: pointer;
}

#processing {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s linear;
  z-index: 1000;

  &.active {
    opacity: 1;
    pointer-events: all;
  }
}

#processing.fixed {
  position: fixed;
}

.processing-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
}

.processing-container {
  position: absolute;
  text-align: center;
}

.processing-container .icon-processing {
  width: 66px;
  height: 66px;
  background-image: url("/api/assets/mays/icons/processing-white.png");
  margin: auto;
}

.processing-container span {
  position: relative;
  font-size: 20px;
  color: #fff;
}

/* select 2 multiple */
.combobox-container {
  .select2-container {
    width: 100% !important;
  }
}

.select2-container--default .select2-selection--multiple {
  display: inline-flex;
  align-items: center;
  width: 100%;
  min-height: 40px;
  border: 1px solid #e7e7e7;
  -webkit-transition: border-color 0.3s linear;
  transition: border-color 0.3s linear;
  white-space: normal;
  /* padding: 0 30px 0 15px;
   */
}

.select2-container--default .select2-selection--multiple:hover,
.select2-container--default .select2-selection--multiple:focus,
.select2-container--default .select2-selection--multiple:focus-visible {
  border-color: var(--brand-color);
  outline: 0;
  cursor: auto;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
  background-color: transparent;
  border: none;
  padding: 0;
  margin: 0;
  font-weight: 300;
  font-size: 1.3rem;
}

/* calendar css */
.months-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 3px;
}

.months-item {
  width: calc(33.3% - 20px);
  text-decoration: none;
  background: #fff;
  box-shadow: 0 0 6px 1px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  display: none;
}

.months-item.active {
  display: block;
}

@media screen and (max-width: 900px) {
  .months-item {
    width: calc(50% - 15px);
  }
}

@media screen and (max-width: 600px) {
  .months-item {
    width: 100%;
    margin-right: 10px;
  }
}

.months-item.single {
  width: 100%;
}

.months-item .months-title {
  font-size: 1.6rem;
  color: #555;
  font-weight: bold;
  background: #ededed;
  padding: 6px 10px;
  border-radius: 10px 10px 0 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.months-item .months-contents {
  padding: 5px 10px 10px 10px;
  font-size: 1.4rem;
  color: var(--brand-color);
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.months-item .months-contents .day-item {
  display: flex;
  gap: 10px;
}

.months-item .months-contents .day-item .day-value {
  font-size: 1.6rem;
  line-height: 20px;
  font-weight: bold;
  flex-grow: 0;
  flex-shrink: 0;
  width: 22px;
}

.months-item .months-contents .day-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.months-item .months-contents .day-list .list-item {
  display: flex;
  flex-direction: column;
}

.months-item .months-contents .day-list .list-item .list-title {
  position: relative;
  min-height: 20px;
  line-height: 20px;
  font-size: 1.4rem;
  font-weight: bold;
}

.months-item .months-contents .day-list .list-item .list-title::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  flex-grow: 0;
  flex-shrink: 0;
  width: 22px;
  height: 20px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.months-item .months-contents .day-list .list-item .list-title.holiday::before {
  background-image: url(../images/icon-holiday.png);
}

.months-item .months-contents .day-list .list-item .list-title.birthday::before {
  background-image: url(../images/icon-birthday.png);
}

.months-item .months-contents .day-list .list-item .list-title.vacations::before {
  background-image: url(../images/icon-vacations.png);
}

.months-item .months-contents .day-list .list-item .list-contents {
  display: flex;
  flex-direction: column;
}

.months-item .months-contents .day-list .list-item .list-contents .list-subtitle {
  margin-top: 5px;
  font-weight: bold;
}

.global-error {
  font-size: 1.4rem;
}

#game-data .default-table .row.header .column:first-child,
#game-data .default-table .row.item .column:first-child {
  padding-left: 10px;
  min-width: 160px;
}

.event-note {
  position: absolute;
  top: 0;
  right: 0;
  width: 24px;
  height: 24px;
}

.event-note::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-left: 24px solid transparent;
  border-bottom: 24px solid transparent;
  border-top: 24px solid #333;
}

.event-note span {
  position: absolute;
  top: 1px;
  right: 1px;
  color: #fff;
  font-size: 0.8rem;
  line-height: 0.8rem;
}

.switch {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  font-size: 14px;
  line-height: 20px;
  height: 20px;
  vertical-align: middle;
}

.switch-input {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
  margin: 0;
}

.switch-core {
  margin: 0;
  position: relative;
  width: 40px;
  height: 20px;
  border: 1px solid #dcdfe6;
  outline: 0;
  border-radius: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background: #dcdfe6;
  -webkit-transition:
    border-color 0.3s,
    background-color 0.3s;
  transition:
    border-color 0.3s,
    background-color 0.3s;
  vertical-align: middle;
  width: 40px;
  border-color: rgb(255, 73, 73);
  background-color: rgb(255, 73, 73);
  cursor: pointer;
}

.switch-core:after {
  content: "";
  position: absolute;
  top: 1px;
  left: 1px;
  border-radius: 100%;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  width: 16px;
  height: 16px;
  background-color: #fff;
}

.switch.checked .switch-core {
  width: 40px;
  border-color: rgb(19, 206, 102);
  background-color: rgb(19, 206, 102);
}

.switch.checked .switch-core:after {
  left: 100%;
  margin-left: -17px;
}

.list-container.table-mode {
  overflow: auto;
  border-radius: 10px;
  border: 1px solid #e7e7e7;
  max-height: 300px;
  position: relative;
}

table.default-table.calendar th,
table.default-table.calendar td {
  border: none !important;
  border-radius: 0 !important;
}

table.default-table.calendar thead th {
  border-bottom: 1px solid #e7e7e7 !important;
}

table.default-table.calendar tbody tr:not(:last-child) th,
table.default-table.calendar tbody tr:not(:last-child) td {
  border-bottom: dashed 1px #e7e7e7 !important;
}

table.default-table.calendar tbody .row th {
  position: sticky;
  left: 0;
  background: #f9f9f9;
  z-index: 4;
}

table.default-table.calendar tbody .row th::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  border-right: 1px dashed #e7e7e7;
  pointer-events: none; /* para não interferir com cliques */
}

table.default-table.calendar thead .row th.sticky {
  left: 0;
  z-index: 6;
}

table.default-table.calendar .row.item .column {
  font-size: 1.1rem;
  font-weight: normal;
}

.bottom-options {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  background-color: #fff;
  padding: 16px 2rem;
  border-top: 2px solid #d7d7d7;
  z-index: 9;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bottom-options {
  .button:last-child {
    margin-right: 0;
  }
}

:root {
  --ms-py: 0;
  --ms-px: 0;
  --ms-ring-color: #f0520030;
  --ms-spinner-color: var(--primary-color);
  --ms-tag-font-size: 16px;
  --ms-tag-line-height: 20px;
  --ms-tag-font-weight: 400;
  --ms-tag-bg: var(--primary-color);
  --ms-tag-remove-mx: 5px;
  --ms-option-font-size: 14px;
  --ms-option-bg-selected: var(--primary-color);
  --ms-option-bg-selected-pointed: var(--primary-color);
}

.multiselect-tag-wrapper,
.multiselect-tag-remove-icon,
.multiselect-option.is-selected span {
  color: white;
}

.multiselect-tag-remove-icon {
  width: 16px !important;
  height: 16px !important;
}

.multiselect-no-options,
.multiselect-no-results,
.multiselect-multiple-label {
  font-size: var(--ms-option-font-size);
}

.multiselect-wrapper {
  height: 100%;
}

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

.notes-list {
  text-align: left;
  padding-left: 20px;
}

.notes-list li {
  margin-bottom: 5px;
}

.icon-information {
  margin-left: 5px;
  position: relative;
  font-size: 1.2rem;
  display: inline-block;
  width: 20px;
  cursor: pointer;
  font-family: icomoon !important;
  speak: never;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}

.icon-information::before {
  content: "\e961";
}

/* Custom Tooltip (ElementUI el-popover / el-tooltip style) */
.custom-tooltip {
  position: fixed;
  z-index: 9999;
  max-width: 320px;
  background-color: #ffffff;
  border: 1px solid #ebeef5;
  border-radius: 4px;
  padding: 12px 16px;
  color: #606266;
  font-family: "Montserrat", "Arial", "sans-serif";
  font-size: 13px;
  line-height: 1.5;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  word-break: break-word;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 0.2s ease,
    transform 0.2s ease;
}

.custom-tooltip.active {
  opacity: 1 !important;
  pointer-events: auto;
}

/* Tooltip offset animation depending on placement */
.custom-tooltip[data-placement="top"] {
  transform: translateY(0);
}
.custom-tooltip[data-placement="top"]:not(.active) {
  transform: translateY(6px);
}

.custom-tooltip[data-placement="bottom"] {
  transform: translateY(0);
}
.custom-tooltip[data-placement="bottom"]:not(.active) {
  transform: translateY(-6px);
}

.custom-tooltip[data-placement="right"] {
  transform: translateX(0);
}
.custom-tooltip[data-placement="right"]:not(.active) {
  transform: translateX(-6px);
}

.custom-tooltip[data-placement="left"] {
  transform: translateX(0);
}
.custom-tooltip[data-placement="left"]:not(.active) {
  transform: translateX(6px);
}

/* Arrow core styles */
.custom-tooltip-arrow {
  position: absolute;
  width: 0;
  height: 0;
  border-color: transparent;
  border-style: solid;
  pointer-events: none;
}

/* Placement top */
.custom-tooltip[data-placement="top"] .custom-tooltip-arrow {
  bottom: -6px;
  border-width: 6px 6px 0;
  border-top-color: #fff;
}
.custom-tooltip[data-placement="top"] .custom-tooltip-arrow::after {
  content: " ";
  position: absolute;
  bottom: 1px;
  margin-left: -6px; /* Centered inside the 12px parent border width */
  border-width: 6px 6px 0;
  border-top-color: #ffffff;
}

/* Placement bottom */
.custom-tooltip[data-placement="bottom"] .custom-tooltip-arrow {
  top: -6px;
  border-width: 0 6px 6px;
  border-bottom-color: #fff;
}
.custom-tooltip[data-placement="bottom"] .custom-tooltip-arrow::after {
  content: " ";
  position: absolute;
  top: 1px;
  margin-left: -6px; /* Centered inside the 12px parent border width */
  border-width: 0 6px 6px;
  border-top-color: transparent; /* reset default to avoid interference */
  border-bottom-color: #ffffff;
}

/* Placement right */
.custom-tooltip[data-placement="right"] .custom-tooltip-arrow {
  left: -6px;
  border-width: 6px 6px 6px 0;
  border-right-color: #fff;
}
.custom-tooltip[data-placement="right"] .custom-tooltip-arrow::after {
  content: " ";
  position: absolute;
  left: 1px;
  margin-top: -6px; /* Centered inside the 12px parent border height */
  border-width: 6px 6px 6px 0;
  border-right-color: #ffffff;
}

/* Placement left */
.custom-tooltip[data-placement="left"] .custom-tooltip-arrow {
  right: -6px;
  border-width: 6px 0 6px 6px;
  border-left-color: #ebeef5;
}
.custom-tooltip[data-placement="left"] .custom-tooltip-arrow::after {
  content: " ";
  position: absolute;
  right: 1px;
  margin-top: -6px; /* Centered inside the 12px parent border height */
  border-width: 6px 0 6px 6px;
  border-left-color: #ffffff;
}
