/**
 * CSS frontend do widget Mousa Publicidade.
 *
 * @package MousaPublicidade
 * @since   1.0.0
 */

.mousa-publicidade-loop { display: flex; flex-direction: column; gap: 24px; }

/* Filtros */
.mousa-filters { padding: 16px; border-radius: 12px; background: #f8fafc; }
.mousa-filters__row { display: flex; flex-wrap: wrap; gap: 12px; align-items: stretch; }
.mousa-filters__field { flex: 1 1 160px; display: flex; min-width: 0; }
.mousa-filters__field--search { flex: 3 1 240px; }
.mousa-filters__field--select { flex: 1 1 160px; max-width: 240px; }
.mousa-filters__field--order { flex: 0 1 200px; max-width: 220px; }
.mousa-filters__field input,
.mousa-filters__field select { width: 100%; min-height: 36px; padding: 6px 10px; border: 1px solid #cbd5e1; border-radius: 8px; background: #fff; font: inherit; font-size: 13px; line-height: 1.3; color: #0f172a; }
.mousa-filters__field input:focus,
.mousa-filters__field select:focus { outline: none; border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37,99,235,.15); }
.mousa-filters__submit { min-height: 36px; padding: 6px 14px; border: 0; border-radius: 8px; background: #0f172a; color: #fff; font-size: 13px; font-weight: 500; cursor: pointer; }
.mousa-filters__submit:hover { background: #1e293b; }
.mousa-filters__clear { display: inline-flex; align-items: center; padding: 0; background: transparent; color: #475569; font-size: 13px; text-decoration: underline; text-underline-offset: 3px; }
.mousa-filters__clear:hover { color: #0f172a; }

.screen-reader-text { clip: rect(1px,1px,1px,1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; }

/* Grid */
.mousa-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 24px; }
@media (max-width: 1024px) { .mousa-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 640px) { .mousa-grid { grid-template-columns: 1fr; } }

/* Card */
.mousa-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; }
.mousa-card__image { height: 220px; overflow: hidden; background: #f1f5f9; }
.mousa-card__image a, .mousa-card__image { display: block; }
.mousa-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mousa-card__image-placeholder { display: block; width: 100%; height: 100%; background: linear-gradient(135deg,#f1f5f9 0%,#e2e8f0 100%); }

.mousa-card__body { padding: 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.mousa-card__categories { display: flex; flex-wrap: wrap; gap: 6px; }
.mousa-card__category { display: inline-flex; align-items: center; padding: 4px 10px; background: #e2e8f0; color: #0f172a; font-size: 12px; line-height: 1.2; border-radius: 999px; border: 1px solid transparent; }
.mousa-card__neighborhood { display: inline-flex; align-items: center; gap: 4px; color: #64748b; font-size: 13px; margin-bottom: 2px; }
.mousa-card__neighborhood svg { width: 14px; height: 14px; flex: 0 0 14px; color: inherit; }
.mousa-card__price-wrap { display: flex; flex-direction: column; gap: 0; }
.mousa-card__price-label { color: #94a3b8; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; }
.mousa-card__price { color: #0f172a; font-size: 22px; font-weight: 700; line-height: 1.2; }
.mousa-card__specs { display: flex; flex-wrap: wrap; gap: 6px; }
.mousa-card__spec { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; background: #f1f5f9; color: #475569; border-radius: 999px; font-size: 12px; line-height: 1.3; }
.mousa-card__spec svg { width: 16px; height: 16px; flex: 0 0 16px; color: #2563eb; }
.mousa-card__title { margin: 0; font-size: 18px; line-height: 1.3; color: #0f172a; }
.mousa-card__title a { color: inherit; text-decoration: none; }
.mousa-card__title a:hover { color: #2563eb; }
.mousa-card__excerpt { margin: 0; color: #475569; font-size: 14px; line-height: 1.5; }
.mousa-card__footer { display: flex; margin-top: auto; }
.mousa-card__button { display: inline-flex; align-items: center; justify-content: center; padding: 10px 18px; background: #2563eb; color: #fff; text-decoration: none; border: 1px solid transparent; border-radius: 8px; font-weight: 500; transition: background .15s; }
.mousa-card__button:hover { background: #1d4ed8; }

/* Empty */
.mousa-empty { padding: 32px; background: #f8fafc; border: 1px dashed #cbd5e1; border-radius: 12px; text-align: center; color: #475569; }

/* Pagination */
.mousa-pagination { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 6px; }
.mousa-pagination a, .mousa-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; padding: 8px 14px; background: #f1f5f9; color: #334155; border: 1px solid transparent; border-radius: 8px; text-decoration: none; font-size: 14px; }
.mousa-pagination a:hover { background: #e2e8f0; }
.mousa-pagination .is-active { background: #2563eb; color: #fff; }
.mousa-pagination__dots { background: transparent !important; }
