/* ==========================================================================
   Componentes compartilhados Vruumy
   Carregado em todas as páginas (home, produto, vitrine, experiências).
   ========================================================================== */

/* ==========================================================================
   Breadcrumb
   ========================================================================== */
.vruumy-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .25rem;
	max-width: 1320px;
	margin: 0 auto;
	padding: 1.1rem clamp(1.25rem, 3vw, 2.5rem);
	font-size: .75rem;
	letter-spacing: .04em;
	color: var(--vruumy-text-muted);
}
.vruumy-breadcrumb a {
	color: var(--vruumy-text-muted);
	text-decoration: none;
	transition: color .2s var(--vruumy-ease);
}
.vruumy-breadcrumb a:hover { color: var(--vruumy-blue); }
.vruumy-breadcrumb__sep {
	margin: 0 .15rem;
	opacity: .4;
	user-select: none;
}
.vruumy-breadcrumb__current { color: var(--vruumy-white); }

/* ==========================================================================
   Faixa de confiança
   ========================================================================== */
.vruumy-trustbar {
	border-top: 1px solid var(--vruumy-border);
	border-bottom: 1px solid var(--vruumy-border);
	background: var(--vruumy-gray);
	overflow-x: auto;
	scrollbar-width: none;
}
.vruumy-trustbar::-webkit-scrollbar { display: none; }
.vruumy-trustbar__list {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(1.5rem, 4vw, 3.25rem);
	max-width: 1320px;
	min-width: max-content;
	margin: 0 auto;
	padding: 1.1rem clamp(1.25rem, 3vw, 2.5rem);
	list-style: none;
}
.vruumy-trustbar__list li {
	display: flex;
	align-items: center;
	gap: .75rem;
	white-space: nowrap;
	font-size: .76rem;
	font-weight: 600;
	letter-spacing: .03em;
	color: var(--vruumy-white);
}
.vruumy-trustbar__list .vruumy-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: 1px solid var(--vruumy-blue);
	background: rgba(0, 178, 255, .12);
	box-shadow: 0 0 8px rgba(0, 178, 255, .85), 0 0 22px rgba(0, 178, 255, .55), inset 0 0 10px rgba(0, 178, 255, .35);
	color: var(--vruumy-blue);
	filter: drop-shadow(0 0 4px rgba(0, 178, 255, .9));
	flex-shrink: 0;
}
.vruumy-trustbar__list .vruumy-icon svg { width: 18px; height: 18px; }
.vruumy-trustbar__list li:nth-child(2n) .vruumy-icon {
	border-color: var(--vruumy-pink);
	background: rgba(255, 45, 142, .12);
	box-shadow: 0 0 8px rgba(255, 45, 142, .85), 0 0 22px rgba(255, 45, 142, .55), inset 0 0 10px rgba(255, 45, 142, .35);
	color: var(--vruumy-pink);
	filter: drop-shadow(0 0 4px rgba(255, 45, 142, .9));
}

/* ==========================================================================
   Cabeçalhos de seção
   ========================================================================== */
.vruumy-section-title {
	position: relative;
	display: inline-block;
	margin: 0;
	padding-bottom: .6rem;
	font-size: clamp(1.2rem, 2.6vw, 1.7rem);
	letter-spacing: .05em;
	color: var(--vruumy-white);
}
.vruumy-section-title::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 56px;
	height: 2px;
	background: var(--vruumy-gradient);
	box-shadow: var(--vruumy-glow-blue);
}
.vruumy-section-title--center { display: block; text-align: center; }
.vruumy-section-title--center::after { left: 50%; transform: translateX(-50%); }

.vruumy-section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 3vw, 2.5rem);
}
.vruumy-section-link {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	font-family: var(--vruumy-font-heading);
	font-size: .74rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--vruumy-blue);
	text-decoration: none;
	transition: color .25s var(--vruumy-ease), gap .25s var(--vruumy-ease);
}
.vruumy-section-link .vruumy-icon { width: 16px; height: 16px; }
.vruumy-section-link:hover { gap: .65rem; color: var(--vruumy-pink); }

.vruumy-empty-state {
	max-width: 1320px;
	margin: 1.75rem auto 0;
	padding: 2.5rem clamp(1.5rem, 4vw, 2.5rem);
	border: 1px dashed var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	color: var(--vruumy-text-muted);
	font-size: .9rem;
	text-align: center;
}

/* ==========================================================================
   Card de produto — usado na home, vitrine e arquivo
   ========================================================================== */
.vruumy-product-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	background: var(--vruumy-gray);
	transition: transform .35s var(--vruumy-ease), border-color .35s var(--vruumy-ease), box-shadow .35s var(--vruumy-ease);
}
.vruumy-product-card:hover {
	transform: translateY(-6px);
	border-color: var(--vruumy-blue);
	box-shadow: var(--vruumy-glow-blue), var(--vruumy-shadow-deep);
}
.vruumy-product-card__media {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	background: radial-gradient(circle at 50% 62%, rgba(0, 178, 255, .08), transparent 65%), var(--vruumy-black);
	text-decoration: none;
}
.vruumy-product-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 1.5rem;
}
.vruumy-product-card__badge {
	position: absolute;
	top: .9rem;
	left: .9rem;
	z-index: 1;
	padding: .35rem .8rem;
	border-radius: 999px;
	font-family: var(--vruumy-font-heading);
	font-size: .6rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--vruumy-white);
}
.vruumy-product-card__badge--best { background: var(--vruumy-gradient); box-shadow: var(--vruumy-glow-pink); }
.vruumy-product-card__badge--top { background: linear-gradient(135deg, var(--vruumy-blue), #2563eb); box-shadow: var(--vruumy-glow-blue); }
.vruumy-product-card__body {
	display: flex;
	flex-direction: column;
	gap: .4rem;
	padding: 1.25rem 1.4rem 1.5rem;
	flex: 1;
}
.vruumy-product-card__title {
	margin: 0;
	font-family: var(--vruumy-font-heading);
	font-size: .92rem;
	letter-spacing: .03em;
	line-height: 1.35;
	text-transform: none;
}
.vruumy-product-card__title a { color: var(--vruumy-white); text-decoration: none; }
.vruumy-product-card__title a:hover { color: var(--vruumy-blue); }
.vruumy-product-card__rating .star-rating { font-size: .85rem; color: var(--vruumy-blue); }
.vruumy-product-card__price {
	margin: .15rem 0 0;
	font-family: var(--vruumy-font-heading);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--vruumy-white);
}
.vruumy-product-card__price ins { color: var(--vruumy-pink); text-decoration: none; }
.vruumy-product-card__price del { color: var(--vruumy-text-muted); font-size: .8em; opacity: .7; }
.vruumy-product-card__installment { margin: 0; font-size: .76rem; color: var(--vruumy-text-muted); }
.vruumy-product-card__cta {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	margin-top: auto;
	padding-top: .75rem;
	font-family: var(--vruumy-font-heading);
	font-size: .72rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--vruumy-blue);
	text-decoration: none;
	border-top: 1px solid var(--vruumy-border);
	transition: gap .25s var(--vruumy-ease), color .25s var(--vruumy-ease);
}
.vruumy-product-card__cta .vruumy-icon { width: 14px; height: 14px; }
.vruumy-product-card__cta:hover { gap: .55rem; color: var(--vruumy-pink); }

/* ==========================================================================
   Responsivo — componentes compartilhados
   ========================================================================== */
@media (max-width: 680px) {
	.vruumy-trustbar__list { justify-content: flex-start; }
	.vruumy-section-head { flex-direction: column; align-items: flex-start; gap: .5rem; }
}
