:root {
  --bg-1: #0f172a;
  --bg-2: #1d2b64;
  --bg-3: #19223a;
  --text: #eef2ff;
  --muted: #c0c9ec;
  --glass: rgba(255, 255, 255, 0.13);
  --glass-border: rgba(255, 255, 255, 0.28);
  --accent: #61d3ff;
  --accent-2: #5f8cff;
  --danger: #ff6b6b;
  --ok: #68f3b6;
  --shadow: 0 24px 60px rgba(5, 12, 30, 0.35);
  --admin-ink: #1b2944;
  --admin-subtle: #6a7d9f;
  --admin-surface: rgba(247, 250, 255, 0.95);
  --admin-card: rgba(255, 255, 255, 0.92);
  --admin-border: rgba(157, 179, 232, 0.44);
  --admin-primary: #1a56db;
  --admin-primary-dark: #1238a2;
  --admin-secondary: #0b776a;
  --admin-tertiary: #6b3df2;
  --admin-danger: #c84f64;
  --admin-shadow: 0 28px 60px rgba(17, 31, 66, 0.14);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: "Manrope", "Sora", "Trebuchet MS", sans-serif;
  color: #191c1e;
  background:
    radial-gradient(circle at 14% 12%, rgba(26, 86, 219, 0.08), transparent 30%),
    radial-gradient(circle at 86% 8%, rgba(107, 61, 242, 0.08), transparent 26%),
    linear-gradient(180deg, #f7f9fb, #eef3fb 58%, #edf2f9);
  background-attachment: fixed;
}

.bg-ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 68% 76%, rgba(107, 61, 242, 0.08), transparent 32%),
    radial-gradient(circle at 18% 84%, rgba(26, 86, 219, 0.1), transparent 38%);
  filter: blur(26px);
}

.app-shell {
  position: relative;
  z-index: 1;
  width: min(1700px, 100% - 2rem);
  margin: 1rem auto 2rem;
}

.app-shell--reader {
  width: 100%;
  margin: 0;
  min-height: 100vh;
  padding-bottom: 2rem;
}

.reader-topbar {
  position: fixed;
  inset: 0 0 auto;
  z-index: 30;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.65);
  box-shadow: 0 18px 36px rgba(20, 42, 88, 0.08);
}

.reader-topbar-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: min(100%, 1560px);
  margin: 0 auto;
  padding: 0.95rem 1.5rem;
}

.reader-brand-block {
  display: flex;
  align-items: center;
  gap: 2rem;
  min-width: 0;
}

.reader-brand {
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: #2146a4;
  white-space: nowrap;
}

.reader-top-links {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.reader-top-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.2rem;
  padding: 0.3rem 0.75rem;
  border-radius: 0.75rem;
  color: #6f778a;
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 600;
  transition: color 160ms ease, background 160ms ease, transform 160ms ease;
}

.reader-top-link:hover {
  color: #1353d8;
  background: rgba(26, 86, 219, 0.08);
  transform: translateY(-1px);
}

.reader-top-link--active {
  color: #1a56db;
  font-weight: 800;
  box-shadow: inset 0 -2px 0 #1a56db;
}

.reader-topbar-actions {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.reader-topbar-icon {
  position: relative;
  width: 2.6rem;
  height: 2.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #6f778a;
  box-shadow: none;
}

.reader-topbar-icon:hover {
  color: #1353d8;
  background: rgba(26, 86, 219, 0.08);
}

.reader-sidebar-toggle .material-symbols-outlined {
  transition: transform 180ms ease;
}

.reader-topbar-dot {
  position: absolute;
  top: 0.55rem;
  right: 0.65rem;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: #ba1a1a;
}

.reader-top-avatar {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(19, 83, 216, 0.14);
  background: linear-gradient(135deg, rgba(26, 86, 219, 0.16), rgba(107, 61, 242, 0.16));
  color: #1a56db;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.reader-layout-shell {
  display: block;
}

.reader-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 20;
  width: 16rem;
  padding: 5.3rem 1rem 1rem;
  transition: width 220ms ease, padding 220ms ease, transform 220ms ease;
}

.reader-sidebar-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  padding: 0.6rem 0.45rem;
  overflow: hidden;
  overflow: clip;
  background: rgba(248, 250, 252, 0.52);
  backdrop-filter: blur(26px);
  -webkit-backdrop-filter: blur(26px);
  border-right: 1px solid rgba(255, 255, 255, 0.5);
  transition:
    padding 220ms ease,
    gap 220ms ease,
    border-radius 220ms ease,
    background 220ms ease,
    max-height 220ms ease,
    opacity 220ms ease;
}

.reader-user-card {
  display: grid;
  gap: 0.65rem;
  padding: 0.85rem;
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.48);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.reader-user-card-mark {
  width: 2.55rem;
  height: 2.55rem;
  border-radius: 0.82rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #1a56db, #5d00cc);
  color: #fff;
  box-shadow: 0 16px 28px rgba(26, 86, 219, 0.22);
}

.reader-user-card-copy {
  display: grid;
  gap: 0.18rem;
}

.reader-user-card-copy strong {
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: 0.96rem;
  font-weight: 700;
  color: #1a2540;
}

.reader-user-card-copy p {
  margin: 0;
  font-size: 0.76rem;
  color: #6f778a;
}

.reader-user-chip-row {
  display: grid;
  gap: 0.34rem;
}

.reader-user-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  padding: 0.48rem 0.6rem;
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.66);
  color: #1f2d48;
}

.reader-user-chip-label,
.reader-sidebar-label,
.reader-stage-label {
  font-size: 0.67rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #8a92a6;
}

.reader-user-chip strong {
  font-size: 0.75rem;
  font-weight: 700;
  color: #21355d;
}

.reader-sidebar-section {
  display: grid;
  gap: 0.65rem;
}

.reader-sidebar-section--menu {
  min-height: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  overflow-y: auto;
  padding-right: 0.12rem;
}

.reader-sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0 0.45rem;
}

.reader-sidebar-head--categories {
  margin-top: 0.3rem;
}

.reader-tree-helper {
  margin: -0.1rem 0 0;
  padding: 0 0.45rem;
  color: #72809b;
  font-size: 0.68rem;
  line-height: 1.35;
}

.reader-sidebar-links {
  display: grid;
  gap: 0.2rem;
}

.reader-sidebar-section--menu .reader-sidebar-links {
  flex: 0 0 auto;
}

.reader-sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.64rem 0.78rem;
  border-radius: 1rem;
  color: #58647d;
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 600;
  transition: transform 180ms ease, color 180ms ease, background 180ms ease;
}

.reader-sidebar-link:hover {
  color: #1353d8;
  background: rgba(255, 255, 255, 0.58);
  transform: translateX(3px);
}

.reader-sidebar-link--active {
  color: #1a56db;
  font-weight: 800;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 10px 24px rgba(20, 42, 88, 0.08);
}

.reader-sidebar-link--footer {
  width: 100%;
  border: 0;
  justify-content: flex-start;
  background: transparent;
  box-shadow: none;
}

.reader-sidebar-link .material-symbols-outlined {
  font-size: 1.15rem;
}

.reader-inline-action {
  border: 0;
  background: transparent;
  color: #1353d8;
  padding: 0.2rem 0;
  font-size: 0.76rem;
  font-weight: 800;
  box-shadow: none;
}

.reader-inline-action:hover {
  color: #0f43b0;
  background: transparent;
}

.reader-sidebar-section--tree {
  min-height: 0;
  flex: 1 1 auto;
}

.doc-tree--reader {
  flex: 0 0 auto;
  min-height: 0;
  max-height: none;
  overflow: visible;
  padding-right: 0.2rem;
}

.doc-tree--reader .category-block {
  margin: 0 0 0.3rem;
  padding: 0;
  border: 0;
  background: transparent;
}

.doc-tree--reader .category-toggle {
  position: relative;
  display: grid;
  width: 100%;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 0.7rem;
  padding: 0.75rem 0.9rem;
  border: 0;
  border-radius: 0.9rem;
  background: transparent;
  color: #6a7285;
}

.doc-tree--reader .category-toggle:hover,
.doc-tree--reader .category-toggle.expanded {
  transform: translateX(2px);
  background: rgba(26, 86, 219, 0.08);
  color: #1353d8;
}

.category-toggle-icon {
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 0.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(26, 86, 219, 0.08);
  color: #1353d8;
  font-size: 1.1rem;
}

.category-toggle-copy {
  display: grid;
  gap: 0.14rem;
  min-width: 0;
}

.category-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: inherit;
  line-height: 1.35;
}

.category-toggle-meta {
  color: inherit;
  font-size: 0.63rem;
  letter-spacing: 0.11em;
}

.category-toggle-chevron {
  color: inherit;
  font-size: 1rem;
  transition: transform 180ms ease;
}

.doc-tree--reader .category-toggle.expanded .category-toggle-chevron {
  transform: rotate(180deg);
}

.doc-tree--reader .category-body {
  padding: 0.12rem 0 0.35rem 0.9rem;
}

.doc-tree--reader .subject-group + .subject-group {
  margin-top: 0.15rem;
}

.doc-tree--reader .subject-toggle {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.6rem;
  padding: 0.7rem 0.8rem;
  border: 0;
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.42);
  color: #44516d;
}

.doc-tree--reader .subject-toggle:hover,
.doc-tree--reader .subject-toggle.expanded {
  background: rgba(255, 255, 255, 0.72);
  color: #173f9d;
  transform: translateX(2px);
}

.subject-toggle-label {
  font-size: 0.76rem;
  font-weight: 700;
  color: inherit;
  min-width: 0;
}

.subject-toggle-trail {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  margin-left: auto;
}

.subject-toggle-meta {
  font-size: 0.62rem;
  letter-spacing: 0.11em;
  color: inherit;
}

.subject-toggle-chevron {
  font-size: 1rem;
  color: inherit;
  transition: transform 180ms ease;
}

.doc-tree--reader .subject-toggle.expanded .subject-toggle-chevron {
  transform: rotate(90deg);
}

.doc-tree--reader .subject-book-list,
.doc-tree--reader .standalone-category-book-list {
  gap: 0.35rem;
  padding: 0.35rem 0 0 0.55rem;
}

.doc-tree--reader .doc-btn {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.18rem;
  padding: 0.72rem 0.85rem 0.72rem 1rem;
  border: 0;
  border-radius: 0.95rem;
  margin-top: 0;
  background: rgba(255, 255, 255, 0.68);
  color: #25324d;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.doc-tree--reader .doc-btn::before {
  content: "";
  position: absolute;
  left: 0.38rem;
  top: 50%;
  width: 0.36rem;
  height: 1.4rem;
  border-radius: 999px;
  background: rgba(26, 86, 219, 0.14);
  transform: translateY(-50%);
}

.doc-tree--reader .doc-btn:hover,
.doc-tree--reader .doc-btn.active {
  transform: translateX(2px);
  border-color: transparent;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 22px rgba(20, 42, 88, 0.08);
}

.doc-tree--reader .doc-btn.active::before {
  background: linear-gradient(180deg, #1a56db, #6b3df2);
}

.doc-btn-title {
  font-size: 0.76rem;
  font-weight: 700;
  color: inherit;
}

.doc-btn-meta {
  color: #7f8aa1;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
}

.reader-sidebar-footer {
  display: grid;
  gap: 0.2rem;
  margin-top: 0.35rem;
  padding-top: 0.45rem;
  border-top: 1px solid rgba(210, 219, 235, 0.6);
  background: rgba(248, 250, 252, 0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.reader-primary-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.45rem;
  padding: 0.62rem 0.82rem;
  border-radius: 999px;
  text-decoration: none;
  background: linear-gradient(135deg, #003fb1, #1a56db);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 18px 28px rgba(26, 86, 219, 0.22);
}

.reader-sidebar-link--footer {
  padding: 0.58rem 0.74rem;
}

.reader-main {
  margin-left: 16rem;
  padding: 5.5rem 2rem 0;
  transition: margin-left 220ms ease, padding 220ms ease;
}

.reader-main-inner {
  width: min(100%, 1280px);
  margin: 0 auto;
}

.reader-hero {
  margin-bottom: 1.6rem;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.reader-hero-copy {
  max-width: 42rem;
}

.reader-hero-kicker-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.reader-hero-kicker {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.65rem;
  border-radius: 0.45rem;
  background: rgba(11, 119, 106, 0.1);
  border: 1px solid rgba(11, 119, 106, 0.12);
  color: #0b776a;
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.reader-hero-submeta {
  font-size: 0.78rem;
  font-weight: 600;
  color: #7f8aa1;
}

.reader-hero h1 {
  margin: 0;
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: clamp(2rem, 3.4vw, 3.55rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
  color: #17233d;
}

.reader-hero p {
  margin: 0.55rem 0 0;
  color: #73809b;
  font-size: clamp(1rem, 1.45vw, 1.35rem);
  font-weight: 500;
}

.reader-hero-actions {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.reader-secondary-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.9rem;
  padding: 0.7rem 1.15rem;
  border-radius: 999px;
  border: 1px solid rgba(223, 228, 238, 0.95);
  background: rgba(255, 255, 255, 0.82);
  color: #17233d;
  font-size: 0.85rem;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(20, 42, 88, 0.08);
}

.reader-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.78fr);
  gap: 2rem;
  align-items: start;
}

.reader-stage-card,
.reader-context-card {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 24px 46px rgba(22, 42, 88, 0.08);
}

.reader-stage-card {
  display: flex;
  flex-direction: column;
  min-height: 760px;
  border-radius: 1.8rem;
  overflow: hidden;
}

.reader-stage-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.15rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.75);
  background: rgba(255, 255, 255, 0.38);
}

.reader-stage-toolbar-group {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.reader-stage-actions {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.reader-stage-icon {
  width: 2.35rem;
  height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 0.8rem;
  background: transparent;
  color: #6f778a;
  box-shadow: none;
}

.reader-stage-icon:hover {
  background: rgba(0, 0, 0, 0.05);
  color: #17233d;
}

.pdf-stage--reader {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 680px;
  padding: 1rem;
  border: 0;
  border-radius: 0;
  background: #fff;
}

.viewer-status {
  font-size: 0.83rem;
  color: #6f778a;
  margin-bottom: 0.7rem;
}

.flipbook-frame {
  width: 100%;
  min-height: 620px;
  border: 0;
  border-radius: 1rem;
  background:
    linear-gradient(180deg, rgba(247, 250, 255, 0.98), rgba(245, 248, 253, 0.98));
  box-shadow: 0 28px 56px rgba(17, 31, 66, 0.18);
}

.reader-progress {
  height: 0.38rem;
  width: 100%;
  background: rgba(226, 232, 240, 0.9);
  overflow: hidden;
}

.reader-progress-fill {
  height: 100%;
  width: 8%;
  border-radius: 0 999px 999px 0;
  background: linear-gradient(90deg, #003fb1, #1a56db);
  transition: width 220ms ease;
}

.reader-context {
  display: grid;
  gap: 1rem;
}

.reader-context-card {
  padding: 1.2rem;
  border-radius: 1.65rem;
}

.reader-context-card--insight {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.86)),
    radial-gradient(circle at top right, rgba(93, 0, 204, 0.08), transparent 40%);
  box-shadow: 0 0 24px rgba(93, 0, 204, 0.08);
}

.reader-context-head {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.8rem;
}

.reader-context-head .material-symbols-outlined {
  color: #5d00cc;
}

.reader-context-head h3,
.reader-context-card h4 {
  margin: 0;
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: 1.02rem;
  font-weight: 700;
  color: #17233d;
  letter-spacing: -0.03em;
}

.reader-context-card h4 {
  margin-bottom: 0.8rem;
}

.reader-context-card p {
  margin: 0;
  color: #68758f;
  line-height: 1.7;
  font-size: 0.92rem;
}

.reader-context-metrics,
.reader-stat-stack {
  display: grid;
  gap: 0.7rem;
}

.reader-context-row,
.reader-stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.85rem 0.95rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.64);
  color: #5f6d89;
  font-size: 0.9rem;
}

.reader-context-row strong,
.reader-stat-row strong {
  color: #17233d;
}

.reader-related-list {
  display: grid;
  gap: 0.7rem;
}

.reader-related-item {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.78rem;
  border: 0;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.58);
  color: #17233d;
  text-align: left;
  box-shadow: none;
}

.reader-related-item:hover {
  background: rgba(255, 255, 255, 0.82);
  transform: translateX(2px);
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar {
  width: 5.4rem;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-main {
  margin-left: 5.4rem;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-inner {
  padding-inline: 0.35rem;
  align-items: stretch;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-user-card {
  padding-inline: 0.65rem;
  justify-items: center;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-user-card-copy,
.app-shell--reader.reader-shell--sidebar-collapsed .reader-user-chip-row,
.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-head--categories,
.app-shell--reader.reader-shell--sidebar-collapsed .reader-tree-helper,
.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-link span:not(.material-symbols-outlined),
.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-footer .reader-primary-cta {
  display: none;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-link {
  justify-content: center;
  padding-inline: 0.6rem;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-section--menu {
  overflow-y: auto;
  padding-right: 0;
}

.app-shell--reader.reader-shell--sidebar-collapsed .doc-tree--reader {
  display: grid;
  gap: 0.28rem;
  overflow: visible;
  padding-right: 0;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-tree-link--category,
.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-tree-link--subject {
  justify-content: center;
  width: 100%;
  margin-left: 0;
  padding: 0.52rem;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-tree-link--book,
.app-shell--reader.reader-shell--sidebar-collapsed .standalone-category-book-list,
.app-shell--reader.reader-shell--sidebar-collapsed .subject-book-list {
  display: none !important;
}

.app-shell--reader.reader-shell--sidebar-collapsed .category-toggle-copy,
.app-shell--reader.reader-shell--sidebar-collapsed .category-toggle-meta,
.app-shell--reader.reader-shell--sidebar-collapsed .category-toggle-chevron,
.app-shell--reader.reader-shell--sidebar-collapsed .subject-toggle-label,
.app-shell--reader.reader-shell--sidebar-collapsed .subject-toggle-meta,
.app-shell--reader.reader-shell--sidebar-collapsed .subject-toggle-chevron {
  display: none;
}

.app-shell--reader.reader-shell--sidebar-collapsed .category-body {
  padding: 0.12rem 0 0;
}

.app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-toggle .material-symbols-outlined {
  transform: rotate(180deg);
}

.reader-related-cover {
  width: 2.6rem;
  height: 3.4rem;
  border-radius: 0.55rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(26, 86, 219, 0.16), rgba(93, 0, 204, 0.18));
  color: #1a56db;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.reader-related-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.reader-related-copy strong {
  font-size: 0.84rem;
  color: #17233d;
}

.reader-related-copy span {
  font-size: 0.72rem;
  color: #7a879f;
}

.reader-reading-head {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.8rem;
  color: #0b776a;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.glass-card {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.08));
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px) saturate(130%);
  -webkit-backdrop-filter: blur(18px) saturate(130%);
}

.glass-pill {
  background: rgba(15, 26, 52, 0.46);
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  padding: 0.75rem 1.1rem;
}

.hero {
  border-radius: 24px;
  padding: 0.9rem 1rem;
  display: block;
}

.hero-summary-line {
  display: flex;
  align-items: center;
  gap: 0.36rem;
  min-width: 0;
  width: 100%;
  flex-wrap: nowrap;
}

.hero-inline-item {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  padding: 0.46rem 0.58rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(8, 16, 34, 0.32);
  white-space: nowrap;
  min-width: 0;
  flex: 1 1 0;
}

.hero-inline-item strong {
  font-size: 0.75rem;
  line-height: 1.2;
  color: var(--text);
  display: block;
  max-width: none;
  overflow: hidden;
  text-overflow: ellipsis;
}

#userBadge {
  max-width: none;
}

#heroRoleValue {
  max-width: none;
}

#heroProgrammeValue {
  max-width: none;
}

#heroStatusValue {
  max-width: none;
}

#classBadge {
  max-width: none;
}

.hero-inline-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  white-space: nowrap;
  flex: 1.2 1 0;
}

.hero-inline-actions .ghost-btn {
  padding: 0.42rem 0.56rem;
  font-size: 0.72rem;
  line-height: 1;
  white-space: nowrap;
  flex: 1 1 0;
  min-width: 0;
}

.meta-label {
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.045em;
  color: var(--muted);
  flex: 0 0 auto;
}

@media (max-width: 1500px) {
  .hero {
    padding-inline: 0.9rem;
  }
}

@media (max-width: 1360px) {
  .hero-summary-line {
    gap: 0.28rem;
  }

  .hero-inline-item {
    padding: 0.42rem 0.5rem;
  }

  .hero-inline-item strong {
    font-size: 0.72rem;
  }

  .hero-inline-actions {
    flex-basis: 1.1fr;
  }

  .hero-inline-actions .ghost-btn {
    padding-inline: 0.48rem;
    font-size: 0.7rem;
  }
}

.workspace {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.side-panel,
.viewer-panel,
.admin-panel {
  border-radius: 22px;
  padding: 1rem;
}

.side-panel {
  display: block;
}

.admin-panel--bottom {
  margin-top: 1rem;
}

.reader-main > .admin-panel {
  width: min(100%, 1280px);
  margin: 1rem auto 0;
  transition: width 220ms ease, margin 220ms ease;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.8rem;
}

.panel-head h2,
.viewer-panel h2,
.admin-panel h2 {
  margin: 0;
  font-size: 1.05rem;
}

.doc-tree {
  min-height: 0;
  max-height: calc(100vh - 250px);
  overflow: auto;
  padding-right: 0.25rem;
}

.category-block {
  margin-bottom: 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.17);
  border-radius: 14px;
  padding: 0.7rem;
  background: rgba(11, 20, 42, 0.33);
}

.category-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 12px;
  padding: 0.72rem 0.78rem;
  background: rgba(8, 18, 39, 0.58);
  color: var(--text);
  cursor: pointer;
  transition: border-color 0.14s ease, background 0.14s ease, transform 0.14s ease;
}

.category-toggle:hover,
.category-toggle.expanded {
  border-color: rgba(97, 211, 255, 0.8);
  background: rgba(16, 31, 59, 0.88);
  transform: translateY(-1px);
}

.category-title {
  color: #d7deff;
  font-size: 0.95rem;
  font-weight: 700;
}

.category-toggle-meta {
  flex-shrink: 0;
  color: var(--muted);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.category-body {
  padding-top: 0.58rem;
}

.category-body:not(.expanded) {
  display: none;
}

.subject-group + .subject-group {
  margin-top: 0.45rem;
}

.subject-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 11px;
  padding: 0.62rem 0.7rem;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  cursor: pointer;
  transition: border-color 0.14s ease, background 0.14s ease, transform 0.14s ease;
}

.subject-toggle:hover,
.subject-toggle.expanded {
  border-color: rgba(97, 211, 255, 0.8);
  background: rgba(20, 33, 65, 0.75);
  transform: translateY(-1px);
}

.subject-toggle-label {
  font-size: 0.92rem;
  font-weight: 600;
}

.subject-toggle-meta {
  flex-shrink: 0;
  color: var(--muted);
  font-size: 0.75rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.subject-book-list {
  display: grid;
  gap: 0.34rem;
  padding: 0.42rem 0 0 0.38rem;
}

.standalone-category-book-list {
  display: grid;
  gap: 0.34rem;
  padding-top: 0.42rem;
}

.subject-book-list:not(.expanded) {
  display: none;
}

.app-shell--reader .reader-sidebar-section--tree {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
}

.app-shell--reader .doc-tree--reader {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 0.35rem;
  min-height: 14rem;
  max-height: none;
  overflow: auto;
}

.app-shell--reader .doc-tree--reader .category-title,
.app-shell--reader .doc-tree--reader .subject-toggle-label,
.app-shell--reader .doc-tree--reader .doc-btn-title {
  color: inherit;
}

.app-shell--reader .doc-tree--reader .category-toggle-meta {
  color: #6f7c95;
}

.app-shell--reader .doc-tree--reader .subject-toggle-meta,
.app-shell--reader .doc-tree--reader .doc-btn-meta {
  color: #7b879d;
}

.app-shell--reader .doc-tree--reader:empty::before {
  content: "Loading categories...";
  color: #72809b;
  font-size: 0.78rem;
}

.app-shell--reader .reader-sidebar-head--categories {
  margin-top: 0.35rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(210, 219, 235, 0.55);
}

.app-shell--reader .reader-sidebar-tree-link {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-align: left;
  border: 0;
  border-radius: 1rem;
  box-shadow: none;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--category {
  padding: 0.62rem 0.78rem;
  background: rgba(255, 255, 255, 0.58);
  color: #58647d;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--category:hover,
.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--category.expanded {
  background: rgba(255, 255, 255, 0.82);
  color: #1353d8;
  transform: translateX(3px);
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--category .category-toggle-meta {
  display: none;
}

.app-shell--reader .doc-tree--reader .category-toggle-icon {
  flex: 0 0 auto;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 0;
  background: transparent;
  font-size: 1.15rem;
}

.app-shell--reader .doc-tree--reader .category-body {
  padding: 0.18rem 0 0.32rem;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--subject {
  margin-left: 0.75rem;
  width: calc(100% - 0.75rem);
  padding: 0.56rem 0.72rem;
  background: rgba(255, 255, 255, 0.32);
  color: #52617a;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--subject:hover,
.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--subject.expanded {
  background: rgba(255, 255, 255, 0.68);
  color: #173f9d;
  transform: translateX(3px);
}

.app-shell--reader .doc-tree--reader .subject-toggle-icon {
  flex: 0 0 auto;
  font-size: 1.05rem;
  color: inherit;
}

.app-shell--reader .doc-tree--reader .subject-book-list,
.app-shell--reader .doc-tree--reader .standalone-category-book-list {
  gap: 0.16rem;
  padding: 0.12rem 0 0 0;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--book {
  margin-left: 1.35rem;
  width: calc(100% - 1.35rem);
  padding: 0.52rem 0.68rem 0.52rem 0.92rem;
  border-radius: 0 1rem 1rem 0;
  background: transparent;
  color: #4f5c75;
  border-left: 2px solid rgba(26, 86, 219, 0.14);
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--book::before {
  left: 0;
}

.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--book:hover,
.app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--book.active {
  background: rgba(255, 255, 255, 0.76);
  color: #173f9d;
  border-left-color: #1a56db;
  transform: translateX(3px);
}

.app-shell--reader .doc-tree--reader .category-title,
.app-shell--reader .doc-tree--reader .subject-toggle-label,
.app-shell--reader .doc-tree--reader .doc-btn-title {
  font-size: 0.82rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-shell--reader .doc-tree--reader .subject-toggle-meta,
.app-shell--reader .doc-tree--reader .doc-btn-meta {
  display: none;
}

.doc-btn {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.18rem;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  padding: 0.55rem 0.58rem;
  margin-top: 0.28rem;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  cursor: pointer;
  transition: transform 0.12s ease, border-color 0.12s ease;
}

.doc-btn:hover,
.doc-btn.active {
  transform: translateY(-1px);
  border-color: rgba(97, 211, 255, 0.8);
}

.doc-btn-title {
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.35;
}

.doc-btn-meta {
  color: var(--muted);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.viewer-panel {
  min-height: calc(100vh - 250px);
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 0.8rem;
}

.viewer-toolbar {
  display: grid;
  gap: 0.45rem;
}

.doc-context h2 {
  margin: 0;
  font-size: 1.1rem;
}

.doc-context p {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.83rem;
}

.toolbar-row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.small-btn,
.ghost-btn,
button[type="submit"],
button[type="button"] {
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.11);
  color: var(--text);
  border-radius: 10px;
  padding: 0.47rem 0.74rem;
  cursor: pointer;
}

.ghost-btn {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.small-btn:hover,
.ghost-btn:hover,
button[type="submit"]:hover,
button[type="button"]:hover {
  border-color: rgba(97, 211, 255, 0.78);
}

button[type="submit"] {
  background: linear-gradient(130deg, var(--accent), var(--accent-2));
  color: #091124;
  font-weight: 700;
}

.app-shell--reader button.reader-topbar-icon,
.app-shell--reader button.reader-stage-icon,
.app-shell--reader button.reader-inline-action,
.app-shell--reader button.reader-sidebar-link--footer,
.app-shell--reader button.reader-related-item {
  border: 0;
  box-shadow: none;
}

.app-shell--reader button.reader-topbar-icon {
  background: transparent;
  color: #6f778a;
}

.app-shell--reader button.reader-topbar-icon:hover {
  color: #1353d8;
  background: rgba(26, 86, 219, 0.08);
}

.app-shell--reader button.reader-stage-icon {
  background: transparent;
  color: #6f778a;
}

.app-shell--reader button.reader-stage-icon:hover {
  background: rgba(0, 0, 0, 0.05);
  color: #17233d;
}

.app-shell--reader button.reader-inline-action {
  background: transparent;
  color: #1353d8;
}

.app-shell--reader button.reader-inline-action:hover {
  background: transparent;
  color: #0f43b0;
}

.app-shell--reader button.reader-sidebar-link--footer {
  background: transparent;
  color: #58647d;
}

.app-shell--reader button.reader-secondary-cta {
  border: 1px solid rgba(223, 228, 238, 0.95);
  background: rgba(255, 255, 255, 0.82);
  color: #17233d;
  box-shadow: 0 14px 28px rgba(20, 42, 88, 0.08);
}

.app-shell--reader button.reader-related-item {
  background: rgba(255, 255, 255, 0.58);
  color: #17233d;
}

.app-shell--reader button.reader-related-item:hover {
  background: rgba(255, 255, 255, 0.82);
}

.app-shell--reader button:focus-visible,
.app-shell--reader a:focus-visible {
  outline: 2px solid rgba(26, 86, 219, 0.34);
  outline-offset: 2px;
}

.danger-btn {
  background: rgba(255, 88, 103, 0.22);
  border-color: rgba(255, 148, 158, 0.66);
}

input,
select {
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  background: rgba(0, 0, 0, 0.18);
  color: var(--text);
  padding: 0.48rem 0.58rem;
}

textarea {
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  background: rgba(0, 0, 0, 0.18);
  color: var(--text);
  padding: 0.48rem 0.58rem;
  resize: vertical;
  min-height: 86px;
}

input::placeholder {
  color: rgba(238, 242, 255, 0.62);
}

textarea::placeholder {
  color: rgba(238, 242, 255, 0.62);
}

.viewer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
  min-height: 0;
}

.pdf-stage {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  padding: 0.6rem;
  overflow: auto;
  background: rgba(1, 7, 20, 0.42);
}

.viewer-status {
  font-size: 0.84rem;
  color: var(--muted);
  margin-bottom: 0.55rem;
}

.flipbook-frame {
  width: 100%;
  min-height: min(75vh, 920px);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.38);
}

.admin-note,
.admin-status {
  margin: 0.2rem 0 0.7rem;
  color: var(--muted);
  font-size: 0.83rem;
}

.admin-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.admin-panel-head h2 {
  margin: 0;
}

.admin-panel form {
  display: grid;
  gap: 0.6rem;
}

.admin-panel--bottom #adminForm,
.admin-panel--bottom .admin-user-editor form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.admin-panel--bottom #adminForm > .book-batch-editor,
.admin-panel--bottom #adminForm > .admin-actions,
.admin-panel--bottom .admin-user-editor form > .admin-actions,
.admin-panel--bottom .admin-user-editor form > #adminUserTeacherProgrammesWrap {
  grid-column: 1 / -1;
}

.admin-panel label {
  display: grid;
  gap: 0.3rem;
  font-size: 0.84rem;
  color: var(--muted);
}

.field-hint {
  font-size: 0.74rem;
  line-height: 1.35;
  color: rgba(238, 242, 255, 0.68);
}

.book-batch-editor {
  display: grid;
  gap: 0.65rem;
}

.book-batch-head {
  display: flex;
  justify-content: space-between;
  gap: 0.7rem;
  align-items: flex-start;
  flex-wrap: wrap;
}

.book-batch-head h3 {
  margin: 0;
  font-size: 0.95rem;
  color: var(--text);
}

.book-batch-head .admin-note {
  margin: 0.22rem 0 0;
}

.book-draft-list {
  display: grid;
  gap: 0.7rem;
}

.book-draft-row {
  display: grid;
  gap: 0.55rem;
  padding: 0.7rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(8, 15, 32, 0.3);
}

.book-draft-row-head {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}

.book-draft-row-title {
  font-size: 0.84rem;
  letter-spacing: 0.03em;
}

.book-draft-row-grid {
  display: grid;
  gap: 0.55rem;
}

.admin-actions {
  display: flex;
  gap: 0.46rem;
  flex-wrap: wrap;
}

.admin-subject-groups,
.admin-subject-order,
.admin-docs {
  margin-top: 0.9rem;
}

.admin-subject-groups-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.admin-subject-groups-head h3 {
  margin: 0;
  font-size: 0.95rem;
}

#adminSubjectGroupsList {
  display: grid;
  gap: 0.7rem;
  margin-top: 0.7rem;
}

.admin-subject-group-card {
  display: grid;
  gap: 0.55rem;
  padding: 0.78rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(8, 15, 32, 0.3);
}

.admin-subject-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.admin-subject-group-actions {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.admin-subject-group-field {
  display: grid;
  gap: 0.32rem;
}

.admin-row {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.2);
  padding: 0.42rem;
  margin-bottom: 0.35rem;
  display: flex;
  justify-content: space-between;
  gap: 0.4rem;
}

.admin-row p {
  margin: 0;
  font-size: 0.75rem;
  color: var(--muted);
}

.admin-users {
  margin-top: 0.9rem;
}

.admin-subject-order h3,
.admin-docs h3,
.admin-users h3 {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
}

.admin-user-console {
  margin-top: 0.75rem;
  padding: 0.9rem;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(247, 250, 255, 0.94), rgba(234, 241, 255, 0.88));
  border: 1px solid rgba(198, 214, 255, 0.9);
  box-shadow: 0 22px 48px rgba(9, 19, 42, 0.18);
  color: #203152;
}

.admin-user-console .admin-note {
  color: #5f6f94;
}

.admin-user-console input,
.admin-user-console select {
  color: #203152;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(153, 180, 248, 0.55);
}

.admin-user-console input::placeholder {
  color: #8b9abb;
}

.admin-user-console-top {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 0.8rem;
}

.admin-user-bulk-toolbar {
  width: 100%;
  display: flex;
  gap: 0.55rem;
  align-items: center;
  flex-wrap: wrap;
}

.admin-user-status-tabs {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.admin-panel .admin-user-status-tab {
  border: 1px solid rgba(153, 180, 248, 0.42);
  background: rgba(255, 255, 255, 0.86);
  color: #315190;
  border-radius: 999px;
  padding: 0.58rem 0.9rem;
  display: inline-flex;
  gap: 0.5rem;
  align-items: center;
  font-weight: 600;
}

.admin-panel .admin-user-status-tab--active {
  color: #0d58ff;
  border-color: rgba(13, 88, 255, 0.26);
  box-shadow: inset 0 -2px 0 rgba(13, 88, 255, 0.8);
}

.admin-user-status-count {
  min-width: 1.6rem;
  height: 1.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(13, 88, 255, 0.12);
  color: #0d58ff;
  font-size: 0.74rem;
}

.admin-user-toolbar {
  display: flex;
  gap: 0.55rem;
  align-items: end;
  flex-wrap: wrap;
}

.admin-user-toolbar--search-only {
  width: 100%;
}

.admin-user-selection-summary {
  min-height: 2.75rem;
  display: inline-flex;
  align-items: center;
  padding: 0.62rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(153, 180, 248, 0.42);
  background: rgba(255, 255, 255, 0.86);
  color: #315190;
  font-size: 0.83rem;
  font-weight: 600;
  white-space: nowrap;
}

.admin-panel .admin-user-bulk-btn {
  min-height: 2.75rem;
  padding-inline: 1rem;
  font-weight: 700;
}

.admin-user-bulk-btn--danger {
  color: #c54b5b;
  border-color: rgba(197, 75, 91, 0.24);
}

.admin-user-bulk-btn--danger:hover {
  border-color: rgba(197, 75, 91, 0.42);
  background: rgba(197, 75, 91, 0.08);
}

.admin-user-inline-status {
  margin-top: 0.75rem;
}

.admin-user-search,
.admin-user-toolbar-select {
  display: grid;
  gap: 0.28rem;
}

.admin-user-search {
  min-width: min(320px, 100%);
}

.admin-user-search--wide {
  width: min(520px, 100%);
}

.admin-user-search input {
  min-width: 260px;
}

.admin-user-toolbar-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6f7fa6;
}

.admin-user-table {
  border-radius: 18px;
  border: 1px solid rgba(153, 180, 248, 0.35);
  background: rgba(255, 255, 255, 0.72);
  overflow: auto;
}

.admin-user-table-head,
.admin-user-table-row {
  min-width: 1880px;
  display: grid;
  grid-template-columns:
    minmax(140px, 1.05fr)
    minmax(140px, 1.05fr)
    minmax(140px, 1.05fr)
    minmax(240px, 1.7fr)
    minmax(170px, 1.1fr)
    minmax(220px, 1.45fr)
    minmax(150px, 1fr)
    minmax(180px, 1.2fr)
    minmax(130px, 0.95fr)
    minmax(150px, 0.95fr)
    minmax(160px, 1fr)
    minmax(150px, 0.95fr);
  align-items: center;
}

.admin-user-table-head {
  position: sticky;
  top: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(196, 218, 255, 0.95), rgba(206, 223, 255, 0.9));
  color: #26385f;
  font-weight: 700;
  border-bottom: 1px solid rgba(132, 168, 245, 0.45);
}

.admin-user-head-cell,
.admin-user-table-cell {
  padding: 0.95rem 1rem;
}

.admin-user-head-cell {
  font-size: 0.8rem;
  display: grid;
  gap: 0.45rem;
  align-content: start;
}

.admin-user-head-cell--check,
.admin-user-table-cell--actions {
  min-width: 0;
  display: flex;
  justify-content: center;
}

.admin-user-head-cell--check {
  align-items: center;
  justify-content: center;
}

.admin-user-head-cell--filter,
.admin-user-head-cell--actions {
  display: grid;
  gap: 0.45rem;
  align-content: start;
}

.admin-user-head-label {
  font-size: 0.72rem;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #60739d;
}

.admin-user-table-body {
  color: #2f3f66;
}

.admin-user-filter-input,
.admin-user-filter-select {
  width: 100%;
  min-width: 0;
  min-height: 2.15rem;
  font-size: 0.77rem;
  color: #203152;
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(153, 180, 248, 0.42);
}

.admin-user-filter-reset {
  width: 100%;
  min-height: 2.15rem;
  padding: 0.42rem 0.6rem;
  font-size: 0.76rem;
}

.admin-user-table-row {
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid rgba(214, 225, 245, 0.9);
  cursor: pointer;
}

.admin-user-table-row:last-child {
  border-bottom: 0;
}

.admin-user-table-row:hover {
  background: rgba(247, 250, 255, 0.98);
}

.admin-user-table-row--selected {
  background: rgba(240, 246, 255, 0.98);
  box-shadow: inset 0 0 0 1px rgba(45, 116, 255, 0.12);
}

.admin-user-table-row--editing {
  align-items: start;
}

.admin-user-table-row--active {
  background: rgba(237, 245, 255, 0.98);
  box-shadow: inset 3px 0 0 #2d74ff;
}

.admin-user-table-cell {
  min-width: 0;
}

.admin-user-primary {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.admin-user-primary strong {
  font-size: 0.95rem;
  color: #273a60;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-user-primary span {
  font-size: 0.78rem;
  color: #66789f;
  line-height: 1.45;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-user-access {
  display: grid;
  gap: 0.3rem;
}

.admin-user-access-meta {
  font-size: 0.76rem;
  color: #5f7199;
  line-height: 1.35;
}

.admin-user-action-btn {
  width: 100%;
  padding: 0.46rem 0.68rem;
  border-radius: 12px;
  border: 1px solid rgba(22, 34, 56, 0.18);
  background: rgba(22, 34, 56, 0.08);
  color: #162238;
  font-size: 0.76rem;
  font-weight: 700;
  text-align: left;
}

.admin-user-action-btn:hover {
  background: rgba(22, 34, 56, 0.14);
  border-color: rgba(22, 34, 56, 0.28);
}

.admin-user-action-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.admin-user-action-btn--primary {
  color: #162238;
}

.admin-user-action-btn--solid {
  border-color: #0f1726 !important;
  background: #0f1726 !important;
  color: #f5f8ff !important;
  text-align: center;
}

.admin-user-action-btn--solid:hover {
  border-color: #1c2940 !important;
  background: #1c2940 !important;
}

.admin-user-action-btn--solid-danger {
  border-color: #0f1726 !important;
  background: #0f1726 !important;
  color: #ffd6dc !important;
  text-align: center;
}

.admin-user-action-btn--solid-danger:hover {
  border-color: #24314a !important;
  background: #24314a !important;
}

.admin-user-action-btn--danger {
  color: #c54b5b;
}

.admin-user-menu {
  position: relative;
}

.admin-user-edit-actions {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: center;
}

.admin-user-menu-toggle {
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 999px;
  border: 1px solid #0f1726 !important;
  background: #0f1726 !important;
  color: #f5f8ff !important;
  font-size: 1.2rem;
  line-height: 1;
}

.admin-user-menu-toggle:hover {
  border-color: #1c2940 !important;
  background: #1c2940 !important;
}

.admin-user-action-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 0.45rem);
  min-width: 220px;
  display: grid;
  gap: 0.2rem;
  padding: 0.45rem;
  border-radius: 16px;
  background: #0f1726;
  border: 1px solid #24314a;
  box-shadow: 0 18px 40px rgba(4, 10, 24, 0.42);
  z-index: 5;
  animation: admin-user-menu-slide-in 160ms ease;
}

.admin-user-action-menu .admin-user-action-btn {
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.06);
  color: #f5f8ff !important;
}

.admin-user-action-menu .admin-user-action-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.16);
}

.admin-user-action-menu .admin-user-action-btn--danger {
  color: #ffd6dc !important;
}

@keyframes admin-user-menu-slide-in {
  from {
    opacity: 0;
    transform: translateY(-6px) scale(0.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.admin-user-inline-field,
.admin-user-inline-select {
  width: 100%;
  min-width: 0;
  font-size: 0.83rem;
}

.admin-user-inline-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.78rem;
  color: #48608f;
}

.admin-user-inline-checkbox input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin: 0;
}

.admin-user-inline-programmes {
  display: grid;
  gap: 0.32rem;
}

.admin-user-inline-programme-option {
  display: flex;
  align-items: center;
  gap: 0.42rem;
  font-size: 0.77rem;
  color: #38517f;
}

.admin-user-inline-programme-option input[type="checkbox"] {
  width: 0.95rem;
  height: 0.95rem;
  margin: 0;
}

.admin-user-inline-class-note {
  font-size: 0.77rem;
  color: #6b7ea7;
  line-height: 1.4;
}

.admin-user-console input[type="checkbox"] {
  width: 1.08rem;
  height: 1.08rem;
  accent-color: #2d74ff;
}

.subject-order-row {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.2);
  padding: 0.48rem 0.58rem;
  margin-bottom: 0.38rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
}

.subject-order-label {
  min-width: 0;
  font-size: 0.83rem;
  color: var(--text);
  word-break: break-word;
}

.subject-order-actions {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.admin-user-editor {
  margin-top: 0.8rem;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  padding-top: 0.8rem;
}

.admin-user-editor h3 {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
}

.admin-user-editor form {
  display: grid;
  gap: 0.55rem;
}

.admin-user-editor input[readonly] {
  opacity: 0.78;
  cursor: not-allowed;
}

.admin-checkbox-field {
  align-content: start;
}

.admin-checkbox-row {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.3rem;
  color: var(--text);
}

.admin-checkbox-row input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin: 0;
}

.admin-user-row {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.2);
  padding: 0.5rem;
  margin-bottom: 0.42rem;
  display: flex;
  justify-content: space-between;
  gap: 0.55rem;
  align-items: flex-start;
}

.admin-user-meta {
  min-width: 0;
}

.admin-user-meta p {
  margin: 0.14rem 0 0;
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1.42;
  word-break: break-word;
}

.admin-user-actions {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.user-status {
  display: inline-flex;
  margin-top: 0.36rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  padding: 0.12rem 0.46rem;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.user-status--pending {
  color: #ffe89a;
  border-color: rgba(255, 232, 154, 0.62);
  background: rgba(255, 202, 87, 0.16);
}

.user-status--approved {
  color: #b8ffd9;
  border-color: rgba(184, 255, 217, 0.55);
  background: rgba(79, 220, 163, 0.18);
}

.user-status--rejected {
  color: #ffbcc2;
  border-color: rgba(255, 188, 194, 0.55);
  background: rgba(255, 107, 107, 0.18);
}

.auth-overlay {
  position: fixed;
  inset: 0;
  z-index: 4;
  display: grid;
  place-items: center;
  background: rgba(6, 11, 24, 0.72);
  backdrop-filter: blur(14px);
}

.auth-card {
  width: min(460px, calc(100% - 1.4rem));
  max-height: calc(100dvh - 2rem);
  overflow: auto;
  border-radius: 18px;
  padding: 1rem;
  display: grid;
  gap: 0.65rem;
}

.auth-card h2 {
  margin: 0;
}

.auth-card p,
.auth-status {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.auth-tabs {
  display: flex;
  gap: 0.5rem;
}

.auth-tab {
  border-radius: 10px;
}

.auth-tab.auth-tab--active {
  border-color: rgba(97, 211, 255, 0.78);
}

.auth-form {
  display: grid;
  gap: 0.6rem;
}

.auth-form label {
  display: grid;
  gap: 0.26rem;
  font-size: 0.82rem;
  color: var(--muted);
}

.password-field {
  position: relative;
  display: flex;
  align-items: center;
}

.password-field input {
  width: 100%;
  padding-right: 4.8rem;
}

.password-toggle {
  position: absolute;
  right: 0.42rem;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: rgba(97, 211, 255, 0.96);
  font-size: 0.78rem;
  font-weight: 700;
  padding: 0.24rem 0.32rem;
  border-radius: 7px;
  cursor: pointer;
}

.password-toggle:hover {
  background: rgba(97, 211, 255, 0.1);
}

.password-criteria {
  margin-top: -0.12rem;
  padding: 0.65rem 0.75rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(7, 14, 28, 0.34);
}

.password-criteria-title {
  font-size: 0.77rem;
  font-weight: 700;
  color: rgba(238, 242, 255, 0.9);
  margin-bottom: 0.42rem;
}

.password-criteria-list {
  margin: 0;
  padding-left: 1rem;
  display: grid;
  gap: 0.26rem;
}

.password-criteria-item {
  font-size: 0.76rem;
  line-height: 1.35;
}

.password-criteria-item--valid {
  color: #8cf1bd;
}

.password-criteria-item--invalid {
  color: #ff9da6;
}

.programme-choice-block {
  display: grid;
  gap: 0.45rem;
  padding: 0.7rem 0.78rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(7, 14, 28, 0.34);
}

.programme-choice-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: rgba(238, 242, 255, 0.92);
}

.programme-choice-grid {
  display: grid;
  gap: 0.45rem;
}

.programme-choice-option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--text);
  font-size: 0.8rem;
}

.programme-choice-option input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin: 0;
}

.admin-panel {
  position: relative;
  overflow: hidden;
  padding: 1.45rem;
  border-radius: 32px;
  background:
    radial-gradient(circle at top right, rgba(107, 61, 242, 0.12), transparent 32%),
    radial-gradient(circle at left top, rgba(26, 86, 219, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(247, 250, 255, 0.96), rgba(235, 241, 252, 0.94));
  border: 1px solid rgba(220, 230, 250, 0.88);
  box-shadow: var(--admin-shadow);
  color: var(--admin-ink);
}

.admin-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.18), transparent 48%),
    radial-gradient(circle at 12% 14%, rgba(26, 86, 219, 0.1), transparent 22%);
}

.admin-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1.15rem;
}

.admin-panel-head--hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.admin-panel-copy {
  display: grid;
  gap: 0.35rem;
  max-width: 760px;
}

.admin-kicker,
.admin-section-kicker,
.admin-live-label {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.admin-kicker,
.admin-section-kicker {
  color: var(--admin-tertiary);
}

.admin-panel-head--hero h2,
.admin-surface h3,
.admin-side-card h3,
.admin-preview-card h3 {
  margin: 0;
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: #132546;
}

.admin-panel-head--hero h2 {
  font-size: clamp(1.95rem, 2.1vw, 3rem);
}

.admin-panel .admin-note,
.admin-panel .field-hint {
  color: var(--admin-subtle);
}

.admin-panel-actions {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.admin-live-indicator {
  display: grid;
  gap: 0.18rem;
  min-width: 190px;
  padding: 0.8rem 0.95rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(157, 179, 232, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.admin-live-indicator strong {
  font-size: 0.9rem;
  color: #22365d;
}

.admin-live-indicator--soft {
  min-width: 240px;
}

.admin-panel .ghost-btn,
.admin-panel .small-btn {
  border-color: rgba(157, 179, 232, 0.42);
  background: rgba(255, 255, 255, 0.84);
  color: #233863;
  box-shadow: 0 10px 22px rgba(17, 31, 66, 0.08);
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.admin-panel .ghost-btn:hover,
.admin-panel .small-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(26, 86, 219, 0.42);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 16px 28px rgba(17, 31, 66, 0.1);
}

.admin-panel #newBookBtn,
.admin-panel #saveDocBtn,
.admin-panel #saveSubjectGroupsBtn,
.admin-panel #adminUserSaveBtn,
.admin-panel #adminUserApproveSelectedBtn {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--admin-primary), var(--admin-primary-dark));
  box-shadow: 0 18px 30px rgba(26, 86, 219, 0.24);
}

.admin-panel #newBookBtn:hover,
.admin-panel #saveDocBtn:hover,
.admin-panel #saveSubjectGroupsBtn:hover,
.admin-panel #adminUserSaveBtn:hover,
.admin-panel #adminUserApproveSelectedBtn:hover {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, #1f63f3, #143ca8);
}

.admin-panel .danger-btn,
.admin-panel .admin-user-bulk-btn--danger,
.admin-panel .admin-user-action-btn--danger {
  color: var(--admin-danger);
  border-color: rgba(200, 79, 100, 0.22);
  background: rgba(255, 241, 244, 0.94);
}

.admin-panel .danger-btn:hover,
.admin-panel .admin-user-bulk-btn--danger:hover,
.admin-panel .admin-user-action-btn--danger:hover {
  border-color: rgba(200, 79, 100, 0.38);
  background: rgba(255, 233, 239, 0.98);
}

.admin-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

.admin-metric-card,
.admin-user-insight-card {
  display: grid;
  gap: 0.4rem;
  min-height: 150px;
  padding: 1.15rem;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(157, 179, 232, 0.3);
  box-shadow: 0 18px 34px rgba(17, 31, 66, 0.08);
}

.admin-metric-card--primary,
.admin-user-insight-card--wide {
  background:
    radial-gradient(circle at top right, rgba(107, 61, 242, 0.16), transparent 38%),
    linear-gradient(135deg, rgba(26, 86, 219, 0.08), rgba(255, 255, 255, 0.98));
}

.admin-metric-card--accent,
.admin-user-insight-card--accent {
  background:
    radial-gradient(circle at top right, rgba(11, 119, 106, 0.16), transparent 42%),
    linear-gradient(135deg, rgba(11, 119, 106, 0.08), rgba(255, 255, 255, 0.98));
}

.admin-metric-label {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #5e739c;
}

.admin-metric-value {
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: clamp(2rem, 2.3vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 1;
  color: #102446;
}

.admin-metric-copy {
  margin: 0;
  color: #687b9d;
  font-size: 0.86rem;
  line-height: 1.5;
}

.admin-scroll-block {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.35rem;
  scrollbar-gutter: stable both-edges;
  -webkit-overflow-scrolling: touch;
}

.admin-scroll-block::-webkit-scrollbar {
  height: 0.8rem;
}

.admin-scroll-block::-webkit-scrollbar-track {
  background: rgba(204, 216, 244, 0.45);
  border-radius: 999px;
}

.admin-scroll-block::-webkit-scrollbar-thumb {
  background: rgba(26, 86, 219, 0.34);
  border-radius: 999px;
}

.admin-scroll-block--metrics > .admin-metric-grid {
  min-width: 1120px;
  grid-template-columns: repeat(4, minmax(248px, 1fr));
}

.admin-scroll-block--editor > .admin-editor-layout {
  min-width: 1480px;
  grid-template-columns: minmax(980px, 1.45fr) minmax(360px, 0.72fr);
}

.admin-scroll-block--editor .admin-form-grid {
  grid-template-columns: repeat(2, minmax(280px, 1fr));
}

.admin-scroll-block--editor .admin-library-grid {
  grid-template-columns: minmax(760px, 1.18fr) minmax(320px, 0.78fr);
}

.admin-scroll-block--insights > .admin-user-insight-grid {
  min-width: 1480px;
  grid-template-columns: repeat(6, minmax(220px, 1fr));
}

.admin-scroll-block--console > .admin-user-console {
  min-width: 2140px;
}

.admin-scroll-block--console .admin-user-console-top,
.admin-scroll-block--console .admin-user-bulk-toolbar,
.admin-scroll-block--console .admin-user-toolbar {
  flex-direction: row;
  align-items: center;
}

.admin-scroll-block--console .admin-user-status-tabs {
  display: flex;
}

.admin-scroll-block--console .admin-user-toolbar-select--compact {
  display: none;
}

.admin-editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.72fr);
  gap: 1rem;
  align-items: start;
}

.admin-editor-main,
.admin-editor-sidebar {
  display: grid;
  gap: 1rem;
}

.admin-surface,
.admin-side-card,
.admin-preview-card {
  border-radius: 30px;
  padding: 1.2rem;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(157, 179, 232, 0.28);
  box-shadow: 0 18px 34px rgba(17, 31, 66, 0.08);
}

.admin-surface-head,
.admin-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.8rem;
}

.admin-mode-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: rgba(107, 61, 242, 0.1);
  border: 1px solid rgba(107, 61, 242, 0.18);
  color: var(--admin-tertiary);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#adminForm {
  display: grid;
  gap: 1rem;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem;
}

.admin-form-grid > label,
.admin-form-grid > .programme-choice-block {
  display: grid;
  gap: 0.42rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(244, 247, 255, 0.82);
  border: 1px solid rgba(157, 179, 232, 0.2);
}

.admin-panel label,
.admin-panel .programme-choice-title {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5e739c;
}

.admin-panel input,
.admin-panel select,
.admin-panel textarea {
  width: 100%;
  color: #203254;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(157, 179, 232, 0.38);
  border-radius: 16px;
  padding: 0.85rem 0.9rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.admin-panel input:focus,
.admin-panel select:focus,
.admin-panel textarea:focus {
  outline: 0;
  border-color: rgba(26, 86, 219, 0.46);
  box-shadow: 0 0 0 4px rgba(26, 86, 219, 0.08);
}

.admin-panel input::placeholder,
.admin-panel textarea::placeholder {
  color: #8b9abb;
}

.admin-panel textarea {
  min-height: 120px;
}

.admin-panel .programme-choice-block {
  align-content: start;
  background: linear-gradient(180deg, rgba(248, 250, 255, 0.98), rgba(239, 244, 255, 0.92));
  border-color: rgba(157, 179, 232, 0.26);
}

.admin-panel .programme-choice-option {
  color: #2b3f69;
  font-size: 0.88rem;
  text-transform: none;
  letter-spacing: 0;
}

.book-batch-editor {
  gap: 0.8rem;
  padding: 1.05rem;
  border-radius: 26px;
  background: rgba(245, 248, 255, 0.9);
  border: 1px solid rgba(157, 179, 232, 0.22);
}

.book-batch-head {
  align-items: center;
}

.book-batch-head h3 {
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: 1.2rem;
  letter-spacing: -0.03em;
  color: #132546;
}

.book-draft-list {
  gap: 0.8rem;
}

.book-draft-row {
  gap: 0.65rem;
  padding: 1rem;
  border-radius: 24px;
  border: 1px solid rgba(157, 179, 232, 0.24);
  background: rgba(255, 255, 255, 0.88);
}

.book-draft-row-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: #22365d;
}

.admin-actions {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.admin-status {
  margin: 0;
  padding: 0.9rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(157, 179, 232, 0.26);
  background: rgba(255, 255, 255, 0.8);
  color: #25406f;
  font-size: 0.88rem;
  line-height: 1.5;
}

.admin-status[data-tone="error"] {
  border-color: rgba(200, 79, 100, 0.22);
  background: rgba(255, 241, 244, 0.96);
  color: #a4334a;
}

.admin-library-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.78fr);
  gap: 1rem;
}

#adminDocsSection {
  grid-column: 1 / -1;
}

.admin-subject-groups-head {
  margin-bottom: 0.2rem;
}

#adminSubjectGroupsList,
#adminDocsList,
#adminSubjectOrderList {
  display: grid;
  gap: 0.75rem;
}

.admin-subject-group-card,
.admin-row,
.subject-order-row {
  padding: 1rem;
  border-radius: 22px;
  border: 1px solid rgba(157, 179, 232, 0.22);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 24px rgba(17, 31, 66, 0.05);
}

.admin-subject-group-head,
.admin-row,
.subject-order-row {
  align-items: center;
}

.admin-subject-group-head strong,
.admin-row strong,
.subject-order-label {
  font-family: "Space Grotesk", "Sora", sans-serif;
  color: #1c3157;
}

.admin-row p {
  color: #6b7e9f;
}

.admin-preview-card {
  overflow: hidden;
  padding: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 250, 255, 0.96));
}

.admin-preview-cover {
  position: relative;
  display: grid;
  gap: 0.45rem;
  min-height: 260px;
  padding: 1.3rem;
  background:
    radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.22), transparent 22%),
    radial-gradient(circle at 82% 12%, rgba(255, 255, 255, 0.18), transparent 24%),
    linear-gradient(145deg, #143ca8, #2d64e7 46%, #6b3df2 92%);
  color: #fff;
}

.admin-preview-cover::after {
  content: "";
  position: absolute;
  right: 1.35rem;
  bottom: -2rem;
  width: 150px;
  height: 190px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.08)),
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(17, 31, 66, 0.28));
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 24px 44px rgba(13, 26, 61, 0.26);
  transform: rotate(9deg);
}

.admin-preview-chip {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.45rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  background: rgba(255, 255, 255, 0.12);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.admin-preview-kicker,
.admin-preview-copy,
.admin-preview-card h3 {
  position: relative;
  z-index: 1;
}

.admin-preview-kicker {
  margin: auto 0 0;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.74);
}

.admin-preview-card h3 {
  max-width: 70%;
  font-size: 2rem;
  line-height: 1.02;
  color: #fff;
}

.admin-preview-copy {
  max-width: 72%;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  line-height: 1.6;
}

.admin-preview-body {
  display: grid;
  gap: 0.75rem;
  padding: 1.15rem;
}

.admin-preview-row,
.admin-side-list-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(157, 179, 232, 0.16);
  color: #5e739c;
}

.admin-preview-row:last-of-type,
.admin-side-list-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.admin-preview-row strong,
.admin-side-list-row strong {
  color: #1b2944;
}

.admin-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.admin-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.48rem 0.7rem;
  border-radius: 999px;
  background: rgba(26, 86, 219, 0.08);
  border: 1px solid rgba(26, 86, 219, 0.12);
  color: #1a56db;
  font-size: 0.76rem;
  font-weight: 700;
}

.admin-side-card {
  gap: 0.75rem;
}

.admin-side-card--accent {
  background: linear-gradient(180deg, rgba(245, 255, 252, 0.94), rgba(255, 255, 255, 0.95));
}

.admin-side-card-head {
  display: grid;
  gap: 0.28rem;
  margin-bottom: 0.75rem;
}

.admin-side-list {
  display: grid;
  gap: 0.7rem;
}

.admin-users {
  margin-top: 0;
}

.admin-section-head--users {
  margin-bottom: 1rem;
}

.admin-user-insight-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.admin-user-insight-card--wide {
  grid-column: span 2;
}

.admin-user-console {
  margin-top: 0;
  padding: 1.1rem;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(247, 250, 255, 0.96), rgba(237, 243, 255, 0.9));
  border: 1px solid rgba(198, 214, 255, 0.88);
  box-shadow: 0 22px 48px rgba(9, 19, 42, 0.14);
  color: #203152;
}

.admin-user-console-copy {
  display: grid;
  gap: 0.75rem;
  flex: 1 1 360px;
}

.admin-user-console-top {
  gap: 1rem;
  margin-bottom: 0.95rem;
}

.admin-user-status-tabs {
  gap: 0.45rem;
}

.admin-user-status-tab {
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(153, 180, 248, 0.34);
  color: #355699;
}

.admin-user-status-tab--active {
  color: #0d58ff;
  border-color: rgba(13, 88, 255, 0.22);
  box-shadow: inset 0 -2px 0 rgba(13, 88, 255, 0.8);
}

.admin-user-toolbar {
  flex: 1 1 640px;
  justify-content: flex-end;
}

.admin-user-toolbar-select {
  min-width: 150px;
}

.admin-user-toolbar-select--compact {
  display: none;
}

.admin-user-search,
.admin-user-toolbar-select {
  gap: 0.3rem;
}

.admin-user-selection-summary {
  min-height: 2.8rem;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(153, 180, 248, 0.34);
}

.admin-user-bulk-toolbar {
  margin-bottom: 0.95rem;
}

.admin-user-bulk-btn {
  min-height: 2.8rem;
  font-weight: 700;
}

.admin-user-table {
  border-radius: 22px;
  border: 1px solid rgba(153, 180, 248, 0.34);
  background: rgba(255, 255, 255, 0.76);
}

.admin-user-table-head,
.admin-user-table-row {
  min-width: 1980px;
  grid-template-columns:
    minmax(72px, 0.45fr)
    minmax(148px, 1.05fr)
    minmax(140px, 1fr)
    minmax(140px, 1fr)
    minmax(240px, 1.7fr)
    minmax(170px, 1.1fr)
    minmax(220px, 1.45fr)
    minmax(150px, 1fr)
    minmax(190px, 1.2fr)
    minmax(130px, 0.92fr)
    minmax(150px, 0.95fr)
    minmax(160px, 1fr)
    minmax(152px, 0.92fr);
}

.admin-user-table-head {
  background: linear-gradient(180deg, rgba(199, 218, 255, 0.96), rgba(213, 228, 255, 0.92));
}

.admin-user-head-cell,
.admin-user-table-cell {
  padding: 0.9rem 0.92rem;
}

.admin-user-head-cell {
  gap: 0.5rem;
}

.admin-user-head-cell--check,
.admin-user-table-cell--check,
.admin-user-table-cell--actions {
  justify-content: center;
  align-items: center;
}

.admin-user-table-cell--check {
  display: flex;
}

.admin-panel .admin-user-head-check {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  font-size: 0.73rem;
  color: #5670a2;
  text-transform: none;
  letter-spacing: 0;
}

.admin-panel .admin-user-head-check input[type="checkbox"],
.admin-panel .admin-user-table-cell--check input[type="checkbox"] {
  width: 1.05rem;
  height: 1.05rem;
  margin: 0;
  accent-color: #2d74ff;
}

.admin-user-filter-input,
.admin-user-filter-select,
.admin-panel .admin-user-filter-reset {
  min-height: 2.3rem;
  border-radius: 14px;
}

.admin-user-filter-reset {
  padding: 0.45rem 0.7rem;
  border: 1px solid rgba(153, 180, 248, 0.3);
  background: rgba(255, 255, 255, 0.94);
  color: #315190;
  font-weight: 700;
}

.admin-user-table-row {
  background: rgba(255, 255, 255, 0.96);
}

.admin-user-table-row:hover {
  background: rgba(249, 251, 255, 0.98);
}

.admin-user-table-row--selected {
  background: rgba(240, 246, 255, 0.98);
}

.admin-user-primary strong {
  color: #22365d;
}

.admin-user-primary span,
.admin-user-access-meta {
  color: #62749a;
}

.admin-panel .admin-user-action-btn {
  background: rgba(22, 34, 56, 0.06);
  border-color: rgba(22, 34, 56, 0.16);
  box-shadow: none;
}

.admin-panel .admin-user-action-btn--solid,
.admin-panel .admin-user-menu-toggle {
  border-color: #0f1726 !important;
  background: #0f1726 !important;
  color: #f5f8ff !important;
  box-shadow: none;
}

.admin-panel .admin-user-action-btn--solid-danger {
  border-color: #0f1726 !important;
  background: #0f1726 !important;
  color: #ffd6dc !important;
}

.admin-panel .admin-user-action-menu .admin-user-action-btn {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: #f5f8ff !important;
}

.admin-user-inline-status {
  margin-top: 0.95rem;
}

.admin-panel .admin-metric-card,
.admin-panel .admin-user-insight-card,
.admin-panel .admin-editor-main,
.admin-panel .admin-editor-sidebar,
.admin-panel .admin-surface,
.admin-panel .admin-side-card,
.admin-panel .admin-preview-card,
.admin-panel .admin-user-console,
.admin-panel .admin-user-console-copy,
.admin-panel .admin-user-table,
.admin-panel .admin-user-head-cell,
.admin-panel .admin-user-table-cell,
.admin-panel .book-draft-row,
.admin-panel .admin-row,
.admin-panel .admin-subject-group-card,
.admin-panel .subject-order-row {
  min-width: 0;
}

.admin-panel .admin-note,
.admin-panel .admin-metric-copy,
.admin-panel .admin-preview-copy,
.admin-panel .admin-preview-row strong,
.admin-panel .admin-side-list-row strong,
.admin-panel .admin-user-primary strong,
.admin-panel .admin-user-primary span,
.admin-panel .admin-user-access-meta,
.admin-panel .field-hint,
.admin-panel button,
.admin-panel label,
.admin-panel span,
.admin-panel p {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.admin-scroll-block {
  overflow: visible;
  padding-bottom: 0;
  scrollbar-gutter: auto;
}

.admin-scroll-block--metrics > .admin-metric-grid {
  min-width: 0;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.admin-scroll-block--editor > .admin-editor-layout {
  min-width: 0;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr));
}

.admin-scroll-block--editor .admin-form-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.admin-scroll-block--editor .admin-library-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
}

.admin-scroll-block--insights > .admin-user-insight-grid {
  min-width: 0;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.admin-scroll-block--console > .admin-user-console {
  min-width: 0;
}

.admin-scroll-block--console .admin-user-console-top,
.admin-scroll-block--console .admin-user-bulk-toolbar,
.admin-scroll-block--console .admin-user-toolbar {
  align-items: stretch;
  flex-wrap: wrap;
}

.admin-scroll-block--console .admin-user-status-tabs {
  display: flex;
  flex-wrap: wrap;
}

.admin-scroll-block--console .admin-user-toolbar-select--compact {
  display: none;
}

.admin-user-search,
.admin-user-search--wide,
.admin-user-toolbar-select {
  width: 100%;
  min-width: min(240px, 100%);
  flex: 1 1 240px;
}

.admin-user-search input {
  min-width: 0;
}

.admin-user-selection-summary {
  white-space: normal;
}

.admin-user-table {
  overflow: visible;
}

.admin-user-table-head,
.admin-user-table-row {
  min-width: 0;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
  align-items: start;
}

.admin-user-head-cell--check,
.admin-user-table-cell--check,
.admin-user-head-cell--actions,
.admin-user-table-cell--actions {
  justify-content: flex-start;
}

.admin-preview-row,
.admin-side-list-row {
  align-items: flex-start;
  flex-wrap: wrap;
}

.user-status {
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 800;
}

.user-status--pending {
  color: #b56c09;
  border-color: rgba(229, 170, 42, 0.34);
  background: rgba(255, 237, 204, 0.96);
}

.user-status--approved {
  color: #0b776a;
  border-color: rgba(11, 119, 106, 0.22);
  background: rgba(222, 249, 244, 0.96);
}

.user-status--rejected {
  color: #b0374c;
  border-color: rgba(200, 79, 100, 0.22);
  background: rgba(255, 238, 242, 0.96);
}

@media (max-height: 920px) {
  .reader-sidebar {
    padding-top: 5rem;
  }

  .reader-sidebar-inner {
    gap: 0.65rem;
    padding-top: 0.45rem;
    padding-bottom: 0.45rem;
  }

  .reader-user-card {
    gap: 0.5rem;
    padding: 0.72rem;
  }

  .reader-user-card-mark {
    width: 2.35rem;
    height: 2.35rem;
  }

  .reader-user-card-copy strong {
    font-size: 0.9rem;
  }

  .reader-user-card-copy p {
    font-size: 0.72rem;
  }

  .reader-user-chip {
    padding: 0.4rem 0.52rem;
  }

  .reader-sidebar-link {
    padding: 0.56rem 0.72rem;
    font-size: 0.79rem;
  }

  .reader-tree-helper {
    font-size: 0.64rem;
  }

  .app-shell--reader .reader-sidebar-head--categories {
    padding-top: 0.38rem;
  }

  .app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--category {
    padding: 0.56rem 0.72rem;
  }

  .app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--subject {
    padding: 0.5rem 0.66rem;
  }

  .app-shell--reader .doc-tree--reader .reader-sidebar-tree-link--book {
    padding: 0.44rem 0.6rem 0.44rem 0.84rem;
  }

  .reader-primary-cta {
    min-height: 2.2rem;
    font-size: 0.68rem;
  }

  .reader-sidebar-link--footer {
    padding: 0.5rem 0.68rem;
  }
}

@media (max-width: 1300px) {
  .reader-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .reader-context {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .workspace {
    grid-template-columns: 280px minmax(0, 1fr);
  }
}

@media (max-width: 980px) {
  .reader-topbar-main {
    padding-inline: 1rem;
  }

  .reader-top-links {
    display: none;
  }

  .reader-sidebar {
    position: static;
    width: auto;
    padding: 5rem 1rem 0;
  }

  .reader-sidebar-inner {
    height: auto;
    overflow: visible;
    border-right: 0;
    border-radius: 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.62);
    box-shadow: 0 18px 34px rgba(22, 42, 88, 0.08);
  }

  .reader-main {
    margin-left: 0;
    padding: 1rem;
  }

  .reader-main > .admin-panel {
    width: 100%;
    margin: 1rem auto 0;
  }

  .app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar {
    width: auto;
    padding-bottom: 0;
  }

  .app-shell--reader.reader-shell--sidebar-collapsed .reader-sidebar-inner {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-width: 0;
    box-shadow: none;
    overflow: hidden;
  }

  .app-shell--reader.reader-shell--sidebar-collapsed .reader-main {
    margin-left: 0;
    padding-top: 0.35rem;
  }

  .reader-context {
    grid-template-columns: 1fr;
  }

  .reader-stage-card {
    min-height: 640px;
  }

  .pdf-stage--reader {
    min-height: 540px;
  }

  .flipbook-frame {
    min-height: 500px;
  }

  .hero {
    padding: 0.75rem;
  }

  .hero-summary-line {
    gap: 0.24rem;
    overflow-x: auto;
    scrollbar-width: thin;
    padding-bottom: 0.1rem;
  }

  .hero-inline-item {
    min-width: 104px;
    padding: 0.4rem 0.46rem;
  }

  .hero-inline-actions {
    min-width: 176px;
  }

  .admin-panel-head {
    align-items: stretch;
  }

  .book-batch-head {
    flex-direction: column;
    align-items: stretch;
  }

  .workspace {
    grid-template-columns: 1fr;
  }

  .admin-panel--bottom #adminForm,
  .admin-panel--bottom .admin-user-editor form {
    grid-template-columns: 1fr;
  }

  .admin-user-console-top,
  .admin-user-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-user-search {
    min-width: 100%;
  }

  .admin-user-search input {
    min-width: 100%;
  }

  .doc-tree,
  .side-panel,
  .viewer-panel {
    min-height: 0;
    max-height: none;
  }

  .viewer-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .reader-topbar-main {
    gap: 0.6rem;
  }

  .reader-brand {
    font-size: 1rem;
  }

  .reader-sidebar {
    padding-inline: 0.75rem;
  }

  .reader-main {
    padding-inline: 0.75rem;
  }

  .reader-tree-helper {
    font-size: 0.68rem;
  }

  .reader-hero {
    margin-bottom: 1rem;
  }

  .reader-hero-actions {
    width: 100%;
  }

  .reader-secondary-cta {
    width: 100%;
    justify-content: center;
  }

  .reader-stage-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .reader-stage-toolbar-group {
    justify-content: space-between;
  }

  .reader-context-card {
    padding: 1rem;
  }

  .flipbook-frame {
    min-height: 420px;
  }

  .app-shell {
    width: min(100% - 1rem, 1700px);
    margin: 0.5rem auto 1rem;
  }

  .hero {
    padding: 0.45rem;
  }

  .hero-summary-line {
    gap: 0.12rem;
    overflow: hidden;
  }

  .hero-inline-item {
    min-width: 0;
    padding: 0.28rem 0.3rem;
  }

  .meta-label {
    display: none;
  }

  .hero-inline-actions {
    min-width: 0;
    gap: 0.12rem;
    flex: 0 0 auto;
  }

  .hero-inline-item strong {
    font-size: 0.57rem;
  }

  .hero-inline-actions .ghost-btn {
    min-width: 0;
    flex: 0 0 auto;
    padding: 0.3rem 0.26rem;
    font-size: 0;
  }

  .hero-inline-actions .ghost-btn::after {
    content: attr(data-short-label);
    font-size: 0.56rem;
    line-height: 1;
  }
}

@media (max-width: 480px) {
  .hero {
    overflow: hidden;
  }

  .hero-summary-line {
    width: 122%;
    transform: scale(0.82);
    transform-origin: left top;
    margin-bottom: -0.4rem;
  }
}

@media (max-width: 1280px) {
  .admin-metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-editor-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-user-insight-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .admin-panel {
    padding: 1rem;
    border-radius: 28px;
  }

  .admin-panel-head--hero,
  .admin-section-head,
  .admin-surface-head {
    align-items: stretch;
  }

  .admin-panel-actions,
  .admin-user-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-form-grid,
  .admin-library-grid,
  .admin-user-insight-grid {
    grid-template-columns: 1fr;
  }

  .admin-user-insight-card--wide {
    grid-column: auto;
  }

  .admin-user-console-top,
  .admin-user-bulk-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-user-toolbar-select--compact {
    display: grid;
  }

  .admin-user-status-tabs {
    display: none;
  }
}

@media (max-width: 720px) {
  .admin-metric-grid {
    grid-template-columns: 1fr;
  }

  .admin-preview-card h3,
  .admin-preview-copy {
    max-width: 100%;
  }

  .admin-preview-cover::after {
    right: 1rem;
    bottom: -2.5rem;
    width: 120px;
    height: 160px;
  }

  .admin-actions {
    flex-direction: column;
  }

  .admin-actions > * {
    width: 100%;
  }
}

/* Lexis-inspired admin redesign */
.reader-main > .admin-panel {
  width: min(100%, 1440px);
  margin: 1.35rem auto 0;
}

.admin-panel {
  padding: 0.15rem;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.admin-panel::before {
  display: none;
}

.admin-shell {
  gap: 1.5rem;
}

.admin-scroll-block {
  overflow: visible;
  padding: 0;
}

.admin-breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.42rem;
  margin-bottom: 1rem;
  color: #7f8aa1;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.admin-breadcrumb .material-symbols-outlined {
  font-size: 1rem;
  color: #a3afc9;
}

.admin-panel-head--hero {
  align-items: flex-end;
  gap: 1.2rem;
  margin-bottom: 0.15rem;
}

.admin-panel-copy {
  max-width: 860px;
  gap: 0.5rem;
}

.admin-kicker {
  color: #5f6fff;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
}

.admin-panel-head--hero h2 {
  font-size: clamp(2.9rem, 5vw, 4.8rem);
  line-height: 0.94;
  letter-spacing: -0.06em;
  color: #162543;
}

.admin-panel .admin-note,
.admin-panel .field-hint,
.admin-section-intro {
  color: #667a9d;
  font-size: 0.98rem;
  line-height: 1.65;
}

.admin-section-intro {
  margin: 0.55rem 0 0;
  max-width: 42rem;
}

.admin-panel-actions {
  justify-content: flex-end;
  gap: 0.85rem;
}

.admin-security-pill,
.admin-live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 3rem;
  padding: 0.78rem 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.42);
  box-shadow: 0 20px 44px rgba(17, 31, 66, 0.08);
}

.admin-security-pill {
  color: #006a61;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.admin-security-pill .material-symbols-outlined {
  font-size: 1rem;
  font-variation-settings: "FILL" 1, "wght" 560, "GRAD" 0, "opsz" 20;
}

.admin-live-indicator {
  display: grid;
  gap: 0.12rem;
  min-width: 230px;
  padding-block: 0.72rem;
}

.admin-live-indicator strong {
  font-size: 0.92rem;
}

.admin-panel #newBookBtn,
.admin-panel #saveDocBtn,
.admin-panel #saveSubjectGroupsBtn,
.admin-panel #adminUserSaveBtn,
.admin-panel #adminUserApproveSelectedBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  min-height: 3.3rem;
  padding: 0.9rem 1.35rem;
  border-radius: 999px;
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, #003fb1, #1a56db 58%, #4f7dff);
  box-shadow: 0 22px 42px rgba(19, 83, 216, 0.22);
}

.admin-panel #newBookBtn:hover,
.admin-panel #saveDocBtn:hover,
.admin-panel #saveSubjectGroupsBtn:hover,
.admin-panel #adminUserSaveBtn:hover,
.admin-panel #adminUserApproveSelectedBtn:hover {
  background: linear-gradient(135deg, #0046c5, #2564f3 60%, #5c86ff);
}

.admin-panel .ghost-btn,
.admin-panel .small-btn,
.admin-user-bulk-btn,
.admin-user-filter-reset,
.admin-panel .admin-user-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 3rem;
  border-radius: 999px;
  border: 1px solid rgba(195, 197, 215, 0.48);
  background: rgba(255, 255, 255, 0.62);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  color: #415577;
  box-shadow: 0 16px 30px rgba(17, 31, 66, 0.08);
}

.admin-panel .danger-btn,
.admin-panel .admin-user-bulk-btn--danger,
.admin-panel .admin-user-action-btn--danger {
  background: rgba(255, 241, 244, 0.88);
  color: #c84f64;
  border-color: rgba(200, 79, 100, 0.22);
}

.admin-metric-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.admin-metric-card,
.admin-user-insight-card {
  min-height: 168px;
  padding: 1.3rem;
  border-radius: 2rem;
  background: rgba(255, 255, 255, 0.52);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.42);
  box-shadow: 0 24px 44px rgba(16, 30, 63, 0.08);
}

.admin-metric-card--primary,
.admin-user-insight-card--wide {
  background:
    radial-gradient(circle at top right, rgba(79, 125, 255, 0.18), transparent 38%),
    rgba(255, 255, 255, 0.58);
}

.admin-metric-card--accent,
.admin-user-insight-card--accent {
  background:
    radial-gradient(circle at top right, rgba(118, 50, 231, 0.14), transparent 38%),
    rgba(255, 255, 255, 0.58);
}

.admin-metric-label {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  color: #8390aa;
}

.admin-metric-value {
  font-size: clamp(2.4rem, 3vw, 3.25rem);
  color: #172640;
}

.admin-editor-layout {
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.9fr);
  gap: 1rem;
}

.admin-surface,
.admin-side-card,
.admin-preview-card,
.admin-users {
  border-radius: 2rem;
  background: rgba(255, 255, 255, 0.52);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.42);
  box-shadow: 0 28px 56px rgba(16, 30, 63, 0.09);
}

.admin-surface--editor {
  padding: 1.8rem;
}

.admin-surface-head,
.admin-section-head,
.admin-side-card-head {
  margin-bottom: 1rem;
}

.admin-section-kicker {
  color: #7283a6;
}

.admin-surface h3,
.admin-side-card h3,
.admin-preview-card h3,
.admin-users h3 {
  font-size: clamp(1.55rem, 2.2vw, 2.2rem);
  line-height: 1.02;
}

#adminForm {
  gap: 1.15rem;
}

.admin-form-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.admin-form-grid > label,
.admin-form-grid > .programme-choice-block {
  padding: 1.1rem;
  border-radius: 1.7rem;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.admin-panel label,
.admin-panel .programme-choice-title {
  gap: 0.5rem;
  color: #7c8aa6;
  font-size: 0.71rem;
  letter-spacing: 0.16em;
}

.admin-panel input,
.admin-panel select,
.admin-panel textarea {
  min-height: 3.5rem;
  border: 0;
  border-radius: 1.25rem;
  background: rgba(247, 249, 251, 0.96);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.admin-panel textarea {
  min-height: 8.8rem;
  resize: vertical;
}

.book-batch-editor {
  padding: 1.25rem;
  border-radius: 1.8rem;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid rgba(255, 255, 255, 0.36);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.book-batch-head {
  align-items: flex-start;
  justify-content: space-between;
}

.book-batch-head h3,
#bookBatchTitle {
  font-size: 1.55rem;
  letter-spacing: -0.04em;
}

.book-draft-list {
  display: grid;
  gap: 0.9rem;
}

.book-draft-row {
  padding: 1.05rem;
  border-radius: 1.6rem;
  background: rgba(247, 249, 251, 0.92);
  border: 1px solid rgba(206, 214, 236, 0.55);
  box-shadow: 0 16px 30px rgba(17, 31, 66, 0.05);
}

.book-draft-row-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.28fr);
  gap: 0.75rem;
}

.admin-actions {
  justify-content: space-between;
  align-items: center;
  gap: 0.7rem;
}

.admin-status {
  border-radius: 1.3rem;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.34);
}

.admin-library-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

#adminDocsSection {
  grid-column: 1 / -1;
}

#adminSubjectGroupsList,
#adminDocsList,
#adminSubjectOrderList {
  gap: 0.9rem;
}

.admin-subject-group-card,
.admin-row,
.subject-order-row {
  padding: 1.05rem 1.1rem;
  border-radius: 1.5rem;
  background: rgba(247, 249, 251, 0.88);
  border: 1px solid rgba(206, 214, 236, 0.55);
}

.admin-preview-card {
  padding: 0;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.62);
}

.admin-preview-cover {
  min-height: 292px;
  padding: 1.45rem;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.22), transparent 20%),
    linear-gradient(145deg, #003fb1, #1a56db 50%, #7632e7);
}

.admin-preview-cover::before {
  content: "";
  position: absolute;
  inset: 1.25rem 1.2rem 1.4rem auto;
  width: 34%;
  min-width: 122px;
  border-radius: 1.6rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.26), rgba(255, 255, 255, 0.06)),
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(7, 18, 42, 0.38));
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 24px 44px rgba(7, 18, 42, 0.28);
  transform: rotate(8deg);
}

.admin-preview-cover::after {
  content: "";
  position: absolute;
  inset: auto 2.1rem 1.2rem auto;
  width: 30%;
  min-width: 108px;
  height: 74%;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(7, 18, 42, 0.2));
  transform: rotate(-3deg);
  opacity: 0.8;
}

.admin-preview-chip {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.22);
}

.admin-preview-kicker {
  margin-top: auto;
}

.admin-preview-card h3 {
  max-width: 14ch;
  font-size: clamp(2rem, 3vw, 2.5rem);
}

.admin-preview-copy {
  max-width: 30ch;
}

.admin-preview-body {
  gap: 0.85rem;
  padding: 1.25rem;
  background: rgba(255, 255, 255, 0.9);
}

.admin-preview-row,
.admin-side-list-row {
  align-items: flex-start;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.admin-side-card {
  padding: 1.35rem;
}

.admin-side-card--insight {
  background:
    linear-gradient(180deg, rgba(118, 50, 231, 0.08), rgba(255, 255, 255, 0.62));
}

.admin-side-card--audit {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(242, 244, 246, 0.82));
}

.admin-side-list {
  gap: 0.8rem;
}

.admin-users {
  padding: 1.45rem;
}

.admin-user-insight-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.admin-user-insight-card--wide {
  grid-column: span 2;
}

.admin-user-console {
  padding: 1.25rem;
  border-radius: 1.8rem;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(255, 255, 255, 0.38);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.58), 0 22px 42px rgba(16, 30, 63, 0.08);
}

.admin-user-console-top,
.admin-user-bulk-toolbar,
.admin-user-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

.admin-user-toolbar {
  flex: 1 1 520px;
  justify-content: flex-end;
}

.admin-user-search,
.admin-user-toolbar-select {
  display: grid;
  gap: 0.32rem;
  min-width: min(240px, 100%);
  flex: 1 1 240px;
}

.admin-user-search input {
  min-width: 0;
}

.admin-user-selection-summary {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  white-space: normal;
}

.admin-user-table {
  overflow: hidden;
  border-radius: 1.6rem;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(214, 223, 242, 0.78);
}

.admin-user-table-head,
.admin-user-table-row {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(152px, 1fr));
  align-items: start;
}

.admin-user-table-head {
  background: rgba(242, 246, 255, 0.96);
}

.admin-user-head-cell,
.admin-user-table-cell {
  min-width: 0;
  padding: 0.88rem 0.9rem;
}

.admin-user-head-cell--check,
.admin-user-table-cell--check,
.admin-user-head-cell--actions,
.admin-user-table-cell--actions {
  justify-content: flex-start;
}

.admin-panel .admin-user-status-tab {
  border-radius: 999px;
}

.admin-user-inline-status {
  margin-top: 1rem;
}

.admin-user-editor {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(195, 205, 228, 0.44);
}

.admin-user-editor form {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.85rem;
}

.admin-panel .admin-note,
.admin-panel .admin-metric-copy,
.admin-panel .admin-preview-copy,
.admin-panel .admin-preview-row strong,
.admin-panel .admin-side-list-row strong,
.admin-panel .admin-user-primary strong,
.admin-panel .admin-user-primary span,
.admin-panel .admin-user-access-meta,
.admin-panel .field-hint,
.admin-panel button,
.admin-panel label,
.admin-panel span,
.admin-panel p {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 1360px) {
  .admin-editor-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-preview-card h3,
  .admin-preview-copy {
    max-width: 100%;
  }
}

@media (max-width: 1080px) {
  .admin-metric-grid,
  .admin-library-grid,
  .admin-user-insight-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-user-insight-card--wide {
    grid-column: span 2;
  }

  .book-draft-row-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .admin-panel-head--hero h2 {
    font-size: clamp(2.2rem, 10vw, 3.1rem);
  }

  .admin-panel-actions,
  .admin-actions,
  .admin-user-bulk-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-metric-grid,
  .admin-library-grid,
  .admin-user-insight-grid,
  .admin-form-grid,
  .admin-user-editor form {
    grid-template-columns: 1fr;
  }

  .admin-user-insight-card--wide {
    grid-column: auto;
  }

  .admin-preview-cover {
    min-height: 250px;
  }

  .admin-preview-cover::before,
  .admin-preview-cover::after {
    right: 1.1rem;
  }

  .admin-panel #newBookBtn,
  .admin-panel #saveDocBtn,
  .admin-panel #saveSubjectGroupsBtn,
  .admin-panel #adminUserSaveBtn,
  .admin-panel #adminUserApproveSelectedBtn,
  .admin-panel .ghost-btn,
  .admin-panel .small-btn,
  .admin-user-bulk-btn,
  .admin-user-filter-reset {
    width: 100%;
  }
}

/* Wider editor surface with two-column cards inside each management section */
.reader-main > .admin-panel {
  width: 100%;
  max-width: none;
  margin: 1.35rem 0 0;
}

.admin-scroll-block--editor > .admin-editor-layout {
  min-width: 0;
}

.admin-scroll-block--editor .admin-library-grid,
.admin-library-grid {
  grid-template-columns: minmax(0, 1fr);
}

#adminSubjectGroupsList,
#adminSubjectOrderList,
#adminDocsList {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: start;
}

#adminSubjectGroupsList > *,
#adminSubjectOrderList > *,
#adminDocsList > * {
  min-width: 0;
  height: 100%;
}

.admin-subject-group-card,
.subject-order-row,
.admin-row {
  margin-bottom: 0;
  height: 100%;
}

.admin-collapsible-section {
  overflow: hidden;
}

.admin-section-head--toggle {
  align-items: center;
  gap: 1rem;
}

.admin-section-head--toggle > .admin-section-toggle {
  flex: 1 1 auto;
}

.admin-section-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.admin-section-toggle:hover {
  transform: none;
  background: transparent;
  box-shadow: none;
}

.admin-section-toggle:disabled {
  cursor: default;
  opacity: 0.72;
}

.admin-section-toggle-copy {
  display: grid;
  gap: 0.14rem;
  min-width: 0;
}

.admin-section-toggle-copy h3 {
  margin: 0;
}

.admin-section-toggle-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  flex-shrink: 0;
  color: #7283a6;
}

.admin-section-toggle-hint {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.admin-section-toggle-icon {
  transition: transform 180ms ease;
}

.admin-collapsible-section:not(.is-collapsed) .admin-section-toggle-icon {
  transform: rotate(180deg);
}

.admin-section-content {
  display: grid;
  gap: 0.85rem;
}

.admin-section-content > * {
  min-width: 0;
}

.admin-collapsible-section.is-collapsed .admin-section-content > .admin-note,
.admin-collapsible-section.is-collapsed .admin-section-content > .admin-actions {
  display: none;
}

.admin-collapsible-section.is-collapsed #adminSubjectGroupsList > :nth-child(n + 3),
.admin-collapsible-section.is-collapsed #adminSubjectOrderList > :nth-child(n + 3),
.admin-collapsible-section.is-collapsed #adminDocsList > :nth-child(n + 3) {
  display: none;
}

@media (min-width: 1201px) {
  .admin-panel--bottom #adminForm {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-scroll-block--editor > .admin-editor-layout,
  .admin-editor-layout {
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
  }

  .admin-editor-main {
    display: grid;
    gap: 1rem;
  }

  .admin-surface--editor .admin-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-surface--editor,
  #adminStatus,
  .admin-library-grid,
  .admin-editor-sidebar {
    grid-column: auto;
    grid-row: auto;
  }

  .admin-editor-sidebar {
    align-self: start;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1200px) {
  .admin-editor-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  #adminSubjectGroupsList,
  #adminSubjectOrderList,
  #adminDocsList {
    grid-template-columns: 1fr;
  }

  .admin-collapsible-section.is-collapsed #adminSubjectGroupsList > :nth-child(n + 2),
  .admin-collapsible-section.is-collapsed #adminSubjectOrderList > :nth-child(n + 2),
  .admin-collapsible-section.is-collapsed #adminDocsList > :nth-child(n + 2) {
    display: none;
  }

  .admin-editor-sidebar {
    grid-template-columns: 1fr;
  }
}

/* Compact users list with right drawer */
.admin-user-table {
  --admin-user-visible-rows: 6;
  --admin-user-row-height: 5.35rem;
  overflow-x: auto;
  overflow-y: hidden;
}

#adminUsersList {
  max-height: calc(var(--admin-user-visible-rows) * var(--admin-user-row-height));
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

#adminUsersSection {
  position: relative;
}

#adminUsersSection .admin-scroll-block--console,
#adminUsersSection #adminUserStatus {
  transition: margin-right 220ms ease;
}

#adminUsersSection.admin-users-section--drawer-open .admin-scroll-block--console,
#adminUsersSection.admin-users-section--drawer-open #adminUserStatus {
  margin-right: min(500px, calc(100vw - 0.75rem));
}

#adminUserTableHead,
#adminUsersList > .admin-user-table-row {
  min-height: var(--admin-user-row-height);
  min-width: 0;
  grid-template-columns:
    minmax(72px, 0.45fr)
    minmax(150px, 1fr)
    minmax(150px, 1fr)
    minmax(190px, 1fr)
    minmax(150px, 0.9fr)
    minmax(320px, 1.55fr);
  align-items: center;
}

.admin-user-table-cell--review,
.admin-user-head-cell--actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.admin-user-review-stack {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.admin-user-review-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.admin-user-review-actions:empty {
  display: none;
}

.admin-user-review-btn {
  min-height: 2.55rem;
  padding: 0.62rem 0.92rem;
  border-radius: 999px;
  border: 1px solid rgba(153, 180, 248, 0.36);
  background: rgba(255, 255, 255, 0.94);
  color: #29457d;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 20px rgba(17, 31, 66, 0.08);
  opacity: 1;
}

.admin-user-review-btn:hover {
  border-color: rgba(26, 86, 219, 0.34);
  background: rgba(255, 255, 255, 1);
}

.admin-user-review-btn--approve {
  color: #0b776a;
  border-color: rgba(11, 119, 106, 0.26);
  background: rgba(222, 249, 244, 0.92);
}

.admin-user-review-btn--reject {
  color: #c84f64;
  border-color: rgba(200, 79, 100, 0.22);
  background: rgba(255, 241, 244, 0.92);
}

.admin-user-review-btn--delete {
  color: #fff !important;
  border-color: #922948 !important;
  background: linear-gradient(135deg, #d34c73, #922948) !important;
  box-shadow: 0 14px 28px rgba(146, 41, 72, 0.26);
  opacity: 1 !important;
  text-shadow: 0 1px 0 rgba(27, 10, 16, 0.2);
}

.admin-user-review-btn--delete:hover {
  color: #fff !important;
  border-color: #7c1f3b !important;
  background: linear-gradient(135deg, #df5d83, #7c1f3b) !important;
}

.admin-user-review-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.admin-user-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(15, 23, 38, 0);
  pointer-events: none;
  opacity: 0;
  transition: opacity 220ms ease, background 220ms ease;
}

.admin-user-drawer-backdrop.is-open {
  background: rgba(15, 23, 38, 0.14);
  opacity: 1;
  pointer-events: auto;
}

.admin-user-editor {
  position: fixed;
  top: 4.9rem;
  right: 0;
  bottom: 0;
  width: min(500px, calc(100vw - 0.75rem));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.8rem;
  margin: 0;
  padding: 0.7rem 0.55rem 0.75rem;
  border-left: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 1.75rem 0 0 0;
  background: rgba(248, 250, 252, 0.52);
  box-shadow: -20px 0 42px rgba(20, 42, 88, 0.12);
  backdrop-filter: blur(26px);
  -webkit-backdrop-filter: blur(26px);
  overflow: hidden;
  overflow: clip;
  z-index: 61;
  height: calc(100vh - 4.9rem);
  max-height: calc(100vh - 4.9rem);
  opacity: 0;
  transform: translateX(calc(100% + 1.5rem));
  transition: transform 220ms ease, opacity 220ms ease;
}

.admin-user-editor.is-open {
  opacity: 1;
  transform: translateX(0);
}

.admin-user-drawer-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: flex-start;
  gap: 0.9rem;
  margin: 0;
  padding: 0.9rem;
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.48);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.admin-user-drawer-mark {
  width: 2.55rem;
  height: 2.55rem;
  border-radius: 0.82rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #1a56db, #5d00cc);
  color: #fff;
  box-shadow: 0 16px 28px rgba(26, 86, 219, 0.22);
}

.admin-user-drawer-mark .material-symbols-outlined {
  font-size: 1.2rem;
}

.admin-user-drawer-head-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.admin-user-drawer-head-copy .admin-section-kicker {
  font-size: 0.67rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #8a92a6;
}

.admin-user-drawer-head-copy h3 {
  margin: 0;
  font-family: "Space Grotesk", "Sora", sans-serif;
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.15;
  color: #1a2540;
}

.admin-user-drawer-head-copy .admin-note {
  margin: 0;
  font-size: 0.76rem;
  color: #6f778a;
  line-height: 1.35;
}

.admin-user-drawer-close {
  width: 2.55rem;
  height: 2.55rem;
  padding: 0;
  flex-shrink: 0;
  border-color: rgba(255, 255, 255, 0.55) !important;
  background: rgba(255, 255, 255, 0.68) !important;
  color: #5a6780 !important;
  box-shadow: none;
}

.admin-user-drawer-close .material-symbols-outlined {
  font-size: 1.15rem;
}

.admin-user-drawer-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.34rem;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
}

.admin-user-drawer-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  padding: 0.48rem 0.6rem;
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.66);
  color: #1f2d48;
}

.admin-user-drawer-summary-row span {
  font-size: 0.67rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #8a92a6;
}

.admin-user-drawer-summary-row strong {
  font-size: 0.75rem;
  font-weight: 700;
  color: #21355d;
  text-align: right;
}

.admin-user-drawer-note {
  margin: 0;
  padding: 0 0.45rem;
  color: #72809b;
  font-size: 0.68rem;
  line-height: 1.35;
}

.admin-user-editor-body {
  min-height: 0;
  display: grid;
  align-content: start;
  gap: 0.7rem;
  overflow-y: auto;
  overflow-x: hidden;
  overflow-anchor: none;
  overscroll-behavior: contain;
  padding-right: 0.12rem;
  padding-left: 0.08rem;
}

.admin-user-editor form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: minmax(4.55rem, auto);
  gap: 0.85rem;
  align-content: start;
  min-height: 0;
  max-height: none;
  overflow: visible;
  padding: 0.9rem;
  padding-bottom: 0.95rem;
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.48);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.admin-user-editor form > label,
.admin-user-editor form > .programme-choice-block,
.admin-user-editor form > .admin-note {
  min-width: 0;
}

.admin-user-editor form > label {
  display: grid;
  gap: 0.32rem;
  align-content: start;
  color: #5e6b85;
  font-size: 0.72rem;
  font-weight: 800;
}

.admin-user-editor form > label > input,
.admin-user-editor form > label > select {
  width: 100%;
  min-height: 2.8rem;
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.68);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
  color: #21355d;
}

.admin-user-editor form > label > input::placeholder {
  color: #8a92a6;
}

.admin-user-editor form > .programme-choice-block {
  border-radius: 0.95rem;
}

.admin-user-editor form > .admin-checkbox-field,
.admin-user-editor form > #adminUserTeacherProgrammesWrap,
.admin-user-editor form > #adminUserSystemNote {
  grid-column: 1 / -1;
}

.admin-user-drawer-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
  align-items: stretch;
  margin: 0 0.08rem;
  padding: 0.5rem 0 0;
  border-top: 1px solid rgba(210, 219, 235, 0.6);
  background: rgba(248, 250, 252, 0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.admin-user-drawer-actions > button {
  min-height: 2.9rem;
  font-weight: 800;
  border-radius: 999px;
}

#adminUserDeleteBtn {
  grid-column: auto;
  color: #a03252 !important;
  border-color: rgba(200, 79, 100, 0.22) !important;
  background: rgba(255, 241, 244, 0.94) !important;
  box-shadow: none;
}

#adminUserDeleteBtn:hover {
  border-color: rgba(200, 79, 100, 0.38) !important;
  background: rgba(255, 233, 239, 0.98) !important;
}

#adminUserCancelBtn {
  border-color: rgba(255, 255, 255, 0.55) !important;
  background: rgba(255, 255, 255, 0.68) !important;
  color: #58647d !important;
  box-shadow: none !important;
}

#adminUserCancelBtn:hover {
  color: #1353d8 !important;
  background: rgba(255, 255, 255, 0.92) !important;
}

.admin-user-editor .admin-checkbox-row {
  color: #35527f;
}

.admin-user-filter-input,
.admin-user-filter-select,
.admin-user-search input,
.admin-panel #adminUserResetFiltersBtn,
.admin-panel #adminUserResetFiltersInlineBtn {
  color: #1e315c !important;
  border: 1px solid rgba(129, 155, 219, 0.48) !important;
  background: rgba(255, 255, 255, 0.98) !important;
  box-shadow: 0 10px 20px rgba(18, 31, 64, 0.08);
}

.admin-user-filter-input::placeholder,
.admin-user-search input::placeholder {
  color: #5f7199;
  opacity: 1;
}

.admin-user-filter-select,
.admin-user-search input {
  font-weight: 700;
}

.admin-panel #adminUserResetFiltersBtn,
.admin-panel #adminUserResetFiltersInlineBtn {
  color: #1f4aa5 !important;
  font-weight: 800;
}

.admin-panel #adminUserResetFiltersBtn:hover,
.admin-panel #adminUserResetFiltersInlineBtn:hover {
  border-color: rgba(31, 74, 165, 0.4) !important;
  background: rgba(245, 249, 255, 1) !important;
}

@media (max-width: 1180px) {
  #adminUserTableHead,
  #adminUsersList > .admin-user-table-row {
    grid-template-columns:
      minmax(72px, 0.45fr)
      minmax(140px, 1fr)
      minmax(140px, 1fr)
      minmax(160px, 1fr)
      minmax(130px, 0.9fr)
      minmax(260px, 1.35fr);
  }
}

@media (max-width: 980px) {
  #adminUsersSection.admin-users-section--drawer-open .admin-scroll-block--console,
  #adminUsersSection.admin-users-section--drawer-open #adminUserStatus {
    margin-right: 0;
  }

  .admin-user-drawer-backdrop.is-open {
    background: rgba(13, 24, 47, 0.22);
  }

  .admin-user-editor {
    top: 4.8rem;
    right: 0;
    bottom: 0;
    width: min(460px, calc(100vw - 0.5rem));
    border-radius: 1.5rem 0 0 0;
    height: calc(100vh - 4.8rem);
    max-height: calc(100vh - 4.8rem);
  }

  #adminUserTableHead,
  #adminUsersList > .admin-user-table-row {
    min-width: 860px;
  }
}

@media (max-width: 640px) {
  .admin-user-drawer-summary,
  .admin-user-editor form,
  .admin-user-drawer-actions {
    grid-template-columns: 1fr;
  }

  .admin-user-editor {
    width: 100vw;
    right: 0;
    bottom: 0;
    padding-left: 0.85rem;
    padding-right: 0.85rem;
    border-radius: 1.5rem 1.5rem 0 0;
    height: calc(100vh - 5rem);
    max-height: calc(100vh - 5rem);
  }
}
