/* ═══════════════════════════════════════
   9b. APP — Preview Dokumen Mobile
   Masalah: Dokumen A4 terpotong di mobile
   Solusi: Horizontal scroll + pinch-to-zoom
   PENTING: HANYA untuk app dengan struktur .app-body
   DASHBOARD: Ini CSS TIDAK boleh affect dashboard
   ═══════════════════════════════════════ */

/* Tablet & Mobile: Panel preview scroll horizontal */
/* GUARD: Hanya apply jika ada element dengan class app-body yang punya panel-right */
@media (max-width: 768px) {
  /* Override overflow:hidden di app-body - tapi JIKA ada panel-right */
  body:has(.app-body .panel-right) .app-body {
    overflow: visible !important;
  }

  body:has(.app-body .panel-right) .app-body .panel-right {
    overflow-x: auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* Document preview tidak di-constrain */
  body:has(.app-body .panel-right) .app-body .panel-right #document-preview,
  body:has(.app-body .panel-right) .app-body .panel-right .document-preview,
  body:has(.app-body .panel-right) .app-body .panel-right .preview-container {
    min-width: 800px !important;
    max-width: none !important;
    width: auto !important;
  }

  /* element .page */
  body:has(.app-body .panel-right) .app-body .panel-right #document-preview .page,
  body:has(.app-body .panel-right) .app-body .panel-right .document-preview .page,
  body:has(.app-body .panel-right) .app-body .panel-right .preview-container .page {
    min-width: 800px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* Override inline style pada .panel-content */
  body:has(.app-body .panel-right) .app-body .panel-right .panel-content[style*="overflow-y"] {
    overflow-x: auto !important;
    overflow-y: auto !important;
  }

  /* Empty state */
  body:has(.app-body .panel-right) .app-body .panel-right .preview-empty-state {
    min-width: 100% !important;
    width: 100% !important;
    max-width: none !important;
  }

  /* Container utama */
  body:has(.app-body .panel-right) .app-body .panel-right .panel-content,
  body:has(.app-body .panel-right) .app-body .panel-right #preview-container {
    min-width: auto !important;
    width: 100% !important;
    max-width: none !important;
  }

  /* Indicator scroll */
  body:has(.app-body .panel-right) .app-body .panel-right::after {
    content: '← geser untuk lihat lengkap →';
    display: block;
    text-align: center;
    font-size: 10px;
    color: var(--ink-faint, var(--color-text-muted));
    padding: 6px 4px;
    font-family: var(--ui-font, system-ui, sans-serif);
    background: var(--paper-warm, var(--color-bg-section));
    border-top: 1px solid var(--rule-dark, var(--color-border-panel));
    position: sticky;
    bottom: 0;
    z-index: 10;
  }
}

/* FIX UNTUK DASHBOARD: Pastikan main-content bisa di-scroll di mobile */
@media (max-width: 768px) {
  /* Hanya jika TIDAK ada .app-body (dashboard) */
  body:not(:has(.app-body)) .main-content {
    overflow-x: hidden;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
}

/* Desktop: Hide indicator - hanya untuk app dengan .panel-right */
@media (min-width: 769px) {
  body:has(.app-body .panel-right) .app-body .panel-right::after {
    display: none !important;
  }
}

/* ═══════════════════════════════════════
   10. APP — Editor Area Mobile
   ═══════════════════════════════════════ */

/* Mobile: Editor area lebih kecil */
@media (max-width: 768px) {
  .editor-area,
  .code-editor,
  textarea.editor {
    min-height: 200px !important;
    max-height: 400px;
  }
}

@media (max-width: 480px) {
  .editor-area,
  .code-editor,
  textarea.editor {
    min-height: 150px !important;
    max-height: 300px;
  }
}

/* ═══════════════════════════════════════
   11. APP — Modal Mobile
   ═══════════════════════════════════════ */

@media (max-width: 480px) {
  .modal-content,
  .modal-dialog,
  .dialog-box {
    width: 95vw !important;
    max-width: 95vw !important;
    margin: 1rem auto;
    max-height: 90vh;
    overflow-y: auto;
  }

  .modal-header {
    padding: 12px 16px;
  }

  .modal-body {
    padding: 16px;
  }

  .modal-footer {
    padding: 12px 16px;
  }
}

/* ═══════════════════════════════════════
   9c. APP — Fullscreen Preview Modal
   Untuk lihat dokumen A4 utuh di mobile
   ═══════════════════════════════════════ */

/* Mobile only: Fullscreen button */
@media (max-width: 768px) {
  .panel-right .fullscreen-btn {
    display: flex !important;
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--ui-bg, #f5f5f5);
    justify-content: flex-end;
    padding: 8px 12px;
    border-bottom: 1px solid var(--rule, #ddd);
  }

  .panel-right .fullscreen-btn button {
    display: flex !important;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 0.85rem;
    background: var(--ui-bg, #fff);
    border: 1px solid var(--rule-dark, #ccc);
    border-radius: 6px;
    cursor: pointer;
    color: var(--ink, #333);
    white-space: nowrap;
  }

  .panel-right .fullscreen-btn button:hover {
    background: var(--paper-warm, #f0f0f0);
  }

  /* Fullscreen overlay - PENTING: z-index tinggi agar di atas semua */
  .document-fullscreen-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #1a1a1a;
    z-index: 2147483647; /* Max z-index */
    overflow-x: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .document-fullscreen-overlay.active {
    display: block;
  }

  /* Fullscreen content - biarkan konten menentukan lebar */
  .document-fullscreen-overlay .fullscreen-content {
    width: 100%;
    min-width: 100%;
    min-height: 100vh;
    padding: 60px 16px 20px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    box-sizing: border-box;
  }

  /* Close button - PENTING: posisi fixed */
  .document-fullscreen-overlay .fullscreen-close {
    position: fixed;
    top: 12px;
    right: 12px;
    width: 44px;
    height: 44px;
    background: #fff;
    border: none;
    border-radius: 50%;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0,0,0,0.3);
    z-index: 2147483648;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Dokumen di fullscreen - PENTING: max-width none agar tidak terpotong */
  .document-fullscreen-overlay .page {
    width: 210mm !important;
    min-width: 210mm !important;
    max-width: none !important;
    margin: 0 auto;
    background: #fff;
    box-shadow: 0 4px 24px rgba(0,0,0,0.4);
    transform-origin: top center;
  }

  /* Pastikan semua element di dalam fullscreen tidak di-constrain */
  .document-fullscreen-overlay #document-preview,
  .document-fullscreen-overlay .document-preview,
  .document-fullscreen-overlay #preview-container {
    width: 100% !important;
    max-width: none !important;
    overflow: visible !important;
  }

  /* Empty state di fullscreen juga harus visible */
  .document-fullscreen-overlay .preview-empty-state {
    min-height: auto !important;
    height: auto !important;
    padding: 40px 20px !important;
  }
}

/* Desktop: Hide button */
@media (min-width: 769px) {
  .panel-right .fullscreen-btn {
    display: none !important;
  }
}

/* ═══════════════════════════════════════
   9d. APP — Fullscreen Document Scaling
   Scale dokumen agar muat di layar mobile
   PENTING: HANYA saat overlay active
   ═══════════════════════════════════════ */

/* Mobile: Scale dokumen agar muat (HANYA saat fullscreen active) */
@media (max-width: 768px) {
  /* Fullscreen dokumen - scale agar muat */
  /* PENTING: Selector .active agar TIDAK pengaruhi panel preview biasa */
  .document-fullscreen-overlay.active .page {
    /* Hanya max-width, TIDAK width: 100% atau min-width: unset */
    max-width: calc(100vw - 32px) !important;
    /* min-width tetap dari section 9c (210mm) */
    /* width tetap auto, dokumen akan shrink sesuai max-width */
  }

  /* Container fullscreen - biarkan responsif */
  .document-fullscreen-overlay.active .fullscreen-content {
    align-items: center;
    padding: 60px 8px 20px 8px;
  }

  /* Preview containers di fullscreen */
  .document-fullscreen-overlay.active #document-preview,
  .document-fullscreen-overlay.active .document-preview {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /* Note: Jangan paksa overflow-x hidden di fullscreen agar konten tidak terpotong. */
}

/* Print: Kembalikan ke ukuran normal */
@media print {
  .document-fullscreen-overlay .page {
    width: 210mm !important;
    max-width: none !important;
    transform: none !important;
  }
}

/* ═══════════════════════════════════════
   DASHBOARD — Fix Alur Container Tablet Kecil
   Kasus: viewport <= 1024 dan area main sempit (sidebar aktif)
   Solusi: paksa alur jadi horizontal-scroll agar tidak terpotong
   ═══════════════════════════════════════ */

@media (max-width: 1024px) {
  body[data-app="dashboard"] .alur-container {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  body[data-app="dashboard"] .alur-flow {
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    gap: 6px !important;
    padding-bottom: 8px !important;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }

  body[data-app="dashboard"] .alur-item,
  body[data-app="dashboard"] .alur-connector {
    flex-shrink: 0 !important;
  }
}

/* ═══════════════════════════════════════
   DASHBOARD COMPACT MODE
   Mode kompak apps-grid di dashboard - AUTO di mobile
   ═══════════════════════════════════════ */

@media (max-width: 768px) {
  /* Compact mode untuk apps-grid - langsung aktif tanpa perlu klik */
  .apps-grid {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .apps-grid .app-card {
    flex: 0 0 calc(50% - 4px) !important;
    padding: 10px !important;
    flex-direction: row !important;
    gap: 8px !important;
  }

  .apps-grid .app-card-icon {
    width: 32px !important;
    height: 32px !important;
    font-size: 16px !important;
  }

  .apps-grid .app-card-info {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .apps-grid .app-card-name {
    font-size: 0.85rem !important;
  }

  .apps-grid .app-card-desc {
    display: none !important;
  }

  .apps-grid .app-card-footer {
    display: none !important;
  }
}
