/* =====================================================================
   Página "Cerrajería"
   Estilos de los bloques cerr-* (hero reutiliza .fdq-hero-banner).
   ===================================================================== */

/* ---------- Hero (imagen de fondo, sin degradado) ---------- */
.cerr-hero.fdq-hero-banner {
  background-image: url("../../images/cerrajeros/cerrajero-madrid.webp");
  background-size: cover;
  background-position: center;
}

/* ---------- Hero: indicador de confianza extra ---------- */
.cerr-hero-trust {
  display: flex;
  align-items: center;
  gap: var(--fdq-space-sm);
  margin: var(--fdq-space-lg) 0 0;
  font-size: var(--fdq-fs-label);
  font-weight: 700;
  letter-spacing: var(--fdq-tracking-caps);
  text-transform: uppercase;
  color: #fff;
}
.cerr-hero-trust .material-symbols-outlined { color: var(--fdq-secondary-container); }

/* ---------- Banda de urgencia ---------- */
.cerr-urgency {
  padding-block: var(--fdq-space-lg);
  border-bottom: 4px solid var(--fdq-secondary-container);
}
.cerr-urgency__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--fdq-space-sm);
}
.cerr-urgency__title { margin: 0; color: var(--fdq-secondary-container); }
.cerr-urgency__text {
  margin: 0 auto;
  max-width: 48rem;
  font-size: var(--fdq-fs-body-lg);
  color: rgba(255, 255, 255, 0.9);
}

/* ---------- Cabecera de sección reutilizable ---------- */
.cerr-head { text-align: center; margin-bottom: var(--fdq-space-xl); }
.cerr-head__title { margin: 0 0 var(--fdq-space-xs); color: var(--fdq-on-surface); }
.cerr-head__subtitle { margin: 0; font-size: var(--fdq-fs-body-lg); color: var(--fdq-on-surface-variant); }

/* ---------- Servicios ---------- */
.cerr-services { padding-block: var(--fdq-space-xl); }
.cerr-services__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
}
.cerr-services__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--fdq-space-md);
}
.cerr-services__grid > * { margin-block: 0; }
.cerr-service {
  display: flex;
  flex-direction: column;
  gap: var(--fdq-space-sm);
  padding: var(--fdq-space-md);
  background-color: var(--fdq-surface-container-lowest);
  border: 1px solid var(--fdq-outline-variant);
  border-radius: var(--fdq-radius-md);
  transition: box-shadow var(--fdq-duration-base) var(--fdq-ease-out);
}
.cerr-service:hover { box-shadow: var(--fdq-shadow-sm); }
.cerr-service__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin: 0;
  background-color: var(--fdq-surface-container);
  border-radius: var(--fdq-radius-md);
}
.cerr-service__icon .material-symbols-outlined { color: var(--fdq-primary-container); }
.cerr-service__title { margin: 0; color: var(--fdq-on-surface); }
.cerr-service__text { margin: 0; flex-grow: 1; color: var(--fdq-on-surface-variant); }
.cerr-service__link { margin: 0; margin-top: auto; }
.cerr-service__link a {
  display: inline-flex;
  align-items: center;
  gap: var(--fdq-space-xs);
  font-weight: 600;
  color: var(--fdq-secondary-container);
}
.cerr-service__link a:hover { text-decoration: underline; }
.cerr-service__link .material-symbols-outlined { font-size: 16px; }

/* ---------- Diferencial: "No somos una centralita" ----------
   Fondo: foto del interior de la tienda (ya oscurecida) con velo para legibilidad;
   textos en blanco e iconos en cian. */
.cerr-difference {
  padding-block: var(--fdq-space-xl);
  background-image:
    linear-gradient(rgba(4, 22, 50, 0.66), rgba(4, 22, 50, 0.66)),
    url("../../images/cerrajeros/cerrajero-barrio-salamanca.webp");
  background-size: cover;
  background-position: center;
}
.cerr-difference__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--fdq-space-sm);
}
.cerr-difference__icon { margin: 0; }
.cerr-difference__icon .material-symbols-outlined { font-size: 48px; color: var(--fdq-secondary-container); }
.cerr-difference__title { margin: 0; color: #fff; }
.cerr-difference__text {
  margin: 0;
  max-width: 48rem;
  font-size: var(--fdq-fs-body-lg);
  color: rgba(255, 255, 255, 0.9);
}
.cerr-difference__address {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--fdq-space-xs);
  margin: var(--fdq-space-md) 0 0;
  padding: var(--fdq-space-sm);
  background-color: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--fdq-radius-md);
  color: rgba(255, 255, 255, 0.9);
}
.cerr-difference__address .material-symbols-outlined { color: var(--fdq-secondary-container); }
.cerr-difference__address strong { color: #fff; }

/* ---------- Proceso: "Cómo trabajamos" ---------- */
.cerr-process { padding-block: var(--fdq-space-xl); }
.cerr-process__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
}
.cerr-process__steps {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--fdq-space-md);
}
.cerr-process__steps > * { margin-block: 0; }
.cerr-step {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--fdq-space-xs);
}
.cerr-step__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin: 0 0 var(--fdq-space-xs);
  background-color: var(--fdq-primary-container);
  color: #fff;
  border: 4px solid var(--fdq-surface-bright);
  border-radius: var(--fdq-radius-pill);
  font-family: var(--fdq-font-heading);
  font-size: 20px;
  font-weight: 600;
}
.cerr-step__title { margin: 0; font-size: 18px; color: var(--fdq-on-surface); }

/* ---------- Seguridad y especialización ---------- */
.cerr-security {
  padding-block: var(--fdq-space-xl);
  border-block: 1px solid var(--fdq-outline-variant);
}
.cerr-security__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--fdq-space-xl);
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
}
.cerr-security__content { display: flex; flex-direction: column; gap: var(--fdq-space-sm); }
.cerr-security__icon { margin: 0; }
.cerr-security__icon .material-symbols-outlined { font-size: 40px; color: var(--fdq-primary-container); }
.cerr-security__title { margin: 0; color: var(--fdq-on-surface); }
.cerr-security__text { margin: 0; font-size: var(--fdq-fs-body-lg); color: var(--fdq-on-surface-variant); }
.cerr-security__media {
  min-height: 320px;
}

/* ---------- Precios ---------- */
.cerr-pricing {
  padding-block: var(--fdq-space-xl);
  background-color: #f8f9ff;
}
.cerr-pricing__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--fdq-space-xl);
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
}
.cerr-pricing__left { display: flex; flex-direction: column; gap: var(--fdq-space-lg); }
.cerr-pricing__title {
  margin: 0 0 var(--fdq-space-sm);
  font-size: var(--fdq-fs-h1);
  line-height: var(--fdq-lh-tight);
  color: var(--fdq-primary);
}
.cerr-pricing__text { margin: 0; font-size: var(--fdq-fs-body-lg); color: var(--fdq-on-surface-variant); }
.cerr-pricing__subtitle { margin: 0 0 var(--fdq-space-sm); color: var(--fdq-primary); }
.cerr-brands {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--fdq-space-sm);
}
.cerr-brands > * { margin-block: 0; }
.cerr-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 64px;
  margin: 0;
  padding: var(--fdq-space-sm);
  background-color: #fff;
  border: 1px solid var(--fdq-outline-variant);
  border-radius: var(--fdq-radius-lg);
  font-weight: 700;
  color: var(--fdq-primary);
  box-shadow: var(--fdq-shadow-sm);
}
.cerr-table {
  background-color: #fff;
  border: 1px solid var(--fdq-outline-variant);
  border-radius: var(--fdq-radius-xl);
  overflow: hidden;
  box-shadow: var(--fdq-shadow-lg);
}
.cerr-table__head {
  padding: var(--fdq-space-md);
  background-color: var(--fdq-primary);
  color: #fff;
}
.cerr-table__h {
  margin: 0;
  font-family: var(--fdq-font-heading);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cerr-rate {
  padding: var(--fdq-space-md);
  border-top: 1px solid rgba(197, 198, 206, 0.4);
}
.cerr-rate__name { display: flex; flex-direction: column; }
.cerr-rate__title { margin: 0; font-weight: 700; color: var(--fdq-primary); }
.cerr-rate__sub { margin: 0; font-size: 12px; color: var(--fdq-on-surface-variant); }
.cerr-rate__price { margin: 0; font-weight: 700; color: var(--fdq-secondary-container); white-space: nowrap; }
.cerr-rate__multi { text-align: right; }
.cerr-rate__multi > * { margin: 0; }
.cerr-rate__label { font-size: 12px; font-style: italic; color: var(--fdq-on-surface-variant); }
.cerr-table__note {
  margin: 0;
  padding: var(--fdq-space-md);
  background-color: var(--fdq-surface-container-low);
  font-size: 12px;
  font-style: italic;
  color: var(--fdq-on-surface-variant);
}

/* ---------- Bloque de conversión (WhatsApp foto) ---------- */
.cerr-whatsapp { padding-block: var(--fdq-space-xl); }
.cerr-whatsapp__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--fdq-space-md);
}
.cerr-whatsapp__title { margin: 0; color: #fff; }
.cerr-whatsapp__text {
  margin: 0;
  max-width: 42rem;
  font-size: var(--fdq-fs-body-lg);
  color: rgba(255, 255, 255, 0.9);
}

/* ---------- Cobertura (SEO local) + confianza ---------- */
.cerr-coverage { padding-block: var(--fdq-space-xl); }
.cerr-coverage__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--fdq-space-xl);
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
}
.cerr-coverage__areas { display: flex; flex-direction: column; gap: var(--fdq-space-sm); }
.cerr-coverage__title { margin: 0; color: var(--fdq-on-surface); }
.cerr-coverage__text { margin: 0; color: var(--fdq-on-surface-variant); }
.cerr-coverage__tags { gap: var(--fdq-space-xs); }
.cerr-tag {
  margin: 0;
  padding: var(--fdq-space-xs) var(--fdq-space-sm);
  background-color: var(--fdq-surface-container-low);
  border: 1px solid var(--fdq-outline-variant);
  border-radius: var(--fdq-radius-md);
  font-size: var(--fdq-fs-label);
  font-weight: 700;
  letter-spacing: var(--fdq-tracking-caps);
  text-transform: uppercase;
  color: var(--fdq-on-surface);
}
.cerr-coverage__badges { gap: var(--fdq-space-md); align-items: center; }
.cerr-badge {
  display: flex;
  align-items: center;
  gap: var(--fdq-space-xs);
  margin: 0;
  padding: var(--fdq-space-xs) var(--fdq-space-sm);
  background-color: rgba(27, 43, 72, 0.10);
  border-radius: var(--fdq-radius-md);
  font-size: 16px;
  font-weight: 600;
  color: var(--fdq-primary-container);
}
.cerr-badge .material-symbols-outlined { color: var(--fdq-primary-container); }

/* ---------- CTA final ---------- */
.cerr-cta { padding-block: var(--fdq-space-xl); }
.cerr-cta__inner {
  max-width: var(--fdq-container-max);
  margin-inline: auto;
  padding-inline: var(--fdq-space-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--fdq-space-md);
}
.cerr-cta__title { margin: 0; color: #fff; }
.cerr-cta__buttons { gap: var(--fdq-space-sm); }

/* ---------- Responsive ---------- */
@media (min-width: 640px) {
  .cerr-process__steps { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 768px) {
  .cerr-services__grid { grid-template-columns: repeat(2, 1fr); }
  .cerr-security__inner { grid-template-columns: 1fr 1fr; }
  .cerr-coverage__inner { grid-template-columns: 1fr 1fr; }
  .cerr-coverage__badges { justify-content: flex-end; }
  .cerr-process__steps { grid-template-columns: repeat(4, 1fr); }
  .cerr-process__steps::before {
    content: "";
    position: absolute;
    top: 24px;
    left: 12.5%;
    right: 12.5%;
    height: 2px;
    background-color: var(--fdq-outline-variant);
    z-index: 0;
  }
}
@media (min-width: 1024px) {
  .cerr-services__grid { grid-template-columns: repeat(4, 1fr); }
  .cerr-pricing__inner { grid-template-columns: 1fr 1fr; }
}

/* =====================================================================
   Iconos SVG/PNG (sustituyen a los material symbols) y foto con <img>
   ===================================================================== */
/* Caja cuadrada + object-fit:contain: cada SVG tiene proporciones distintas
   (anchos/altos dispares), así todos ocupan el mismo hueco y quedan uniformes. */
.cerr-hero-trust .fdq-icon-img { width: 18px; height: 18px; object-fit: contain; }
.cerr-service__icon .fdq-icon-img { width: 28px; height: 28px; object-fit: contain; }
.cerr-difference__icon .fdq-icon-img { width: 48px; height: 48px; object-fit: contain; }
.cerr-difference__address .fdq-icon-img { width: 18px; height: 18px; object-fit: contain; }
.cerr-security__icon .fdq-icon-img { width: 40px; height: 40px; object-fit: contain; }
.cerr-badge .fdq-icon-img { width: 22px; height: 22px; object-fit: contain; }

/* Foto de la sección de seguridad */
.cerr-security__media { overflow: hidden; }
.cerr-security__img { display: block; width: 100%; height: 100%; object-fit: cover; }
