/* =========================================================
   FILE READER — MINIMIZE BUTTON
========================================================= */

.gb-file-reader-minimize-btn {
  position: relative;
  z-index: 40;

  width: 30px !important;
  height: 30px !important;
  min-height: 30px !important;

  display: grid;
  place-items: center;

  padding: 0 !important;

  border-radius: 999px !important;

  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;

  cursor: pointer;
}

.gb-file-reader-minimize-btn:hover {
  transform: translateY(-1px);
}

/* =========================================================
   FILE READER — MINIMIZED ICON
========================================================= */

.gb-file-reader-minimized {
  position: relative;

  width: 96px;
  height: 76px;

  display: grid;
  place-items: center;
  gap: 4px;

  padding: 10px;

  border: 1px solid rgba(79, 163, 209, 0.48);
  border-radius: 22px;

  background:
    radial-gradient(circle at 50% 18%, rgba(79, 163, 209, 0.32), transparent 60%),
    linear-gradient(180deg, #17283c 0%, #0d1827 58%, #060b14 100%);

  color: rgba(235, 249, 255, 0.96);

  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.62),
    0 0 32px rgba(79, 163, 209, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.10),
    inset 0 -12px 24px rgba(0, 0, 0, 0.28);

  cursor: pointer;
  user-select: none;

  transform:
    translate3d(
      var(--gb-file-reader-icon-drag-x, 0px),
      var(--gb-file-reader-icon-drag-y, 0px),
      0
    );

  touch-action: auto;
}

.gb-file-reader-minimized[hidden] {
  display: none !important;
}

.gb-file-reader-minimized__icon {
  width: 42px;
  height: 32px;

  display: grid;
  place-items: center;

  border: 1px solid rgba(138, 216, 255, 0.34);
  border-radius: 12px;

  background:
    linear-gradient(
      180deg,
      rgba(79, 163, 209, 0.20),
      rgba(79, 163, 209, 0.08)
    );

  color: rgba(138, 216, 255, 0.96);

  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.05em;

  pointer-events: none;
}

.gb-file-reader-minimized__label {
  font-size: 0.68rem;
  line-height: 1;
  font-weight: 850;
  color: rgba(226, 246, 255, 0.86);

  pointer-events: none;
}

.gb-file-reader-minimized.is-file-reader-icon-draggable-ready {
  will-change: transform;
}

.gb-file-reader-minimized.is-file-reader-icon-dragging {
  cursor: grabbing;
  user-select: none;

  box-shadow:
    0 30px 76px rgba(0, 0, 0, 0.72),
    0 0 38px rgba(79, 163, 209, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -12px 24px rgba(0,0,0,0.34);
}

/* =========================================================
   FILE READER — PANEL DRAG HOST
========================================================= */

.file-reader-panel {
  transform:
    translate3d(
      var(--gb-file-reader-drag-x, 0px),
      var(--gb-file-reader-drag-y, 0px),
      0
    );

  touch-action: auto;
}

.file-reader-panel.is-file-reader-draggable-ready {
  will-change: transform;
}

.file-reader-panel.is-file-reader-dragging {
  cursor: grabbing;
  user-select: none;
}

/* =========================================================
   FILE READER — TOP MICRO HANDLE
========================================================= */

.gb-file-reader-drag-handle {
  position: absolute;
  top: 8px;
  left: 50%;

  width: 58px;
  height: 4px;

  border-radius: 999px;

  background:
    linear-gradient(
      90deg,
      transparent,
      rgba(138, 216, 255, 0.62),
      transparent
    );

  box-shadow:
    0 0 12px rgba(79, 163, 209, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.48);

  transform: translateX(-50%);

  cursor: grab;
  z-index: 50;
}

.file-reader-panel.is-file-reader-dragging .gb-file-reader-drag-handle {
  cursor: grabbing;
}

/* =========================================================
   FILE READER — PANEL DRAG PERIMETER
========================================================= */

:root {
  --gb-file-reader-drag-edge-size: 12px;
  --gb-file-reader-icon-drag-edge-size: 12px;
}

.gb-file-reader-drag-perimeter {
  position: absolute;
  inset: 0;
  z-index: 30;

  border-radius: inherit;

  /*
    Important:
    wrapper must not capture the workspace.
    Only edge children can receive pointer events.
  */
  pointer-events: none;
}

.gb-file-reader-drag-perimeter__edge {
  position: absolute;

  touch-action: none;
  user-select: none;
  cursor: grab !important;
}

.gb-file-reader-drag-perimeter__edge--top {
  top: 0;
  left: 0;
  right: 0;
  height: var(--gb-file-reader-drag-edge-size);
}

.gb-file-reader-drag-perimeter__edge--right {
  top: 0;
  right: 0;
  bottom: 0;
  width: var(--gb-file-reader-drag-edge-size);
}

.gb-file-reader-drag-perimeter__edge--bottom {
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--gb-file-reader-drag-edge-size);
}

.gb-file-reader-drag-perimeter__edge--left {
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--gb-file-reader-drag-edge-size);
}

.file-reader-panel.is-file-reader-dragging .gb-file-reader-drag-perimeter__edge {
  cursor: grabbing !important;
}

/* =========================================================
   FILE READER — MINIMIZED ICON DRAG PERIMETER
========================================================= */

.gb-file-reader-icon-drag-perimeter {
  position: absolute;
  inset: 0;
  z-index: 20;

  border-radius: inherit;

  /*
    Same principle:
    wrapper passes through; thin edges drag.
  */
  pointer-events: none;
}

.gb-file-reader-icon-drag-perimeter__edge {
  position: absolute;

  touch-action: none;
  user-select: none;
  cursor: grab !important;
}

.gb-file-reader-icon-drag-perimeter__edge--top {
  top: 0;
  left: 0;
  right: 0;
  height: var(--gb-file-reader-icon-drag-edge-size);
}

.gb-file-reader-icon-drag-perimeter__edge--right {
  top: 0;
  right: 0;
  bottom: 0;
  width: var(--gb-file-reader-icon-drag-edge-size);
}

.gb-file-reader-icon-drag-perimeter__edge--bottom {
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--gb-file-reader-icon-drag-edge-size);
}

.gb-file-reader-icon-drag-perimeter__edge--left {
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--gb-file-reader-icon-drag-edge-size);
}

.gb-file-reader-minimized.is-file-reader-icon-dragging
.gb-file-reader-icon-drag-perimeter__edge {
  cursor: grabbing !important;
}

/* =========================================================
   FILE READER — PROTECT INTERACTIVE CONTENT
========================================================= */

.file-reader-panel .module-header,
.file-reader-toolbar,
.file-reader-preview,
.pagination-panel,
.sanity-zone-file,
.file-reader-output,
#fileReaderOutput {
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* Internet Explorer 10+ */
  cursor: default;
}

.file-reader-panel .module-header *,
.file-reader-toolbar *,
.file-reader-preview *,
.pagination-panel *,
.sanity-zone-file *,
.file-reader-output *,
#fileReaderOutput * {
  cursor: auto;
}

.file-reader-panel button {
  cursor: pointer;
}

.file-reader-panel button:disabled {
  cursor: not-allowed;
}
/* =========================================================
   WIDGET LAYER — START LEFT / TOP OF WORKSPACE
========================================================= */

.zom-widget-layer {
  position: fixed;
  z-index: 240;

  top: 5px;
  left: calc(var(--app-rail-width, 0px) + 5px);
  right: auto;
  bottom: auto;

  width: auto;
  max-width: calc(100vw - var(--app-rail-width, 0px) - 10px);
  max-height: calc(100dvh - 10px);

  display: flex;
  justify-content: flex-start;
  align-items: flex-start;

  pointer-events: none !important;
}

.zom-widget-layer[hidden] {
  display: none !important;
}

.zom-widget {
  pointer-events: none !important;
}

.zom-widget[hidden] {
  display: none !important;
}

.zom-widget.is-active {
  pointer-events: none !important;
}

.zom-widget--genebean-file-reader {
  width: auto;
  max-width: none;
  pointer-events: none !important;
}

.zom-widget--genebean-file-reader .module-file-reader {
  pointer-events: none;
}

.zom-widget--genebean-file-reader .file-reader-panel,
.zom-widget--genebean-file-reader .gb-file-reader-minimized {
  pointer-events: auto;
}
/* =========================================================
   MOBILE SAFETY
========================================================= */

@media (max-width: 768px) {
  .file-reader-panel,
  .gb-file-reader-minimized {
    transform: none !important;
    touch-action: auto;
  }

  .gb-file-reader-drag-handle,
  .gb-file-reader-drag-perimeter,
  .gb-file-reader-icon-drag-perimeter {
    display: none !important;
  }

  .gb-file-reader-minimized {
    width: 88px;
    height: 68px;
  }
}