* {
  font-family: 'Noto Sans JP', sans-serif;
}

.element-monitor {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background: linear-gradient(
    180deg,
    rgba(0, 68, 136, 1) 0%,
    rgba(0, 17, 34, 1) 100%
  );
}

.element-monitor .glass-bg {
  position: absolute;
  top: 98px;
  left: 80px;
  width: calc(100% - 160px);
  height: 86vh;
  overflow: hidden;
}

.element-monitor .glass-bg-radial {
  background: radial-gradient(
    50% 50% at 49% 50%,
    rgba(255, 255, 255, 1) 46%,
    rgba(255, 255, 255, 0) 100%
  );
  position: absolute;
  top: -2px;
  left: -2px;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  border-top-width: 1.5px;
  border-top-style: solid;
  border-left-width: 1px;
  border-left-style: solid;
  border-color: #ffffff85;
  box-shadow: 4px 8px 13.1px #2b2b2b40, inset 4px 4px 20px #e5e7eb, inset -8px
    -8px 15.6px #e5e7eb;
  backdrop-filter: blur(16px) brightness(100%);
  -webkit-backdrop-filter: blur(16px) brightness(100%);
  background-blend-mode: luminosity;
}

.element-monitor .div {
  background: linear-gradient(
    123deg,
    rgba(255, 255, 255, 0.4) 0%,
    rgba(255, 255, 255, 0.5) 100%
  );
  position: absolute;
  top: -2px;
  left: -2px;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  border-top-width: 1.5px;
  border-top-style: solid;
  border-left-width: 1px;
  border-left-style: solid;
  border-color: #ffffff85;
  box-shadow: 4px 8px 13.1px #2b2b2b40, inset 4px 4px 20px #e5e7eb, inset -8px
    -8px 15.6px #e5e7eb;
  backdrop-filter: blur(16px) brightness(100%);
  -webkit-backdrop-filter: blur(16px) brightness(100%);
  background-blend-mode: luminosity;
  /* padding-bottom: 44px; */
  /* overflow: hidden; */
}

.element-monitor .cards {
  display: flex;
  flex-direction: column;
  width: calc(100% - 80px);
  /* height: calc(100vw - 350px); */
  align-items: flex-start;
  justify-content: space-between;
  position: absolute;
  top: 175px;
  left: 40px;
  /* z-index: -100; */
}

.element-monitor .frame {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 45px;
  position: relative;
  height: auto;
  flex-wrap: wrap;
  overflow: scroll;
  border-radius: 5px;
}

.element-monitor .div-2 {
  display: flex;
  flex-direction: column;
  width: 189px;
  align-items: flex-start;
  position: relative;
  box-shadow:
    0px 4px 6px #0000000d, 0px 10px 15px -3px #0000001a, inset 2px 2px 4px #00000040, inset -2px -2px 4px #00000040;
  border-radius: 4px;
}

.element-monitor .frame-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-radius: 4px 4px 0px 0px;
  height: 56px;
  overflow: hidden;
}

.ERRSTOP {
  background: linear-gradient(
    180deg,
    rgba(217, 94, 94, 1) 31%,
    rgba(207, 48, 48, 1) 100%
  );
}
.ERRSTOP .plus-btn {
  display: inline-flex !important;
}

.OK {
  background: linear-gradient(
    180deg,
    rgba(87, 188, 135, 1) 34%,
    rgba(56, 148, 100, 1) 100%
  );
}

.PLANSTOP {
  background: linear-gradient(
    180deg,
    rgba(107, 114, 128, 1) 34%,
    rgba(64, 76, 94, 1) 100%
  );
}

.CONFOK {
  background: linear-gradient(180deg, #E8D631 15.87%, #F4BE43 100%);
}

.element-monitor .frame-2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  height: 100%;
}

.element-monitor .text-wrapper {
  position: relative;
  width: fit-content;
  font-family: var(--noto-sans-med-24-font-family);
  font-weight: var(--noto-sans-med-24-font-weight);
  color: var(--variable-collection-neutral-white);
  font-size: var(--noto-sans-med-24-font-size);
  letter-spacing: var(--noto-sans-med-24-letter-spacing);
  line-height: var(--noto-sans-med-24-line-height);
  font-style: var(--noto-sans-med-24-font-style);
}

.element-monitor .plus-btn {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px;
  position: relative;
  flex: 0 0 auto;
  background-color: var(--variable-collection-neutral-white-duplicate);
  border-radius: 100px;
  box-shadow: 0px 4px 4px #00000040;
  display: none;
}

.element-monitor .plus {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(/img/plus-01-5.svg);
  background-size: 100% 100%;
}

.element-monitor .frame-3 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 24px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: var(--variable-collection-neutral-white);
  border-radius: 0px 0px 2px 2px;
}

.element-monitor .item-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.element-monitor .text-wrapper-2 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Noto Sans JP-Bold", Helvetica;
  font-weight: 700;
  color: var(--variable-collection-gray2);
  font-size: 16px;
  letter-spacing: -0.48px;
  line-height: normal;
  text-decoration: underline;
}

.element-monitor .frame-4 {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.element-monitor .frame-5 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.element-monitor .text-wrapper-3 {
  align-self: stretch;
  margin-top: -1.00px;
  font-family: var(--reg-16-font-family);
  font-weight: var(--reg-16-font-weight);
  color: var(--variable-collection-gray3);
  font-size: var(--reg-16-font-size);
  letter-spacing: var(--reg-16-letter-spacing);
  position: relative;
  line-height: var(--reg-16-line-height);
  font-style: var(--reg-16-font-style);
}

.element-monitor .text-wrapper-4 {
  align-self: stretch;
  font-family: var(--reg-16-font-family);
  font-weight: var(--reg-16-font-weight);
  color: var(--variable-collection-gray3);
  font-size: var(--reg-16-font-size);
  letter-spacing: var(--reg-16-letter-spacing);
  position: relative;
  line-height: var(--reg-16-line-height);
  font-style: var(--reg-16-font-style);
}

.element-monitor .frame-6 {
  display: flex;
  flex-direction: column;
  width: 53px;
  align-items: flex-end;
  gap: 8px;
  position: relative;
}

.element-monitor .text-wrapper-5 {
  align-self: stretch;
  margin-top: -1.00px;
  font-family: var(--bold-16-font-family);
  font-weight: var(--bold-16-font-weight);
  color: var(--variable-collection-gray1);
  font-size: var(--bold-16-font-size);
  text-align: right;
  letter-spacing: var(--bold-16-letter-spacing);
  position: relative;
  line-height: var(--bold-16-line-height);
  font-style: var(--bold-16-font-style);
  line-height: 39px;
}

.element-monitor .text-wrapper-6 {
  align-self: stretch;
  font-family: var(--bold-16-font-family);
  font-weight: var(--bold-16-font-weight);
  color: var(--variable-collection-gray1);
  font-size: var(--bold-16-font-size);
  text-align: right;
  letter-spacing: var(--bold-16-letter-spacing);
  position: relative;
  line-height: var(--bold-16-line-height);
  font-style: var(--bold-16-font-style);
  line-height: 24px;
}

.element-monitor .div-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-radius: 2px 2px 0px 0px;
  height: 56px;
}

.element-monitor .plus-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px;
  position: relative;
  flex: 0 0 auto;
  background-color: var(--variable-collection-neutral-white-duplicate);
  border-radius: 100px;
  box-shadow: 0px 4px 4px #00000040;
  opacity: 0;
}

.element-monitor .plus-2 {
  margin-top: -204.00px;
  margin-left: -457.25px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-13.png);
  background-size: 100% 100%;
}

.element-monitor .frame-7 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-radius: 2px 2px 0px 0px;
  height: 56px;
}

.element-monitor .plus-3 {
  margin-top: -206.00px;
  margin-left: -709.50px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-20.png);
  background-size: 100% 100%;
}

.element-monitor .DJT {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Noto Sans JP-Bold", Helvetica;
  font-weight: 700;
  color: var(--variable-collection-gray2);
  font-size: 16px;
  letter-spacing: -0.48px;
  line-height: normal;
  text-decoration: underline;
  white-space: nowrap;
}

.element-monitor .plus-4 {
  margin-top: -204.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-12.png);
  background-size: 100% 100%;
}

.element-monitor .plus-5 {
  margin-top: -204.00px;
  margin-left: -1214.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-11.png);
  background-size: 100% 100%;
}

.element-monitor .frame-8 {
  display: flex;
  align-items: center;
  gap: 63.25px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.element-monitor .plus-6 {
  margin-top: -459.00px;
  margin-left: -205.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-10.png);
  background-size: 100% 100%;
}

.element-monitor .frame-9 {
  background: linear-gradient(
    180deg,
    rgba(232, 214, 49, 1) 16%,
    rgba(244, 190, 67, 1) 100%
  );
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-radius: 2px 2px 0px 0px;
}

.element-monitor .plus-7 {
  margin-top: -461.00px;
  margin-left: -457.25px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-4.png);
  background-size: 100% 100%;
}

.element-monitor .plus-8 {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-2.svg);
  background-size: 100% 100%;
}

.element-monitor .plus-9 {
  margin-top: -459.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-21.png);
  background-size: 100% 100%;
}

.element-monitor .plus-10 {
  margin-top: -461.00px;
  margin-left: -1214.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-14.png);
  background-size: 100% 100%;
}

.element-monitor .plus-11 {
  margin-top: -714.00px;
  margin-left: -205.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-19.png);
  background-size: 100% 100%;
}

.element-monitor .plus-12 {
  margin-top: -716.00px;
  margin-left: -457.25px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-8.png);
  background-size: 100% 100%;
}

.element-monitor .plus-13 {
  margin-top: -714.00px;
  margin-left: -709.50px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-7.png);
  background-size: 100% 100%;
}

.element-monitor .plus-14 {
  margin-top: -716.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-5.png);
  background-size: 100% 100%;
}

.element-monitor .plus-15 {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/image.svg);
  background-size: 100% 100%;
}

.element-monitor .plus-16 {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01.svg);
  background-size: 100% 100%;
}

.element-monitor .plus-17 {
  margin-top: -969.00px;
  margin-left: -457.25px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-22.png);
  background-size: 100% 100%;
}

.element-monitor .plus-18 {
  margin-top: -971.00px;
  margin-left: -709.50px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-15.png);
  background-size: 100% 100%;
}

.element-monitor .plus-19 {
  margin-top: -969.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-18.png);
  background-size: 100% 100%;
}

.element-monitor .plus-20 {
  margin-top: -971.00px;
  margin-left: -1214.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-2.png);
  background-size: 100% 100%;
}

.element-monitor .plus-21 {
  margin-top: -1226.00px;
  margin-left: -205.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-16.png);
  background-size: 100% 100%;
}

.element-monitor .plus-22 {
  margin-top: -1224.00px;
  margin-left: -457.25px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-9.png);
  background-size: 100% 100%;
}

.element-monitor .plus-23 {
  margin-top: -1224.00px;
  margin-left: -709.50px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-3.png);
  background-size: 100% 100%;
}

.element-monitor .plus-24 {
  margin-top: -1226.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-6.png);
  background-size: 100% 100%;
}

.element-monitor .plus-25 {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-3.svg);
  background-size: 100% 100%;
}

.element-monitor .plus-26 {
  margin-top: -1479.00px;
  margin-left: -205.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01.png);
  background-size: 100% 100%;
}

.element-monitor .plus-27 {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-4.svg);
  background-size: 100% 100%;
}

.element-monitor .plus-28 {
  margin-top: -1481.00px;
  margin-left: -709.50px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/image.png);
  background-size: 100% 100%;
}

.element-monitor .plus-29 {
  margin-top: -1481.00px;
  margin-left: -961.75px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-17.png);
  background-size: 100% 100%;
}

.element-monitor .plus-30 {
  margin-top: -1479.00px;
  margin-left: -1214.00px;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/plus-01-23.png);
  background-size: 100% 100%;
}

.element-monitor .to-top {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px;
  position: absolute;
  bottom: 82px;
  right: 110px;
  border-radius: 100px;
  border: 2px solid;
  border-color: #ffffff4c;
  box-shadow: 0px 4px 4px #00000040, inset 4px 4px 4px #0000001c;
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 0.5) 100%
  );
}

.element-monitor .img {
  position: relative;
  width: 24px;
  height: 24px;
}

.element-monitor .dropdown {
  gap: 24px;
  position: absolute;
  top: 40px;
  left: 40px;
  display: inline-flex;
  align-items: center;
}

.element-monitor .dropdown-2 {
  gap: 30px;
  position: relative;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
}

.element-monitor .div-3 {
  display: inline-flex;
  align-items: center;
  gap: 30px;
  position: relative;
  flex: 0 0 auto;
  cursor: pointer;
}

.element-monitor .div-4 {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  position: relative;
  flex: 0 0 auto;
}

.element-monitor .text-wrapper-7 {
  font-family: var(--reg-16-font-family);
  font-weight: var(--reg-16-font-weight);
  color: var(--variable-collection-gray2);
  position: relative;
  width: fit-content;
  font-size: var(--reg-16-font-size);
  letter-spacing: var(--reg-16-letter-spacing);
  line-height: var(--reg-16-line-height);
  font-style: var(--reg-16-font-style);
}

.element-monitor .factory-dropdown {
  display: flex;
  flex-direction: column;
  width: 128px;
  align-items: center;
  gap: 24px;
  padding: 8px 0px;
  position: relative;
  background-color: var(--variable-collection-neutral-white);
  border-radius: 2px;
  box-shadow: var(--shadow);
}

.element-monitor .frame-10 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.element-monitor .text-wrapper-8 {
  margin-top: -1.00px;
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--variable-collection-gray3);
  position: relative;
  width: fit-content;
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .process-dropdown {
  display: flex;
  flex-direction: column;
  width: 172px;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 8px 0px;
  position: relative;
  background-color: var(--variable-collection-neutral-white);
  border-radius: 2px;
  box-shadow: var(--shadow);
}

.element-monitor .line-dropdown {
  display: flex;
  flex-direction: column;
  width: 100px;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 8px 0px;
  position: relative;
  background-color: var(--variable-collection-neutral-white);
  border-radius: 2px;
  box-shadow: var(--shadow);
}

.element-monitor .blue-btn {
  display: inline-flex;
  height: 40px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 20px;
  position: relative;
  flex: 0 0 auto;
  border-radius: 8px;
  border: none;
  box-shadow: 2px 2px 4px -3px #0000002e, inset 1px 2px 3px #0077ef;
  background: linear-gradient(
    180deg,
    rgba(0, 120, 240, 1) 0%,
    rgba(0, 68, 136, 1) 100%
  );
}

.element-monitor .blue-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 2px;
  border-radius: 8px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.2) 0%,
    rgba(245, 245, 245, 0.2) 100%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  z-index: 1;
  pointer-events: none;
}

.element-monitor .text-wrapper-9 {
  width: fit-content;
  margin-top: -9.50px;
  margin-bottom: -5.50px;
  font-family: var(--bold-16-font-family);
  font-weight: var(--bold-16-font-weight);
  color: var(--variable-collection-neutral-white);
  font-size: var(--bold-16-font-size);
  letter-spacing: var(--bold-16-letter-spacing);
  position: relative;
  line-height: var(--bold-16-line-height);
  font-style: var(--bold-16-font-style);
}

.element-monitor .machine-toggle {
  display: flex;
  width: 155px;
  align-items: center;
  gap: 17px;
  padding: 2px 2px 2px 2px;
  position: relative;
  background-color: var(--color-white-duplicate);
  border-radius: 100px;
  border-right-width: 1px;
  border-right-style: solid;
  border-bottom-width: 0px;
  border-bottom-style: solid;
  border-color: var(--color-gray6-duplicate);
  box-shadow: var(--lightest-shadow);
  cursor: pointer;
}

.element-monitor .pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 10px 24px;
  position: relative;
  flex: 0 0 auto;
  border-radius: 40px;
  border-top-width: 1.5px;
  border-top-style: solid;
  border-color: #00448899;
  box-shadow: 0px 2px 4px -2px #0000000d, 0px 4px 6px -1px #0000001a, inset 2px
    2px 4px #ffffff94;
  background: linear-gradient(
    180deg,
    rgba(0, 120, 240, 1) 0%,
    rgba(0, 68, 136, 1) 100%
  );
  background-color: var(--variable-collection-primary2);
  position: absolute;
  height: 38px;
  width: 75px;
}
.machine-toggle .lablel {
  /* color: red; */
  inset: 0;
  display: flex;
  width: 150px;
  height: 38px;
  align-items: center;
  /* border: thin solid green; */
}
.machine-toggle .lablel div {
  flex: 1;
  text-align: center;
  width: 77px;
}

.element-monitor .text-wrapper-10 {
  width: fit-content;
  margin-top: -1.50px;
  text-shadow: 0px 2px 4px #0000001f;
  font-family: var(--noto-16-bold-font-family);
  font-weight: var(--noto-16-bold-font-weight);
  color: var(--color-white-duplicate);
  font-size: var(--noto-16-bold-font-size);
  letter-spacing: var(--noto-16-bold-letter-spacing);
  position: relative;
  line-height: var(--noto-16-bold-line-height);
  font-style: var(--noto-16-bold-font-style);
  /* box-shadow: var(--drop-1); */
}

.element-monitor .text-wrapper-11 {
  width: fit-content;
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--color-gray5-duplicate);
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  position: relative;
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .data {
  display: flex;
  width: 1206px;
  align-items: center;
  gap: 32px;
  position: absolute;
  top: 110px;
  left: 40px;
}

.element-monitor .red-tab {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  padding: 4px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.50px;
  margin-bottom: -1.50px;
  margin-left: -1.50px;
  border-radius: 2px;
  border: 1.5px solid;
  border-color: #d95d5d80;
}

.element-monitor .ellipse {
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(225, 131, 131, 1) 0%,
    rgba(215, 83, 83, 1) 100%
  );
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  aspect-ratio: 1;
}

.element-monitor .text-wrapper-12 {
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--variable-collection-gray2);
  position: relative;
  width: fit-content;
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .green-tab {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  padding: 4px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.50px;
  margin-bottom: -1.50px;
  border-radius: 2px;
  border: 1.5px solid;
  border-color: #45ad7680;
}

.element-monitor .ellipse-2 {
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(103, 189, 144, 1) 0%,
    rgba(63, 166, 112, 1) 100%
  );
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  aspect-ratio: 1;
}

.element-monitor .gray-tab {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  padding: 4px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.50px;
  margin-bottom: -1.50px;
  border-radius: 2px;
  border: 1.5px solid;
  border-color: #3741514c;
}

.element-monitor .ellipse-3 {
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  aspect-ratio: 1;
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(107, 114, 128, 1) 0%,
    rgba(76, 90, 112, 1) 100%
  );
  background-color: var(--variable-collection-gray3);
}

.element-monitor .yellow-tab {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  padding: 4px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.50px;
  margin-bottom: -1.50px;
  margin-right: -1.50px;
  border-radius: 2px;
  border: 1.5px solid;
  border-color: #e5a00080;
}

.element-monitor .ellipse-4 {
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  aspect-ratio: 1;
  background: radial-gradient(
    50% 50% at 50% 50%,
    rgba(241, 195, 90, 1) 0%,
    rgba(229, 160, 0, 1) 100%
  );
}

.element-monitor .outline-btn-small {
  display: inline-flex;
  height: 34px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 4px 16px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.00px;
  margin-bottom: -1.00px;
  margin-right: -1.00px;
  border-radius: 8px;
  border: 2px solid;
  border-color: var(--variable-collection-primary3);
}

.element-monitor .text-wrapper-13 {
  font-family: var(--noto-sans-bold-18-font-family);
  font-weight: var(--noto-sans-bold-18-font-weight);
  color: var(--variable-collection-primary3);
  font-size: var(--noto-sans-bold-18-font-size);
  letter-spacing: var(--noto-sans-bold-18-letter-spacing);
  position: relative;
  width: fit-content;
  line-height: var(--noto-sans-bold-18-line-height);
  font-style: var(--noto-sans-bold-18-font-style);
}

.element-monitor .frame-12 {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.element-monitor .text-wrapper-14 {
  font-family: var(--reg-16-font-family);
  font-weight: var(--reg-16-font-weight);
  color: var(--variable-collection-gray3-duplicate);
  position: relative;
  width: fit-content;
  font-size: var(--reg-16-font-size);
  letter-spacing: var(--reg-16-letter-spacing);
  line-height: var(--reg-16-line-height);
  font-style: var(--reg-16-font-style);
}

.element-monitor .text-wrapper-15 {
  width: fit-content;
  margin-top: -1.00px;
  font-family: var(--black-24-font-family);
  font-weight: var(--black-24-font-weight);
  color: var(--variable-collection-gray2-duplicate);
  font-size: var(--black-24-font-size);
  letter-spacing: var(--black-24-letter-spacing);
  position: relative;
  line-height: var(--black-24-line-height);
  font-style: var(--black-24-font-style);
}

.element-monitor .header-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 1440px;
  height: 98px;
}

.element-monitor .tab-bar {
  position: absolute;
  top: 98px;
  left: 93px;
  width: calc(100% - 96 * 2px);
  height: 10px;
  display: flex;
  border-radius: 40px;
  box-shadow:
    0px 2px 4px -2px #0000000d, 0px 4px 6px -1px #0000001a, inset 0px 4px 4px #ffffff40, inset 0px -2px 4px #ffffff40;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.2) 0%,
    rgba(255, 255, 255, 0.3) 100%
  );
}

.element-monitor .bar-wrapper {
  width: 112px;
  margin-left: 324px;
  display: flex;
  border-radius: 20px;
  box-shadow:
    0px 2px 4px -2px #0000000d, 0px 4px 6px -1px #0000001a, inset 0px 4px 4px #ffffff40, inset 0px -2px 4px #ffffff40;
  background: linear-gradient(
    180deg,
    rgba(0, 120, 240, 1) 0%,
    rgba(0, 68, 136, 1) 100%
  );
}

.element-monitor .bar {
  width: 112px;
  height: 10px;
  border-radius: 20px;
  box-shadow:
    0px 2px 4px -2px #0000000d, 0px 4px 6px -1px #0000001a, inset 0px 4px 4px #ffffff40, inset 0px -2px 4px #ffffff40;
  mix-blend-mode: overlay;
  background: linear-gradient(
    180deg,
    rgba(0, 120, 240, 1) 0%,
    rgba(0, 68, 136, 1) 100%
  );
  opacity: 0.6;
}

.element-monitor .tabs {
  gap: 111px;
  position: absolute;
  top: 58px;
  left: 80px;
  display: inline-flex;
  align-items: center;
}

.element-monitor .logo {
  position: relative;
  width: 98px;
  height: 19px;
  background-image: url(./img/logo-1.png);
  background-size: 100% 100%;
}

.element-monitor .tabs-2 {
  height: 34px;
  gap: 24px;
  position: relative;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
}

.element-monitor .active {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 24px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -1.00px;
  margin-bottom: -1.00px;
  margin-left: -1.00px;
  border-radius: 4px 4px 0px 0px;
  border-top-width: 1px;
  border-top-style: solid;
  border-right-width: 2px;
  border-right-style: solid;
  border-color: #ffffffb8;
  box-shadow: inset 4px 4px 6px #9ca3af40, inset -4px -4px 10px #9ca3af40, 2px
    0px 4.6px #00000040;
  backdrop-filter: blur(7.65px) brightness(100%);
  -webkit-backdrop-filter: blur(7.65px) brightness(100%);
  background-blend-mode: luminosity;
  background: linear-gradient(
    123deg,
    rgba(255, 255, 255, 0.6) 0%,
    rgba(255, 255, 255, 0.9) 100%
  );
}
.active a {
  font-weight: bold;
  color: black !important;
}

.element-monitor .text-wrapper-16 {
  width: fit-content;
  margin-top: -1px;
  font-family: var(--bold-16-font-family);
  font-weight: var(--bold-16-font-weight);
  color: var(--variable-collection-gray1);
  font-size: var(--bold-16-font-size);
  letter-spacing: var(--bold-16-letter-spacing);
  position: relative;
  line-height: var(--bold-16-line-height);
  font-style: var(--bold-16-font-style);
}

.element-monitor .tab-inactive {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 24px;
  position: relative;
  flex: 0 0 auto;
  border-radius: 4px 4px 0px 0px;
  box-shadow: inset 4px 4px 6px #9ca3af40, inset -4px -4px 10px #9ca3af40, 2px
    0px 4.6px #00000040;
  backdrop-filter: blur(7.65px) brightness(100%);
  -webkit-backdrop-filter: blur(7.65px) brightness(100%);
  background-blend-mode: luminosity;
  background: linear-gradient(
    123deg,
    rgba(255, 255, 255, 0.21) 0%,
    rgba(255, 255, 255, 0.37) 100%
  );
}

.element-monitor .text-wrapper-17 {
  width: fit-content;
  margin-top: -2.00px;
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--variable-collection-gray2);
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  position: relative;
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .text-wrapper-18 {
  margin-top: -2.00px;
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--variable-collection-gray2);
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  white-space: nowrap;
  position: relative;
  width: fit-content;
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .tab-icon {
  display: inline-flex;
  height: 39px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 24px;
  position: relative;
  flex: 0 0 auto;
  border-radius: 4px 4px 0px 0px;
  box-shadow: inset 4px 4px 6px #9ca3af40, inset -4px -4px 10px #9ca3af40, 2px
    0px 4.6px #00000040;
  backdrop-filter: blur(7.65px) brightness(100%);
  -webkit-backdrop-filter: blur(7.65px) brightness(100%);
  background-blend-mode: luminosity;
  background: linear-gradient(
    123deg,
    rgba(255, 255, 255, 0.21) 0%,
    rgba(255, 255, 255, 0.37) 100%
  );
}

.element-monitor .frame-13 {
  display: inline-flex;
  align-items: flex-end;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -0.50px;
  margin-bottom: -0.50px;
}

.element-monitor .logout {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/logout-02.svg);
  background-size: 100% 100%;
}

.element-monitor .text-wrapper-19 {
  font-family: var(--noto-sans-med-16-font-family);
  font-weight: var(--noto-sans-med-16-font-weight);
  color: var(--variable-collection-gray2);
  font-size: var(--noto-sans-med-16-font-size);
  letter-spacing: var(--noto-sans-med-16-letter-spacing);
  white-space: nowrap;
  position: relative;
  width: fit-content;
  line-height: var(--noto-sans-med-16-line-height);
  font-style: var(--noto-sans-med-16-font-style);
}

.element-monitor .palette {
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url(./img/palette.svg);
  background-size: 100% 100%;
}

.element-monitor .menu {
  position: relative;
  width: 23.55px;
  height: 24px;
}


.table {
  width: 100%;
  border-collapse: collapse;
  border-radius: 0 4px 4px 4px;
  overflow: hidden;
}

.table th {
  padding: 10px
}
.table a {
  color: inherit !important;
}

thead {
  color: #4C5A70;
}
thead th {
  padding: 4px 16px;
  /* line-height: 30px; */
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  /* color: #4C5A70; */
}
.table tbody tr {
  background: #FFFFFF;
  color: #4C5A70;
}
.table tbody td {
  padding: 0px 16px;
  line-height: 30px;
  text-align: right;
  border-left: 1px solid rgba(229, 231, 235, 0.37);
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
}
.stop_factor_1, .stop_factor_0 {
  display: none;
}

.total {
  position: absolute;
  top: 485px;
  left: 40px;
  font-family: var(--reg-16-font-family);
  bottom: 0px;
  overflow: auto;
  width: calc(100% - 80px);
}
.table_sum th {
  border-left: 1px solid rgba(229, 231, 235, 0.37);
}
.stop_factor_view {
  display: inline;
}
.stop_factor_view i {
  background-image: url(/img/eye.svg);
}
.total_chart {
  font-family: var(--reg-16-font-family);
  background: #FFFFFF;
  border-width: 0px 1px 1px 0px;
  border-style: solid;
  border-color: #E5E7EB;
  /* shadow-sm */
  box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.08);
  border-radius: 10px;
  top: 120px;
  position: absolute;
  left: 40px;
  width: calc(100vw - 240px);
  height: 330px;
  color: #4C5A70;
}
.total_chart .title {
  /* border: thin solid green; */
  padding: 20px 30px;
}
.total_chart .year {
  display: inline-block;
  font-size: 30px;
  font-weight: 900;
  border-bottom: 2px solid #E5E7EB;
  margin-right: 20px;
  line-height: 40px;
  width: 75px;
  text-align: center;
}
.total_chart .legend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: 130px;
}
.total_chart .color {
  width: 24px;
  height: 24px;
  border-radius: 12px;
  box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.08);
}
.total_chart .text {
  /* width: 100px; */
  color: inherit;
}
.chart {
  /* border: thin solid green; */
  margin: 0px 30px 0 20px;
  height: calc(100% - 85px);
}
.insign_control {
  /* border: thin solid green; */
  margin-top: 40px;
  text-align: center;
  font-family: var(--noto-sans-med-24-font-family);
  width: 100%;
  color: #4C5A70;
  font-weight: 700;
  line-height: 19px;
  font-size: 16px;
  font-style: normal;
}
.insign_control label {
  margin-right: 12px;
}
.active_btn {
  justify-content: center;
  align-items: center;
  padding: 0px 26px;
  gap: 8px;
  background: linear-gradient(180deg, #0078F0 0%, #004488 100%);
  box-shadow: 2px 2px 4px -3px rgba(0, 0, 0, 0.18), inset 1px 2px 3px #0078F0;
  border-radius: 8px;
  color: white;
  height: 40px;
  border: none;
  line-height: inherit;
  font-size: 16px;
  font-weight: 600;
  display: inline-flex;
  cursor: pointer;
}
.small_btn {
  justify-content: center;
  align-items: center;
  /* padding: 0px 18px; */
  gap: 8px;
  border: 2px solid #0078F0 !important;
  border-radius: 8px;
  color: #0078F0;
  height: 32px;
  border: none;
  line-height: inherit;
  font-size: 14px;
  display: inline-flex;
  cursor: pointer;
  background: none;
  width: 110px;
  margin-right: 20px;
  font-weight: 600;
}

.iyear {
  font-size: 30px;
  font-family: 'Noto Sans JP', Helvetica;
  font-style: normal;
  font-weight: 700;
  font-size: 48px;
  line-height: 72px;
  letter-spacing: 0.04em;
  color: #4C5A70;
  flex: none;
  order: 0;
  flex-grow: 0;
  text-align: center;
  margin-top: 10px;
}
.insight-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 20px 20px;
  border-radius: 10px;
  box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1), 0px 1px 2px -1px rgba(0, 0, 0, 0.1);
  width: calc(50% - 44px);
  height: 400px;
  background-color: white;
  flex-direction: column;
  padding-bottom: 10px;
}
.insight-item h3, .insight-item h4 {
  font-size: 22px;
  font-family: 'Noto Sans JP', Helvetica;
  color: #253241;
  font-weight: 700;
  margin-top: 20px;
}
.insight-item h4 {
  font-size: 16px;
  margin-bottom: 12px;
}
.insight-item-content {
  width: 92%;
  height: 86%;
}
.insight-item-content canvas {
  margin: auto;
}
.legend {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
  margin-top: 8px;
  margin-bottom: 12px;
}

.legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-right: 18px;
  font-size: 14px;
  color: #333;
  font-family: 'Noto Sans JP', Helvetica;
}

.legend-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  flex-shrink: 0;
}

.top3-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 8px;
}

.top3-card {/* border: 1.5px solid #1a3060; */border-radius: 8px;overflow: hidden;filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.08));}

.top3-header {
background: #1a3060;
color: #fff;
text-align: center;
padding: 10px 6px 8px;
}

.top3-hours {
font-size: 22px;
font-weight: 900;
line-height: 1;
}

.top3-hours span {font-size: 12px;font-weight: 500;margin-left: 1px;}

.top3-label {font-size: 12px;font-weight: 700;margin-top: 4px;letter-spacing: 0.02em;}

.top3-body {padding: 8px 10px;background-color: #F9FAFB;text-align: center;}

.top3-diff {display: flex;align-items: center;gap: 5px;font-size: 12px;color: #333;margin-bottom: 10px;}

.top3-diff .badge {background: #1a3060;color: #fff;border-radius: 50%;width: 24px;height: 24px;display: flex;align-items: center;justify-content: center;font-size: 14px;flex-shrink: 0;}

.top3-note {display: flex;align-items: flex-start;gap: 4px;font-size: 12px;color: #555;/* border-top: 1px solid #eee; */padding-top: 10px;}

.top3-note .icon {
font-size: 11px;
flex-shrink: 0;
color: #888;
}

.divider {
height: 1px;
background: #e8eaf0;
margin: 10px 0;
}
.top3-grid {
width: 90%;
}
body {
  font-family: "Noto Sans JP-Bold", Helvetica;
}

/* ── Tag Grid ── */
.tag-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 24px;
}
.tag-row {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  align-items: center;
}
.tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11.5px;
  font-weight: 700;
  width: 66px;
  height: 28px;
  border-radius: 5px;
  color: #fff;
  cursor: default;
  flex-shrink: 0;
  letter-spacing: 0.01em;
  /* inner shadow to give slight depth like screenshot */
  box-shadow: inset 0 -1px 0 rgba(0,0,0,0.15), 0 1px 2px rgba(0,0,0,0.1);
}
/* Exact colors matched to screenshot */
.g  { background: #3daf6e; }   /* green  < 5%  */
.y  { background: #e8a800; }   /* yellow ~25%  */
.o  { background: #f07628; }   /* orange ~40%  */
.r  { background: #e03030; }   /* red    50%+  */

/* ── Legend ── */
.legend-wrap4 {
  display: flex;
  justify-content: flex-end;
  padding-right: 4px;
}

.legend4 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.leg-dots4 {
  display: flex;
  align-items: center;
}

.leg-dot4 {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  border: 2.5px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,0.22);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.leg-line4 {
  height: 3px;
  width: 56px;
  margin: 0 -1px;
  flex-shrink: 0;
  z-index: 0;
}

.leg-labels4 {
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
}

.leg-lbl4 {
  font-size: 11.5px;
  color: #374151;
  font-weight: 500;
  text-align: center;
  /* spacing: dot=17px, line=56px → total=17+56+17+56+17+56+17 = 236px, 4 labels over 236px */
  /* first label under first dot, then spaced by dot+line */
  width: 90px;
}
.leg-lbl4:first-child { width: 26px; margin-right: 30px; }
.leg-lbl4:nth-child(2){ width: 26px; margin-right: 30px; }
.leg-lbl4:nth-child(3){ width: 26px; margin-right: 30px; }
.leg-lbl4:nth-child(4){ width: 36px; }
.work_rate {
  background-color: #0078F0;
  border-radius: 4px 4px 0px 0px;
  width: 110px;
  height: 42px;
  color: white;
  font-weight: 700;
  font-size: 16px;
  line-height: 22px;
  border: none;
}
#detail_work_rate tr:first-child {
  background-color: #0078F0;
  color: white;
  font-size: 16px;
  font-weight: 700;
}
#detail_work_rate tr:last-child {
  background-color: #002B57;
  color: white;
  font-weight: 700;
}
.sumary {
  background: none;
  color: #4C5A70;
}
.sumary td {
  text-align: center;
  padding: 2px;
}
.sumary tr:nth-child(2) {
  font-weight: 700;
  font-size: 28px;
}
.chart_container {
  position: absolute;
  top: 120px;
  left: 40px;
  width: calc(100% - 80px);
  bottom: 20px;
  background-color: white;
  border-radius: 10px;
  border-width: 0px 1px 1px 0px;
  box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.08);
  overflow: scroll;
}

/* Chart Screen */
.chart_item {
  background: #fff;
  padding: 25px 85px;
  width: 100%;
  max-width: 100%;
  /* border: 1px solid #e3eaf2; */
}
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 13px;
}

.header-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.machine-id {
  font-weight: 700;
  font-size: 22px;
  color: #1a3a5c;
  letter-spacing: 0.04em;
}

.icon-btn {
  background: #1a7cd4;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
}

.unit-label {
  color: black;
  font-size: 13px;
  font-weight: 500;
}

/* Time axis */
.time-axis {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
}

.time-tick {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.time-tick:first-child { align-items: flex-start; }
.time-tick:last-child  { align-items: flex-end; }

.time-label {
  font-size: 12px;
  color: #5a7a99;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.time-sub {
  display: flex;
  align-items: center;
  gap: 2px;
  font-size: 11px;
  color: #b0c8e0;
}

/* Body row */
.body-row {
  display: flex;
  align-items: stretch;
  gap: 24px;
}

.bars-col {
  flex: 1;
  position: relative;
}

/* Segment bar */
.segment-bar {
  position: relative;
  height: 50px;
  background: #e8f0f8;
  border-radius: 7px;
  overflow: visible;
  /* border: 1px solid #dce8f2; */
}

.seg {
  position: absolute;
  top: 0;
  bottom: 0;
  transition: filter 0.15s;
  cursor: pointer;
}
.seg:hover { filter: brightness(1.12); z-index: 2; }

/* Tooltip */
.tooltip {
  display: none;
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  background: #1a3a5c;
  color: #fff;
  font-size: 11px;
  font-family: 'IBM Plex Mono', monospace;
  padding: 3px 8px;
  border-radius: 5px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 10;
}
.seg:hover .tooltip { display: block; }

/* Job bar row */
.job-row {
  position: relative;
  height: 26px;
  margin-top: 5px;
}

.job-bar {
  position: absolute;
  top: 4px;
  height: 18px;
  background: #1a6bbf;
  border-radius: 9px;
  display: flex;
  align-items: center;
  padding-left: 12px;
  overflow: hidden;
}

.job-label {
  color: #fff;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.job-end-marker {
  position: absolute;
  top: 0;
  width: 2px;
  height: 26px;
  background: #1a6bbf;
  border-radius: 2px;
}

/* Stats */
.stats-col {
  min-width: 140px;
  display: flex;
  flex-direction: column;
  justify-content: start;
  gap: 5px;
  padding-left: 20px;
  border-left: 1px solid #e3eaf2;
}

.stat-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.stat-label {
  font-size: 14px;
  color: #5a7a99;
  white-space: nowrap;
}

.stat-value {
  font-size: 15px;
  font-weight: 700;
  color: #1a3a5c;
  letter-spacing: 0.01em;
}
.login_container {
  border: thin solid #005EBD;
  background-color: white;
  border-radius: 12px;
  overflow: hidden;
  padding: 35px;
  margin: auto;
  width: 350px;
  margin-top: 200px;
  box-shadow: 0px 10px 15px -3px rgba(0, 0, 0, 0.1), inset -2px -2px 4px rgba(0, 0, 0, 0.25), inset 2px 2px 4px rgba(0, 0, 0, 0.25);
  filter: drop-shadow(0px 4px 6px rgba(0, 0, 0, 0.05));
}
.login_container input {
  width: 100%;
  padding: 10px;
  margin-bottom: 20px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
}
.login_container .btn:hover {
  background-color: #004a94;
  box-shadow: 0px 12px 20px -2px rgba(0, 0, 0, 0.15);
  transform: translateY(-2px);
  transition: all 0.3s ease;
  color: white;
}
.text-danger {
  color: red;
  font-size: 14px;
  margin-bottom: 10px;
}
.dropdown-content {
  position: absolute;
  background: #FAFAFA;
  padding: 8px;
  border-radius: 2px;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.12);
  position: absolute;
  top: 44px;
  width: 128px;
  display: none;
  cursor: pointer;
}
.dropdown-item {padding: 8px;color: rgba(107, 114, 128, 1);}
.dropdown-item:hover {
  background-color: #E5E7EB;
  color: rgba(76, 90, 112, 1);
}
.red-tab:hover, .red-tab.selected {
  border: 1.5px solid #D95E5E;
  background-color: rgba(217, 94, 94, 0.3);
}
.green-tab:hover, .green-tab.selected {
  border: 1.5px solid #45AE77;
  background-color: rgba(69, 174, 119, 0.3);
}
.gray-tab:hover, .gray-tab.selected {
  border: 1.5px solid #4C5A70;
  background-color: rgba(229, 231, 235, 0.9);
}
.yellow-tab:hover, .yellow-tab.selected {
  border: 1.5px solid #E5A000;
  background-color: rgba(229, 160, 0, 0.3);
}