/* NoteSmart V31: header final, notifikasi sukses, filter siswa, submit jurnal guru. */
:root { --ns-v31-toast-z: 2147483600; }

/* Header utama tidak boleh hilang di halaman admin/mobile. */
@media (max-width: 768px) {
  body:not(.ns-guru-jurnal-v31) #root > div.min-h-screen > header.md\:hidden,
  body:not(.ns-guru-jurnal-v31) #root header.md\:hidden,
  body:not(.ns-guru-jurnal-v31) #root > div > header {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    min-height: 64px !important;
    max-height: none !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 80 !important;
    transform: none !important;
    clip: auto !important;
    clip-path: none !important;
    overflow: visible !important;
  }
  body:not(.ns-guru-jurnal-v31) #root > div.min-h-screen > header.md\:hidden > div,
  body:not(.ns-guru-jurnal-v31) #root header.md\:hidden > div {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    min-height: 64px !important;
  }

  /* Khusus halaman isian jurnal guru: pakai header hijau bawaan guru saja, jangan double dengan header aplikasi. */
  body.ns-guru-jurnal-v31.ns-v31-hide-app-header #root > div.min-h-screen > header.md\:hidden,
  body.ns-guru-jurnal-v31.ns-v31-hide-app-header #root header.md\:hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
  }
  body.ns-guru-jurnal-v31 #root main {
    padding-top: 0 !important;
  }
  body.ns-guru-jurnal-v31 [data-testid="guru-top-header"] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 90 !important;
    margin-top: 0 !important;
    transform: none !important;
  }
  body.ns-guru-jurnal-v31 [data-testid="guru-bottom-nav"] {
    z-index: 85 !important;
  }
}

/* Modal jurnal guru tetap berada di tengah viewport dan footer/tombol tidak jauh di bawah. */
[data-testid="guru-jurnal-modal"] {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: max(10px, env(safe-area-inset-top)) 10px max(10px, env(safe-area-inset-bottom)) !important;
  overflow: hidden !important;
  z-index: 2147483000 !important;
}
[data-testid="guru-jurnal-modal"] > div.relative {
  width: min(100%, 46rem) !important;
  max-width: calc(100vw - 20px) !important;
  max-height: calc(100dvh - 20px) !important;
  overflow: hidden !important;
  margin: auto !important;
  transform: none !important;
}
[data-testid="guru-jurnal-modal"] > div.relative > div:nth-child(2) {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
  max-height: calc(100dvh - 174px) !important;
}
[data-testid="guru-jurnal-modal"] > div.relative > div:last-child {
  position: sticky !important;
  bottom: 0 !important;
  background: #fff !important;
  gap: 8px !important;
  z-index: 5 !important;
}
[data-testid="guru-jurnal-modal"] [data-testid="guru-submit"] {
  background: #24523d !important;
  color: #fff !important;
}

/* Toast sukses hijau tambahan agar setiap aksi berhasil terlihat jelas. */
#ns-v31-toast-stack {
  position: fixed !important;
  left: 50% !important;
  top: max(14px, env(safe-area-inset-top)) !important;
  transform: translateX(-50%) !important;
  z-index: var(--ns-v31-toast-z) !important;
  width: min(calc(100vw - 24px), 520px) !important;
  display: grid !important;
  gap: 10px !important;
  pointer-events: none !important;
}
.ns-v31-toast {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  border-radius: 18px !important;
  padding: 13px 15px !important;
  background: #ecfdf5 !important;
  color: #065f46 !important;
  border: 1px solid #a7f3d0 !important;
  box-shadow: 0 18px 42px rgba(6, 95, 70, .18) !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  pointer-events: auto !important;
  animation: ns-v31-toast-in .18s ease-out both !important;
}
.ns-v31-toast b {
  display: inline-grid !important;
  place-items: center !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 999px !important;
  background: #10b981 !important;
  color: #fff !important;
  flex: 0 0 auto !important;
  font-size: 13px !important;
}
@keyframes ns-v31-toast-in {
  from { opacity: 0; transform: translateY(-8px) scale(.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Filter cepat Data Siswa. */
.ns-v31-student-filter {
  display: grid !important;
  grid-template-columns: 1fr 1fr auto !important;
  gap: 10px !important;
  margin: 0 0 12px !important;
  padding: 12px !important;
  border: 1px solid rgba(36,82,61,.12) !important;
  border-radius: 20px !important;
  background: linear-gradient(180deg, #ffffff, #f8fafc) !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, .04) !important;
}
.ns-v31-student-filter label {
  display: block !important;
  font-size: 10px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  font-weight: 900 !important;
  color: #64748b !important;
  margin: 0 0 5px !important;
}
.ns-v31-student-filter input,
.ns-v31-student-filter select {
  width: 100% !important;
  min-height: 44px !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 15px !important;
  padding: 0 12px !important;
  background: #fff !important;
  color: #111827 !important;
  font-size: 14px !important;
  outline: none !important;
}
.ns-v31-student-filter button {
  align-self: end !important;
  min-height: 44px !important;
  border: 1px solid #dbe7e1 !important;
  border-radius: 15px !important;
  padding: 0 14px !important;
  background: #f8fafc !important;
  color: #24523d !important;
  font-weight: 900 !important;
}
.ns-v31-empty-filter {
  display: none;
  margin: 8px 0 12px !important;
  padding: 12px 14px !important;
  border-radius: 16px !important;
  background: #fff7ed !important;
  color: #9a3412 !important;
  font-weight: 800 !important;
  font-size: 13px !important;
}
.ns-v31-empty-filter.is-visible { display: block !important; }
@media (max-width: 560px) {
  .ns-v31-student-filter { grid-template-columns: 1fr !important; }
  .ns-v31-student-filter button { width: 100% !important; }
}

/* Jaga klik tombol aksi tetap stabil. */
button, a, input, select, textarea { -webkit-tap-highlight-color: transparent !important; }
button:active, a:active { transform: none !important; }


/* V32: header utama dikembalikan; hanya disembunyikan jika JS memastikan ada header guru terpisah. */
@media (max-width: 768px) {
  body:not(.ns-v31-hide-app-header) #root header,
  body:not(.ns-v31-hide-app-header) #root header.md\:hidden,
  body:not(.ns-v31-hide-app-header) #root > div.min-h-screen > header.md\:hidden {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    min-height: 64px !important;
    height: auto !important;
    max-height: none !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 90 !important;
    transform: none !important;
    overflow: visible !important;
  }
  [data-testid="guru-top-header"] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 91 !important;
    transform: none !important;
  }
}

/* V35: filter siswa V31 dinonaktifkan supaya tidak dobel dengan filter V33. */
.ns-v31-student-filter,
.ns-v31-empty-filter{
  display:none!important;visibility:hidden!important;height:0!important;min-height:0!important;margin:0!important;padding:0!important;border:0!important;overflow:hidden!important;
}
