.slide-fade-enter-active {
  transition: all 0.3s ease-out;
}

.slide-fade-leave-active {
  transition: all 0.8s cubic-bezier(1, 0.5, 0.8, 1);
}

.slide-fade-enter-from,
.slide-fade-leave-to {
  transform: translateX(-100%);
  opacity: 0;
}

.slide-open-enter-active {
  transition: all 0.5s cubic-bezier(1, 0.5, 0.8, 1);
}

.slide-open-leave-active {
  transition: all 0.5s cubic-bezier(1, 0.5, 0.8, 1);
}

.slide-open-enter-from,
.slide-open-leave-to {
  transform: translateX(-100%);
  opacity: 0;
}

.slide-open-enter-to,
.slide-open-leave-from {
  transform: translateX(0);
  opacity: 1;
}

.calendar-button {
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 1024px) {
  body::-webkit-scrollbar {
    display: none;
  }
}

.red-button {
  background-color: #dd0000;
  color: #fff;
  font-weight: 600;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.3s ease-in-out;
}

.red-button:hover {
  background-color: #000;
}

.white-button {
  background-color: #fff;
  color: #000;
  font-weight: 600;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.3s ease-out;
  border: 1px solid transparent;
}

.white-button:hover {
  background-color: #000;
  color: #fff;
  border-color: #fff;
}

.accent-hover:hover .accent-hover-child {
  transition: all 0.15s ease-out;
  box-shadow: -10px 10px 0 0 #dd0000, -10px 10px 0 0 #dd0000,
    -10px 10px 0 0 #dd0000, -10px 10px 0 0 #dd0000, -10px 10px 0 0 #dd0000;
}

.smooth-15 {
  transition: all 0.3s ease-out;
}

.smooth-30 {
  transition: all 0.3s ease-out;
}

/* Pagination */
.pagination {
  @apply self-center justify-self-end flex items-center justify-center gap-4;
}
.page-link:not(.break-view-link) {
  @apply flex items-center justify-center h-[36px] w-[36px] rounded-full border-2 border-accent font-[600] text-[18px] leading-[24px] text-accent cursor-pointer;
}
.page-link.active {
  @apply text-white bg-accent;
}

.page-link.prev-link-item.disabled,
.page-link.next-link-item.disabled {
  @apply opacity-50 cursor-not-allowed;
}

@media screen and (max-width: 1024px) {
  body::-webkit-scrollbar {
    display: none;
  }
}

button {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-family: inherit;
  justify-content: center;
  transition: all 0.3s ease-in-out;
}
button:disabled {
  cursor: not-allowed;
  opacity: 0.5;
  pointer-events: none;
}
button:focus {
  outline: none;
}
button:focus-visible {
  box-shadow: 0 0 0 3px rgba(164, 202, 254, 0.45);
}
button.btn-round {
  border-radius: 9999px;
}
button.btn-small {
  font-size: 12px;
  font-weight: 530;
  line-height: 1;
  padding: 12px 30px;
}
button.btn-red {
  --tw-bg-opacity: 1;
  --tw-text-opacity: 1;
  background-color: rgba(var(--ci-rgb));
  background-color: rgb(221 0 0 / var(--tw-bg-opacity));
  color: #fff;
  color: rgb(255 255 255 / var(--tw-text-opacity));
  font-weight: 600 !important;
}

.red-button {
  align-items: center;
  background-color: rgba(var(--ci-rgb));
  border-radius: 999px;
  color: #fff;
  display: flex;
  font-weight: 600;
  justify-content: center;
  text-align: center;
  transition: all 0.3s ease-in-out;
}
.red-button:hover {
  background-color: #000;
}
.white-button {
  align-items: center;
  background-color: #fff;
  border: 1px solid transparent;
  border-radius: 999px;
  color: #000;
  display: flex;
  font-weight: 600;
  justify-content: center;
  text-align: center;
  transition: all 0.3s ease-out;
}
.white-button:hover {
  background-color: #000;
  border-color: #fff;
  color: #fff;
}
.accent-hover:hover .accent-hover-child {
  box-shadow: -10px 10px 0 0 rgba(var(--ci-rgb));, -10px 10px 0 0 rgba(var(--ci-rgb));, -10px 10px 0 0 rgba(var(--ci-rgb));
    -10px 10px 0 0 rgba(var(--ci-rgb));, -10px 10px 0 0 rgba(var(--ci-rgb));
  transition: all 0.15s ease-out;
}
.smooth-15,
.smooth-30 {
  transition: all 0.3s ease-out;
}
.pagination {
  align-items: center;
  align-self: center;
  display: flex;
  gap: 1rem;
  justify-content: center;
  justify-self: end;
}
.page-link:not(.break-view-link) {
  --tw-border-opacity: 1;
  --tw-text-opacity: 1;
  align-items: center;
  border-color: rgba(var(--ci-rgb));
  border-color: rgb(221 0 0 / var(--tw-border-opacity));
  border-radius: 9999px;
  border-width: 2px;
  color: rgba(var(--ci-rgb));
  color: rgb(221 0 0 / var(--tw-text-opacity));
  cursor: pointer;
  display: flex;
  font-size: 18px;
  font-weight: 600;
  height: 36px;
  justify-content: center;
  line-height: 24px;
  width: 36px;
}
.page-link.active {
  --tw-bg-opacity: 1;
  --tw-text-opacity: 1;
  background-color: rgba(var(--ci-rgb));
  background-color: rgb(221 0 0 / var(--tw-bg-opacity));
  color: #fff;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}
.page-link.next-link-item.disabled,
.page-link.prev-link-item.disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.main-navigation-desktop-submenu {
  position: absolute;
  margin-top: 0.5rem;
  transform-origin: top;
  border-radius: 12px;
  background-color: #fff;
  box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  white-space: normal;
  display: hidden;
  opacity: 0;
  scale: 0.95;
  transition: all 0.3s ease-out;
  pointer-events: none;
  user-select: none;
}

.main-navigation-desktop-submenu.active {
  display: flex;
  opacity: 1;
  scale: 1;
  pointer-events: auto;
  user-select: auto;
}

.input-container label {
  position: absolute;
  top: 17.5px;
  left: 12px;
  transition: all 0.3s ease;
  pointer-events: none;

  color: var(--accent-gray);
  font-size: 16px;
  line-height: 18px;
}

/* Change label font size and translate-y if input is focused */
.input-container input:focus + label {
  font-size: 10px;
  transform: translateY(-32px);
}

/* Change label font size and translate-y if input is not empty */
.input-container input:not(:placeholder-shown) + label {
  font-size: 10px;
  transform: translateY(-32px);
}

input.text-input {
  display: block;
  width: 100%;
  height: 52px;
  border-color: rgba(239, 239, 241, 0.5);

  padding: 0 12px;
  color: var(--accent-gray);
  font-size: 16px;
  line-height: 16px;
  transition: all 0.3s ease;
  background-color: rgba(239, 239, 241, 0.5);
}

textarea.textarea-input {
  display: block;
  width: 100%;
  height: 120px;
  border-color: rgba(239, 239, 241, 0.5);

  padding: 12px;
  color: var(--accent-gray);
  font-size: 16px;
  line-height: 16px;
  transition: all 0.3s ease;
  background-color: rgba(239, 239, 241, 0.5);
}

.input-container textarea + label {
  position: absolute;
  top: 11.5px;
  left: 12px;
  transition: all 0.3s ease;
  pointer-events: none;

  color: var(--accent-gray);
  font-size: 16px;
  line-height: 18px;
}

/* Change label font size and translate-y if input is focused */
.input-container textarea:focus + label {
  font-size: 10px;
  transform: translateY(-32px);
}

/* Change label font size and translate-y if input is not empty */
.input-container textarea:not(:placeholder-shown) + label {
  font-size: 10px;
  transform: translateY(-32px);
}

input:focus,
textarea:focus {
  outline: none;
  border-color: rgba(239, 239, 241, 0.5);
  background-color: rgba(239, 239, 241, 1);
}

.input-container label {
  position: absolute;
  top: 17.5px;
  left: 12px;
  transition: all 0.3s ease;
  pointer-events: none;

  color: var(--accent-gray);
  font-size: 16px;
  line-height: 18px;
}

/* Change label font size and translate-y if input is focused */
.input-container input:focus + label {
  font-size: 10px;
  transform: translateY(-32px);
}

/* Change label font size and translate-y if input is not empty */
.input-container input:not(:placeholder-shown) + label {
  font-size: 10px;
  transform: translateY(-32px);
}

input.text-input {
  display: block;
  width: 100%;
  height: 52px;
  border-color: rgba(239, 239, 241, 0.5);

  padding: 0 12px;
  color: var(--accent-gray);
  font-size: 16px;
  line-height: 16px;
  transition: all 0.3s ease;
  background-color: rgba(239, 239, 241, 0.5);
}

textarea.textarea-input {
  display: block;
  width: 100%;
  height: 120px;
  border-color: rgba(239, 239, 241, 0.5);

  padding: 12px;
  color: var(--accent-gray);
  font-size: 16px;
  line-height: 16px;
  transition: all 0.3s ease;
  background-color: rgba(239, 239, 241, 0.5);
}

.input-container textarea + label {
  position: absolute;
  top: 11.5px;
  left: 12px;
  transition: all 0.3s ease;
  pointer-events: none;

  color: var(--accent-gray);
  font-size: 16px;
  line-height: 18px;
}

/* Change label font size and translate-y if input is focused */
.input-container textarea:focus + label {
  font-size: 10px;
  transform: translateY(-32px);
}

/* Change label font size and translate-y if input is not empty */
.input-container textarea:not(:placeholder-shown) + label {
  font-size: 10px;
  transform: translateY(-32px);
}

input:focus,
textarea:focus {
  outline: none;
  border-color: rgba(239, 239, 241, 0.5);
  background-color: rgba(239, 239, 241, 1);
}

.media-library-page .video.presenter {
  display: none;
}

.media-library-page .video.presenter.is-active {
  display: block;
}
