/**
 * Mermaid.js — styling self-contained (tanpa bergantung CSS vars tema).
 * File ini hanya dimuat pada halaman yang memuat diagram (lihat
 * `layouts/_default/baseof.html`). Di-scope ke `pre.mermaid` saja
 * supaya aman disisipkan ke layout manapun.
 *
 * Sinkron dengan `bestpractice.unisbadri.com/_custom.scss` (bagian
 * Mermaid) — kalau salah satu di-update, idealnya yang lain ikut.
 *
 * Kontrak kelas:
 *  - `pre.mermaid`                     : kontainer diagram (sebelum render berisi teks sumber).
 *  - `pre.mermaid[data-processed]`     : sudah dirender jadi SVG.
 *  - `pre.mermaid[data-mm-enhanced]`   : toolbar & pan/zoom sudah dipasang.
 *  - `pre.mermaid.is-dragging`         : sedang di-drag (pan).
 *  - `pre.mermaid > .mermaid-toolbar`  : toolbar control (top-right).
 *  - `pre.mermaid .mermaid-btn`        : tombol individual.
 *  - `pre.mermaid .mermaid-zoom`       : label persentase zoom.
 *  - `pre.mermaid .mermaid-sep`        : separator vertikal di toolbar.
 *  - `[data-tooltip]`                  : tooltip teks custom (pengganti `title`).
 */

pre.mermaid {
  --mermaid-radius: 0.9rem;
  --mermaid-border: #e9ecef;
  --mermaid-border-strong: #d0d7de;
  --mermaid-bg-top: #f4f7fd;
  --mermaid-bg-bottom: #ffffff;
  --mermaid-shadow:
    0 8px 28px rgba(15, 23, 42, 0.06),
    0 1px 2px rgba(15, 23, 42, 0.04);
  --mermaid-toolbar-bg: rgba(255, 255, 255, 0.82);
  --mermaid-text: #0f172a;
  --mermaid-accent: #0055bb;
  --mermaid-accent-soft: rgba(0, 85, 187, 0.14);
  --mermaid-accent-strong: rgba(0, 85, 187, 0.35);

  position: relative;
  display: block;
  margin: 1.5rem 0;
  padding: 2.65rem 1.25rem 1.25rem;
  background: linear-gradient(
    180deg,
    var(--mermaid-bg-top) 0%,
    var(--mermaid-bg-bottom) 60%
  );
  border: 1px solid var(--mermaid-border);
  border-radius: var(--mermaid-radius);
  box-shadow: var(--mermaid-shadow);
  overflow: hidden;
  text-align: center;
  line-height: 1.4;
  font-size: 0.9rem;

  /* Sembunyikan teks sumber sebelum Mermaid selesai merender. */
  color: transparent;
  visibility: hidden;
}

pre.mermaid[data-processed="true"] {
  color: inherit;
  visibility: visible;
}

pre.mermaid svg {
  display: block;
  margin: 0 auto;
  max-width: 100%;
  height: auto;
  will-change: transform;
}

pre.mermaid[data-mm-enhanced="1"] svg {
  cursor: grab;
}

pre.mermaid.is-dragging,
pre.mermaid.is-dragging svg {
  cursor: grabbing;
  user-select: none;
}

pre.mermaid:focus-visible {
  outline: none;
  box-shadow:
    var(--mermaid-shadow),
    0 0 0 3px var(--mermaid-accent-strong);
}

/* ————————————————————————————————————————————————
   Toolbar: zoom in/out, indikator %, reset, export, fullscreen.
   ———————————————————————————————————————————————— */
pre.mermaid .mermaid-toolbar {
  position: absolute;
  top: 0.6rem;
  right: 0.65rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.3rem 0.38rem;
  border: 1px solid var(--mermaid-border);
  border-radius: 0.65rem;
  background: var(--mermaid-toolbar-bg);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
  user-select: none;
}

pre.mermaid .mermaid-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0.45rem;
  background: transparent;
  color: var(--mermaid-text);
  cursor: pointer;
  line-height: 0;
  transition: background 0.15s ease, color 0.15s ease;
}

pre.mermaid .mermaid-btn:hover,
pre.mermaid .mermaid-btn:focus-visible {
  background: var(--mermaid-accent-soft);
  color: var(--mermaid-accent);
  outline: none;
}

pre.mermaid .mermaid-btn:active {
  background: var(--mermaid-accent-strong);
}

pre.mermaid .mermaid-btn[disabled],
pre.mermaid .mermaid-btn[aria-busy="true"] {
  opacity: 0.55;
  cursor: progress;
  pointer-events: none;
}

/* Tooltip kustom: pakai `data-tooltip` (bukan `title`) supaya tidak
   bentrok dengan tooltip bawaan browser yang muncul lambat & tidak
   bisa distyle. */
pre.mermaid [data-tooltip] {
  position: relative;
}

pre.mermaid [data-tooltip]::after,
pre.mermaid [data-tooltip]::before {
  position: absolute;
  top: calc(100% + 0.45rem);
  left: 50%;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.14s ease, transform 0.14s ease;
  z-index: 3;
}

pre.mermaid [data-tooltip]::after {
  content: attr(data-tooltip);
  transform: translate(-50%, -2px);
  padding: 0.35rem 0.65rem;
  background: #0f172a;
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.01em;
  white-space: nowrap;
  border-radius: 0.4rem;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.22);
}

pre.mermaid [data-tooltip]::before {
  content: "";
  top: calc(100% + 0.15rem);
  transform: translate(-50%, -2px);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 5px solid #0f172a;
}

pre.mermaid [data-tooltip]:hover::after,
pre.mermaid [data-tooltip]:hover::before,
pre.mermaid .mermaid-btn:focus-visible[data-tooltip]::after,
pre.mermaid .mermaid-btn:focus-visible[data-tooltip]::before {
  opacity: 1;
  transform: translate(-50%, 0);
  transition-delay: 0.12s;
}

/* Tombol terakhir: tooltip ditarik ke dalam supaya tidak keluar kartu. */
pre.mermaid .mermaid-toolbar > [data-tooltip]:last-child::after {
  left: auto;
  right: 0;
  transform: translate(0, -2px);
}

pre.mermaid .mermaid-toolbar > [data-tooltip]:last-child:hover::after,
pre.mermaid .mermaid-toolbar > .mermaid-btn:focus-visible[data-tooltip]:last-child::after {
  transform: translate(0, 0);
}

pre.mermaid .mermaid-toolbar > [data-tooltip]:last-child::before {
  left: calc(100% - 1rem);
}

/* Tooltip off di HP — hover tidak konsisten & layar sempit. */
@media screen and (max-width: 40rem) {
  pre.mermaid [data-tooltip]::after,
  pre.mermaid [data-tooltip]::before {
    display: none;
  }
}

pre.mermaid .mermaid-btn--error {
  background: rgba(239, 68, 68, 0.18);
  color: #ef4444;
  animation: mermaid-btn-shake 0.32s ease;
}

@keyframes mermaid-btn-shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-3px); }
  75% { transform: translateX(3px); }
}

pre.mermaid .mermaid-btn svg {
  display: block;
  width: 18px;
  height: 18px;
  margin: 0;
  max-width: none;
  will-change: auto;
}

pre.mermaid .mermaid-zoom {
  min-width: 3rem;
  font-size: 0.82rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  color: var(--mermaid-accent);
  text-align: center;
  padding: 0 0.2rem;
}

pre.mermaid .mermaid-sep {
  width: 1px;
  height: 1.3rem;
  margin: 0 0.22rem;
  background: var(--mermaid-border-strong);
}

/* Fullscreen. */
pre.mermaid:fullscreen {
  border-radius: 0;
  border: 0;
  margin: 0;
  padding: 3.5rem 2rem 2rem;
  background: var(--mermaid-bg-bottom);
  display: flex;
  align-items: center;
  justify-content: center;
}

pre.mermaid:fullscreen svg {
  max-width: 100%;
  max-height: 100%;
}

pre.mermaid:fullscreen .mermaid-toolbar {
  top: 1rem;
  right: 1rem;
}

/* Typografi teks SVG — konsisten dengan body font. */
pre.mermaid svg .label,
pre.mermaid svg .nodeLabel,
pre.mermaid svg .edgeLabel,
pre.mermaid svg .titleText {
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, sans-serif;
}

/**
 * Rounded corner untuk node rectangle Mermaid. Dipakai via CSS property
 * `rx`/`ry` (didukung Chrome/Firefox/Safari modern) supaya node kotak
 * siku bawaan Mermaid tampak lebih lembut & selaras dengan container.
 */
pre.mermaid svg g.node rect,
pre.mermaid svg g.node .label-container,
pre.mermaid svg g.actor rect,
pre.mermaid svg rect.actor,
pre.mermaid svg g.note rect,
pre.mermaid svg rect.note,
pre.mermaid svg g.label-container rect {
  rx: 8px;
  ry: 8px;
}

pre.mermaid svg g.cluster rect,
pre.mermaid svg g.cluster .cluster-label rect {
  rx: 12px;
  ry: 12px;
}



pre.mermaid svg .edgeLabel rect,
pre.mermaid svg foreignObject .edgeLabel {
  rx: 6px;
  ry: 6px;
}

pre.mermaid svg g.node:not(.clickable):hover rect,
pre.mermaid svg g.node:not(.clickable):hover polygon,
pre.mermaid svg g.node:not(.clickable):hover circle,
pre.mermaid svg g.node:not(.clickable):hover path {
  filter: drop-shadow(0 2px 6px rgba(0, 85, 187, 0.18));
  transition: filter 0.2s ease;
}

/* ————————————————————————————————————————————————
   Dark mode — kompatibel dengan tema yang menaruh `theme-dark` atau
   `theme-is-dark` di `<html>`, atau `data-theme="dark"`.
   ———————————————————————————————————————————————— */
html.theme-dark pre.mermaid,
html.theme-is-dark pre.mermaid,
html[data-theme="dark"] pre.mermaid {
  --mermaid-border: rgba(255, 255, 255, 0.12);
  --mermaid-border-strong: rgba(255, 255, 255, 0.22);
  --mermaid-bg-top: #343a40;
  --mermaid-bg-bottom: #2a2f34;
  --mermaid-shadow:
    0 10px 32px rgba(0, 0, 0, 0.35),
    0 1px 2px rgba(0, 0, 0, 0.25);
  --mermaid-toolbar-bg: rgba(52, 58, 64, 0.82);
  --mermaid-text: #e9ecef;
  --mermaid-accent: #84b2ff;
  --mermaid-accent-soft: rgba(132, 178, 255, 0.18);
  --mermaid-accent-strong: rgba(132, 178, 255, 0.45);
}

html.theme-dark pre.mermaid [data-tooltip]::after,
html.theme-is-dark pre.mermaid [data-tooltip]::after,
html[data-theme="dark"] pre.mermaid [data-tooltip]::after {
  background: #f1f5f9;
  color: #0f172a;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
}

html.theme-dark pre.mermaid [data-tooltip]::before,
html.theme-is-dark pre.mermaid [data-tooltip]::before,
html[data-theme="dark"] pre.mermaid [data-tooltip]::before {
  border-bottom-color: #f1f5f9;
}

html.theme-dark pre.mermaid .mermaid-btn--error,
html.theme-is-dark pre.mermaid .mermaid-btn--error,
html[data-theme="dark"] pre.mermaid .mermaid-btn--error {
  background: rgba(248, 113, 113, 0.22);
  color: #fca5a5;
}

html.theme-dark pre.mermaid svg g.node:not(.clickable):hover rect,
html.theme-dark pre.mermaid svg g.node:not(.clickable):hover polygon,
html.theme-dark pre.mermaid svg g.node:not(.clickable):hover circle,
html.theme-dark pre.mermaid svg g.node:not(.clickable):hover path,
html.theme-is-dark pre.mermaid svg g.node:not(.clickable):hover rect,
html.theme-is-dark pre.mermaid svg g.node:not(.clickable):hover polygon,
html.theme-is-dark pre.mermaid svg g.node:not(.clickable):hover circle,
html.theme-is-dark pre.mermaid svg g.node:not(.clickable):hover path,
html[data-theme="dark"] pre.mermaid svg g.node:not(.clickable):hover rect,
html[data-theme="dark"] pre.mermaid svg g.node:not(.clickable):hover polygon,
html[data-theme="dark"] pre.mermaid svg g.node:not(.clickable):hover circle,
html[data-theme="dark"] pre.mermaid svg g.node:not(.clickable):hover path {
  filter: drop-shadow(0 2px 8px rgba(132, 178, 255, 0.35));
}

/* Responsif HP — padding & toolbar lebih ringkas. */
@media screen and (max-width: 40rem) {
  pre.mermaid {
    padding: 2.3rem 0.7rem 0.9rem;
    margin: 1.25rem 0;
    border-radius: 0.75rem;
  }

  pre.mermaid .mermaid-toolbar {
    top: 0.4rem;
    right: 0.4rem;
    padding: 0.18rem 0.22rem;
  }

  pre.mermaid .mermaid-btn {
    width: 1.55rem;
    height: 1.55rem;
  }

  pre.mermaid .mermaid-zoom {
    min-width: 2.1rem;
    font-size: 0.66rem;
  }
}
