
:root {
  --fc-sticky-header-footer-z: 3;
  --fc-popover-z: 4;
}

.fc-YI {
  z-index: var(--fc-popover-z) !important;
}

.fc-Pm {
  isolation: isolate;
}

/*
This will prevent all ancestors from customizing their box size unless they use .contentBox
*/
.fc-3i,
.fc-3i *,
.fc-3i *:before,
.fc-3i *:after {
  box-sizing: border-box !important;
}

/* classes attached to <body> */
.fc-c8,
.fc-c8 * {
  cursor: not-allowed !important;
}

.fc-ZO {
  -ms-overflow-style: none !important; /* IE and Edge */
  scrollbar-width: none !important; /* Firefox */
}

/* Hide scrollbar for Chrome, Safari and Opera */
.fc-ZO::-webkit-scrollbar {
  display: none !important;
}

.fc-lS {
  flex-shrink: 0 !important;
}

.fc-MF .fc-2k {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
}

/* HACK for Safari. Can't do break-inside:avoid with flexbox items, likely b/c it's not standard:
   https://stackoverflow.com/a/60256345 */
.fc-Mp .fc-2k > * {
  float: left !important;
}

[dir=rtl] .fc-Mp .fc-2k > *,
.fc-Mp[dir=rtl] .fc-2k > * {
  float: right !important;
}

.fc-Mp .fc-2k::after {
  content: "" !important;
  display: block !important;
  clear: both !important;
}

.fc-Hl {
  cursor: pointer !important;
}

.fc-Pf {
  cursor: n-resize !important;
}

.fc-mb {
  cursor: s-resize !important;
}

.fc-0A {
  cursor: w-resize !important;
}

[dir=rtl] .fc-0A {
  cursor: e-resize !important;
}

.fc-AX {
  cursor: e-resize !important;
}

[dir=rtl] .fc-AX {
  cursor: w-resize !important;
}

.fc-fF {
  cursor: col-resize !important;
}

.fc-I8,
.fc-Gm,
.fc-v2 {
  position: absolute !important;
  box-sizing: content-box !important;
  width: 100% !important;
  height: 100% !important;
}

.fc-I8 {
  padding: 10px !important;
  margin: -10px !important;
}

.fc-Gm {
  padding-left: 10px !important;
  padding-right: 10px !important;
  margin-left: -10px !important;
  margin-right: -10px !important;
}

.fc-v2 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  margin-top: -10px !important;
  margin-bottom: -10px !important;
}

/* QUESTION: why not use -left -right instead of negative margins/padding for ALL? */
.fc-5q {
  position: absolute;
  top: 0;
  bottom: 0;
  left: -5px;
  right: -5px;
}

.fc-sC {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.fc-X3 {
  visibility: hidden;
}

/* Border Utils */
/* ------------------------------------------------------------------------------------------------- */

/* TODO: break-out to x and y. don't have "only" all */
/* TODO: instead of "border" utils, call them "borderless" to subtract? */

.fc-3m {
  border: 0 !important;
}

.fc-e5 {
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
}

.fc-jH {
  border-top: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
}

.fc-ur,
.fc-Ru {
  border-top: 0 !important;
  border-bottom: 0 !important;
}

.fc-ur {
  border-inline-end: 0 !important;
}

.fc-Ru {
  border-inline-start: 0 !important;
}

.fc-kC {
  border-left: 0 !important;
  border-right: 0 !important;
}

.fc-B2 {
  border-top: 0 !important;
  border-bottom: 0 !important;
}

/* for matching cell start-border, assumed to be 1px, which can't be guaranteed */
.fc-Zl {
  border-inline-start: 1px solid transparent !important;
}

/* Flexbox Utils */
/* ------------------------------------------------------------------------------------------------- */

.fc-Tx {
  display: flex !important;
  flex-direction: row !important;
}

.fc-iT {
  display: flex !important;
  flex-direction: column !important;
}

.fc-Jh {
  flex-grow: 1 !important;
}

.fc-uV {
  flex-grow: 1 !important;
  flex-basis: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
}

.fc-fP {
  min-height: 0 !important;
}

/*
TODO: use liquidX/Y elsewhere because frees up min other dimension; less collisions
*/
.fc-WN {
  flex-grow: 1 !important;
  flex-basis: 0 !important;
  min-width: 0 !important;
}

/* Print-Safe Utils (media:screen ONLY) */
/* ------------------------------------------------------------------------------------------------- */

.fc-MF .fc-oN,
.fc-MF .fc-2l {
  display: flex !important;
  flex-direction: column !important;
}

/* Table Utils */
/* ------------------------------------------------------------------------------------------------- */

.fc-DG {
  padding: 0 !important;
}

.fc-V7 {
  margin: 0 !important;
}

.fc-r1 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.fc-p5 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.fc-YJ {
  white-space: nowrap !important;
}

.fc-8L {
  white-space: pre !important;
}

/* Misc Utils */
/* ------------------------------------------------------------------------------------------------- */

.fc-AM {
  overflow-anchor: none;
}

.fc-ed {
  overflow: hidden !important;
}

/*
TODO: eventually use this on daygrid/timegrid events' inner, time, and title, FOR PRINT
Needed to prevent wrapping to multiple lines, increasing height, throwing off print-positioning,
which can't rely on dynamic height detection after print-flag activated.
*/
.fc-o5 {
  white-space: nowrap !important;
  overflow: hidden !important;
}

.fc-KG {
  position: relative !important;
}

.fc-x6 {
  position: absolute !important;
}

.fc-4r {
  inset-inline-start: 0 !important;
}

.fc-v4 {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
}

.fc-wX,
.fc-aR {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
}

.fc-2v,
.fc-6w {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
}

.fc-wX {
  top: 0 !important;
}

.fc-6w {
  left: 0 !important;
  right: 0 !important;
  width: 0 !important;
}

@media not print {
  .fc-1n {
    position: sticky !important;
  }

  .fc-n6 {
    position: sticky !important;
    top: 0 !important;
  }

  /* Sticks to either left or right (the flex "start") depending on ltr/rtl */
  .fc-ev {
    position: sticky !important;
    inset-inline-start: 0 !important;
  }

  .fc-xv {
    position: sticky !important;
    top: 0 !important;
    z-index: var(--fc-sticky-header-footer-z) !important;
  }
}

/* Only needed when padding/border must be separate from width/height */
.fc-4H {
  box-sizing: content-box !important;
}

.fc-FY {
  position: absolute !important;
  left: -10000px !important;
}

.fc-fV {
  align-items: center !important;
}

.fc-Eg {
  align-items: flex-start !important;
}

.fc-9C {
  align-items: flex-end !important;
}

/* Footer Scrollbar */
/* ------------------------------------------------------------------------------------------------- */

.fc-g8 {
  position: sticky !important;
  bottom: 0 !important;
  z-index: var(--fc-sticky-header-footer-z) !important;
}

.fc-4B > * {
  margin-top: -1px !important;
}

.fc-4B > * > * {
  height: 1px !important;
}

/* Print-Safe Utils */
/* ------------------------------------------------------------------------------------------------- */

.fc-Mp .fc-Uh {
  -moz-column-break-inside: avoid !important;
       break-inside: avoid !important;
}

.fc-Mp .fc-oN {
  display: table !important;
  table-layout: fixed !important;
  width: 100% !important;
  border-spacing: 0 !important;
  border-collapse: separate !important;
}

.fc-Mp .fc-2l {
  display: table-header-group !important;
  -moz-column-break-inside: avoid !important;
       break-inside: avoid !important;
  background: #fff !important;
  z-index: 9999 !important;
  position: relative !important;
}

.fc-WJ {
  /* min-height when multiple rows coexist, provides sane aspect-ratio for cells */
  min-height: 6em !important;
}

/* Z-index */
/* ------------------------------------------------------------------------------------------------- */

.fc-ti {
  z-index: 0;
}

.fc-iO {
  z-index: 1;
}

.fc-LC:focus-visible {
  z-index: 2;
}

/* INTERNAL MARKER -- used to mark an element for internal significance */
/* ------------------------------------------------------------------------------------------------- */

.fc-s0 {}

.fc-Tg {}
.fc-Rl {}
.fc-DD {}
.fc-ep {}
.fc-KH {}
.fc-aL {}
.fc-bL {}
.fc-PM {}

.fc-99 {}

.fc-XW {}

.fc-8n {}

.fc-1Y {}

.fc-Uz {}

.fc-wu {}
