/**
 * Getrix Immobili — CSS frontend
 *
 * Stili volutamente neutri e a basso peso. Usano variabili CSS così
 * il tema può sovrascriverle senza editare il file.
 */

.getrix-lista, .getrix-detail, .getrix-search, .getrix-slider {
	--gx-color-primary: #1a5d3a;
	--gx-color-accent:  #d4a017;
	--gx-color-text:    #222;
	--gx-color-muted:   #666;
	--gx-color-bg:      #fff;
	--gx-color-card:    #fff;
	--gx-color-border:  #e6e6e6;
	--gx-radius:        8px;
	--gx-shadow:        0 2px 6px rgba(0,0,0,.06);
	--gx-shadow-hover:  0 6px 18px rgba(0,0,0,.10);
	font-family: inherit;
	color: var(--gx-color-text);
	box-sizing: border-box;
}
.getrix-lista *, .getrix-detail *, .getrix-search *, .getrix-slider * { box-sizing: inherit; }

/* ---------- Grid lista ---------- */
.getrix-lista__count { color: var(--gx-color-muted); margin: 0 0 1rem; font-size: .9rem; }
.getrix-grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.getrix-cols-1 .getrix-grid { grid-template-columns: 1fr; }
.getrix-cols-2 .getrix-grid { grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); }
.getrix-cols-4 .getrix-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

/* ---------- Card immobile ---------- */
.getrix-card {
	background: var(--gx-color-card);
	border: 1px solid var(--gx-color-border);
	border-radius: var(--gx-radius);
	overflow: hidden;
	box-shadow: var(--gx-shadow);
	transition: transform .2s ease, box-shadow .2s ease;
	display: flex; flex-direction: column;
}
.getrix-card:hover { transform: translateY(-2px); box-shadow: var(--gx-shadow-hover); }
.getrix-card__media { position: relative; display: block; aspect-ratio: 4 / 3; overflow: hidden; background: #f3f3f3; }
.getrix-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.getrix-card__badge {
	position: absolute; top: .5rem; left: .5rem;
	background: var(--gx-color-primary); color: #fff;
	padding: .2rem .5rem; font-size: .75rem;
	border-radius: 999px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em;
}
.getrix-card__badge--evid { background: var(--gx-color-accent); color: #1a1a1a; right: .5rem; left: auto; }
.getrix-cat-vendita { background: #1a5d3a; }
.getrix-cat-affitto { background: #2557a7; }
.getrix-cat-affitto_vacanze { background: #b14a08; }
.getrix-cat-asta { background: #7a1a1a; }

.getrix-card__body { padding: .9rem 1rem 1rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.getrix-card__type { font-size: .8rem; text-transform: uppercase; color: var(--gx-color-muted); letter-spacing: .04em; }
.getrix-card__title { margin: 0; font-size: 1.05rem; line-height: 1.3; }
.getrix-card__title a { color: inherit; text-decoration: none; }
.getrix-card__title a:hover { color: var(--gx-color-primary); }
.getrix-card__location { margin: 0; font-size: .85rem; color: var(--gx-color-muted); }
.getrix-card__features { list-style: none; padding: 0; margin: .35rem 0 0; display: flex; flex-wrap: wrap; gap: .6rem; font-size: .85rem; color: #444; }
.getrix-card__feature::before { content: "• "; color: var(--gx-color-muted); }
.getrix-card__features li:first-child::before { content: ""; }

.getrix-card__footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: .75rem; border-top: 1px solid var(--gx-color-border); }
.getrix-card__price { font-weight: 700; color: var(--gx-color-primary); font-size: 1.1rem; }
.getrix-card__cta { color: var(--gx-color-primary); font-size: .9rem; text-decoration: none; font-weight: 600; }
.getrix-card__cta:hover { text-decoration: underline; }

/* ---------- Dettaglio ---------- */
.getrix-detail { max-width: 1200px; margin: 0 auto; padding: 1rem; }
.getrix-detail__header { margin-bottom: 1rem; }
.getrix-detail__badge { display: inline-block; padding: .25rem .6rem; border-radius: 999px; color: #fff; font-size: .8rem; text-transform: uppercase; margin-right: .5rem; }
.getrix-detail__type { color: var(--gx-color-muted); font-size: .9rem; text-transform: uppercase; letter-spacing: .04em; }
.getrix-detail__title { margin: .3rem 0; font-size: 1.8rem; line-height: 1.2; }
.getrix-detail__location { color: var(--gx-color-muted); margin: 0; }
.getrix-detail__price { color: var(--gx-color-primary); font-size: 2rem; font-weight: 700; margin: .6rem 0 0; }

.getrix-detail__gallery { margin: 1rem 0; }
.getrix-detail__gallery-main {
	position: relative;
	display: block;
	width: 100%;
	padding: 0;
	border: 0;
	background: none;
	cursor: zoom-in;
	border-radius: var(--gx-radius);
	overflow: hidden;
}
.getrix-detail__main-img { width: 100%; max-height: 520px; object-fit: cover; display: block; transition: transform .3s ease; }
.getrix-detail__gallery-main:hover .getrix-detail__main-img { transform: scale(1.02); }
.getrix-detail__main-icon {
	position: absolute; top: 1rem; right: 1rem;
	background: rgba(0,0,0,.6); color: #fff;
	width: 40px; height: 40px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: 1.2rem;
	pointer-events: none;
}
.getrix-detail__main-count {
	position: absolute; bottom: 1rem; right: 1rem;
	background: rgba(0,0,0,.65); color: #fff;
	padding: .25rem .7rem; border-radius: 999px;
	font-size: .85rem; font-weight: 600;
	pointer-events: none;
}
.getrix-detail__gallery-thumbs { display: flex; gap: .4rem; margin-top: .5rem; overflow-x: auto; padding-bottom: .25rem; }
.getrix-detail__thumb { flex: 0 0 auto; padding: 0; border: 2px solid transparent; background: none; cursor: pointer; border-radius: 6px; overflow: hidden; transition: border-color .2s; }
.getrix-detail__thumb:hover { border-color: var(--gx-color-primary); }
.getrix-detail__thumb.is-active { border-color: var(--gx-color-primary); }
.getrix-detail__thumb img { display: block; width: 90px; height: 70px; object-fit: cover; }

/* ---------- Lightbox ---------- */
.getrix-lightbox {
	display: none;
	position: fixed; inset: 0;
	background: rgba(0,0,0,.92);
	z-index: 99999;
	align-items: center; justify-content: center;
}
.getrix-lightbox.is-open { display: flex; }
.getrix-lightbox__stage {
	max-width: 95vw; max-height: 90vh;
	display: flex; align-items: center; justify-content: center;
}
.getrix-lightbox__img {
	max-width: 95vw; max-height: 90vh;
	object-fit: contain;
	box-shadow: 0 8px 32px rgba(0,0,0,.5);
	border-radius: 4px;
	user-select: none;
}
.getrix-lightbox__close,
.getrix-lightbox__nav {
	position: absolute;
	background: rgba(255,255,255,.15);
	color: #fff;
	border: none;
	width: 50px; height: 50px;
	border-radius: 50%;
	cursor: pointer;
	font-size: 1.8rem;
	line-height: 1;
	display: flex; align-items: center; justify-content: center;
	transition: background .2s;
}
.getrix-lightbox__close:hover,
.getrix-lightbox__nav:hover { background: rgba(255,255,255,.3); }
.getrix-lightbox__close { top: 1.5rem; right: 1.5rem; font-size: 1.8rem; }
.getrix-lightbox__nav--prev { left: 1.5rem; top: 50%; transform: translateY(-50%); font-size: 2.2rem; }
.getrix-lightbox__nav--next { right: 1.5rem; top: 50%; transform: translateY(-50%); font-size: 2.2rem; }
.getrix-lightbox__counter {
	position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
	color: #fff;
	background: rgba(0,0,0,.5);
	padding: .35rem 1rem;
	border-radius: 999px;
	font-size: .9rem; font-weight: 600;
}
@media (max-width: 600px) {
	.getrix-lightbox__close { top: .75rem; right: .75rem; width: 40px; height: 40px; }
	.getrix-lightbox__nav--prev { left: .25rem; width: 40px; height: 40px; font-size: 1.8rem; }
	.getrix-lightbox__nav--next { right: .25rem; width: 40px; height: 40px; font-size: 1.8rem; }
}

.getrix-detail__body { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; margin-top: 1.5rem; }
@media (max-width: 768px) { .getrix-detail__body { grid-template-columns: 1fr; } }
.getrix-detail__main h2 { margin: 1.5rem 0 .5rem; font-size: 1.3rem; color: var(--gx-color-primary); }
.getrix-detail__lead { font-size: 1.15rem; line-height: 1.5; font-style: italic; color: var(--gx-color-muted); margin: 0 0 1rem; padding-left: .8rem; border-left: 3px solid var(--gx-color-primary); }
.getrix-detail__desc { line-height: 1.6; }

.getrix-detail__specs table { width: 100%; border-collapse: collapse; }
.getrix-detail__specs th, .getrix-detail__specs td { padding: .5rem .25rem; border-bottom: 1px solid var(--gx-color-border); text-align: left; }
.getrix-detail__specs th { color: var(--gx-color-muted); font-weight: 500; width: 45%; }
.getrix-detail__sidebar h3 { font-size: 1rem; text-transform: uppercase; letter-spacing: .04em; margin: 1.5rem 0 .5rem; color: var(--gx-color-primary); }
.getrix-detail__flags ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: .35rem; }
.getrix-detail__flags li { font-size: .9rem; }
.getrix-detail__back { display: inline-block; margin-top: 1.5rem; color: var(--gx-color-primary); text-decoration: none; }
.getrix-detail__back:hover { text-decoration: underline; }

.getrix-energy-badge { display: inline-block; padding: .4rem .8rem; font-weight: 700; color: #fff; border-radius: 4px; font-size: 1.1rem; }
.getrix-energy-a { background: #1a8a3a; } .getrix-energy-b { background: #5fb14a; }
.getrix-energy-c { background: #c5d83a; color: #333; } .getrix-energy-d { background: #f5d325; color: #333; }
.getrix-energy-e { background: #f5a623; } .getrix-energy-f { background: #e67e22; } .getrix-energy-g { background: #c0392b; }

/* ---------- Ricerca ---------- */
.getrix-search {
	background: #f7f7f5;
	border: 1px solid var(--gx-color-border);
	border-radius: var(--gx-radius);
	padding: 1rem;
	margin-bottom: 1.5rem;
}
.getrix-search__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: .8rem; }
.getrix-search__field--q { grid-column: 1 / -1; }
.getrix-search__field label {
	display: block;
	font-size: .8rem;
	color: var(--gx-search-label-color, var(--gx-color-muted));
	margin-bottom: .2rem;
	text-transform: uppercase;
	letter-spacing: .03em;
}
.getrix-search__field input,
.getrix-search__field select {
	width: 100%;
	padding: .45rem .55rem;
	border: 1px solid var(--gx-color-border);
	border-radius: 5px;
	background: #fff;
	font-size: .95rem;
}
.getrix-search__actions { margin-top: .8rem; display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.getrix-search__reset {
	color: var(--gx-search-reset-color, var(--gx-color-muted));
	text-decoration: none;
	font-size: .9rem;
}
.getrix-search__reset:hover { text-decoration: underline; opacity: .85; }

/* Stile catalogo / risultati (default) */
.getrix-search--catalogo { /* eredita .getrix-search */ }

/* Stile homepage / hero (configurabile da Impostazioni) */
.getrix-search--homepage.getrix-search--no-bg {
	background: transparent;
	padding-left: 0;
	padding-right: 0;
}
.getrix-search--homepage:not(.getrix-search--no-bg) {
	background: var(--gx-search-bg, transparent);
}
.getrix-search--homepage.getrix-search--no-border {
	border: none;
}

.getrix-button { display: inline-block; padding: .55rem 1.2rem; background: var(--gx-color-primary); color: #fff; border: none; border-radius: 5px; cursor: pointer; font-weight: 600; font-size: .95rem; text-decoration: none; }
.getrix-button--primary { background: var(--gx-color-primary); }
.getrix-button:hover { filter: brightness(.92); }

/* ---------- Slider ---------- */
.getrix-slider { margin: 1rem 0; }
.getrix-slider__track {
	display: flex;
	align-items: stretch;
	gap: 1rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	-ms-overflow-style: none;
}
.getrix-slider__track::-webkit-scrollbar { display: none; }
.getrix-slider__slide {
	flex: 0 0 320px;
	scroll-snap-align: start;
	display: flex;
}
.getrix-slider__slide .getrix-card { width: 100%; height: 100%; }
.getrix-slider__controls {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: .35rem;
	margin-top: 1rem;
}
.getrix-slider__nav {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	padding: .55rem 1rem;
	background: var(--gx-color-primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-weight: 600;
	font-size: .92rem;
	font-family: inherit;
	cursor: pointer;
	transition: background .15s, transform .1s;
}
.getrix-slider__nav:hover { background: #1a4f8a; transform: translateY(-1px); }
.getrix-slider__nav:focus-visible { outline: 2px solid var(--gx-color-primary); outline-offset: 2px; }
@media (max-width: 520px) {
	.getrix-slider__nav { padding: .5rem .7rem; font-size: .85rem; }
}

/* ---------- Paginazione ---------- */
/* ---------- Pagination (lista immobili) ---------- */
.getrix-pagination {
	margin: 2.5rem 0 1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .9rem;
}
.getrix-pagination__info {
	color: var(--gx-color-muted);
	font-size: .92rem;
	font-weight: 500;
}
.getrix-pagination__controls {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	gap: .35rem;
}
.getrix-pagination__btn {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	padding: .55rem 1rem;
	background: var(--gx-color-primary);
	color: #fff;
	text-decoration: none;
	border-radius: 8px;
	font-weight: 600;
	font-size: .92rem;
	transition: background .15s, transform .1s;
}
.getrix-pagination__btn:hover { background: #1a4f8a; transform: translateY(-1px); color: #fff; }
.getrix-pagination__btn.is-disabled {
	background: #e5e7eb;
	color: #9ca3af;
	cursor: not-allowed;
	pointer-events: none;
}
.getrix-pagination__numbers {
	display: flex;
	gap: .25rem;
	align-items: center;
	padding: 0 .4rem;
}
.getrix-pagination__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 .55rem;
	border: 1px solid var(--gx-color-border);
	background: #fff;
	color: var(--gx-color-text);
	text-decoration: none;
	border-radius: 8px;
	font-weight: 500;
	transition: background .15s, border-color .15s;
}
.getrix-pagination__num:hover {
	background: #f3f4f6;
	border-color: var(--gx-color-primary);
	color: var(--gx-color-primary);
}
.getrix-pagination__num.is-current {
	background: var(--gx-color-primary);
	color: #fff;
	border-color: var(--gx-color-primary);
	cursor: default;
}
.getrix-pagination__dots {
	color: var(--gx-color-muted);
	padding: 0 .35rem;
	font-weight: 700;
}
@media (max-width: 520px) {
	.getrix-pagination__btn { padding: .5rem .7rem; font-size: .85rem; }
	.getrix-pagination__num { min-width: 34px; height: 34px; font-size: .9rem; }
	.getrix-pagination__numbers { padding: 0 .15rem; }
}

/* ---------- Stato ---------- */
.getrix-empty { padding: 2rem; text-align: center; color: var(--gx-color-muted); background: #f7f7f5; border-radius: var(--gx-radius); }
.getrix-error { color: #c0392b; background: #fbeae8; padding: 1rem; border-radius: var(--gx-radius); }

/* ---------- Archivio ---------- */
.getrix-page--archive { max-width: 1200px; margin: 0 auto; padding: 1rem; }
.getrix-archive__header h1 { margin: 0 0 .5rem; }
.getrix-archive__desc { color: var(--gx-color-muted); margin-bottom: 1rem; }
