/* Media Library admin page (/admin/media). Everything is scoped under
   #adminMediaLibrary (page) and #mlibEditPanel / #mlibDeleteModal (overlays)
   so this file can ride the global bundle without leaking. */
#adminMediaLibrary {
  --mlib-brand: #09083a;
  --mlib-brand-hover: #12114e;
  --mlib-surface: var(--bs-body-bg, #fff);
  --ml-image: #0e7c6b;
  --ml-video: #b3324b;
  --ml-audio: #5b3fa8;
  --ml-document: #a86b1f;
  --ml-file: #475569;
}
#adminMediaLibrary [data-type=image] {
  --t: var(--ml-image);
}
#adminMediaLibrary [data-type=video] {
  --t: var(--ml-video);
}
#adminMediaLibrary [data-type=audio] {
  --t: var(--ml-audio);
}
#adminMediaLibrary [data-type=document] {
  --t: var(--ml-document);
}
#adminMediaLibrary [data-type=file] {
  --t: var(--ml-file);
}
#adminMediaLibrary .mlib-subtitle {
  font-size: 0.9rem;
}
#adminMediaLibrary .mlib-count-badge {
  background: color-mix(in srgb, var(--mlib-brand) 10%, var(--mlib-surface));
  color: var(--mlib-brand);
  font-size: 0.85rem;
  font-weight: 600;
  vertical-align: middle;
}
#adminMediaLibrary {
  /* ---------------- Type pill rail ---------------- */
}
#adminMediaLibrary .mlib-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--bs-border-color);
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--bs-body-color);
  background: transparent;
  transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}
#adminMediaLibrary .mlib-pill:hover {
  background: color-mix(in srgb, var(--mlib-brand) 6%, transparent);
}
#adminMediaLibrary .mlib-pill.active {
  background: var(--mlib-brand);
  border-color: var(--mlib-brand);
  color: #fff;
}
#adminMediaLibrary .mlib-pill.active .mlib-dot {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.35);
}
#adminMediaLibrary .mlib-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex: 0 0 auto;
}
#adminMediaLibrary [data-dot=image] {
  background: var(--ml-image);
}
#adminMediaLibrary [data-dot=video] {
  background: var(--ml-video);
}
#adminMediaLibrary [data-dot=audio] {
  background: var(--ml-audio);
}
#adminMediaLibrary [data-dot=document] {
  background: var(--ml-document);
}
#adminMediaLibrary [data-dot=file] {
  background: var(--ml-file);
}
#adminMediaLibrary {
  /* ---------------- Sticky toolbar ---------------- */
}
#adminMediaLibrary .mlib-stick-sentinel {
  height: 1px;
}
#adminMediaLibrary .mlib-toolbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--mlib-surface);
  transition: box-shadow 200ms ease;
}
#adminMediaLibrary .mlib-toolbar.is-stuck {
  border-bottom: 1px solid var(--bs-border-color);
  box-shadow: 0 4px 8px -4px rgba(9, 8, 58, 0.08);
}
#adminMediaLibrary .mlib-toolbar.is-stuck .mlib-toolbar-upload {
  display: inline-flex;
}
#adminMediaLibrary .mlib-toolbar-upload {
  display: none;
  width: 31px;
  height: 31px;
  align-items: center;
  justify-content: center;
  padding: 0;
  animation: mlibFadeIn 150ms ease;
}
#adminMediaLibrary .mlib-search {
  width: clamp(220px, 32vw, 360px);
}
#adminMediaLibrary .mlib-search .mlib-search-input {
  padding-left: 36px;
  padding-right: 36px;
}
#adminMediaLibrary .mlib-search .mlib-search-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bs-secondary-color);
  pointer-events: none;
}
#adminMediaLibrary .mlib-search .mlib-search-kbd {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  padding: 1px 6px;
  color: var(--bs-secondary-color);
  background: transparent;
  border: 1px solid var(--bs-border-color);
  border-radius: 4px;
  pointer-events: none;
  transition: opacity 120ms ease;
}
#adminMediaLibrary .mlib-search:focus-within .mlib-search-kbd {
  opacity: 0;
}
#adminMediaLibrary .mlib-search .mlib-search-clear {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  padding: 2px 8px;
  color: var(--bs-secondary-color);
  border: 0;
}
#adminMediaLibrary .mlib-search .mlib-search-clear:hover {
  color: var(--bs-body-color);
}
#adminMediaLibrary .mlib-view-toggle .btn {
  border: 1px solid var(--bs-border-color);
  color: var(--bs-secondary-color);
}
#adminMediaLibrary .mlib-view-toggle .btn.active {
  background: var(--mlib-brand);
  border-color: var(--mlib-brand);
  color: #fff;
}
#adminMediaLibrary {
  /* ---------------- Upload queue ---------------- */
}
#adminMediaLibrary .mlib-queue {
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--mlib-brand) 2%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-queue-row {
  position: relative;
  min-height: 36px;
  padding: 4px 2px 8px;
}
#adminMediaLibrary .mlib-queue-name {
  max-width: 50%;
}
#adminMediaLibrary .mlib-queue-pct {
  font-variant-numeric: tabular-nums;
  min-width: 38px;
  text-align: right;
}
#adminMediaLibrary .mlib-queue-bar {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  border-radius: 2px;
  background: var(--bs-border-color);
  overflow: hidden;
}
#adminMediaLibrary .mlib-queue-fill {
  height: 100%;
  width: 0;
  border-radius: 2px;
  background: var(--mlib-brand);
  transition: width 200ms linear;
}
#adminMediaLibrary .mlib-queue-fill.mlib-queue-fill-done {
  background: var(--bs-success);
}
#adminMediaLibrary .mlib-queue-fill.mlib-queue-fill-error {
  background: var(--bs-danger);
}
#adminMediaLibrary {
  /* ---------------- Grid + tiles ---------------- */
}
#adminMediaLibrary .mlib-content {
  min-height: 320px;
}
#adminMediaLibrary .mlib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
  padding-top: 12px;
}
#adminMediaLibrary .mlib-tile {
  position: relative;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--mlib-surface);
  box-shadow: 0 1px 3px rgba(9, 8, 58, 0.06);
  overflow: hidden;
  cursor: pointer;
  transition: transform 150ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 150ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
#adminMediaLibrary .mlib-tile:hover, #adminMediaLibrary .mlib-tile:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(9, 8, 58, 0.12);
}
#adminMediaLibrary .mlib-tile:focus-visible {
  outline: 2px solid var(--mlib-brand);
  outline-offset: 2px;
}
#adminMediaLibrary .mlib-tile.mlib-selected {
  box-shadow: 0 0 0 2px var(--mlib-brand);
}
#adminMediaLibrary .mlib-tile.mlib-active {
  box-shadow: 0 0 0 2px var(--mlib-brand), 0 6px 16px rgba(9, 8, 58, 0.12);
}
#adminMediaLibrary .mlib-tile.mlib-out {
  transform: scale(0.9);
  opacity: 0;
  transition: transform 180ms ease-in, opacity 180ms ease-in;
}
#adminMediaLibrary .mlib-tile.mlib-cascade {
  animation: mlibCascade 240ms cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: calc(var(--i, 0) * 24ms);
}
#adminMediaLibrary .mlib-tile.mlib-arrived {
  animation: mlibArrive 240ms cubic-bezier(0.16, 1, 0.3, 1) both, mlibHalo 1.5s ease-out 240ms;
}
#adminMediaLibrary .mlib-tile.mlib-arrived-reveal .mlib-overlay {
  opacity: 1;
}
#adminMediaLibrary .mlib-tile.mlib-arrived-reveal .mlib-ov-copy {
  animation: mlibPulse 700ms ease-in-out;
}
#adminMediaLibrary .mlib-tile.mlib-copy-ring {
  animation: mlibCopyRing 600ms ease-out;
}
#adminMediaLibrary .mlib-thumb {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bs-tertiary-bg, #f1f3f5);
}
#adminMediaLibrary .mlib-img {
  display: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 300ms ease-out;
}
#adminMediaLibrary .mlib-tile[data-type=image]:not(.mlib-img-broken) .mlib-img {
  display: block;
}
#adminMediaLibrary .mlib-tile[data-type=image]:not(.mlib-img-broken) .mlib-plate {
  display: none;
}
#adminMediaLibrary .mlib-tile:hover .mlib-img {
  transform: scale(1.03);
}
#adminMediaLibrary {
  /* Duotone type plate */
}
#adminMediaLibrary .mlib-plate {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, color-mix(in srgb, var(--t) 4%, transparent) 0 1px, transparent 1px 12px), color-mix(in srgb, var(--t) 8%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-chip {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--t) 14%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-chip i {
  font-size: 18px;
  color: var(--t);
}
#adminMediaLibrary .mlib-ext {
  position: absolute;
  left: 10px;
  bottom: 10px;
  font-family: var(--bs-font-monospace);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  color: var(--t);
  background: color-mix(in srgb, var(--t) 12%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-mono {
  position: absolute;
  right: -6px;
  bottom: -10px;
  font-size: 2.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: color-mix(in srgb, var(--t) 18%, transparent);
  user-select: none;
}
#adminMediaLibrary .mlib-play {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.85);
  align-items: center;
  justify-content: center;
  transition: transform 160ms ease;
}
#adminMediaLibrary .mlib-play i {
  font-size: 24px;
  color: var(--ml-video);
  margin-left: 2px;
}
#adminMediaLibrary .mlib-tile[data-type=video] .mlib-play {
  display: flex;
}
#adminMediaLibrary .mlib-tile[data-type=video]:hover .mlib-play {
  transform: translate(-50%, -50%) scale(1.08);
}
#adminMediaLibrary .mlib-wave {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  align-items: flex-end;
  gap: 3px;
  height: 24px;
}
#adminMediaLibrary .mlib-wave i {
  display: block;
  width: 3px;
  border-radius: 2px;
  background: var(--ml-audio);
  opacity: 0.35;
  transform-origin: bottom;
}
#adminMediaLibrary .mlib-wave i:nth-child(1) {
  height: 8px;
}
#adminMediaLibrary .mlib-wave i:nth-child(2) {
  height: 16px;
}
#adminMediaLibrary .mlib-wave i:nth-child(3) {
  height: 22px;
}
#adminMediaLibrary .mlib-wave i:nth-child(4) {
  height: 14px;
}
#adminMediaLibrary .mlib-wave i:nth-child(5) {
  height: 9px;
}
#adminMediaLibrary .mlib-tile[data-type=audio] .mlib-wave {
  display: flex;
}
#adminMediaLibrary .mlib-tile[data-type=audio]:hover .mlib-wave i {
  animation: mlibWave 600ms ease-in-out;
}
#adminMediaLibrary .mlib-tile[data-type=audio]:hover .mlib-wave i:nth-child(2) {
  animation-delay: 60ms;
}
#adminMediaLibrary .mlib-tile[data-type=audio]:hover .mlib-wave i:nth-child(3) {
  animation-delay: 120ms;
}
#adminMediaLibrary .mlib-tile[data-type=audio]:hover .mlib-wave i:nth-child(4) {
  animation-delay: 180ms;
}
#adminMediaLibrary .mlib-tile[data-type=audio]:hover .mlib-wave i:nth-child(5) {
  animation-delay: 240ms;
}
#adminMediaLibrary {
  /* Document dog-ear fold */
}
#adminMediaLibrary .mlib-tile[data-type=document] .mlib-plate::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 20px;
  height: 20px;
  background: linear-gradient(225deg, var(--mlib-surface) 0 50%, color-mix(in srgb, var(--t) 30%, var(--mlib-surface)) 50% 100%);
  border-bottom-left-radius: 6px;
  filter: drop-shadow(-1px 1px 1px rgba(0, 0, 0, 0.06));
}
#adminMediaLibrary .mlib-lock {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(9, 8, 58, 0.75);
  color: #fff;
  font-size: 11px;
}
#adminMediaLibrary .mlib-tile[data-type=document] .mlib-lock {
  right: 24px;
}
#adminMediaLibrary {
  /* Selection checkbox */
}
#adminMediaLibrary .mlib-check {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 120ms ease, transform 160ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
#adminMediaLibrary .mlib-check:checked {
  background-color: var(--mlib-brand);
  border-color: var(--mlib-brand);
}
#adminMediaLibrary .mlib-tile:hover .mlib-check,
#adminMediaLibrary .mlib-tile:focus-within .mlib-check, #adminMediaLibrary.mlib-selecting .mlib-check,
#adminMediaLibrary .mlib-check:checked {
  opacity: 1;
  transform: scale(1);
}
#adminMediaLibrary {
  /* Hover overlay actions */
}
#adminMediaLibrary .mlib-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 6px;
  padding: 8px;
  background: linear-gradient(transparent 55%, rgba(9, 8, 58, 0.55));
  opacity: 0;
  transition: opacity 150ms ease;
}
#adminMediaLibrary .mlib-tile:hover .mlib-overlay,
#adminMediaLibrary .mlib-tile:focus-within .mlib-overlay {
  opacity: 1;
}
@media (hover: none) {
  #adminMediaLibrary .mlib-overlay {
    opacity: 0.7;
  }
}
#adminMediaLibrary .mlib-ov-btn {
  width: 28px;
  height: 28px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #fff;
  color: var(--mlib-brand);
  border: 0;
  transition: transform 120ms ease, background-color 120ms ease;
}
#adminMediaLibrary .mlib-ov-btn:hover {
  background: #fff;
  color: var(--mlib-brand-hover);
  transform: scale(1.08);
}
#adminMediaLibrary .mlib-ov-btn i {
  font-size: 14px;
}
#adminMediaLibrary .mlib-ov-btn.mlib-ov-copy {
  width: 32px;
  height: 32px;
}
#adminMediaLibrary .mlib-ov-btn.mlib-ov-copy i {
  font-size: 17px;
}
#adminMediaLibrary .mlib-copied {
  color: var(--bs-success) !important;
  animation: mlibCopyPop 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
#adminMediaLibrary .mlib-caption {
  padding: 8px 10px 10px;
}
#adminMediaLibrary .mlib-caption .mlib-name {
  font-size: 13.5px;
  font-weight: 500;
}
#adminMediaLibrary .mlib-caption .mlib-meta {
  font-size: 12px;
}
#adminMediaLibrary {
  /* Anchored delete confirm */
}
#adminMediaLibrary .mlib-confirm {
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 8px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  background: var(--mlib-surface);
  border: 1px solid var(--bs-border-color);
  animation: mlibFadeIn 120ms ease;
}
#adminMediaLibrary .mlib-confirm span {
  margin-right: auto;
  font-weight: 600;
}
#adminMediaLibrary {
  /* ---------------- Skeletons ---------------- */
}
#adminMediaLibrary .mlib-skel {
  pointer-events: none;
}
#adminMediaLibrary .mlib-skel .mlib-thumb,
#adminMediaLibrary .mlib-skel .mlib-skel-line {
  background: linear-gradient(100deg, var(--bs-tertiary-bg, #f1f3f5) 40%, color-mix(in srgb, var(--bs-body-color) 5%, var(--bs-tertiary-bg, #f1f3f5)) 50%, var(--bs-tertiary-bg, #f1f3f5) 60%);
  background-size: 200% 100%;
  animation: mlibShimmer 1.4s linear infinite;
  animation-delay: calc(var(--i, 0) * 90ms);
}
#adminMediaLibrary .mlib-skel .mlib-skel-line {
  display: block;
  height: 12px;
  border-radius: 6px;
  margin-bottom: 6px;
}
#adminMediaLibrary .mlib-skel .mlib-skel-line-short {
  width: 55%;
  margin-bottom: 0;
}
#adminMediaLibrary {
  /* ---------------- Table view ---------------- */
}
#adminMediaLibrary .mlib-table tbody tr {
  cursor: pointer;
}
#adminMediaLibrary .mlib-table .mlib-th-check {
  width: 36px;
}
#adminMediaLibrary .mlib-table .mlib-th-thumb {
  width: 56px;
}
#adminMediaLibrary .mlib-row-thumb {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 6px;
  overflow: hidden;
  background: color-mix(in srgb, var(--t, var(--ml-file)) 10%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-row-thumb .mlib-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#adminMediaLibrary .mlib-row-thumb .mlib-row-icon {
  font-size: 17px;
  color: var(--t, var(--ml-file));
}
#adminMediaLibrary .mlib-row-names {
  max-width: 320px;
}
#adminMediaLibrary .mlib-table .mlib-check {
  position: static;
  opacity: 1;
  transform: none;
  width: 16px;
  height: 16px;
}
#adminMediaLibrary .mlib-row.mlib-selected {
  background: color-mix(in srgb, var(--mlib-brand) 6%, transparent);
}
#adminMediaLibrary .mlib-type-pill {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  padding: 2px 10px;
  border-radius: 999px;
  color: var(--t, var(--ml-file));
  background: color-mix(in srgb, var(--t, var(--ml-file)) 12%, var(--mlib-surface));
}
#adminMediaLibrary .mlib-private-text {
  font-weight: 500;
}
#adminMediaLibrary {
  /* ---------------- States ---------------- */
}
#adminMediaLibrary .mlib-empty {
  padding: 64px 24px;
}
#adminMediaLibrary .mlib-empty-copy {
  max-width: 420px;
}
#adminMediaLibrary .mlib-empty-art {
  display: flex;
  justify-content: center;
}
#adminMediaLibrary .mlib-empty-art .mlib-empty-plate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 88px;
  border-radius: 8px;
  font-size: 26px;
  box-shadow: 0 4px 12px rgba(9, 8, 58, 0.1);
  border: 1px solid var(--bs-border-color);
}
#adminMediaLibrary .mlib-empty-art .mlib-empty-plate[data-plate=image] {
  background: color-mix(in srgb, var(--ml-image) 15%, var(--mlib-surface));
  color: var(--ml-image);
  transform: rotate(-6deg) translateX(10px);
}
#adminMediaLibrary .mlib-empty-art .mlib-empty-plate[data-plate=video] {
  background: color-mix(in srgb, var(--ml-video) 15%, var(--mlib-surface));
  color: var(--ml-video);
  z-index: 1;
}
#adminMediaLibrary .mlib-empty-art .mlib-empty-plate[data-plate=audio] {
  background: color-mix(in srgb, var(--ml-audio) 15%, var(--mlib-surface));
  color: var(--ml-audio);
  transform: rotate(6deg) translateX(-10px);
}
#adminMediaLibrary .mlib-io-sentinel {
  height: 1px;
  width: 100%;
}
#adminMediaLibrary {
  /* ---------------- Selection command bar ---------------- */
}
#adminMediaLibrary .mlib-selectbar {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1080;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px 8px 18px;
  border-radius: 999px;
  background: var(--mlib-brand);
  color: #fff;
  box-shadow: 0 8px 24px rgba(9, 8, 58, 0.35);
  animation: mlibBarIn 200ms cubic-bezier(0.22, 1, 0.36, 1);
}
#adminMediaLibrary .mlib-selectbar-btn {
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 999px;
  white-space: nowrap;
}
#adminMediaLibrary .mlib-selectbar-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
#adminMediaLibrary .mlib-selectbar-danger {
  border-color: rgba(255, 130, 140, 0.55);
  color: #ffd2d6;
}
#adminMediaLibrary .mlib-selectbar-danger:hover {
  background: rgba(220, 53, 69, 0.35);
  color: #fff;
}
#adminMediaLibrary .mlib-count-pulse {
  animation: mlibCountPulse 150ms ease;
  display: inline-block;
}
#adminMediaLibrary {
  /* ---------------- Drop veil ---------------- */
}
#adminMediaLibrary .mlib-dropveil {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(9, 8, 58, 0.06);
  backdrop-filter: none;
  animation: mlibFadeIn 150ms ease;
  pointer-events: none;
}
#adminMediaLibrary .mlib-dropveil-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 40px 64px;
  border: 2px dashed var(--mlib-brand);
  border-radius: 16px;
  background: color-mix(in srgb, var(--mlib-surface) 92%, transparent);
  color: var(--mlib-brand);
  animation: mlibBorderPulse 1.4s ease-in-out infinite;
}
#adminMediaLibrary .mlib-dropveil-inner i {
  font-size: 40px;
  animation: mlibBob 1.4s ease-in-out infinite;
}

/* ---------------- Edit offcanvas ---------------- */
#mlibEditPanel {
  --mlib-brand: #09083a;
  --mlib-surface: var(--bs-body-bg, #fff);
  --ml-image: #0e7c6b;
  --ml-video: #b3324b;
  --ml-audio: #5b3fa8;
  --ml-document: #a86b1f;
  --ml-file: #475569;
  width: 400px;
  max-width: 92vw;
  box-shadow: -8px 0 24px rgba(9, 8, 58, 0.12);
}
#mlibEditPanel .mlib-panel-accent {
  height: 3px;
  flex: 0 0 auto;
  background: var(--ml-file);
}
#mlibEditPanel .mlib-panel-accent[data-type=image] {
  background: var(--ml-image);
}
#mlibEditPanel .mlib-panel-accent[data-type=video] {
  background: var(--ml-video);
}
#mlibEditPanel .mlib-panel-accent[data-type=audio] {
  background: var(--ml-audio);
}
#mlibEditPanel .mlib-panel-accent[data-type=document] {
  background: var(--ml-document);
}
#mlibEditPanel .mlib-panel-nav {
  width: 30px;
  height: 30px;
  padding: 0;
}
#mlibEditPanel [data-mlib-panel-body] {
  transition: opacity 120ms ease;
}
#mlibEditPanel [data-mlib-panel-body].mlib-panel-fading {
  opacity: 0.25;
}
#mlibEditPanel .mlib-panel-preview {
  text-align: center;
}
#mlibEditPanel .mlib-panel-preview img,
#mlibEditPanel .mlib-panel-preview video {
  max-width: 100%;
  max-height: 220px;
  border-radius: 8px;
  object-fit: contain;
  background: var(--bs-tertiary-bg, #f1f3f5);
}
#mlibEditPanel .mlib-preview-plate {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 140px;
  border-radius: 8px;
  background: var(--bs-tertiary-bg, #f1f3f5);
}
#mlibEditPanel .mlib-preview-plate i {
  font-size: 48px;
  color: var(--bs-secondary-color);
}
#mlibEditPanel .mlib-url-input,
#mlibEditPanel .mlib-mono-input {
  font-size: 12.5px;
}
#mlibEditPanel .mlib-panel-footer {
  background: var(--bs-body-bg);
}

/* ---------------- Dark mode token overrides ---------------- */
[data-bs-theme=dark] #adminMediaLibrary,
[data-bs-theme=dark] #mlibEditPanel {
  --ml-image: #38c7ab;
  --ml-video: #f4738c;
  --ml-audio: #b39bf0;
  --ml-document: #e0ab62;
  --ml-file: #9fb0c3;
}

/* ---------------- Keyframes ---------------- */
@keyframes mlibCascade {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes mlibArrive {
  from {
    opacity: 0;
    transform: scale(0.92);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes mlibHalo {
  0% {
    box-shadow: 0 0 0 0 rgba(9, 8, 58, 0.15);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(9, 8, 58, 0.15);
  }
  100% {
    box-shadow: 0 0 0 6px rgba(9, 8, 58, 0);
  }
}
@keyframes mlibCopyPop {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.25);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes mlibCopyRing {
  0% {
    box-shadow: 0 0 0 1px rgba(25, 135, 84, 0.7);
  }
  100% {
    box-shadow: 0 0 0 1px rgba(25, 135, 84, 0);
  }
}
@keyframes mlibPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.15);
  }
}
@keyframes mlibWave {
  0%, 100% {
    transform: scaleY(1);
  }
  40% {
    transform: scaleY(1.6);
  }
  70% {
    transform: scaleY(0.7);
  }
}
@keyframes mlibShimmer {
  from {
    background-position: 200% 0;
  }
  to {
    background-position: -200% 0;
  }
}
@keyframes mlibFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mlibBarIn {
  from {
    opacity: 0;
    transform: translate(-50%, 16px);
  }
  to {
    opacity: 1;
    transform: translate(-50%, 0);
  }
}
@keyframes mlibCountPulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes mlibBob {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}
@keyframes mlibBorderPulse {
  0%, 100% {
    border-color: rgba(9, 8, 58, 0.4);
  }
  50% {
    border-color: rgb(9, 8, 58);
  }
}
/* ---------------- Reduced motion ---------------- */
@media (prefers-reduced-motion: reduce) {
  #adminMediaLibrary *,
  #adminMediaLibrary *::before,
  #adminMediaLibrary *::after,
  #mlibEditPanel * {
    animation: none !important;
    transition: none !important;
  }
}

/*# sourceMappingURL=admin_media_library.css.map */
