/* Shop page specific styles – built on top of base.css */

/* Layout helpers */
.section { padding-block: var(--space-16); }
.section--alt { background: var(--gray-50); }
.section-header { margin-block-end: var(--space-6); }
.section-header p { color: var(--color-muted); }

/* Hero */
.shop-hero { position: relative; background: linear-gradient(135deg, rgba(255,212,0,0.18), rgba(20,184,166,0.12)), var(--color-bg); padding-block: var(--space-18); overflow: hidden; }
.shop-hero::before, .shop-hero::after { content: ""; position: absolute; inset: auto auto -30px -30px; width: 160px; height: 160px; background: radial-gradient(circle at 30% 30%, rgba(217,70,239,0.28), transparent 60%); filter: blur(4px); border-radius: var(--radius-xl); }
.shop-hero::after { inset: -30px -30px auto auto; background: radial-gradient(circle at 70% 70%, rgba(20,184,166,0.28), transparent 60%); }
.hero-grid { grid-template-columns: 1.2fr 1fr; gap: var(--space-8); }
.hero-copy .nav-inline { margin-top: var(--space-5); }
.hero-media img { border-radius: var(--radius-lg); }

@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; }
}

/* Filters */
.filters { display: grid; gap: var(--space-6); }
.filters-row { display: grid; gap: var(--space-2); }
.filters-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
.filters-actions { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.range-wrap { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--space-3); }
#priceOutput { font-weight: 700; color: var(--color-text); }
.results-count { color: var(--color-muted); }

@media (max-width: 960px) {
  .filters-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .filters-grid { grid-template-columns: 1fr; }
}

/* Products */
#productGrid { margin-top: var(--space-8); }
.product-card { display: grid; gap: var(--space-3); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--color-surface); box-shadow: var(--shadow-sm); transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-in-out); }
.product-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.product-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); }
.product-meta { display: flex; align-items: center; gap: var(--space-3); color: var(--color-muted); }
.color-dot { width: 12px; height: 12px; border-radius: 50%; border: 1px solid var(--color-border); }
.dot-yellow { background: var(--color-yellow); }
.dot-teal { background: var(--color-primary); }
.dot-magenta { background: var(--color-accent); }
.dot-navy { background: var(--color-navy); }
.dot-white { background: var(--color-white); }
.price { font-weight: 800; }
.card-actions { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }

/* Lists */
.bests-list { display: grid; gap: var(--space-3); }
.payment-list { display: grid; gap: var(--space-2); margin-block: var(--space-4) var(--space-2); }

/* Tables */
.size-card { display: grid; gap: var(--space-4); }
.size-table { width: 100%; border-collapse: collapse; }
.size-table th, .size-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--color-border); }
.size-table thead th { background: var(--gray-100); font-weight: 700; }

/* Reviews */
.review p { font-style: italic; }

/* CTAs */
.cta-row { margin-top: var(--space-5); display: flex; flex-wrap: wrap; gap: var(--space-4); }
