@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Source+Serif+4:wght@400;600&display=swap");

:root {
  color-scheme: light;
  --bg: #f5f2eb;
  --bg-2: #e5ece8;
  --surface: #fffdf8;
  --surface-soft: rgba(255, 253, 248, 0.92);
  --surface-strong: rgba(255, 253, 248, 0.98);
  --line: rgba(18, 63, 70, 0.12);
  --text: #172326;
  --muted: #68777a;
  --accent: #123f46;
  --accent-2: #6f8067;
  --accent-rgb: 18, 63, 70;
  --accent-2-rgb: 111, 128, 103;
  --danger: #bf4a3a;
  --shadow: 0 24px 54px rgba(18, 63, 70, 0.14);
}

.icon-sprite {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.title-icon,
.button-icon,
.messages-composer-icon {
  width: 1em;
  height: 1em;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex: 0 0 auto;
}

.title-icon {
  color: var(--accent);
  width: 0.9em;
  height: 0.9em;
}

.button-with-icon,
.notifications-enable {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.notifications-enable {
  text-align: center;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100vh;
  width: 100%;
  overflow-x: clip;
  font-family: "Space Grotesk", "Helvetica Neue", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(var(--accent-rgb), 0.2), transparent 42%),
    radial-gradient(circle at 80% 8%, rgba(var(--accent-2-rgb), 0.16), transparent 34%),
    linear-gradient(160deg, var(--bg), var(--bg-2));
  overscroll-behavior: none;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: linear-gradient(
      115deg,
      rgba(23, 33, 43, 0.06) 0%,
      rgba(23, 33, 43, 0) 60%
    ),
    repeating-linear-gradient(
      90deg,
      rgba(23, 33, 43, 0.025),
      rgba(23, 33, 43, 0.025) 1px,
      transparent 1px,
      transparent 120px
    );
  pointer-events: none;
  z-index: -1;
}

.debug-panel {
  position: fixed;
  bottom: 16px;
  right: 16px;
  width: min(360px, 92vw);
  max-height: 40vh;
  overflow: auto;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(16, 24, 26, 0.18);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 16px 32px rgba(16, 24, 26, 0.18);
  font-size: 0.8rem;
  color: var(--text);
  z-index: 100;
}

.debug-panel h4 {
  margin: 0 0 8px;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.debug-line {
  padding: 6px 0;
  border-bottom: 1px dashed rgba(16, 24, 26, 0.12);
  word-break: break-word;
}

.debug-line:last-child {
  border-bottom: none;
}

.debug-tag {
  font-weight: 600;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translate(-50%, 16px);
  opacity: 0;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(16, 24, 26, 0.92);
  color: #fff;
  font-size: 0.9rem;
  box-shadow: 0 16px 32px rgba(16, 24, 26, 0.2);
  z-index: 120;
  pointer-events: none;
  max-width: min(90vw, 520px);
  text-align: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

.toast.error {
  background: rgba(216, 75, 75, 0.95);
}

.app {
  position: relative;
  min-height: 100vh;
  max-width: 100%;
  overflow-x: clip;
}

.app-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 48px;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 40px;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 0;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  background: rgba(255, 253, 248, 0.94);
  box-shadow: 0 14px 30px rgba(23, 33, 43, 0.1);
  backdrop-filter: blur(12px);
  z-index: 32;
}

body[data-auth="logged-out"] .app-topbar {
  display: none;
}

.app-topbar-title {
  min-width: 0;
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-notifications-button {
  position: relative;
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  justify-self: end;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--accent);
  cursor: pointer;
}

.app-notifications-button:hover,
.app-notifications-button:focus-visible {
  color: var(--text);
  background: rgba(var(--accent-rgb), 0.08);
  outline: none;
}

.app-topbar-icon {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.app-notifications-badge {
  position: absolute;
  top: 3px;
  right: 2px;
  min-width: 17px;
  height: 17px;
  padding: 0 5px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--danger);
  color: #fff;
  border: 2px solid rgba(255, 253, 248, 0.98);
  font-size: 0.66rem;
  line-height: 1;
  font-weight: 800;
}

.app-notifications-badge[hidden] {
  display: none;
}

.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 260px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 58px 16px 16px;
  background:
    linear-gradient(180deg, rgba(255, 252, 246, 0.9), rgba(233, 238, 232, 0.88)),
    linear-gradient(150deg, rgba(var(--accent-rgb), 0.08), rgba(var(--accent-2-rgb), 0.08));
  border-right: 1px solid var(--line);
  box-shadow: 18px 0 42px rgba(23, 33, 43, 0.1);
  transform: translateX(-110%);
  transition: transform 0.25s ease;
  z-index: 50;
  overflow: hidden;
}

.nav-toggle {
  position: static;
  width: 36px;
  height: 36px;
  padding: 6px 5px;
  border: 0;
  background: transparent;
  display: grid;
  place-items: center;
  gap: 3px;
  cursor: pointer;
  box-shadow: none;
  z-index: auto;
}

.nav-toggle span {
  width: 16px;
  height: 1.8px;
  background: var(--accent);
  border-radius: 999px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

body[data-nav="open"] .nav-toggle span:nth-child(1) {
  transform: translateY(4px) rotate(45deg);
}

body[data-nav="open"] .nav-toggle span:nth-child(2) {
  opacity: 0;
}

body[data-nav="open"] .nav-toggle span:nth-child(3) {
  transform: translateY(-4px) rotate(-45deg);
}

.nav-toggle:hover span,
.nav-toggle:focus-visible span {
  background: var(--text);
}

.nav-scrim {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.46);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  border: none;
  backdrop-filter: grayscale(0.25);
  z-index: 40;
}

body[data-nav="open"] .nav-scrim {
  opacity: 1;
  pointer-events: auto;
}

body[data-auth="logged-in"][data-nav="open"] .sidebar {
  transform: translateX(0);
}

body[data-auth="logged-out"] .sidebar {
  transform: translateX(-110%);
  pointer-events: none;
}

body[data-auth="logged-out"] .nav-toggle {
  opacity: 0;
  pointer-events: none;
}

.brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.brand-home,
.brand-profile {
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.brand-home {
  min-width: 0;
}

.logo-text {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fffaf3;
  box-shadow: 0 12px 22px rgba(23, 33, 43, 0.18);
  white-space: nowrap;
  transition: transform 0.2s ease;
}

.brand-profile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  color: var(--text);
  background: rgba(255, 252, 246, 0.86);
  border: 1px solid rgba(var(--accent-rgb), 0.18);
  box-shadow: 0 10px 20px rgba(23, 33, 43, 0.08);
  flex-shrink: 0;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.brand-profile svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.brand-home:hover .logo-text,
.brand-profile:hover {
  transform: translateY(-1px);
}

.sidebar-body {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 6px;
  margin-right: -6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(var(--accent-rgb), 0.24) transparent;
}

.nav::-webkit-scrollbar {
  width: 8px;
}

.nav::-webkit-scrollbar-thumb {
  background: rgba(var(--accent-rgb), 0.2);
  border-radius: 999px;
}

.nav::-webkit-scrollbar-track {
  background: transparent;
}

.nav-item {
  border: 1px solid var(--line);
  background: rgba(255, 252, 246, 0.96);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.95rem;
  cursor: pointer;
  text-align: left;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.nav-item.nav-item-icon {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.nav-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.18), rgba(var(--accent-2-rgb), 0.18));
  border: 1px solid rgba(var(--accent-rgb), 0.24);
}

.nav-icon svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sidebar .nav-item {
  min-height: 30px;
  padding: 5px 8px;
  font-size: 0.82rem;
  line-height: 1.2;
}

.sidebar .nav-item.nav-item-icon {
  gap: 6px;
}

.sidebar .nav-icon {
  width: 20px;
  height: 20px;
}

.sidebar .nav-icon svg {
  width: 11px;
  height: 11px;
}

#logoutBtn {
  background: rgba(216, 75, 75, 0.1);
  border-color: rgba(216, 75, 75, 0.24);
  color: #b83232;
}

#logoutBtn .nav-icon {
  color: #b83232;
  background: rgba(216, 75, 75, 0.12);
  border-color: rgba(216, 75, 75, 0.24);
}

#logoutBtn:hover,
#logoutBtn:focus-visible {
  background: rgba(216, 75, 75, 0.16);
  border-color: rgba(216, 75, 75, 0.34);
  color: #9f2424;
}

.nav-item:hover {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.1), rgba(var(--accent-2-rgb), 0.14));
  border-color: rgba(var(--accent-rgb), 0.28);
  transform: translateX(2px);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.12);
}

.nav-foot {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  font-size: 0.75rem;
  color: var(--muted);
}

.app-install-alert {
  display: none;
  width: min(1180px, 100%);
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  margin-bottom: 14px;
  border-radius: 20px;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  background:
    linear-gradient(135deg, rgba(var(--accent-rgb), 0.08), rgba(var(--accent-2-rgb), 0.1)),
    rgba(255, 252, 246, 0.94);
  box-shadow: 0 14px 30px rgba(23, 33, 43, 0.08);
}

.app-install-alert-copy {
  display: grid;
  gap: 4px;
}

.app-install-alert-copy strong {
  font-size: 0.98rem;
}

.app-install-alert-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.app-install-alert-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

.content {
  display: grid;
  place-items: center;
  padding: 72px 24px 36px;
  min-width: 0;
  max-width: 100%;
  overflow-x: clip;
}

.content > * {
  min-width: 0;
  max-width: 100%;
}

body[data-auth="logged-out"] .content {
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}

body[data-auth="logged-out"] .dashboard-pull-indicator {
  display: none;
}

body[data-view="attendance"] .content,
body[data-view="attendance-list"] .content,
body[data-view="dashboard"] .content,
body[data-view="announcements"] .content,
body[data-view="announcement-compose"] .content,
body[data-view="message-compose"] .content,
body[data-view="subject-details"] .content,
body[data-view="subject-detail-compose"] .content,
body[data-view="dau-summaries"] .content,
body[data-view="dau-summary-compose"] .content,
body[data-view="photo-manager"] .content,
body[data-view="profile"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="photo-manager"] .content {
  padding-top: 0;
}

.launch-card,
.login-card,
.error-card,
.update-card {
  width: min(440px, 92vw);
  padding: 32px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.launch-card {
  display: none;
  place-items: center;
  gap: 18px;
  text-align: center;
}

.launch-logo {
  width: 96px;
  height: 96px;
  border-radius: 22px;
  box-shadow: 0 18px 36px rgba(var(--accent-rgb), 0.18);
}

.launch-copy {
  display: grid;
  gap: 8px;
}

.launch-card h1 {
  margin: 0;
  color: var(--accent);
  font-size: 1.5rem;
  line-height: 1.1;
}

.launch-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.login-card {
  width: min(480px, 92vw);
  padding: 36px;
  display: grid;
  gap: 20px;
  background:
    radial-gradient(circle at top right, rgba(var(--accent-rgb), 0.12), transparent 36%),
    linear-gradient(165deg, rgba(255, 252, 246, 0.98), rgba(247, 241, 233, 0.94));
  border: 1px solid rgba(23, 33, 43, 0.08);
  box-shadow:
    0 34px 72px rgba(23, 33, 43, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.login-card-header {
  display: grid;
  gap: 0;
}

.login-card h1 {
  margin: 0;
  font-size: 2.2rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.dashboard-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.profile-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.photo-manager-view {
  display: none;
  width: 100%;
  max-width: 980px;
  gap: 16px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.time-table-view {
  display: none;
  width: 100%;
  max-width: 1100px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.time-table-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 6px;
}

.time-table-header h1 {
  margin: 0;
  font-size: 1.32rem;
}

.time-table-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.time-table-status:empty {
  display: none;
}

.time-table-status.error {
  color: var(--danger);
}

.time-table-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.time-table-tab {
  min-height: 34px;
  border: 1px solid rgba(var(--accent-rgb), 0.18);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(255, 252, 246, 0.9);
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
}

.time-table-tab[aria-pressed="true"] {
  background: rgba(var(--accent-rgb), 0.12);
  border-color: rgba(var(--accent-rgb), 0.35);
  color: var(--accent);
}

.time-table-card {
  display: grid;
  gap: 12px;
}

.time-table-card-header {
  display: grid;
  gap: 2px;
}

.time-table-card-header h2,
.time-table-card-header p {
  margin: 0;
}

.time-table-card-header h2 {
  font-size: 1.08rem;
}

.time-table-card-header p {
  color: var(--muted);
  font-size: 0.88rem;
}

.time-table-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  background: rgba(255, 252, 246, 0.94);
  box-shadow: 0 10px 22px rgba(23, 33, 43, 0.06);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x pan-y;
}

.time-table-grid {
  width: 100%;
  min-width: 680px;
  border-collapse: separate;
  border-spacing: 0;
}

.time-table-grid th,
.time-table-grid td {
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  border-right: 1px solid rgba(15, 23, 42, 0.08);
  padding: 10px;
  text-align: left;
  vertical-align: top;
  font-size: 0.86rem;
  line-height: 1.35;
}

.time-table-grid tr:last-child th,
.time-table-grid tr:last-child td {
  border-bottom: 0;
}

.time-table-grid th:last-child,
.time-table-grid td:last-child {
  border-right: 0;
}

.time-table-grid thead th {
  background: rgba(var(--accent-rgb), 0.09);
  color: var(--text);
  font-weight: 800;
  white-space: nowrap;
}

.time-table-grid th:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
  min-width: 88px;
  box-shadow: 8px 0 14px rgba(15, 23, 42, 0.06);
}

.time-table-grid thead th:first-child {
  z-index: 3;
}

.time-table-grid thead th span,
.time-table-grid thead th small {
  display: block;
}

.time-table-grid thead th small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.time-table-grid tbody th {
  background: rgba(var(--accent-rgb), 0.05);
  font-weight: 800;
  white-space: nowrap;
}

.time-table-grid tbody tr.is-today th,
.time-table-grid tbody tr.is-today td {
  background: rgba(var(--accent-rgb), 0.1);
}

.time-table-grid tbody tr.is-today th {
  color: var(--accent);
}

.time-table-grid thead th:first-child {
  background: linear-gradient(rgba(var(--accent-rgb), 0.09), rgba(var(--accent-rgb), 0.09)), var(--surface-strong);
}

.time-table-grid tbody th:first-child {
  background: linear-gradient(rgba(var(--accent-rgb), 0.05), rgba(var(--accent-rgb), 0.05)), var(--surface-strong);
}

.time-table-grid tbody tr.is-today th:first-child {
  background: linear-gradient(rgba(var(--accent-rgb), 0.1), rgba(var(--accent-rgb), 0.1)), var(--surface-strong);
}

.time-table-empty {
  display: none;
}

.photo-manager-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.photo-manager-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.photo-manager-status.error {
  color: var(--danger);
}

.photo-manager-form {
  display: grid;
  gap: 16px;
}

.photo-manager-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.photo-camera-canvas {
  display: none;
}

.photo-cropper {
  position: relative;
  width: min(320px, 100%);
  max-width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(16, 24, 26, 0.15);
  background: rgba(248, 250, 252, 0.9);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.08);
  touch-action: none;
}

.photo-cropper video,
.photo-cropper img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  user-select: none;
  pointer-events: none;
  z-index: 1;
}

.photo-cropper-placeholder {
  position: absolute;
  inset: 0;
  display: none;
  place-items: center;
  padding: 12px;
  text-align: center;
  font-size: 0.85rem;
  color: var(--muted);
  z-index: 2;
}

.photo-cropper[data-mode="idle"] .photo-cropper-placeholder {
  display: grid;
}

.photo-cropper-grid {
  position: absolute;
  border: 2px solid rgba(14, 165, 164, 0.7);
  border-radius: 14px;
  box-shadow: 0 0 0 9999px rgba(15, 23, 42, 0.25);
  cursor: grab;
  touch-action: none;
  display: none;
  z-index: 3;
}

.photo-cropper[data-ready="true"][data-mode="crop"] .photo-cropper-grid {
  display: block;
}

.photo-cropper-grid.dragging {
  cursor: grabbing;
}

.photo-cropper-grid.resizing {
  cursor: nwse-resize;
}

.photo-cropper-grid .grid-line {
  position: absolute;
  background: rgba(255, 255, 255, 0.7);
}

.photo-cropper-grid .grid-line.vertical {
  top: 0;
  bottom: 0;
  width: 1px;
}

.photo-cropper-grid .grid-line.horizontal {
  left: 0;
  right: 0;
  height: 1px;
}

.photo-cropper-grid .grid-line.vertical.one {
  left: 33.333%;
}

.photo-cropper-grid .grid-line.vertical.two {
  left: 66.666%;
}

.photo-cropper-grid .grid-line.horizontal.one {
  top: 33.333%;
}

.photo-cropper-grid .grid-line.horizontal.two {
  top: 66.666%;
}

.photo-cropper-handle {
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid rgba(14, 165, 164, 0.9);
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.25);
  touch-action: none;
  z-index: 2;
}

.photo-cropper-handle.nw {
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  cursor: nwse-resize;
}

.photo-cropper-handle.ne {
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  cursor: nesw-resize;
}

.photo-cropper-handle.sw {
  bottom: 0;
  left: 0;
  transform: translate(-50%, 50%);
  cursor: nesw-resize;
}

.photo-cropper-handle.se {
  bottom: 0;
  right: 0;
  transform: translate(50%, 50%);
  cursor: nwse-resize;
}

.photo-cropper-overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 10px 12px;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0) 0%, rgba(15, 23, 42, 0.65) 100%);
  color: #fff;
  z-index: 4;
  pointer-events: none;
}

.photo-cropper[data-mode="idle"] .photo-cropper-overlay {
  display: none;
}

.photo-cropper-hint {
  display: none;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.92);
}

.photo-cropper[data-mode="camera"] .photo-cropper-hint[data-mode="camera"],
.photo-cropper[data-mode="crop"] .photo-cropper-hint[data-mode="crop"] {
  display: block;
}

.photo-cropper video {
  display: none;
}

.photo-cropper img {
  display: none;
}

.photo-cropper[data-mode="camera"] video {
  display: block;
}

.photo-cropper[data-mode="crop"] img {
  display: block;
}

.dashboard-header,
.profile-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.dashboard-header,
.profile-header,
.calendar-header,
.messages-header,
.circulars-header,
.policies-header,
.leave-notifications-header,
.fees-header,
.academic-updates-header,
.elearning-header,
.photo-manager-header {
  padding-top: 0;
}

.dashboard-header h1,
.profile-header h1 {
  margin: 0 0 6px;
  font-size: 1.72rem;
}

.profile-rows {
  display: grid;
  gap: 10px;
}

.profile-grid {
  display: grid;
  gap: 14px;
}

.profile-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}

.profile-tabs::-webkit-scrollbar {
  display: none;
}

.profile-tab {
  flex: 0 0 auto;
  border: 1px solid rgba(var(--accent-rgb), 0.18);
  background: rgba(255, 255, 255, 0.78);
  color: var(--text);
  border-radius: 999px;
  padding: 7px 8px;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
  white-space: nowrap;
}

.profile-tab[aria-selected="true"] {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.profile-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.profile-status:empty {
  display: none;
}

.profile-status.error {
  color: var(--danger);
}

.profile-tab-panel {
  display: none;
  width: 100%;
  gap: 12px;
}

.profile-tab-panel > .card-header {
  align-items: center;
}

.profile-tab-panel > .card-header h2 {
  margin: 0;
  font-size: 1.1rem;
}

.profile-record-list {
  display: grid;
  gap: 12px;
}

.profile-record-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.86);
}

.profile-record-card.is-clickable {
  cursor: pointer;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.profile-record-card.is-clickable:hover,
.profile-record-card.is-clickable:focus-visible {
  border-color: rgba(var(--accent-rgb), 0.32);
  box-shadow: 0 10px 22px rgba(23, 33, 43, 0.08);
  transform: translateY(-1px);
  outline: none;
}

.profile-record-card h3 {
  margin: 0;
  font-size: 1rem;
}

.profile-record-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 0.86rem;
}

.profile-record-fields {
  display: grid;
  gap: 8px;
  margin: 0;
}

.profile-record-fields div {
  display: grid;
  grid-template-columns: minmax(0, 130px) minmax(0, 1fr);
  gap: 8px;
  padding-top: 8px;
  border-top: 1px dashed rgba(16, 24, 26, 0.12);
}

.profile-record-fields dt {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.profile-record-fields dd {
  margin: 0;
  color: var(--text);
  overflow-wrap: anywhere;
}

.profile-record-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.profile-record-badge {
  display: inline-flex;
  width: fit-content;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(216, 75, 75, 0.12);
  color: var(--danger);
  font-size: 0.78rem;
  font-weight: 700;
}

.achievement-detail {
  display: grid;
  gap: 12px;
}

.achievement-modal-card {
  width: min(620px, 94vw);
}

.health-checkup-detail {
  display: grid;
  gap: 12px;
}

.health-checkup-detail-body {
  display: none;
  gap: 12px;
}

.health-checkup-detail-body.show {
  display: grid;
}

.health-checkup-modal-card {
  width: min(620px, 94vw);
}

@media (min-width: 780px) {
  .profile-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  }
}

.profile-card {
  border-radius: 20px;
  padding: 18px;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(245, 240, 233, 0.84));
  box-shadow: 0 14px 30px rgba(23, 33, 43, 0.06);
  display: grid;
  gap: 14px;
}

.profile-eyebrow {
  display: inline-flex;
  width: fit-content;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.1);
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.profile-row {
  display: grid;
  grid-template-columns: minmax(0, 120px) minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding-bottom: 6px;
  border-bottom: 1px dashed rgba(16, 24, 26, 0.12);
}

.profile-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.profile-security-card {
  align-content: start;
}

.profile-security-row {
  display: grid;
  gap: 10px;
}

.profile-security-row .primary {
  width: fit-content;
  max-width: 100%;
}

.profile-label {
  font-size: 0.85rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.profile-value {
  font-size: 0.95rem;
  color: var(--text);
  text-align: left;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.profile-about {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 4px 2px 0;
  font-size: 0.82rem;
  color: var(--muted);
}

.profile-about strong {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text);
  text-align: right;
}

.profile-select {
  display: none;
  grid-column: 2 / -1;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(16, 24, 26, 0.2);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  font-size: 0.95rem;
  font-family: inherit;
}

.quick-actions {
  display: grid;
  gap: 12px;
}

.quick-actions h2 {
  margin: 0;
  font-size: 1.1rem;
}

.quick-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}

.quick-action {
  display: grid;
  place-items: center;
  text-align: center;
  padding: 14px;
}

.notification-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 60;
}

.notification-modal.show {
  display: flex;
}

.push-prompt-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 70;
}

.push-prompt-modal.show {
  display: flex;
}

.notification-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(4px);
}

.notification-modal-card {
  position: relative;
  width: min(560px, 94vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 18px 18px 22px;
  display: grid;
  gap: 12px;
  animation: fadeUp 0.3s ease-out;
}

.notification-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.notification-modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.push-prompt-card {
  position: relative;
  width: min(440px, 94vw);
  border-radius: 18px;
  border: 1px solid var(--line);
  background: var(--surface-strong);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 18px;
  display: grid;
  gap: 14px;
  animation: fadeUp 0.3s ease-out;
}

.push-prompt-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: rgba(var(--accent-rgb), 0.1);
  color: var(--accent);
}

.push-prompt-icon .title-icon {
  width: 24px;
  height: 24px;
}

.push-prompt-content {
  display: grid;
  gap: 8px;
}

.push-prompt-content h3 {
  margin: 0;
  font-size: 1.15rem;
}

.push-prompt-content p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.push-prompt-status {
  min-height: 18px;
  font-size: 0.86rem;
  color: var(--accent);
}

.push-prompt-status:empty {
  display: none;
}

.push-prompt-status.error {
  color: var(--danger);
}

.push-prompt-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

body.modal-open {
  overflow: hidden;
}

.notifications-count {
  font-size: 0.85rem;
  color: var(--muted);
  padding-top: 6px;
}

.notifications-count:empty {
  display: none;
}

.dashboard-pull-indicator {
  width: min(100%, 880px);
  justify-self: center;
  height: 0;
  overflow: hidden;
  display: grid;
  place-items: center;
  opacity: 0;
  transition: height 0.2s ease, opacity 0.2s ease;
}

.dashboard-pull-indicator.show {
  opacity: 1;
}

.dashboard-pull-indicator span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 700;
}

.dashboard-pull-indicator[data-state="ready"] span {
  background: rgba(var(--accent-2-rgb), 0.14);
  color: var(--accent-2);
}

.dashboard-pull-indicator[data-state="loading"] span {
  background: rgba(var(--accent-rgb), 0.16);
}

.notifications-actions {
  display: grid;
  gap: 6px;
  justify-items: end;
}

.notifications-enable {
  padding: 6px 10px;
  font-size: 0.82rem;
  border-radius: 999px;
}

.notifications-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
  margin-top: -4px;
}

.notifications-status:empty {
  display: none;
}

.notifications-status.error {
  color: var(--danger);
}

.notifications-list {
  display: grid;
  gap: 12px;
}

.notifications-sentinel {
  display: none;
  padding: 4px 0 2px;
  text-align: center;
  color: var(--muted);
  font-size: 0.82rem;
}

.notification-card {
  border-radius: 14px;
  border: 1px solid rgba(var(--accent-rgb), 0.16);
  background: rgba(255, 252, 246, 0.96);
  padding: 12px 14px;
  display: grid;
  gap: 6px;
  width: 100%;
  min-width: 0;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
  transition: border 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.notification-card > * {
  min-width: 0;
  max-width: 100%;
}

.notification-card.is-read {
  border-color: rgba(23, 33, 43, 0.08);
  background: rgba(255, 252, 246, 0.78);
  box-shadow: none;
}

.notification-card:hover {
  border-color: rgba(var(--accent-rgb), 0.28);
  box-shadow: 0 10px 24px rgba(23, 33, 43, 0.08);
  transform: translateY(-1px);
}

.notification-card.unread {
  border-color: rgba(var(--accent-rgb), 0.4);
  background: rgba(var(--accent-rgb), 0.08);
  font-weight: 600;
}

.notification-card.is-read h4 {
  color: rgba(23, 33, 43, 0.88);
}

.notification-card.is-read .notification-body,
.notification-card.is-read .notification-time {
  color: rgba(99, 113, 128, 0.92);
}

.notification-card-title-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
}

.notification-card h4 {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  font-size: 0.98rem;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.notification-card-clip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  color: var(--accent-2);
}

.notification-card-clip svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.notification-card .meta,
.notification-card .notification-time {
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 500;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.notification-card .body {
  font-size: 0.9rem;
  color: var(--text);
  font-weight: 400;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.notification-card.unread .body {
  font-weight: 500;
}

.notification-detail {
  border-radius: 16px;
  border: 1px dashed rgba(var(--accent-rgb), 0.28);
  padding: 12px 14px;
  background: rgba(255, 252, 246, 0.75);
  display: grid;
  gap: 8px;
}

.notification-detail-empty {
  font-size: 0.9rem;
  color: var(--muted);
}

.notification-detail-body {
  display: none;
  gap: 8px;
}

.notification-detail-body.show {
  display: grid;
}

.notification-detail-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.notification-detail-header h3 {
  margin: 0;
  font-size: 1.05rem;
}

.notification-detail-time {
  font-size: 0.82rem;
  color: var(--muted);
}

.notification-detail-meta {
  font-size: 0.85rem;
  color: var(--accent-2);
}

.notification-detail-text {
  font-size: 0.95rem;
  color: var(--text);
  line-height: 1.5;
  white-space: normal;
}

.notification-detail-text a {
  color: var(--accent-2);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.notification-detail-files {
  display: grid;
  gap: 6px;
}

.notification-detail-files a {
  color: var(--accent-2);
  text-decoration: none;
  font-size: 0.85rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.attendance-list-view {
  display: none;
  width: 100%;
  max-width: 880px;
  gap: 18px;
  padding: 20px 22px 24px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.announcements-view {
  display: none;
  width: 100%;
  max-width: 980px;
  gap: 16px;
  padding: 18px 20px 24px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.messages-view {
  display: none;
  width: 100%;
  max-width: 980px;
  gap: 16px;
  padding: 18px 20px 24px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.message-compose-view {
  display: none;
  width: min(760px, 94vw);
  max-width: 760px;
  gap: 12px;
  padding: 12px 16px 20px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.message-compose-view h1 {
  margin: 0 0 4px;
  font-size: 1.3rem;
}

.message-compose-view .sub {
  margin: 0;
}

.messages-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.messages-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.messages-status.error {
  color: var(--danger);
}

.attendance-search,
.announcements-search,
.notifications-search {
  width: 100%;
  max-width: 760px;
  margin: 4px 0 12px;
}

.search-input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(16, 24, 26, 0.15);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  font-size: 0.95rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.search-input:focus {
  border-color: rgba(14, 165, 164, 0.6);
  box-shadow: 0 0 0 3px rgba(14, 165, 164, 0.18);
}

.messages-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 18px;
}

body[data-view="messages"][data-messages-mode="detail"] .messages-list {
  display: none;
}

body[data-view="messages"][data-messages-mode="list"] .message-thread-detail {
  display: none;
}

.messages-list {
  display: grid;
  gap: 12px;
}

.message-thread-card {
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.9);
  padding: 14px 16px;
  display: grid;
  gap: 8px;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.message-thread-card.active {
  border-color: rgba(14, 165, 164, 0.6);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.18);
}

.message-thread-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16, 24, 26, 0.12);
}

.message-thread-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

.message-thread-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.message-thread-preview {
  font-size: 0.85rem;
  color: var(--muted);
}

.message-thread-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--muted);
}

.message-thread-status {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(16, 24, 26, 0.1);
  color: var(--text);
}

.message-thread-status.closed {
  background: rgba(216, 75, 75, 0.18);
  color: #8b1b1b;
}

.message-thread-detail {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
  min-height: 240px;
}

.message-thread-nav {
  display: flex;
  justify-content: flex-start;
}

.message-thread-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.message-thread-body {
  display: none;
  gap: 12px;
}

.message-thread-body.show {
  display: grid;
}

.message-thread-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.message-thread-header h2 {
  margin: 0;
  font-size: 1.1rem;
}

.message-thread-messages {
  display: grid;
  gap: 10px;
  padding: 8px 4px;
}

.message-thread-actions {
  display: flex;
  justify-content: flex-start;
  padding-top: 4px;
}

.message-bubble {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(16, 24, 26, 0.06);
  color: var(--text);
  font-size: 0.9rem;
  display: grid;
  gap: 6px;
  white-space: pre-wrap;
}

.message-bubble.self {
  background: rgba(14, 165, 164, 0.16);
  border: 1px solid rgba(14, 165, 164, 0.25);
  justify-self: end;
}

.message-bubble .meta {
  font-size: 0.75rem;
  color: var(--muted);
}

.message-bubble a {
  color: var(--accent-2);
  text-decoration: none;
  font-size: 0.82rem;
}

.message-reply-form {
  border-top: 1px dashed rgba(16, 24, 26, 0.12);
  padding-top: 12px;
  display: grid;
  gap: 10px;
}

.message-reply-actions {
  display: flex;
  justify-content: flex-end;
}

.message-compose-form {
  width: 100%;
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
}

.message-compose-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
}

.announcement-compose-view {
  display: none;
  width: 100%;
  max-width: 720px;
  gap: 10px;
  padding: 12px 16px 20px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.announcement-compose-view .announcements-header {
  gap: 8px;
}

.announcement-compose-view h1 {
  margin: 0 0 4px;
  font-size: 1.3rem;
}

.announcement-compose-view .sub {
  margin: 0;
}

.subject-detail-view {
  display: none;
  width: 100%;
  max-width: 980px;
  gap: 16px;
  padding: 18px 20px 24px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.subject-detail-compose-view {
  display: none;
  width: 100%;
  max-width: 860px;
  gap: 12px;
  padding: 16px 18px 22px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.dau-summary-view {
  display: none;
  width: 100%;
  max-width: 980px;
  gap: 16px;
  padding: 18px 20px 24px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.dau-summary-compose-view {
  display: none;
  width: 100%;
  max-width: 760px;
  gap: 12px;
  padding: 16px 18px 22px;
  border-radius: 24px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.dau-summary-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.dau-summary-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.dau-summary-status.error {
  color: var(--danger);
}

.dau-summary-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 18px;
}

body[data-view="dau-summaries"][data-dau-summary-mode="detail"] .dau-summary-list {
  display: none;
}

body[data-view="dau-summaries"][data-dau-summary-mode="list"] .dau-summary-panel {
  display: none;
}

.dau-summary-list {
  display: grid;
  gap: 12px;
}

.dau-summary-card {
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.9);
  padding: 14px 16px;
  display: grid;
  gap: 8px;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dau-summary-card.active {
  border-color: rgba(14, 165, 164, 0.6);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.18);
}

.dau-summary-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16, 24, 26, 0.12);
}

.dau-summary-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

.dau-summary-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.dau-summary-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--muted);
}

.dau-summary-panel {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.94);
  padding: 18px 20px;
}

.dau-summary-nav {
  display: flex;
  justify-content: flex-end;
}

.dau-summary-empty {
  text-align: center;
  color: var(--muted);
  font-size: 0.95rem;
  padding: 30px 12px;
}

.dau-summary-body {
  display: none;
  flex-direction: column;
  gap: 12px;
}

.dau-summary-body.show {
  display: flex;
}

.dau-summary-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.dau-summary-header-row h2 {
  margin: 0;
  font-size: 1.2rem;
}

.dau-summary-status-pill {
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(16, 24, 26, 0.08);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.dau-summary-status-pill.published {
  background: rgba(14, 165, 164, 0.18);
  color: var(--accent-2);
}

.dau-summary-content {
  display: grid;
  gap: 12px;
}

.dau-summary-detail-card {
  border-radius: 14px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: #fff;
  padding: 12px 14px;
  display: grid;
  gap: 8px;
}

.dau-summary-detail-card h4 {
  margin: 0;
  font-size: 1rem;
}

.dau-summary-detail-grid {
  display: grid;
  gap: 8px;
  font-size: 0.88rem;
  color: var(--text);
}

.dau-summary-detail-grid span {
  color: var(--muted);
}

.dau-summary-notifications {
  border-radius: 14px;
  border: 1px dashed rgba(16, 24, 26, 0.2);
  background: rgba(255, 255, 255, 0.7);
  padding: 12px 14px;
  font-size: 0.88rem;
  color: var(--muted);
}

.dau-summary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.dau-summary-form {
  display: grid;
  gap: 14px;
}

.subject-detail-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.subject-detail-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.subject-detail-status.error {
  color: var(--danger);
}

.subject-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 18px;
}

body[data-view="subject-details"][data-subject-detail-mode="detail"] .subject-detail-list {
  display: none;
}

body[data-view="subject-details"][data-subject-detail-mode="list"] .subject-detail-panel {
  display: none;
}

.subject-detail-list {
  display: grid;
  gap: 12px;
}

.subject-detail-card {
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.9);
  padding: 14px 16px;
  display: grid;
  gap: 8px;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.subject-detail-card.active {
  border-color: rgba(14, 165, 164, 0.6);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.18);
}

.subject-detail-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16, 24, 26, 0.12);
}

.subject-detail-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

.subject-detail-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.subject-detail-excerpt {
  font-size: 0.85rem;
  color: var(--muted);
}

.subject-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--muted);
}

.subject-detail-panel {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
  min-height: 240px;
}

.subject-detail-nav {
  display: flex;
  justify-content: flex-start;
}

.subject-detail-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.subject-detail-body {
  display: none;
  gap: 10px;
}

.subject-detail-body.show {
  display: grid;
}

.subject-detail-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.subject-detail-header-row h2 {
  margin: 0;
  font-size: 1.1rem;
}

.subject-detail-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(16, 24, 26, 0.1);
  color: var(--text);
}

.subject-detail-status-pill.published {
  background: rgba(14, 165, 164, 0.2);
  color: #075e5d;
}

.subject-detail-fields {
  display: grid;
  gap: 10px;
}

.subject-detail-field {
  display: grid;
  gap: 4px;
}

.subject-detail-field .label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.subject-detail-field .value {
  font-size: 0.9rem;
  color: var(--text);
  white-space: pre-wrap;
}

.subject-detail-attachments {
  display: grid;
  gap: 6px;
  font-size: 0.85rem;
}

.subject-detail-attachments a {
  color: var(--accent-2);
  text-decoration: none;
}

.subject-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.subject-detail-form {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
}

.announcements-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.announcements-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.announcements-status.error {
  color: var(--danger);
}

.announcements-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}

body[data-view="announcements"][data-announcements-mode="detail"] .announcements-list {
  display: none;
}

body[data-view="announcements"][data-announcements-mode="list"] .announcement-detail {
  display: none;
}

.announcements-list {
  display: grid;
  gap: 12px;
}

.announcement-detail {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
  min-height: 240px;
}

.announcement-detail-nav {
  display: flex;
  justify-content: flex-start;
}

.announcement-detail-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.announcement-detail-body {
  display: none;
  gap: 10px;
}

.announcement-detail-body.show {
  display: grid;
}

.announcement-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.announcement-detail-header h2 {
  margin: 0;
  font-size: 1.1rem;
}

.announcement-files {
  display: grid;
  gap: 6px;
  font-size: 0.85rem;
}

.announcement-files a {
  color: var(--accent-2);
  text-decoration: none;
}

.announcement-card {
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.9);
  padding: 14px 16px;
  display: grid;
  gap: 8px;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.announcement-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.announcement-card.active {
  border-color: rgba(14, 165, 164, 0.6);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.18);
}

.announcement-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16, 24, 26, 0.12);
}

.announcement-card h3 {
  margin: 0;
  font-size: 1.05rem;
  flex: 1;
  min-width: 0;
}

.announcement-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--muted);
}

.announcement-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(16, 24, 26, 0.1);
  color: var(--text);
}

.announcement-status-pill.sent {
  background: rgba(14, 165, 164, 0.2);
  color: #075e5d;
}

.announcement-status-pill.cancelled {
  background: rgba(216, 75, 75, 0.18);
  color: #8b1b1b;
}

.announcement-body {
  font-size: 0.9rem;
  color: var(--text);
}

.announcement-actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.announcement-form {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.95);
  padding: 16px;
  display: grid;
  gap: 12px;
}

.announcement-form h2 {
  margin: 0;
  font-size: 1.05rem;
}

.announcement-form textarea {
  resize: vertical;
}

.announcement-recipients {
  display: grid;
  gap: 10px;
}

.selection-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.selection-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.12);
  color: var(--text);
  font-size: 0.8rem;
}

.selection-pill button {
  border: none;
  background: transparent;
  font-size: 0.9rem;
  cursor: pointer;
  color: var(--muted);
}

.selection-pill button:hover {
  color: var(--text);
}

.checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--text);
}

.hint {
  font-size: 0.8rem;
  color: var(--muted);
  margin-top: 4px;
}

.announcement-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
}

.attendance-list-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.attendance-list-status.error {
  color: var(--danger);
}

.attendance-groups {
  display: grid;
  gap: 12px;
}

.attendance-group {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.attendance-group:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16, 24, 26, 0.15);
}

.attendance-group.active {
  border-color: rgba(14, 165, 164, 0.6);
  background: rgba(14, 165, 164, 0.14);
  box-shadow: inset 0 0 0 1px rgba(14, 165, 164, 0.18);
}

.attendance-view {
  display: none;
  width: 100%;
  max-width: 960px;
  gap: 12px;
  padding: 8px 0 24px;
  border-radius: 0;
  background: transparent;
  border: none;
  backdrop-filter: none;
  box-shadow: none;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.attendance-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.attendance-view h1 {
  margin: 0 0 4px;
  font-size: 1.6rem;
}

.attendance-view .sub {
  margin: 0 0 10px;
  font-size: 0.95rem;
}

.attendance-meta {
  display: grid;
  gap: 8px;
  align-items: end;
  justify-items: end;
}

.attendance-date .field.inline {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  gap: 10px;
}

.attendance-date-static {
  font-size: 0.9rem;
  color: var(--muted);
  text-align: right;
}

.attendance-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.attendance-status.error {
  color: var(--danger);
}

.attendance-card {
  border-radius: 0;
  border: none;
  background: transparent;
  padding: 0;
  display: grid;
  gap: 8px;
}

.status-guide {
  font-size: 0.85rem;
  color: var(--muted);
}

.attendance-table {
  display: grid;
  gap: 8px;
}

.attendance-row {
  display: grid;
  grid-template-columns: 56px 1fr 56px;
  align-items: center;
  gap: 6px;
  padding: 6px 4px;
  border-radius: 0;
  border-bottom: 1px solid rgba(16, 24, 26, 0.08);
  background: transparent;
  width: 100%;
  font-size: 0.92rem;
}

.attendance-row > div {
  min-width: 0;
}

.attendance-row > div:nth-child(2) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attendance-header-row {
  border-bottom: 1px solid rgba(16, 24, 26, 0.18);
  background: transparent;
  color: var(--muted);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.attendance-body:empty {
  display: none;
}

.attendance-empty {
  display: none;
  padding: 14px;
  border-radius: 14px;
  border: 1px dashed rgba(16, 24, 26, 0.18);
  color: var(--muted);
  font-size: 0.9rem;
  text-align: center;
}

.attendance-empty.show {
  display: block;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(16, 24, 26, 0.18);
  background: rgba(16, 24, 26, 0.08);
  font-weight: 600;
  font-size: 0.8rem;
  cursor: pointer;
  min-width: 34px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.status-pill:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(16, 24, 26, 0.15);
}

.status-pill.present {
  background: rgba(14, 165, 164, 0.2);
  color: #075e5d;
  border-color: rgba(14, 165, 164, 0.45);
}

.status-pill.absent {
  background: rgba(216, 75, 75, 0.18);
  color: #8b1b1b;
  border-color: rgba(216, 75, 75, 0.35);
}

.status-pill.neutral {
  background: rgba(16, 24, 26, 0.08);
  color: var(--text);
  border-color: rgba(16, 24, 26, 0.2);
}

.attendance-actions {
  display: flex;
  justify-content: flex-end;
}

.dashboard-view h1 {
  margin: 0 0 6px;
  font-size: 2rem;
  letter-spacing: -0.02em;
}

.dashboard-card {
  min-height: 180px;
  border-radius: 18px;
  border: 1px dashed rgba(14, 165, 164, 0.35);
  background: linear-gradient(140deg, rgba(14, 165, 164, 0.08), rgba(249, 115, 22, 0.08));
}

.classes-panel h2 {
  margin: 0 0 12px;
  font-size: 1.2rem;
}

.classes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.classes-list li {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(14, 165, 164, 0.18);
  background: rgba(255, 255, 255, 0.95);
  font-size: 0.95rem;
}

.classes-list li.empty {
  color: var(--muted);
  border-style: dashed;
  background: rgba(255, 255, 255, 0.7);
}

.error-card {
  display: none;
  text-align: center;
}

.update-card {
  display: none;
  text-align: center;
}

.error-card h1 {
  margin: 12px 0 8px;
  font-size: 1.9rem;
}

.error-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(216, 75, 75, 0.12);
  color: var(--danger);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.update-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(14, 165, 164, 0.18);
  color: var(--accent-2);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-view="error"] .login-card {
  display: none;
}

body[data-view="launch"] .login-card,
body[data-view="launch"] .error-card,
body[data-view="launch"] .update-card,
body[data-view="launch"] .dashboard-view,
body[data-view="launch"] .attendance-list-view,
body[data-view="launch"] .attendance-view,
body[data-view="launch"] .announcements-view,
body[data-view="launch"] .announcement-compose-view,
body[data-view="launch"] .messages-view,
body[data-view="launch"] .message-compose-view,
body[data-view="launch"] .subject-detail-view,
body[data-view="launch"] .subject-detail-compose-view,
body[data-view="launch"] .dau-summary-view,
body[data-view="launch"] .dau-summary-compose-view,
body[data-view="launch"] .photo-manager-view,
body[data-view="launch"] .profile-view {
  display: none;
}

body[data-view="launch"] .launch-card {
  display: grid;
}

body[data-view="error"] .error-card {
  display: block;
}

body[data-view="error"] .launch-card,
body[data-view="update"] .login-card,
body[data-view="update"] .error-card,
body[data-view="update"] .launch-card,
body[data-view="update"] .dashboard-view,
body[data-view="update"] .attendance-list-view,
body[data-view="update"] .attendance-view,
body[data-view="update"] .announcements-view,
body[data-view="update"] .announcement-compose-view,
body[data-view="update"] .messages-view,
body[data-view="update"] .message-compose-view,
body[data-view="update"] .subject-detail-view,
body[data-view="update"] .subject-detail-compose-view,
body[data-view="update"] .dau-summary-view,
body[data-view="update"] .dau-summary-compose-view,
body[data-view="update"] .photo-manager-view,
body[data-view="update"] .profile-view {
  display: none;
}

body[data-view="update"] .update-card {
  display: block;
}

body[data-view="login"] .error-card,
body[data-view="login"] .update-card,
body[data-view="login"] .launch-card,
body[data-view="login"] .dashboard-view,
body[data-view="login"] .attendance-list-view,
body[data-view="login"] .attendance-view,
body[data-view="login"] .announcements-view,
body[data-view="login"] .announcement-compose-view,
body[data-view="login"] .messages-view,
body[data-view="login"] .message-compose-view,
body[data-view="login"] .subject-detail-view,
body[data-view="login"] .subject-detail-compose-view,
body[data-view="login"] .dau-summary-view,
body[data-view="login"] .dau-summary-compose-view,
body[data-view="login"] .photo-manager-view,
body[data-view="login"] .profile-view {
  display: none;
}

body[data-view="login"] .login-card {
  display: grid;
}

body[data-view="dashboard"] .login-card,
body[data-view="dashboard"] .launch-card,
body[data-view="dashboard"] .error-card {
  display: none;
}

body[data-view="dashboard"] .dashboard-view {
  display: grid;
}

body[data-view="profile"] .login-card,
body[data-view="profile"] .error-card,
body[data-view="profile"] .dashboard-view,
body[data-view="profile"] .attendance-list-view,
body[data-view="profile"] .attendance-view,
body[data-view="profile"] .announcements-view,
body[data-view="profile"] .announcement-compose-view {
  display: none;
}

body[data-view="profile"] .profile-view {
  display: grid;
}

body[data-view="photo-manager"] .login-card,
body[data-view="photo-manager"] .error-card,
body[data-view="photo-manager"] .dashboard-view,
body[data-view="photo-manager"] .attendance-list-view,
body[data-view="photo-manager"] .attendance-view,
body[data-view="photo-manager"] .announcements-view,
body[data-view="photo-manager"] .announcement-compose-view,
body[data-view="photo-manager"] .messages-view,
body[data-view="photo-manager"] .message-compose-view,
body[data-view="photo-manager"] .subject-detail-view,
body[data-view="photo-manager"] .subject-detail-compose-view,
body[data-view="photo-manager"] .dau-summary-view,
body[data-view="photo-manager"] .dau-summary-compose-view,
body[data-view="photo-manager"] .profile-view {
  display: none;
}

body[data-view="photo-manager"] .photo-manager-view {
  display: grid;
}

body[data-view="attendance-list"] .login-card,
body[data-view="attendance-list"] .error-card,
body[data-view="attendance-list"] .dashboard-view,
body[data-view="attendance-list"] .attendance-view {
  display: none;
}

body[data-view="attendance-list"] .attendance-list-view {
  display: grid;
}

body[data-view="announcements"] .login-card,
body[data-view="announcements"] .error-card,
body[data-view="announcements"] .dashboard-view,
body[data-view="announcements"] .attendance-list-view,
body[data-view="announcements"] .attendance-view {
  display: none;
}

body[data-view="announcements"] .announcements-view {
  display: grid;
}

body[data-view="messages"] .login-card,
body[data-view="messages"] .error-card,
body[data-view="messages"] .dashboard-view,
body[data-view="messages"] .attendance-list-view,
body[data-view="messages"] .attendance-view,
body[data-view="messages"] .announcements-view,
body[data-view="messages"] .announcement-compose-view,
body[data-view="messages"] .subject-detail-view,
body[data-view="messages"] .subject-detail-compose-view,
body[data-view="messages"] .dau-summary-view,
body[data-view="messages"] .dau-summary-compose-view,
body[data-view="messages"] .profile-view {
  display: none;
}

body[data-view="messages"] .messages-view {
  display: grid;
}

body[data-view="subject-details"] .login-card,
body[data-view="subject-details"] .error-card,
body[data-view="subject-details"] .dashboard-view,
body[data-view="subject-details"] .attendance-list-view,
body[data-view="subject-details"] .attendance-view,
body[data-view="subject-details"] .announcements-view,
body[data-view="subject-details"] .announcement-compose-view {
  display: none;
}

body[data-view="subject-details"] .subject-detail-view {
  display: grid;
}

body[data-view="dau-summaries"] .login-card,
body[data-view="dau-summaries"] .error-card,
body[data-view="dau-summaries"] .dashboard-view,
body[data-view="dau-summaries"] .attendance-list-view,
body[data-view="dau-summaries"] .attendance-view,
body[data-view="dau-summaries"] .announcements-view,
body[data-view="dau-summaries"] .announcement-compose-view,
body[data-view="dau-summaries"] .subject-detail-view,
body[data-view="dau-summaries"] .subject-detail-compose-view {
  display: none;
}

body[data-view="dau-summaries"] .dau-summary-view {
  display: grid;
}

body[data-view="announcement-compose"] .login-card,
body[data-view="announcement-compose"] .error-card,
body[data-view="announcement-compose"] .dashboard-view,
body[data-view="announcement-compose"] .attendance-list-view,
body[data-view="announcement-compose"] .attendance-view,
body[data-view="announcement-compose"] .announcements-view {
  display: none;
}

body[data-view="announcement-compose"] .announcement-compose-view {
  display: grid;
}

body[data-view="message-compose"] .login-card,
body[data-view="message-compose"] .error-card,
body[data-view="message-compose"] .dashboard-view,
body[data-view="message-compose"] .attendance-list-view,
body[data-view="message-compose"] .attendance-view,
body[data-view="message-compose"] .announcements-view,
body[data-view="message-compose"] .announcement-compose-view,
body[data-view="message-compose"] .messages-view,
body[data-view="message-compose"] .subject-detail-view,
body[data-view="message-compose"] .subject-detail-compose-view,
body[data-view="message-compose"] .dau-summary-view,
body[data-view="message-compose"] .dau-summary-compose-view,
body[data-view="message-compose"] .profile-view {
  display: none;
}

body[data-view="message-compose"] .message-compose-view {
  display: grid;
}

body[data-view="dau-summary-compose"] .login-card,
body[data-view="dau-summary-compose"] .error-card,
body[data-view="dau-summary-compose"] .dashboard-view,
body[data-view="dau-summary-compose"] .attendance-list-view,
body[data-view="dau-summary-compose"] .attendance-view,
body[data-view="dau-summary-compose"] .announcements-view,
body[data-view="dau-summary-compose"] .announcement-compose-view,
body[data-view="dau-summary-compose"] .subject-detail-view,
body[data-view="dau-summary-compose"] .subject-detail-compose-view,
body[data-view="dau-summary-compose"] .dau-summary-view {
  display: none;
}

body[data-view="dau-summary-compose"] .dau-summary-compose-view {
  display: grid;
}

body[data-view="subject-detail-compose"] .login-card,
body[data-view="subject-detail-compose"] .error-card,
body[data-view="subject-detail-compose"] .dashboard-view,
body[data-view="subject-detail-compose"] .attendance-list-view,
body[data-view="subject-detail-compose"] .attendance-view,
body[data-view="subject-detail-compose"] .announcements-view,
body[data-view="subject-detail-compose"] .announcement-compose-view,
body[data-view="subject-detail-compose"] .subject-detail-view {
  display: none;
}

body[data-view="subject-detail-compose"] .subject-detail-compose-view {
  display: grid;
}

body[data-view="attendance"] .login-card,
body[data-view="attendance"] .error-card,
body[data-view="attendance"] .dashboard-view,
body[data-view="attendance"] .attendance-list-view {
  display: none;
}

body[data-view="attendance"] .attendance-view {
  display: grid;
}

body[data-view="attendance"] .attendance-summary-view {
  display: grid;
}

body[data-view="attendance"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="time-table"] .login-card,
body[data-view="time-table"] .error-card,
body[data-view="time-table"] .dashboard-view,
body[data-view="time-table"] .profile-view,
body[data-view="time-table"] .calendar-view,
body[data-view="time-table"] .attendance-summary-view,
body[data-view="time-table"] .messages-view,
body[data-view="time-table"] .circulars-view,
body[data-view="time-table"] .policies-view,
body[data-view="time-table"] .fees-view,
body[data-view="time-table"] .transport-view,
body[data-view="time-table"] .academic-updates-view,
body[data-view="time-table"] .elearning-view {
  display: none;
}

body[data-view="time-table"] .time-table-view {
  display: grid;
}

body[data-view="time-table"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
  overflow-x: visible;
  overflow-y: visible;
}

.status {
  min-height: 20px;
  font-size: 0.9rem;
  color: var(--accent-2);
}

.status.error {
  color: var(--danger);
}

.login-form {
  display: grid;
  gap: 18px;
}

.forgot-password-form {
  display: grid;
  gap: 14px;
  margin-top: 14px;
  padding-top: 16px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.forgot-password-form[hidden] {
  display: none;
}

.forgot-password-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.forgot-password-actions .primary,
.forgot-password-actions .nav-item {
  flex: 1 1 160px;
  justify-content: center;
  margin-top: 0;
  text-align: center;
}

.login-link-btn {
  justify-self: center;
  border: 0;
  background: transparent;
  color: var(--accent);
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  padding: 4px 6px;
}

.login-link-btn:hover {
  color: var(--accent-2);
}

.password-reset-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.password-reset-modal.show {
  display: flex;
}

.password-reset-card {
  position: relative;
  width: min(460px, 94vw);
  border-radius: 20px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 22px;
  display: grid;
  gap: 16px;
  animation: fadeUp 0.3s ease-out;
}

.password-reset-header {
  display: grid;
  gap: 6px;
}

.password-reset-header h3,
.password-reset-header p {
  margin: 0;
}

.password-reset-header h3 {
  font-size: 1.2rem;
}

.password-reset-header p {
  color: var(--muted);
  line-height: 1.5;
}

.password-reset-form {
  display: grid;
  gap: 14px;
}

.change-password-form {
  display: grid;
  gap: 14px;
}

.change-password-actions {
  display: flex;
  justify-content: flex-end;
}

.password-reset-status,
.change-password-status {
  min-height: 20px;
  font-size: 0.92rem;
  color: var(--muted);
}

.password-reset-status.error,
.change-password-status.error {
  color: var(--danger);
}

.field {
  display: grid;
  gap: 10px;
  font-size: 0.95rem;
}

.field > span {
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--accent);
}

.login-field {
  gap: 0;
}

.field-input-wrap {
  position: relative;
}

.field input {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(16, 24, 26, 0.12);
  background: rgba(255, 255, 255, 0.96);
  color: var(--text);
  font-size: 1rem;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.login-field input {
  padding-right: 52px;
}

.field input::placeholder,
.field textarea::placeholder {
  color: var(--muted);
}

.field input[type="file"] {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px dashed rgba(16, 24, 26, 0.2);
  background: rgba(255, 255, 255, 0.85);
  font-size: 0.9rem;
}

.field select,
.field textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(16, 24, 26, 0.15);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  font-family: inherit;
}

.field select:focus,
.field textarea:focus {
  border-color: rgba(var(--accent-rgb), 0.42);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.14);
}

.field input:focus {
  border-color: rgba(var(--accent-rgb), 0.42);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.14);
}

.field-input-action {
  position: absolute;
  top: 50%;
  right: 12px;
  width: 32px;
  height: 32px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-50%);
  cursor: pointer;
}

.field-input-action:hover {
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.08);
}

.field-input-action svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.field-input-action .eye-closed {
  display: none;
}

.field-input-action[aria-pressed="true"] .eye-open {
  display: none;
}

.field-input-action[aria-pressed="true"] .eye-closed {
  display: block;
}

.primary {
  margin-top: 6px;
  min-height: 52px;
  padding: 12px 18px;
  border-radius: 16px;
  border: none;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fffaf3;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(var(--accent-rgb), 0.24);
}

.danger {
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(220, 38, 38, 0.4);
  background: rgba(220, 38, 38, 0.12);
  color: var(--danger);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.danger:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(220, 38, 38, 0.24);
}

.danger:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.login-card-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(23, 33, 43, 0.08);
}

.login-reset-copy {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.login-reset-btn {
  min-height: 42px;
  padding: 10px 16px;
}

@media (max-width: 800px) {
  .sidebar {
    width: 240px;
  }

  .brand {
    gap: 10px;
  }

  .logo-text {
    width: 100%;
    justify-content: center;
  }

  .content {
    padding-top: 64px;
  }

  body[data-auth="logged-in"] .content {
    padding-top: 6px;
    padding-bottom: 14px;
  }

  .login-card {
    width: min(100%, 94vw);
    padding: 28px 22px;
    gap: 18px;
  }

  .login-card h1 {
    font-size: 1.95rem;
  }

  .login-card-footer {
    display: grid;
  }

  .login-reset-btn {
    width: 100%;
  }

  .app-install-alert {
    display: none;
    width: 100%;
    padding: 12px 14px;
    margin-bottom: 12px;
    align-items: stretch;
    justify-content: stretch;
    flex-direction: column;
  }

  .app-install-alert-actions {
    width: 100%;
    justify-content: stretch;
  }

  .app-install-alert-actions .primary,
  .app-install-alert-actions .nav-item {
    width: 100%;
  }

  .announcements-view {
    padding: 18px 18px 24px;
  }

  .announcements-layout {
    grid-template-columns: 1fr;
  }

  .messages-view {
    padding: 18px 18px 24px;
  }

  .messages-layout {
    grid-template-columns: 1fr;
  }

  .subject-detail-view {
    padding: 18px 18px 24px;
  }

  .subject-detail-layout {
    grid-template-columns: 1fr;
  }

  .dau-summary-view {
    padding: 18px 18px 24px;
  }

  .dau-summary-layout {
    grid-template-columns: 1fr;
  }

  .announcement-compose-view {
    padding: 18px 18px 24px;
  }

  .message-compose-view {
    padding: 18px 18px 24px;
  }

  .subject-detail-compose-view {
    padding: 18px 18px 24px;
  }

  .dau-summary-compose-view {
    padding: 18px 18px 24px;
  }

  .attendance-header {
    flex-direction: column;
    align-items: stretch;
  }

  .attendance-meta {
    justify-items: start;
  }

  .attendance-row {
    grid-template-columns: 48px 1fr 48px;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
  }
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.dashboard-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.dashboard-grid,
.profile-grid {
  display: grid;
  gap: 14px;
}

@media (min-width: 780px) {
  .dashboard-grid,
  .profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.dashboard-card {
  border-radius: 16px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: rgba(255, 252, 246, 0.92);
  display: grid;
  gap: 12px;
}

.dashboard-card h2 {
  margin: 0;
  font-size: 1.1rem;
}

.card-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.muted {
  color: var(--muted);
  font-size: 0.85rem;
}

.children-list {
  display: grid;
  gap: 10px;
}

.achievements-list {
  display: grid;
  gap: 10px;
}

.achievement-card {
  width: 100%;
  color: inherit;
  font: inherit;
  text-align: left;
  appearance: none;
}

.achievement-card-copy {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.achievement-filters {
  display: none;
  flex-wrap: wrap;
  gap: 8px;
}

.achievement-filter {
  border: 1px solid rgba(var(--accent-rgb), 0.18);
  background: rgba(255, 255, 255, 0.74);
  color: var(--text);
  border-radius: 999px;
  padding: 7px 12px;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
}

.achievement-filter[data-active="true"] {
  background: rgba(var(--accent-rgb), 0.13);
  border-color: rgba(var(--accent-rgb), 0.34);
  color: var(--accent);
}

.child-card {
  border-radius: 12px;
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), 0.16);
  background: rgba(255, 252, 246, 0.9);
  display: grid;
  gap: 8px;
}

.child-name {
  font-weight: 600;
}

.child-meta {
  color: var(--muted);
  font-size: 0.85rem;
}

.child-details {
  display: grid;
  gap: 8px;
}

.child-detail-row {
  display: grid;
  grid-template-columns: minmax(0, 96px) minmax(0, 1fr);
  gap: 8px;
  padding-top: 8px;
  border-top: 1px dashed rgba(16, 24, 26, 0.12);
}

.child-detail-label {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.child-detail-value {
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 420px) {
  .child-detail-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 3px;
  }
}

.empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.field.checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
}

.field.checkbox input {
  width: auto;
}

.notification-body {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.notification-time {
  font-size: 0.75rem;
  color: var(--muted);
}

.nav-group {
  display: grid;
  gap: 6px;
}

.nav-section {
  display: grid;
  gap: 5px;
}

.nav-collapse {
  display: grid;
  gap: 5px;
}

.nav-collapse > summary {
  list-style: none;
}

.nav-collapse > summary::-webkit-details-marker {
  display: none;
}

.sidebar .nav-group-trigger {
  width: 100%;
  user-select: none;
}

.nav-group-label {
  flex: 1;
  min-width: 0;
}

.nav-chevron {
  width: 8px;
  height: 8px;
  margin-left: auto;
  border-right: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}

.nav-collapse[open] .nav-chevron {
  transform: rotate(225deg);
}

.nav-group-items {
  display: grid;
  gap: 5px;
  padding-left: 12px;
}

.nav-group-items .nav-item {
  width: 100%;
}

.nav-section-title {
  padding: 4px 8px 0;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.nav-divider {
  height: 1px;
  background: rgba(15, 23, 42, 0.08);
  margin: 4px 0 2px;
}

.nav-item.is-active {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.18));
  border-color: rgba(var(--accent-rgb), 0.28);
  box-shadow: 0 12px 28px rgba(23, 33, 43, 0.12);
}

.nav-collapse.is-active > .nav-group-trigger {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.1), rgba(var(--accent-2-rgb), 0.14));
  border-color: rgba(var(--accent-rgb), 0.24);
}

.calendar-view {
  display: none;
  width: 100%;
  max-width: 900px;
  gap: 6px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.calendar-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 6px;
}

.calendar-header h1 {
  margin: 0;
  font-size: 1.32rem;
}

.calendar-copy {
  margin: 0;
  color: var(--muted);
  font-family: "Source Serif 4", serif;
  font-size: 0.88rem;
  line-height: 1.25;
}

.calendar-refresh {
  white-space: nowrap;
}

.calendar-status {
  min-height: 0;
  font-size: 0.9rem;
  color: var(--accent);
}

.calendar-status:empty {
  display: none;
}

.calendar-status.error {
  color: var(--danger);
}

.calendar-toolbar {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
}

.calendar-month-switcher {
  width: min(100%, 380px);
  min-height: 36px;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) 30px;
  align-items: center;
  gap: 6px;
  padding: 3px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 13px;
  background: rgba(255, 252, 246, 0.92);
  box-shadow: 0 6px 14px rgba(23, 33, 43, 0.06);
}

.calendar-month-label {
  margin: 0;
  min-width: 0;
  font-size: 0.98rem;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-nav-btn {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(var(--accent-rgb), 0.18);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--accent);
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(23, 33, 43, 0.06);
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease,
    background 0.2s ease;
}

.calendar-nav-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(var(--accent-rgb), 0.32);
  background: rgba(var(--accent-rgb), 0.08);
  box-shadow: 0 8px 16px rgba(23, 33, 43, 0.09);
}

.calendar-nav-btn .button-icon {
  width: 15px;
  height: 15px;
}

.calendar-weekdays,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.calendar-grid,
.attendance-calendar-grid {
  touch-action: pan-y;
}

.calendar-weekday {
  padding: 0 2px;
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.calendar-cell {
  position: relative;
  min-height: 50px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 5px;
  display: grid;
  align-content: start;
  justify-items: start;
  gap: 0;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.calendar-cell:hover {
  transform: translateY(-1px);
  border-color: rgba(var(--accent-rgb), 0.24);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.calendar-cell.is-outside-month {
  opacity: 0.48;
  background: rgba(255, 252, 246, 0.7);
}

.calendar-cell.is-selected {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: 0 0 0 2px rgba(var(--accent-rgb), 0.12);
  background: linear-gradient(160deg, rgba(var(--accent-rgb), 0.08), rgba(255, 255, 255, 0.98));
}

.calendar-cell-number {
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
}

.calendar-cell.is-today .calendar-cell-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  min-height: 20px;
  padding: 2px 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fffaf3;
  box-shadow: 0 8px 18px rgba(var(--accent-rgb), 0.24);
}

.calendar-cell-markers {
  position: absolute;
  left: 6px;
  bottom: 5px;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
}

.calendar-cell-marker {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--calendar-marker, var(--accent));
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9);
}

.calendar-cell-count {
  position: absolute;
  right: 6px;
  bottom: 2px;
  font-size: 0.64rem;
  color: var(--muted);
  font-weight: 600;
}

.calendar-day-header {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.calendar-day-title {
  margin: 0;
  font-size: 1.12rem;
}

.calendar-day-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.84rem;
  font-weight: 700;
}

.calendar-day-events {
  display: grid;
  gap: 12px;
}

.calendar-agenda-card {
  justify-items: stretch;
}

.calendar-day-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 67;
}

.calendar-day-modal.show {
  display: flex;
}

.calendar-day-modal-card {
  position: relative;
  width: min(640px, 94vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 18px 18px 22px;
  display: grid;
  gap: 12px;
  animation: fadeUp 0.3s ease-out;
}

.calendar-day-modal-content {
  display: grid;
  gap: 12px;
}

.calendar-summary-grid {
  display: grid;
  gap: 12px;
}

@media (min-width: 720px) {
  .calendar-summary-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.calendar-summary-card {
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.98), rgba(240, 234, 226, 0.9));
  padding: 16px;
  display: grid;
  gap: 6px;
}

.calendar-summary-label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.calendar-summary-value {
  font-size: 1.3rem;
}

.calendar-month-filters {
  display: none;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: thin;
}

.calendar-filter {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.88);
  color: var(--muted);
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease,
    background 0.2s ease;
}

.calendar-filter.is-active {
  color: var(--text);
  border-color: rgba(var(--accent-rgb), 0.28);
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.16));
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
}

.calendar-list {
  display: grid;
  gap: 14px;
}

.calendar-date-group {
  display: grid;
  gap: 12px;
}

.calendar-date-header {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.calendar-date-weekday {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.calendar-date-title {
  font-size: 1rem;
}

.calendar-date-events {
  display: grid;
  gap: 12px;
}

.calendar-event-card {
  --calendar-accent: var(--accent);
  --calendar-accent-soft: rgba(var(--accent-rgb), 0.12);
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(160deg, var(--calendar-accent-soft), rgba(255, 255, 255, 0.96));
  padding: 16px;
  display: grid;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.calendar-event-card:hover {
  transform: translateY(-1px);
  border-color: var(--calendar-accent);
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.12);
}

.attendance-summary-view {
  display: none;
  width: 100%;
  max-width: 960px;
  gap: 14px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.attendance-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.attendance-header h1 {
  margin: 0;
  font-size: 1.32rem;
}

.attendance-subtitle {
  margin: 4px 0 0;
  color: var(--muted);
  font-family: "Source Serif 4", serif;
  font-size: 0.88rem;
}

.attendance-status {
  min-height: 0;
  font-size: 0.9rem;
  color: var(--accent);
}

.attendance-status:empty {
  display: none;
}

.attendance-status.error {
  color: var(--danger);
}

.attendance-student-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.attendance-student-tab {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--muted);
  padding: 9px 13px;
  font-size: 0.9rem;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}

.attendance-student-tab[aria-pressed="true"] {
  color: var(--text);
  border-color: rgba(var(--accent-rgb), 0.28);
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.16));
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
}

.attendance-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

@media (min-width: 720px) {
  .attendance-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.attendance-metric-card,
.attendance-calendar-panel {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.96);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07);
}

.attendance-metric-card {
  border-radius: 14px;
  padding: 10px;
  display: grid;
  gap: 3px;
}

.attendance-metric-card--primary {
  background: linear-gradient(160deg, rgba(var(--accent-rgb), 0.12), rgba(255, 255, 255, 0.96));
}

.attendance-metric-card--absent {
  background: linear-gradient(160deg, rgba(216, 75, 75, 0.12), rgba(255, 255, 255, 0.96));
}

.attendance-metric-label {
  color: var(--muted);
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.attendance-metric-value {
  font-size: 1.12rem;
  line-height: 1.1;
}

.attendance-metric-meta {
  color: var(--muted);
  font-size: 0.68rem;
  line-height: 1.18;
}

.attendance-section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.attendance-section-heading h2 {
  margin: 0;
  font-size: 1rem;
}

.attendance-calendar-panel {
  border-radius: 20px;
  padding: 14px;
  display: grid;
  gap: 12px;
}

.attendance-calendar-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

@media (min-width: 640px) {
  .attendance-calendar-summary {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.attendance-calendar-summary-item {
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: var(--muted);
  padding: 6px 8px;
  font-size: 0.72rem;
  font-weight: 800;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.attendance-calendar-summary-item--primary {
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.attendance-calendar-summary-item--present {
  background: rgba(5, 150, 105, 0.12);
  color: #047857;
}

.attendance-calendar-summary-item--absent {
  background: rgba(216, 75, 75, 0.12);
  color: var(--danger);
}

.attendance-calendar-weekdays,
.attendance-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.attendance-calendar-weekday {
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.attendance-calendar-cell {
  position: relative;
  min-height: 54px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.9);
  padding: 6px;
  display: grid;
  align-content: start;
  gap: 5px;
}

.attendance-calendar-cell.is-outside-month {
  opacity: 0.46;
  background: rgba(255, 252, 246, 0.68);
}

.attendance-calendar-cell.is-today .attendance-calendar-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.14);
  color: var(--accent);
}

.attendance-calendar-cell.is-absent {
  border-color: rgba(216, 75, 75, 0.35);
  background: linear-gradient(160deg, rgba(216, 75, 75, 0.14), rgba(255, 255, 255, 0.95));
}

.attendance-calendar-cell.is-present {
  border-color: rgba(5, 150, 105, 0.32);
  background: linear-gradient(160deg, rgba(5, 150, 105, 0.12), rgba(255, 255, 255, 0.95));
}

.attendance-calendar-cell.is-other {
  border-color: rgba(var(--accent-rgb), 0.32);
  background: linear-gradient(160deg, rgba(var(--accent-rgb), 0.12), rgba(255, 255, 255, 0.95));
}

.attendance-calendar-number {
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
}

.attendance-calendar-absent-badge,
.attendance-calendar-status-badge {
  width: fit-content;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  border-radius: 999px;
  padding: 3px 6px;
  font-size: 0.62rem;
  font-weight: 800;
  white-space: nowrap;
}

.attendance-calendar-absent-badge,
.attendance-calendar-status-badge--absent {
  background: rgba(216, 75, 75, 0.14);
  color: var(--danger);
}

.attendance-calendar-status-badge--present {
  background: rgba(5, 150, 105, 0.13);
  color: #047857;
}

.attendance-calendar-status-badge--other {
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.calendar-event-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.calendar-event-title-wrap {
  display: grid;
  gap: 8px;
}

.calendar-event-kind {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--calendar-accent);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.calendar-event-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

.calendar-event-when {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 600;
}

.calendar-event-meta {
  color: var(--muted);
  font-size: 0.88rem;
}

.calendar-event-body {
  margin: 0;
  color: var(--text);
  font-size: 0.94rem;
  line-height: 1.55;
}

.calendar-upcoming {
  display: grid;
  gap: 6px;
  margin-top: 2px;
  padding: 8px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  background: rgba(255, 252, 246, 0.9);
}

.calendar-upcoming-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.calendar-upcoming-header h2 {
  margin: 0;
  font-size: 0.88rem;
}

.calendar-upcoming-header span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.1);
  color: var(--accent);
  font-size: 0.7rem;
  font-weight: 700;
  white-space: nowrap;
}

.calendar-upcoming-list {
  display: grid;
  gap: 5px;
}

.calendar-upcoming-card {
  border-left: 4px solid var(--calendar-accent);
  border-radius: 10px;
  padding: 7px 9px;
  gap: 0;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: none;
}

.calendar-upcoming-card:hover {
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
}

.calendar-upcoming-card .calendar-event-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.calendar-upcoming-card .calendar-event-title-wrap {
  min-width: 0;
  gap: 0;
}

.calendar-upcoming-card h3 {
  min-width: 0;
  font-size: 0.86rem;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.calendar-upcoming-card .calendar-event-when {
  min-height: 0;
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  font-size: 0.74rem;
  white-space: nowrap;
}

.calendar-upcoming-empty {
  padding: 4px 0 0;
}

.calendar-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 68;
}

.calendar-modal.show {
  display: flex;
}

.calendar-modal-card {
  position: relative;
  width: min(680px, 94vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 18px 18px 22px;
  display: grid;
  gap: 12px;
  animation: fadeUp 0.3s ease-out;
}

.calendar-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.calendar-modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.calendar-detail {
  border-radius: 16px;
  border: 1px dashed rgba(var(--accent-rgb), 0.28);
  padding: 14px;
  background: rgba(255, 252, 246, 0.75);
  display: grid;
  gap: 10px;
}

.calendar-detail-empty {
  font-size: 0.92rem;
  color: var(--muted);
}

.calendar-detail-body {
  --calendar-accent: var(--accent);
  --calendar-accent-soft: rgba(var(--accent-rgb), 0.12);
  display: none;
  gap: 12px;
  border-radius: 16px;
  padding: 4px;
}

.calendar-detail-body.show {
  display: grid;
}

.calendar-detail-top h3 {
  margin: 0 0 6px;
  font-size: 1.15rem;
}

.calendar-detail-when {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.calendar-detail-meta {
  color: var(--calendar-accent);
  font-size: 0.9rem;
  font-weight: 600;
}

.calendar-detail-text {
  padding: 14px;
  border-radius: 16px;
  background: linear-gradient(160deg, var(--calendar-accent-soft), rgba(255, 255, 255, 0.96));
  color: var(--text);
  line-height: 1.65;
  white-space: pre-wrap;
}

.messages-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 14px;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
  box-shadow: none;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.messages-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.messages-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.messages-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.messages-status {
  font-size: 0.9rem;
  color: var(--accent);
}

.messages-status:empty {
  display: none;
}

.messages-status.error {
  color: var(--danger);
}

.messages-availability-card {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 0;
}

.messages-availability-card strong {
  font-size: 0.88rem;
}

.messages-availability-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.messages-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  width: 100%;
}

.messages-tab {
  border: none;
  background: transparent;
  color: var(--muted);
  border-radius: 14px;
  padding: 10px 14px;
  font-size: 0.92rem;
  font-weight: 600;
  cursor: pointer;
}

.messages-tab[aria-selected="true"] {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.18));
  color: var(--text);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.22);
}

.messages-layout {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  gap: 16px;
}

body[data-view="messages"][data-messages-pane="detail"] .messages-layout {
  align-items: stretch;
  min-height: calc(100dvh - 96px);
}

.messages-list-panel,
.messages-detail-panel {
  display: grid;
  gap: 12px;
  min-width: 0;
}

body[data-view="messages"][data-messages-pane="list"] .messages-detail-panel {
  display: none;
}

body[data-view="messages"][data-messages-pane="detail"] .messages-list-panel {
  display: none;
}

body[data-view="messages"][data-messages-pane="list"] .messages-list-panel {
  animation: messagesPaneEnterLeft 0.28s ease both;
}

body[data-view="messages"][data-messages-pane="detail"] .messages-header,
body[data-view="messages"][data-messages-pane="detail"] .messages-status,
body[data-view="messages"][data-messages-pane="detail"] .messages-tabs,
body[data-view="messages"][data-messages-pane="detail"] .messages-availability-card {
  display: none;
}

body[data-view="messages"][data-messages-pane="detail"] .messages-detail-panel {
  min-height: inherit;
  height: 100%;
  animation: messagesPaneEnterRight 0.3s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.messages-thread-list {
  display: grid;
  gap: 10px;
}

.messages-thread-card {
  width: 100%;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.07);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(255, 255, 255, 0.98));
  padding: 12px 14px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.messages-thread-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  border-color: rgba(var(--accent-rgb), 0.28);
}

.messages-thread-card.is-active {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.1);
  background: linear-gradient(160deg, rgba(240, 234, 226, 0.9), rgba(255, 255, 255, 0.98));
}

.messages-thread-avatar {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.18), rgba(var(--accent-2-rgb), 0.2));
  color: var(--accent);
  font-size: 0.9rem;
  font-weight: 800;
}

.messages-thread-content {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.messages-thread-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
}

.messages-thread-top h3 {
  margin: 0;
  font-size: 1.02rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messages-thread-top p,
.messages-thread-preview,
.messages-thread-meta,
.messages-conversation-empty,
.messages-conversation-closed,
.messages-detail-meta,
.messages-reply-hint,
.messages-compose-hint {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.messages-thread-preview {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messages-thread-meta {
  font-size: 0.78rem;
}

.messages-thread-pill,
.messages-thread-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.84rem;
  font-weight: 700;
  white-space: nowrap;
}

.messages-thread-status.closed {
  background: rgba(100, 116, 139, 0.12);
  color: #475569;
}

.messages-detail-empty {
  padding: 4px 0;
  color: var(--muted);
}

.messages-detail-card {
  display: none;
  gap: 14px;
  padding: 0;
}

.messages-detail-card.show {
  display: grid;
  min-height: inherit;
  height: 100%;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.messages-detail-heading {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.messages-detail-back {
  display: inline-flex;
  width: auto;
  min-height: 30px;
  padding: 6px 10px;
  justify-self: end;
  flex-shrink: 0;
  font-size: 0.8rem;
  line-height: 1;
}

.academic-update-back,
.elearning-back {
  display: inline-flex;
  width: auto;
  min-height: 30px;
  padding: 6px 10px;
  justify-self: end;
  flex-shrink: 0;
  font-size: 0.8rem;
  line-height: 1;
}

.messages-detail-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  padding-left: 44px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.messages-detail-header h2 {
  margin: 0 0 4px;
  font-size: 1.15rem;
  overflow-wrap: anywhere;
}

.messages-bubble-file {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(var(--accent-rgb), 0.22);
  color: var(--accent);
  text-decoration: none;
  background: rgba(255, 252, 246, 0.8);
  font-size: 0.84rem;
  font-weight: 600;
}

.messages-conversation {
  display: grid;
  gap: 12px;
  align-content: end;
  min-height: 0;
  overflow: auto;
  padding: 16px 12px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.035) 25%, transparent 25%) 0 0 / 26px 26px,
    linear-gradient(225deg, rgba(15, 23, 42, 0.03) 25%, transparent 25%) 0 0 / 26px 26px,
    linear-gradient(180deg, rgba(242, 248, 242, 0.96), rgba(232, 241, 234, 0.86));
}

.messages-bubble-row {
  display: grid;
  gap: 6px;
  justify-items: start;
}

.messages-bubble-row.is-mine {
  justify-items: end;
}

.messages-bubble-meta {
  font-size: 0.76rem;
  color: var(--muted);
  text-align: right;
}

.messages-bubble {
  max-width: min(100%, 560px);
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 18px 18px 18px 6px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
  position: relative;
}

.messages-bubble-row.is-mine .messages-bubble {
  border-radius: 18px 18px 6px 18px;
  background: linear-gradient(160deg, rgba(220, 248, 198, 0.96), rgba(235, 255, 222, 0.98));
}

.messages-bubble::before {
  content: "";
  position: absolute;
  left: -6px;
  bottom: 0;
  width: 12px;
  height: 14px;
  background: inherit;
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

.messages-bubble-row.is-mine .messages-bubble::before {
  left: auto;
  right: -6px;
  clip-path: polygon(0 0, 100% 100%, 0 100%);
}

.messages-bubble-text {
  margin: 0;
  line-height: 1.6;
  white-space: pre-wrap;
}

.messages-reply-form {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  background: rgba(255, 252, 246, 0.96);
  position: sticky;
  bottom: 0;
  z-index: 5;
  box-shadow: 0 -12px 28px rgba(15, 23, 42, 0.08);
}

.messages-reply-composer {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.messages-reply-form.has-send .messages-reply-composer {
  grid-template-columns: 46px minmax(0, 1fr) 46px;
}

.messages-reply-body-field {
  gap: 0;
}

.messages-reply-body-field > span {
  display: none;
}

.messages-reply-body-field textarea {
  min-height: 44px;
  max-height: 104px;
  resize: vertical;
  border-radius: 22px;
  padding: 11px 14px;
}

.messages-attach-button,
.messages-reply-send {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  border-radius: 999px;
  cursor: pointer;
}

.messages-attach-button {
  border: 1px solid rgba(var(--accent-rgb), 0.16);
  background: rgba(255, 255, 255, 0.9);
  color: var(--muted);
  transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.messages-attach-button:hover {
  transform: translateY(-1px);
  border-color: rgba(var(--accent-rgb), 0.32);
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.08);
}

.messages-reply-file-input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.messages-composer-icon {
  width: 20px;
  height: 20px;
}

.messages-reply-send {
  padding: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.messages-reply-send[hidden] {
  display: none;
}

.messages-reply-meta-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 10px;
}

.messages-reply-file-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--muted);
  font-size: 0.8rem;
}

.messages-reply-actions,
.messages-compose-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.messages-reply-actions {
  justify-content: center;
}

.messages-end-thread {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 14px;
  border: 1px solid rgba(191, 74, 58, 0.24);
  border-radius: 14px;
  background: rgba(191, 74, 58, 0.1);
  color: #9f2f22;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: none;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.messages-end-thread:hover {
  transform: translateY(-1px);
  border-color: rgba(191, 74, 58, 0.34);
  background: rgba(191, 74, 58, 0.16);
}

.messages-reply-hint.error,
.messages-compose-hint.error {
  color: var(--danger);
}

.messages-compose-hint:empty {
  display: none;
}

@keyframes messagesPaneEnterRight {
  from {
    opacity: 0;
    transform: translateX(22px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes messagesPaneEnterLeft {
  from {
    opacity: 0;
    transform: translateX(-16px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.messages-compose-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 69;
}

.messages-compose-modal.show {
  display: flex;
}

.messages-compose-card {
  position: relative;
  width: min(640px, 94vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: var(--surface-strong);
  box-shadow: 0 30px 60px rgba(15, 23, 42, 0.28);
  padding: 20px;
  display: grid;
  gap: 16px;
  animation: fadeUp 0.3s ease-out;
}

.messages-compose-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.messages-compose-header h3 {
  margin: 0;
  font-size: 1.15rem;
}

.messages-compose-form {
  display: grid;
  gap: 14px;
}

.circulars-view,
.policies-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 10px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.circulars-header,
.policies-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.circulars-header h1,
.policies-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.circulars-status,
.policies-status {
  font-size: 0.9rem;
  color: var(--accent);
}

.circulars-status:empty,
.policies-status:empty {
  display: none;
}

.circulars-status.error,
.policies-status.error {
  color: var(--danger);
}

.circulars-list,
.policies-list {
  display: grid;
  gap: 12px;
}

.circular-card {
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: rgba(255, 253, 248, 0.96);
  padding: 14px;
  display: grid;
  gap: 8px;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.circular-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  border-color: rgba(var(--accent-rgb), 0.28);
}

.circular-card:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}

.circular-card:disabled:hover {
  transform: none;
  box-shadow: none;
  border-color: rgba(15, 23, 42, 0.1);
}

.circular-card-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.circular-card h3 {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 500;
  line-height: 1.3;
}

.circular-card-date {
  width: fit-content;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.08);
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 500;
  padding: 4px 9px;
  white-space: nowrap;
}

.circular-card-meta {
  color: var(--muted);
  font-size: 0.84rem;
}

.circular-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 65;
}

.circular-modal.show {
  display: flex;
}

.circular-modal-card {
  position: relative;
  width: min(720px, 94vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.25);
  padding: 18px 18px 22px;
  display: grid;
  gap: 12px;
  animation: fadeUp 0.3s ease-out;
}

.circular-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.circular-modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.circular-detail {
  display: grid;
  gap: 10px;
}

.circular-detail-empty {
  font-size: 0.92rem;
  color: var(--muted);
}

.circular-detail-body {
  display: none;
  gap: 10px;
}

.circular-detail-body.show {
  display: grid;
}

.circular-detail-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.circular-detail-date {
  margin: 0;
  color: var(--muted);
  font-size: 0.85rem;
}

.circular-detail-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.85rem;
  font-weight: 700;
}

.circular-detail-meta {
  color: var(--accent);
  font-size: 0.88rem;
}

.circular-detail-meta:empty {
  display: none;
}

.circular-detail-text {
  color: var(--text);
  font-size: 0.96rem;
  line-height: 1.6;
}

.rendered-html {
  min-width: 0;
  overflow-wrap: anywhere;
}

.rendered-html p {
  margin-top: 0;
}

.rendered-html img,
.rendered-html iframe {
  max-width: 100%;
}

.rendered-html-table-wrap {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 10px 0 14px;
  overflow-x: auto;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 10px;
  background: rgba(255, 253, 248, 0.84);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(var(--accent-rgb), 0.28) transparent;
}

.rendered-html-table-wrap::after {
  content: "";
  position: sticky;
  right: 0;
  display: block;
  width: 30px;
  height: 1px;
  margin-top: -1px;
  margin-left: auto;
  pointer-events: none;
  box-shadow: -18px 0 22px rgba(255, 253, 248, 0.9);
}

.rendered-html-table-wrap table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  table-layout: auto;
  font-size: 0.78rem;
  line-height: 1.35;
}

.rendered-html-table-wrap th,
.rendered-html-table-wrap td {
  min-width: 84px;
  max-width: 180px;
  padding: 7px 8px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  vertical-align: top;
  white-space: normal;
  overflow-wrap: anywhere;
}

.rendered-html-table-wrap th {
  background: rgba(var(--accent-rgb), 0.08);
  color: var(--accent);
  font-weight: 600;
}

.circular-detail-files {
  display: grid;
  gap: 8px;
}

.circular-detail-files a {
  color: var(--accent);
  text-decoration: none;
  font-size: 0.88rem;
}

.fees-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.fees-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.fees-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.fees-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.fees-status:empty {
  display: none;
}

.fees-status.error {
  color: var(--danger);
}

.fees-tabs {
  display: inline-grid;
  grid-auto-flow: column;
  gap: 8px;
  padding: 6px;
  border-radius: 18px;
  background: rgba(255, 252, 246, 0.82);
  border: 1px solid rgba(15, 23, 42, 0.08);
  width: fit-content;
  max-width: 100%;
}

.fees-tab {
  border: none;
  background: transparent;
  color: var(--muted);
  border-radius: 14px;
  padding: 10px 14px;
  font-size: 0.92rem;
  font-weight: 600;
  cursor: pointer;
}

.fees-tab[aria-selected="true"] {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.18));
  color: var(--text);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.22);
}

.fees-return-card {
  display: none;
  gap: 14px;
  border-radius: 18px;
  border: 1px solid rgba(var(--accent-2-rgb), 0.22);
  background: linear-gradient(160deg, rgba(247, 240, 233, 0.94), rgba(255, 255, 255, 0.92));
  padding: 16px;
}

.fees-return-card.show {
  display: grid;
}

.fees-return-card h2 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.fees-return-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.fees-return-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.fees-due-panel,
.fees-transactions-panel {
  display: none;
}

body[data-fees-tab="due"] .fees-due-panel,
body[data-fees-tab="transactions"] .fees-transactions-panel {
  display: block;
}

.fees-student-groups,
.fees-transactions-list {
  display: grid;
  gap: 14px;
}

.fees-student-card,
.fees-transaction-card {
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 16px;
  display: grid;
  gap: 14px;
}

.fees-student-header,
.fees-transaction-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.fees-student-title h2,
.fees-transaction-header h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.fees-student-title p,
.fees-transaction-header p,
.fees-receipt-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.fees-total-pill,
.fees-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.88rem;
  font-weight: 700;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.fees-installment-list,
.fees-receipt-list {
  display: grid;
  gap: 10px;
}

.fees-installment-card,
.fees-receipt-card {
  display: grid;
  gap: 12px;
  border-radius: 16px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(250, 247, 241, 0.88);
}

.fees-installment-card {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  cursor: pointer;
}

.fees-installment-card input {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.fees-installment-details {
  display: grid;
  gap: 8px;
}

.fees-installment-top {
  display: flex;
  gap: 12px;
  align-items: baseline;
  justify-content: space-between;
}

.fees-installment-top strong,
.fees-receipt-card strong {
  font-size: 0.98rem;
}

.fees-installment-amount,
.fees-transaction-total strong {
  font-weight: 700;
  font-size: 0.96rem;
}

.fees-installment-meta {
  color: var(--muted);
  font-size: 0.88rem;
}

.fees-late-pill {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(var(--accent-2-rgb), 0.12);
  color: var(--accent-2);
  font-size: 0.78rem;
  font-weight: 600;
}

.fees-student-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.fees-selected-copy,
.fees-transaction-empty,
.fees-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.fees-transaction-total {
  display: grid;
  justify-items: end;
  gap: 6px;
}

.fees-receipt-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.document-requests-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.document-requests-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.document-requests-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.document-requests-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.document-requests-status:empty {
  display: none;
}

.document-requests-status.error {
  color: var(--danger);
}

.document-request-return-card {
  display: none;
  gap: 14px;
  border-radius: 18px;
  border: 1px solid rgba(var(--accent-2-rgb), 0.22);
  background: linear-gradient(160deg, rgba(247, 240, 233, 0.94), rgba(255, 255, 255, 0.92));
  padding: 16px;
}

.document-request-return-card.show {
  display: grid;
}

.document-request-return-card h2 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.document-request-return-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.document-request-return-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.document-requests-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.document-request-form,
.document-request-card {
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 16px;
}

.document-request-form {
  display: grid;
  gap: 12px;
}

.document-request-form h2 {
  margin: 0;
  font-size: 1.05rem;
}

.document-request-form textarea {
  resize: vertical;
}

.document-request-form-actions {
  display: flex;
  justify-content: flex-end;
}

.document-requests-list,
.document-requests-list-panel {
  display: grid;
  gap: 14px;
}

.document-request-card {
  display: grid;
  gap: 12px;
}

.document-request-card-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.document-request-card h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.document-request-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.document-request-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.document-request-status-pill.requested,
.document-request-status-pill.issued,
.document-request-status-pill.delivered {
  background: rgba(var(--accent-2-rgb), 0.16);
  color: var(--accent-2);
}

.document-request-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.document-request-fields > div {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(250, 247, 241, 0.88);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.document-request-fields span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.document-request-fields strong {
  color: var(--text);
  font-size: 0.92rem;
  overflow-wrap: anywhere;
}

.document-requests-empty {
  padding: 14px 0;
}

.leave-notifications-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.leave-notifications-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.leave-notifications-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.leave-notifications-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.leave-notifications-status:empty {
  display: none;
}

.leave-notifications-status.error {
  color: var(--danger);
}

.leave-notifications-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.leave-notifications-layout.is-list-only {
  grid-template-columns: 1fr;
}

.leave-notification-form,
.leave-notification-card {
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 16px;
}

.leave-notification-form {
  display: grid;
  gap: 12px;
}

.leave-notification-form[hidden] {
  display: none;
}

.leave-notification-form h2 {
  margin: 0;
  font-size: 1.05rem;
}

.leave-notification-date-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.leave-notification-form textarea {
  resize: vertical;
}

.leave-notification-form-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.leave-notification-form-actions .nav-item {
  display: none;
}

.leave-notifications-list,
.leave-notifications-list-panel {
  display: grid;
  gap: 14px;
}

.leave-notification-card {
  display: grid;
  gap: 12px;
}

.leave-notification-card-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.leave-notification-card h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.leave-notification-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.leave-notification-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.leave-notification-status-pill.approved {
  background: rgba(var(--accent-2-rgb), 0.16);
  color: var(--accent-2);
}

.leave-notification-status-pill.rejected {
  background: rgba(var(--danger-rgb), 0.12);
  color: var(--danger);
}

.leave-notification-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.leave-notification-fields > div {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(250, 247, 241, 0.88);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.leave-notification-fields span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.leave-notification-fields strong {
  color: var(--text);
  font-size: 0.92rem;
  overflow-wrap: anywhere;
}

.leave-notification-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.leave-notifications-empty {
  padding: 14px 0;
}

@media (max-width: 800px) {
  .document-requests-layout,
  .leave-notifications-layout,
  .leave-notification-date-grid {
    grid-template-columns: 1fr;
  }

  .document-request-form-actions .primary,
  .document-request-return-actions .primary,
  .document-request-return-actions .nav-item,
  .leave-notification-form-actions .primary,
  .leave-notification-form-actions .nav-item {
    width: 100%;
  }
}

.referrals-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.referrals-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.referrals-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.referrals-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.referrals-status:empty {
  display: none;
}

.referrals-status.error {
  color: var(--danger);
}

.referrals-blocker,
.referrals-form,
.referrals-share-card,
.referral-card {
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 16px;
}

.referrals-blocker {
  display: none;
  gap: 6px;
  border-color: rgba(var(--accent-2-rgb), 0.2);
  background: rgba(var(--accent-2-rgb), 0.08);
}

.referrals-blocker.show {
  display: grid;
}

.referrals-blocker p,
.referrals-share-card p,
.referral-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.5;
}

.referrals-form {
  display: grid;
  gap: 14px;
}

.referrals-form[hidden],
.referrals-share-card[hidden] {
  display: none;
}

.referrals-form .field[hidden] {
  display: none;
}

.referrals-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.referrals-email-field {
  grid-column: 1 / -1;
}

.referrals-share-card {
  display: none;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border-color: rgba(var(--accent-rgb), 0.18);
  background: linear-gradient(160deg, rgba(var(--accent-rgb), 0.08), rgba(255, 255, 255, 0.92));
}

.referrals-share-card.show {
  display: grid;
}

.referrals-eyebrow {
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
}

.referrals-share-card h2,
.referral-card h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.referrals-list {
  display: grid;
  gap: 12px;
}

.referral-card {
  display: grid;
  gap: 12px;
}

.referral-card-top,
.referrals-card-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.referral-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 700;
}

.referral-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 0.86rem;
}

.referrals-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.payment-handoff-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 70;
}

.payment-handoff-modal.show {
  display: flex;
}

.payment-handoff-card {
  position: relative;
  width: min(520px, 94vw);
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: var(--surface-strong);
  box-shadow: 0 30px 60px rgba(15, 23, 42, 0.28);
  padding: 20px;
  display: grid;
  gap: 16px;
  animation: fadeUp 0.3s ease-out;
}

.payment-handoff-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.payment-handoff-header h3 {
  margin: 0;
  font-size: 1.15rem;
}

.payment-handoff-copy {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.payment-handoff-summary {
  display: grid;
  gap: 4px;
  border-radius: 18px;
  padding: 16px;
  background: linear-gradient(160deg, rgba(var(--accent-rgb), 0.08), rgba(var(--accent-2-rgb), 0.12));
}

.payment-handoff-summary strong {
  font-size: 1.35rem;
}

.payment-handoff-summary span {
  color: var(--muted);
}

.payment-handoff-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.payment-handoff-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.transport-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 12px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.transport-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.transport-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.transport-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.transport-status:empty {
  display: none;
}

.transport-status.error {
  color: var(--danger);
}

.transport-route-groups {
  display: grid;
  gap: 14px;
}

.transport-route-top,
.transport-route-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.transport-route-card {
  display: grid;
  gap: 14px;
  border-radius: 18px;
  padding: 16px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
}

.transport-route-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.transport-route-title strong {
  font-size: 0.98rem;
}

.transport-route-meta-actions {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-left: auto;
}

.transport-route-actions {
  margin-left: 0;
}

.transport-route-actions .primary {
  min-height: 34px;
  padding: 8px 14px;
}

.transport-direction-pill,
.transport-route-unavailable {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
}

.transport-direction-pill {
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
}

.transport-route-unavailable {
  background: rgba(15, 23, 42, 0.06);
  color: var(--muted);
}

.transport-route-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.transport-route-field {
  display: grid;
  gap: 3px;
  min-width: 0;
  border-radius: 14px;
  padding: 10px;
  background: rgba(250, 247, 241, 0.88);
}

.transport-route-field span {
  color: var(--muted);
  font-size: 0.76rem;
}

.transport-route-field strong {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 0.9rem;
}

.transport-empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.academic-updates-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 14px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.academic-updates-list-pane,
.academic-updates-detail-pane {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

body[data-view="academic-updates"][data-academic-updates-pane="list"] .academic-updates-detail-pane {
  display: none;
}

body[data-view="academic-updates"][data-academic-updates-pane="detail"] .academic-updates-list-pane {
  display: none;
}

body[data-view="academic-updates"][data-academic-updates-pane="list"] .academic-updates-list-pane {
  animation: messagesPaneEnterLeft 0.28s ease both;
}

body[data-view="academic-updates"][data-academic-updates-pane="detail"] .academic-updates-detail-pane {
  animation: messagesPaneEnterRight 0.3s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.academic-updates-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.academic-updates-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.academic-updates-status,
.academic-update-detail-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.academic-updates-status:empty,
.academic-update-detail-status:empty {
  display: none;
}

.academic-updates-status.error,
.academic-update-detail-status.error {
  color: var(--danger);
}

.academic-updates-search {
  width: min(420px, 100%);
  min-height: 48px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  color: var(--text);
  font: inherit;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.academic-updates-search::placeholder {
  color: var(--muted);
}

.academic-updates-search:focus {
  outline: none;
  border-color: rgba(var(--accent-rgb), 0.26);
  box-shadow: 0 0 0 4px rgba(var(--accent-rgb), 0.08);
}

.academic-updates-list {
  display: grid;
  gap: 12px;
}

.academic-update-card {
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 16px;
  display: grid;
  gap: 8px;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.academic-update-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  border-color: rgba(var(--accent-rgb), 0.28);
}

.academic-update-card.is-active {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.1);
}

.academic-update-card h3 {
  margin: 0;
  font-size: 1.04rem;
}

.academic-update-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.academic-update-card-clip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--accent);
  flex-shrink: 0;
}

.academic-update-card-clip svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.academic-update-card-date,
.academic-update-detail-meta,
.academic-update-subject-empty {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.academic-update-card-subjects {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.academic-update-card-subject {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), 0.1);
  color: var(--accent);
  font-size: 0.8rem;
  font-weight: 600;
}

.academic-update-detail-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
}

.academic-update-back {
  margin-left: auto;
}

.academic-update-detail-heading {
  display: grid;
  gap: 4px;
}

.academic-update-detail-heading h2 {
  margin: 0;
  font-size: 1.2rem;
}

.academic-update-detail-meta {
  margin: 0;
}

.academic-update-detail-empty {
  color: var(--muted);
}

.academic-update-detail-body {
  display: none;
  gap: 16px;
}

.academic-update-detail-body.show {
  display: grid;
}

.academic-update-info-card,
.academic-update-files {
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  padding: 14px;
}

.academic-update-info-label {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

.academic-update-subject-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  overflow: visible;
}

.academic-update-subject-tab {
  border: none;
  background: rgba(255, 252, 246, 0.88);
  color: var(--muted);
  border-radius: 12px;
  max-width: min(38vw, 132px);
  min-height: 30px;
  padding: 6px 9px;
  font-size: 0.78rem;
  font-weight: 500;
  line-height: 1.15;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.academic-update-subject-tab[aria-selected="true"] {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.18));
  color: var(--text);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.22);
}

.academic-update-subject-panel {
  display: grid;
  gap: 16px;
}

.academic-update-subject-header h3,
.academic-update-files h4 {
  margin: 0;
}

.academic-update-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.academic-update-info-card {
  display: grid;
  gap: 8px;
}

.academic-update-info-value {
  line-height: 1.6;
}

.academic-update-info-value.is-multiline {
  white-space: pre-wrap;
}

.academic-update-files {
  display: grid;
  gap: 12px;
}

.academic-update-file-list {
  display: grid;
  gap: 10px;
}

.academic-update-file-link {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(var(--accent-rgb), 0.22);
  color: var(--accent);
  background: rgba(255, 252, 246, 0.84);
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 600;
}

.elearning-view {
  display: none;
  width: 100%;
  max-width: 1180px;
  gap: 14px;
  padding: 0;
  animation: fadeUp 0.8s ease-out 0.1s both;
}

.elearning-overview,
.elearning-layout,
.elearning-list-pane,
.elearning-detail-pane {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

body[data-view="elearning"][data-elearning-pane="list"] .elearning-detail-pane {
  display: none;
}

body[data-view="elearning"][data-elearning-pane="chapters"] .elearning-list-pane,
body[data-view="elearning"][data-elearning-pane="chapter"] .elearning-list-pane {
  display: none;
}

body[data-view="elearning"][data-elearning-pane="list"] .elearning-list-pane {
  animation: messagesPaneEnterLeft 0.28s ease both;
}

body[data-view="elearning"][data-elearning-pane="chapters"] .elearning-detail-pane,
body[data-view="elearning"][data-elearning-pane="chapter"] .elearning-detail-pane {
  animation: messagesPaneEnterRight 0.3s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.elearning-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.elearning-header h1 {
  margin: 0;
  font-size: 1.7rem;
}

.elearning-status,
.elearning-detail-status {
  min-height: 18px;
  font-size: 0.9rem;
  color: var(--accent);
}

.elearning-status:empty,
.elearning-detail-status:empty {
  display: none;
}

.elearning-status.error,
.elearning-detail-status.error {
  color: var(--danger);
}

.elearning-child-tabs {
  display: none;
  flex-wrap: wrap;
  gap: 10px;
}

.elearning-child-tab {
  display: grid;
  gap: 4px;
  min-height: 52px;
  padding: 10px 14px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  color: var(--text);
  cursor: pointer;
  text-align: left;
  flex: 1 1 220px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.elearning-child-tab[aria-pressed="true"] {
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-2-rgb), 0.18));
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.22);
}

.elearning-child-tab-label {
  font-size: 0.94rem;
  font-weight: 700;
}

.elearning-child-tab-meta {
  color: var(--muted);
  font-size: 0.82rem;
}

.elearning-course-list,
.elearning-chapter-list {
  display: grid;
  gap: 12px;
}

.elearning-course-card {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.elearning-course-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  border-color: rgba(var(--accent-rgb), 0.28);
}

.elearning-course-card.is-active {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.1);
}

.elearning-course-content {
  display: grid;
  gap: 4px;
}

.elearning-course-content h3,
.elearning-detail-heading h2,
.elearning-chapter-heading h3,
.elearning-resource-section h4 {
  margin: 0;
}

.elearning-course-meta,
.elearning-detail-meta,
.elearning-chapter-meta,
.elearning-resource-meta,
.elearning-detail-empty,
.elearning-detail-empty-copy {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.elearning-detail-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
}

.elearning-back {
  margin-left: auto;
}

.elearning-detail-heading {
  display: grid;
  gap: 4px;
}

.elearning-detail-body {
  display: none;
  gap: 16px;
}

.elearning-detail-body.show {
  display: grid;
}

.elearning-chapter-card,
.elearning-resource-item {
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 252, 246, 0.94);
}

.elearning-chapter-card {
  padding: 16px;
  display: grid;
  gap: 12px;
  min-width: 0;
  max-width: 100%;
}

.elearning-chapter-list-card {
  width: 100%;
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.elearning-chapter-list-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  border-color: rgba(var(--accent-rgb), 0.28);
}

.elearning-chapter-list-card.is-active {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.1);
}

.elearning-chapter-detail-card {
  width: 100%;
}

.elearning-chapter-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
  max-width: 100%;
}

.elearning-chapter-heading {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.elearning-chapter-summary {
  margin: 0;
  line-height: 1.6;
  overflow-wrap: anywhere;
}

.elearning-chapter-summary.rendered-html p,
.elearning-chapter-summary.rendered-html ul,
.elearning-chapter-summary.rendered-html ol {
  margin: 0 0 8px;
}

.elearning-chapter-summary.rendered-html > :last-child {
  margin-bottom: 0;
}

.elearning-resource-section {
  display: grid;
  gap: 10px;
}

.elearning-resource-section h4 {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

.elearning-resource-list {
  display: grid;
  gap: 10px;
}

.elearning-resource-item {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  color: var(--text);
  text-decoration: none;
  min-width: 0;
  max-width: 100%;
}

.elearning-resource-item strong {
  font-size: 0.94rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.elearning-resource-item:hover {
  border-color: rgba(var(--accent-rgb), 0.24);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

body[data-view="academic-updates"] .login-card,
body[data-view="academic-updates"] .error-card,
body[data-view="academic-updates"] .dashboard-view,
body[data-view="academic-updates"] .profile-view,
body[data-view="academic-updates"] .calendar-view,
body[data-view="academic-updates"] .messages-view,
body[data-view="academic-updates"] .circulars-view,
body[data-view="academic-updates"] .policies-view,
body[data-view="academic-updates"] .fees-view {
  display: none;
}

body[data-view="academic-updates"] .academic-updates-view {
  display: grid;
}

body[data-view="academic-updates"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="elearning"] .login-card,
body[data-view="elearning"] .error-card,
body[data-view="elearning"] .dashboard-view,
body[data-view="elearning"] .profile-view,
body[data-view="elearning"] .calendar-view,
body[data-view="elearning"] .messages-view,
body[data-view="elearning"] .circulars-view,
body[data-view="elearning"] .policies-view,
body[data-view="elearning"] .fees-view,
body[data-view="elearning"] .academic-updates-view {
  display: none;
}

body[data-view="elearning"] .elearning-view {
  display: grid;
}

body[data-view="elearning"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="fees"] .login-card,
body[data-view="fees"] .error-card,
body[data-view="fees"] .dashboard-view,
body[data-view="fees"] .messages-view,
body[data-view="fees"] .policies-view {
  display: none;
}

body[data-view="fees"] .fees-view {
  display: grid;
}

body[data-view="fees"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="document-requests"] .login-card,
body[data-view="document-requests"] .error-card,
body[data-view="document-requests"] .dashboard-view,
body[data-view="document-requests"] .profile-view,
body[data-view="document-requests"] .calendar-view,
body[data-view="document-requests"] .attendance-summary-view,
body[data-view="document-requests"] .messages-view,
body[data-view="document-requests"] .circulars-view,
body[data-view="document-requests"] .policies-view,
body[data-view="document-requests"] .fees-view,
body[data-view="document-requests"] .referrals-view,
body[data-view="document-requests"] .transport-view,
body[data-view="document-requests"] .academic-updates-view,
body[data-view="document-requests"] .elearning-view {
  display: none;
}

body[data-view="document-requests"] .document-requests-view {
  display: grid;
}

body[data-view="document-requests"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="referrals"] .login-card,
body[data-view="referrals"] .error-card,
body[data-view="referrals"] .dashboard-view,
body[data-view="referrals"] .profile-view,
body[data-view="referrals"] .calendar-view,
body[data-view="referrals"] .attendance-summary-view,
body[data-view="referrals"] .messages-view,
body[data-view="referrals"] .circulars-view,
body[data-view="referrals"] .policies-view,
body[data-view="referrals"] .fees-view,
body[data-view="referrals"] .transport-view,
body[data-view="referrals"] .academic-updates-view,
body[data-view="referrals"] .elearning-view {
  display: none;
}

body[data-view="referrals"] .referrals-view {
  display: grid;
}

body[data-view="referrals"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="circulars"] .login-card,
body[data-view="circulars"] .error-card,
body[data-view="circulars"] .dashboard-view,
body[data-view="circulars"] .calendar-view,
body[data-view="circulars"] .messages-view,
body[data-view="circulars"] .policies-view,
body[data-view="circulars"] .fees-view {
  display: none;
}

body[data-view="circulars"] .circulars-view {
  display: grid;
}

body[data-view="circulars"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="policies"] .login-card,
body[data-view="policies"] .error-card,
body[data-view="policies"] .dashboard-view,
body[data-view="policies"] .profile-view,
body[data-view="policies"] .calendar-view,
body[data-view="policies"] .attendance-summary-view,
body[data-view="policies"] .messages-view,
body[data-view="policies"] .circulars-view,
body[data-view="policies"] .fees-view,
body[data-view="policies"] .document-requests-view,
body[data-view="policies"] .referrals-view,
body[data-view="policies"] .transport-view,
body[data-view="policies"] .academic-updates-view,
body[data-view="policies"] .elearning-view {
  display: none;
}

body[data-view="policies"] .policies-view {
  display: grid;
}

body[data-view="policies"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="leave-notifications"] .login-card,
body[data-view="leave-notifications"] .error-card,
body[data-view="leave-notifications"] .dashboard-view,
body[data-view="leave-notifications"] .profile-view,
body[data-view="leave-notifications"] .calendar-view,
body[data-view="leave-notifications"] .attendance-summary-view,
body[data-view="leave-notifications"] .messages-view,
body[data-view="leave-notifications"] .circulars-view,
body[data-view="leave-notifications"] .policies-view,
body[data-view="leave-notifications"] .fees-view,
body[data-view="leave-notifications"] .document-requests-view,
body[data-view="leave-notifications"] .referrals-view,
body[data-view="leave-notifications"] .transport-view,
body[data-view="leave-notifications"] .academic-updates-view,
body[data-view="leave-notifications"] .elearning-view {
  display: none;
}

body[data-view="leave-notifications"] .leave-notifications-view {
  display: grid;
}

body[data-view="leave-notifications"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="calendar"] .login-card,
body[data-view="calendar"] .error-card,
body[data-view="calendar"] .dashboard-view,
body[data-view="calendar"] .circulars-view,
body[data-view="calendar"] .policies-view,
body[data-view="calendar"] .messages-view,
body[data-view="calendar"] .fees-view {
  display: none;
}

body[data-view="calendar"] .calendar-view {
  display: grid;
}

body[data-view="calendar"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="messages"] .login-card,
body[data-view="messages"] .error-card,
body[data-view="messages"] .dashboard-view,
body[data-view="messages"] .calendar-view,
body[data-view="messages"] .circulars-view,
body[data-view="messages"] .policies-view,
body[data-view="messages"] .fees-view {
  display: none;
}

body[data-view="messages"] .messages-view {
  display: grid;
}

body[data-view="messages"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

body[data-view="transport"] .login-card,
body[data-view="transport"] .error-card,
body[data-view="transport"] .dashboard-view,
body[data-view="transport"] .profile-view,
body[data-view="transport"] .calendar-view,
body[data-view="transport"] .messages-view,
body[data-view="transport"] .circulars-view,
body[data-view="transport"] .policies-view,
body[data-view="transport"] .fees-view,
body[data-view="transport"] .academic-updates-view,
body[data-view="transport"] .elearning-view {
  display: none;
}

body[data-view="transport"] .transport-view {
  display: grid;
}

body[data-view="transport"] .content {
  place-items: start center;
  align-content: start;
  padding-top: 8px;
  padding-bottom: 18px;
}

@media (max-width: 800px) {
  .referrals-form-grid,
  .referrals-share-card {
    grid-template-columns: 1fr;
  }

  .referrals-card-actions {
    width: 100%;
  }

  .messages-view {
    gap: 12px;
    padding: 0;
  }

  .messages-header-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .messages-header-actions,
  .messages-tabs,
  .messages-thread-top,
  .messages-detail-header,
  .messages-detail-heading,
  .messages-reply-actions,
  .messages-compose-actions {
    width: 100%;
  }

  .messages-tabs,
  .messages-thread-top,
  .messages-detail-header,
  .messages-detail-heading,
  .messages-reply-actions,
  .messages-compose-actions {
    display: grid;
    justify-content: stretch;
  }

  .messages-tabs,
  .messages-reply-actions,
  .messages-compose-actions {
    grid-template-columns: 1fr;
  }

  .messages-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-view="messages"][data-messages-pane="detail"] .messages-layout {
    min-height: calc(100dvh - 170px);
  }

  .messages-thread-card {
    padding: 14px;
    border-radius: 18px;
  }

  body[data-view="messages"][data-messages-pane="detail"] .messages-detail-card.show {
    gap: 12px;
    min-height: calc(100dvh - 170px);
  }

  .messages-detail-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 10px;
    padding-left: 44px;
    padding-bottom: 10px;
  }

  .messages-detail-heading {
    width: auto;
    min-width: 0;
    justify-content: start;
  }

  .messages-detail-back {
    width: auto;
    margin-left: auto;
    justify-self: end;
  }

  .messages-reply-actions {
    justify-items: center;
  }

  .messages-end-thread {
    width: 100%;
    justify-self: center;
  }

  .messages-reply-composer,
  .messages-reply-meta-row {
    grid-template-columns: 1fr;
  }

  .messages-reply-composer {
    grid-template-columns: 44px minmax(0, 1fr);
  }

  .messages-reply-form.has-send .messages-reply-composer {
    grid-template-columns: 44px minmax(0, 1fr) 44px;
  }

  .messages-conversation {
    padding: 14px 10px;
    border-radius: 20px;
  }

  .messages-bubble {
    max-width: min(100%, 88vw);
  }

  .messages-reply-form {
    padding: 12px;
    border-radius: 20px;
  }

  .messages-header-actions .primary,
  .messages-header-actions .nav-item,
  .messages-reply-send,
  .messages-reply-actions .nav-item,
  .messages-compose-actions .primary,
  .messages-compose-actions .nav-item {
    width: 100%;
  }

  .calendar-view {
    padding: 0;
  }

  .calendar-toolbar {
    align-items: center;
  }

  .calendar-month-switcher {
    width: 100%;
    min-height: 34px;
    grid-template-columns: 30px minmax(0, 1fr) 30px;
    gap: 4px;
  }

  .calendar-nav-btn {
    width: 30px;
    height: 30px;
  }

  .calendar-weekdays,
  .calendar-grid {
    gap: 3px;
  }

  .calendar-weekday {
    font-size: 0.58rem;
    padding: 0;
  }

  .calendar-cell {
    min-height: 42px;
    padding: 4px;
    border-radius: 9px;
  }

  .calendar-cell-number {
    font-size: 0.72rem;
  }

  .calendar-cell.is-today .calendar-cell-number {
    min-width: 18px;
    min-height: 18px;
    padding: 2px 5px;
  }

  .calendar-cell-markers {
    left: 5px;
    bottom: 4px;
    gap: 3px;
  }

  .calendar-cell-marker {
    width: 5px;
    height: 5px;
  }

  .calendar-cell-count {
    right: 5px;
    bottom: 1px;
    font-size: 0.58rem;
  }

  .calendar-upcoming {
    padding: 7px;
  }

  .calendar-upcoming-header {
    display: flex;
    align-items: center;
  }

  .calendar-upcoming-card {
    padding: 6px 8px;
  }

  .calendar-upcoming-card h3 {
    font-size: 0.82rem;
  }

  .calendar-upcoming-card .calendar-event-when {
    font-size: 0.7rem;
  }

  .calendar-day-modal,
  .calendar-modal {
    padding: 14px;
  }

  .calendar-event-top,
  .calendar-detail-top {
    display: grid;
  }

  .calendar-event-when {
    width: fit-content;
  }

  .circulars-view,
  .policies-view,
  .leave-notifications-view {
    padding: 0;
  }

  .circular-card-top,
  .circular-detail-top {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .circular-card-top,
  .circular-detail-top {
    display: grid;
  }

  .circular-card-date {
    white-space: normal;
  }

  .fees-view {
    padding: 0;
  }

  .academic-updates-view {
    gap: 12px;
    padding: 0;
  }

  .elearning-view {
    gap: 12px;
    padding: 0;
  }

  .transport-view {
    gap: 12px;
    padding: 0;
  }

  .transport-route-fields {
    grid-template-columns: 1fr;
  }

  .elearning-layout {
    min-height: calc(100dvh - 170px);
  }

  .elearning-detail-header,
  .elearning-chapter-top {
    display: grid;
  }

  .elearning-detail-header {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .elearning-course-card {
    padding: 14px;
    border-radius: 18px;
  }

  .academic-updates-search {
    width: 100%;
  }

  .academic-update-detail-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .academic-update-info-grid {
    grid-template-columns: 1fr;
  }

  .fees-tabs {
    width: 100%;
    grid-auto-flow: row;
  }

  .fees-tab {
    width: 100%;
  }

  .fees-installment-top,
  .fees-receipt-card,
  .fees-student-actions,
  .fees-return-actions,
  .payment-handoff-actions {
    display: grid;
    justify-content: stretch;
  }

  .fees-installment-top,
  .fees-student-actions,
  .fees-return-actions,
  .payment-handoff-actions {
    grid-template-columns: 1fr;
  }

  .fees-student-actions .primary,
  .fees-student-actions .nav-item,
  .fees-return-actions .nav-item,
  .fees-return-actions .primary,
  .payment-handoff-actions .primary,
  .payment-handoff-actions .nav-item {
    width: 100%;
  }

  .fees-transaction-total {
    justify-items: start;
  }
}

body {
  background:
    linear-gradient(120deg, rgba(var(--accent-rgb), 0.08), transparent 42%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
}

body::before {
  background-image:
    linear-gradient(115deg, rgba(var(--accent-rgb), 0.045) 0%, rgba(var(--accent-rgb), 0) 58%),
    repeating-linear-gradient(
      90deg,
      rgba(var(--accent-rgb), 0.018),
      rgba(var(--accent-rgb), 0.018) 1px,
      transparent 1px,
      transparent 128px
    );
}

.sidebar {
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.95), rgba(238, 244, 240, 0.94)),
    linear-gradient(150deg, rgba(var(--accent-rgb), 0.06), rgba(var(--accent-2-rgb), 0.08));
  box-shadow: 18px 0 38px rgba(var(--accent-rgb), 0.1);
}

body[data-auth="logged-in"] .content {
  padding-top: 70px;
}

.logo-text {
  border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), #1f6267);
  letter-spacing: 0.02em;
}

.brand-profile,
.nav-toggle,
.nav-item,
.fees-tab,
.messages-tab,
.achievement-filter,
.academic-update-subject-tab,
.elearning-child-tab {
  border-radius: 14px;
}

.nav-item {
  background: rgba(255, 253, 248, 0.9);
  box-shadow: none;
}

.nav-icon {
  border-radius: 10px;
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.08);
  border-color: rgba(var(--accent-rgb), 0.16);
}

.nav-item:hover,
.nav-item.is-active {
  background: rgba(var(--accent-rgb), 0.08);
  border-color: rgba(var(--accent-rgb), 0.2);
  box-shadow: 0 10px 22px rgba(var(--accent-rgb), 0.1);
}

.login-card,
.profile-card,
.notification-card,
.circular-card,
.fees-student-card,
.fees-transaction-card,
.academic-update-card,
.academic-update-info-card,
.academic-update-files,
.elearning-course-card,
.elearning-chapter-card,
.elearning-resource-item,
.calendar-cell,
.calendar-month-switcher,
.calendar-upcoming,
.fees-tabs {
  background: rgba(255, 253, 248, 0.94);
  border-color: rgba(var(--accent-rgb), 0.1);
  box-shadow: 0 16px 34px rgba(var(--accent-rgb), 0.07);
}

.login-card {
  background:
    linear-gradient(160deg, rgba(255, 253, 248, 0.98), rgba(239, 246, 242, 0.94));
}

.login-card h1,
  .dashboard-header h1,
  .profile-header h1,
  .calendar-header h1,
  .time-table-header h1,
  .messages-header h1,
  .circulars-header h1,
.fees-header h1,
.academic-updates-header h1,
.elearning-header h1 {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  letter-spacing: 0;
}

.primary {
  background: linear-gradient(135deg, var(--accent), #1f6267);
  color: #fffdf8;
  box-shadow: 0 12px 22px rgba(var(--accent-rgb), 0.18);
}

.primary:hover {
  box-shadow: 0 16px 30px rgba(var(--accent-rgb), 0.22);
}

.field input,
.field select,
.field textarea,
.notifications-search,
.academic-updates-search {
  background: rgba(255, 253, 248, 0.96);
  border-color: rgba(var(--accent-rgb), 0.14);
}

.profile-eyebrow,
.fees-total-pill,
.fees-status-pill,
.calendar-day-count,
.circular-detail-number,
.academic-update-card-subject {
  background: rgba(var(--accent-rgb), 0.09);
  color: var(--accent);
}

.fees-tab[aria-selected="true"],
.messages-tab[aria-selected="true"],
.academic-update-subject-tab[aria-selected="true"],
.elearning-child-tab[aria-pressed="true"],
.achievement-filter[data-active="true"] {
  background: rgba(var(--accent-rgb), 0.1);
  color: var(--accent);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.18);
}

.calendar-cell.today {
  border-color: rgba(var(--accent-rgb), 0.34);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-rgb), 0.16);
}

.notification-card.unread {
  background: rgba(var(--accent-rgb), 0.07);
  border-color: rgba(var(--accent-rgb), 0.26);
}

.danger {
  background: rgba(191, 74, 58, 0.08);
}

.calendar-cell {
  box-shadow: none;
}

.calendar-month-switcher,
.calendar-upcoming {
  box-shadow: 0 6px 14px rgba(var(--accent-rgb), 0.05);
}

.calendar-upcoming-card {
  box-shadow: none;
}

.messages-view {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

/* Desktop shell: keep the mobile app intact, but make wide screens feel native. */
@media (min-width: 960px) {
  :root {
    --desktop-sidebar-width: 272px;
    --desktop-topbar-height: 64px;
  }

  body[data-auth="logged-in"] {
    background: linear-gradient(180deg, #f6f8f7 0%, #eef3f0 100%);
  }

  body[data-auth="logged-in"]::before {
    background-image:
      linear-gradient(90deg, rgba(var(--accent-rgb), 0.035) 1px, transparent 1px),
      linear-gradient(180deg, rgba(var(--accent-rgb), 0.025) 1px, transparent 1px);
    background-position: var(--desktop-sidebar-width) var(--desktop-topbar-height);
    background-size: 72px 72px;
  }

  body[data-auth="logged-in"] .sidebar {
    width: var(--desktop-sidebar-width);
    transform: translateX(0);
    padding: 20px 18px 18px;
    gap: 18px;
    background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(243, 247, 244, 0.96));
    border-right: 1px solid rgba(var(--accent-rgb), 0.12);
    box-shadow: 12px 0 32px rgba(var(--accent-rgb), 0.08);
    z-index: 42;
  }

  body[data-auth="logged-in"] .brand {
    align-items: stretch;
    gap: 10px;
  }

  body[data-auth="logged-in"] .brand-home {
    flex: 1 1 auto;
  }

  body[data-auth="logged-in"] .logo-text {
    width: 100%;
    min-height: 44px;
    justify-content: center;
    padding: 10px 12px;
    border-radius: 12px;
    box-shadow: none;
  }

  body[data-auth="logged-in"] .brand-profile {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    box-shadow: none;
  }

  body[data-auth="logged-in"] .nav {
    gap: 4px;
    padding-right: 8px;
    margin-right: -8px;
  }

  body[data-auth="logged-in"] .sidebar .nav-item {
    min-height: 40px;
    padding: 9px 10px;
    border-radius: 12px;
    font-size: 0.9rem;
    line-height: 1.25;
  }

  body[data-auth="logged-in"] .sidebar .nav-item:hover,
  body[data-auth="logged-in"] .sidebar .nav-item:focus-visible {
    transform: none;
  }

  body[data-auth="logged-in"] .sidebar .nav-icon {
    width: 26px;
    height: 26px;
  }

  body[data-auth="logged-in"] .sidebar .nav-icon svg {
    width: 14px;
    height: 14px;
  }

  body[data-auth="logged-in"] .app-topbar {
    left: var(--desktop-sidebar-width);
    height: var(--desktop-topbar-height);
    grid-template-columns: minmax(0, 1fr) 44px;
    padding: 10px clamp(28px, 4vw, 56px);
    border-top: 0;
    border-right: 0;
    border-left: 0;
    border-color: rgba(var(--accent-rgb), 0.1);
    background: rgba(255, 253, 248, 0.92);
    box-shadow: 0 10px 28px rgba(var(--accent-rgb), 0.07);
    backdrop-filter: blur(18px);
    z-index: 38;
  }

  body[data-auth="logged-in"] .app-topbar .nav-toggle {
    display: none;
  }

  body[data-auth="logged-in"] .app-topbar-title {
    text-align: left;
    font-size: 1rem;
  }

  body[data-auth="logged-in"] .app-notifications-button {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: rgba(var(--accent-rgb), 0.07);
  }

  body[data-auth="logged-in"] .nav-scrim,
  body[data-auth="logged-in"] .dashboard-pull-indicator {
    display: none;
  }

  body[data-auth="logged-in"] .content,
  body[data-auth="logged-in"][data-view] .content {
    width: calc(100% - var(--desktop-sidebar-width));
    min-height: 100vh;
    margin-left: var(--desktop-sidebar-width);
    padding: calc(var(--desktop-topbar-height) + 28px) clamp(28px, 4vw, 56px) 48px;
    place-items: start center;
    align-content: start;
  }

  body[data-auth="logged-in"][data-view="photo-manager"] .content,
  body[data-auth="logged-in"][data-view="time-table"] .content {
    padding-top: calc(var(--desktop-topbar-height) + 28px);
  }

  body[data-auth="logged-in"] .dashboard-view,
  body[data-auth="logged-in"] .profile-view,
  body[data-auth="logged-in"] .time-table-view,
  body[data-auth="logged-in"] .messages-view,
  body[data-auth="logged-in"] .circulars-view,
  body[data-auth="logged-in"] .policies-view,
  body[data-auth="logged-in"] .leave-notifications-view,
  body[data-auth="logged-in"] .fees-view,
  body[data-auth="logged-in"] .document-requests-view,
  body[data-auth="logged-in"] .referrals-view,
  body[data-auth="logged-in"] .transport-view,
  body[data-auth="logged-in"] .academic-updates-view,
  body[data-auth="logged-in"] .elearning-view,
  body[data-auth="logged-in"] .attendance-summary-view {
    width: 100%;
    max-width: 1180px;
  }

  body[data-auth="logged-in"] .calendar-view {
    max-width: 980px;
  }

  body[data-auth="logged-in"] .dashboard-header,
  body[data-auth="logged-in"] .profile-header,
  body[data-auth="logged-in"] .calendar-header,
  body[data-auth="logged-in"] .time-table-header,
  body[data-auth="logged-in"] .messages-header,
  body[data-auth="logged-in"] .circulars-header,
  body[data-auth="logged-in"] .policies-header,
  body[data-auth="logged-in"] .leave-notifications-header,
  body[data-auth="logged-in"] .fees-header,
  body[data-auth="logged-in"] .referrals-header,
  body[data-auth="logged-in"] .transport-header,
  body[data-auth="logged-in"] .academic-updates-header,
  body[data-auth="logged-in"] .elearning-header {
    align-items: center;
  }

  body[data-auth="logged-in"] .dashboard-header h1,
  body[data-auth="logged-in"] .profile-header h1,
  body[data-auth="logged-in"] .calendar-header h1,
  body[data-auth="logged-in"] .time-table-header h1,
  body[data-auth="logged-in"] .messages-header h1,
  body[data-auth="logged-in"] .circulars-header h1,
  body[data-auth="logged-in"] .policies-header h1,
  body[data-auth="logged-in"] .leave-notifications-header h1,
  body[data-auth="logged-in"] .fees-header h1,
  body[data-auth="logged-in"] .referrals-header h1,
  body[data-auth="logged-in"] .transport-header h1,
  body[data-auth="logged-in"] .academic-updates-header h1,
  body[data-auth="logged-in"] .elearning-header h1 {
    font-size: 1.8rem;
  }

  body[data-auth="logged-in"] .profile-tabs,
  body[data-auth="logged-in"] .fees-tabs,
  body[data-auth="logged-in"] .messages-tabs,
  body[data-auth="logged-in"] .time-table-tabs,
  body[data-auth="logged-in"] .attendance-student-tabs,
  body[data-auth="logged-in"] .elearning-child-tabs {
    flex-wrap: wrap;
    overflow: visible;
  }

  body[data-auth="logged-in"] .notifications-list,
  body[data-auth="logged-in"] .circulars-list,
  body[data-auth="logged-in"] .leave-notifications-list,
  body[data-auth="logged-in"] .fees-student-groups,
  body[data-auth="logged-in"] .fees-transactions-list,
  body[data-auth="logged-in"] .transport-route-groups {
    gap: 16px;
  }

  body[data-auth="logged-in"] .children-list {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  }

  body[data-auth="logged-in"] .notification-card,
  body[data-auth="logged-in"] .leave-notification-card,
  body[data-auth="logged-in"] .fees-student-card,
  body[data-auth="logged-in"] .fees-transaction-card,
  body[data-auth="logged-in"] .transport-route-card,
  body[data-auth="logged-in"] .academic-update-card,
  body[data-auth="logged-in"] .elearning-course-card,
  body[data-auth="logged-in"] .profile-card {
    border-radius: 16px;
  }
}

@media (min-width: 1100px) {
  body[data-auth="logged-in"][data-view="messages"] .messages-layout,
  body[data-auth="logged-in"][data-view="academic-updates"] .academic-updates-view,
  body[data-auth="logged-in"][data-view="elearning"] .elearning-layout {
    display: grid;
    grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.3fr);
    align-items: start;
    gap: 20px;
  }

  body[data-auth="logged-in"][data-view="messages"] .messages-list-panel,
  body[data-auth="logged-in"][data-view="messages"] .messages-detail-panel,
  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="list"] .messages-detail-panel,
  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="detail"] .messages-list-panel,
  body[data-auth="logged-in"][data-view="academic-updates"][data-academic-updates-pane="list"] .academic-updates-detail-pane,
  body[data-auth="logged-in"][data-view="academic-updates"][data-academic-updates-pane="detail"] .academic-updates-list-pane,
  body[data-auth="logged-in"][data-view="elearning"][data-elearning-pane="list"] .elearning-detail-pane,
  body[data-auth="logged-in"][data-view="elearning"][data-elearning-pane="chapters"] .elearning-list-pane,
  body[data-auth="logged-in"][data-view="elearning"][data-elearning-pane="chapter"] .elearning-list-pane {
    display: grid;
    animation: none;
  }

  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="detail"] .messages-header {
    display: flex;
  }

  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="detail"] .messages-status {
    display: block;
  }

  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="detail"] .messages-status:empty {
    display: none;
  }

  body[data-auth="logged-in"][data-view="messages"][data-messages-pane="detail"] .messages-tabs {
    display: flex;
  }

  body[data-auth="logged-in"] .academic-updates-list-pane,
  body[data-auth="logged-in"] .academic-updates-detail-pane,
  body[data-auth="logged-in"] .elearning-list-pane,
  body[data-auth="logged-in"] .elearning-detail-pane {
    min-height: 0;
  }
}

@media (min-width: 1280px) {
  :root {
    --desktop-sidebar-width: 280px;
  }
}
