/* catalog.css — filters, catalog grid, pagination, list view */


.filters {
  border-radius:26px;
  padding:18px;
  display:grid;
  gap:14px;
  grid-template-columns:1.3fr repeat(7, 1fr);
  margin-bottom:18px;
}

.results-bar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin:6px 2px 16px;
}

.catalog-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:18px;
}
.pagination {
  margin-top:20px;
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
}

.page-btn {
  min-width:42px;
}

.page-btn.active {
  border-color:var(--lineAccent);
  background:linear-gradient(180deg, #fcd34d 0%, #f59e0b 100%);
  color:#231504;
}

@media (max-width:1200px) {
  .filters {
    grid-template-columns:repeat(4, 1fr);
  }
  .field-search {
    grid-column:1 / -1;
  }
}

/* V6.7 â€” Vue liste catalogue (compact) */

.catalog-grid.view-list {
  grid-template-columns: 1fr;
  
  gap: 4px;
}


.catalog-grid.view-list .food-card {
  flex-direction: row;
  
  align-items: center;
  
  min-height: 0;
  
  border-radius: 10px;
}


/* â”€â”€ Image â”€â”€ */

.catalog-grid.view-list .food-thumb-link {
  flex: 0 0 52px;
  
  align-self: stretch;
}


.catalog-grid.view-list .food-thumb-wrap {
  min-height: 52px;
  
  height: 100%;
  
  border-bottom: none;
  
  border-right: 1px solid var(--line);
}


.catalog-grid.view-list .food-thumb {
  height: 52px;
  
  padding: 4px;
}


.catalog-grid.view-list .food-expansion-badge {
  display: none;
}

.catalog-grid.view-list .food-max-stack-badge {
  bottom: 2px !important;
  right: 2px !important;
  font-size: 8px !important;
  padding: 1px 4px !important;
  border-radius: 4px;
}


/* â”€â”€ Contenu : ligne unique horizontale â”€â”€ */

.catalog-grid.view-list .food-content {
  flex-direction: row;
  
  align-items: center;
  
  gap: 8px;
  
  padding: 0 10px;
  
  flex-wrap: nowrap;
  
  overflow: hidden;
  
  min-width: 0;
}


/* â”€â”€ Nom + type â”€â”€ */

.catalog-grid.view-list .food-head {
  flex: 0 0 auto;
  
  min-width: 140px;
  
  max-width: 200px;
  
  flex-direction: column;
  
  gap: 3px;
  
  align-items: flex-start;
}


.catalog-grid.view-list .food-name {
  font-size: 13px;
  
  font-weight: 700;
  
  line-height: 1.2;
  
  white-space: nowrap;
  
  overflow: hidden;
  
  text-overflow: ellipsis;
  
  max-width: 195px;
  
  display: block;
}


.catalog-grid.view-list .food-station {
  display: none;
}


.catalog-grid.view-list .food-head .food-type {
  font-size: 10px;
  
  padding: 2px 7px;
  
  line-height: 1.4;
}


/* â”€â”€ Masquer le superflu â”€â”€ */

.catalog-grid.view-list .food-notes {
  display: none;
}


.catalog-grid.view-list .food-joke {
  display: none;
}


.catalog-grid.view-list .detail-row {
  display: none;
}


/* â”€â”€ Stats : 6 boÃ®tes de mÃªme taille â”€â”€ */

.catalog-grid.view-list .info-grid {
  flex: 0 0 auto;
  
  display: flex;
  
  flex-direction: row;
  
  gap: 3px;
  
  align-items: stretch;
}


/* BoÃ®tes Ã©gales, centrÃ©es verticalement */

.catalog-grid.view-list .info-box {
  flex: 0 0 50px;
  
  width: 50px;
  
  padding: 4px 2px;
  
  border-radius: 7px;
  
  display: flex;
  
  flex-direction: column;
  
  align-items: center;
  
  justify-content: center;
  
  gap: 1px;
  
  text-align: center;
}


.catalog-grid.view-list .info-box span:not(.score-info):not(.score-tooltip),
.catalog-grid.view-list .info-box .score-label {
  display: block;
  
  font-size: 9px;
  
  margin-bottom: 0;
  
  letter-spacing: .05em;
  
  line-height: 1.2;
  
  text-align: center;
}


.catalog-grid.view-list .info-box strong {
  display: block;
  
  font-size: 11px;
  
  line-height: 1.2;
}


/* Score : icÃ´ne â„¹ toujours visible en liste, tooltip au survol de l'icÃ´ne (comportement natif) */

.catalog-grid.view-list .score-label {
  display: inline-flex !important;
  white-space: nowrap;
  align-items: center;
}


/* Permettre au tooltip de dÃ©border la carte (overflow:hidden bloque le positionnement absolu) */

.catalog-grid.view-list .food-card,
.catalog-grid.view-list .food-content,
.catalog-grid.view-list .info-grid {
  overflow: visible;
}


/* Score (4e) et Duration (5e) un peu plus larges */

.catalog-grid.view-list .info-grid .info-box:nth-child(4),
.catalog-grid.view-list .info-grid .info-box:nth-child(5) {
  flex: 0 0 76px;
  width: 76px;
}


/* RÃ©ordonner : Spoil (6e) avant Duration (5e) */

.catalog-grid.view-list .info-grid .info-box:nth-child(5) {
  order: 6;
}


.catalog-grid.view-list .info-grid .info-box:nth-child(6) {
  order: 5;
}


/* â”€â”€ Tags : espace restant, ligne unique â”€â”€ */

.catalog-grid.view-list .food-tags {
  flex: 1 1 0;
  
  flex-wrap: nowrap;
  
  overflow: hidden;
  
  max-height: 22px;
  
  gap: 4px;
  
  align-items: center;
}


.catalog-grid.view-list .food-tags .tag {
  padding: 3px 5px;

  font-size: 10px;

  white-space: nowrap;

  flex-shrink: 0;
}

.catalog-grid.view-list .food-tags .tag > span:last-child {
  display: none;
}

.catalog-grid.view-list .food-tags .tag .buff-icon {
  margin-right: 0;
}


/* â”€â”€ Boutons : icÃ´nes 28Ã—28 â”€â”€ */

.catalog-grid.view-list .food-actions {
  flex: 0 0 auto;
  
  gap: 4px;
  
  margin-top: 0;
}


.catalog-grid.view-list .food-detail-link,
.catalog-grid.view-list .food-compare-btn,
.catalog-grid.view-list .food-share-btn {
  width: 28px;
  height: 28px;
  min-width: 28px;
  max-width: 28px;
  padding: 0;
  font-size: 0;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 1;
  box-sizing: border-box;
}


.catalog-grid.view-list .food-detail-link::before {
  content: '\2197';
  font-size: 13px;
  display: block;
  line-height: 1;
}


.catalog-grid.view-list .food-compare-btn::before {
  content: '\2295';
  font-size: 13px;
  display: block;
  line-height: 1;
}


.catalog-grid.view-list .food-share-btn::before {
  content: '\1F517';
  font-size: 13px;
  display: block;
  line-height: 1;
}


.catalog-grid.view-list .food-compare-btn.is-comparing {
  background: rgba(251,191,36,.18);
  border-color: rgba(251,191,36,.5);
}


.catalog-grid.view-list .food-compare-btn.is-comparing::before {
  content: '\2714';
  color: #fbbf24;
  font-size: 14px;
}


.load-more-btn {
  display: block;
  
  width: 100%;
  
  margin-top: 18px;
  
  padding: 16px;
  
  font-size: 15px;
}


.load-more-btn .load-more-count {
  opacity: 0.65;
  
  font-weight: 400;
  
  margin-left: 6px;
}


#viewToggleBtn {
  margin-left: auto;
}



@media (max-width: 760px) {


    /* — Catalogue — */

  .food-thumb {
    height: 180px;
  }

  .food-thumb-wrap {
    min-height: 180px;
  }


    /* — Vue liste – adaptation mobile — */
    /* Layout 2 lignes : [image | nom + actions] puis [stats]  */
    /* L'ordre HTML est : food-head → info-grid → food-tags → food-actions */
    /* On utilise order pour déplacer les actions à côté du nom */
    /* Toute la carte est cliquable via stretched link (::after sur detail-link) */

  .catalog-grid.view-list .food-card {
    cursor: pointer;
  }

  .catalog-grid.view-list .food-thumb-link {
    flex: 0 0 40px;
    align-self: center;
  }

  .catalog-grid.view-list .food-thumb-wrap {
    min-height: 40px;
    border-right: none;
    border-radius: 8px;
    overflow: hidden;
  }

  .catalog-grid.view-list .food-thumb {
    height: 40px;
    padding: 2px;
  }

  .catalog-grid.view-list .food-content {
    flex: 1 1 0;
    min-width: 0;
    flex-wrap: wrap;
    gap: 0;
    padding: 0 8px;
    overflow: hidden !important;
  }

  /* Ligne 1 : nom prend la place restante */
  .catalog-grid.view-list .food-head {
    min-width: 0;
    max-width: none;
    flex: 1 1 0;
    order: 1;
    padding: 6px 0;
  }

  .catalog-grid.view-list .food-name {
    max-width: none;
    font-size: 12px;
  }

  /* Actions remontées à droite du nom via order */
  .catalog-grid.view-list .food-actions {
    flex: 0 0 auto;
    order: 2;
    align-self: center;
    gap: 3px;
  }

  /* Boutons compacts : 24×24, identiques */
  .catalog-grid.view-list .food-detail-link,
  .catalog-grid.view-list .food-compare-btn,
  .catalog-grid.view-list .food-share-btn {
    width: 24px;
    height: 24px;
    min-width: 24px;
    max-width: 24px;
    padding: 0;
    border-radius: 6px;
  }

  .catalog-grid.view-list .food-detail-link::before,
  .catalog-grid.view-list .food-compare-btn::before,
  .catalog-grid.view-list .food-share-btn::before {
    font-size: 11px;
  }

  /* Ligne 2 : stats pleine largeur */
  .catalog-grid.view-list .info-grid {
    flex: 0 0 100%;
    order: 3;
    border-top: 1px solid var(--line);
    padding: 4px 0;
    justify-content: space-evenly;
  }

  /* Tags cachés */
  .catalog-grid.view-list .food-tags {
    display: none;
    order: 4;
  }

  /* Masquer duration et spoil (5e et 6e) */
  .catalog-grid.view-list .info-grid .info-box:nth-child(5),
  .catalog-grid.view-list .info-grid .info-box:nth-child(6) {
    display: none;
  }

  /* Stats flexibles */
  .catalog-grid.view-list .info-box {
    flex: 1 1 0;
    min-width: 0;
    width: auto;
    padding: 3px 2px;
  }

  .catalog-grid.view-list .info-box strong {
    font-size: 10px;
  }

  /* Score : même taille que les autres */
  .catalog-grid.view-list .info-grid .info-box:nth-child(4) {
    flex: 1 1 0;
    width: auto;
  }

  /* Cacher la bulle (i) du score sur mobile */
  .catalog-grid.view-list .score-info {
    display: none;
  }
}
