/*
 * @package     Joomla.Site
 * @subpackage  mod_categoryarticles
 *
 * Neutral, generic module styling.
 */

.mod-ca {
  width: 100%;
}

.mod-ca-group + .mod-ca-group {
  margin-top: 1.25rem;
}

.mod-ca-title {
  margin: 0 0 0.75rem 0;
  font-size: 1.15rem;
  line-height: 1.3;
}

.mod-ca-title__link {
  text-decoration: none;
}

.mod-ca-grid {
  display: grid;
  gap: 1rem;
}

.mod-ca-cols-1 .mod-ca-grid { grid-template-columns: 1fr; }
.mod-ca-cols-2 .mod-ca-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.mod-ca-cols-3 .mod-ca-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mod-ca-cols-4 .mod-ca-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 992px) {
  .mod-ca-cols-3 .mod-ca-grid,
  .mod-ca-cols-4 .mod-ca-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 576px) {
  .mod-ca-cols-2 .mod-ca-grid,
  .mod-ca-cols-3 .mod-ca-grid,
  .mod-ca-cols-4 .mod-ca-grid { grid-template-columns: 1fr; }
}

.mod-ca-card {
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 0.75rem;
  overflow: hidden;
  background: transparent;
}

.mod-ca-card__media {
  display: block;
  overflow: hidden;
}

.mod-ca-card__media img {
  width: 100%;
  height: auto;
  display: block;

  /* hover animation */
  transform: scale(1);
  transition: transform 180ms ease;
  will-change: transform;
}

/* Zoom effect on hover (mouse) */
.mod-ca-card:hover .mod-ca-card__media img {
  transform: scale(1.05);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .mod-ca-card__media img {
    transition: none;
  }
}

.mod-ca-card__body {
  padding: 0.9rem 1rem 1rem;
}

.mod-ca-card__title {
  margin: 0 0 0.4rem 0;
  font-size: 1.05rem;
  line-height: 1.35;
}

.mod-ca-card__title a {
  text-decoration: none;
}

.mod-ca-card__meta {
  font-size: 0.85rem;
  opacity: 0.8;
  margin-bottom: 0.5rem;
}

.mod-ca-card__text {
  margin: 0;
  line-height: 1.5;
}

/* Accordion/Tabs wrappers stay neutral; templates provide markup */
.mod-ca-accordion .mod-ca-acc-item + .mod-ca-acc-item { margin-top: 0.5rem; }
.mod-ca-tabs .mod-ca-tablist { display: flex; gap: 0.5rem; flex-wrap: wrap; }

.mod-ca-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.75rem;
}

.mod-ca-list__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem;
  align-items: start;
}

.mod-ca-thumb {
  display: block;
  width: 96px;
  border-radius: 0.5rem;
  overflow: hidden;
}

.mod-ca-thumb img {
  width: 96px;
  height: 64px;
  object-fit: cover;
  display: block;
  transform: scale(1);
  transition: transform 180ms ease;
  will-change: transform;
}

.mod-ca-thumb:hover img {
  transform: scale(1.05);
}

@media (prefers-reduced-motion: reduce) {
  .mod-ca-thumb img { transition: none; }
}

.mod-ca-list__title {
  font-weight: 600;
  text-decoration: none;
}

.mod-ca-list__meta {
  font-size: 0.85rem;
  opacity: 0.8;
  margin-top: 0.15rem;
}

.mod-ca-list__text {
  margin-top: 0.25rem;
  line-height: 1.45;
}


/* Mixed feed: category badge */
.mod-ca-card__badge{
  position:absolute;
  top:10px;
  left:10px;
  z-index:2;
  font-size:12px;
  line-height:1;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  color:#fff;
  backdrop-filter: blur(4px);
}

.mod-ca-card__badge a{
  color:inherit;
  text-decoration:none;
}
