/**
 * Listing cards UI – premium, modern (Airbnb-style).
 * Applies to Explore and any page that shows listing grids.
 * Child theme: mylisting-child. CSS only, no PHP/logic changes.
 */

/* -------------------------------------------------------------------------
   Hero / título grande (estilo “Compare instaladores…” – centralizado, destaque)
   ------------------------------------------------------------------------- */
.sm-explore-hero {
	background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 50%, #f8fafc 100%);
	background-size: cover;
	background-position: center;
	margin-bottom: 2rem;
	padding: 3rem 1rem;
	text-align: center;
	position: relative;
}

.sm-explore-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, 0.75);
	pointer-events: none;
}

.sm-explore-hero-inner {
	position: relative;
	z-index: 1;
	max-width: 800px;
	margin: 0 auto;
}

.sm-explore-hero-title {
	font-size: 1.75rem;
	font-weight: 700;
	margin: 0 0 0.5rem 0;
	line-height: 1.25;
	color: #0f172a;
	letter-spacing: -0.02em;
}

.sm-explore-hero-subtitle {
	font-size: 1rem;
	color: #64748b;
	margin: 0;
	line-height: 1.5;
	font-weight: 400;
}

@media (min-width: 768px) {
	.sm-explore-hero {
		padding: 4rem 1.5rem;
	}
	.sm-explore-hero-title {
		font-size: 2.5rem;
	}
	.sm-explore-hero-subtitle {
		font-size: 1.125rem;
	}
}

/* -------------------------------------------------------------------------
   Card container (all listing preview cards)
   ------------------------------------------------------------------------- */
.lf-item-container.listing-preview,
.grid-item .lf-item-container.listing-preview {
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	overflow: hidden;
	transition: all 0.25s ease;
}

.lf-item-container.listing-preview:hover,
.grid-item .lf-item-container.listing-preview:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
}

/* -------------------------------------------------------------------------
   Spacing inside card
   ------------------------------------------------------------------------- */
.listing-preview .lf-item-info,
.listing-preview .lf-item-info-2 {
	padding: 18px 20px 20px;
}

/* -------------------------------------------------------------------------
   Always show company name + verified icon (like template); address on hover
   ------------------------------------------------------------------------- */
/* Default: show at least title + check icon (70px visible); do not hide fully */
.grid-item .lf-item-container.listing-preview.lf-type-2 .lf-item-info-2,
.lf-item-container.listing-preview.lf-type-2 .lf-item-info-2,
.grid-item .lf-item-container.listing-preview .lf-item-info-2,
.lf-item-container.listing-preview .lf-item-info-2 {
	transform: translateY(calc(100% - 70px)) !important;
}
.lf-item-container.listing-preview.no-tagline.no-logo .lf-item-info-2,
.grid-item .lf-item-container.listing-preview.no-tagline.no-logo .lf-item-info-2 {
	transform: translateY(calc(100% - 70px)) !important;
}
/* Hover: slide up to show full block (address, etc.) */
.lf-item-container.listing-preview:hover .lf-item-info-2,
.grid-item .lf-item-container.listing-preview:hover .lf-item-info-2 {
	transform: translateY(0) !important;
}

.listing-preview .lf-item-info-2 h6 {
	margin-top: 6px;
	margin-bottom: 10px;
}

/* -------------------------------------------------------------------------
   Title typography
   - .lf-item-info (on image): white text
   - .lf-item-info-2 (white block): dark text so title is visible
   ------------------------------------------------------------------------- */
.listing-preview .lf-item-info h4.listing-preview-title,
.listing-preview .lf-item-info > h4 {
	font-weight: 600;
	font-size: 18px;
	color: #fff;
}
.listing-preview .lf-item-info-2 h4.listing-preview-title,
.listing-preview .lf-item-info-2 > h4 {
	font-weight: 600;
	font-size: 18px;
	color: #0f172a;
}

/* -------------------------------------------------------------------------
   Location / city – white on image, dark on white block
   ------------------------------------------------------------------------- */
.listing-preview .lf-item-info .lf-contact,
.listing-preview .lf-item-info .lf-contact li {
	color: #fff;
	font-size: 14px;
}
.listing-preview .lf-item-info-2 .lf-contact,
.listing-preview .lf-item-info-2 .lf-contact li,
.listing-preview .lf-item-info-2 h6 {
	color: #475569;
	font-size: 14px;
	font-weight: 400;
}

/* -------------------------------------------------------------------------
   Badge (e.g. "Painel Solar", promoted badge)
   ------------------------------------------------------------------------- */
.listing-preview .lf-head .lf-head-btn,
.listing-preview .lf-head-btn.ad-badge {
	border-radius: 20px;
	padding: 4px 10px;
	font-size: 12px;
	font-weight: 500;
}

/* -------------------------------------------------------------------------
   Card image / background
   ------------------------------------------------------------------------- */
.listing-preview .lf-background {
	border-top-left-radius: 16px;
	border-top-right-radius: 16px;
	background-size: cover;
	background-position: center;
}

.listing-preview .pc-slider,
.listing-preview .pc-slider .single-slide,
.listing-preview .pc-slides img.single-slide {
	border-top-left-radius: 16px;
	border-top-right-radius: 16px;
	object-fit: cover;
}

/* Fallback image rotation (listings without featured image) */
.listing-fallback-image {
	object-fit: cover;
	height: 100%;
	width: 100%;
}

/* -------------------------------------------------------------------------
   Grid spacing (gap between cards)
   ------------------------------------------------------------------------- */
.results-view .grid-item,
.fc-type-2-results .grid-item,
.row.results-view .grid-item {
	margin-bottom: 24px;
}

/* -------------------------------------------------------------------------
   Pagination – active page
   ------------------------------------------------------------------------- */
nav.job-manager-pagination ul li span.current {
	background: #facc15;
	color: #111;
	border-radius: 50%;
	min-width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
}

nav.job-manager-pagination ul li a {
	border-radius: 50%;
	min-width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

/* -------------------------------------------------------------------------
   Explore sidebar: avoid "Localização" label overlapping the city name
   (Location filter uses floating label; when value is set it can overlap)
   ------------------------------------------------------------------------- */
.finder-search .explore-filter.location-filter.md-group label,
.finder-search .explore-filter.location-filter.md-group input:focus ~ label,
.finder-search .explore-filter.location-filter.md-group input:valid ~ label {
	top: 0;
	transform: none;
}

/* Remove the (i) icon that overlaps "Localização" label – user requested "tire o i" */
.finder-search .explore-filter.location-filter .geocode-location,
.finder-search .explore-filter.location-filter .icon-location-user {
	display: none;
}
