
.vg-fivodocs-wrapper {
  margin: 2rem 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* LIST – vertical stack */
.vg-fivodocs-layout-list .vg-fivodocs-items {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* GRID – same card, multiple columns */
.vg-fivodocs-layout-grid .vg-fivodocs-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0.75rem;
}

/* Card container */
.vg-fivodocs-item {
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.04);
  transition: box-shadow 0.15s ease, transform 0.15s ease, border-color 0.15s ease;
}

.vg-fivodocs-item:hover {
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
  border-color: #d1d5db;
}

/* Inner clickable pill */
.vg-fivodocs-pill {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.85rem 1.2rem;
  text-decoration: none;
}

/* Left icon */
.vg-fivodocs-pill-left {
  flex: 0 0 auto;
}

.vg-fivodocs-file-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px; /* soft radius */
  background: #f3f4f6;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vg-fivodocs-file-icon-img {
  max-width: 22px;
  max-height: 22px;
  object-fit: contain;
}

.vg-fivodocs-file-ext {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #6b7280;
}

/* Center content */
.vg-fivodocs-pill-center {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.vg-fivodocs-file-name {
  font-size: 0.95rem;
  font-weight: 500;
  color: #111827;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; /* single line with ellipsis */
}

/* Meta row – category + size */
.vg-fivodocs-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  color: #9ca3af;
}

.vg-fivodocs-file-size {
  margin-left: 0.5rem;
}

/* Category pill */
.vg-fivodocs-cat-pill {
  padding: 0.1rem 0.55rem;
  border-radius: 999px;
  background: #eef2ff;
  color: #4b5563;
  font-size: 0.7rem;
}

/* Right icons */
.vg-fivodocs-pill-right {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.vg-fivodocs-icon {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid #e5e7eb;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f9fafb;
}

.vg-fivodocs-icon-img {
  max-width: 16px;
  max-height: 16px;
  object-fit: contain;
}

/* Fallback CSS icons when no image is set */
.vg-fivodocs-icon-download:not(:has(img))::before,
.vg-fivodocs-icon-more:not(:has(img))::before {
  content: "";
  display: block;
}

/* Simple download arrow */
.vg-fivodocs-icon-download:not(:has(img))::before {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  border: 1.4px solid #9ca3af;
  border-top-color: transparent;
  border-left-color: transparent;
  transform: rotate(45deg) translateY(-1px);
  box-shadow: -3px 3px 0 0 #9ca3af;
}

/* Three vertical dots */
.vg-fivodocs-icon-more:not(:has(img))::before {
  width: 2px;
  height: 2px;
  border-radius: 999px;
  background: #9ca3af;
  box-shadow: 0 -4px 0 0 #9ca3af, 0 4px 0 0 #9ca3af;
}

/* Empty state */
.vg-fivodocs-empty {
  font-size: 0.9rem;
  color: #6b7280;
}

/* Admin icon table */
.vg-fivodocs-icons-table .vg-fivodocs-icon-preview {
  width: 40px;
  height: 40px;
  border-radius: 6px;
  background: #f3f4f6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.75rem;
}

.vg-fivodocs-icons-table .vg-fivodocs-icon-preview img {
  max-width: 24px;
  max-height: 24px;
  object-fit: contain;
}

.vg-fivodocs-icon-placeholder {
  font-size: 1.1rem;
  color: #9ca3af;
}
