.alphauzi-custom-list-post {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  display: flow-root;
  /*
   * Defaults untuk styling gambar (bisa di-override via CSS custom properties).
   * Contoh: .alphauzi-custom-list-post { --post-image-width: 220px; }
   */
  --post-image-gap: 16px;
  --post-image-hover-scale: 1.03;
  --custom-list-image-ratio: 3 / 4;
  --custom-list-image-width: 180px;
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, sans-serif;
  padding: 0;
  margin: 0 auto;
}

/* Elementor flex — sama pola dengan blog-list agar lebar mengikuti kolom (terutama tablet). */
.elementor-element[data-widget_type^="alphauzi_custom_list_post"] {
  min-width: 0;
  max-width: 100%;
  flex-shrink: 1;
  width: 100%;
  box-sizing: border-box;
}

.elementor-element[data-widget_type^="alphauzi_custom_list_post"] > .elementor-widget-container {
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}

.e-con:has(.alphauzi-custom-list-post),
.e-con-inner:has(.alphauzi-custom-list-post),
.e-con.e-flex:has(.alphauzi-custom-list-post),
.e-child:has(.alphauzi-custom-list-post) {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.elementor-widget-wrap:has(.alphauzi-custom-list-post) {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.elementor-widget-container:has(> .alphauzi-custom-list-post) {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.elementor-section .elementor-container:has(.alphauzi-custom-list-post),
.elementor-column:has(.alphauzi-custom-list-post),
.elementor-column-wrap:has(.alphauzi-custom-list-post) {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.alphauzi-custom-list-post .list-post-container {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-width: 0;
}

.alphauzi-custom-list-post .list-post-item {
  list-style: none;
  margin: 0 0 20px 0;
  padding: 0;
  box-sizing: border-box;
  --item-spacing: 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  column-gap: var(--post-image-gap, 16px);
}

.alphauzi-custom-list-post .list-post-item::before,
.alphauzi-custom-list-post .list-post-item::after {
  content: none !important;
  display: none !important;
}

.alphauzi-custom-list-post .list-post-item[style*="--item-spacing"],
.alphauzi-custom-list-post .list-post-item[data-item-spacing] {
  margin-bottom: var(--item-spacing, 20px) !important;
}

.alphauzi-custom-list-post .list-post-item[data-item-spacing] {
  margin-bottom: calc(var(--item-spacing, 20px) * 1px) !important;
}

.alphauzi-custom-list-post .list-post-item:last-child {
  margin-bottom: 0;
}

.alphauzi-custom-list-post .post-image {
  margin-bottom: 0;
  overflow: hidden;
  border-radius: 0;
  margin: 0;
  padding: 0;
  background: #fff;
  box-sizing: border-box;
  flex: 0 0 var(--custom-list-image-width, 180px);
  width: var(--custom-list-image-width, 180px);
  min-width: 0;
  max-width: var(--custom-list-image-width, 180px);
  height: auto;
  aspect-ratio: var(--custom-list-image-ratio, 3 / 4);
  align-self: flex-start;
}

.alphauzi-custom-list-post .post-image a {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
}

.alphauzi-custom-list-post .post-image .post-image-thumb {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  transition: transform 0.3s ease;
  border-radius: inherit;
}

.alphauzi-custom-list-post .post-category,
.alphauzi-custom-list-post .post-title {
  flex: 0 0 auto;
  min-width: 0;
}

.alphauzi-custom-list-post .post-text {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center; /* bikin category+title di tengah tinggi gambar */
}

.alphauzi-custom-list-post .list-post-item:hover .post-image .post-image-thumb {
  transform: scale(var(--post-image-hover-scale, 1.03));
}

.alphauzi-custom-list-post .post-category {
  font-size: 12px;
  letter-spacing: 1.5px;
  font-weight: 500;
  margin-bottom: 8px;
  text-transform: uppercase;
  color: #6f665b;
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --category-spacing: 8px;
}

.alphauzi-custom-list-post .post-category[style*="--category-spacing"],
.alphauzi-custom-list-post .post-category[data-category-spacing] {
  margin-bottom: var(--category-spacing, 8px) !important;
}

.alphauzi-custom-list-post .post-category[data-category-spacing] {
  margin-bottom: calc(var(--category-spacing, 8px) * 1px) !important;
}

.alphauzi-custom-list-post .post-title {
  margin: 0;
  padding: 0;
  font-size: 24px;
  line-height: 1.3;
  font-weight: 400;
  font-family: Georgia, "Times New Roman", serif;
  color: #000000;
  display: block;
  overflow-wrap: break-word;
  word-wrap: break-word;
  min-width: 0;
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
}

.alphauzi-custom-list-post .post-title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.3s ease;
  display: inline-block;
  line-height: inherit;
}

.alphauzi-custom-list-post .post-title a:hover {
  color: #6f665b;
}

.alphauzi-custom-list-post .post-separator {
  width: 100%;
  height: 1px;
  background-color: #6f665b;
  margin-top: 10px;
  display: block;
  flex: 0 0 100%;
  --separator-height: 1px;
  --separator-spacing: 10px;
}

.alphauzi-custom-list-post .post-separator[style*="--separator-height"],
.alphauzi-custom-list-post .post-separator[data-separator-height] {
  height: var(--separator-height, 1px) !important;
}

.alphauzi-custom-list-post .post-separator[data-separator-height] {
  height: calc(var(--separator-height, 1px) * 1px) !important;
}

.alphauzi-custom-list-post .post-separator[style*="--separator-spacing"],
.alphauzi-custom-list-post .post-separator[data-separator-spacing] {
  margin-top: var(--separator-spacing, 10px) !important;
}

.alphauzi-custom-list-post .post-separator[data-separator-spacing] {
  margin-top: calc(var(--separator-spacing, 10px) * 1px) !important;
}

/*
 * Mobile (≤600px): tinggi mengikuti konten; min-height:0 aman dengan reset mobile di bawah.
 */
@media (max-width: 600px) {
  .elementor-element[data-widget_type^="alphauzi_custom_list_post"] > .elementor-widget-container {
    display: block;
    height: fit-content;
    min-height: 0 !important;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .elementor-widget-alphauzi_custom_list_post .elementor-widget-container {
    height: fit-content;
    min-height: 0 !important;
  }

  .e-con:has(.alphauzi-custom-list-post),
  .e-con-inner:has(.alphauzi-custom-list-post),
  .e-child:has(.alphauzi-custom-list-post) {
    min-height: 0;
    justify-content: flex-start;
  }

  .elementor-column:has(.alphauzi-custom-list-post),
  .elementor-column-wrap:has(.alphauzi-custom-list-post) {
    justify-content: flex-start;
  }

  .elementor-widget-container:has(> .alphauzi-custom-list-post) {
    height: fit-content;
    min-height: 0 !important;
  }

  .alphauzi-custom-list-post {
    height: fit-content;
    min-height: 0;
    margin: 0;
  }
}

/*
 * Tablet saja (601–1024px): hindari min-height:0 + stretch flex yang memotong konten (tumpang tindih).
 * Tinggi = konten; overflow visible; item daftar tidak boleh “collapse” di bawah isi teks.
 */
@media (max-width: 1024px) and (min-width: 601px) {
  .elementor-element[data-widget_type^="alphauzi_custom_list_post"] {
    overflow: visible !important;
    min-height: auto !important;
    height: auto !important;
    max-height: none !important;
  }

  .elementor-widget-wrap:has(.alphauzi-custom-list-post) {
    align-items: flex-start;
    align-content: flex-start;
  }

  .elementor-column:has(.alphauzi-custom-list-post),
  .elementor-column-wrap:has(.alphauzi-custom-list-post) {
    align-items: flex-start;
  }

  .elementor-element[data-widget_type^="alphauzi_custom_list_post"] > .elementor-widget-container,
  .elementor-widget-alphauzi_custom_list_post .elementor-widget-container,
  .elementor-widget-container:has(> .alphauzi-custom-list-post) {
    display: block;
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .alphauzi-custom-list-post {
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    margin: 0;
  }

  .alphauzi-custom-list-post .list-post-container {
    flex: 0 1 auto;
    min-height: auto;
    overflow: visible;
  }

  /*
   * Grid (bukan flex nowrap): .post-separator punya flex-basis 100% — kalau dipaksa satu baris
   * dengan gambar+teks, layout pecah (teks turun / kolom kosong). Grid menempatkan separator
   * di baris kedua full width.
   */
  .alphauzi-custom-list-post .list-post-item {
    flex: 0 0 auto;
    min-height: auto;
    overflow: visible;
    display: grid !important;
    grid-template-columns: var(--custom-list-image-width, 180px) minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: var(--post-image-gap, 16px);
    row-gap: 0;
    align-items: center;
  }

  .alphauzi-custom-list-post .list-post-item:not(:has(.post-image)) {
    grid-template-columns: minmax(0, 1fr);
  }

  .alphauzi-custom-list-post .list-post-item:not(:has(.post-image)) .post-text {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .alphauzi-custom-list-post .list-post-item:not(:has(.post-image)) .post-separator {
    grid-column: 1 / -1;
    grid-row: 2;
  }

  .alphauzi-custom-list-post .post-image {
    grid-column: 1;
    grid-row: 1;
    width: var(--custom-list-image-width, 180px);
    max-width: var(--custom-list-image-width, 180px);
    flex: none;
    margin-bottom: 0;
    aspect-ratio: var(--custom-list-image-ratio, 3 / 4);
    align-self: center;
  }

  .alphauzi-custom-list-post .post-text {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
    width: auto;
  }

  .alphauzi-custom-list-post .post-separator {
    grid-column: 1 / -1;
    grid-row: 2;
    flex: none !important;
    width: 100% !important;
    max-width: none;
  }

  .alphauzi-custom-list-post .post-title {
    font-size: 22px;
  }

  .alphauzi-custom-list-post .post-title a {
    display: block;
  }

  .alphauzi-custom-list-post .post-category {
    font-size: 11px;
  }
}

/*
 * Tablet (portrait/preview Elementor): paksa widget full-width agar tidak muncul kolom kosong di kanan.
 * Elementor sering mengunci lebar via CSS variable (--container-widget-width), jadi perlu dioverride juga.
 */
@media (max-width: 1024px) and (min-width: 768px) {
  .elementor-element[data-widget_type^="alphauzi_custom_list_post"] {
    --container-widget-width: 100% !important;
    --container-widget-flex-grow: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    flex-basis: 100% !important;
    min-width: 100% !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
  }

  .e-con:has(.elementor-element[data-widget_type^="alphauzi_custom_list_post"]),
  .e-con-inner:has(.elementor-element[data-widget_type^="alphauzi_custom_list_post"]),
  .elementor-widget-wrap:has(.elementor-element[data-widget_type^="alphauzi_custom_list_post"]) {
    justify-content: flex-start !important;
  }

  .elementor-element[data-widget_type^="alphauzi_custom_list_post"] > .elementor-widget-container,
  .elementor-widget-container:has(> .alphauzi-custom-list-post),
  .alphauzi-custom-list-post,
  .alphauzi-custom-list-post .list-post-container {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  /* Lebar & gap gambar dari kontrol responsif Elementor (--custom-list-image-width, --post-image-gap). */
}

/* Responsive Styles - Mobile */
@media (max-width: 600px) {
  .elementor-widget-alphauzi_custom_list_post .elementor-widget-container,
  .elementor-widget-container .alphauzi-custom-list-post {
    margin: 0 !important;
    padding: 0 !important;
  }

  .alphauzi-custom-list-post .list-post-container {
    gap: 0 !important;
    row-gap: 0 !important;
    column-gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .alphauzi-custom-list-post .list-post-item {
    margin-top: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin-bottom: 15px;
    display: block !important;
  }

  .alphauzi-custom-list-post .post-text {
    display: block !important;
    width: 100% !important;
  }

  .alphauzi-custom-list-post .list-post-item:last-child {
    margin-bottom: 0 !important;
  }

  .alphauzi-custom-list-post .post-title {
    font-size: 20px !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    height: auto !important;
    -webkit-margin-before: 0 !important;
    -webkit-margin-after: 0 !important;
    -webkit-margin-start: 0 !important;
    -webkit-margin-end: 0 !important;
  }

  .alphauzi-custom-list-post .post-title a {
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
  }

  .alphauzi-custom-list-post .post-category {
    font-size: 11px !important;
    margin-top: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
    margin-bottom: 4px;
  }

  .alphauzi-custom-list-post .post-image {
    margin-bottom: 10px;
    border-radius: 0;
    width: var(--custom-list-image-width, 100%);
    max-width: min(100%, var(--custom-list-image-width, 100%));
    flex: 0 0 var(--custom-list-image-width, 100%);
    aspect-ratio: var(--custom-list-image-ratio, 3 / 4);
  }

  .alphauzi-custom-list-post .post-separator {
    margin-bottom: 0 !important;
    padding: 0 !important;
    margin-top: 8px;
    height: 1px;
  }
}

/* Extra Small Mobile */
@media (max-width: 480px) {
  .elementor-widget-alphauzi_custom_list_post .elementor-widget-container,
  .elementor-widget-container .alphauzi-custom-list-post {
    margin: 0 !important;
    padding: 0 !important;
  }

  .alphauzi-custom-list-post .list-post-container {
    gap: 0 !important;
    row-gap: 0 !important;
    column-gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .alphauzi-custom-list-post .list-post-item {
    margin-top: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin-bottom: 12px;
    display: block !important;
  }

  .alphauzi-custom-list-post .post-text {
    display: block !important;
    width: 100% !important;
  }

  .alphauzi-custom-list-post .list-post-item:last-child {
    margin-bottom: 0 !important;
  }

  .alphauzi-custom-list-post .post-title {
    font-size: 18px !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    height: auto !important;
    -webkit-margin-before: 0 !important;
    -webkit-margin-after: 0 !important;
    -webkit-margin-start: 0 !important;
    -webkit-margin-end: 0 !important;
  }

  .alphauzi-custom-list-post .post-title a {
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
  }

  .alphauzi-custom-list-post .post-category {
    font-size: 10px !important;
    margin-top: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
    margin-bottom: 4px;
  }

  .alphauzi-custom-list-post .post-image {
    margin-bottom: 8px;
    border-radius: 0;
    width: var(--custom-list-image-width, 100%);
    max-width: min(100%, var(--custom-list-image-width, 100%));
    flex: 0 0 var(--custom-list-image-width, 100%);
    aspect-ratio: var(--custom-list-image-ratio, 3 / 4);
  }

  .alphauzi-custom-list-post .post-separator {
    margin-bottom: 0 !important;
    padding: 0 !important;
    margin-top: 8px;
    height: 1px;
  }
}
