.shop{
  padding: 22px 0 44px;
}

.subnav{
  position: relative;
  z-index: 40;
  background: rgba(20, 28, 51, 0.7);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.subnav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 12px 0;
}

.chips{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 22px;
  min-height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.82);
  font-weight: 800;
  font-size: 14px;
}
.chip:hover{ background: rgba(255,255,255,.07); }
.chip.is-active{
  background: rgba(109,92,255,.18);
  border-color: rgba(109,92,255,.35);
  color: rgba(255,255,255,.92);
}

.subnav-right{
  display:flex;
  align-items:center;
  gap: 12px;
  flex: 0 0 auto;
}
.view-toggle{
  display:inline-flex;
  gap: 8px;
}
.vt{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  display:grid;
  place-items:center;
  color: rgba(255,255,255,.85);
}
.vt.is-on{
  background: rgba(43,212,255,.12);
  border-color: rgba(43,212,255,.22);
}

/* Grille boutique */
.products{
  display:grid;
  gap: 14px;
  margin-top: 16px;
}
.products--grid{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Carte produit */
.pcard{
  border-radius: 18px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
  overflow:hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,.40);
}
.pcard-cover{
  display:block;
  height: 170px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.pcard-badge{
  position:absolute;
  left: 10px;
  top: 10px;
  font-size: 11px;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.12);
}
.pcard-body{
  padding: 12px;
}
.pcard-title{
  font-weight: 900;
  font-size: 13px;
  line-height: 1.25;
  margin-bottom: 6px;
}
.pcard-meta{
  font-size: 12px;
  margin-bottom: 10px;
}
.pcard-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

/* Mode liste */
.products--list{
  grid-template-columns: 1fr;
}
.products--list .pcard{
  display:grid;
  grid-template-columns: 220px 1fr;
}
.products--list .pcard-cover{
  height: 100%;
  min-height: 150px;
}
.products--list .pcard-actions{
  justify-content:flex-start;
  gap: 12px;
}

/* Empty */
.empty{
  margin-top: 24px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

/* Responsive */
@media (max-width: 1080px){
  .products--grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .chip{
  padding: 8px 16px;
  font-size: 10px;
}
}

@media (max-width: 720px){
  .subnav-inner{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .subnav-right{
    justify-content: space-between;
  }
  .products--grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .products--list .pcard{
    grid-template-columns: 1fr;
  }
  .products--list .pcard-cover{
    height: 170px;
    min-height: 170px;
  }
}

.products--grid{
  display:grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 16px;
}

@media (max-width: 1080px){
  .products--grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .products--grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.pcard-actions{
  display:flex;
  align-items:center;
  gap: 10px;
  justify-content: space-between;
}
.pcard-actions .buy{
  margin-left: auto;
}
