/* ════════════════════════════════════════════════════════════ */
/*  ESTILOS IDGEN — Pegar en Apariencia → Personalizar → CSS    */
/*  adicional, o en el CSS del tema ASAP                         */
/* ════════════════════════════════════════════════════════════ */

/* ── Botón sucursal ── */
.boton-sucursal {
  display: inline-block;
  background-color: #00a3c4;
  color: #fff !important;
  font-weight: 700;
  font-size: 1rem;
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  text-align: center;
  text-decoration: none !important;
  border-bottom: 4px solid #0075e3;
  transition: transform 0.2s linear, background-color 0.2s ease;
}
.boton-sucursal:hover { transform: scale(1.05); background-color: #0091b0; }

/* ── CTAs fila ── */
.idgen-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  justify-content: center;
  margin: 1.5rem 0 2rem;
}

/* ── Columna cuadrada (ficha + mapa) ── */
.columna-cuadrada {
  display: flex;
  flex-wrap: wrap;
  border: 2px solid #00a3c4;
  border-radius: 6px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
  margin-bottom: 2rem;
}
.columna-cuadrada .info,
.columna-cuadrada .mapa { flex: 1 1 300px; padding: 1.5rem; }
.columna-cuadrada h2.localtit,
.columna-cuadrada h2.mapatit {
  all: unset;
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: 1.3rem !important;
  font-weight: 700;
  color: #0075e3 !important;
  margin-bottom: 1rem;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}

/* ── Lista flecha ── */
ul.listaflecha { list-style: none; margin: 1rem 0 1.25rem; padding: 0 5px; font-size: 17px; line-height: 1.6; }
ul.listaflecha li { position: relative; padding-left: 1.6em; margin-bottom: .5rem; }
ul.listaflecha li::before { content: "\25BA"; position: absolute; left: 0; top: .35em; color: #619CDA; font-size: .9em; }
ul.listaflecha li strong { color: #37474F; font-weight: 700; }

/* ── Mapa placeholder ── */
.mapa-placeholder {
  width: 100%; aspect-ratio: 4/3; min-height: 280px;
  background: linear-gradient(135deg,#e6f0ff,#d0e8f5);
  border-radius: 10px; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  color: #64748b; font-size: .9rem; gap: .5rem;
  border: 1px dashed #00a3c4;
}

/* ── Tarjetas info (horario, teléfono, documentos) ── */
.fila-tarjetas { display: flex; flex-wrap: wrap; gap: 1.5rem; margin: 1.5rem 0; align-items: stretch; }
.tarjeta-info {
  flex: 1 1 260px; min-width: 0; background: #fff;
  border: 2px solid #00a3c4; border-radius: 10px;
  padding: 1.25rem 1.5rem 1.5rem;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
  overflow-wrap: anywhere; word-break: break-word;
}
.tarjeta-info h2 {
  all: unset; display: block;
  font-size: 1.2rem !important; font-weight: 700;
  color: #0075e3 !important; margin-bottom: .75rem; line-height: 1.4;
  background: none !important; border: none !important; padding: 0 !important;
}
.tarjeta-info p { font-size: 1rem; color: #181818; line-height: 1.6; margin-bottom: .5rem; }
.tarjeta-info .boton-sucursal { display: block; text-align: center; margin-top: 1rem; }

/* ── Cajas de texto ── */
.cajaverdeclara { background:#f0fdf9; border-left:4px solid #b3e6d2; padding:1rem 1.25rem; border-radius:4px; margin:1.5rem 0; font-size:1rem; line-height:1.6; }
.cajagrisclara  { background:#f5f5f5; border-left:4px solid #d1d1d1; padding:1rem 1.25rem; border-radius:4px; margin:1.5rem 0; font-size:1rem; line-height:1.6; }
.cajaazulclara  { background:#e6f0ff; border-left:4px solid #0075e3; padding:1rem 1.25rem; border-radius:4px; margin:1.5rem 0; font-size:1rem; line-height:1.6; }

/* ── Tabla aranceles ── */
.tabla-aranceles { width:100%; border-collapse:collapse; margin:1rem 0 1.5rem; font-size:.93rem; }
.tabla-aranceles th { background:#002a5c; color:#fff; padding:.6rem 1rem; text-align:left; font-weight:700; }
.tabla-aranceles td { padding:.55rem 1rem; border-bottom:1px solid #e6eaf0; }
.tabla-aranceles tr:nth-child(even) td { background:#f5f7fa; }
.tabla-aranceles tr:last-child td { border-bottom:none; }

/* ── CLUSTER TRÁMITES ── */
.idgen-tramites-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .85rem;
  margin: 1rem 0 1.5rem;
}
.idgen-tramite-card {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  border: 1px solid #e0eaf5 !important;
  background: #fff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.05) !important;
  transition: transform .18s, box-shadow .18s !important;
  color: inherit !important;
  height: 100%;
}
.idgen-tramite-card:hover { transform: translateY(-3px) !important; box-shadow: 0 8px 20px rgba(0,115,150,.13) !important; }
.idgen-card-accent { height: 5px; background: linear-gradient(90deg, #00a3c4, #0075e3); flex-shrink: 0; width: 100%; }
.idgen-card-body { padding: .9rem 1rem 1rem; display: flex; flex-direction: column; gap: .3rem; flex: 1; }

/* H3 dentro de clusters — anular estilos globales del tema */
.idgen-tramites-grid h3,
.idgen-ciudad-grid h3 {
  font-size: .95rem !important;
  font-weight: 700 !important;
  color: #002a5c !important;
  margin: 0 0 .25rem !important;
  line-height: 1.35 !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.idgen-card-tag { font-size:.68rem; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:#00a3c4; display:block; margin-bottom:.1rem; }
.idgen-card-desc { font-size:.82rem; color:#6a7e99; line-height:1.45; display:block; font-weight:400; margin-top:.15rem; }
.idgen-card-more {
  font-size:.78rem; font-weight:700; color:#0075e3;
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:.7rem; padding-top:.6rem;
  border-top:1px solid #eef3f9;
}
.idgen-card-more i { transition: transform .2s ease; font-size:.85em; }
.idgen-tramite-card:hover .idgen-card-more { color:#005bb5; }
.idgen-tramite-card:hover .idgen-card-more i { transform: translateX(4px); }

/* ── CLUSTER CIUDADES ── */
.idgen-ciudad-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .6rem;
  margin: 1rem 0 1.25rem;
}
.idgen-ciudad-card {
  display: block !important;
  text-decoration: none !important;
  padding: .7rem .9rem !important;
  border-radius: 8px !important;
  background: #fff !important;
  border: 1px solid #ddeaf8 !important;
  border-left: 3px solid #00a3c4 !important;
  color: #002a5c !important;
  line-height: 1.3 !important;
  transition: transform .15s, box-shadow .15s !important;
}
.idgen-ciudad-card:hover { transform: translateY(-2px) !important; box-shadow: 0 5px 14px rgba(0,115,150,.1) !important; border-left-color: #0075e3 !important; }
.idgen-ciudad-card h3 {
  font-size: .88rem !important;
  font-weight: 700 !important;
  color: #002a5c !important;
  margin: 0 !important;
  line-height: 1.3 !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.idgen-ciudad-sub { display:block; font-size:.72rem; font-weight:400; color:#7a9ab8; margin-top:.15rem; }

/* ── Botón centrado ── */
.idgen-btn-center { text-align:center; margin:1.25rem 0 1.75rem; }

/* ── FAQ ── */
.faq-wrap h3 { font-size: 1.1rem; font-weight: 700; color: #002a5c; margin-top: 1.25rem; margin-bottom: .4rem; }
.faq-wrap p { font-size: 1rem; color: #181818; margin-bottom: .5rem; }

/* ── Responsive ── */
@media (max-width: 900px) { .idgen-ciudad-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 680px) {
  .columna-cuadrada { flex-direction: column; }
  .fila-tarjetas { flex-direction: column; }
  .idgen-tramites-grid { grid-template-columns: repeat(2,1fr); }
  .idgen-ciudad-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 420px) {
  .idgen-tramites-grid { grid-template-columns: 1fr; }
  .idgen-ciudad-grid { grid-template-columns: repeat(2,1fr); }
  .idgen-ctas { flex-direction: column; align-items: stretch; }
  .idgen-ctas .boton-sucursal { width:100%; text-align:center; }
}

/* ── Tabla de horario (caja Horario de atención) ── */
.idgen-horario-tabla { width:100%; border-collapse:collapse; margin:.25rem 0 .5rem; font-size:.92rem; }
.idgen-horario-tabla td { padding:.4rem .5rem; border-bottom:1px solid #eef3f9; }
.idgen-horario-tabla td:first-child { font-weight:600; color:#37474F; width:42%; }
.idgen-horario-tabla td:last-child { color:#181818; }
.idgen-horario-tabla tr:last-child td { border-bottom:none; }
.idgen-horario-tabla .idgen-cerrado { color:#b0392b; font-weight:600; }
.idgen-horario-tip { font-size:.85rem; color:#6a7e99; margin-top:.4rem; font-style:italic; }
