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

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

.fc-A3 {
  isolation: isolate;
}

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

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

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

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

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

.fc-Yp .fc-Vv {
  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-sg .fc-Vv > * {
  float: left !important;
}

[dir=rtl] .fc-sg .fc-Vv > *,
.fc-sg[dir=rtl] .fc-Vv > * {
  float: right !important;
}

.fc-sg .fc-Vv::after {
  content: "" !important;
  display: block !important;
  clear: both !important;
}

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

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

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

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

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

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

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

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

.fc-yN,
.fc-Y1,
.fc-EP {
  position: absolute !important;
  box-sizing: content-box !important;
  width: 100% !important;
  height: 100% !important;
}

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

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

.fc-EP {
  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-ig {
  position: absolute;
  top: 0;
  bottom: 0;
  left: -5px;
  right: -5px;
}

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

.fc-ff {
  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-n1 {
  border: 0 !important;
}

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

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

.fc-3P,
.fc-VG {
  border-top: 0 !important;
  border-bottom: 0 !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

.fc-Yp .fc-XT,
.fc-Yp .fc-8D {
  display: flex !important;
  flex-direction: column !important;
}

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

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

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

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

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

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

.fc-3K {
  white-space: pre !important;
}

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

.fc-1y {
  overflow-anchor: none;
}

.fc-wt {
  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-ry {
  white-space: nowrap !important;
  overflow: hidden !important;
}

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

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

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

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

.fc-Mn,
.fc-Af {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
}

.fc-l2,
.fc-QP {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
}

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

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

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

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

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

  .fc-KQ {
    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-fj {
  box-sizing: content-box !important;
}

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

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

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

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

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

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

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

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

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

.fc-sg .fc-Eu {
  -moz-column-break-inside: avoid !important;
       break-inside: avoid !important;
}

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

.fc-sg .fc-8D {
  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-uq {
  /* min-height when multiple rows coexist, provides sane aspect-ratio for cells */
  min-height: 6em !important;
}

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

.fc-9p {
  z-index: 0;
}

.fc-0T {
  z-index: 1;
}

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

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

.fc-8F {}

.fc-UP {}
.fc-W8 {}
.fc-8g {}
.fc-kF {}
.fc-lN {}
.fc-K6 {}
.fc-N7 {}
.fc-Qn {}

.fc-K8 {}

.fc-2l {}

.fc-db {}

.fc-bE {}

.fc-Nd {}

.fc-3S {}
