/* NoteSmart V70: fallback khusus iPhone/Safari agar tombol aksi jurnal selalu terlihat.
   Patch ini tidak mengubah API/logika kirim; tombol floating hanya memicu tombol asli React. */
:root{
  --ns-v70-vh: 1vh;
  --ns-v70-visual-height: 100vh;
  --ns-v70-safe-bottom: env(safe-area-inset-bottom, 0px);
  --ns-v70-actionbar-height: 154px;
}

@media (max-width: 768px){
  body.ns-v70-ios-journal-open{
    overflow: hidden !important;
    overscroll-behavior: none !important;
    -webkit-overflow-scrolling: auto !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-bottom-nav"],
  body.ns-v70-ios-journal-open nav[data-testid="guru-bottom-nav"]{
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"]{
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: var(--ns-v70-visual-height) !important;
    min-height: var(--ns-v70-visual-height) !important;
    max-height: var(--ns-v70-visual-height) !important;
    padding: max(6px, env(safe-area-inset-top, 0px)) 0 0 !important;
    align-items: flex-end !important;
    justify-content: center !important;
    overflow: hidden !important;
    z-index: 2147483000 !important;
    box-sizing: border-box !important;
    transform: none !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"] > div.relative{
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(var(--ns-v70-visual-height) - max(6px, env(safe-area-inset-top, 0px))) !important;
    max-height: calc(var(--ns-v70-visual-height) - max(6px, env(safe-area-inset-top, 0px))) !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;
    transform: none !important;
    animation: none !important;
    box-sizing: border-box !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"] > div.relative > div:first-child{
    flex: 0 0 auto !important;
    min-height: 60px !important;
    padding: 13px 16px !important;
    background: #fff !important;
    z-index: 5 !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"] h3{
    font-size: 17px !important;
    line-height: 1.25 !important;
    max-width: calc(100vw - 84px) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"] > div.relative > div:nth-child(2){
    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 calc(var(--ns-v70-actionbar-height) + 18px + var(--ns-v70-safe-bottom)) !important;
    box-sizing: border-box !important;
  }

  /* Footer asli tetap ada untuk logika React, tetapi tidak dipakai sebagai layout iOS
     karena pada sebagian iPhone footer turun ke bawah viewport. */
  body.ns-v70-ios-journal-open [data-testid="guru-jurnal-modal"] > div.relative > div:last-child{
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    padding: 0 !important;
    border: 0 !important;
    margin: 0 !important;
  }

  #ns-v70-journal-actionbar{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2147483647 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 10px !important;
    width: 100vw !important;
    padding: 12px 16px calc(14px + var(--ns-v70-safe-bottom)) !important;
    box-sizing: border-box !important;
    background: rgba(255,255,255,.98) !important;
    border-top: 1px solid rgba(31,41,55,.12) !important;
    box-shadow: 0 -14px 34px rgba(15,23,42,.16) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    backdrop-filter: blur(14px) !important;
  }

  #ns-v70-journal-actionbar button{
    appearance: none !important;
    -webkit-appearance: none !important;
    min-width: 0 !important;
    min-height: 52px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(36,82,61,.18) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    text-align: center !important;
    white-space: nowrap !important;
    padding: 0 12px !important;
    box-sizing: border-box !important;
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
  }

  #ns-v70-journal-actionbar .ns-v70-close{
    color: #1f2937 !important;
    background: #fff !important;
    border-color: rgba(31,41,55,.12) !important;
  }

  #ns-v70-journal-actionbar .ns-v70-draft{
    color: #24523d !important;
    background: #fff !important;
    border-color: rgba(36,82,61,.32) !important;
  }

  #ns-v70-journal-actionbar .ns-v70-submit{
    grid-column: 1 / -1 !important;
    color: #fff !important;
    background: #24523d !important;
    border-color: #24523d !important;
    min-height: 58px !important;
    font-size: 16px !important;
    box-shadow: 0 10px 22px rgba(36,82,61,.24) !important;
  }

  #ns-v70-journal-actionbar button:disabled,
  #ns-v70-journal-actionbar button[aria-disabled="true"]{
    opacity: .55 !important;
    filter: grayscale(.18) !important;
  }
}

@media (max-width: 380px){
  #ns-v70-journal-actionbar{
    gap: 8px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  #ns-v70-journal-actionbar button{
    min-height: 50px !important;
    font-size: 14px !important;
  }
  #ns-v70-journal-actionbar .ns-v70-submit{
    min-height: 56px !important;
    font-size: 15px !important;
  }
}
