/* RESETS */
:root {
  line-height: unset;
}

/*  */

body {
  display: flex;
  justify-content: center;
  align-items: center;
}

html,
body {
  /* BACKWARDS COMPATIBILITY */
  height: 100vh;
  overflow: visible;
}

body {
  padding: 2vh;
}

[v-cloak] {
  display: none;
}

.prayertimes-wrapper {
  --prop-border_width: 0.2026vmax;
  --prop-border_radius: 4vmax;
  --prop-padding-top: 2vmax;
  --prop-padding-bottom: 2vmax;
  --prop-padding-left: 2.5vmax;
  --prop-padding-right: 4vmax;

  display: flex;
  border-radius: var(--prop-border_radius);
  position: relative;
  flex-direction: row-reverse;
  column-gap: 3vw;
  width: 100%;
  height: 100%;
  min-width: 280px;
  padding-top: var(--prop-padding-top);
  padding-bottom: var(--prop-padding-bottom);
  padding-inline-end: var(--prop-padding-left);
  padding-inline-start: var(--prop-padding-right);
}

body {
  color: var(--color-text);
  font-size: 5vb;
}

.prayertimes-wrapper>.info {
  position: relative;
  display: grid;

  text-align: start;
  flex: 1;
  grid-template-rows: repeat(5, min-content) 1fr;
  grid-template-columns: 19.5vh 1fr;
}

.islamic-event {
  grid-row: 1 / 4;
  grid-column: -1 / 1;
}

.localtime {
  grid-row: 1;
  grid-column: 2 / 3;
}

.date {
  grid-row: 2;
  grid-column: 2 / 3;
}

#notification {
  grid-row: 3 / 7;
  grid-column: -1 / 1;
}

.sanad {
  grid-row: 3;
  grid-column: -1 / 1;
}

.content {
  grid-row: 4;
  grid-column: -1 / 1;
}

.source {
  grid-row: 5;
  grid-column: -1 / 1;
}

.campaign-notification-slider {
  grid-row: 6;
  grid-column: 1 / -1;
  position: relative;
  height: 18vh;
  width: 100%;
  align-self: end;
  z-index: 5;
}

#saying_decoration {
  grid-row: 6;
  grid-column: 2 / 3;
}

#masjid_logo {
  grid-row: 1 / 3;
  grid-column: 1 / 2;
}

.masjid_logo__shadow {
  grid-row: 1 / 3;
  grid-column: 1 / 2;
}

.islamic-event {
  top: 0;
  position: absolute;
}

.islamic-event__icon {
  width: 34vh;
  height: 25vh;
}

#masjid_logo {
  position: relative;
  width: 110%;
  height: 110%;
  margin-top: auto;
  /* Disable Hardware acceleration */
  transform: translateZ(0);

  object-fit: contain;
  object-position: center;
  aspect-ratio: 1;
}

.masjid_logo__shadow {
  position: absolute;
  top: 50%;
  inset-inline-end: 0;
  align-self: flex-start;

  width: 1.5vw;
  height: 90%;

  opacity: 0.3;
}

[dir="rtl"] .masjid_logo__shadow {
  border-top-left-radius: 100%;
  border-bottom-left-radius: 100%;
  transform: translate(-185%, -50%) scaleX(0.25);
  box-shadow: -0.25rem 0 0.5rem -0.05rem var(--color-text);
}

[dir="ltr"] .masjid_logo__shadow {
  border-top-right-radius: 100%;
  border-bottom-right-radius: 100%;
  transform: translate(185%, -50%) scaleX(0.25);
  box-shadow: 0.25rem 0 0.5rem -0.05rem var(--color-darker_text);
}

.masjid_logo__shadow::after {
  content: "";
  position: absolute;
  top: 0;
  inset-inline-start: 0;
  width: 1rem;
  height: 100%;
  background-color: var(--color-ui);
}

[dir="rtl"] .masjid_logo__shadow::after {
  transform: translateX(100%);
}

[dir="ltr"] .masjid_logo__shadow::after {
  transform: translateX(-100%);
}

.localtime,
.date {
  padding-inline-start: 5vw;
}

#saying_decoration {
  margin-inline-end: auto;
  margin-inline-start: 2vw;
}

.prayertimes-wrapper>.info>.icon {
  background-image: var(--url);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;

  height: 150px;
  /* aspect-ratio: var(--aspect); */
}

.prayertimes-wrapper>.mwaqeet {
  display: flex;
  flex-direction: column;
  /*
  margin: 0 1vw;
  width: 34vw;
  */
  width: 38vw;
}

.prayertimes-wrapper>.mwaqeet>.heading {
  color: var(--color-darker_text);
  text-align: center;
  font-size: 3vmax;
}

.prayertimes-wrapper>.mwaqeet>.prayers {
  display: flex;
  flex-direction: column;
  height: fit-content;
  text-align: end;
  justify-items: center;
  font-size: 7.5vb;
  line-height: 145%;
  width: 100%;
  padding-inline-end: 1.5vw;
}

.prayer__decoration {
  position: absolute;
  width: 94%;
  height: 100%;
  background-color: var(--color-subtle);
  z-index: -1;
  left: 3%;
}

.prayer--iqama-wait {
  color: var(--color-darker_text);
  font-weight: bolder;
}

.prayer {
  position: relative;
  display: flex;
  flex-direction: row-reverse;
  text-align: start;
  justify-content: flex-start;
  margin-bottom: -0.3vb;
}

.prayer__name {
  display: block;
  font-weight: bold;
  /*width: 13vw;*/
  flex: 1;
  line-height: 1.3;
  height: 1.5em;
  display: flex;
  justify-content: flex-start;
  align-items: end;
}

.prayer__image {
  width: 0.6em;
  height: 0.6em;
  fill: currentColor;
  margin-inline-end: 1.5vw;

  align-self: center;
}

.prayer__time {
  font-size: 8.5vb;
  width: 7vw;
  line-height: 1.1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  text-align: start;
  letter-spacing: -0.3vb;
  margin-top: 1.7vb;
}

.prayer__iqama-wait-duration {
  text-align: end;
  font-size: 6vb;
}

.localtime {
  color: var(--color-darker_text);
  font-size: 16vb;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-end;
  margin-top: 5.5vh;
  /* was vmax */
  line-height: 0.5;
}

.localtime::after {
  content: attr(m);
  font-weight: lighter;
  font-size: 14vb;
  margin-inline-start: 1vb;
}

.separator {
  position: relative;
  display: flex;

  flex-direction: column;
  justify-content: center;
  align-items: center;

  height: 45vh;
  aspect-ratio: 1 / 20;

  top: 17%;
}

.separator__line {
  width: 20%;

  background-color: var(--color-text);
  transform: scaleY(1.1);
}

.separator__line--large {
  height: 7%;
}

.separator__line--small {
  height: 1%;
}

.separator__line--flex {
  flex: 1;
}

.separator__circle {
  --radius: 1.25vh;
  position: relative;
  z-index: 1;

  width: var(--radius);
  height: var(--radius);
  border-radius: 50%;
}

.separator__circle--fill {
  background-color: var(--color-text);
}

.separator__circle--outline {
  background-color: var(--color-ui);
  border: 0.4vh solid var(--color-text);
}

.separator__circle--large {
  --radius: 2.25vh;
}

.separator__feather {
  position: absolute;
  width: 2vh;
  height: 2vh;
}

.separator__feather--top-left {
  bottom: 0;
  left: 0;
  transform: scaleX(-1) translateX(100%) translateX(-0.2vh);
}

.separator__feather--top-right {
  bottom: 0;
  right: 0;
  transform: scaleX(1) translateX(100%) translateX(-0.2vh);
}

.separator__feather--bottom-left {
  top: 0;
  left: 0;
  transform: scaleY(-1) scaleX(-1) translateX(100%) translateX(-0.4vh);
}

.separator__feather--bottom-right {
  top: 0;
  right: 0;
  transform: scaleY(-1) scaleX(1) translateX(100%) translateX(-0.4vh);
}

.sanad,
.content,
.source {
  text-align: start;
  font-weight: lighter;
}

.source {
  padding-inline-start: 3.5vb;
  font-size: 3vb;
}

.sanad {
  padding-inline-start: 3.5vb;
  margin-top: 0.75rem;
  margin-bottom: 0.10rem;
  font-size: 4.5vb;
  font-feature-settings: "ss01" 0;
}

.date {
  font-size: 4.9vb;
  /* font-weight: bold; */
  white-space: nowrap;
  font-feature-settings: "ss01" 0;
}

.campaign-notification {
  display: flex;
  align-items: center;
  gap: 2vmin;
  padding: 3vmin 2.5vmin 1.5vmin;
  position: absolute;
  bottom: 10px;
  left: 0;
  height: fit-content;
  width: 100%;
  box-sizing: border-box;

  border: 0.2vmax solid var(--color-border);
  border-radius: 1.5vmax;
  background-color: var(--color-ui);
  box-shadow: rgba(0, 0, 0, 0.1) 0 1vmin 1.38vmin -0.27vmin,
    rgba(0, 0, 0, 0.05) 0 0.37vmin 0.55vmin -0.18vmin;
  font-size: 1vmin;
}

.campaign-notification__icon {
  width: 1.3rem;
  height: 1.3rem;
  flex-shrink: 0;
  margin-bottom: auto;
}

.campaign-notification__icon * {
  fill: var(--color-darker_text);
}


.campaign-notification__title {
  font-size: 1rem;
  font-feature-settings: normal;
  white-space: pre-wrap;
  line-height: 1;
}

.campaign-notification__description {
  font-size: 0.7rem;
  margin-top: .5vmin;
}

.campaign-notification__qr {
  background: white;
  padding: 0.5vmax;
  border-radius: 5px;
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
}

#notification {
  position: absolute;

  top: 2.8vmin;
  inset-inline-end: 0;
  width: 100%;
  height: calc(100% - 8vb);

  z-index: 1;
  margin-top: 4vb;
  margin-inline-start: -1.125vmax;
  margin-bottom: 1.125vmax;
}

.content {
  font-size: 6.5vb;
  line-height: 1.35;
  font-weight: 700;
}

.timing-status {
  display: flex;
  position: relative;

  width: 80%;
  /* padding: 0.5vb; */
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.1vw;

  transform: translateY(20%);

  margin-inline: auto;

  background-color: var(--color-darker_text);
  color: var(--color-bright_text);

  font-size: 7.5vb;
  /* font-weight: bold; */
  /* line-height: 10vb; */
  text-align: center;
  white-space: nowrap;
}

.notification__body {
  white-space: pre-wrap;
}

.timing-status__span {
  flex: 1;
}

.timing-status__span--title {
  line-height: 1.6;
  font-size: 7vb;
}

.timing-status__span--start {
  text-align: end;
  /* padding-inline-end: 1vmin; */
}

.timing-status__span--end {
  text-align: start;
  padding-inline-start: 1vmin;
}

.clock {
  display: flex;
  justify-content: flex-end;
}

[dir="rtl"] .clock {
  flex-direction: row-reverse;
  justify-content: flex-start;
}

.timing-status .clock__part {
  letter-spacing: -0.2vb;
}

.clock__part {
  display: inline-block;
}

.swiggly-tip {
  position: absolute;
  height: 100%;
  top: 0;
}

.swiggly-tip--left {
  left: 0;
  transform: scale(-1) translateX(100%) translateX(-0.02rem);
}

.swiggly-tip--right {
  right: 0;
  transform: scale(1) translateX(100%) translateX(-0.02rem);
}

.notifications {
  --notification-icon-size: 14.75vmin;

  display: flex;
  flex-direction: column;
  position: relative;
  padding-bottom: 1vmin;

  text-align: center;
  line-height: 1.2;

  border: calc(0.45vmax / 2) solid var(--light-color-border);
  border-radius: 1.5vmax;
  background-color: var(--color-ui);
  box-shadow: rgba(0, 0, 0, 0.1) 0 1vmin 1.38vmin -0.27vmin,
    rgba(0, 0, 0, 0.05) 0 0.37vmin 0.55vmin -0.18vmin;
}

.notification__icon {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--notification-icon-size);
  height: var(--notification-icon-size);
  padding: 3vmin;

  border-radius: 50%;
  border: 1vmin solid var(--color-ui);

  background-color: var(--color-darker_text);
}

.notification__content-container {
  display: flex;
  flex: 1;
  min-height: 0;

  transition: transform 1s ease-in-out;
  transform: translateX(0%);
}

.notification__content-container {
  transform: translateX(calc(-1 * var(--x)));
}

[dir="rtl"] .notification__content-container {
  transform: translateX(calc(1 * var(--x)));
}

.notification__content {
  position: relative;
  min-width: 100%;
  width: 100%;
  height: 100%;

  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.notification__content--active {
  opacity: 1;
}

.notification__bullets {
  display: flex;
  gap: 0.92vmin;
  justify-content: center;
  align-items: center;
  padding-top: 0.37vmin;
  padding-bottom: 2vmin;
}

.notification__bullet {
  width: 1.3vmin;
  height: 1.3vmin;
  border-radius: 50%;
  background-color: var(--color-text);
  transition: background-color 0.3s ease, width 0.3s ease;
}

.notification__bullet--active {
  background-color: var(--color-darker_text);
  width: 2vmin;
  border-radius: 100vmax;
}

.notification__content {
  display: flex;
  flex-direction: column;
  padding-top: calc(var(--notification-icon-size) / 2 + 1vmin);
  padding-inline: 4vw;
  height: 100%;
  width: 100%;
  font-size: 1rem;
}

.notification__qr {
  position: absolute;
  bottom: -2vmin;
  inset-inline-end: 3vmin;
  width: 13vmin;
  height: 13vmin;

  color: black;
  padding: 0.5vmax;
  background: white;
  border-radius: 5px;
}

.notification__lesson-subject {
  font-size: 1em;
  color: var(--color-text);
}

.notification__lesson-author {
  font-size: 1em;
  padding-block: 0.92vmin;
  font-weight: bold;
  color: var(--color-darker_text);
}

.notification__lecture-subject {
  font-size: 1.7em;
  color: var(--color-text);
}

.notification__lecture-time {
  font-size: 1em;
  color: var(--color-text);
  font-feature-settings: "ss01" 0;
}

.notification__activity-time {
  font-size: 1em;
  color: var(--color-text);
  font-feature-settings: "ss01" 0;
}

.notification__lecture-author {
  font-size: 1.3em;
  padding-block: 0.92vmin;
  font-weight: bold;
  color: var(--color-darker_text);
}

.notification__lesson-title-label {
  font-size: 1.01em;
  margin-top: -0.5vmin;
  color: var(--color-text);
}

.notification__lesson-title {
  font-size: 1em;
  font-weight: bold;
  color: var(--color-darker_text);
}

.notification__header {
  font-size: 1.5em;
  /* please em should be used here to prevent the content from overflowing */
  /* was 7vb */
  font-weight: bold;
  color: var(--color-darker_text);
}

.notification__body {
  margin-block: auto;
  font-size: 1.2em;
  /* was 6.3vb */
  font-weight: normal;
  color: var(--color-text);
  margin-block: 0.3vmin;
  line-height: 1.3;
  font-feature-settings: "ss01" 0;
}

.notification__footer {
  margin-top: 0.5vmin;
  font-size: 0.9em;
  /* was 3.5vb */
  color: var(--color-text);
}


@media (orientation: landscape) {
  .campaign-notification__body {
    width: 100%;
  }
}

@media (orientation: portrait) {
  .portrait__header {
    display: flex;
    /* justify-self: flex-start; */
    flex-direction: row-reverse;
  }

  .localtime {
    grid-row: 1;
    grid-column: -1 / 1;
  }

  .date {
    grid-row: 2;
    grid-column: -1 / 1;
  }

  .islamic-event {
    display: none;
  }

  body {
    padding: 1.25dvh;
    font-size: 2vb;
  }

  .separator {
    display: none !important;
  }

  .prayertimes-wrapper {
    flex-direction: column;
    padding-block: 1dvh;
    padding-inline: 3.5vh;
  }

  .prayertimes-wrapper>.info {
    grid-template-columns: 100%;
    justify-items: center;
  }

  .campaign-notification__title {
    font-size: .9rem;
  }

  .campaign-notification__description {
    font-size: .7rem;
  }

  #saying_decoration {
    display: none;
  }

  .timing-status {
    /* line-height: 6vb; */
    font-size: 4.5vb;
    width: 80%;
  }

  .timing-status__span--title {
    /* line-height: 6vb; */
    font-size: 4.5vb;
    padding-top: 0.5vb;
  }

  .clock .clock__part {
    font-size: 5vb;
    letter-spacing: -0.1vb;
    /* margin-bottom: -0.5vb; */
  }

  .localtime .clock__part {
    font-size: 7vb;
    line-height: 1;
    letter-spacing: normal;
  }

  .localtime {
    margin-top: 4vh;
    line-height: 80%;
  }

  .date {
    font-size: 3vb;
    padding-bottom: 2vh;
  }

  .localtime,
  .date {
    padding-inline-start: 0;
    line-height: 0.5;
  }

  .clock {
    font-size: 5.5vb;
  }

  .sanad {
    padding-inline-start: 0;
    margin-top: 3vh;
    font-size: 2.5vb;
    font-feature-settings: "ss01" 0;
  }

  .source {
    padding-inline-start: 0;
    font-size: 2vb;
  }

  .content {
    font-size: 3vb;
    /* line-height: 1.4; */
    font-weight: 700;
  }

  .campaign-notification-slider {
    grid-row: 8 / 2;
    grid-column: 1;
    height: 15vh;
    margin-top: 3vh;
    bottom: -0.4rem;
    position: absolute;
  }

  .notification__header {
    font-size: 1.137em;
  }

  .notification__body {
    font-size: 0.96em;
    line-height: 1.4;
  }

  .notification__footer {
    font-size: 0.711em;
  }

  .sanad {
    grid-row: 3;
  }

  .content {
    grid-row: 4;
  }

  .source {
    grid-row: 5;
  }

  .sanad,
  .content,
  .source {
    text-align: center;
  }

  #masjid_logo {
    height: 12vh;
    margin-bottom: 1vh;
  }

  .localtime::after {
    font-size: 5vb;
  }

  .prayertimes-wrapper>.mwaqeet>.heading {
    font-size: 3vmax;
    margin-top: 1vmax;
  }

  .prayer__time {
    font-size: max(3.35vi, 4.85vb);
    margin-top: 0.2rem;
  }

  .prayer__iqama-wait-duration {
    font-size: max(2.25vi, 3.75vb);
    white-space: nowrap;
  }

  .prayertimes-wrapper>.mwaqeet>.prayers {
    font-size: 4vb;
    padding-inline: 3.33vw;
  }

  .prayer__name {
    padding-inline-start: 2.5vw;
  }

  #masjid_logo {
    grid-row: 7;
    grid-column: 1;
  }

  #notification {
    grid-row: 3 / 8;
    margin-top: calc(var(--notification-icon-size) / 2 - 1vh);
    margin-inline-start: 0;
    margin-bottom: 0;
    margin-top: 5vh;
    height: calc(100% - calc(var(--notification-icon-size) / 2 + 1.5vh));
  }

  .prayertimes-wrapper>.mwaqeet {
    width: 100%;
    margin: 0;
  }

  .info>.portrait__header {
    grid-row: 9;
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 16vh 1fr;
    grid-template-rows: auto auto;
    align-items: center;
    width: 93vw;
    padding-bottom: 1vh;
    position: relative;
    margin-inline-start: 5vh;
    align-self: end;
    margin-top: 1.5vh;
  }

  .info>.portrait__header #masjid_logo {
    grid-row: 1 / 3;
    grid-column: 1;
    position: relative;
    max-width: 14vh;
    max-height: 9.5vh;
    height: unset;
    margin: 0;
    object-fit: contain;
    margin-top: 2vh;
  }

  .info>.portrait__header .masjid_logo__shadow {
    position: absolute;
    inset-inline-start: 11.5vh;
    top: 58%;
  }


  .info>.portrait__header .date-time {
    grid-row: 1 / 3;
    grid-column: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-inline-start: 0;
  }

  .info>.portrait__header .localtime {
    margin-top: 0;
    padding-inline-start: 0;
    font-size: 14vb;
    line-height: 1;
  }

  .info>.portrait__header .localtime .clock__part {
    font-size: inherit;
  }

  .info>.portrait__header .localtime::after {
    font-size: 8vb;
  }

  .info>.portrait__header .date {
    padding-inline-start: 0;
    padding-bottom: 0;
    font-size: 2.5vb;
    text-align: start;
  }

  [dir="rtl"] .info>.portrait__header .masjid_logo__shadow {
    height: 85%;
    box-shadow: -0.18rem 0 0.3rem -0.02rem var(--color-text);
  }

  [dir="ltr"] .info>.portrait__header .masjid_logo__shadow {
    height: 85%;
    box-shadow: 0.18rem 0 0.3rem -0.02rem var(--color-text);
  }
}

/*  */
.background {
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;

  width: 100%;
  height: 100%;
  border-radius: inherit;

  --_offset: var(--prop-border_radius);
  --_inner-size: calc(100% - calc(var(--_offset) * 2));
}

.background>* {
  position: absolute;
}

.background>.background__side {
  background-color: var(--color-border);
  width: var(--_inner-size);
  height: var(--_inner-size);
}

.background>.background__corner {
  --_size: calc(var(--_offset) + 2px);
  width: var(--_size);
  height: var(--_size);

  --_scale_percent: 0%;
  transform: scale(var(--x), var(--y)) translateZ(0)
    /* Disable Hardware acceleration */
  ;
}

.background>.background__top_left {
  top: 0;
  left: 0;
  --x: 1;
  --y: 1;
}

.background>.background__top_right {
  top: 0;
  right: 0;
  --x: -1;
  --y: 1;
}

.background>.background__bottom_left {
  bottom: 0;
  left: 0;
  --x: 1;
  --y: -1;
}

.background>.background__bottom_right {
  bottom: 0;
  right: 0;
  --x: -1;
  --y: -1;
}

.background>.background__top {
  top: 0;
  left: var(--_offset);
  height: var(--prop-border_width);
}

.background>.background__left {
  top: var(--_offset);
  left: 0;
  width: var(--prop-border_width);
}

.background>.background__right {
  top: var(--_offset);
  right: 0;
  width: var(--prop-border_width);
}

.background>.background__bottom {
  bottom: 0;
  left: var(--_offset);
  height: var(--prop-border_width);
}

.background>.background__inner {
  background-color: var(--color-ui);
}

.background>.background__inner_top {
  width: var(--_inner-size);
  height: var(--_offset);
  left: var(--_offset);
  top: 0;
}

.background>.background__inner_center {
  width: 100%;
  height: var(--_inner-size);
  top: var(--_offset);
}

.background>.background__inner_bottom {
  width: var(--_inner-size);
  height: var(--_offset);
  left: var(--_offset);
  bottom: 0;
}

/* NEW MODIFIED */
.background-pattern {
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.splash {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-size: 2rem;
  z-index: 100;
}

.splash__prayer {
  width: 52%;
  height: 52%;
}

.splash__azkar {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
}

.splash>*>svg {
  width: 93%;
  height: 93%;
  display: block;
  margin: auto;
}

.fade-enter-active,
.fade-leave-active {
  transition: opacity 500ms ease;
}

.fade-enter-to,
.fade-leave-from {
  opacity: 1;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

.slide-fade-enter-active,
.slide-fade-leave-active {
  transition: transform 750ms ease, opacity 750ms ease;

  will-change: transform, opacity;
}

.slide-fade-enter-from {
  opacity: 0;
  transform: translateY(50%);
}

.slide-fade-enter-to {
  opacity: 1;
  transform: translateY(0);
}

.slide-fade-leave-from {
  opacity: 1;
  transform: translateY(0);
}

.slide-fade-leave-to {
  opacity: 0;
  transform: translateY(50%);
}

.sub-splash-enter-active,
.sub-splash-leave-active {
  transition: opacity 200ms ease, transform 300ms ease;
}

.sub-splash-enter-from {
  opacity: 0;
  transform: translateY(-10%);
}

.sub-splash-leave-to {
  opacity: 0;
  transform: translateY(10%);
}

.slide-up-enter-active,
.slide-up-leave-active {
  transition: opacity 0.2s ease-out, transform 0.2s ease-out;
}

.slide-up-enter-from {
  opacity: 0;
  transform: translateY(25%);
}

.slide-up-leave-to {
  opacity: 0;
  transform: translateY(-25%);
}

.clock-part-enter-active,
.clock-part-leave-active {
  transition: opacity 0.1s ease-out, transform 0.1s ease-out;
  transition-delay: var(--transition-delay);
}

.clock-part-enter-from {
  opacity: 0;
  transform: translateY(-25%);
}

.clock-part-leave-to {
  opacity: 0;
  transform: scale(0.5) translateY(25%);
}

.campaign-slide-enter-active {
  transition: transform 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),
    opacity 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 2;
}

.campaign-slide-leave-active {
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}

.campaign-slide-enter-from {
  transform: translateY(100%) scale(0.9);
  opacity: 0;
}

.campaign-slide-leave-to {
  transform: translateY(-20%) scale(0.85);
  opacity: 0;
}

.campaign-notification__bullets {
  position: absolute;
  bottom: 1vmin;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 1vmin;
  z-index: 10;
}

.campaign-notification__bullet {
  width: 1vmin;
  height: 1vmin;
  border-radius: 50%;
  background-color: var(--color-text);
  opacity: 0.3;
  transition: all 0.3s ease;
}

.campaign-notification__bullet--active {
  opacity: 1;
  background-color: var(--color-darker_text);
  transform: scale(1.2);
}