:root {
  --scp-purple: #39366e;
  --scp-purple-deep: #171342;
  --scp-lavender: #c0bfdb;
  --scp-lavender-soft: #f4f2fb;
  --scp-blue: #1a6aff;
  --scp-blue-soft: #eaf1ff;
  --scp-teal: #20b8c7;
  --scp-teal-soft: #e9fbfd;
  --scp-green: #62c370;
  --scp-green-soft: #eef9f0;
  --scp-pink: #ed1566;
  --scp-pink-soft: #fdeaf2;
  --scp-ink: #1f2533;
  --scp-muted: #6e6e6e;
  --scp-surface: #ffffff;
  --scp-border: #e5e2f3;
  --bs-primary: var(--scp-blue);
  --bs-primary-rgb: 26, 106, 255;
  --bs-body-color: var(--scp-ink);
  --bs-body-bg: var(--scp-lavender-soft);
  --bs-border-radius: .5rem;
}

body {
  min-height: 100vh;
  font-family: "Poppins", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
}

.scp-app-body {
  background:
    radial-gradient(circle at top left, rgba(32, 184, 199, .12), transparent 28rem),
    linear-gradient(180deg, #fbfbff 0%, var(--scp-lavender-soft) 100%);
}

.scp-topbar {
  background: var(--scp-purple-deep);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  box-shadow: 0 10px 30px rgba(23, 19, 66, .14);
}

.scp-topbar .navbar-brand,
.scp-topbar .nav-link {
  color: rgba(255, 255, 255, .84);
}

.scp-topbar .navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  font-weight: 700;
}

.scp-topbar .nav-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  border-radius: .5rem;
  padding: .55rem .75rem;
}

.scp-topbar .nav-link:hover,
.scp-topbar .nav-link.active {
  color: #ffffff;
  background: rgba(255, 255, 255, .1);
}

.scp-topbar .navbar-toggler {
  border-color: rgba(255, 255, 255, .25);
}

.scp-topbar .navbar-toggler-icon {
  filter: invert(1);
}

.scp-login-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--scp-purple-deep);
  font-weight: 700;
}

.scp-main {
  min-height: calc(100vh - 116px);
}

.scp-shell {
  min-height: calc(100vh - 116px);
}

.scp-sidebar {
  padding: 1.25rem;
  border-right: 1px solid var(--scp-border);
}

.scp-sidebar .nav-link {
  display: flex;
  align-items: center;
  gap: .65rem;
  color: #524f7b;
  border-radius: .5rem;
  font-weight: 600;
}

.scp-sidebar .nav-link.active {
  background: var(--scp-purple);
  color: #ffffff;
}

.scp-sidebar .nav-link.disabled {
  color: #aaa4c7;
}

.scp-content {
  padding: 1.25rem;
}

@media (min-width: 992px) {
  .scp-content {
    padding: 2rem;
  }
}

.scp-page-heading {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .scp-page-heading {
    flex-direction: row;
    align-items: center;
  }
}

.scp-eyebrow {
  color: var(--scp-teal);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.scp-panel,
.scp-metric {
  background: rgba(255, 255, 255, .92);
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  box-shadow: 0 10px 28px rgba(57, 54, 110, .08);
}

.scp-panel {
  padding: 1.25rem;
}

@media (min-width: 768px) {
  .scp-panel {
    padding: 1.5rem;
  }
}

.scp-metric {
  display: flex;
  align-items: center;
  gap: .9rem;
  min-height: 7rem;
  padding: 1rem;
}

.scp-metric-icon {
  display: inline-flex;
  width: 2.75rem;
  height: 2.75rem;
  flex: 0 0 2.75rem;
  align-items: center;
  justify-content: center;
  border-radius: .5rem;
  font-size: 1.35rem;
}

.scp-checklist {
  display: grid;
  gap: .5rem;
  color: var(--scp-purple);
  font-weight: 700;
}

.scp-checklist i {
  color: var(--scp-green);
  margin-right: .35rem;
}

.scp-admin-tabs {
  margin-bottom: 1.5rem;
}

.scp-admin-tabs .nav-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  white-space: nowrap;
  border: 1px solid var(--scp-border);
  background: #ffffff;
  color: #56517d;
}

.scp-admin-tabs .nav-link.active {
  background: var(--scp-purple);
  border-color: var(--scp-purple);
  color: #ffffff;
}

.scp-message-list .list-group-item {
  border-color: var(--scp-border);
  padding: .9rem 1rem;
}

.scp-message-list .list-group-item.active {
  background: var(--scp-purple);
  border-color: var(--scp-purple);
}

.scp-empty-state {
  display: grid;
  min-height: 12rem;
  place-items: center;
  align-content: center;
  text-align: center;
}

.scp-empty-state i {
  color: var(--scp-teal);
  font-size: 2rem;
  margin-bottom: .65rem;
}

.scp-contact-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.scp-chat-shell {
  display: grid;
  min-height: calc(100vh - 260px);
  overflow: hidden;
  background: rgba(255, 255, 255, .92);
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  box-shadow: 0 10px 28px rgba(57, 54, 110, .08);
}

.scp-chat-thread {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  max-height: calc(100vh - 360px);
  min-height: 18rem;
  overflow-y: auto;
  padding: 1rem;
}

.scp-chat-thread.is-review {
  max-height: none;
}

.scp-message-bubble {
  width: min(100%, 42rem);
  padding: .85rem 1rem;
  background: var(--scp-blue-soft);
  border: 1px solid rgba(26, 106, 255, .14);
  border-radius: .5rem;
}

.scp-message-bubble.is-mine {
  align-self: flex-end;
  background: var(--scp-teal-soft);
  border-color: rgba(32, 184, 199, .18);
}

.scp-message-bubble.is-deleted {
  border-style: dashed;
  background: #fff8ea;
}

.scp-deleted-message-panel {
  border-top: 1px solid var(--scp-border);
  padding: 1rem;
  background: #fffdf8;
}

.scp-message-admin-actions {
  border-top: 1px solid var(--scp-border);
  padding-top: .85rem;
}

.scp-message-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .75rem;
  justify-content: space-between;
  color: var(--scp-muted);
  font-size: .8rem;
  font-weight: 700;
}

.scp-message-body {
  margin-top: .35rem;
  white-space: pre-wrap;
  word-break: break-word;
}

.scp-message-action-menu {
  width: min(22rem, calc(100vw - 2rem));
}

.scp-row-action-menu {
  width: min(24rem, calc(100vw - 2rem));
}

.scp-row-action-menu .form-control-sm[type="datetime-local"] {
  width: 100%;
}

.scp-confirm-details {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: .35rem .75rem;
  padding: .85rem;
  background: var(--scp-lavender-soft);
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
}

.scp-confirm-details dt {
  color: var(--scp-purple);
  font-size: .78rem;
  font-weight: 800;
}

.scp-confirm-details dd {
  min-width: 0;
  margin: 0;
  color: var(--scp-muted);
  word-break: break-word;
}

.scp-post-body {
  max-width: 56rem;
}

.scp-post-body p {
  margin-bottom: 1rem;
  line-height: 1.65;
}

.scp-message-media {
  display: grid;
  gap: .65rem;
  margin-top: .65rem;
}

.scp-message-media img,
.scp-message-media video {
  display: block;
  width: min(100%, 32rem);
  max-height: 22rem;
  object-fit: contain;
  background: #ffffff;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
}

.scp-file-chip {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  align-items: center;
  gap: .45rem;
  padding: .55rem .7rem;
  color: var(--scp-purple);
  text-decoration: none;
  background: #ffffff;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
}

.scp-file-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scp-compose-stack {
  border-top: 1px solid var(--scp-border);
  background: #ffffff;
}

.scp-compose {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: end;
  padding: 1rem;
}

.scp-media-compose {
  display: grid;
  grid-template-columns: minmax(11rem, .75fr) minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
  padding: 0 1rem 1rem;
}

@media (max-width: 575.98px) {
  .scp-compose,
  .scp-media-compose {
    grid-template-columns: 1fr;
  }
}

.scp-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  gap: .75rem;
}

.scp-check-card {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  min-height: 4rem;
  padding: .85rem;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  background: #ffffff;
}

.scp-check-card small {
  display: block;
  color: var(--scp-muted);
}

.scp-auth-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at 18% 18%, rgba(32, 184, 199, .24), transparent 22rem),
    radial-gradient(circle at 92% 10%, rgba(237, 21, 102, .09), transparent 16rem),
    linear-gradient(135deg, var(--scp-purple-deep), var(--scp-purple));
}

.scp-auth-wrap {
  display: grid;
  min-height: 100vh;
  place-items: center;
  gap: 2rem;
  padding: 1.25rem;
}

@media (min-width: 992px) {
  .scp-auth-wrap {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 440px);
    padding: 3rem;
  }
}

.scp-auth-brand {
  max-width: 42rem;
  color: #ffffff;
}

.scp-auth-brand h1 {
  font-size: clamp(2.25rem, 5vw, 4.5rem);
  font-weight: 800;
  line-height: 1;
}

.scp-auth-copy {
  max-width: 31rem;
  color: rgba(255, 255, 255, .72);
  font-size: 1.1rem;
}

.scp-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5.75rem;
  height: 5.75rem;
  margin-bottom: 1.25rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, .12);
  box-shadow: 0 18px 45px rgba(0, 0, 0, .2);
}

.scp-public {
  min-height: 100vh;
  background: #fbfbff;
}

.scp-public-nav {
  position: absolute;
  z-index: 2;
  inset: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
}

.scp-public-nav .navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  color: #ffffff;
  font-weight: 800;
  text-decoration: none;
  text-shadow: 0 1px 8px rgba(23, 19, 66, .35);
}

.scp-public-hero {
  display: flex;
  min-height: 74svh;
  align-items: center;
  padding: 6rem 1rem 4rem;
  color: #ffffff;
  background:
    linear-gradient(90deg, rgba(23, 19, 66, .72), rgba(23, 19, 66, .2)),
    url("/static/images/public-hero.png") center / cover no-repeat;
}

.scp-public-hero-copy {
  width: min(42rem, 100%);
  margin-left: clamp(0rem, 6vw, 5rem);
}

.scp-public-hero h1 {
  max-width: 12ch;
  margin-bottom: 1rem;
  font-size: clamp(2.6rem, 7vw, 5.8rem);
  font-weight: 800;
  line-height: .95;
}

.scp-public-hero p:not(.scp-eyebrow) {
  max-width: 34rem;
  color: rgba(255, 255, 255, .88);
  font-size: 1.18rem;
}

.scp-public-band {
  padding: clamp(2.5rem, 6vw, 5rem) 1rem;
}

.scp-public-band-soft {
  background: var(--scp-lavender-soft);
}

.scp-public-inner {
  width: min(1100px, 100%);
  margin: 0 auto;
}

.scp-section-heading {
  margin-bottom: 1.5rem;
}

.scp-section-heading h2 {
  margin-bottom: 0;
  font-size: clamp(1.7rem, 4vw, 3rem);
  font-weight: 800;
}

.scp-public-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  gap: 1rem;
}

.scp-public-card,
.scp-public-form {
  padding: 1.25rem;
  background: #ffffff;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  box-shadow: 0 10px 24px rgba(57, 54, 110, .08);
}

@media (max-width: 575.98px) {
  .scp-public-nav {
    align-items: flex-start;
  }

  .scp-public-nav .navbar-brand span {
    display: none;
  }

  .scp-public-hero {
    min-height: 70svh;
    padding-top: 5.5rem;
  }
}

.scp-auth-card {
  width: min(100%, 440px);
  padding: 1.25rem;
  background: #ffffff;
  border: 1px solid rgba(255, 255, 255, .6);
  border-radius: .75rem;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .24);
}

@media (min-width: 576px) {
  .scp-auth-card {
    padding: 2rem;
  }
}

.scp-footer {
  padding: 1rem 0;
  background: rgba(255, 255, 255, .64);
  border-top: 1px solid var(--scp-border);
  font-size: .9rem;
}

.scp-footer .container-fluid {
  display: flex;
  flex-direction: column;
  gap: .25rem;
}

@media (min-width: 576px) {
  .scp-footer .container-fluid {
    flex-direction: row;
    justify-content: space-between;
  }
}

.bg-purple-soft {
  background: var(--scp-lavender-soft);
}

.bg-teal-soft {
  background: var(--scp-teal-soft);
}

.bg-green-soft {
  background: var(--scp-green-soft);
}

.bg-blue-soft {
  background: var(--scp-blue-soft);
}

.bg-pink-soft {
  background: var(--scp-pink-soft);
}

.text-purple {
  color: var(--scp-purple);
}

.text-teal {
  color: var(--scp-teal);
}

.text-green {
  color: var(--scp-green);
}

.text-blue {
  color: var(--scp-blue);
}

.text-pink {
  color: var(--scp-pink);
}

.scp-code-block {
  overflow: auto;
  padding: 1rem;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  background: #fbfbff;
  color: var(--scp-ink);
  white-space: pre-wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  font-weight: 700;
}

.btn-primary {
  --bs-btn-bg: var(--scp-blue);
  --bs-btn-border-color: var(--scp-blue);
  --bs-btn-hover-bg: #0f57dd;
  --bs-btn-hover-border-color: #0f57dd;
}

.scp-table {
  margin-bottom: 0;
}

.scp-table th {
  color: #5c587f;
  font-size: .78rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.scp-status-strip {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.scp-person-card {
  display: flex;
  align-items: center;
  gap: .8rem;
  min-height: 4.5rem;
  padding: .85rem;
  color: var(--scp-ink);
  text-decoration: none;
  background: #ffffff;
  border: 1px solid var(--scp-border);
  border-radius: .5rem;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.scp-person-card:hover {
  border-color: var(--scp-lavender);
  box-shadow: 0 10px 24px rgba(57, 54, 110, .1);
  color: var(--scp-ink);
  transform: translateY(-1px);
}

.scp-person-card small {
  display: block;
  color: var(--scp-muted);
}

.scp-avatar {
  display: inline-flex;
  width: 2.5rem;
  height: 2.5rem;
  flex: 0 0 2.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--scp-lavender-soft);
  color: var(--scp-purple);
  font-weight: 800;
}

.list-group-item {
  background: transparent;
}

.scp-calendar {
  min-height: 38rem;
}

.scp-calendar .fc {
  color: var(--scp-ink);
}

.scp-calendar .fc-toolbar {
  flex-wrap: wrap;
  gap: .75rem;
}

.scp-calendar .fc-toolbar-title {
  font-size: clamp(1.1rem, 2vw, 1.45rem);
  font-weight: 800;
}

.scp-calendar .fc-button {
  border-radius: .45rem;
  font-weight: 700;
}

.scp-calendar .fc-button-primary {
  background: var(--scp-purple);
  border-color: var(--scp-purple);
}

.scp-calendar .fc-button-primary:hover,
.scp-calendar .fc-button-primary:focus {
  background: var(--scp-purple-deep);
  border-color: var(--scp-purple-deep);
}

.scp-calendar .fc-event {
  border: 0;
  border-radius: .35rem;
  padding: .1rem .2rem;
  font-weight: 700;
}

.scp-calendar-activity,
.scp-calendar-meeting {
  background: var(--scp-blue);
}

.scp-calendar-holiday,
.scp-calendar-reminder {
  background: var(--scp-teal);
}

.scp-calendar-closure,
.scp-calendar-early_dismissal {
  background: var(--scp-pink);
}

.scp-calendar-canceled {
  background: #747081 !important;
  text-decoration: line-through;
}

.scp-tutoring-requested {
  background: var(--scp-teal);
}

.scp-tutoring-confirmed {
  background: var(--scp-blue);
}

.scp-tutoring-completed {
  background: var(--scp-green);
}

.scp-tutoring-no_show {
  background: var(--scp-pink);
}

.scp-admin-actions {
  display: grid;
  gap: .5rem;
  min-width: min(100%, 32rem);
}

.scp-admin-actions .form-control-sm[type="datetime-local"] {
  width: 12rem;
}

.scp-feedback-nav-btn {
  align-items: center;
  border: 0;
  color: rgba(255, 255, 255, .88) !important;
  display: inline-flex;
  gap: .35rem;
  min-height: 2.25rem;
  padding: .45rem .6rem;
  text-decoration: none;
}

.scp-feedback-nav-btn:hover,
.scp-feedback-nav-btn:focus {
  color: #fff !important;
}

.scp-feedback-modal {
  border: 0;
  border-radius: .5rem;
  box-shadow: 0 1.25rem 3rem rgba(23, 19, 66, .25);
}

.scp-feedback-categories {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.scp-reminder-settings {
  background: var(--scp-lavender-soft);
  border: 1px solid rgba(57, 54, 110, .12);
  border-radius: .5rem;
  padding: 1rem;
}

@media (max-width: 575.98px) {
  .scp-calendar {
    min-height: 31rem;
  }

  .scp-calendar .fc-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .scp-calendar .fc-toolbar-chunk {
    display: flex;
    justify-content: center;
  }
}
