/* frontend/src/style.css */

/* Global settings (not theme-specific, typically inherited from host or base HTML) */
#management-report-mfe {
  line-height: 1.5;
  font-weight: 400;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Base body styles (will be prefixed to #management-report-mfe body) */
#management-report-mfe {
  margin: 0;
  display: flex;
  min-width: 320px;
  min-height: 100vh;
  /* Removed direct color/background-color from here */
}

/* The MFE's root container itself. Primarily for layout, not theme colors directly. */
#management-report-mfe #management-report-mfe {
  width: 95%;
  /* Take full width of parent #management-report-mfe */
  margin: 0 auto;
  /* Center the content */
  padding: 1rem;
  text-align: center;
  /* Importantly: NO color or background-color here. These will be controlled by the theme classes below. */
}

/*
 * DARK MODE THEME VARIABLES (Default for the MFE)
 * These values are applied directly to the MFE's content wrapper via its class.
 * All subsequent elements will inherit these, or use the variables.
 * PostCSS will transform this to: `#management-report-mfe .mfe-theme-dark`
 */
#management-report-mfe .mfe-theme-dark {
  --main-bg: #1f2a38;
  /* Very Dark Desaturated Blue */
  --surface-bg: #2a3b4f;
  /* Dark Slate Blue (Cards, Inputs) */
  --surface-hover: #3b4f6a;
  /* Medium Dark Slate Blue (Hover states, Dropdowns) */
  --border-color: #4d6480;
  /* Medium Slate Blue (Borders) */
  --text-primary: #e8f1f9;
  /* Very Pale Blueish White */
  --text-secondary: #b0c4de;
  /* Lighter Slate Blue (Subtle text) */
  --primary-color: #4d8aff;
  /* Moderate Blue */
  --primary-hover: #336fcc;
  /* Darker Blue */
  --disabled-bg: #495057;
  /* Medium Grey (Neutral Disabled) */
  --disabled-text: #9fb3c8;
  /* Lighter Slate Grey */
  --link-color: #87cefa;
  /* Light Sky Blue */
  --link-hover: #ffd700;
  /* Gold */
  --border-dark: #000;
  /* Status colors (often consistent across themes, but defined here for completeness) */
  --status-green: #b1f98e;
  --status-yellow: #fdff84;
  --status-red: #fb7e7e;

  /* Explicitly set base colors for the MFE's content based on variables */
  color: var(--text-primary);
  background-color: var(--main-bg);

  /* Set basic layout for the content wrapper if needed */
  display: flex;
  /* Adjust if your App.vue doesn't need this */
  flex-direction: column;
  /* Adjust if your App.vue doesn't need this */
  min-height: 100vh;
  /* Ensure content takes full height within its context */
  width: 100%;
  /* Take full width of its parent */
  border: 0px solid;
  border-radius: 0.25rem;
}

/*
 * LIGHT MODE THEME VARIABLES (Overrides)
 * This class will be applied to the *inner* div in App.vue.
 * PostCSS will transform this to: `#management-report-mfe .mfe-theme-light`
 * It will override the variables defined in .mfe-theme-dark.
 */
#management-report-mfe .mfe-theme-light {
  --main-bg: #f8f9fa;
  --surface-bg: #ffffff;
  --surface-hover: #e9ecef;
  --border-color: #dee2e6;
  --text-primary: #212529;
  --text-secondary: #6c757d;
  --primary-color: #007bff;
  --primary-hover: #0086ff;
  --disabled-bg: #e2e6ea;
  --disabled-text: #adb5bd;
  --link-color: #007bff;
  --link-hover: #0056b3;

  --border-dark: #000;
  --status-green: #28a745;
  --status-yellow: #b5ad53;
  --status-red: #dc3545;

  /* Apply overrides to the inner div for its background/text colors */
  color: var(--text-primary);
  background-color: var(--main-bg);
  /* Set basic layout for the content wrapper if needed */
  display: flex;
  /* Adjust if your App.vue doesn't need this */
  flex-direction: column;
  /* Adjust if your App.vue doesn't need this */
  min-height: 100vh;
  /* Ensure content takes full height within its context */
  width: 100%;
  /* Take full width of its parent */
  border: 0px solid;
  border-radius: 0.25rem;
}

/*
 * GENERAL STYLES (now using CSS variables)
 * These selectors will be prefixed by PostCSS with '#management-report-mfe '.
 * Their colors will automatically resolve based on the active theme variables
 * defined on the #management-report-mfe element.
 */

#management-report-mfe h1 {
  font-size: 3.2em;
  line-height: 1.1;
  color: var(--text-primary);
}

#management-report-mfe a {
  font-weight: 500;
  color: var(--link-color);
  text-decoration: inherit;
}

#management-report-mfe a:hover {
  color: var(--link-hover);
}

#management-report-mfe button {
  margin: 0.2em;
  padding: 10px 18px;
  /* Consistent with Admin.css button padding */
  font-size: 1em;
  font-weight: 500;
  font-family: inherit;
  background-color: var(--primary-color);
  color: var(--text-primary);
  /* Button text color */
  border: 1px solid var(--primary-color);
  border-radius: 4px;
  cursor: pointer;
  transition:
    background-color 0.25s,
    border-color 0.25s,
    color 0.25s;
}

#management-report-mfe button:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
}

#management-report-mfe button:focus,
#management-report-mfe button:focus-visible {
  outline: 4px auto -webkit-focus-ring-color;
}

#management-report-mfe .card {
  padding: 2em;
  background-color: var(--surface-bg);
  color: var(--text-primary);
}
#management-report-mfe .login-container {
  max-width: 400px;
  margin: 40px auto;
  padding: 20px;
  border-radius: 8px;
  color: var(--text-primary);
  background-color: var(--surface-bg);
}

#management-report-mfe .login-container h2 {
  text-align: center;
  margin-bottom: 20px;
}

#management-report-mfe .login-container form {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.input {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.input label {
  font-weight: bold;
}

.input input {
  padding: 8px;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  background-color: var(--surface-bg);
  color: var(--text-primary);
}

#management-report-mfe button {
  padding: 10px;
  background-color: var(--primary-color);
  color: var(--text-primary);
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease-in-out;
}

#management-report-mfe button:hover {
  background-color: var(--primary-hover);
}

#management-report-mfe button:disabled {
  background-color: var(--disabled-bg);
  cursor: not-allowed;
}
.flatpickr-calendar {
  background: transparent;
  opacity: 0;
  display: none;
  text-align: center;
  visibility: hidden;
  padding: 0;
  -webkit-animation: none;
          animation: none;
  direction: ltr;
  border: 0;
  font-size: 14px;
  line-height: 24px;
  border-radius: 5px;
  position: absolute;
  width: 307.875px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  background: #3f4458;
  -webkit-box-shadow: 1px 0 0 #20222c, -1px 0 0 #20222c, 0 1px 0 #20222c, 0 -1px 0 #20222c, 0 3px 13px rgba(0,0,0,0.08);
          box-shadow: 1px 0 0 #20222c, -1px 0 0 #20222c, 0 1px 0 #20222c, 0 -1px 0 #20222c, 0 3px 13px rgba(0,0,0,0.08);
}
.flatpickr-calendar.open,
.flatpickr-calendar.inline {
  opacity: 1;
  max-height: 640px;
  visibility: visible;
}
.flatpickr-calendar.open {
  display: inline-block;
  z-index: 99999;
}
.flatpickr-calendar.animate.open {
  -webkit-animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
          animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.flatpickr-calendar.inline {
  display: block;
  position: relative;
  top: 2px;
}
.flatpickr-calendar.static {
  position: absolute;
  top: calc(100% + 2px);
}
.flatpickr-calendar.static.open {
  z-index: 999;
  display: block;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
  -webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
          box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-calendar .hasWeeks .dayContainer,
.flatpickr-calendar .hasTime .dayContainer {
  border-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.flatpickr-calendar .hasWeeks .dayContainer {
  border-left: 0;
}
.flatpickr-calendar.hasTime .flatpickr-time {
  height: 40px;
  border-top: 1px solid #20222c;
}
.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
  height: auto;
}
.flatpickr-calendar:before,
.flatpickr-calendar:after {
  position: absolute;
  display: block;
  pointer-events: none;
  border: solid transparent;
  content: '';
  height: 0;
  width: 0;
  left: 22px;
}
.flatpickr-calendar.rightMost:before,
.flatpickr-calendar.arrowRight:before,
.flatpickr-calendar.rightMost:after,
.flatpickr-calendar.arrowRight:after {
  left: auto;
  right: 22px;
}
.flatpickr-calendar.arrowCenter:before,
.flatpickr-calendar.arrowCenter:after {
  left: 50%;
  right: 50%;
}
.flatpickr-calendar:before {
  border-width: 5px;
  margin: 0 -5px;
}
.flatpickr-calendar:after {
  border-width: 4px;
  margin: 0 -4px;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
  bottom: 100%;
}
.flatpickr-calendar.arrowTop:before {
  border-bottom-color: #20222c;
}
.flatpickr-calendar.arrowTop:after {
  border-bottom-color: #3f4458;
}
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
  top: 100%;
}
.flatpickr-calendar.arrowBottom:before {
  border-top-color: #20222c;
}
.flatpickr-calendar.arrowBottom:after {
  border-top-color: #3f4458;
}
.flatpickr-calendar:focus {
  outline: 0;
}
.flatpickr-wrapper {
  position: relative;
  display: inline-block;
}
.flatpickr-months {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-months .flatpickr-month {
  background: #3f4458;
  color: #fff;
  fill: #fff;
  height: 34px;
  line-height: 1;
  text-align: center;
  position: relative;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  overflow: hidden;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  text-decoration: none;
  cursor: pointer;
  position: absolute;
  top: 0;
  height: 34px;
  padding: 10px;
  z-index: 3;
  color: #fff;
  fill: #fff;
}
.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,
.flatpickr-months .flatpickr-next-month.flatpickr-disabled {
  display: none;
}
.flatpickr-months .flatpickr-prev-month i,
.flatpickr-months .flatpickr-next-month i {
  position: relative;
}
.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
/*
      /*rtl:begin:ignore*/
/*
      */
  left: 0;
/*
      /*rtl:end:ignore*/
/*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,
.flatpickr-months .flatpickr-next-month.flatpickr-next-month {
/*
      /*rtl:begin:ignore*/
/*
      */
  right: 0;
/*
      /*rtl:end:ignore*/
/*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  color: #eee;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: #f64747;
}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 14px;
  height: 14px;
}
.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  -webkit-transition: fill 0.1s;
  transition: fill 0.1s;
  fill: inherit;
}
.numInputWrapper {
  position: relative;
  height: auto;
}
.numInputWrapper input,
.numInputWrapper span {
  display: inline-block;
}
.numInputWrapper input {
  width: 100%;
}
.numInputWrapper input::-ms-clear {
  display: none;
}
.numInputWrapper input::-webkit-outer-spin-button,
.numInputWrapper input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
}
.numInputWrapper span {
  position: absolute;
  right: 0;
  width: 14px;
  padding: 0 4px 0 2px;
  height: 50%;
  line-height: 50%;
  opacity: 0;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.15);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.numInputWrapper span:hover {
  background: rgba(192,187,167,0.1);
}
.numInputWrapper span:active {
  background: rgba(192,187,167,0.2);
}
.numInputWrapper span:after {
  display: block;
  content: "";
  position: absolute;
}
.numInputWrapper span.arrowUp {
  top: 0;
  border-bottom: 0;
}
.numInputWrapper span.arrowUp:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 4px solid rgba(255,255,255,0.6);
  top: 26%;
}
.numInputWrapper span.arrowDown {
  top: 50%;
}
.numInputWrapper span.arrowDown:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid rgba(255,255,255,0.6);
  top: 40%;
}
.numInputWrapper span svg {
  width: inherit;
  height: auto;
}
.numInputWrapper span svg path {
  fill: rgba(255,255,255,0.5);
}
.numInputWrapper:hover {
  background: rgba(192,187,167,0.05);
}
.numInputWrapper:hover span {
  opacity: 1;
}
.flatpickr-current-month {
  font-size: 135%;
  line-height: inherit;
  font-weight: 300;
  color: inherit;
  position: absolute;
  width: 75%;
  left: 12.5%;
  padding: 7.48px 0 0 0;
  line-height: 1;
  height: 34px;
  display: inline-block;
  text-align: center;
  -webkit-transform: translate3d(0px, 0px, 0px);
          transform: translate3d(0px, 0px, 0px);
}
.flatpickr-current-month span.cur-month {
  font-family: inherit;
  font-weight: 700;
  color: inherit;
  display: inline-block;
  margin-left: 0.5ch;
  padding: 0;
}
.flatpickr-current-month span.cur-month:hover {
  background: rgba(192,187,167,0.05);
}
.flatpickr-current-month .numInputWrapper {
  width: 6ch;
  width: 7ch\0;
  display: inline-block;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after {
  border-bottom-color: #fff;
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
  border-top-color: #fff;
}
.flatpickr-current-month input.cur-year {
  background: transparent;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: inherit;
  cursor: text;
  padding: 0 0 0 0.5ch;
  margin: 0;
  display: inline-block;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  line-height: inherit;
  height: auto;
  border: 0;
  border-radius: 0;
  vertical-align: initial;
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}
.flatpickr-current-month input.cur-year:focus {
  outline: 0;
}
.flatpickr-current-month input.cur-year[disabled],
.flatpickr-current-month input.cur-year[disabled]:hover {
  font-size: 100%;
  color: rgba(255,255,255,0.5);
  background: transparent;
  pointer-events: none;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
  appearance: menulist;
  background: #3f4458;
  border: none;
  border-radius: 0;
  box-sizing: border-box;
  color: inherit;
  cursor: pointer;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  height: auto;
  line-height: inherit;
  margin: -1px 0 0 0;
  outline: none;
  padding: 0 0 0 0.5ch;
  position: relative;
  vertical-align: initial;
  -webkit-box-sizing: border-box;
  -webkit-appearance: menulist;
  -moz-appearance: menulist;
  width: auto;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:focus,
.flatpickr-current-month .flatpickr-monthDropdown-months:active {
  outline: none;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
  background: rgba(192,187,167,0.05);
}
.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
  background-color: #3f4458;
  outline: none;
  padding: 0;
}
.flatpickr-weekdays {
  background: transparent;
  text-align: center;
  overflow: hidden;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 28px;
}
.flatpickr-weekdays .flatpickr-weekdaycontainer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
span.flatpickr-weekday {
  cursor: default;
  font-size: 90%;
  background: #3f4458;
  color: #fff;
  line-height: 1;
  margin: 0;
  text-align: center;
  display: block;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-weight: bolder;
}
#management-report-mfe .dayContainer,
.flatpickr-weeks {
  padding: 1px 0 0 0;
}
.flatpickr-days {
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 307.875px;
}
.flatpickr-days:focus {
  outline: 0;
}
#management-report-mfe .dayContainer {
  padding: 0;
  outline: 0;
  text-align: left;
  width: 307.875px;
  min-width: 307.875px;
  max-width: 307.875px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: inline-block;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
          flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-around;
          justify-content: space-around;
  -webkit-transform: translate3d(0px, 0px, 0px);
          transform: translate3d(0px, 0px, 0px);
  opacity: 1;
}
#management-report-mfe .dayContainer + .dayContainer {
  -webkit-box-shadow: -1px 0 0 #20222c;
          box-shadow: -1px 0 0 #20222c;
}
.flatpickr-day {
  background: none;
  border: 1px solid transparent;
  border-radius: 150px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: rgba(255,255,255,0.95);
  cursor: pointer;
  font-weight: 400;
  width: 14.2857143%;
  -webkit-flex-basis: 14.2857143%;
      -ms-flex-preferred-size: 14.2857143%;
          flex-basis: 14.2857143%;
  max-width: 39px;
  height: 39px;
  line-height: 39px;
  margin: 0;
  display: inline-block;
  position: relative;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}
.flatpickr-day.inRange,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.today.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day:focus,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.nextMonthDay:focus {
  cursor: pointer;
  outline: 0;
  background: #646c8c;
  border-color: #646c8c;
}
.flatpickr-day.today {
  border-color: #eee;
}
.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  border-color: #eee;
  background: #eee;
  color: #3f4458;
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  background: #80cbc4;
  -webkit-box-shadow: none;
          box-shadow: none;
  color: #fff;
  border-color: #80cbc4;
}
.flatpickr-day.selected.startRange,
.flatpickr-day.startRange.startRange,
.flatpickr-day.endRange.startRange {
  border-radius: 50px 0 0 50px;
}
.flatpickr-day.selected.endRange,
.flatpickr-day.startRange.endRange,
.flatpickr-day.endRange.endRange {
  border-radius: 0 50px 50px 0;
}
.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
  -webkit-box-shadow: -10px 0 0 #80cbc4;
          box-shadow: -10px 0 0 #80cbc4;
}
.flatpickr-day.selected.startRange.endRange,
.flatpickr-day.startRange.startRange.endRange,
.flatpickr-day.endRange.startRange.endRange {
  border-radius: 50px;
}
.flatpickr-day.inRange {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #646c8c, 5px 0 0 #646c8c;
          box-shadow: -5px 0 0 #646c8c, 5px 0 0 #646c8c;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
  color: rgba(255,255,255,0.3);
  background: transparent;
  border-color: transparent;
  cursor: default;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
  cursor: not-allowed;
  color: rgba(255,255,255,0.1);
}
.flatpickr-day.week.selected {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #80cbc4, 5px 0 0 #80cbc4;
          box-shadow: -5px 0 0 #80cbc4, 5px 0 0 #80cbc4;
}
.flatpickr-day.hidden {
  visibility: hidden;
}
.rangeMode .flatpickr-day {
  margin-top: 1px;
}
.flatpickr-weekwrapper {
  float: left;
}
.flatpickr-weekwrapper .flatpickr-weeks {
  padding: 0 12px;
  -webkit-box-shadow: 1px 0 0 #20222c;
          box-shadow: 1px 0 0 #20222c;
}
.flatpickr-weekwrapper .flatpickr-weekday {
  float: none;
  width: 100%;
  line-height: 28px;
}
.flatpickr-weekwrapper span.flatpickr-day,
.flatpickr-weekwrapper span.flatpickr-day:hover {
  display: block;
  width: 100%;
  max-width: none;
  color: rgba(255,255,255,0.3);
  background: transparent;
  cursor: default;
  border: none;
}
.flatpickr-innerContainer {
  display: block;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.flatpickr-rContainer {
  display: inline-block;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.flatpickr-time {
  text-align: center;
  outline: 0;
  display: block;
  height: 0;
  line-height: 40px;
  max-height: 40px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-time:after {
  content: "";
  display: table;
  clear: both;
}
.flatpickr-time .numInputWrapper {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 40%;
  height: 40px;
  float: left;
}
.flatpickr-time .numInputWrapper span.arrowUp:after {
  border-bottom-color: rgba(255,255,255,0.95);
}
.flatpickr-time .numInputWrapper span.arrowDown:after {
  border-top-color: rgba(255,255,255,0.95);
}
.flatpickr-time.hasSeconds .numInputWrapper {
  width: 26%;
}
.flatpickr-time.time24hr .numInputWrapper {
  width: 49%;
}
.flatpickr-time input {
  background: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: 0;
  border-radius: 0;
  text-align: center;
  margin: 0;
  padding: 0;
  height: inherit;
  line-height: inherit;
  color: rgba(255,255,255,0.95);
  font-size: 14px;
  position: relative;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}
.flatpickr-time input.flatpickr-hour {
  font-weight: bold;
}
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
  font-weight: 400;
}
.flatpickr-time input:focus {
  outline: 0;
  border: 0;
}
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
  height: inherit;
  float: left;
  line-height: inherit;
  color: rgba(255,255,255,0.95);
  font-weight: bold;
  width: 2%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-align-self: center;
      -ms-flex-item-align: center;
          align-self: center;
}
.flatpickr-time .flatpickr-am-pm {
  outline: 0;
  width: 18%;
  cursor: pointer;
  text-align: center;
  font-weight: 400;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #6a7395;
}
.flatpickr-input[readonly] {
  cursor: pointer;
}
@-webkit-keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
            transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
            transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
/* Global layout */
#management-report-mfe {
  font-family: sans-serif;
  margin: 0;
  padding: 0;
}

#management-report-mfe .metrics-dashboard {
  border-radius: 0.25rem;
  position: relative;
  padding: 2rem;
  width: 95%;
}

#management-report-mfe .summary-container {
  position: relative;
}

/* Utility Classes */
#management-report-mfe .hidden {
  display: none;
}

#management-report-mfe .no-data {
  text-align: center;
  padding: 20px;
}

#management-report-mfe .loading-indicator {
  text-align: center;
  padding: 10px;
}
#management-report-mfe .controls {
  display: flex;
  gap: 15px;
  margin-bottom: 20px;
  flex-wrap: wrap;
  align-items: center;
}

#management-report-mfe .controls select,
.controls input[type="text"],
.controls input[type="date"],
.controls input[type="number"] {
  padding: 8px 10px;
  background-color: var(--surface-bg);
  border: 1px solid var(--border-color);
  border-radius: 4px;
  color: var(--text-primary);
  min-width: 150px;
  box-sizing: border-box;
}

#management-report-mfe .controls label {
  margin-right: 5px;
  font-weight: normal;
}

#management-report-mfe .pagination {
  margin-top: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

#management-report-mfe .pagination button {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: var(--text-primary);
}

#management-report-mfe .pagination button:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
}

#management-report-mfe .pagination button:disabled {
  background-color: var(--disabled-bg);
  border-color: var(--disabled-bg);
  color: var(--disabled-text);
  cursor: not-allowed;
  opacity: 0.7;
}

#management-report-mfe .dropdown-actions {
  display: flex;
  justify-content: left;
  border-bottom: 1px solid var(--border-dark);
  align-items: center;
}

#management-report-mfe .dropdown-actions button {
  font-size: 0.85em;
  border-radius: 4px;
  cursor: pointer;
  background-color: var(--surface-hover);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  margin: 0 0 0 0;
}

#management-report-mfe .dropdown-actions button:hover {
  background-color: var(--primary-hover);
}
#management-report-mfe .navigation {
  margin-bottom: 15px;
}

#management-report-mfe .back-button {
  background-color: var(--primary-color);
  color: var(--text-primary);
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

#management-report-mfe .back-button:disabled {
  background-color: #9999;
  cursor: not-allowed;
  opacity: 0.7;
}

#management-report-mfe .back-button:hover {
  background-color: var(--primary-hover);
}

#management-report-mfe .control-container {
  position: relative;
  display: flex;
}

/* Dropdown styles */

#management-report-mfe .dropdown-man {
  position: relative;
  background-color: var(--surface-bg);
  border: 1px solid var(--border-dark);
  color: var(--text-primary);
  border-radius: 4px;
  max-height: 200px;
  min-width: 220px;
  overflow-y: auto;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  padding: 0.5rem;
}
#management-report-mfe .summary-toggle,
#management-report-mfe .column-toggle {
  display: flex;
  gap: 15px;
  margin-bottom: 20px;
  flex-wrap: wrap;
  justify-content: center;
}

#management-report-mfe .summary-toggle label,
#management-report-mfe .column-toggle label {
  display: flex;
  align-items: center;
  gap: 5px;
}

#management-report-mfe .summary-card {
  display: flex;
  gap: 0.4rem;
  margin: 1rem 0;
  justify-content: center;
  flex-wrap: wrap;
}

#management-report-mfe .summary-item {
  background-color: var(--surface-bg);
  padding: 1em;
  border-radius: 8px;
  min-width: 15rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

#management-report-mfe .summary-value {
  font-size: 16;
  font-weight: bold;
  margin-bottom: 2px;
  text-wrap: wrap;
}

#management-report-mfe .summary-label {
  color: var(--text-secondary);
  font-size: 14;
}
/* Table container */
#management-report-mfe .data-grid-container {
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
}

#management-report-mfe .data-grid-wrapper {
  position: relative;
  max-height: 80vh;
  overflow-x: auto;
}

#management-report-mfe .data-grid {
  position: relative;
  display: table;
  border-collapse: collapse;
  font-size: 16px;
  overflow-x: auto;
  width: max-content;
  min-width: 100%;
}

#management-report-mfe .data-grid .sticky-column {
  position: sticky;
  left: 0;
  z-index: 2;
  background-color: var(--main-bg);
  color: var(--text-primary);
  border-right: 2px solid var(--border-dark);
}

#management-report-mfe .data-grid th.sticky-column {
  z-index: 3;
}

#management-report-mfe .data-grid th {
  background-color: var(--main-bg);
  position: sticky;
  top: 0;
  z-index: 1;
  cursor: pointer;
  text-align: center;
  color: var(--text-primary);
  padding: 12px;
  border: 0px solid var(--border-dark);
}

#management-report-mfe .data-grid th:hover {
  background-color: var(--primary-hover);
}

/* Table cells */
#management-report-mfe .data-grid td {
  border: 2px solid var(--border-dark);
  padding: 12px;
  text-align: center;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 300px;
}

/* Ensure uniform row height */
#management-report-mfe .data-grid tr {
  height: 50px;
  border: 2px solid var(--border-dark);
}

#management-report-mfe .data-grid tr:hover {
  background-color: var(--primary-hover);
}

#management-report-mfe .row-overall {
  background-color: var(--main-bg);
  color: var(--text-primary);
}

#management-report-mfe .row-region {
  background-color: var(--surface-bg);
  color: var(--text-primary);
}

#management-report-mfe .row-branch {
  background-color: var(--surface-hover);
  color: var(--text-primary);
}

#management-report-mfe .row-team {
  background-color: var(--border-color);
  color: var(--text-primary);
}

#management-report-mfe .row-user {
  background-color: var(--user-row);
  color: var(--text-primary);
}

#management-report-mfe .row-zone {
  background-color: var(--main-bg);
  color: var(--text-primary);
}

#management-report-mfe .row-product {
  background-color: var(--text-light);
  color: var(--text-primary);
}

#management-report-mfe .clickable-name {
  color: var(--link-color);
  text-decoration: underline;
  cursor: pointer;
}

#management-report-mfe .clickable-name:hover {
  color: var(--link-hover);
}

#management-report-mfe .achieved-ahead {
  color: var(--status-green);
  font-weight: 800;
}

#management-report-mfe .achieved-close {
  color: var(--status-yellow);
  font-weight: 800;
}

#management-report-mfe .achieved-behind {
  color: var(--status-red);
  font-weight: 800;
}

#management-report-mfe .high-par {
  color: var(--status-red);
  font-weight: 800;
}
