/* ==========================================================================
   Vitrine / arquivo de produtos — archive-product.php
   Depende de components.css (breadcrumb, product-card, section-title).
   ========================================================================== */

.vruumy-archive { overflow-x: clip; }

/* ==========================================================================
   Topo da vitrine
   ========================================================================== */
.vruumy-archive__hero {
	padding: clamp(3rem, 7vw, 5rem) clamp(1.25rem, 3vw, 2.5rem) clamp(1.5rem, 3vw, 2rem);
	background:
		radial-gradient(circle at 20% 50%, rgba(0, 178, 255, .1), transparent 55%),
		radial-gradient(circle at 80% 50%, rgba(255, 45, 142, .09), transparent 55%),
		var(--vruumy-gray);
	border-bottom: 1px solid var(--vruumy-border);
}
.vruumy-archive__hero-inner {
	max-width: 1320px;
	margin: 0 auto;
}
.vruumy-archive__hero-eyebrow {
	display: block;
	margin-bottom: .6rem;
	font-family: var(--vruumy-font-heading);
	font-size: .68rem;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--vruumy-pink);
}
.vruumy-archive__hero-title {
	margin: 0;
	font-size: clamp(1.6rem, 4vw, 2.8rem);
	letter-spacing: .03em;
	color: var(--vruumy-white);
}

/* ==========================================================================
   Controles: filtros + ordenação
   ========================================================================== */
.vruumy-archive__controls {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	max-width: 1320px;
	margin: 0 auto;
	padding: 1.25rem clamp(1.25rem, 3vw, 2.5rem);
	border-bottom: 1px solid var(--vruumy-border);
}

.vruumy-archive__filters {
	display: flex;
	align-items: center;
	gap: .5rem;
	flex-wrap: wrap;
}
.vruumy-archive__filter {
	display: inline-block;
	padding: .45rem 1.1rem;
	border: 1px solid var(--vruumy-border);
	border-radius: 999px;
	background: transparent;
	font-family: var(--vruumy-font-heading);
	font-size: .7rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
	text-decoration: none;
	cursor: pointer;
	transition: border-color .25s var(--vruumy-ease), color .25s var(--vruumy-ease), box-shadow .25s var(--vruumy-ease);
}
.vruumy-archive__filter:hover {
	border-color: var(--vruumy-blue);
	color: var(--vruumy-blue);
}
.vruumy-archive__filter.is-active {
	border-color: var(--vruumy-blue);
	color: var(--vruumy-white);
	background: rgba(0, 178, 255, .12);
	box-shadow: var(--vruumy-glow-blue);
}

.vruumy-archive__sort {
	display: flex;
	align-items: center;
	gap: .75rem;
}
.vruumy-archive__sort label {
	font-size: .72rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
	white-space: nowrap;
}
.vruumy-archive__sort select,
.woocommerce-ordering select {
	padding: .45rem .9rem;
	border: 1px solid var(--vruumy-border) !important;
	border-radius: var(--vruumy-radius) !important;
	background: var(--vruumy-gray) !important;
	color: var(--vruumy-white) !important;
	font-family: var(--vruumy-font-body) !important;
	font-size: .8rem !important;
	cursor: pointer;
	appearance: auto;
}

/* ==========================================================================
   Meta-info (count + resultados)
   ========================================================================== */
.vruumy-archive__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	max-width: 1320px;
	margin: 0 auto;
	padding: 1rem clamp(1.25rem, 3vw, 2.5rem) 0;
}
.vruumy-archive__count {
	font-size: .8rem;
	color: var(--vruumy-text-muted);
}

/* ==========================================================================
   Grade de produtos
   ========================================================================== */
.vruumy-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 1.5rem;
	max-width: 1320px;
	margin: 2rem auto 0;
	padding: 0 clamp(1.25rem, 3vw, 2.5rem);
}

/* ==========================================================================
   Estado vazio
   ========================================================================== */
.vruumy-archive__empty {
	max-width: 1320px;
	margin: 3rem auto;
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.5rem);
	border: 1px dashed var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	text-align: center;
	color: var(--vruumy-text-muted);
}
.vruumy-archive__empty p { font-size: .94rem; margin: 0; }
.vruumy-archive__empty a {
	color: var(--vruumy-blue);
	text-decoration: none;
	font-family: var(--vruumy-font-heading);
	font-size: .76rem;
	letter-spacing: .1em;
	text-transform: uppercase;
}

/* ==========================================================================
   Paginação
   ========================================================================== */
.vruumy-archive__pagination,
.woocommerce-pagination {
	display: flex;
	justify-content: center;
	max-width: 1320px;
	margin: 3rem auto 4rem;
	padding: 0 clamp(1.25rem, 3vw, 2.5rem);
}
.vruumy-archive__pagination ul,
.woocommerce-pagination ul {
	display: flex;
	gap: .4rem;
	margin: 0;
	padding: 0;
	list-style: none;
}
.vruumy-archive__pagination li a,
.vruumy-archive__pagination li span,
.woocommerce-pagination li a,
.woocommerce-pagination li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 .75rem;
	border: 1px solid var(--vruumy-border);
	border-radius: 8px;
	font-family: var(--vruumy-font-heading);
	font-size: .76rem;
	letter-spacing: .06em;
	color: var(--vruumy-text-muted);
	text-decoration: none;
	transition: border-color .25s var(--vruumy-ease), color .25s var(--vruumy-ease), box-shadow .25s var(--vruumy-ease);
}
.vruumy-archive__pagination li a:hover,
.woocommerce-pagination li a:hover {
	border-color: var(--vruumy-blue);
	color: var(--vruumy-blue);
	box-shadow: var(--vruumy-glow-blue);
}
.vruumy-archive__pagination li span.current,
.woocommerce-pagination li span.current {
	border-color: var(--vruumy-blue);
	color: var(--vruumy-white);
	background: rgba(0, 178, 255, .12);
	box-shadow: var(--vruumy-glow-blue);
}

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width: 768px) {
	.vruumy-archive__controls { flex-direction: column; align-items: flex-start; }
	.vruumy-archive__grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}

@media (max-width: 480px) {
	.vruumy-archive__grid { grid-template-columns: 1fr 1fr; gap: .9rem; }
}
