/**
 * @file
 * Filtres exposés stylés en pills pour la View animals (page /animais).
 *
 * Cible les widgets BEF (Better Exposed Filters) en mode Checkboxes/Radio.
 * Transforme chaque option en pill cliquable avec picto SVG.
 *
 * Pour basculer un filtre en pills :
 *   /admin/structure/views/view/animals/edit/page_search
 *   → cliquer sur le filtre
 *   → BEF section
 *   → Display Exposed Form: Checkboxes/Radio Buttons
 *   → Apply
 *
 * Filtres concernés actuellement : Sex, Type, Color, Sociável com.
 * Breed garde son autocomplete. Ordenar por garde son select.
 */

/* ─────── Header de la View (titre + intro) ─────── */
/* L'admin écrit le texte dans Views UI → Header > Global: Text area.
   Pattern recommandé : "[view:total_rows] animals to adopt" + sous-titre. */
.animals-listing__header {
  margin: 0 0 2rem;
  text-align: center;
}
.animals-listing__header h1,
.animals-listing__header h2,
.animals-listing__header > p:first-child,
.animals-listing__header .views-field-nothing {
  font-family: "Fraunces", "Georgia", serif;
  font-weight: 800;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ocdm-text-strong, #1f1820);
  margin: 0 0 0.5rem;
}
/* Mettre en évidence le chiffre (premier nombre du header) en framboise italic */
.animals-listing__header em,
.animals-listing__header strong {
  color: var(--ocdm-framboise, #c9357a);
  font-style: italic;
  font-weight: 800;
}
.animals-listing__header p {
  margin: 0.25rem 0;
  color: var(--ocdm-text-muted, #6b6470);
  font-size: 1rem;
}
.animals-listing__header > *:last-child {
  margin-bottom: 0;
}

/* Soulignement décoratif sous le titre */
.animals-listing__header::after {
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  background: var(--ocdm-blue, #b8d0db);
  border-radius: 2px;
  margin: 0.75rem auto 0;
}

/* ─────── Layout général des filtres ─────── */
.animals-listing__filters .views-exposed-form {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  align-items: flex-start;
}

.animals-listing__filters .form-item {
  margin: 0;
}

/* Le wrapper d'un filtre (label + widget) — flex column pour mettre le label
   au-dessus et le widget en dessous. */
.animals-listing__filters .form-item-busca,
.animals-listing__filters .form-item-sexo,
.animals-listing__filters .form-item-tipo,
.animals-listing__filters .form-item-color,
.animals-listing__filters .form-item-breed,
.animals-listing__filters .form-item-sociavel,
.animals-listing__filters .form-item-sort-by {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.animals-listing__filters .form-item > label {
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ocdm-text-strong, #1f1820);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ─────── Pills container (bef-radios / bef-checkboxes) ─────── */
.bef-radios,
.bef-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Hide native input (radio / checkbox). On stylise le label. */
.bef-radios .form-item input,
.bef-checkboxes .form-item input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Chaque option = un wrapper .form-item dans BEF. */
.bef-radios .form-item,
.bef-checkboxes .form-item {
  margin: 0;
  display: inline-flex;
}

/* Label devient le pill cliquable. */
.bef-radios .form-item label,
.bef-checkboxes .form-item label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.9rem;
  background: #fff;
  border: 1.5px solid var(--ocdm-border, #e5dfd3);
  border-radius: 999px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ocdm-text-strong, #1f1820);
  cursor: pointer;
  transition: all 0.15s ease;
  user-select: none;
  white-space: nowrap;
}

/* Hover state */
.bef-radios .form-item label:hover,
.bef-checkboxes .form-item label:hover {
  background: var(--ocdm-blue-soft, #dce9ee);
  border-color: var(--ocdm-blue, #b8d0db);
}

/* Focus accessibility */
.bef-radios .form-item input:focus-visible + label,
.bef-checkboxes .form-item input:focus-visible + label {
  outline: 2px solid var(--ocdm-framboise, #c9357a);
  outline-offset: 2px;
}

/* Checked / selected state — framboise plein */
.bef-radios .form-item input:checked + label,
.bef-checkboxes .form-item input:checked + label {
  background: var(--ocdm-framboise, #c9357a);
  border-color: var(--ocdm-framboise, #c9357a);
  color: #fff;
}
.bef-radios .form-item input:checked + label .picto,
.bef-checkboxes .form-item input:checked + label .picto {
  color: #fff;
}

/* Fallback taille — appliqué même hors contexte BEF (au cas où le widget
   n'est pas encore basculé). Évite que le SVG 256px prenne la taille
   naturelle et soit gigantesque. */
.animals-listing__filters .picto {
  display: inline-flex;
  width: 1.3em;
  height: 1.3em;
  vertical-align: middle;
}
.animals-listing__filters .picto svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ─────── Picto SVG dans le label ─────── */
.bef-radios .form-item label .picto,
.bef-checkboxes .form-item label .picto {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.3em;
  height: 1.3em;
  color: var(--ocdm-framboise, #c9357a);
  transition: color 0.15s ease;
}
.bef-radios .form-item label .picto svg,
.bef-checkboxes .form-item label .picto svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ─────── BEF Links widget (Sex, Type, Sociável) ─────── */
/* Markup BEF Links : <div class="bef-links"><ul><li><a class="bef-link [bef-link--selected]">…</a></li></ul></div> */
.bef-links ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.bef-links li {
  margin: 0;
  list-style: none;
}
.bef-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.9rem;
  background: #fff;
  border: 1.5px solid var(--ocdm-border, #e5dfd3);
  border-radius: 999px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ocdm-text-strong, #1f1820) !important;
  text-decoration: none !important;
  cursor: pointer;
  transition: all 0.15s ease;
  user-select: none;
  white-space: nowrap;
}
.bef-link:hover {
  background: var(--ocdm-blue-soft, #dce9ee);
  border-color: var(--ocdm-blue, #b8d0db);
  color: var(--ocdm-text-strong, #1f1820) !important;
}
.bef-link:focus-visible {
  outline: 2px solid var(--ocdm-framboise, #c9357a);
  outline-offset: 2px;
}
.bef-link--selected,
.bef-link.bef-link--selected {
  background: var(--ocdm-framboise, #c9357a);
  border-color: var(--ocdm-framboise, #c9357a);
  color: #fff !important;
}
.bef-link--selected:hover {
  background: var(--ocdm-framboise-dark, #a52764);
  border-color: var(--ocdm-framboise-dark, #a52764);
  color: #fff !important;
}
.bef-link .picto {
  color: var(--ocdm-framboise, #c9357a);
  transition: color 0.15s ease;
}
/* DOIT venir APRÈS .bef-link .picto — sinon même spécificité (0,0,2,0)
   et l'ordre fait que le picto reste framboise sur le pill actif. */
.bef-link--selected .picto {
  color: #fff;
}

/* ─────── Select2 (Color, Breed) ─────── */
.animals-listing__filters .select2-container .select2-selection {
  border: 1.5px solid var(--ocdm-border, #e5dfd3) !important;
  border-radius: 999px !important;
  height: auto !important;
  min-height: 40px;
  padding: 0.15rem 0.75rem;
  background: #fff;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.88rem;
  transition: border-color 0.15s ease;
}
.animals-listing__filters .select2-container--focus .select2-selection,
.animals-listing__filters .select2-container--open .select2-selection {
  border-color: var(--ocdm-framboise, #c9357a) !important;
  outline: none;
}
.animals-listing__filters .select2-container .select2-selection__rendered {
  line-height: 30px;
  color: var(--ocdm-text-strong, #1f1820);
}
.animals-listing__filters .select2-container .select2-selection__arrow {
  height: 36px;
}
.animals-listing__filters .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--ocdm-framboise, #c9357a);
  border: none;
  border-radius: 999px;
  padding: 2px 0.6rem;
  margin: 3px 4px 3px 0;
  color: #fff;
  font-size: 0.8rem;
  font-weight: 600;
}
.animals-listing__filters .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  color: #fff !important;
  margin-right: 0.3rem;
}

/* ─────── Champ texte "Buscar por nome" et autocomplete Breed ─────── */
.animals-listing__filters .form-item-busca input[type="text"],
.animals-listing__filters .form-item-breed input[type="text"] {
  padding: 0.55rem 1rem;
  border: 1.5px solid var(--ocdm-border, #e5dfd3);
  border-radius: 999px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.9rem;
  min-width: 220px;
  background: #fff;
  transition: border-color 0.15s ease;
}
.animals-listing__filters .form-item-busca input[type="text"]:focus,
.animals-listing__filters .form-item-breed input[type="text"]:focus {
  border-color: var(--ocdm-framboise, #c9357a);
  outline: none;
}

/* ─────── Sort select reste classique mais stylé ─────── */
.animals-listing__filters .form-item-sort-by select {
  padding: 0.5rem 2rem 0.5rem 1rem;
  border: 1.5px solid var(--ocdm-border, #e5dfd3);
  border-radius: 999px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  background: #fff;
  cursor: pointer;
}

/* ─────── Boutons Aplicar / Limpar ─────── */
.animals-listing__filters .form-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.5rem;
  width: 100%;
  flex-basis: 100%;
}
.animals-listing__filters .form-actions .button {
  padding: 0.55rem 1.5rem;
  border-radius: 999px;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.9rem;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: all 0.15s ease;
}
.animals-listing__filters .form-actions [data-drupal-selector*="reset"],
.animals-listing__filters .form-actions .form-submit:not([data-drupal-selector*="submit"]) {
  background: transparent;
  border-color: var(--ocdm-border, #e5dfd3);
  color: var(--ocdm-text-strong);
}
.animals-listing__filters .form-actions input[type="submit"]:hover {
  background: var(--ocdm-framboise-dark);
}

/* Couleur swatch pour le filter Color — pastille devant le label */
.bef-checkboxes .form-item label.has-color::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--swatch, #ccc);
  border: 1px solid rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 768px) {
  .animals-listing__filters .views-exposed-form {
    gap: 0.85rem;
  }
  .bef-radios .form-item label,
  .bef-checkboxes .form-item label {
    font-size: 0.82rem;
    padding: 0.4rem 0.75rem;
  }
}
