/* Gruppi Locali — archive page */

.grp-label {
	font-size: .8rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	color: var(--ali-teal, #00C0C6); margin-bottom: 10px;
}

/* Hero */
.grp-hero { padding: 72px 24px 40px; text-align: center; }
.grp-hero__content { max-width: 760px; margin: 0 auto; }
.grp-hero h1 { margin: 0 0 12px; font-size: clamp(2rem, 4.5vw, 3.1rem); }
.grp-hero__subtitle { font-size: 1.1rem; color: var(--ali-text-secondary, #64748B); margin: 0; }

/* Filters */
.grp-grid-section { padding: 0 24px 72px; }
.grp-grid-inner { max-width: 1140px; margin: 0 auto; }
.grp-filters { display: flex; flex-wrap: wrap; gap: 16px; margin: 0 0 32px; }
.grp-filter { display: flex; flex-direction: column; gap: 6px; min-width: 200px; }
.grp-filter label { font-size: .82rem; font-weight: 600; color: var(--ali-navy-light, #A367A1); }
.grp-filter select {
	padding: 10px 12px; border: 1px solid var(--ali-warm-gray, #E2E8F0);
	border-radius: 8px; background: #fff; font-size: .95rem;
}
.grp-filter select:disabled { opacity: .55; }

/* Grid */
.grp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 22px; }
.grp-card {
	display: flex; flex-direction: column; text-decoration: none; color: inherit;
	background: #fff; border: 1px solid var(--ali-warm-gray, #E2E8F0);
	border-radius: 14px; overflow: hidden; transition: transform .15s, box-shadow .15s;
}
.grp-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(124,94,150,.15); }
.grp-card--hidden { display: none; }
.grp-card__img { aspect-ratio: 16 / 10; background: #eef6f8; overflow: hidden; }
.grp-card__img img { width: 100%; height: 100%; object-fit: cover; }
.grp-card__placeholder {
	display: block; width: 100%; height: 100%;
	background: linear-gradient(120deg, var(--ali-teal, #00C0C6), var(--ali-navy-light, #A367A1)); opacity: .25;
}
.grp-card__body { padding: 16px; }
.grp-card__body h2 { margin: 0 0 10px; font-size: 1.15rem; }
.grp-card__badges { display: flex; flex-wrap: wrap; gap: 6px; }
.grp-badge {
	display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600;
}
.grp-badge--regione { background: rgba(8,145,178,.12); color: var(--ali-teal, #00C0C6); }
.grp-badge--provincia { background: rgba(124,94,150,.12); color: var(--ali-navy-light, #A367A1); }
.grp-grid-empty { grid-column: 1 / -1; text-align: center; color: var(--ali-text-secondary, #64748B); padding: 40px 0; }

/* CTA */
.grp-cta { padding: 64px 24px; text-align: center; background: var(--ali-cream, #FAFAF8); }
.grp-cta-inner { max-width: 640px; margin: 0 auto; }
.grp-cta h2 { margin: 0 0 12px; }
.grp-cta-text { color: var(--ali-text-secondary, #64748B); margin: 0 0 24px; }
.grp-btn {
	display: inline-block; padding: 12px 28px; border-radius: 999px;
	background: var(--ali-teal, #00C0C6); color: #fff; text-decoration: none; font-weight: 600;
}
.grp-btn:hover { background: var(--ali-navy-light, #A367A1); }

/* Search input */
.grp-filter--search { flex: 1 1 240px; }
.grp-filter input[type="search"] {
	padding: 10px 12px; border: 1px solid var(--ali-warm-gray, #E2E8F0);
	border-radius: 8px; background: #fff; font-size: .95rem; width: 100%;
}

/* Results bar */
.grp-results { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 0 0 18px; }
.grp-results__count { font-size: .9rem; color: var(--ali-text-secondary, #64748B); font-weight: 600; }
.grp-results__clear {
	background: none; border: 0; cursor: pointer; padding: 4px 8px;
	font-size: .88rem; font-weight: 600; color: var(--ali-teal, #00C0C6);
}
.grp-results__clear:hover { color: var(--ali-navy-light, #A367A1); text-decoration: underline; }

/* No hover underline on cards / primary CTA button */
.grp-card, .grp-card:hover, .grp-card:focus { text-decoration: none; }
.grp-btn, .grp-btn:hover, .grp-btn:focus { text-decoration: none; }
