/**
 * zones.css — Hub « Zones d'intervention » (.page-zones) + pages villes
 * (.page-locality). SEO local. Mobile-first, tokens dotflo.
 */

/* Respiration des sections (chaque page définit son propre .block) */
.page-zones .block,
.page-locality .block { padding: clamp(3.5rem, 8vw, 7rem) 0; }

/* ========================= HÉROS ========================= */
.page-zones .zones-hero,
.page-locality .loc-hero {
  padding: calc(var(--space-10) + var(--space-2)) 0 var(--space-8);
  border-bottom: var(--border-width) solid var(--border-color);
}
.zones-hero__inner { max-width: 52rem; }
.zones-hero h1, .loc-hero h1 { margin-top: var(--space-2); }
.zones-hero .intro, .loc-hero .intro { color: var(--color-neutral-1); max-width: 46rem; margin-top: var(--space-3); }
.zones-hero > .container > div:last-child { margin-top: var(--space-4); }

.loc-hero__inner { display: flex; flex-direction: column; align-items: flex-start; max-width: 52rem; }
.loc-hero .breadcrumb { align-self: flex-start; margin-bottom: var(--space-4); font-size: var(--text-small); }
.loc-hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-4); }

/* ==================== HUB : grille villes ==================== */
.zones-lead { color: var(--color-neutral-1); margin-top: var(--space-2); max-width: 46rem; }
.zones-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; margin: 0; padding: 0; list-style: none; }
@media (min-width: 40rem) { .zones-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 60rem) { .zones-grid { grid-template-columns: repeat(3, 1fr); } }
.zone-card {
  display: flex; align-items: baseline; gap: 0.6rem;
  padding: 1.15rem 1.4rem; text-decoration: none; color: inherit;
  background: var(--color-surface); border: var(--border-width) solid var(--border-color);
  border-radius: var(--radius-lg);
  transition: border-color var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out);
}
.zone-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.zone-card__name { font-family: var(--font-display); font-weight: var(--font-weight-bold); font-size: 1.05rem; }
.zone-card__cp { color: var(--color-neutral-1); font-family: var(--font-mono); font-size: 0.8rem; }
.zone-card__go { margin-left: auto; color: var(--color-accent); font-size: 1.1rem; }
.zones-note { margin-top: var(--space-4); color: var(--color-neutral-1); font-size: var(--text-small); }

/* ==================== VILLE : services ==================== */
.loc-services { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 48rem) { .loc-services { grid-template-columns: repeat(2, 1fr); } }
.loc-service {
  display: flex; flex-direction: column; gap: 0.5rem;
  padding: 1.6rem 1.75rem; text-decoration: none; color: inherit;
  background: linear-gradient(180deg, var(--color-surface), var(--color-bg-2));
  border: var(--border-width) solid var(--border-color); border-radius: var(--radius-lg);
  transition: border-color var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out);
}
.loc-service:hover { border-color: color-mix(in srgb, var(--color-accent) 32%, transparent); transform: translateY(-3px); }
.loc-service h3 { font-size: 1.25rem; }
.loc-service p { color: var(--color-neutral-1); font-size: 0.98rem; margin-top: 0.35rem; }
.loc-service .go { margin-top: auto; padding-top: 0.75rem; color: var(--color-accent); font-weight: 600; font-size: 0.9rem; }

/* ============ VILLE : split référencement local ============ */
.loc-split { display: grid; gap: var(--space-5); align-items: start; }
@media (min-width: 60rem) { .loc-split { grid-template-columns: 1.1fr 0.9fr; gap: var(--space-8); } }
.loc-split h2 { margin: var(--space-1) 0 var(--space-3); }
.loc-split p { color: var(--color-neutral-1); }

/* ==================== VILLE : réalisations ==================== */
.loc-reals { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 48rem) { .loc-reals { grid-template-columns: repeat(3, 1fr); } }
.loc-real {
  display: flex; flex-direction: column; text-decoration: none; color: inherit;
  background: var(--color-surface); border: var(--border-width) solid var(--border-color);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: border-color var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out);
}
.loc-real:hover { border-color: var(--color-accent); transform: translateY(-3px); }
.loc-real__media { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: var(--color-bg-2); }
.loc-real__media img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.loc-real__body { padding: 1rem 1.25rem 1.25rem; display: flex; flex-direction: column; gap: 0.25rem; }
.loc-real__title { font-family: var(--font-display); font-weight: var(--font-weight-bold); font-size: 1.1rem; }
.loc-real__baseline { color: var(--color-neutral-1); font-size: 0.9rem; }
.loc-reals__more { margin-top: var(--space-4); }

/* ==================== VILLE : autres villes ==================== */
.loc-cities { display: flex; flex-wrap: wrap; gap: 0.6rem 1.5rem; margin: 0; padding: 0; list-style: none; }

@media (prefers-reduced-motion: reduce) {
  .zone-card, .loc-service, .loc-real { transition: none; }
}
