/* ============================================================
   GI Base — main stylesheet
   Tutto guidato da CSS variables (--gi-*) iniettate dal Customizer.
   I child theme override solo il :root o aggiungono regole sopra.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--gi-font-body, system-ui, sans-serif);
	color: var(--gi-ink, #0e1726);
	background: var(--gi-bg, #fff);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--gi-font-heading, inherit);
	color: var(--gi-ink);
	line-height: 1.2;
	margin: 0 0 .5em;
	letter-spacing: -.01em;
}
h1 { font-size: clamp(28px, 3.4vw, 44px); }
h2 { font-size: clamp(22px, 2.4vw, 32px); }
h3 { font-size: 18px; }

a { color: var(--gi-primary); text-decoration: none; }
a:hover { color: var(--gi-primary-dark); }

img { max-width: 100%; height: auto; display: block; }

.gi-muted { color: var(--gi-muted); }
.gi-link { color: var(--gi-primary); font-weight: 600; }

.gi-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

/* Header */
.gi-header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(255,255,255,.92);
	backdrop-filter: saturate(140%) blur(10px);
	border-bottom: 1px solid #eef1f6;
}
.gi-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px; min-height: 72px;
}
.gi-logo { display: flex; align-items: center; gap: 10px; font-weight: 700; color: var(--gi-ink); }
.gi-logo__mark {
	width: 36px; height: 36px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--gi-primary); color: #fff;
	border-radius: 10px; font-weight: 800; font-size: 14px;
	box-shadow: 0 6px 16px -6px var(--gi-primary);
}
.gi-logo__text { font-size: 17px; }
.gi-logo--footer .gi-logo__text { color: #fff; }
.gi-logo--footer .gi-logo__mark { background: #fff; color: var(--gi-primary); box-shadow: none; }

.gi-nav__list {
	display: flex; gap: 22px; list-style: none; margin: 0; padding: 0;
	font-weight: 500;
}
.gi-nav__list a { color: var(--gi-ink); }
.gi-nav__list a:hover { color: var(--gi-primary); }

.gi-cta-phone {
	background: var(--gi-ink); color: #fff; padding: 10px 14px;
	border-radius: var(--gi-radius); font-weight: 600; font-size: 14px;
}
.gi-cta-phone:hover { background: var(--gi-primary); color: #fff; }

/* Buttons */
.gi-btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 12px 22px; border-radius: var(--gi-radius);
	font-weight: 600; border: 0; cursor: pointer;
	transition: transform .08s ease, background .2s ease, color .2s ease;
	font-size: 15px;
}
.gi-btn:hover { transform: translateY(-1px); }
.gi-btn--primary { background: var(--gi-primary); color: #fff; }
.gi-btn--primary:hover { background: var(--gi-primary-dark); color: #fff; }
.gi-btn--accent { background: var(--gi-accent); color: #fff; }
.gi-btn--accent:hover { color: #fff; filter: brightness(.95); }

/* Hero */
.gi-hero {
	position: relative; min-height: 560px;
	background-size: cover; background-position: center;
	color: #fff; display: flex; align-items: center;
}
.gi-hero__inner { width: 100%; padding: 80px 20px; }
.gi-hero__title {
	color: #fff; max-width: 820px; font-size: clamp(34px, 5vw, 60px); font-weight: 800;
	text-shadow: 0 2px 24px rgba(0,0,0,.3);
}
.gi-hero__subtitle {
	color: rgba(255,255,255,.92); max-width: 680px; font-size: 18px; margin-bottom: 28px;
	text-shadow: 0 2px 16px rgba(0,0,0,.4);
}
.gi-hero__search {
	background: #fff; border-radius: calc(var(--gi-radius) * 1.4);
	padding: 18px; box-shadow: 0 30px 60px -20px rgba(14,23,38,.35);
	max-width: 1080px;
}

/* Sections */
.gi-section { padding: 64px 0; }
.gi-section--alt { background: var(--gi-surface); }
.gi-section__head {
	display: flex; align-items: baseline; justify-content: space-between;
	margin-bottom: 28px; gap: 16px; flex-wrap: wrap;
}

/* Sortable wrapper (homepage / inline) */
.gi-sortable { width: 100%; }
.gi-sortable__head {
	display: flex; justify-content: flex-end; align-items: center;
	margin-bottom: 18px; padding: 10px 14px;
	background: var(--gi-surface); border-radius: 10px;
	border: 1px solid #e2e7f0;
}
.gi-sortable__sort {
	display: inline-flex; align-items: center; gap: 10px;
	color: var(--gi-ink); font-size: 14px; font-weight: 600;
	cursor: pointer;
}
.gi-sortable__sort::before {
	content: '⇅'; font-size: 18px; color: var(--gi-primary); font-weight: 700;
}
.gi-sortable__select {
	padding: 10px 36px 10px 14px; border-radius: 8px;
	border: 1px solid var(--gi-primary); background: #fff;
	font-size: 14px; font-weight: 600; color: var(--gi-ink);
	font-family: inherit; cursor: pointer;
	box-shadow: 0 1px 2px rgba(15,111,255,.08);
	appearance: none; -webkit-appearance: none;
	background-image:
		linear-gradient(45deg, transparent 50%, var(--gi-primary) 50%),
		linear-gradient(135deg, var(--gi-primary) 50%, transparent 50%);
	background-position: right 14px top 17px, right 8px top 17px;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}
.gi-sortable__select:hover { border-color: var(--gi-primary-dark); }
.gi-sortable__select:focus { outline: 2px solid var(--gi-primary); outline-offset: 2px; }
.gi-sortable__body { transition: opacity .2s ease; min-height: 200px; }

/* Search form */
.gi-search { width: 100%; }
.gi-search__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 12px; align-items: end;
}
.gi-field { display: flex; flex-direction: column; font-size: 12px; font-weight: 600; color: var(--gi-muted); text-transform: uppercase; letter-spacing: .04em; }
.gi-field span { margin-bottom: 6px; }
.gi-field input, .gi-field select {
	padding: 12px; border: 1px solid #e2e7f0; border-radius: 10px;
	font-size: 14px; font-weight: 500; color: var(--gi-ink); background: #fff;
	font-family: inherit;
}
.gi-field input:focus, .gi-field select:focus {
	outline: 2px solid var(--gi-primary); outline-offset: 1px; border-color: var(--gi-primary);
}

/* Grid + cards */
.gi-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
	gap: 24px;
}
.gi-card {
	background: #fff; border-radius: var(--gi-radius); overflow: hidden;
	box-shadow: 0 1px 0 #eef1f6, 0 20px 40px -28px rgba(14,23,38,.25);
	display: flex; flex-direction: column;
	transition: transform .12s ease, box-shadow .2s ease;
}
.gi-card:hover { transform: translateY(-3px); box-shadow: 0 30px 60px -28px rgba(14,23,38,.4); }
.gi-card__media {
	position: relative; display: block;
	height: 220px; background-size: cover; background-position: center;
}
.gi-card__media--placeholder {
	background: linear-gradient(135deg, var(--gi-surface) 0%, #e2e7f0 100%);
	display: flex; align-items: center; justify-content: center;
}
.gi-card__noimg { font-size: 64px; opacity: .35; }
.gi-badge {
	position: absolute; top: 12px; left: 12px;
	background: var(--gi-accent); color: #fff;
	padding: 4px 10px; border-radius: 999px;
	font-size: 12px; font-weight: 700; letter-spacing: .02em;
}
.gi-card__body { padding: 16px 18px 20px; display: flex; flex-direction: column; gap: 8px; }
.gi-card__meta { font-size: 12px; color: var(--gi-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.gi-card__title { font-size: 17px; margin: 0; }
.gi-card__title a { color: var(--gi-ink); }
.gi-card__title a:hover { color: var(--gi-primary); }
.gi-card__price { color: var(--gi-primary); font-weight: 800; font-size: 22px; }
.gi-card__features {
	list-style: none; padding: 0; margin: 6px 0 0;
	display: flex; flex-wrap: wrap; gap: 14px;
	color: var(--gi-muted); font-size: 13px;
}
.gi-card__features li { display: inline-flex; align-items: center; gap: 4px; }

/* CTA strip */
.gi-cta {
	background: linear-gradient(135deg, var(--gi-primary), var(--gi-primary-dark));
	color: #fff; padding: 56px 0;
}
.gi-cta__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 24px; flex-wrap: wrap;
}
.gi-cta h2 { color: #fff; margin: 0 0 6px; }
.gi-cta p { margin: 0; color: rgba(255,255,255,.9); }

/* Footer */
.gi-footer {
	background: var(--gi-ink); color: rgba(255,255,255,.85);
	padding: 56px 0 20px; margin-top: 64px;
}
.gi-footer h4 { color: #fff; }
.gi-footer a { color: rgba(255,255,255,.85); }
.gi-footer a:hover { color: var(--gi-accent); }
.gi-footer__grid {
	display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 36px;
	padding-bottom: 32px; border-bottom: 1px solid rgba(255,255,255,.1);
}
.gi-footer__menu { list-style: none; padding: 0; margin: 0; }
.gi-footer__menu li { margin: 6px 0; }
.gi-footer__bottom { padding-top: 20px; color: rgba(255,255,255,.6); }

/* Property single */
.gi-prop__head {
	display: flex; align-items: flex-start; justify-content: space-between;
	gap: 20px; flex-wrap: wrap; margin-bottom: 22px;
}
.gi-prop__crumbs { font-size: 12px; color: var(--gi-muted); text-transform: uppercase; letter-spacing: .04em; }
.gi-prop__title { margin: 8px 0 4px; }
.gi-prop__ref { color: var(--gi-muted); font-size: 13px; }
.gi-prop__price { font-size: clamp(28px, 4vw, 40px); font-weight: 800; color: var(--gi-primary); white-space: nowrap; }
.gi-prop__hero {
	height: 460px; background-size: cover; background-position: center;
	border-radius: var(--gi-radius); margin-bottom: 32px;
}

/* Gallery */
.gi-gallery { margin-bottom: 32px; }
.gi-gallery__hero {
	position: relative; height: clamp(320px, 50vh, 560px);
	background-size: cover; background-position: center;
	border-radius: var(--gi-radius); cursor: zoom-in; overflow: hidden;
	transition: transform .15s ease;
}
.gi-gallery__hero:hover { transform: scale(1.005); }
.gi-gallery__hero--noimg {
	background: linear-gradient(135deg, var(--gi-surface), #e2e7f0);
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	cursor: default; color: var(--gi-muted);
}
.gi-gallery__hero--noimg:hover { transform: none; }
.gi-gallery__noimg-icon { font-size: 96px; opacity: .35; margin-bottom: 8px; }
.gi-gallery__noimg-text { font-size: 16px; font-weight: 500; }
.gi-gallery__count {
	position: absolute; right: 16px; bottom: 16px;
	background: rgba(14,23,38,.78); color: #fff; padding: 6px 12px;
	border-radius: 999px; font-size: 13px; font-weight: 600;
}
.gi-gallery__strip {
	display: flex; gap: 10px; margin-top: 12px; overflow-x: auto;
	padding-bottom: 4px; scroll-snap-type: x mandatory;
}
.gi-gallery__thumb {
	flex: 0 0 110px; height: 80px; border: 0; padding: 0; cursor: pointer;
	border-radius: 10px; background-size: cover; background-position: center;
	box-shadow: 0 1px 0 #eef1f6; scroll-snap-align: start;
	outline: 2px solid transparent; transition: outline-color .15s ease, transform .1s ease;
}
.gi-gallery__thumb:hover { transform: translateY(-2px); }
.gi-gallery__thumb.is-active { outline-color: var(--gi-primary); }

/* Lightbox */
.gi-lightbox {
	position: fixed; inset: 0; z-index: 9999;
	background: rgba(8,12,22,.94);
	display: none; align-items: center; justify-content: center;
}
.gi-lightbox.is-open { display: flex; }
.gi-lightbox__img { max-width: 92vw; max-height: 86vh; box-shadow: 0 30px 80px -20px rgba(0,0,0,.6); border-radius: 10px; }
.gi-lightbox__close, .gi-lightbox__prev, .gi-lightbox__next {
	position: absolute; background: rgba(255,255,255,.12); color: #fff;
	border: 0; border-radius: 999px; cursor: pointer;
	width: 48px; height: 48px; font-size: 24px; line-height: 1;
	transition: background .15s ease;
}
.gi-lightbox__close:hover, .gi-lightbox__prev:hover, .gi-lightbox__next:hover { background: rgba(255,255,255,.25); }
.gi-lightbox__close { top: 20px; right: 20px; }
.gi-lightbox__prev  { left: 20px;  top: 50%; transform: translateY(-50%); }
.gi-lightbox__next  { right: 20px; top: 50%; transform: translateY(-50%); }
.gi-lightbox__counter {
	position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
	color: rgba(255,255,255,.8); font-weight: 600; font-size: 14px;
}
.gi-prop__grid {
	display: grid; grid-template-columns: 1.6fr 1fr; gap: 32px; align-items: start;
}
.gi-prop__main h2 { margin-top: 28px; }
.gi-prop__specs {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px;
}
.gi-prop__specs li {
	background: var(--gi-surface); border-radius: 10px; padding: 12px 14px;
	display: flex; flex-direction: column; gap: 2px;
}
.gi-prop__specs span { font-size: 12px; color: var(--gi-muted); text-transform: uppercase; letter-spacing: .04em; }
.gi-prop__features {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 8px;
}
.gi-prop__features li { background: var(--gi-surface); border-radius: 8px; padding: 8px 12px; font-size: 14px; }

.gi-card--contact { padding: 22px; box-shadow: 0 30px 60px -28px rgba(14,23,38,.35); }
.gi-contact { display: flex; flex-direction: column; gap: 12px; }
.gi-contact__title { margin: 0 0 4px; }
.gi-contact__lead { margin-top: 0; }
.gi-contact__phone { margin-top: 12px; }
.gi-contact label { display: flex; flex-direction: column; font-size: 12px; color: var(--gi-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.gi-contact input, .gi-contact textarea {
	margin-top: 4px; padding: 12px; border: 1px solid #e2e7f0; border-radius: 10px;
	font-family: inherit; font-size: 14px; color: var(--gi-ink); background: #fff;
}
.gi-contact input:focus, .gi-contact textarea:focus { outline: 2px solid var(--gi-primary); outline-offset: 1px; border-color: var(--gi-primary); }
.gi-contact__grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.gi-contact--compact .gi-contact__grid { grid-template-columns: 1fr; }
.gi-contact .gi-btn { align-self: flex-start; }
.gi-checkbox { flex-direction: row !important; align-items: center; gap: 8px; text-transform: none !important; font-weight: 500 !important; font-size: 13px !important; color: var(--gi-muted); }

.gi-alert { padding: 12px 16px; border-radius: 10px; margin-bottom: 14px; font-size: 14px; font-weight: 500; }
.gi-alert--ok  { background: #e7f7ed; color: #1b6b3a; border-left: 4px solid #14b572; }
.gi-alert--err { background: #fdecec; color: #9a1f1f; border-left: 4px solid #d9534f; }

@media (max-width: 700px) {
	.gi-contact__grid { grid-template-columns: 1fr; }
}

/* Archive layout */
.gi-archive { display: grid; grid-template-columns: 280px 1fr; gap: 28px; align-items: start; }
.gi-archive__filters { position: sticky; top: 100px; background: var(--gi-surface); padding: 20px; border-radius: var(--gi-radius); }
.gi-archive__filters .gi-search__grid { grid-template-columns: 1fr; }

/* Map */
.gi-map { width: 100%; border-radius: var(--gi-radius); overflow: hidden; }

/* Map search page (cerca-mappa) */
.gi-mapsearch {
	display: grid; grid-template-columns: 380px 1fr;
	height: calc(100vh - 72px);
	overflow: hidden;
}
.gi-mapsearch__panel {
	background: #fff; border-right: 1px solid #e6e9ef;
	display: flex; flex-direction: column; overflow: hidden;
}
.gi-mapsearch__head { padding: 22px 22px 12px; border-bottom: 1px solid #eef1f6; }
.gi-mapsearch__head h1 { margin: 0 0 6px; font-size: 22px; }
.gi-mapsearch__head p { margin: 0; font-size: 13px; }
.gi-mapsearch__filters {
	display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
	padding: 16px 22px; border-bottom: 1px solid #eef1f6;
}
.gi-mapsearch__filter { display: flex; flex-direction: column; gap: 4px; font-size: 11px; font-weight: 700; color: var(--gi-muted); text-transform: uppercase; letter-spacing: .04em; }
.gi-mapsearch__filter:nth-child(3) { grid-column: 1 / -1; }
.gi-mapsearch__filter input, .gi-mapsearch__filter select {
	padding: 9px 10px; border: 1px solid #e2e7f0; border-radius: 8px;
	font-size: 14px; font-weight: 500; color: var(--gi-ink); background: #fff;
	font-family: inherit; text-transform: none;
}
.gi-mapsearch__status {
	display: flex; align-items: center; justify-content: space-between;
	padding: 12px 22px; background: var(--gi-surface); font-size: 14px;
}
.gi-mapsearch__status strong { font-size: 18px; color: var(--gi-primary); margin-right: 4px; }
.gi-btn--ghost { background: transparent; color: var(--gi-muted); padding: 6px 10px; font-size: 12px; border: 1px solid #e2e7f0; }
.gi-btn--ghost:hover { background: #fff; color: var(--gi-ink); }
.gi-mapsearch__results { padding: 16px 22px; overflow-y: auto; flex: 1; }
.gi-mapsearch__list { display: flex; flex-direction: column; gap: 12px; }
.gi-mapsearch__list .gi-card { box-shadow: 0 1px 0 #eef1f6; }
.gi-mapsearch__list .gi-card__media { height: 140px; }
.gi-mapsearch__map { height: 100%; }
.page-template-default.page main.gi-main:has(.gi-mapsearch) { padding: 0; margin: 0; }

@media (max-width: 900px) {
	.gi-mapsearch { grid-template-columns: 1fr; grid-template-rows: auto 60vh; height: auto; }
	.gi-mapsearch__panel { max-height: 50vh; }
}

/* Pagination */
.gi-pagination { margin-top: 32px; }
.gi-pagination .page-numbers { display: inline-flex; padding: 8px 14px; margin: 0 2px; border-radius: 8px; background: var(--gi-surface); color: var(--gi-ink); font-weight: 600; }
.gi-pagination .current { background: var(--gi-primary); color: #fff; }

/* Empty */
.gi-empty { background: var(--gi-surface); padding: 40px; text-align: center; border-radius: var(--gi-radius); color: var(--gi-muted); }

/* Page hero (sottopagine) */
.gi-page-hero {
	background: linear-gradient(135deg, var(--gi-primary), var(--gi-primary-dark));
	color: #fff; padding: 72px 0 56px;
}
.gi-page-hero__tag {
	display: inline-block; background: rgba(255,255,255,.18); color: #fff;
	padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em;
}
.gi-page-hero__title { color: #fff; margin: 14px 0 10px; font-size: clamp(34px, 5vw, 56px); }
.gi-page-hero__sub   { color: rgba(255,255,255,.92); max-width: 720px; font-size: 17px; }

/* Contatti */
.gi-contacts__grid {
	display: grid; gap: 18px;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.gi-info {
	background: #fff; border-radius: var(--gi-radius); padding: 22px;
	box-shadow: 0 1px 0 #eef1f6, 0 20px 40px -28px rgba(14,23,38,.2);
	text-decoration: none; color: var(--gi-ink); display: block;
	transition: transform .12s ease;
}
a.gi-info:hover { transform: translateY(-3px); color: var(--gi-ink); }
.gi-info__icon  { font-size: 28px; margin-bottom: 8px; }
.gi-info__label { font-size: 12px; color: var(--gi-muted); text-transform: uppercase; letter-spacing: .06em; font-weight: 700; }
.gi-info__value { font-size: 18px; font-weight: 700; margin: 4px 0 4px; }
.gi-info__hint  { font-size: 13px; color: var(--gi-muted); }

.gi-contacts__form-wrap {
	display: grid; grid-template-columns: 1fr 1.2fr; gap: 40px; align-items: start;
}
.gi-contacts__form-box {
	background: #fff; padding: 28px; border-radius: var(--gi-radius);
	box-shadow: 0 30px 60px -28px rgba(14,23,38,.3);
}
.gi-contacts__perks { list-style: none; padding: 0; margin: 16px 0 0; }
.gi-contacts__perks li { padding: 6px 0; color: var(--gi-ink); font-weight: 500; }

/* About */
.gi-about__grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
}
.gi-about__media {
	height: 360px; background-size: cover; background-position: center;
	border-radius: var(--gi-radius);
	box-shadow: 0 30px 60px -28px rgba(14,23,38,.4);
}

.gi-stats {
	display: grid; gap: 24px;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.gi-stat {
	background: #fff; border-radius: var(--gi-radius); padding: 28px;
	text-align: center;
	box-shadow: 0 1px 0 #eef1f6, 0 20px 40px -28px rgba(14,23,38,.2);
}
.gi-stat strong { display: block; font-size: clamp(34px, 4vw, 48px); color: var(--gi-primary); font-weight: 800; line-height: 1; }
.gi-stat span   { color: var(--gi-muted); font-size: 14px; margin-top: 6px; display: block; }

.gi-values {
	display: grid; gap: 24px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.gi-value {
	background: #fff; border-radius: var(--gi-radius); padding: 24px;
	box-shadow: 0 1px 0 #eef1f6, 0 20px 40px -28px rgba(14,23,38,.2);
}
.gi-value__icon { font-size: 32px; margin-bottom: 8px; }
.gi-value h3 { margin: 4px 0 6px; }

@media (max-width: 800px) {
	.gi-contacts__form-wrap, .gi-about__grid { grid-template-columns: 1fr; }
}

/* Responsive */
@media (max-width: 900px) {
	.gi-nav { display: none; }
	.gi-cta-phone { font-size: 13px; padding: 8px 12px; }
	.gi-prop__grid { grid-template-columns: 1fr; }
	.gi-archive { grid-template-columns: 1fr; }
	.gi-archive__filters { position: static; }
	.gi-footer__grid { grid-template-columns: 1fr; gap: 24px; }
}
