/* NoteSmart V68: perbaikan footer tombol jurnal pada iPhone/Safari.
   Masalah: pada beberapa iPhone, modal jurnal lebih tinggi dari visual viewport sehingga footer
   Simpan Draft / Kirim Laporan turun di bawah area layar. Patch ini hanya menargetkan
   modal isian jurnal guru dan tidak mengubah logika kirim/draft. */
:root{
  --ns-v68-vh: 1vh;
  --ns-v68-modal-top-gap: max(6px, env(safe-area-inset-top, 0px));
  --ns-v68-modal-bottom-safe: env(safe-area-inset-bottom, 0px);
}

@media (max-width: 768px){
  body.ns-v68-guru-modal-open{
    overflow: hidden !important;
    overscroll-behavior: none !important;
  }
  body.ns-v68-guru-modal-open [data-testid="guru-bottom-nav"]{
    visibility: hidden !important;
    pointer-events: none !important;
  }

  /* Overlay modal jurnal harus mengikuti tinggi layar nyata iOS, bukan 90vh lama. */
  [data-testid="guru-jurnal-modal"]{
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: calc(var(--ns-v68-vh) * 100) !important;
    min-height: calc(var(--ns-v68-vh) * 100) !important;
    max-height: calc(var(--ns-v68-vh) * 100) !important;
    padding: var(--ns-v68-modal-top-gap) 0 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
    overflow: hidden !important;
    z-index: 2147483600 !important;
    box-sizing: border-box !important;
    transform: none !important;
    isolation: isolate !important;
  }

  [data-testid="guru-jurnal-modal"] > .absolute.inset-0,
  [data-testid="guru-jurnal-modal"] > div:first-child{
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
  }

  [data-testid="guru-jurnal-modal"] > div.relative,
  [data-testid="guru-jurnal-modal"] [data-ns-v68-journal-panel="1"]{
    position: relative !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc((var(--ns-v68-vh) * 100) - var(--ns-v68-modal-top-gap)) !important;
    max-height: calc((var(--ns-v68-vh) * 100) - var(--ns-v68-modal-top-gap)) !important;
    min-height: 0 !important;
    margin: 0 !important;
    border-radius: 28px 28px 0 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    transform: none !important;
    animation: none !important;
    opacity: 1 !important;
  }

  [data-testid="guru-jurnal-modal"] > div.relative > div:first-child,
  [data-testid="guru-jurnal-modal"] [data-ns-v68-journal-header="1"]{
    flex: 0 0 auto !important;
    min-height: 62px !important;
    padding: 14px 16px !important;
    background: #fff !important;
    z-index: 3 !important;
  }
  [data-testid="guru-jurnal-modal"] h3{
    font-size: 17px !important;
    line-height: 1.25 !important;
    max-width: calc(100vw - 82px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  /* Area isi yang boleh discroll. Footer tidak ikut masuk ke area scroll. */
  [data-testid="guru-jurnal-modal"] > div.relative > div:nth-child(2),
  [data-testid="guru-jurnal-modal"] [data-ns-v68-journal-body="1"]{
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    padding: 14px 16px 18px !important;
    box-sizing: border-box !important;
  }

  /* Footer tombol selalu terlihat di bawah, termasuk pada iPhone dengan safe area. */
  [data-testid="guru-jurnal-modal"] > div.relative > div:last-child,
  [data-testid="guru-jurnal-modal"] [data-ns-v68-journal-footer="1"]{
    flex: 0 0 auto !important;
    min-height: auto !important;
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    z-index: 6 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 12px 16px calc(13px + var(--ns-v68-modal-bottom-safe)) !important;
    border-top: 1px solid rgba(31,41,55,.12) !important;
    background: rgba(255,255,255,.98) !important;
    box-shadow: 0 -12px 32px rgba(15,23,42,.10) !important;
    box-sizing: border-box !important;
    transform: translateZ(0) !important;
  }

  [data-testid="guru-jurnal-modal"] [data-testid="guru-cancel"]{
    order: 1 !important;
  }
  [data-testid="guru-jurnal-modal"] [data-testid="guru-save-draft"]{
    order: 2 !important;
  }
  [data-testid="guru-jurnal-modal"] [data-testid="guru-submit"]{
    order: 3 !important;
    grid-column: 1 / -1 !important;
  }
  [data-testid="guru-jurnal-modal"] [data-testid="guru-cancel"],
  [data-testid="guru-jurnal-modal"] [data-testid="guru-save-draft"],
  [data-testid="guru-jurnal-modal"] [data-testid="guru-submit"]{
    width: 100% !important;
    min-width: 0 !important;
    min-height: 52px !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: nowrap !important;
    border-radius: 999px !important;
    font-size: 15px !important;
    line-height: 1.1 !important;
  }

  [data-testid="guru-jurnal-modal"] .ns-signature-canvas,
  [data-testid="guru-jurnal-modal"] canvas[data-testid="signature-canvas"]{
    height: 128px !important;
    min-height: 128px !important;
    touch-action: none !important;
  }
}

@media (max-width: 380px){
  [data-testid="guru-jurnal-modal"] [data-testid="guru-cancel"],
  [data-testid="guru-jurnal-modal"] [data-testid="guru-save-draft"],
  [data-testid="guru-jurnal-modal"] [data-testid="guru-submit"]{
    font-size: 14px !important;
    min-height: 50px !important;
  }
}
