/*
  Freedom (Omeka S) – Item Sets Grid Override
  ------------------------------------------------
  What this does:
  - Forces the Item Sets browse page (/item-set) into a responsive card grid.
  - Keeps the rest of the site untouched.

  How to use (choose one):
  A) CSS Editor module: paste the contents of this file.
  B) Theme file: save as /themes/freedom/asset/css/item-sets-grid.css and enqueue it.

  Notes:
  - Selectors are intentionally redundant to accommodate slightly different body-class conventions.
  - If your install uses a different wrapper than .resource-list/.resource, inspect the page and
    adjust the selectors accordingly.
*/

:root {
  /* Tweak these to taste */
  --is-grid-min: 16rem;      /* minimum card width */
  --is-grid-gap: 1.25rem;    /* space between cards */
  --is-card-pad: 1rem;       /* inner card padding */
  --is-card-radius: 0.5rem;  /* card corner rounding */
  --is-card-border: rgba(0,0,0,.12);
  --is-card-shadow: 0 2px 10px rgba(0,0,0,.08);
  --is-card-shadow-hover: 0 6px 20px rgba(0,0,0,.14);
}

/* ----------
   1) Scope: ONLY Item Set browse pages
   (Omeka S typically adds body classes like "item-set" and "browse")
   ---------- */
body.item-set.browse .resource-list,
body.browse.item-set .resource-list,
body.resource.browse.item-set .resource-list,
body.site.item-set.browse .resource-list {
  /* Turn the list into a responsive grid */
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--is-grid-min), 1fr));
  gap: var(--is-grid-gap);

  / Reset common list styling */
  list-style: none;
  padding-left: 0;
  margin: 0;
}

/* Sometimes themes wrap the list in a container; keep it from adding odd spacing */
body.item-set.browse .resource-list > li,
body.browse.item-set .resource-list > li,
body.resource.browse.item-set .resource-list > li,
body.site.item-set.browse .resource-list > li {
  margin: 0;
}

/* ----------
   2) Card styling for each item set result
   Omeka commonly uses li.resource (or .resource) for each result.
   ---------- */
body.item-set.browse .resource-list .resource,
body.browse.item-set .resource-list .resource,
body.resource.browse.item-set .resource-list .resource,
body.site.item-set.browse .resource-list .resource {
  border: 1px solid var(--is-card-border);
  border-radius: var(--is-card-radius);
  overflow: hidden;
  background: #fff;
  height: 100%;

  /* Create a vertical layout so title/description align nicely */
  display: flex;
  flex-direction: column;
}

/* Make the whole card clickable when the title link wraps content */
body.item-set.browse .resource-list .resource > a,
body.browse.item-set .resource-list .resource > a,
body.resource.browse.item-set .resource-list .resource > a,
body.site.item-set.browse .resource-list .resource > a {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  text-decoration: none;
  color: inherit;
  height: 100%;
  padding: var(--is-card-pad);
}

/* If the markup is instead: .resource .resource-link, support that too */
body.item-set.browse .resource-list .resource .resource-link,
body.browse.item-set .resource-list .resource .resource-link,
body.resource.browse.item-set .resource-list .resource .resource-link,
body.site.item-set.browse .resource-list .resource .resource-link {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  text-decoration: none;
  color: inherit;
  height: 100%;
  padding: var(--is-card-pad);
}

/* Thumbnail treatment */
body.item-set.browse .resource-list .resource img,
body.browse.item-set .resource-list .resource img,
body.resource.browse.item-set .resource-list .resource img,
body.site.item-set.browse .resource-list .resource img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: calc(var(--is-card-radius) - 0.15rem);

  /* Create consistent tile look even with different image sizes */
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

/* Title: ensure it reads like a card heading */
body.item-set.browse .resource-list .resource h2,
body.item-set.browse .resource-list .resource h3,
body.browse.item-set .resource-list .resource h2,
body.browse.item-set .resource-list .resource h3,
body.resource.browse.item-set .resource-list .resource h2,
body.resource.browse.item-set .resource-list .resource h3 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.3;
}

/* Description (if present) should not blow up the card */
body.item-set.browse .resource-list .resource .description,
body.browse.item-set .resource-list .resource .description,
body.resource.browse.item-set .resource-list .resource .description {
  margin: 0;
  color: rgba(0,0,0,.72);
  font-size: 0.95rem;
  line-height: 1.4;

  / Clamp to keep cards visually consistent */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Push any counts/metadata to the bottom if they exist */
body.item-set.browse .resource-list .resource .meta,
body.browse.item-set .resource-list .resource .meta,
body.resource.browse.item-set .resource-list .resource .meta {
  margin-top: auto;
}

/* Hover/focus states for nicer UX */
body.item-set.browse .resource-list .resource:hover,
body.browse.item-set .resource-list .resource:hover,
body.resource.browse.item-set .resource-list .resource:hover {
  box-shadow: var(--is-card-shadow);
  transform: translateY(-1px);
  transition: box-shadow 160ms ease, transform 160ms ease;
}

body.item-set.browse .resource-list .resource:focus-within,
body.browse.item-set .resource-list .resource:focus-within,
body.resource.browse.item-set .resource-list .resource:focus-within {
  box-shadow: var(--is-card-shadow-hover);
  outline: 2px solid rgba(0, 95, 204, .35);
  outline-offset: 2px;
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  body.item-set.browse .resource-list .resource,
  body.browse.item-set .resource-list .resource,
  body.resource.browse.item-set .resource-list .resource {
    transition: none !important;
    transform: none !important;
  }
}

/* ----------
   3) Responsive refinements
   ---------- */
@media (max-width: 480px) {
  :root { --is-grid-min: 13.5rem; }
}
