/* =========================================================
   SHOP – FRONTEND
   ========================================================= */

.shop-products {
  max-width: 1100px;
}

/* ============================= */
/* GRID */
/* ============================= */

.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-lg);
}

/* ============================= */
/* EMPTY STATE */
/* ============================= */

.shop-empty {
  text-align: center;
  padding: var(--space-xl);
  color: var(--text-secondary);
  font-size: 0.9rem;
}

/* ============================= */
/* CARD */
/* ============================= */

.shop-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);

  display: flex;
  flex-direction: column;
  gap: var(--space-md);

  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.shop-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

/* ============================= */
/* HEADER */
/* ============================= */

.shop-card-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-sm);
}

.shop-card-header h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}

.shop-price {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent-start);
  white-space: nowrap;
}

/* ============================= */
/* DESCRIPTION */
/* ============================= */

.shop-description {
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--text-secondary);
  flex-grow: 1;
}

/* ============================= */
/* ACTIONS */
/* ============================= */

.shop-actions {
  margin-top: auto;
}

.shop-btn {
  width: 100%;
  height: 42px;
  border-radius: var(--radius-md);
  border: none;
  cursor: not-allowed;

  background: linear-gradient(
    135deg,
    rgba(255,255,255,0.15),
    rgba(255,255,255,0.05)
  );

  color: var(--text-secondary);
  font-size: 0.8rem;
  font-weight: 600;
}
