/* ==========================================================
   SASTIPE Deliverables Database
   ========================================================== */


/* Grid */

.sastipe-deliverables {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
  gap: 28px !important;
  margin: 32px 0 !important;
  align-items: stretch !important;
}


/* Cards */

.sastipe-card,
.sastipe-single-card {
  position: relative !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06) !important;
}

.sastipe-card {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
}

.sastipe-card-body {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  padding: 24px 26px 22px !important;
}


/* Preview image */

.sastipe-card-preview {
  width: 100% !important;
  height: 180px !important;
  max-height: 180px !important;
  background: #f8fafc !important;
  border-bottom: 1px solid #e2e8f0 !important;
  overflow: hidden !important;
}

.sastipe-card-preview:empty,
.sastipe-card-preview:not(:has(img)) {
  display: none !important;
}

.sastipe-card-preview img,
.sastipe-card-preview a img,
.sastipe-card-preview .img-fluid {
  width: 100% !important;
  max-width: 100% !important;
  height: 180px !important;
  max-height: 180px !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block !important;
  margin: 0 !important;
  border: 0 !important;
}


/* Metadata */

.sastipe-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
}

.sastipe-wp {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 5px 13px !important;
  border-radius: 999px !important;
  background: #e8f5e9 !important;
  color: #247a36 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

.sastipe-language {
  color: #667085 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
}


/* Title */

.sastipe-title {
  margin: 0 0 14px 0 !important;
  color: #1d2733 !important;
  font-size: 23px !important;
  line-height: 1.18 !important;
  font-weight: 800 !important;
}

.sastipe-title a {
  color: inherit !important;
  text-decoration: none !important;
}

.sastipe-title a:hover,
.sastipe-title a:focus {
  color: #087f72 !important;
  text-decoration: none !important;
}


/* Description: truncated only in list cards */

.sastipe-card .sastipe-description {
  color: #344054 !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  margin-bottom: 28px !important;

  display: -webkit-box !important;
  -webkit-line-clamp: 5 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}


/* Footer */

.sastipe-card-footer {
  margin-top: auto !important;
  padding-top: 8px !important;
  border-top: 0 !important;
}


/* PDF button */

.sastipe-file {
  width: 100% !important;
  display: block !important;
}

/* Hide Moodle's default file/PDF icon */
.sastipe-file img.icon,
.sastipe-file .icon,
.sastipe-file > img,
.sastipe-file > a:first-child img {
  display: none !important;
}

.sastipe-file a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 42px !important;
  padding: 10px 16px !important;
  border-radius: 10px !important;
  background: #087f72 !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 0 !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  border: 0 !important;
  box-shadow: none !important;
}

.sastipe-file a::after {
  content: "Download PDF" !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

.sastipe-file a:hover,
.sastipe-file a:focus {
  background: #05675d !important;
  color: #ffffff !important;
  text-decoration: none !important;
}


/* Floating manager controls */

.sastipe-admin-float {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  z-index: 5 !important;

  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;

  padding: 4px !important;
  border-radius: 11px !important;
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(226, 232, 240, 0.9) !important;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.10) !important;
}

/* Hide manager tools when Moodle outputs no edit/delete controls */
.sastipe-admin-float:not(:has(a)):not(:has(img)) {
  display: none !important;
}

.sastipe-admin-float a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px !important;
  height: 30px !important;
  padding: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: #475569 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.sastipe-admin-float a:hover,
.sastipe-admin-float a:focus {
  background: #f1f5f9 !important;
  color: #0f172a !important;
  text-decoration: none !important;
}

.sastipe-admin-float img,
.sastipe-admin-float img.icon,
.sastipe-admin-float .icon {
  width: 16px !important;
  height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 0.86 !important;
}


/* Single entry view */

.sastipe-single-card {
  max-width: 900px !important;
  margin: 32px auto !important;
}

.sastipe-single-preview {
  width: 100% !important;
  max-height: 380px !important;
  background: #f8fafc !important;
  border-bottom: 1px solid #e2e8f0 !important;
  overflow: hidden !important;
}

.sastipe-single-preview:empty,
.sastipe-single-preview:not(:has(img)) {
  display: none !important;
}

.sastipe-single-preview img,
.sastipe-single-preview a img,
.sastipe-single-preview .img-fluid {
  width: 100% !important;
  max-width: 100% !important;
  max-height: 380px !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block !important;
  margin: 0 !important;
  border: 0 !important;
}

.sastipe-single-body {
  padding: 30px 34px !important;
}

.sastipe-single-title {
  margin: 0 0 14px 0 !important;
  color: #1d2733 !important;
  font-size: 34px !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
}

.sastipe-single-card .sastipe-description {
  color: #344054 !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
  margin-bottom: 30px !important;

  display: block !important;
  overflow: visible !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
}

.sastipe-single-card .sastipe-file a {
  width: auto !important;
  min-width: 220px !important;
}


/* Manager upload/edit form */

.sastipe-entry-form {
  max-width: 780px !important;
}

.sastipe-form-row {
  margin-bottom: 20px !important;
}

.sastipe-form-row label {
  display: block !important;
  margin-bottom: 8px !important;
  color: #1d2733 !important;
  font-weight: 700 !important;
}


/* Mobile */

@media (max-width: 640px) {
  .sastipe-deliverables {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .sastipe-card-preview,
  .sastipe-card-preview img,
  .sastipe-card-preview a img,
  .sastipe-card-preview .img-fluid {
    height: 165px !important;
    max-height: 165px !important;
  }

  .sastipe-card-body,
  .sastipe-single-body {
    padding: 20px !important;
  }

  .sastipe-title {
    font-size: 22px !important;
  }

  .sastipe-file a,
  .sastipe-single-card .sastipe-file a {
    width: 100% !important;
    min-width: 0 !important;
  }

  .sastipe-single-title {
    font-size: 26px !important;
  }

  .sastipe-admin-float {
    top: 10px !important;
    right: 10px !important;
  }
}

/* Remove Moodle Database separator lines only */

#page-mod-data-view .container-fluid.tertiary-navigation.d-flex + hr,
#page-mod-data-view .datapreferences.my-5 + hr,
#page-mod-data-view form#options + hr {
  display: none !important;
}

/* Hide Moodle Database search/sort form controls only */

#page-mod-data-view form#options > .d-flex {
  display: none !important;
}

#page-mod-data-view form#options > div:has(#data_adv_form) {
  display: none !important;
}

#page-mod-data-view form#options {
  margin: 0 !important;
  padding: 0 !important;
  min-height: 0 !important;
}