.prepify-student-surface {
  display: grid;
  gap: 1.25rem;
}

.prepify-student-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 1rem;
}

.prepify-stat-card {
  display: flex;
  min-height: 8rem;
  flex-direction: column;
  justify-content: center;
  border-radius: var(--prepify-radius-lg);
  padding: 1.25rem;
  background: var(--prepify-surface);
  box-shadow: var(--prepify-shadow-sm);
}

.prepify-stat-card strong {
  color: var(--prepify-blue);
  font-size: 2rem;
  line-height: 1;
}

.prepify-student-row {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(9rem, .75fr) minmax(10rem, .85fr);
  gap: 1rem;
  align-items: center;
  border-radius: var(--prepify-radius-lg);
  padding: 1.25rem;
  background: var(--prepify-surface);
  box-shadow: var(--prepify-shadow-sm);
}

.prepify-student-row-title {
  color: var(--prepify-ink);
  font-weight: 700;
}

.prepify-student-row-meta {
  color: var(--prepify-muted);
  font-size: .875rem;
}

.prepify-offer-card {
  display: flex;
  min-height: 15rem;
  flex-direction: column;
  border: 1px solid var(--prepify-line);
  border-radius: var(--prepify-radius-lg);
  padding: 1.25rem;
  background: var(--prepify-surface);
  box-shadow: var(--prepify-shadow-sm);
}

.prepify-offer-card.is-featured {
  border-color: var(--prepify-violet);
  box-shadow: 0 18px 42px rgba(93, 53, 242, .15);
}

.prepify-offer-price {
  color: var(--prepify-ink);
  font-size: 2.25rem;
  font-weight: 800;
  line-height: 1;
}

.prepify-feedback-shell {
  max-width: 46rem;
  margin-inline: auto;
}

.student-catalog-page,
.student-my-exams-page {
  display: grid;
  gap: 1rem;
}

.student-catalog-topbar,
.student-page-hero {
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  background: rgba(255, 255, 255, .9);
  box-shadow: var(--prepify-shadow-sm);
}

.student-catalog-topbar {
  min-height: 4.5rem;
  padding: 1rem 1.25rem;
}

.student-catalog-topbar p,
.student-page-kicker {
  color: var(--prepify-violet);
  letter-spacing: 0;
}

.student-catalog-topbar h1,
.student-page-title {
  color: var(--prepify-blue);
  font-weight: 800;
  letter-spacing: 0;
}

.student-catalog-header-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: .75rem;
}

.student-catalog-mode-switch .btn {
  min-width: 5.75rem;
}

.student-offers-hero {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(247, 243, 255, .94) 58%, rgba(255, 244, 250, .9));
}

.student-context-pills span {
  border-color: var(--prepify-line);
  background: #ffffff;
  color: var(--prepify-ink);
}

.student-offer-metrics span,
.student-balance-pill {
  border-color: var(--prepify-line);
  background: #ffffff;
  color: var(--prepify-muted);
  box-shadow: 0 8px 18px rgba(45, 31, 122, .06);
}

.student-offer-metrics strong {
  color: var(--prepify-blue);
}

.student-catalog-grid {
  gap: 1rem;
}

.student-catalog-card {
  min-height: 17rem;
  border: 1px solid rgba(235, 232, 245, .96);
  border-radius: var(--prepify-radius-lg);
  background: #ffffff;
  box-shadow: var(--prepify-shadow-sm);
}

.student-catalog-card:hover {
  border-color: rgba(93, 53, 242, .38);
  box-shadow: var(--prepify-shadow-md);
}

.student-catalog-card-featured {
  border-color: rgba(255, 47, 178, .45);
}

.student-catalog-bundle-card,
.student-catalog-package-card {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--student-tone-bg) 82%, transparent) 0, transparent 44%),
    linear-gradient(180deg, #ffffff 0%, #fbf9ff 100%);
}

.student-catalog-card-accent {
  border-radius: 8px 8px 0 0;
  background: linear-gradient(90deg, var(--prepify-blue), var(--prepify-pink));
}

.student-catalog-icon,
.student-subject-orb,
.student-package-visual {
  border-radius: var(--prepify-radius-md);
}

.student-catalog-card h2,
.student-package-copy span {
  color: var(--prepify-ink);
}

.student-catalog-card p,
.student-package-copy small {
  color: var(--prepify-muted);
}

.student-card-kicker,
.student-savings-pill {
  background: rgba(255, 47, 178, .12);
  color: #b30d77;
  letter-spacing: 0;
}

.student-card-kicker-muted {
  background: rgba(117, 128, 150, .12);
  color: var(--prepify-muted);
}

.student-catalog-completed {
  display: inline-flex;
  margin-left: .35rem;
  border-radius: 999px;
  background: rgba(36, 197, 143, .14);
  color: #08785a;
  padding: .08rem .35rem;
  font-size: .66rem;
  font-weight: 800;
}

.student-catalog-card-footer {
  border-radius: 0 0 8px 8px;
  border-top-color: var(--prepify-line);
  background: rgba(251, 249, 255, .82);
}

.student-catalog-card-footer strong {
  color: var(--prepify-ink);
}

.student-summary-card,
.student-exam-row,
.student-empty-state {
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  background: #ffffff;
  box-shadow: var(--prepify-shadow-sm);
}

.student-summary-card {
  min-height: 5.25rem;
}

.student-summary-card strong,
.student-exam-primary-count strong,
.student-exam-primary-count span {
  color: var(--prepify-blue);
}

.student-exam-list-header {
  color: var(--prepify-muted);
  letter-spacing: 0;
}

.student-exam-row {
  align-items: stretch;
}

.student-exam-main h2 {
  color: var(--prepify-ink);
  font-weight: 800;
}

.student-exam-meta,
.student-exam-description,
.student-exam-time,
.student-action-note,
.student-exam-secondary-counts,
.student-exam-sources span {
  color: var(--prepify-muted);
}

.student-exam-sources {
  border-left-color: var(--prepify-line);
}

.student-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(93, 53, 242, .1);
  color: var(--prepify-violet);
}

.student-empty-state h2 {
  color: var(--prepify-ink);
}

.student-corrections-page,
.student-correction-status-page,
.student-feedback-page,
.student-correction-result-page {
  display: grid;
  gap: 1rem;
}

.student-status-card,
.feedback-ticket-row,
.feedback-ticket-primary > .card,
.feedback-ticket-side > .card {
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  background: #ffffff;
  box-shadow: var(--prepify-shadow-sm);
}

.student-status-card {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
}

.student-status-card-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
}

.student-status-card-header h2 {
  margin-bottom: .35rem;
  color: var(--prepify-blue);
  font-weight: 800;
  letter-spacing: 0;
}

.student-status-card-header p {
  max-width: 44rem;
  margin-bottom: 0;
  color: var(--prepify-muted);
}

.student-status-meter {
  min-width: 9rem;
  border-radius: var(--prepify-radius-md);
  padding: .85rem 1rem;
  background: linear-gradient(135deg, rgba(93, 53, 242, .1), rgba(255, 47, 178, .08));
  text-align: right;
}

.student-status-meter strong {
  display: block;
  color: var(--prepify-blue);
  font-size: 2rem;
  line-height: 1;
}

.student-status-meter span {
  color: var(--prepify-muted);
  font-size: .8rem;
}

.student-progress-track {
  height: .65rem;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(93, 53, 242, .1);
}

.student-progress-fill,
.student-result-progress span {
  width: 0;
  transition: width .28s ease;
}

.student-status-summary {
  margin-top: .25rem;
}

.student-status-timeline {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: .75rem;
}

.student-status-timeline > div {
  min-width: 0;
  border: 1px solid var(--prepify-line);
  border-radius: var(--prepify-radius-md);
  padding: .85rem;
  background: rgba(251, 249, 255, .78);
}

.student-status-timeline span {
  display: block;
  color: var(--prepify-muted);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
}

.student-status-timeline strong {
  display: block;
  overflow-wrap: anywhere;
  color: var(--prepify-ink);
  font-size: .9rem;
}

.feedback-ticket-list {
  display: grid;
  gap: .75rem;
}

.feedback-ticket-row {
  border-color: rgba(235, 232, 245, .92);
}

.feedback-ticket-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}

.feedback-ticket-id,
.feedback-ticket-meta,
.feedback-image-tile figcaption small,
.feedback-detail-label {
  color: var(--prepify-muted);
  font-size: .8125rem;
}

.feedback-ticket-id {
  font-weight: 700;
}

.feedback-ticket-message {
  color: var(--prepify-ink);
}

.feedback-ticket-list .feedback-ticket-message {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.feedback-ticket-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .875rem;
}

.feedback-ticket-meta > span {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}

.feedback-ticket-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: start;
}

.feedback-ticket-primary,
.feedback-ticket-side {
  display: grid;
  gap: 1rem;
}

.feedback-image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: .75rem;
}

.feedback-image-tile {
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--prepify-line);
  border-radius: var(--prepify-radius-md);
  background: #fff;
}

.feedback-image-tile img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #f5f5f9;
  object-fit: cover;
}

.feedback-image-tile figcaption {
  display: grid;
  min-width: 0;
  gap: .125rem;
  padding: .625rem .75rem;
}

.feedback-image-tile figcaption span {
  overflow: hidden;
  color: var(--prepify-ink);
  font-size: .875rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.feedback-progress {
  display: grid;
  gap: .75rem;
}

.feedback-progress-step {
  display: grid;
  grid-template-columns: 2rem minmax(0, 1fr);
  gap: .75rem;
  align-items: start;
  color: var(--prepify-muted);
}

.feedback-progress-step > span {
  display: inline-flex;
  width: 2rem;
  height: 2rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f5f5f9;
  color: var(--prepify-muted);
  font-weight: 800;
}

.feedback-progress-step.is-active > span {
  background: rgba(93, 53, 242, .14);
  color: var(--prepify-violet);
}

.feedback-progress-step strong {
  display: block;
  color: var(--prepify-ink);
}

.feedback-progress-step small {
  display: block;
  color: var(--prepify-muted);
}

.feedback-detail-stack {
  display: grid;
  gap: .875rem;
}

.feedback-detail-stack > div {
  display: grid;
  min-width: 0;
  gap: .125rem;
}

.prepify-feedback-tickets-page,
.prepify-feedback-ticket-detail-page {
  width: min(100%, 64.5rem);
  margin: -.2rem auto 0;
  gap: 1.05rem;
}

.prepify-ticket-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid rgba(219, 211, 255, .72);
  border-radius: 1rem;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .98) 0%, rgba(255, 250, 255, .96) 100%);
  box-shadow: 0 1.15rem 3rem rgba(45, 31, 122, .08);
  padding: 1.45rem;
}

.prepify-ticket-hero-copy {
  min-width: 0;
}

.prepify-ticket-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .5rem;
  color: var(--prepify-violet);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: uppercase;
}

.prepify-ticket-hero .student-page-title {
  margin: 0 0 .35rem;
  color: var(--prepify-blue);
  font-size: 2.85rem;
  font-weight: 850;
  line-height: 1.02;
}

.prepify-ticket-hero .student-page-subtitle {
  max-width: 34rem;
  margin: 0;
  color: #757b90;
  font-size: .96rem;
  font-weight: 600;
  line-height: 1.45;
}

.prepify-ticket-primary-action {
  flex: 0 0 auto;
  min-height: 2.85rem;
  border: 0;
  border-radius: .75rem;
  background: #ff2fb2;
  box-shadow: 0 .8rem 1.45rem rgba(255, 47, 178, .24);
  font-weight: 850;
}

.prepify-ticket-primary-action:hover,
.prepify-ticket-primary-action:focus-visible {
  background: #f51ca6;
}

.prepify-ticket-back-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  margin-bottom: .7rem;
  color: #5d35f2;
  font-size: .82rem;
  font-weight: 850;
  text-decoration: none;
}

.prepify-ticket-back-link:hover,
.prepify-ticket-back-link:focus-visible {
  color: var(--prepify-blue);
  text-decoration: none;
}

.prepify-ticket-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
}

.prepify-ticket-summary-card {
  display: grid;
  gap: .35rem;
  min-width: 0;
  min-height: 6.25rem;
  align-content: center;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: .85rem;
  background: #ffffff;
  box-shadow: 0 .8rem 2rem rgba(45, 31, 122, .055);
  padding: 1rem 1.1rem;
}

.prepify-ticket-summary-card span {
  color: #8a8fa2;
  font-size: .72rem;
  font-weight: 850;
  line-height: 1.1;
  text-transform: uppercase;
}

.prepify-ticket-summary-card strong {
  display: block;
  overflow-wrap: anywhere;
  color: var(--prepify-blue);
  font-size: 1.9rem;
  font-weight: 900;
  line-height: 1;
}

.prepify-feedback-tickets-page .feedback-ticket-list {
  gap: .85rem;
}

.prepify-ticket-row {
  position: relative;
  display: grid;
  grid-template-columns: .42rem minmax(0, 1fr);
  min-height: 7.4rem;
  overflow: hidden;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: .95rem;
  background: #ffffff;
  box-shadow: 0 .85rem 2.15rem rgba(45, 31, 122, .06);
  padding: 0;
}

.prepify-ticket-status-rail {
  width: 100%;
  height: 100%;
  background: #b5b1c4;
}

.prepify-ticket-row.is-new .prepify-ticket-status-rail {
  background: #5d35f2;
}

.prepify-ticket-row.is-review .prepify-ticket-status-rail {
  background: #f59e0b;
}

.prepify-ticket-row.is-resolved .prepify-ticket-status-rail {
  background: #24c58f;
}

.prepify-ticket-row.is-dismissed .prepify-ticket-status-rail {
  background: #a7aec2;
}

.prepify-ticket-row .feedback-ticket-main {
  padding: 1.1rem 1.15rem;
}

.prepify-ticket-row-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
  margin-bottom: .6rem;
}

.prepify-ticket-id {
  color: #4f5364;
  font-size: .8rem;
  font-weight: 850;
}

.prepify-ticket-chip {
  display: inline-flex;
  min-height: 1.55rem;
  align-items: center;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 850;
  line-height: 1;
  padding: .28rem .62rem;
  white-space: nowrap;
}

.prepify-ticket-chip-category {
  background: #f1efff;
  color: #5d35f2;
}

.prepify-ticket-chip-status.is-new {
  background: rgba(93, 53, 242, .12);
  color: #5d35f2;
}

.prepify-ticket-chip-status.is-review {
  background: rgba(245, 158, 11, .14);
  color: #b86800;
}

.prepify-ticket-chip-status.is-resolved {
  background: rgba(36, 197, 143, .14);
  color: #0f8a64;
}

.prepify-ticket-chip-status.is-dismissed,
.prepify-ticket-chip-status.is-muted,
.prepify-ticket-chip-muted {
  background: #f1f2f6;
  color: #737b8f;
}

.prepify-ticket-row .feedback-ticket-message {
  margin: 0 0 .75rem;
  color: #343746;
  font-size: .95rem;
  font-weight: 650;
  line-height: 1.42;
}

.prepify-ticket-row .feedback-ticket-meta {
  color: #858ba0;
  font-size: .78rem;
  font-weight: 650;
}

.feedback-ticket-meta-item i {
  color: #a099c5;
  font-size: .95rem;
}

.prepify-ticket-row .feedback-ticket-actions {
  align-self: center;
}

.prepify-ticket-row .feedback-ticket-actions .btn {
  min-width: 6.4rem;
  min-height: 2.35rem;
  border: 0;
  border-radius: .62rem;
  background: #5d35f2;
  box-shadow: 0 .55rem 1.1rem rgba(93, 53, 242, .18);
  font-weight: 850;
}

.prepify-ticket-pagination {
  display: flex;
  justify-content: flex-end;
  padding-top: .25rem;
}

.prepify-ticket-empty {
  display: grid;
  justify-items: center;
  gap: .7rem;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: 1rem;
  background: #ffffff;
  box-shadow: 0 1rem 2.5rem rgba(45, 31, 122, .06);
  padding: 2rem 1.25rem;
  text-align: center;
}

.prepify-ticket-empty > span {
  display: inline-flex;
  width: 4.5rem;
  height: 4.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f1efff;
  color: #5d35f2;
  font-size: 2rem;
}

.prepify-ticket-empty h2 {
  margin: 0;
  color: var(--prepify-blue);
  font-size: 1.35rem;
  font-weight: 850;
}

.prepify-ticket-empty p {
  max-width: 25rem;
  margin: 0;
  color: #7d8294;
  font-size: .9rem;
  font-weight: 600;
}

.prepify-ticket-detail-grid {
  gap: 1rem;
}

.prepify-ticket-panel {
  display: grid;
  gap: 1rem;
  min-width: 0;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: .95rem;
  background: #ffffff;
  box-shadow: 0 .85rem 2.15rem rgba(45, 31, 122, .06);
  padding: 1.15rem;
}

.prepify-ticket-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .8rem;
}

.prepify-ticket-panel-header h2 {
  margin: 0;
  color: #2c3140;
  font-size: 1rem;
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.25;
}

.prepify-ticket-message-full {
  margin: 0;
  color: #343746;
  font-size: .98rem;
  font-weight: 600;
  line-height: 1.55;
  white-space: pre-wrap;
}

.prepify-ticket-empty-inline {
  display: inline-flex;
  min-height: 3.3rem;
  align-items: center;
  gap: .55rem;
  border: 1px dashed #d9d4ff;
  border-radius: .75rem;
  background: #fbf9ff;
  color: #7d8294;
  font-size: .9rem;
  font-weight: 700;
  padding: .85rem 1rem;
}

.prepify-ticket-empty-inline i {
  color: #5d35f2;
  font-size: 1.3rem;
}

.prepify-feedback-ticket-detail-page .feedback-progress {
  gap: .9rem;
}

.prepify-feedback-ticket-detail-page .feedback-progress-step {
  position: relative;
}

.prepify-feedback-ticket-detail-page .feedback-progress-step > span {
  background: #f1f2f6;
}

.prepify-feedback-ticket-detail-page .feedback-progress-step.is-active > span {
  background: #5d35f2;
  color: #ffffff;
}

.prepify-feedback-ticket-detail-page .feedback-progress-step strong {
  color: #343746;
  font-size: .88rem;
  font-weight: 850;
}

.prepify-feedback-ticket-detail-page .feedback-progress-step small {
  color: #858ba0;
  font-size: .75rem;
  font-weight: 600;
}

.prepify-feedback-ticket-detail-page .feedback-detail-stack {
  gap: .75rem;
}

.prepify-feedback-ticket-detail-page .feedback-detail-stack > div {
  border-bottom: 1px solid #f0edf8;
  padding-bottom: .72rem;
}

.prepify-feedback-ticket-detail-page .feedback-detail-stack > div:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.prepify-feedback-ticket-detail-page .feedback-detail-stack span:last-child {
  color: #343746;
  font-size: .86rem;
  font-weight: 750;
  line-height: 1.35;
}

.wallet-topup-page,
.payment-result-page {
  display: grid;
  gap: 1.35rem;
}

.prepify-wallet-page {
  width: min(100%, 64rem);
  margin: 0 auto;
  padding-top: 1.15rem;
}

.prepify-wallet-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(15rem, 18.5rem);
  align-items: end;
  gap: 1.5rem;
}

.prepify-wallet-hero .prepify-page-title {
  margin-bottom: .45rem;
  font-size: clamp(2.35rem, 3vw, 3.15rem);
  line-height: 1.06;
}

.prepify-wallet-hero .prepify-page-subtitle {
  max-width: 34rem;
  margin: 0;
  font-size: 1rem;
  line-height: 1.55;
}

.prepify-wallet-summary-card {
  display: grid;
  gap: .2rem;
  min-width: 0;
  padding: 1.1rem 1.2rem;
  border: 1px solid rgba(219, 211, 255, .78);
  border-radius: var(--prepify-radius-lg);
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 47, 178, .14), transparent 36%),
    linear-gradient(135deg, #ffffff 0%, #fff8fd 100%);
  box-shadow: 0 18px 46px rgba(45, 31, 122, .08);
}

.prepify-wallet-summary-card span {
  color: var(--prepify-violet);
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.prepify-wallet-summary-card strong {
  display: block;
  color: var(--prepify-blue);
  font-size: 1.7rem;
  font-weight: 900;
  line-height: 1.15;
}

.wallet-topup-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.16fr) minmax(17rem, .84fr);
  gap: 1.1rem;
  align-items: start;
}

.wallet-topup-card,
.payment-result-card {
  overflow: hidden;
  border: 1px solid rgba(219, 211, 255, .76);
  border-radius: var(--prepify-radius-lg);
  background: #ffffff;
  box-shadow: 0 24px 60px rgba(45, 31, 122, .08);
}

.wallet-topup-card {
  padding: 1.55rem 1.7rem 1.7rem;
}

.wallet-topup-card form {
  display: grid;
  gap: 1.15rem;
}

.wallet-topup-form-head,
.payment-result-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}

.wallet-topup-form-head h2,
.wallet-topup-aside h2,
.payment-result-copy h1 {
  margin: 0;
  color: var(--prepify-blue);
  font-weight: 800;
  letter-spacing: 0;
}

.wallet-topup-form-head h2 {
  font-size: 1.45rem;
  line-height: 1.15;
}

.wallet-range-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .45rem .8rem;
  background: rgba(93, 53, 242, .1);
  color: var(--prepify-violet);
  font-size: .8rem;
  font-weight: 800;
}

.wallet-credit-input-group .form-label,
.wallet-provider-section > .form-label {
  margin-bottom: .55rem;
  color: #3f4351;
  font-size: .9rem;
  font-weight: 800;
}

.wallet-credit-input-group .form-control {
  min-height: 3.35rem;
  border-color: #d8cffd;
  color: var(--prepify-blue);
  font-size: 1.45rem;
  font-weight: 900;
}

.wallet-credit-input-group .form-control:focus {
  border-color: var(--prepify-violet);
  box-shadow: var(--prepify-focus);
}

.wallet-credit-input-group .form-text {
  color: var(--prepify-muted);
  font-weight: 600;
}

.wallet-provider-section,
.wallet-provider-list {
  display: grid;
  gap: .85rem;
}

.payment-provider-option {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  border: 1px solid #d8cffd;
  border-radius: var(--prepify-radius-lg);
  padding: 1rem;
  background: #ffffff;
  cursor: pointer;
  transition: border-color .18s ease, box-shadow .18s ease, opacity .18s ease, background .18s ease;
}

.payment-provider-option:hover,
.payment-provider-option:focus-within {
  border-color: var(--prepify-violet);
  box-shadow: 0 14px 32px rgba(93, 53, 242, .12);
}

.payment-provider-option.is-selected {
  border-color: var(--prepify-blue);
  background: linear-gradient(135deg, #ffffff 0%, #f8f5ff 100%);
  box-shadow: inset 0 0 0 1px rgba(23, 0, 255, .35), 0 16px 34px rgba(45, 31, 122, .08);
}

.payment-provider-option.is-disabled {
  opacity: .55;
}

.wallet-provider-main,
.wallet-provider-costs,
.wallet-topup-summary div {
  display: flex;
  gap: .75rem;
}

.wallet-provider-main {
  min-width: 0;
  align-items: flex-start;
}

.wallet-provider-name {
  display: block;
  color: var(--prepify-ink);
  font-weight: 800;
}

.payment-provider-limit {
  color: var(--prepify-muted);
  font-size: .8rem;
  font-weight: 600;
}

.wallet-provider-costs {
  flex-direction: column;
  align-items: flex-end;
  color: var(--prepify-muted);
  font-size: .8rem;
  font-weight: 700;
}

.wallet-provider-costs strong {
  color: var(--prepify-ink);
}

.wallet-topup-summary {
  display: grid;
  gap: .75rem;
  border-top: 1px solid rgba(235, 232, 245, .9);
  padding-top: 1.1rem;
}

.wallet-topup-summary div {
  justify-content: space-between;
  color: var(--prepify-muted);
  font-weight: 700;
}

.wallet-topup-summary strong {
  color: var(--prepify-ink);
}

.wallet-topup-total {
  align-items: center;
}

.wallet-topup-total strong {
  color: var(--prepify-blue);
  font-size: 1.45rem;
  font-weight: 900;
}

.wallet-topup-summary .wallet-topup-message {
  display: block;
  justify-content: initial;
  border-radius: var(--prepify-radius-sm);
  background: rgba(245, 158, 11, .12);
  color: #9b6500;
  padding: .65rem .75rem;
  font-size: .84rem;
}

.prepify-wallet-submit {
  width: 100%;
  min-height: 3rem;
  border: 0;
  background: #ff2fb2;
  box-shadow: 0 14px 28px rgba(255, 47, 178, .22);
  font-weight: 800;
}

.prepify-wallet-submit:hover,
.prepify-wallet-submit:focus {
  background: #ee1ca3;
}

.prepify-wallet-submit:disabled {
  background: #d9d3ef;
  box-shadow: none;
}

.wallet-topup-aside {
  display: grid;
  gap: 1rem;
}

.wallet-topup-aside section {
  display: grid;
  gap: .45rem;
  padding: 1.15rem;
  border: 1px solid rgba(219, 211, 255, .72);
  border-radius: var(--prepify-radius-lg);
  background: rgba(255, 255, 255, .86);
  box-shadow: 0 14px 34px rgba(45, 31, 122, .07);
}

.wallet-topup-aside i {
  display: inline-flex;
  width: 2.6rem;
  height: 2.6rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(23, 0, 255, .12), rgba(255, 47, 178, .14));
  color: var(--prepify-blue);
  font-size: 1.3rem;
}

.wallet-topup-aside h2 {
  font-size: 1rem;
}

.wallet-topup-aside p,
.payment-result-copy p {
  margin: 0;
  color: var(--prepify-muted);
  font-weight: 600;
}

.wallet-topup-aside .alert-info {
  border: 1px solid rgba(219, 211, 255, .72);
  background: rgba(247, 245, 255, .9);
  color: var(--prepify-violet);
  font-weight: 700;
}

#tempAlert {
  transition: opacity .28s ease, transform .28s ease;
}

#tempAlert.is-hiding {
  opacity: 0;
  transform: translateY(-.25rem);
}

.payment-result-page {
  min-height: min(44rem, calc(100vh - 8rem));
  align-items: center;
  justify-items: center;
}

.prepify-payment-result-page {
  width: min(100%, 64rem);
  margin: 0 auto;
  padding-top: 1.15rem;
}

.payment-result-card {
  display: grid;
  position: relative;
  width: min(100%, 42.5rem);
  gap: 1.25rem;
  padding: 2rem;
  text-align: center;
}

.payment-result-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 47, 178, .14), transparent 34%),
    radial-gradient(circle at 0% 100%, rgba(93, 53, 242, .1), transparent 38%);
}

.payment-result-card > * {
  position: relative;
  z-index: 1;
}

.payment-result-icon {
  display: inline-flex;
  width: 4.5rem;
  height: 4.5rem;
  align-items: center;
  justify-content: center;
  justify-self: center;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(23, 0, 255, .12), rgba(255, 47, 178, .14));
  color: var(--prepify-blue);
  font-size: 2.35rem;
}

.payment-result-card.is-success .payment-result-icon {
  background: rgba(36, 197, 143, .14);
  color: #08785a;
}

.payment-result-card.is-failed .payment-result-icon {
  background: rgba(255, 78, 78, .12);
  color: #b42318;
}

.payment-result-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
  margin: 0;
}

.payment-result-summary div {
  min-width: 0;
  border: 1px solid rgba(219, 211, 255, .72);
  border-radius: var(--prepify-radius-lg);
  padding: .95rem;
  background: rgba(255, 255, 255, .82);
}

.payment-result-summary dt {
  margin-bottom: .25rem;
  color: var(--prepify-violet);
  font-size: .75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.payment-result-summary dd {
  margin-bottom: 0;
  color: var(--prepify-blue);
  font-size: 1.1rem;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.payment-result-actions {
  justify-content: center;
}

.payment-result-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 9.5rem;
  gap: .45rem;
  font-weight: 800;
}

.payment-result-actions .btn-primary {
  border: 0;
  background: #ff2fb2;
  box-shadow: 0 14px 28px rgba(255, 47, 178, .22);
}

.payment-result-actions .btn-primary:hover,
.payment-result-actions .btn-primary:focus {
  background: #ee1ca3;
}

.student-active-exam-page,
.student-submitted-exam-page {
  display: grid;
  gap: 1rem;
  color: var(--prepify-ink);
}

.student-active-exam-hero,
.student-submitted-exam-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  padding: 1.25rem;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(247, 243, 255, .94) 58%, rgba(255, 244, 250, .9));
  box-shadow: var(--prepify-shadow-sm);
}

.student-active-exam-hero h1,
.student-submitted-exam-header h1 {
  margin: .15rem 0 0;
  color: var(--prepify-blue);
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: 0;
}

.student-active-exam-hero p,
.student-submitted-exam-header p {
  margin: .35rem 0 0;
  color: var(--prepify-muted);
}

.student-active-exam-page .student-result-kicker,
.student-submitted-exam-page .student-result-kicker {
  color: var(--prepify-violet);
  letter-spacing: 0;
}

.student-exam-timer {
  display: grid;
  min-width: 13rem;
  gap: .15rem;
  border: 1px solid rgba(93, 53, 242, .16);
  border-radius: var(--prepify-radius-lg);
  padding: .9rem 1rem;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(45, 31, 122, .08);
  text-align: right;
}

.student-exam-timer span,
.student-exam-timer small {
  color: var(--prepify-muted);
  font-size: .78rem;
  font-weight: 700;
}

.student-exam-timer strong {
  color: var(--prepify-blue);
  font-size: 2rem;
  line-height: 1;
}

.student-active-exam-content,
.student-exam-upload-form {
  display: grid;
  gap: 1rem;
}

.student-active-exam-content[hidden] {
  display: none;
}

.student-exam-instruction-modal {
  overflow: hidden;
  border: 0;
  border-radius: var(--prepify-radius-lg);
  box-shadow: var(--prepify-shadow-md);
}

.student-exam-instruction-modal .modal-header,
.student-exam-instruction-modal .modal-footer {
  border-color: var(--prepify-line);
  background: #ffffff;
}

.student-exam-instruction-modal .modal-header {
  align-items: flex-start;
}

.student-exam-instruction-modal .modal-title {
  color: var(--prepify-blue);
  font-weight: 800;
}

.student-exam-instruction-modal .modal-footer {
  justify-content: center;
}

.student-exam-instruction-list {
  display: grid;
  gap: .75rem;
  margin: 0;
  padding-left: 1.1rem;
  color: var(--prepify-ink);
}

.student-exam-lock-alert {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .85rem;
  align-items: start;
  border: 1px solid rgba(245, 158, 11, .28);
  border-radius: var(--prepify-radius-lg);
  padding: 1rem;
  background: rgba(245, 158, 11, .1);
  color: #8a5b00;
}

.student-exam-lock-alert i {
  display: inline-flex;
  width: 2.25rem;
  height: 2.25rem;
  align-items: center;
  justify-content: center;
  border-radius: var(--prepify-radius-md);
  background: rgba(245, 158, 11, .16);
  color: #9b6500;
  font-size: 1.25rem;
}

.student-exam-lock-alert strong,
.student-exam-lock-alert span {
  display: block;
}

.student-exam-lock-alert span {
  margin-top: .12rem;
  color: #9b6500;
  font-size: .86rem;
}

.protected-exam-pdf-viewer,
.student-original-exam-viewer {
  overflow: hidden;
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  background: #f8fafc;
  box-shadow: var(--prepify-shadow-sm);
  user-select: none;
}

.protected-exam-pdf-toolbar,
.student-original-exam-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid var(--prepify-line);
  background: #ffffff;
  padding: .7rem .85rem;
}

.protected-exam-pdf-toolbar strong,
.student-original-exam-toolbar strong {
  color: var(--prepify-ink);
  font-size: .92rem;
  font-weight: 800;
}

.protected-exam-pdf-actions,
.student-original-exam-actions {
  display: flex;
  align-items: center;
  gap: .4rem;
}

.protected-exam-pdf-status,
.student-original-exam-actions span {
  min-width: 6rem;
  color: var(--prepify-muted);
  font-size: .76rem;
  font-weight: 800;
  text-align: center;
}

.protected-exam-pdf-pages,
.student-original-exam-pages {
  height: min(68vh, 46rem);
  overflow: auto;
  padding: 1rem;
}

.protected-exam-pdf-page,
.student-original-exam-page {
  display: flex;
  justify-content: center;
  margin: 0 auto 1rem;
}

.protected-exam-pdf-page canvas,
.student-original-exam-page canvas {
  max-width: 100%;
  border: 1px solid #d8dee9;
  background: #ffffff;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .12);
}

.protected-exam-pdf-message,
.student-original-exam-message {
  display: flex;
  min-height: 12rem;
  align-items: center;
  justify-content: center;
  color: var(--prepify-muted);
  font-weight: 700;
  text-align: center;
}

.student-exam-upload-header,
.answer-upload-card-head,
.student-submit-panel,
.student-submitted-exam-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .85rem;
}

.student-exam-upload-header,
.answer-upload-card,
.student-submit-panel {
  border: 1px solid rgba(235, 232, 245, .92);
  border-radius: var(--prepify-radius-lg);
  background: #ffffff;
  box-shadow: var(--prepify-shadow-sm);
}

.student-exam-upload-header,
.answer-upload-card,
.student-submit-panel {
  padding: 1.15rem;
}

.student-exam-upload-header h2,
.answer-upload-card h3 {
  margin: .15rem 0 .25rem;
  color: var(--prepify-blue);
  font-weight: 800;
  letter-spacing: 0;
}

.answer-upload-card h3 {
  color: var(--prepify-ink);
  font-size: 1.05rem;
}

.student-exam-upload-header p,
.answer-upload-card p,
.student-submit-panel > div > span {
  margin-bottom: 0;
  color: var(--prepify-muted);
}

.student-exam-count-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .38rem .75rem;
  background: rgba(93, 53, 242, .1);
  color: var(--prepify-violet);
  font-size: .8rem;
  font-weight: 800;
}

.answer-upload-card {
  display: grid;
  gap: .85rem;
}

.answer-upload-card .form-control {
  min-height: 3rem;
}

.student-upload-file-list {
  margin: .4rem 0 0;
  padding-left: 1.1rem;
  color: var(--prepify-muted);
  font-size: .84rem;
}

.student-submit-panel {
  align-items: center;
}

.student-submit-panel > div {
  display: grid;
  min-width: 0;
  gap: .18rem;
}

.student-submit-panel strong {
  color: var(--prepify-ink);
}

.student-submit-panel .btn {
  min-width: 12rem;
}

.student-submit-panel .btn:disabled {
  border-color: rgba(93, 53, 242, .26);
  background: linear-gradient(135deg, rgba(93, 53, 242, .68), rgba(255, 47, 178, .42));
  box-shadow: none;
  color: #ffffff;
  opacity: 1;
}

.student-submit-panel .btn:disabled [data-submit-label] {
  color: #ffffff;
}

.prepify-catalog-figma {
  max-width: 64.25rem;
  margin-top: -1.375rem;
  margin-left: clamp(0rem, 4vw, 3.375rem);
  padding-top: .15rem;
  gap: 1.55rem;
}

.prepify-catalog-figma .alert {
  max-width: 44rem;
}

.prepify-pricing-hero {
  display: grid;
  gap: 3.6rem;
}

.prepify-catalog-bundles-only .prepify-pricing-hero {
  gap: 0;
}

.prepify-pricing-heading h1 {
  margin: 0 0 .45rem;
  color: var(--prepify-blue);
  font-size: clamp(2.1rem, 3vw, 2.55rem);
  font-weight: 800;
  line-height: 1.03;
  letter-spacing: 0;
}

.prepify-pricing-heading p {
  max-width: 48rem;
  margin: 0;
  color: #73758c;
  font-size: .95rem;
  line-height: 1.55;
}

.prepify-grade-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.prepify-grade-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .25rem;
  min-height: 2.75rem;
  padding: 0 1.45rem;
  border: 1px solid rgba(236, 232, 247, .72);
  border-radius: 999px;
  background: rgba(255, 255, 255, .88);
  color: #6b6e82;
  font-size: .86rem;
  font-weight: 700;
  box-shadow: 0 .5rem 1.35rem rgba(45, 31, 122, .04);
}

.prepify-grade-tab:hover {
  color: var(--prepify-blue);
}

.prepify-grade-tab.active {
  border-color: rgba(93, 53, 242, .08);
  background: #e2d7ff;
  color: var(--prepify-blue);
}

.prepify-grade-tab span {
  font-weight: 600;
}

.prepify-pricing-section {
  display: grid;
  gap: 1.05rem;
}

.prepify-catalog-bundles-only .prepify-pricing-section {
  margin-top: -.35rem;
}

.prepify-pricing-section h2,
.prepify-catalog-lower-grid h2 {
  display: flex;
  align-items: center;
  gap: .65rem;
  margin: 0;
  color: #26283a;
  font-size: 1.28rem;
  font-weight: 800;
  letter-spacing: 0;
}

.prepify-pricing-section h2 span,
.prepify-catalog-lower-grid h2 span {
  display: inline-block;
  width: .2rem;
  height: 1.75rem;
  border-radius: 999px;
  background: var(--prepify-blue);
}

.prepify-pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.05rem;
  align-items: stretch;
}

.prepify-pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 28.5rem;
  padding: 1.45rem 1.45rem 1.2rem;
  border: 1px solid rgba(232, 228, 241, .94);
  border-radius: 8px;
  background: #ffffff;
  background-clip: padding-box;
  box-shadow: 0 1.15rem 2.65rem rgba(42, 32, 110, .09);
}

.prepify-pricing-card.is-popular {
  border: 2px solid var(--prepify-blue);
  box-shadow: 0 1.2rem 2.9rem rgba(93, 53, 242, .12);
}

.prepify-most-popular {
  position: absolute;
  top: -.85rem;
  left: 50%;
  min-width: 8.25rem;
  transform: translateX(-50%);
  border-radius: 999px;
  background: var(--prepify-blue);
  color: #ffffff;
  padding: .42rem .9rem;
  text-align: center;
  text-transform: uppercase;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 .7rem 1.35rem rgba(93, 53, 242, .18);
}

.prepify-discount-badge {
  flex: 0 0 auto;
  border-radius: 999px;
  background: var(--prepify-pink);
  color: #ffffff;
  padding: .45rem .75rem;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
}

.prepify-pricing-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .9rem;
  min-height: 5rem;
}

.prepify-pricing-card-copy {
  min-width: 0;
}

.prepify-pricing-kicker,
.student-package-kicker {
  display: inline-flex;
  color: #77798c;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
}

.prepify-pricing-kicker {
  margin-bottom: .5rem;
  text-transform: uppercase;
}

.prepify-pricing-card h3 {
  margin: 0 0 .55rem;
  color: var(--prepify-blue);
  font-size: 1.22rem;
  font-weight: 800;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.prepify-pricing-card p {
  display: -webkit-box;
  min-height: 2.1rem;
  margin: 0;
  overflow: hidden;
  color: #858799;
  font-size: .75rem;
  font-weight: 600;
  line-height: 1.4;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.prepify-price-line {
  display: flex;
  align-items: baseline;
  gap: .55rem;
  margin: 1.4rem 0 1.45rem;
}

.prepify-price-line strong {
  color: #1c2535;
  font-size: 3.3rem;
  font-weight: 800;
  line-height: .9;
  letter-spacing: 0;
}

.prepify-pricing-card.is-popular .prepify-price-line strong {
  color: var(--prepify-blue);
}

.prepify-price-line span {
  color: #77798c;
  font-size: .92rem;
  font-weight: 700;
}

.prepify-feature-list {
  display: grid;
  gap: .78rem;
  margin: 0 0 1.65rem;
  padding: 0;
  list-style: none;
}

.prepify-feature-list li {
  display: grid;
  grid-template-columns: 1.1rem minmax(0, 1fr);
  align-items: center;
  gap: .65rem;
  min-width: 0;
  color: #55586f;
  font-size: .78rem;
  font-weight: 700;
  line-height: 1.35;
}

.prepify-feature-list li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 999px;
  background: var(--prepify-blue);
  color: #ffffff;
  font-size: .7rem;
}

.prepify-pricing-card form {
  margin-top: auto;
}

.prepify-buy-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 3rem;
  border: 0;
  border-radius: 8px;
  background: var(--prepify-pink);
  color: #ffffff;
  font-size: .85rem;
  font-weight: 800;
  box-shadow: 0 .8rem 1.55rem rgba(255, 47, 178, .22);
}

.student-catalog-card-footer .btn {
  border-radius: 8px;
}

.prepify-buy-button:hover {
  background: #f11aa5;
  color: #ffffff;
}

.prepify-buy-button:disabled,
.prepify-buy-button.is-disabled {
  background: #d8d4e3;
  color: #ffffff;
  box-shadow: none;
}

.prepify-catalog-lower-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: 1.1rem;
  margin-top: 6.25rem;
}

.prepify-subject-bundle-panel,
.prepify-topic-panel {
  display: grid;
  gap: .9rem;
}

.prepify-subject-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 4.5rem;
  padding: 1rem 1.15rem;
  border: 1px solid rgba(235, 232, 245, .9);
  border-radius: .75rem;
  background: #ffffff;
  box-shadow: 0 .9rem 2rem rgba(45, 31, 122, .06);
}

.prepify-subject-row strong,
.prepify-topic-card strong {
  color: var(--prepify-blue);
  font-weight: 800;
}

.prepify-subject-row small,
.prepify-topic-card small {
  display: block;
  margin-top: .2rem;
  color: #7f8193;
  font-size: .72rem;
  font-weight: 600;
}

.prepify-subject-row b {
  white-space: nowrap;
  color: var(--prepify-blue);
  font-size: .72rem;
  font-weight: 800;
}

.prepify-topic-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}

.prepify-topic-card {
  display: grid;
  justify-items: center;
  gap: .35rem;
  min-height: 9.9rem;
  padding: 1rem .85rem;
  border: 1px solid rgba(235, 232, 245, .9);
  border-radius: .75rem;
  background: #ffffff;
  box-shadow: 0 .9rem 2rem rgba(45, 31, 122, .06);
  text-align: center;
}

.prepify-topic-card > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.65rem;
  height: 2.65rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--student-tone-bg) 84%, #ffffff);
  color: var(--student-tone);
  font-size: 1.25rem;
}

.prepify-topic-card b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 1.55rem;
  margin-top: .45rem;
  border: 1px solid var(--prepify-blue);
  border-radius: .4rem;
  color: var(--prepify-blue);
  font-size: .68rem;
  font-weight: 800;
}

.prepify-package-grid .student-catalog-card {
  overflow: visible;
  border-radius: 8px;
  background: #ffffff;
  background-clip: padding-box;
}

.prepify-package-grid {
  padding-top: .9rem;
}

.prepify-package-grid .student-catalog-card-featured {
  border: 2px solid var(--prepify-blue);
  box-shadow: 0 1.2rem 2.9rem rgba(93, 53, 242, .12);
}

.prepify-package-popular {
  z-index: 2;
}

.student-package-card-main {
  overflow: hidden;
  border-radius: calc(var(--prepify-radius-lg) - 1px) calc(var(--prepify-radius-lg) - 1px) 0 0;
}

.prepify-package-grid .student-catalog-card-accent {
  border-radius: 0;
}

.student-package-card-head {
  min-height: 3.5rem;
}

.student-package-card-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .9rem;
  min-width: 0;
}

.student-package-title-stack {
  display: grid;
  min-width: 0;
  gap: .32rem;
}

.student-package-card-title-row h2 {
  margin: 0;
  min-width: 0;
  color: var(--prepify-blue);
  font-size: 1.28rem;
  font-weight: 800;
  line-height: 1.05;
  overflow-wrap: anywhere;
}

.student-package-card-title-row span {
  flex: 0 0 auto;
  border: 1px solid rgba(93, 53, 242, .12);
  border-radius: 999px;
  background: rgba(93, 53, 242, .08);
  color: var(--prepify-blue);
  padding: .35rem .65rem;
  font-size: .7rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.prepify-my-exams-page {
  max-width: 66.25rem;
  margin-left: auto;
  margin-right: auto;
  padding-top: .1rem;
  gap: 1.65rem;
}

.prepify-my-exams-hero {
  display: grid;
  gap: .45rem;
}

.prepify-my-exams-hero .student-page-title {
  margin: 0;
  color: var(--prepify-blue);
  font-size: clamp(2.65rem, 4vw, 3.45rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
}

.prepify-my-exams-hero .student-page-subtitle {
  margin: 0;
  color: #7b7d91;
  font-size: .95rem;
}

.prepify-my-exams-summary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.05rem;
  margin-top: .25rem;
}

.prepify-my-exams-summary .student-summary-card {
  display: grid;
  justify-items: center;
  min-height: 9rem;
  padding: 1.15rem 1rem;
  border: 0;
  border-radius: .95rem;
  box-shadow: none;
  text-align: center;
}

.prepify-my-exams-summary .student-summary-card > div:last-child {
  display: grid;
  gap: .35rem;
  justify-items: center;
}

.prepify-my-exams-summary .student-summary-icon {
  width: 3rem;
  height: 3rem;
  margin-bottom: .25rem;
  border-radius: 50%;
  font-size: 1.4rem;
}

.prepify-my-exams-summary .student-summary-card strong {
  font-size: 2.35rem;
  font-weight: 800;
  line-height: .95;
  letter-spacing: 0;
}

.prepify-my-exams-summary .student-summary-card span {
  color: #676b7d;
  text-transform: uppercase;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: 0;
}

.prepify-summary-available {
  background: #e9fbf7;
}

.prepify-summary-available strong {
  color: #18c4ad;
}

.prepify-summary-progress {
  background: #eef6ff;
}

.prepify-summary-progress strong {
  color: #20a8f2;
}

.prepify-summary-waiting {
  background: #fff4bf;
}

.prepify-summary-waiting strong {
  color: #ffad12;
}

.prepify-summary-corrected {
  background: #ecfaf1;
}

.prepify-summary-corrected strong {
  color: #29c88d;
}

.prepify-my-exams-page .student-exam-list {
  gap: .75rem;
}

.prepify-my-exams-page .student-exam-list-header {
  padding: 0 1.65rem;
  color: #989cac;
  text-transform: uppercase;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: 0;
}

.prepify-my-exams-page .student-exam-row {
  grid-template-columns: minmax(15rem, 1.4fr) minmax(10rem, .8fr) minmax(11.5rem, .85fr) minmax(12rem, .85fr);
  min-height: 9.7rem;
  padding: 1.65rem 1.75rem;
  border: 0;
  border-radius: 1.25rem;
  background: #ffffff;
  box-shadow: 0 .85rem 2.25rem rgba(45, 31, 122, .07);
}

.prepify-my-exams-page .student-exam-main {
  align-items: center;
  gap: 1rem;
}

.prepify-my-exams-page .student-exam-icon {
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--student-tone-bg, #e7fbf5) 88%, #ffffff);
  color: var(--student-tone, #18c4ad);
  font-size: 1.35rem;
}

.prepify-my-exams-page .student-exam-main h2 {
  color: #252b3a;
  font-size: 1.05rem;
  font-weight: 800;
}

.prepify-my-exams-page .student-exam-main .badge {
  border-radius: .35rem;
  padding: .35rem .55rem;
  text-transform: lowercase;
  font-size: .62rem;
  font-weight: 800;
}

.prepify-my-exams-page .student-exam-main .badge.bg-warning,
.prepify-my-exams-page .student-exam-main .badge.bg-success {
  background: #ffd299 !important;
  color: #e07315 !important;
}

.prepify-my-exams-page .student-exam-main .badge.bg-secondary {
  background: #eef0f4 !important;
  color: #8a91a1 !important;
}

.prepify-my-exams-page .student-exam-meta,
.prepify-my-exams-page .student-exam-description,
.prepify-my-exams-page .student-exam-secondary-counts,
.prepify-my-exams-page .student-exam-time,
.prepify-my-exams-page .student-exam-sources {
  color: #73778c;
  font-size: .8rem;
}

.prepify-my-exams-page .student-exam-primary-count {
  align-items: baseline;
  justify-content: flex-start;
  gap: .55rem;
}

.prepify-my-exams-page .student-exam-primary-count strong {
  color: var(--prepify-blue);
  font-size: 1.35rem;
}

.prepify-my-exams-page .student-exam-primary-count span {
  border-radius: .35rem;
  background: #dcf3ff;
  color: #179be7;
  padding: .22rem .48rem;
  font-size: .64rem;
  font-weight: 800;
}

.prepify-my-exams-page .student-exam-sources {
  border-left: 1px solid rgba(225, 221, 236, .9);
  padding-left: 1.1rem;
}

.prepify-my-exams-page .student-exam-actions .btn {
  min-height: 2.9rem;
  border-radius: .65rem;
  font-size: .82rem;
  font-weight: 800;
}

.prepify-my-exams-page .student-exam-actions .btn-outline-secondary {
  border-color: transparent;
  background: #f0f0f3;
  color: #8c91a1;
}

.prepify-my-exams-page .student-exam-actions .btn-outline-primary {
  border-width: 2px;
  border-color: var(--prepify-violet);
  color: var(--prepify-violet);
}

.prepify-my-exams-page .student-action-note {
  color: #8a8fa1;
  text-align: center;
  font-size: .66rem;
}

.prepify-corrections-page {
  max-width: 66.25rem;
  margin-left: auto;
  margin-right: auto;
  padding-top: .1rem;
  gap: 2rem;
}

.prepify-corrections-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
}

.prepify-corrections-hero .student-page-title {
  margin: 0;
  color: var(--prepify-blue);
  font-size: clamp(2.65rem, 4vw, 3.45rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
}

.prepify-corrections-hero .student-page-subtitle {
  margin: 1rem 0 0;
  color: #7b7d91;
  font-size: .95rem;
}

.prepify-corrections-filter {
  display: inline-flex;
  margin-top: .7rem;
  border-radius: 999px;
  background: rgba(93, 53, 242, .1);
  color: var(--prepify-violet);
  padding: .35rem .7rem;
  font-size: .75rem;
  font-weight: 800;
}

.prepify-corrections-actions {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  padding-top: 1rem;
}

.prepify-corrections-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 8rem;
  min-height: 3rem;
  border-radius: .75rem;
  gap: .45rem;
  font-size: .82rem;
  font-weight: 800;
}

.prepify-corrections-actions .btn-outline-primary {
  border-width: 2px;
  border-color: var(--prepify-violet);
  color: var(--prepify-violet);
  background: #ffffff;
}

.prepify-corrections-summary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.35rem;
  margin-top: .2rem;
}

.prepify-corrections-summary .student-summary-card {
  display: grid;
  justify-items: center;
  min-height: 10.7rem;
  padding: 1.35rem 1rem;
  border: 0;
  border-radius: .95rem;
  box-shadow: none;
  text-align: center;
}

.prepify-corrections-summary .student-summary-card > div:last-child {
  display: grid;
  gap: .45rem;
  justify-items: center;
}

.prepify-corrections-summary .student-summary-icon {
  width: 3rem;
  height: 3rem;
  margin-bottom: .2rem;
  border-radius: 50%;
  font-size: 1.35rem;
}

.prepify-corrections-summary .student-summary-card strong {
  font-size: 2.35rem;
  font-weight: 800;
  line-height: .95;
  letter-spacing: 0;
}

.prepify-corrections-summary .student-summary-card span {
  color: #676b7d;
  text-transform: uppercase;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: 0;
}

.prepify-correction-summary-submitted {
  background: rgba(252, 251, 255, .94);
}

.prepify-correction-summary-submitted .student-summary-icon {
  background: #ded3ff;
  color: var(--prepify-violet);
}

.prepify-correction-summary-submitted strong {
  color: var(--prepify-violet);
}

.prepify-correction-summary-pending {
  background: #eef6ff;
}

.prepify-correction-summary-pending .student-summary-icon {
  background: #d8ebff;
  color: #20a8f2;
}

.prepify-correction-summary-pending strong {
  color: #20a8f2;
}

.prepify-correction-summary-ready {
  background: #ffe0f3;
}

.prepify-correction-summary-ready .student-summary-icon {
  background: #ffc5e6;
  color: #ff2fb2;
}

.prepify-correction-summary-ready strong {
  color: #ff2fb2;
}

.prepify-correction-summary-review {
  background: #fff4bf;
}

.prepify-correction-summary-review .student-summary-icon {
  background: #ffe58a;
  color: #ffad12;
}

.prepify-correction-summary-review strong {
  color: #ffad12;
}

.prepify-corrections-page .student-corrections-list {
  gap: 1rem;
}

.prepify-corrections-page .student-correction-row {
  grid-template-columns: minmax(0, 1fr) auto;
  min-height: 12.1rem;
  align-items: start;
  gap: 1.25rem 1rem;
  padding: 1.65rem 1.75rem 1.45rem;
  border: 0;
  border-radius: 1.25rem;
  background: #ffffff;
  box-shadow: 0 1rem 2.65rem rgba(45, 31, 122, .08);
}

.prepify-corrections-page .student-correction-main {
  align-items: flex-start;
  gap: 1.25rem;
}

.prepify-corrections-page .student-exam-icon {
  width: 3.75rem;
  height: 3.75rem;
  flex: 0 0 3.75rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--student-tone-bg, #eee7ff) 90%, #ffffff);
  color: var(--student-tone, var(--prepify-violet));
  font-size: 1.45rem;
}

.prepify-corrections-page .student-correction-main h2 {
  margin: 0;
  color: #252b3a;
  font-size: 1.35rem;
  font-weight: 800;
}

.prepify-corrections-page .student-exam-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: .35rem;
  color: #73778c;
  font-size: .82rem;
}

.prepify-corrections-page .student-exam-meta::first-letter {
  text-transform: uppercase;
}

.prepify-corrections-page .student-exam-description {
  margin: .75rem 0 0;
  color: var(--prepify-violet);
  font-size: .92rem;
  font-weight: 800;
}

.prepify-corrections-page .student-correction-time {
  display: flex;
  align-items: center;
  gap: .35rem;
  margin-top: .7rem;
  color: #8a8fa1;
  font-size: .8rem;
}

.prepify-corrections-page .student-correction-time i {
  color: var(--prepify-violet);
}

.prepify-corrections-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  min-width: 5.25rem;
  min-height: 2.05rem;
  border-radius: 999px;
  padding: .3rem .8rem;
  text-transform: uppercase;
  font-size: .66rem;
  font-weight: 900;
}

.prepify-corrections-status::before {
  margin-right: .25rem;
  content: "\2713";
  font-weight: 900;
}

.prepify-corrections-status.is-ready {
  background: #14b879;
  color: #ffffff;
}

.prepify-corrections-status.is-pending,
.prepify-corrections-status.is-submitted {
  background: #e9f5ff;
  color: #179be7;
}

.prepify-corrections-status.is-review {
  background: #fff4bf;
  color: #c87a00;
}

.prepify-corrections-status.is-review::before {
  content: "!";
}

.prepify-corrections-page .student-correction-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: .85rem;
  justify-content: stretch;
}

.prepify-corrections-page .student-correction-actions .btn {
  min-height: 3.15rem;
  min-width: 0;
  border-radius: .75rem;
  font-size: .88rem;
  font-weight: 800;
}

.prepify-corrections-page .student-correction-actions .btn-outline-primary {
  border-width: 2px;
  border-color: var(--prepify-violet);
  color: var(--prepify-violet);
  background: #ffffff;
}

.prepify-correction-result-btn {
  border-color: #ff2fb2 !important;
  background: #ff2fb2 !important;
  color: #ffffff !important;
  box-shadow: 0 .8rem 1.5rem rgba(255, 47, 178, .22);
}

.prepify-correction-result-page {
  position: relative;
  max-width: 70.5rem;
  margin-right: auto;
  margin-left: auto;
  padding-top: .15rem;
  gap: 1.5rem;
}

.prepify-correction-result-page::before {
  position: absolute;
  z-index: 0;
  top: 8.15rem;
  left: -.7rem;
  width: 31.5rem;
  height: 48rem;
  background-image:
    linear-gradient(rgba(169, 173, 190, .18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(169, 173, 190, .18) 1px, transparent 1px);
  background-size: 2rem 2rem;
  content: "";
  opacity: .7;
  pointer-events: none;
}

.prepify-correction-result-page > * {
  position: relative;
  z-index: 1;
}

.prepify-correction-result-page .student-replay-shell {
  order: 1;
  grid-template-columns: minmax(0, 49rem) 17rem;
  align-items: start;
  gap: 4.5rem;
  margin-bottom: 0 !important;
}

.prepify-correction-result-page .student-replay-stage,
.prepify-correction-result-page .student-replay-chapters {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.prepify-correction-result-page .student-replay-stage {
  gap: 1.45rem;
  padding: 0;
}

.prepify-correction-result-page .student-replay-stage-header {
  grid-template-columns: minmax(0, 1fr) minmax(13.75rem, 17rem);
  min-height: 3.6rem;
  align-items: start;
}

.prepify-correction-result-page .student-result-kicker {
  color: #a3a5b3;
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-stage-header h2 {
  margin-top: .55rem;
  color: #252b3a;
  font-size: 2rem;
  font-weight: 850;
  line-height: 1.05;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-stage-meta {
  align-self: start;
  align-items: stretch;
  justify-content: flex-end;
  gap: .45rem .75rem;
  width: 100%;
}

.prepify-correction-result-page .student-replay-stage-meta > span:not(.student-result-verdict) {
  align-self: center;
  border: 0;
  background: transparent;
  color: #878c9f;
  padding: 0;
  font-size: .76rem;
}

.prepify-correction-result-page .student-replay-exam-mark {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  width: 100%;
  min-width: 0;
  gap: .18rem .75rem;
  border: 1px solid #ede7ff;
  border-radius: .95rem;
  background: #ffffff;
  box-shadow: 0 .9rem 1.85rem rgba(45, 31, 122, .08);
  padding: .78rem .95rem;
}

.prepify-correction-result-page .student-replay-exam-mark > span {
  grid-column: 1;
  color: #8c92a4;
  font-size: .68rem;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: uppercase;
}

.prepify-correction-result-page .student-replay-exam-mark strong {
  grid-column: 1;
  color: #6d4ee8;
  font-size: 1.45rem;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-exam-mark small {
  grid-column: 1;
  color: #5f6677;
  font-size: .74rem;
  font-weight: 700;
  line-height: 1.25;
}

.prepify-correction-result-page .student-replay-share-button {
  display: inline-flex;
  grid-row: 1 / 4;
  grid-column: 2;
  align-items: center;
  justify-content: center;
  gap: .32rem;
  min-width: 4.65rem;
  min-height: 2.25rem;
  border: 1px solid #e4dcff;
  border-radius: .72rem;
  background: #fbf9ff;
  color: #5d35f2;
  cursor: default;
  font-size: .78rem;
  font-weight: 850;
  line-height: 1;
  padding: .55rem .72rem;
}

.prepify-correction-result-page .student-replay-share-button i {
  font-size: 1rem;
  line-height: 1;
}

.prepify-correction-result-page .student-replay-teaching-area {
  grid-template-columns: 16rem minmax(0, 1fr);
  gap: 1.5rem;
}

.prepify-correction-result-page .student-replay-avatar-panel {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  align-self: stretch;
  height: clamp(23rem, calc(100vh - 21rem), 32rem);
  min-height: clamp(23rem, calc(100vh - 21rem), 32rem);
  align-content: stretch;
  justify-items: stretch;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.prepify-correction-result-page .student-replay-avatar-frame {
  width: 100%;
  height: 100%;
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.prepify-correction-result-page .student-replay-avatar-canvas {
  inset: 0;
  visibility: visible;
}

.prepify-correction-result-page .student-replay-avatar-frame.is-live .student-replay-avatar-canvas {
  opacity: 1;
}

.prepify-correction-result-page .student-replay-avatar-fallback,
.prepify-correction-result-page .student-replay-avatar-pulse {
  visibility: visible;
  opacity: 1;
}

.prepify-correction-result-page .student-replay-avatar-pulse,
.prepify-correction-result-page .student-replay-avatar-copy {
  display: none;
}

.prepify-correction-result-page .student-replay-workspace {
  display: block;
}

.prepify-correction-result-page .student-replay-step-map {
  display: none;
}

.prepify-correction-result-page .student-replay-board {
  height: clamp(26rem, calc(100vh - 27rem), 32rem);
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior-y: auto;
  scrollbar-gutter: stable;
  border: 0;
  border-radius: 1.2rem;
  background: #ffffff;
  box-shadow: 0 1.15rem 2.65rem rgba(45, 31, 122, .08);
  padding: 1.85rem 1.95rem;
  scrollbar-color: #c9b8ff transparent;
  scrollbar-width: thin;
}

.prepify-correction-result-page .student-replay-board::-webkit-scrollbar {
  width: .45rem;
}

.prepify-correction-result-page .student-replay-board::-webkit-scrollbar-track {
  background: transparent;
}

.prepify-correction-result-page .student-replay-board::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #c9b8ff;
}

.prepify-correction-result-page .student-replay-shell.is-avatar-intro .student-replay-workspace,
.prepify-correction-result-page .student-replay-shell.is-avatar-intro .student-replay-subtitles,
.prepify-correction-result-page .student-replay-shell.is-avatar-intro .student-replay-progress {
  opacity: 0;
  pointer-events: none;
}

.prepify-correction-result-page .student-replay-board-topline {
  margin-bottom: 1.35rem;
  color: #8d94a5;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: 0;
}

.prepify-correction-result-page #studentReplayScore {
  color: var(--prepify-violet);
}

.prepify-correction-result-page .student-replay-board h3 {
  margin-bottom: 1.05rem;
  color: #272c39;
  font-size: 1.25rem;
  font-weight: 850;
}

.prepify-correction-result-page .student-replay-steps {
  gap: .95rem;
  font-size: .9rem;
  line-height: 1.42;
}

.prepify-correction-result-page .student-replay-steps li {
  grid-template-columns: 2rem minmax(0, 1fr);
  align-items: start;
  gap: .85rem;
  border: 0;
  border-radius: 0;
  padding: 0;
}

.prepify-correction-result-page .student-replay-steps li::before {
  width: 1.8rem;
  height: 1.8rem;
  background: #e4d8ff;
  color: var(--prepify-violet);
  font-size: .78rem;
}

.prepify-correction-result-page .student-replay-steps li span {
  display: block;
  border-radius: .7rem;
  background: #f7f7fa;
  color: #596070;
  padding: .72rem 1rem;
}

.prepify-correction-result-page .student-replay-steps li.is-active {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.prepify-correction-result-page .student-replay-signals {
  display: block;
  margin-top: 1.45rem;
}

.prepify-correction-result-page .student-replay-signals span {
  display: block;
  border: 0;
  border-left: .25rem solid #ff7417;
  border-radius: .55rem;
  background: #ffd7a6;
  color: #93520e;
  padding: .95rem 1.05rem;
  font-size: .83rem;
  font-weight: 750;
  line-height: 1.48;
}

.prepify-correction-result-page .student-replay-coach-guidance {
  display: block;
  margin-top: .72rem;
  border: 0;
  border-left: .25rem solid #6f57f7;
  border-radius: .55rem;
  background: #eee7ff;
  color: #3f2f84;
  padding: .88rem 1.05rem;
  overflow-wrap: anywhere;
}

.prepify-correction-result-page .student-replay-coach-guidance.is-empty {
  display: none;
}

.prepify-correction-result-page .student-replay-coach-kicker {
  display: block;
  margin-bottom: .25rem;
  color: #6f57f7;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.prepify-correction-result-page .student-replay-coach-guidance p {
  margin: 0;
  color: #4b3a91;
  font-size: .83rem;
  font-weight: 750;
  line-height: 1.48;
}

.prepify-correction-result-page .student-replay-coach-guidance ul {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  margin: .55rem 0 0;
  padding: 0;
  list-style: none;
}

.prepify-correction-result-page .student-replay-coach-guidance li {
  display: inline-flex;
  align-items: center;
  min-height: 1.55rem;
  border-radius: 999px;
  background: #ffffff;
  color: #5f48d9;
  padding: .24rem .5rem;
  font-size: .72rem;
  font-weight: 850;
  line-height: 1.2;
}

.prepify-correction-result-page .student-replay-subtitles {
  display: none;
}

.prepify-correction-result-page .student-replay-progress {
  margin-top: 1.05rem;
}

.prepify-correction-result-page .student-replay-controls {
  position: sticky;
  bottom: .75rem;
  z-index: 5;
  padding-top: .45rem;
  background: rgba(252, 249, 255, .9);
  backdrop-filter: blur(10px);
}

.prepify-correction-result-page .student-replay-shell.is-avatar-intro .student-replay-controls {
  position: sticky;
  bottom: .75rem;
  width: auto;
  transform: none;
}

.prepify-correction-result-page .student-replay-controls .btn {
  min-height: 2.7rem;
  border-radius: .65rem;
}

.prepify-correction-result-page .student-replay-controls .btn-primary {
  border-color: #a98cf7;
  background: #a98cf7;
  box-shadow: none;
}

.prepify-correction-result-page .student-replay-chapters {
  position: sticky;
  top: 6rem;
  height: min(42rem, calc(100vh - 7rem));
  overflow: visible;
}

.prepify-correction-result-page .student-replay-chapters-header {
  border-bottom: 0;
  padding: 0 0 1rem;
}

.prepify-correction-result-page .student-replay-chapters-header span {
  color: #303544;
  font-size: .95rem;
  font-weight: 900;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-chapters-header strong {
  min-width: 1.9rem;
  height: 1.9rem;
  background: #eee7ff;
  color: var(--prepify-violet);
}

.prepify-correction-result-page .student-replay-chapter-list {
  gap: .65rem;
  overflow-y: auto;
  padding: 0 .15rem .25rem 0;
}

.prepify-correction-result-page .student-replay-tree-group {
  border: 0;
  background: transparent;
}

.prepify-correction-result-page .student-replay-tree-group summary {
  border-bottom: 0;
  background: transparent;
  color: var(--prepify-violet);
  padding: .25rem 0 .55rem;
  font-size: .82rem;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-tree-group summary strong {
  background: transparent;
  color: #9ca1b1;
}

.prepify-correction-result-page .student-replay-tree-part {
  gap: .55rem;
  padding: 0 0 .75rem;
}

.prepify-correction-result-page .student-replay-tree-part + .student-replay-tree-part {
  border-top: 0;
}

.prepify-correction-result-page .student-replay-tree-part-title {
  color: #a0a4b2;
  font-size: .68rem;
  letter-spacing: 0;
}

.prepify-correction-result-page .student-replay-question-group {
  gap: .45rem;
  border-left: 0;
  padding-left: 0;
}

.prepify-correction-result-page .student-replay-question-group-title {
  color: #4e5566;
  font-size: .78rem;
}

.prepify-correction-result-page .student-replay-chapter {
  min-height: 3.25rem;
  grid-template-columns: 2rem minmax(0, 1fr) auto;
  gap: .65rem;
  border: 1px solid #e7e9f1;
  border-radius: .6rem;
  background: #ffffff;
  box-shadow: 0 .45rem 1rem rgba(45, 31, 122, .045);
  padding: .55rem .65rem;
}

.prepify-correction-result-page .student-replay-chapter:hover,
.prepify-correction-result-page .student-replay-chapter:focus-visible,
.prepify-correction-result-page .student-replay-chapter.is-active {
  border-color: #dfe2ed;
  background: #ffffff;
  box-shadow: 0 .55rem 1.1rem rgba(45, 31, 122, .07);
}

.prepify-correction-result-page .student-replay-chapter-index {
  width: 1.55rem;
  height: 1.55rem;
  background: #f1f3f7;
  color: #9aa1b1;
}

.prepify-correction-result-page .student-replay-chapter-copy strong {
  color: #596070;
  font-size: .78rem;
}

.prepify-correction-result-page .student-replay-chapter-copy small {
  color: #9298a8;
  font-size: .68rem;
}

.prepify-correction-result-page .student-replay-chapter .student-result-verdict {
  padding: .23rem .48rem;
  color: #ffffff;
  font-size: .58rem;
  font-weight: 900;
}

.prepify-correction-result-page .student-result-verdict-success {
  background: #16bd7a;
  color: #ffffff;
}

.prepify-correction-result-page .student-result-verdict-warning {
  background: #ff7a18;
  color: #ffffff;
}

.prepify-correction-result-page .student-result-verdict-danger {
  background: #ef4d4d;
  color: #ffffff;
}

.prepify-correction-result-page .student-result-verdict-neutral {
  background: #8b5cf6;
  color: #ffffff;
}

.prepify-correction-result-page .student-mark-summary {
  order: 2;
  margin-top: 10rem;
}

.prepify-correction-result-page .student-result-report {
  order: 3;
}

.prepify-correction-result-page .student-coach-guidance {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .75rem;
  border: 1px solid #dfe8ff;
  border-radius: .65rem;
  background: #f7faff;
  padding: .85rem;
  overflow-wrap: anywhere;
}

.prepify-correction-result-page .student-coach-guidance-overall {
  margin-bottom: .8rem;
}

.prepify-correction-result-page .student-coach-guidance-compact {
  background: #fbfcff;
}

.prepify-correction-result-page .student-coach-guidance-icon {
  display: inline-flex;
  width: 2.05rem;
  height: 2.05rem;
  align-items: center;
  justify-content: center;
  border-radius: .55rem;
  background: #ffffff;
  color: #3f63e8;
  box-shadow: inset 0 0 0 1px rgba(63, 99, 232, .14);
}

.prepify-correction-result-page .student-coach-guidance-copy {
  min-width: 0;
}

.prepify-correction-result-page .student-coach-guidance p {
  margin: .28rem 0 0;
  color: #3d4556;
  font-size: .88rem;
  font-weight: 650;
  line-height: 1.45;
}

.prepify-correction-result-page .student-coach-guidance ul {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin: .6rem 0 0;
  padding: 0;
  list-style: none;
}

.prepify-correction-result-page .student-coach-guidance li {
  min-height: 1.7rem;
  display: inline-flex;
  align-items: center;
  border: 1px solid #d7e0fb;
  border-radius: 999px;
  background: #ffffff;
  color: #3f63e8;
  padding: .28rem .55rem;
  font-size: .74rem;
  font-weight: 850;
  line-height: 1.2;
}

.prepify-feedback-success-page {
  position: relative;
  width: min(100%, 43.5rem);
  margin: 1.9rem auto 0;
  gap: 0;
  padding-bottom: 0;
  transform: translateX(-.55rem);
}

.prepify-feedback-success-hero {
  display: grid;
  justify-items: center;
  margin-bottom: 2.05rem;
  text-align: center;
}

.prepify-feedback-success-mark {
  position: relative;
  width: 9.05rem;
  height: 9.05rem;
  margin-bottom: 2.25rem;
}

.prepify-feedback-success-mark::before,
.prepify-feedback-success-mark::after,
.prepify-feedback-success-check::before {
  position: absolute;
  content: "";
}

.prepify-feedback-success-mark::before {
  top: -.95rem;
  left: .72rem;
  width: 8.65rem;
  height: 8.65rem;
  border-radius: 50%;
  background: #ff2fb2;
  box-shadow: 0 1.15rem 2.25rem rgba(255, 47, 178, .34);
}

.prepify-feedback-success-mark::after {
  top: 1.42rem;
  left: 2.85rem;
  width: 3.62rem;
  height: 3.62rem;
  border-radius: 50%;
  background: #ffffff;
}

.prepify-feedback-success-check::before {
  top: 2.12rem;
  left: 3.94rem;
  width: 1.05rem;
  height: 2.05rem;
  border: solid #ff2fb2;
  border-width: 0 .32rem .32rem 0;
  border-radius: .1rem;
  transform: rotate(42deg);
  transform-origin: center;
  z-index: 1;
}

.prepify-feedback-success-orbit,
.prepify-feedback-success-spark {
  position: absolute;
  display: block;
}

.prepify-feedback-success-orbit {
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: #6f57f7;
}

.prepify-feedback-success-orbit-one {
  top: 1.4rem;
  left: 2rem;
}

.prepify-feedback-success-orbit-two {
  top: 4.95rem;
  left: .95rem;
}

.prepify-feedback-success-orbit-three {
  right: 1.35rem;
  bottom: 1.6rem;
  background: #ff8bd9;
}

.prepify-feedback-success-spark {
  width: 1.45rem;
  height: 1.45rem;
}

.prepify-feedback-success-spark::before,
.prepify-feedback-success-spark::after {
  position: absolute;
  border-radius: 999px;
  background: currentColor;
  content: "";
}

.prepify-feedback-success-spark::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: .12rem;
  transform: translateY(-50%);
}

.prepify-feedback-success-spark::after {
  top: 0;
  left: 50%;
  width: .12rem;
  height: 100%;
  transform: translateX(-50%);
}

.prepify-feedback-success-spark-one {
  right: .15rem;
  top: .85rem;
  color: #6f57f7;
}

.prepify-feedback-success-spark-two {
  bottom: 1.35rem;
  left: .1rem;
  color: #ff2fb2;
  transform: scale(.72);
}

.prepify-feedback-success-hero h1 {
  max-width: 36rem;
  margin: 0 0 1.35rem;
  color: var(--prepify-blue);
  font-size: 3rem;
  font-weight: 850;
  line-height: .98;
  letter-spacing: 0;
}

.prepify-feedback-success-hero p {
  max-width: 35rem;
  margin: 0;
  color: #7d8294;
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.45;
}

.prepify-feedback-success-card {
  display: grid;
  justify-items: center;
  min-height: 27.05rem;
  margin-bottom: 1.5rem;
  border: 0;
  border-radius: 1.35rem;
  background: #ffffff;
  box-shadow: 0 1rem 2.5rem rgba(45, 31, 122, .07);
  padding: 4.05rem 3rem 3rem;
  text-align: center;
}

.prepify-feedback-success-card-icon {
  position: relative;
  width: 3.9rem;
  height: 3.9rem;
  margin-bottom: 1.85rem;
  border-radius: 50%;
  background: #eadcff;
}

.prepify-feedback-success-card-icon::before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.55rem;
  height: 1.55rem;
  border: .16rem solid #6b56f6;
  border-radius: 50%;
  content: "";
  transform: translate(-50%, -50%);
}

.prepify-feedback-success-card-icon::after {
  position: absolute;
  top: 1.32rem;
  left: 1.47rem;
  width: .48rem;
  height: .9rem;
  border: solid #6b56f6;
  border-width: 0 .14rem .14rem 0;
  content: "";
  transform: rotate(42deg);
}

.prepify-feedback-success-card-copy {
  width: min(100%, 38rem);
  margin: 0 0 2.15rem;
  color: #666d81;
  font-size: .92rem;
  font-weight: 650;
  line-height: 1.45;
}

.prepify-feedback-success-meta {
  display: grid;
  width: 100%;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.85rem;
  border-radius: .85rem;
  background: #f7f5ff;
  padding: 1rem 1.2rem;
  text-align: left;
}

.prepify-feedback-success-meta span {
  display: block;
  margin-bottom: .35rem;
  color: #b5b1c4;
  font-size: .6rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
  text-transform: uppercase;
}

.prepify-feedback-success-meta strong {
  display: block;
  color: #626779;
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.15;
}

.prepify-feedback-success-meta div:first-child strong {
  color: #5d35f2;
}

.prepify-feedback-success-actions {
  display: flex;
  justify-content: center;
  gap: .85rem;
  width: 100%;
}

.prepify-feedback-success-btn {
  display: inline-flex;
  min-width: 15.45rem;
  min-height: 3.6rem;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  border-radius: .72rem;
  font-size: .94rem;
  font-weight: 850;
  line-height: 1;
  text-decoration: none;
}

.prepify-feedback-success-btn:hover,
.prepify-feedback-success-btn:focus-visible {
  text-decoration: none;
}

.prepify-feedback-success-btn-primary {
  border: 0;
  background: #ff2fb2;
  color: #ffffff;
  box-shadow: 0 .9rem 1.7rem rgba(255, 47, 178, .28);
}

.prepify-feedback-success-btn-primary:hover,
.prepify-feedback-success-btn-primary:focus-visible {
  background: #f51ca6;
  color: #ffffff;
}

.prepify-feedback-success-btn-primary i {
  font-size: 1.28rem;
}

.prepify-feedback-success-btn-secondary {
  border: .13rem solid #5d35f2;
  background: #ffffff;
  color: #5d35f2;
}

.prepify-feedback-success-btn-secondary:hover,
.prepify-feedback-success-btn-secondary:focus-visible {
  border-color: var(--prepify-blue);
  background: #fbf9ff;
  color: var(--prepify-blue);
}

.prepify-feedback-wait-card {
  display: grid;
  grid-template-columns: 3rem minmax(0, 1fr);
  gap: 1.05rem;
  min-height: 10.3rem;
  border: .1rem solid #eadfff;
  border-radius: .75rem;
  background: rgba(255, 250, 255, .78);
  padding: 1.55rem 1.5rem;
}

.prepify-feedback-wait-icon {
  display: inline-flex;
  width: 2.65rem;
  height: 2.65rem;
  align-items: center;
  justify-content: center;
  border-radius: .7rem;
  background: #6b56f6;
  color: #ffffff;
  font-size: 1.55rem;
}

.prepify-feedback-wait-card h2 {
  margin: .05rem 0 .45rem;
  color: #5d35f2;
  font-size: .95rem;
  font-weight: 850;
  line-height: 1.2;
}

.prepify-feedback-wait-card p {
  width: min(100%, 39rem);
  margin: 0 0 .8rem;
  color: #83879a;
  font-size: .76rem;
  font-weight: 600;
  line-height: 1.45;
}

.prepify-feedback-wait-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.prepify-feedback-wait-actions a {
  display: inline-flex;
  min-height: 1.45rem;
  align-items: center;
  border-radius: .36rem;
  background: #ffffff;
  color: #5d35f2;
  font-size: .67rem;
  font-weight: 800;
  line-height: 1;
  padding: .35rem .65rem;
  text-decoration: none;
}

.prepify-feedback-wait-actions a:hover,
.prepify-feedback-wait-actions a:focus-visible {
  color: var(--prepify-blue);
}

.prepify-feedback-create-page {
  position: relative;
  width: min(100%, 43.5rem);
  margin: -1.15rem auto 0;
  gap: 0;
  padding-top: 0;
  transform: translateX(-.625rem);
}

.prepify-feedback-create-page .student-page-title {
  margin: 0 0 1.65rem;
  color: var(--prepify-blue);
  font-size: 3rem;
  font-weight: 850;
  line-height: 1;
  letter-spacing: 0;
}

.prepify-feedback-intro {
  position: relative;
  min-height: 18.4rem;
  overflow: hidden;
  border: 0;
  border-radius: 1.45rem;
  background: #ffffff;
  box-shadow: 0 1rem 2.5rem rgba(45, 31, 122, .07);
  padding: 2.85rem 2rem 2rem;
}

.prepify-feedback-intro h2 {
  margin: 0 0 .95rem;
  color: var(--prepify-violet);
  font-size: 1.35rem;
  font-weight: 850;
  line-height: 1.12;
  letter-spacing: 0;
}

.prepify-feedback-intro p {
  width: min(100%, 28.5rem);
  margin: 0 0 1.55rem;
  color: #7f8395;
  font-size: .86rem;
  font-weight: 600;
  line-height: 1.4;
}

.prepify-feedback-intro h3 {
  margin: 0 0 .7rem;
  color: var(--prepify-violet);
  font-size: .95rem;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: 0;
}

.prepify-feedback-intro ul {
  display: grid;
  gap: .48rem;
  margin: 0;
  padding-left: 1rem;
  color: #727789;
  font-size: .84rem;
  font-weight: 600;
  line-height: 1.28;
}

.prepify-feedback-motif {
  position: absolute;
  top: 3.1rem;
  right: 4.25rem;
  width: 4.4rem;
  height: 3.85rem;
}

.prepify-feedback-motif span {
  position: absolute;
  display: block;
}

.prepify-feedback-motif span:nth-child(1),
.prepify-feedback-motif span:nth-child(2) {
  top: 0;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 50%;
}

.prepify-feedback-motif span:nth-child(1) {
  left: .2rem;
  background: #ddd8ff;
}

.prepify-feedback-motif span:nth-child(2) {
  right: .15rem;
  background: #ffd9f0;
}

.prepify-feedback-motif span:nth-child(3),
.prepify-feedback-motif span:nth-child(4) {
  bottom: .38rem;
  width: .9rem;
  height: 1.65rem;
  border-radius: 999px;
}

.prepify-feedback-motif span:nth-child(3) {
  left: .65rem;
  background: linear-gradient(180deg, #8270ff 0%, #7155fb 100%);
}

.prepify-feedback-motif span:nth-child(4) {
  right: .58rem;
  background: linear-gradient(180deg, #ff79d4 0%, #ff2fb2 100%);
}

.prepify-feedback-motif::before,
.prepify-feedback-motif::after {
  position: absolute;
  top: 1.65rem;
  width: 1.65rem;
  height: .42rem;
  border-radius: 999px;
  background: #d9d4ff;
  content: "";
}

.prepify-feedback-motif::before {
  left: .95rem;
  transform: rotate(42deg);
}

.prepify-feedback-motif::after {
  right: .8rem;
  background: #ffd2ec;
  transform: rotate(-42deg);
}

.prepify-feedback-create-page .student-feedback-card {
  margin-top: 2.45rem;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.prepify-feedback-create-page .student-feedback-card form {
  display: grid;
  gap: 0;
}

.prepify-feedback-field .form-label,
.prepify-feedback-detail-field .form-label {
  margin: 0 0 .78rem;
  color: #3f4351;
  font-size: .92rem;
  font-weight: 850;
  line-height: 1.15;
  letter-spacing: 0;
}

.prepify-feedback-create-page .prepify-feedback-category-field .form-label {
  color: var(--prepify-violet);
  font-size: .98rem;
}

.prepify-feedback-create-page .form-select,
.prepify-feedback-create-page .form-control {
  border: 2px solid #7b61ff;
  border-radius: .85rem;
  background-color: #ffffff;
  color: var(--prepify-violet);
  font-size: .92rem;
  font-weight: 600;
  line-height: 1.35;
}

.prepify-feedback-create-page .form-select {
  min-height: 3.5rem;
  padding: .86rem 1.15rem;
}

.prepify-feedback-field-message {
  margin-top: 1.55rem;
}

.prepify-feedback-create-page .student-feedback-textarea {
  height: 11.25rem;
  min-height: 11.25rem;
  padding: 1.15rem 1.2rem;
  resize: vertical;
  color: #2c3140;
  border-color: #d7ceff !important;
}

.prepify-feedback-create-page .student-feedback-textarea::placeholder {
  color: #d7dbe5;
  opacity: 1;
}

.prepify-feedback-create-page .form-text {
  margin-top: 1.9rem;
  color: #667085;
  font-size: .72rem;
  font-weight: 600;
  line-height: 1.35;
}

.prepify-feedback-create-page .text-danger {
  display: block;
  margin-top: .45rem;
  font-size: .78rem;
}

.prepify-feedback-create-page .student-form-actions {
  margin-top: 1.45rem;
  justify-content: flex-end;
}

.prepify-feedback-create-page .student-form-actions .btn {
  min-width: 11.2rem;
  min-height: 3.45rem;
  border: 0;
  border-radius: .78rem;
  background: #ff2fb2;
  color: #ffffff;
  box-shadow: 0 .9rem 1.6rem rgba(255, 47, 178, .28);
  font-size: .9rem;
  font-weight: 850;
}

.prepify-feedback-create-page .student-form-actions .btn:hover,
.prepify-feedback-create-page .student-form-actions .btn:focus-visible {
  background: #f51ca6;
  color: #ffffff;
}

.prepify-feedback-details {
  position: absolute;
  top: 54.95rem;
  right: 0;
  justify-self: end;
  width: min(100%, 28rem);
  margin-top: 0;
  border-radius: .85rem;
  background: transparent;
  box-shadow: none;
}

.prepify-feedback-details summary {
  cursor: pointer;
  list-style-position: inside;
  padding: .2rem 0;
  color: #6d58ef;
  font-size: .82rem;
  font-weight: 850;
  line-height: 1.35;
  text-align: right;
  text-decoration: underline;
  text-underline-offset: .18rem;
}

.prepify-feedback-details[open] {
  position: static;
  justify-self: stretch;
  width: 100%;
  margin-top: 1rem;
  background: #ffffff;
  box-shadow: 0 .8rem 2rem rgba(45, 31, 122, .06);
}

.prepify-feedback-details[open] summary {
  padding: .85rem 1.1rem;
  color: var(--prepify-violet);
  font-size: .84rem;
  font-weight: 850;
  text-align: left;
}

.prepify-feedback-details-body {
  display: grid;
  gap: 1rem;
  padding: 0 1.1rem 1.1rem;
}

.prepify-feedback-details .form-select,
.prepify-feedback-details .form-control {
  border-color: #ebe8f5;
  color: #2c3140;
}

.prepify-feedback-details .form-text {
  margin-top: .45rem;
}

.prepify-corrections-rest-state,
.prepify-corrections-empty {
  display: grid;
  justify-items: center;
  gap: .85rem;
  text-align: center;
}

.prepify-corrections-rest-state {
  margin-top: 1.5rem;
  color: #9aa1b1;
}

.prepify-corrections-rest-state span,
.prepify-corrections-empty .student-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5.4rem;
  height: 5.4rem;
  border-radius: 50%;
  background: #f0f1f3;
  color: #9aa1b1;
  font-size: 2.2rem;
}

.prepify-corrections-rest-state p,
.prepify-corrections-empty p {
  margin: 0;
  color: #9aa1b1;
  font-size: .9rem;
}

@media print {
  #examContent {
    display: none !important;
  }

  .student-active-exam-page::before {
    display: block;
    padding: 2rem;
    color: var(--prepify-ink);
    content: "Printing is disabled during the exam.";
    font-size: 1.25rem;
    font-weight: 700;
  }
}

@media (max-width: 991.98px) {
  .prepify-student-row {
    grid-template-columns: 1fr;
  }

  .prepify-pricing-grid {
    grid-template-columns: 1fr;
  }

  .prepify-my-exams-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .prepify-my-exams-page .student-exam-row {
    grid-template-columns: 1fr;
  }

  .prepify-my-exams-page .student-exam-sources {
    border-left: 0;
    padding-left: 0;
  }

  .prepify-corrections-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .prepify-corrections-page .student-correction-row {
    grid-template-columns: 1fr;
  }

  .prepify-corrections-status {
    justify-self: start;
  }

  .prepify-correction-result-page .student-replay-shell {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }

  .prepify-correction-result-page .student-replay-teaching-area {
    grid-template-columns: minmax(11rem, .35fr) minmax(0, 1fr);
  }

  .prepify-correction-result-page .student-replay-chapters {
    position: static;
    height: auto;
  }

  .prepify-correction-result-page .student-replay-chapter-list {
    max-height: none;
    overflow: visible;
  }

  .prepify-catalog-lower-grid {
    grid-template-columns: 1fr;
    margin-top: 2.25rem;
  }

  .feedback-ticket-layout,
  .wallet-topup-layout {
    grid-template-columns: 1fr;
  }

  .prepify-wallet-hero {
    grid-template-columns: 1fr;
  }

  .prepify-wallet-summary-card {
    max-width: 30rem;
  }
}

@media (max-width: 767.98px) {
  .prepify-catalog-figma {
    max-width: none;
    margin-left: 0;
    padding-top: 0;
    gap: 1.35rem;
  }

  .prepify-my-exams-page {
    max-width: none;
    margin-left: 0;
    padding-top: 0;
    gap: 1.35rem;
  }

  .prepify-my-exams-hero .student-page-title {
    font-size: 2.55rem;
    line-height: 1.05;
  }

  .prepify-my-exams-summary {
    gap: .85rem;
  }

  .prepify-my-exams-summary .student-summary-card {
    min-height: 8rem;
    padding: 1rem .75rem;
  }

  .prepify-my-exams-summary .student-summary-card strong {
    font-size: 2rem;
  }

  .prepify-my-exams-page .student-exam-list-header {
    display: none;
  }

  .prepify-my-exams-page .student-exam-row {
    min-height: auto;
    padding: 1.1rem;
  }

  .prepify-corrections-page {
    max-width: none;
    margin-left: 0;
    padding-top: 0;
    gap: 1.35rem;
  }

  .prepify-corrections-hero {
    flex-direction: column;
    gap: .85rem;
  }

  .prepify-corrections-hero .student-page-title {
    font-size: 2.55rem;
    line-height: 1.05;
  }

  .prepify-corrections-actions {
    width: 100%;
    padding-top: 0;
  }

  .prepify-corrections-actions .btn {
    flex: 1 1 0;
    min-width: 0;
  }

  .prepify-corrections-summary {
    gap: .85rem;
  }

  .prepify-corrections-summary .student-summary-card {
    min-height: 8rem;
    padding: 1rem .75rem;
  }

  .prepify-corrections-summary .student-summary-card strong {
    font-size: 2rem;
  }

  .prepify-corrections-page .student-correction-row {
    min-height: auto;
    padding: 1.1rem;
  }

  .prepify-corrections-page .student-correction-actions {
    grid-template-columns: 1fr;
  }

  .prepify-correction-result-page {
    max-width: none;
    margin-left: 0;
    padding-top: 0;
  }

  .prepify-feedback-create-page {
    width: 100%;
    max-width: none;
    margin-top: 0;
    transform: none;
  }

  .prepify-feedback-create-page .student-page-title {
    font-size: 2.55rem;
    line-height: 1.05;
  }

  .prepify-feedback-intro {
    min-height: auto;
    padding: 1.4rem;
  }

  .prepify-feedback-motif {
    top: 1.1rem;
    right: 1.2rem;
    transform: scale(.82);
    transform-origin: top right;
  }

  .prepify-feedback-create-page .student-feedback-card {
    margin-top: 1.35rem;
  }

  .prepify-feedback-create-page .student-form-actions .btn {
    width: 100%;
  }

  .prepify-feedback-details {
    margin-top: 1.25rem;
  }

  .prepify-feedback-success-page {
    width: 100%;
    margin-top: 0;
    padding-bottom: 1rem;
    transform: none;
  }

  .prepify-feedback-success-mark {
    width: 7.6rem;
    height: 7.6rem;
    margin-bottom: 1.45rem;
  }

  .prepify-feedback-success-mark::before {
    top: -.4rem;
    left: .65rem;
    width: 6.45rem;
    height: 6.45rem;
  }

  .prepify-feedback-success-mark::after {
    top: 2.35rem;
    left: 2.35rem;
    width: 2.9rem;
    height: 2.9rem;
  }

  .prepify-feedback-success-check::before {
    top: 2.92rem;
    left: 3.12rem;
    width: .9rem;
    height: 1.65rem;
  }

  .prepify-feedback-success-hero h1 {
    font-size: 2.15rem;
    line-height: 1.04;
  }

  .prepify-feedback-success-card {
    min-height: auto;
    padding: 2.35rem 1.15rem 1.25rem;
  }

  .prepify-feedback-success-meta {
    grid-template-columns: 1fr;
  }

  .prepify-feedback-success-actions {
    flex-direction: column;
  }

  .prepify-feedback-success-btn {
    width: 100%;
    min-width: 0;
  }

  .prepify-feedback-wait-card {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 1.2rem;
  }

  .prepify-feedback-tickets-page,
  .prepify-feedback-ticket-detail-page {
    width: 100%;
    max-width: none;
    margin-top: 0;
  }

  .prepify-ticket-hero {
    flex-direction: column;
    padding: 1.15rem;
  }

  .prepify-ticket-hero .student-page-title {
    font-size: 2.35rem;
    line-height: 1.05;
  }

  .prepify-ticket-primary-action,
  .prepify-ticket-primary-action.btn {
    width: 100%;
  }

  .prepify-ticket-summary-grid {
    grid-template-columns: 1fr;
    gap: .7rem;
  }

  .prepify-ticket-summary-card {
    min-height: 5.4rem;
  }

  .prepify-ticket-row {
    min-height: auto;
  }

  .prepify-ticket-row .feedback-ticket-main {
    gap: .85rem;
    padding: 1rem;
  }

  .prepify-ticket-row .feedback-ticket-actions,
  .prepify-ticket-row .feedback-ticket-actions .btn,
  .prepify-ticket-pagination .btn {
    width: 100%;
  }

  .prepify-ticket-panel {
    padding: 1rem;
  }

  .prepify-ticket-panel-header {
    flex-direction: column;
  }

  .prepify-correction-result-page::before {
    display: none;
  }

  .prepify-correction-result-page .student-replay-stage-header {
    grid-template-columns: 1fr;
    min-height: auto;
    gap: .8rem;
  }

  .prepify-correction-result-page .student-replay-stage-header h2 {
    font-size: 1.75rem;
  }

  .prepify-correction-result-page .student-replay-stage-meta {
    justify-content: flex-start;
    padding-bottom: 0;
  }

  .prepify-correction-result-page .student-replay-exam-mark {
    min-width: min(100%, 13.5rem);
  }

  .prepify-correction-result-page .student-replay-teaching-area {
    grid-template-columns: 1fr;
  }

  .prepify-correction-result-page .student-replay-avatar-panel {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: minmax(18rem, 1fr);
    align-items: stretch;
    height: auto;
    min-height: 19.5rem;
    padding: 0;
  }

  .prepify-correction-result-page .student-replay-avatar-frame {
    min-height: 18rem;
    aspect-ratio: auto;
  }

  .prepify-correction-result-page .student-replay-board {
    min-height: auto;
    padding: 1.2rem;
  }

  .prepify-correction-result-page .student-replay-steps li {
    grid-template-columns: 1.75rem minmax(0, 1fr);
    gap: .65rem;
  }

  .prepify-correction-result-page .student-replay-progress {
    margin-top: 2rem;
  }

  .prepify-correction-result-page .student-mark-summary {
    margin-top: 2rem;
  }

  .prepify-pricing-heading h1 {
    font-size: 2rem;
    line-height: 1.1;
  }

  .prepify-grade-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    max-width: 100%;
    padding-bottom: .2rem;
  }

  .prepify-grade-tab {
    flex: 0 0 auto;
    padding-inline: 1.25rem;
  }

  .prepify-pricing-section h2,
  .prepify-catalog-lower-grid h2 {
    align-items: flex-start;
    font-size: 1.25rem;
    line-height: 1.35;
  }

  .prepify-pricing-grid,
  .prepify-topic-grid {
    grid-template-columns: 1fr;
  }

  .prepify-pricing-card {
    min-height: auto;
    padding: 2rem 1.25rem 1.15rem;
  }

  .prepify-pricing-card-copy {
    min-height: 0;
  }

  .prepify-price-line strong {
    font-size: 3rem;
  }

  .prepify-subject-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .student-catalog-header-actions,
  .student-catalog-mode-switch,
  .student-catalog-mode-switch .btn {
    width: 100%;
  }

  .student-catalog-mode-switch {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .student-catalog-card-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .student-catalog-card-footer form,
  .student-catalog-card-footer .btn {
    width: 100%;
  }

  .student-exam-row {
    gap: 1rem;
  }

  .student-status-card {
    padding: 1rem;
  }

  .student-status-meter {
    width: 100%;
    text-align: left;
  }

  .feedback-ticket-main {
    grid-template-columns: 1fr;
  }

  .feedback-ticket-actions {
    justify-self: start;
  }

  .prepify-wallet-page,
  .prepify-payment-result-page {
    width: 100%;
    max-width: none;
    padding-top: 0;
  }

  .prepify-wallet-hero .prepify-page-title {
    font-size: 2.55rem;
    line-height: 1.05;
  }

  .wallet-topup-card {
    padding: 1.15rem;
  }

  .prepify-wallet-summary-card,
  .payment-provider-option,
  .wallet-provider-costs,
  .payment-result-actions .btn,
  .student-submitted-exam-actions,
  .student-submitted-exam-actions .btn,
  .student-submit-panel .btn {
    width: 100%;
  }

  .payment-provider-option,
  .payment-result-summary {
    grid-template-columns: 1fr;
  }

  .wallet-provider-costs {
    align-items: flex-start;
  }

  .payment-result-card {
    padding: 1.2rem;
  }

  .student-active-exam-hero,
  .student-submitted-exam-header,
  .protected-exam-pdf-toolbar,
  .student-original-exam-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .student-exam-timer,
  .protected-exam-pdf-actions,
  .student-original-exam-actions {
    width: 100%;
  }

  .student-exam-timer {
    text-align: left;
  }

  .protected-exam-pdf-actions,
  .student-original-exam-actions {
    justify-content: space-between;
  }

  .protected-exam-pdf-pages,
  .student-original-exam-pages {
    height: 58vh;
    padding: .65rem;
  }
}
.prepify-experience-page {
  min-height: calc(100vh - 9rem);
  display: grid;
  justify-items: center;
  gap: 1.5rem;
  padding: clamp(1rem, 3vw, 3rem) 1rem;
}

.prepify-rating-card {
  width: min(100%, 550px);
  border: 1px solid var(--prepify-line);
  border-radius: var(--prepify-radius-lg);
  background: var(--prepify-surface);
  box-shadow: var(--prepify-shadow-md);
  padding: clamp(1.75rem, 4vw, 2.75rem);
  text-align: center;
}

.prepify-rating-card h1 {
  margin: 0;
  color: var(--prepify-blue);
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 800;
}

.prepify-rating-subtitle {
  margin: 1.25rem 0 1.5rem;
  color: var(--prepify-muted);
  font-size: .9rem;
}

.prepify-rating-latest {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem;
  margin-bottom: 1rem;
  color: var(--prepify-muted);
  font-size: .85rem;
}

.prepify-rating-label {
  margin-top: 1.25rem;
  color: var(--prepify-blue);
  font-weight: 800;
}

.prepify-rating-score {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: .25rem;
  margin-top: 2rem;
  color: var(--prepify-pink);
  font-weight: 800;
}

.prepify-rating-score span {
  font-size: clamp(2.4rem, 8vw, 3.25rem);
  line-height: 1;
}

.prepify-rating-score small {
  color: var(--prepify-faint);
  font-size: 1.3rem;
  font-weight: 700;
}

.prepify-star-options {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .75rem;
}

.prepify-star-option {
  min-width: 2.6rem;
  border: 0;
  border-radius: 50%;
  padding: .35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--prepify-faint);
  background: transparent;
  cursor: pointer;
  transition: color .16s ease, background-color .16s ease, transform .16s ease;
}

.prepify-star-option i {
  font-size: 2.5rem;
}

.prepify-star-option.is-active,
.btn-check:checked + .prepify-star-option {
  background: rgba(245, 158, 11, .12);
  color: var(--prepify-amber);
  transform: translateY(-1px);
}

.btn-check:focus-visible + .prepify-star-option {
  outline: 3px solid rgba(93, 53, 242, .28);
  outline-offset: 4px;
}

.prepify-rating-panel textarea {
  resize: vertical;
}

.prepify-rating-form .form-label {
  display: block;
  text-align: left;
  color: var(--prepify-ink);
  font-size: .9rem;
}

.prepify-rating-form textarea {
  min-height: 5.25rem;
  border-color: var(--prepify-line);
  border-radius: .75rem;
  background: var(--prepify-surface-soft);
}

.prepify-rating-submit {
  width: 100%;
}

.prepify-rating-tip {
  width: min(100%, 550px);
  display: flex;
  gap: .9rem;
  align-items: flex-start;
  border: 1px solid var(--prepify-line);
  border-radius: var(--prepify-radius-lg);
  background: rgba(255, 255, 255, .72);
  padding: 1rem;
}

.prepify-rating-tip-icon {
  width: 2rem;
  height: 2rem;
  border-radius: .55rem;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: #fff;
  background: var(--prepify-violet);
}

.prepify-rating-tip strong {
  color: var(--prepify-violet);
}

.prepify-rating-tip p {
  margin: .25rem 0 0;
  color: var(--prepify-muted);
  font-size: .85rem;
}

.prepify-free-content-list {
  display: grid;
  gap: 1rem;
}

.prepify-free-content-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
}

.prepify-app-shell .prepify-free-content-item {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(251, 249, 255, .92));
}

.prepify-free-content-item h2 {
  margin: 0;
  color: var(--prepify-ink);
  font-size: 1.1rem;
  font-weight: 800;
}

.prepify-free-content-item .btn {
  min-width: 7rem;
}

@media (max-width: 767.98px) {
  .prepify-free-content-item {
    align-items: flex-start;
    flex-direction: column;
  }

  .prepify-free-content-item .btn {
    width: 100%;
  }
}
