:root[data-theme=light] {
  --bg: #F4F6FA;
  --text: #313E51;
  --bg-mobile: url(../../assets/images/pattern-background-mobile-light.svg);
  --bg-tablet: url(../../assets/images/pattern-background-tablet-light.svg);
  --bg-desktop: url(../../assets/images/pattern-background-desktop-light.svg);
  --btn-bg: #FFFFFF;
  --btn-shadow: #ABC1E1;
  --error: #EE5454;
}

:root[data-theme=dark] {
  --bg: #313E51;
  --text: #FFFFFF;
  --bg-mobile: url(../../assets/images/pattern-background-mobile-dark.svg);
  --bg-tablet: url(../../assets/images/pattern-background-tablet-dark.svg);
  --bg-desktop: url(../../assets/images/pattern-background-desktop-dark.svg);
  --btn-bg: #3B4D66;
  --btn-shadow: #2D3949;
  --error: #F4F6FA;
}

@font-face {
  font-family: Rubik;
  src: url(../../assets/fonts/static/Rubik-Medium.ttf);
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

button {
  border: none;
}

body {
  font-family: Rubik, sans-serif;
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-inline: auto;
  color: var(--text);
  background: var(--bg) var(--bg-mobile) center/cover no-repeat;
}
@media (min-width: 768px) {
  body {
    background-image: var(--bg-tablet);
  }
}
@media (min-width: 1024px) {
  body {
    background-image: var(--bg-desktop);
  }
}

.content {
  overflow: auto;
}

.switch {
  position: relative;
  display: inline-block;
  width: 32px;
  height: 20px;
}
@media (min-width: 768px) {
  .switch {
    width: 48px;
    height: 28px;
  }
}
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  background-color: rgb(167, 41, 245);
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: 0.4s;
}
.slider::before {
  background-color: #FFFFFF;
  position: absolute;
  content: "";
  left: 4px;
  bottom: 4px;
  transition: 0.4s;
  width: 12px;
  height: 12px;
}
@media (min-width: 768px) {
  .slider::before {
    width: 20px;
    height: 20px;
  }
}

input:checked + .slider {
  background-color: rgb(167, 41, 245);
}

input:hover + .slider {
  box-shadow: 0 0 4px #626C7F;
}

input:checked + .slider::before {
  transform: translateX(12px);
}
@media (min-width: 768px) {
  input:checked + .slider::before {
    transform: translateX(20px);
  }
}

.slider.round {
  border-radius: 20px;
}
.slider.round::before {
  border-radius: 50%;
}

.bar {
  width: 100%;
  height: 1rem;
  background-color: var(--btn-bg);
  box-shadow: 0 5px 10px var(--btn-shadow);
  border-radius: 10px;
  padding: 4px;
}
.bar__fill {
  width: 60%;
  height: 0.5rem;
  background-color: rgb(167, 41, 245);
  border-radius: 10px;
}

.error, .options-box, .card__box, .card__btn-index, .card, .subject, .header__right, .header__left, .header {
  display: flex;
  align-items: center;
  justify-content: center;
}

.hidden {
  display: none;
}

.content {
  width: 100%;
  max-width: 40rem;
}
@media (min-width: 1024px) {
  .content {
    max-width: 73rem;
  }
}

.header {
  justify-content: space-between;
  padding: 1rem 1.5rem;
}
.header__left {
  gap: clamp(0.5rem, 2vw, 1rem);
}
.header__right {
  gap: clamp(1rem, 2vw, 1.5rem);
}

.card {
  flex-direction: column;
  gap: clamp(2.5rem, 6vw, 8rem);
  padding: 2rem 1.5rem;
}
@media (min-width: 1024px) {
  .card {
    justify-content: space-between;
    flex-direction: row;
    align-items: start;
  }
}
.card__item {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.card__h1 {
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 400;
}
.card--bold {
  display: block;
  font-weight: 700;
}
.card--tall {
  font-size: clamp(5.5rem, 14vw, 9rem);
}
.card__h2 {
  font-size: clamp(1.25rem, 4vw, 2.25rem);
  line-height: 120%;
}
.card__p {
  font-size: clamp(0.875rem, 1.5vw, 1rem);
}
.card__btn {
  width: 100%;
  padding: 1rem;
  border-radius: 12px;
  text-align: left;
  background-color: var(--btn-bg);
  color: inherit;
  font-size: 1.15rem;
  height: 4.5rem;
  display: flex;
  align-items: center;
  box-shadow: 0 5px 10px var(--btn-shadow);
}
@media (min-width: 768px) {
  .card__btn {
    height: 5.5rem;
  }
}
@media (min-width: 1024px) {
  .card__btn {
    height: 6.5rem;
  }
}
.card__btn:hover {
  border: 4px solid rgb(167, 41, 245);
}
.card__btn:active {
  transform: scale(0.99);
}
.card__btn--answer {
  justify-content: space-between;
}
.card__btn--answer:hover {
  border: 4px solid rgb(167, 41, 245);
}
.card__btn--answer:hover .card__btn-index {
  background-color: rgb(167, 41, 245);
  color: #FFFFFF;
}
.card__btn--incorrect {
  border-color: #EE5454;
}
.card__btn--submit {
  height: 3.5rem;
  background-color: rgb(167, 41, 245);
  justify-content: center;
  color: #FFFFFF;
}
@media (min-width: 768px) {
  .card__btn--submit {
    height: 5.75rem;
  }
}
@media (min-width: 1024px) {
  .card__btn--submit {
    height: 104px;
  }
}
.card__btn--submit:hover {
  background-color: rgba(167, 41, 245, 0.5);
  border: none;
}
.card__btn-index {
  width: 40px;
  height: 40px;
  background-color: #EDF1F9;
  border-radius: 6px;
  padding: 10px;
  text-align: center;
  margin-right: 1rem;
  color: #626C7F;
}
.card__btn-index--orange {
  background-color: #FFF5ED;
}
.card__btn-index--green {
  background-color: #F4F6FA;
}
.card__btn-index--blue {
  background-color: #EBF0FF;
}
.card__btn-index--purple {
  background-color: #F6E7FF;
}
.card__btn-index--incorrect {
  background-color: #EE5454;
}
@media (min-width: 768px) {
  .card__btn-index {
    width: 56px;
    height: 56px;
  }
}
.card__box {
  flex-direction: column;
  gap: 1rem;
  background-color: var(--btn-bg);
  border-radius: 24px;
  padding: 3rem;
}

.selected {
  border: 4px solid rgb(167, 41, 245);
}
.selected .card__btn-index {
  background-color: rgb(167, 41, 245);
  color: #FFFFFF;
}

.correct-btn {
  border: 4px solid #2FD887;
}
.correct-btn .card__btn-index {
  background-color: #2FD887;
  color: #FFFFFF;
}

.incorrect-btn {
  border: 4px solid #EE5454;
}
.incorrect-btn .card__btn-index {
  background-color: #EE5454;
  color: #FFFFFF;
}

.error {
  color: var(--error);
  font-size: 1.15rem;
}/*# sourceMappingURL=styles.css.map */