/* =======================================================================
   SAREE – Restyle halaman ARCHIVE menjadi grid kartu (gaya "development")
   Basis      : OJS Default Theme (3.3.0.21)
   Sifat      : HANYA mengubah tata letak/tampilan halaman arsip.
                Warna MENGIKUTI tema saree yang sudah ada (tidak ditambah/diubah).
   Pemasangan : Settings > Website > Appearance > Setup > Additional CSS
                (atau file custom CSS tema). Tempel di paling bawah.
   Catatan     : selektor menyasar markup arsip tema default:
                .issues_archive > li > .obj_issue_summary
   ======================================================================= */

:root {
  --arc-gap:          22px;     /* jarak antar kartu               */
  --arc-radius:       10px;     /* radius sudut kartu              */
  --arc-cover-h:      250px;    /* tinggi area sampul              */
  --arc-card-bg:      #fff;     /* latar kartu (netral)            */
  --arc-border:       rgba(0,0,0,.10);
  --arc-shadow:       0 2px 10px rgba(0,0,0,.08);
  --arc-shadow-hover: 0 10px 24px rgba(0,0,0,.16);
  --arc-min:          210px;    /* lebar minimum kartu (atur kolom)*/
}

/* ---- judul halaman ---- */
.page_issue_archive > h1,
.cmp_issue_archive h1 { margin-bottom: 24px; }

/* ---- kontainer daftar -> GRID kartu ---- */
.issues_archive {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--arc-min), 1fr));
  gap: var(--arc-gap);
}
.issues_archive > li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ---- tiap issue -> KARTU ---- */
.issues_archive .obj_issue_summary {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--arc-card-bg);
  border: 1px solid var(--arc-border);
  border-radius: var(--arc-radius);
  overflow: hidden;
  box-shadow: var(--arc-shadow);
  transition: box-shadow .2s ease, transform .2s ease;
}
.issues_archive .obj_issue_summary:hover {
  box-shadow: var(--arc-shadow-hover);
  transform: translateY(-4px);
}

/* ---- area sampul ---- */
.issues_archive .obj_issue_summary .cover {
  display: block;
  margin: 0;
  width: 100%;
  height: var(--arc-cover-h);
  background: #f3f4f6;
  overflow: hidden;
}
.issues_archive .obj_issue_summary .cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;     /* sampul penuhi area, dipotong rapi */
  display: block;
}

/* ---- placeholder untuk issue TANPA sampul (butuh browser modern :has) ---- */
.issues_archive .obj_issue_summary:not(:has(.cover))::before {
  content: "No Cover";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: var(--arc-cover-h);
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .45;            /* abu lembut dari warna teks yang ada */
  background:
    repeating-linear-gradient(45deg,
      rgba(0,0,0,.03) 0 14px,
      rgba(0,0,0,.06) 14px 28px);
}

/* ---- judul + volume/nomor ---- */
.issues_archive .obj_issue_summary h2 {
  margin: 0;
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1 1 auto;          /* dorong agar tinggi kartu seragam */
  text-align: center;
  font-size: inherit;
}
.issues_archive .obj_issue_summary .title {
  font-size: 1rem;
  line-height: 1.35;
  font-weight: 600;
  /* warna mengikuti warna link tema saree (TIDAK diubah) */
}
.issues_archive .obj_issue_summary .series {
  font-size: .85rem;
  font-weight: 400;
  opacity: .7;             /* turunan warna teks yang sudah ada */
}
.issues_archive .obj_issue_summary .description {
  display: none;           /* sembunyikan deskripsi panjang di arsip */
}

/* ---- paginasi ---- */
.cmp_issue_archive .cmp_pagination,
.page_issue_archive .cmp_pagination {
  margin-top: 28px;
  text-align: center;
}

/* ---- responsif ---- */
@media (max-width: 767px) {
  :root { --arc-min: 150px; --arc-cover-h: 200px; --arc-gap: 14px; }
}
@media (max-width: 420px) {
  .issues_archive { grid-template-columns: repeat(2, 1fr); }
}
