/* set_availability.css — cartes boutiques de l'onglet « Disponibilités » (fiche set).
   Remplace le tableau DataTables. Tout est scopé sous .avail pour éviter les collisions
   avec style.css. Couleurs/rayons via les design tokens (--lb-*). */

.avail .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); gap: 1.1rem; }

/* Barre de tri */
.avail .sort-bar { display: flex; align-items: center; gap: .5rem; margin-bottom: 1rem; color: var(--lb-muted); font-size: .9rem; }
.avail .sort-bar select { max-width: 220px; }

/* Carte */
.avail .sc { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--lb-border);
  border-left: 4px solid var(--lb-brand); border-radius: var(--lb-radius); box-shadow: var(--lb-shadow-sm); overflow: hidden; }
.avail .sc.is-muted { opacity: .6; border-left-color: var(--lb-muted); }
.avail .sc.is-closed { border-left-color: var(--lb-muted); }

.avail .sc-main { flex: 1; }
.avail .sc-head { display: flex; gap: 1.1rem; padding: 1.1rem 1.15rem .75rem; }
.avail .shop-av { width: 92px; height: 92px; object-fit: contain; background: #fff; padding: 4px; box-sizing: border-box; border-radius: var(--lb-radius); flex: 0 0 auto; box-shadow: var(--lb-shadow-sm); }
.avail .sc-name { font-family: var(--lb-font-heading); font-weight: 700; font-size: 1.15rem; line-height: 1.2; }
.avail .sc-name a { color: var(--lb-ink); }
.avail .sc-flag { width: 24px; height: 16px; border-radius: 2px; object-fit: cover; box-shadow: 0 0 0 1px rgba(0, 0, 0, .08); vertical-align: baseline; }
.avail .sc-city { color: var(--lb-muted); font-size: .85rem; margin: .15rem 0 .4rem; }

.avail .sc-body { padding: 0 1.15rem .8rem; }
.avail .comment { font-style: italic; color: #444; font-size: .88rem; margin-bottom: .6rem; }
.avail .opt-badge { padding: .4em .6em; font-weight: 500; font-size: .72rem; margin-right: .25rem; margin-bottom: .25rem; }

/* Note de disponibilité (retour estimé / file / réservé), au-dessus du pied
   pour ne pas décaler le bouton d'une carte à l'autre */
.avail .sc-note { padding: .5rem 1.15rem; font-size: .8rem; color: var(--lb-muted); text-align: right; border-top: 1px dashed var(--lb-border); }
.avail .sc-note a { font-weight: 500; }

/* Pied : prix + CTA */
.avail .sc-foot { padding: .9rem 1.15rem; border-top: 1px solid var(--lb-border); background: var(--lb-surface-alt); }
.avail .price-block { height: 74px; display: flex; flex-direction: column; justify-content: center; }
.avail .prices { display: flex; gap: 1.2rem; }
.avail .price { font-family: var(--lb-font-heading); font-weight: 700; font-size: 2.3rem; line-height: 1; color: var(--lb-ink); }
.avail .price span { font-size: .85rem; font-weight: 400; color: var(--lb-ink); }
.avail .prices .price { font-size: 1.85rem; }
.avail .price-lab { font-size: .68rem; color: var(--lb-muted); text-transform: uppercase; letter-spacing: .03em; margin-top: .15rem; }
.avail .deposit { font-size: .82rem; color: var(--lb-muted); margin-top: .4rem; }
.avail .deposit i { margin-right: .35rem; opacity: .65; }
.avail .deposit strong { color: var(--lb-ink); font-weight: 600; }
.avail .sc-cta { margin-top: .7rem; }
.avail .sc-cta .btn { display: block; width: 100%; box-sizing: border-box; text-align: center; }

/* Mode solo (1 seul magasin, pleine largeur) : prix/CTA dans un panneau à droite */
.avail.solo .sc { flex-direction: row; align-items: stretch; }
.avail.solo .sc-main { display: flex; flex-direction: column; }
.avail.solo .sc-foot { display: flex; flex-direction: column; justify-content: center; align-items: flex-end; gap: 1rem;
  border-top: none; border-left: 1px solid var(--lb-border); min-width: 270px; }
.avail.solo .price-block { height: auto; align-items: flex-end; text-align: right; }
.avail.solo .prices { justify-content: flex-end; }
.avail.solo .sc-cta { margin-top: 0; }
.avail.solo .sc-cta .btn { display: inline-block; width: auto; }

@media (max-width: 640px) {
  .avail.solo .sc { flex-direction: column; }
  .avail.solo .sc-foot { display: block; border-left: none; border-top: 1px solid var(--lb-border); min-width: 0; }
  .avail.solo .price-block { align-items: flex-start; text-align: left; height: 74px; }
  .avail.solo .prices { justify-content: flex-start; }
  .avail.solo .sc-cta .btn { display: block; width: 100%; }
}
