/* --- Fuentes e Importaciones --- */
/*@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:wght@400;500&display=swap');
*/

/* --- Variables y Estilos Base --- */
:root {
    --agn-color-primary: #0073aa;
    --agn-color-text: #333;
    --agn-color-text-light: #666;
    --agn-color-border: #e0e0e0;
    --agn-color-background: #f9f9f9;
    --agn-font-main: 'Roboto', sans-serif;
    --agn-font-title: 'Bebas Neue', sans-serif;
}

body {
    font-family: var(--agn-font-main);
}

/* --- Layout Principal --- */
#agn-directory-wrapper.agn-directory-wrapper {
    display: grid!important;
    grid-template-columns: 1fr!important;
    gap: 40px!important;
}
@media (min-width:768px) {
    #agn-directory-wrapper.agn-directory-wrapper {
        grid-template-columns: 280px 1fr!important;
    }
}

/* --- Sidebar de Filtros (Nuevo Diseño) --- */
#agn-filters-sidebar h3 {
    font-family: var(--agn-font-title);
    font-size: 2rem;
    letter-spacing: 1px;
    margin-bottom: 25px;
    color: var(--agn-color-text);
}
.agn-filter-group { margin-bottom: 25px; }
.agn-filter-group label {
    font-weight: 500;
    display: block;
    margin-bottom: 8px;
    font-size: 0.95em;
}
.agn-filter-group input[type=search],
.agn-filter-group select {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 12px;
    border: 1px solid var(--agn-color-border);
    border-radius: 4px;
    background-color: #fff;
    font-size: 0.95em;
    transition: border-color 0.2s;
}
.agn-filter-group input[type=search]:focus,
.agn-filter-group select:focus {
    border-color: var(--agn-color-primary);
    outline: none;
}
.agn-checkbox-list {
    border: 1px solid var(--agn-color-border);
    padding: 10px;
    max-height: 200px;
    overflow-y: auto;
    background: #fff;
    border-radius: 4px;
}
.agn-checkbox-list label {
    display: flex;
    align-items: center;
    font-weight: 400;
    font-size: 0.9em;
    padding: 4px 0;
}
.agn-checkbox-list input[type="checkbox"] {
    margin-right: 8px;
}
.agn-action-buttons { margin-top: 30px; }
#agn-submit-filters {
    width: 100%;
    padding: 12px;
    background-color: var(--agn-color-primary);
    color: #fff;
    border: none;
    cursor: pointer;
    text-align: center;
    border-radius: 4px;
    font-size: 1.1em;
    margin-bottom: 15px;
    transition: background-color 0.2s;
}
#agn-submit-filters:hover { background-color: #005a87; }
#agn-clear-filters {
    width: 100%;
    background: none;
    border: none;
    color: var(--agn-color-text-light);
    cursor: pointer;
    text-align: center;
    text-decoration: underline;
    padding: 0;
}
#agn-clear-filters:hover { color: var(--agn-color-primary); }

/* --- Área de Resultados (Nuevo Diseño) --- */
#agn-loader { text-align: center; padding: 40px; font-size: 1.2em; width: 100%; }
.agn-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 15px;
}
.agn-results-summary { font-size: 0.95em; color: var(--agn-color-text-light); }
.agn-results-orderby { position: relative; }
.agn-results-orderby label { margin-right: 8px; font-weight: 500; font-size: 0.95em; }
.agn-results-orderby select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 8px 30px 8px 12px;
    border: 1px solid var(--agn-color-border);
    border-radius: 4px;
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'%3E%3Cpath d='M7 10l5 5 5-5H7z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 20px;
    cursor: pointer;
}

/* --- Grilla de Tarjetas --- */
.agn-cards-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}
@media (min-width: 600px) { .agn-cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .agn-cards-grid { grid-template-columns: repeat(3, 1fr); } }

/* --- Tarjetas de Agente (Nuevo Diseño) --- */
.agn-agent-card {
    border: 1px solid var(--agn-color-border);
    border-radius: 6px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,.05);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
}
.agn-agent-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
a.agn-agent-card-link-wrapper { text-decoration: none; color: inherit; }
.agn-agent-card-image {
    background-color: #f0f0f0;
    position: relative;
    padding-top: 65%; /* Proporción más panorámica */
    height: 0;
}
.agn-agent-card-image img {
    position: absolute; top: 0; left: 0;
    width: 100%; height: 100%; object-fit: cover;
}
.agn-agent-card-content { padding: 15px; flex-grow: 1; display: flex; flex-direction: column; }
.agn-agent-card h4 {
    font-family: var(--agn-font-title);
    font-size: 1.75rem;
    letter-spacing: 0.5px;
    margin: 0 0 5px 0;
}
.agn-agent-card-specialties {
    font-size: 0.9em;
    color: var(--agn-color-text-light);
    margin-bottom: 15px;
}
.agn-agent-card-info { margin-bottom: 15px; }
.agn-info-row {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
    font-size: 0.9em;
    color: var(--agn-color-text);
}
.agn-info-icon {
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-right: 10px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}
.agn-icon-email {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'%3E%3Cpath d='M22 6c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6zm-2 0l-8 5-8-5h16zm0 12H4V8l8 5 8-5v10z'/%3E%3C/svg%3E");
}
.agn-icon-location {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z'/%3E%3C/svg%3E");
}
.agn-agent-card-tags {
    margin-top: auto; /* Empuja las etiquetas hacia abajo */
    padding-top: 15px;
    border-top: 1px solid #f0f0f0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.agn-tag {
    background-color: #eef4f8;
    color: #3d6a89;
    padding: 5px 10px;
    border-radius: 15px;
    font-size: 0.8em;
    font-weight: 500;
}

/* --- Paginación (Nuevo Diseño) --- */
.agn-pagination-container {
    margin-top: 40px;
    text-align: center;
}
.agn-pagination-container ul.page-numbers {
    display: inline-flex;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 10px;
    align-items: center;
}
.agn-pagination-container .page-numbers a,
.agn-pagination-container .page-numbers span {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--agn-color-text-light);
    font-weight: 500;
    min-width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: background-color 0.2s, color 0.2s;
}
.agn-pagination-container .page-numbers a:hover {
    color: var(--agn-color-primary);
}
.agn-pagination-container .page-numbers span.current {
    background-color: var(--agn-color-primary);
    color: #fff;
}
.agn-pagination-container .page-numbers .prev,
.agn-pagination-container .page-numbers .next {
    font-size: 1.5rem;
}

/* Alinear siempre la fila de ubicación reservando alto en "roles" */
.agn-cards-grid { align-items: stretch; }     /* asegura cards estiradas */
.agn-agent-card { height: 100%; }             /* iguala alturas de card */

.agn-agent-card-specialties{
  /* ajusta cuántas líneas reservas (2 por defecto) */
  --roles-lines: 2;
  line-height: 1.35;
  min-height: calc(var(--roles-lines) * 1.35em);
  display: block;
}

/* (opcional) un pelín menos de espacio antes de la ubicación */
.agn-agent-card-info{ margin-top: .5rem; }


/* --- FIX responsive en móvil (paginación y contenedores) --- */

/* 1) Permitir salto de línea en la paginación */
.agn-pagination-container ul.page-numbers{
  display: flex;          /* antes estaba inline-flex */
  flex-wrap: wrap;        /* permite varias líneas */
  gap: 10px;
  justify-content: center;
  max-width: 100%;
}

/* 2) Evitar desbordes horizontales en el área de resultados */
#agn-results-main,
#agn-results-container,
.agn-cards-grid { 
  max-width: 100%;
  overflow-x: hidden;
}

/* 3) En layouts grid/flex, habilitar que los hijos encojan si hace falta */
.agn-cards-grid > * { min-width: 0; }

/* 4) Asegurar imágenes responsivas dentro de la card (por si el HTML no trae width/height) */
.agn-agent-card-image img { 
  max-width: 100%;
  height: 100%;
  object-fit: cover;
}
