/* ==========================================================================
   Página de produto — single-product.php
   Depende de components.css (breadcrumb, section-title, trustbar).
   ========================================================================== */

.vruumy-single-product { overflow-x: clip; }

/* ==========================================================================
   Produto — layout principal (galeria + compra)
   ========================================================================== */
.vruumy-single-product__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
	max-width: 1320px;
	margin: 0 auto;
	padding: 2rem clamp(1.25rem, 3vw, 2.5rem) 3rem;
}

/* ==========================================================================
   Galeria
   ========================================================================== */
.vruumy-gallery {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.vruumy-gallery:focus-visible { outline: 2px solid var(--vruumy-blue); border-radius: var(--vruumy-radius); }

.vruumy-gallery__main {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1;
	overflow: hidden;
	border: 1px solid var(--vruumy-border);
	border-radius: calc(var(--vruumy-radius) + 4px);
	background: radial-gradient(circle at 50% 60%, rgba(0, 178, 255, .07), transparent 68%), var(--vruumy-gray);
	margin: 0;
}
.vruumy-gallery__img {
	display: block;
	max-width: 88%;
	max-height: 88%;
	width: auto;
	height: auto;
	object-fit: contain;
	transition: opacity .3s ease;
	filter: drop-shadow(0 20px 40px rgba(0, 0, 0, .5));
}

.vruumy-gallery__badge {
	position: absolute;
	top: 1.1rem;
	left: 1.1rem;
	z-index: 2;
	padding: .4rem 1rem;
	border-radius: 999px;
	background: var(--vruumy-gradient);
	box-shadow: var(--vruumy-glow-pink);
	font-family: var(--vruumy-font-heading);
	font-size: .62rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--vruumy-white);
}

.vruumy-gallery__nav {
	position: absolute;
	top: 50%;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--vruumy-border);
	border-radius: 50%;
	background: rgba(11, 11, 15, .7);
	color: var(--vruumy-white);
	cursor: pointer;
	transform: translateY(-50%);
	backdrop-filter: blur(6px);
	transition: border-color .25s var(--vruumy-ease), box-shadow .25s var(--vruumy-ease), color .25s var(--vruumy-ease);
}
.vruumy-gallery__nav .vruumy-icon { width: 16px; height: 16px; }
.vruumy-gallery__nav--prev { left: .8rem; }
.vruumy-gallery__nav--prev .vruumy-icon { transform: rotate(180deg); }
.vruumy-gallery__nav--next { right: .8rem; }
.vruumy-gallery__nav:hover {
	color: var(--vruumy-blue);
	border-color: var(--vruumy-blue);
	box-shadow: var(--vruumy-glow-blue);
}

.vruumy-gallery__zoom {
	position: absolute;
	bottom: .9rem;
	right: .9rem;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--vruumy-border);
	border-radius: 50%;
	background: rgba(11, 11, 15, .7);
	color: var(--vruumy-text-muted);
	cursor: pointer;
	backdrop-filter: blur(6px);
	transition: color .25s var(--vruumy-ease), border-color .25s var(--vruumy-ease);
}
.vruumy-gallery__zoom .vruumy-icon { width: 15px; height: 15px; }
.vruumy-gallery__zoom:hover { color: var(--vruumy-blue); border-color: var(--vruumy-blue); }

.vruumy-gallery__thumbs {
	display: flex;
	gap: .6rem;
	overflow-x: auto;
	scrollbar-width: none;
	padding-bottom: .15rem;
}
.vruumy-gallery__thumbs::-webkit-scrollbar { display: none; }
.vruumy-gallery__thumb {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	padding: 0;
	overflow: hidden;
	border: 1px solid var(--vruumy-border);
	border-radius: 10px;
	background: var(--vruumy-gray);
	cursor: pointer;
	transition: border-color .25s var(--vruumy-ease), box-shadow .25s var(--vruumy-ease);
}
.vruumy-gallery__thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: .4rem;
}
.vruumy-gallery__thumb.is-active {
	border-color: var(--vruumy-blue);
	box-shadow: var(--vruumy-glow-blue);
}
.vruumy-gallery__thumb:hover { border-color: var(--vruumy-blue); }

/* Modal de zoom */
.vruumy-gallery__modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(11, 11, 15, .92);
	backdrop-filter: blur(12px);
	cursor: zoom-out;
}
.vruumy-gallery__modal[hidden] { display: none; }
.vruumy-gallery__modal img {
	max-width: 90vw;
	max-height: 90vh;
	object-fit: contain;
	border-radius: var(--vruumy-radius);
	cursor: default;
	filter: drop-shadow(0 30px 60px rgba(0, 0, 0, .6));
}
.vruumy-gallery__modal-close {
	position: absolute;
	top: 1.25rem;
	right: 1.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: 1px solid var(--vruumy-border);
	border-radius: 50%;
	background: rgba(255, 255, 255, .05);
	color: var(--vruumy-white);
	cursor: pointer;
	transition: border-color .2s;
}
.vruumy-gallery__modal-close:hover { border-color: var(--vruumy-pink); }
.vruumy-gallery__modal-close .vruumy-icon { width: 18px; height: 18px; transform: rotate(45deg); }

/* ==========================================================================
   Coluna de compra
   ========================================================================== */
.vruumy-buy {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.vruumy-buy__cat {
	display: inline-block;
	padding: .3rem .9rem;
	border: 1px solid rgba(255, 45, 142, .4);
	border-radius: 999px;
	font-family: var(--vruumy-font-heading);
	font-size: .65rem;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--vruumy-pink);
	text-decoration: none;
	transition: box-shadow .25s var(--vruumy-ease), border-color .25s var(--vruumy-ease);
}
.vruumy-buy__cat:hover { border-color: var(--vruumy-pink); box-shadow: var(--vruumy-glow-pink); }

.vruumy-buy__name {
	margin: 0;
	font-size: clamp(1.5rem, 3.2vw, 2.2rem);
	line-height: 1.15;
	letter-spacing: .02em;
	text-transform: none;
	color: var(--vruumy-white);
}

.vruumy-buy__meta {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.vruumy-buy__rating {
	display: flex;
	align-items: center;
	gap: .5rem;
}
.vruumy-buy__rating .star-rating { color: var(--vruumy-blue); }
.vruumy-buy__review-count { font-size: .8rem; color: var(--vruumy-text-muted); }

.vruumy-buy__favorite {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	margin-left: auto;
	border: 1px solid var(--vruumy-border);
	border-radius: 50%;
	background: transparent;
	color: var(--vruumy-text-muted);
	cursor: pointer;
	transition: color .25s var(--vruumy-ease), border-color .25s var(--vruumy-ease), box-shadow .25s var(--vruumy-ease);
}
.vruumy-buy__favorite .vruumy-icon { width: 18px; height: 18px; }
.vruumy-buy__favorite:hover, .vruumy-buy__favorite.is-active {
	color: var(--vruumy-pink);
	border-color: var(--vruumy-pink);
	box-shadow: var(--vruumy-glow-pink);
}

/* Specs rápidas */
.vruumy-buy__specs {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: .75rem;
	padding: 1.25rem;
	border: 1px solid var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	background: rgba(255, 255, 255, .02);
}
.vruumy-buy__spec {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .35rem;
	text-align: center;
}
.vruumy-buy__spec-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border: 1px solid rgba(0, 178, 255, .3);
	border-radius: 50%;
	color: var(--vruumy-blue);
}
.vruumy-buy__spec-icon .vruumy-icon { width: 18px; height: 18px; }
.vruumy-buy__spec-value {
	font-family: var(--vruumy-font-heading);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .02em;
	color: var(--vruumy-white);
}
.vruumy-buy__spec-label {
	font-size: .67rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
}

/* Preço */
.vruumy-buy__pricing {
	display: flex;
	flex-direction: column;
	gap: .3rem;
	padding: 1.5rem;
	border: 1px solid var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	background: linear-gradient(135deg, rgba(0, 178, 255, .05), transparent 60%), var(--vruumy-gray);
}
.vruumy-buy__price {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 800;
	letter-spacing: .01em;
	color: var(--vruumy-white);
	line-height: 1;
}
.vruumy-buy__price ins { color: var(--vruumy-pink); text-decoration: none; }
.vruumy-buy__price del { color: var(--vruumy-text-muted); font-size: .6em; opacity: .7; }
.vruumy-buy__installment {
	margin: 0;
	font-size: .85rem;
	color: var(--vruumy-text-muted);
}

/* Seletor de cores */
.vruumy-buy__colors {
	display: flex;
	flex-direction: column;
	gap: .65rem;
}
.vruumy-buy__colors-label {
	font-family: var(--vruumy-font-heading);
	font-size: .68rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
}
.vruumy-buy__swatches { display: flex; gap: .6rem; flex-wrap: wrap; }
.vruumy-buy__swatch {
	width: 32px;
	height: 32px;
	padding: 0;
	border: 2px solid transparent;
	border-radius: 50%;
	cursor: pointer;
	transition: transform .2s var(--vruumy-ease), box-shadow .2s var(--vruumy-ease);
	background-color: var(--vruumy-border);
}
.vruumy-buy__swatch[data-color="azul"]     { background-color: var(--vruumy-blue); }
.vruumy-buy__swatch[data-color="rosa"]     { background-color: var(--vruumy-pink); }
.vruumy-buy__swatch[data-color="vermelho"] { background-color: #e63939; }
.vruumy-buy__swatch[data-color="verde"]    { background-color: #22c55e; }
.vruumy-buy__swatch[data-color="amarelo"]  { background-color: #facc15; }
.vruumy-buy__swatch[data-color="preto"]    { background-color: #1a1a23; border: 2px solid var(--vruumy-border); }
.vruumy-buy__swatch[data-color="branco"]   { background-color: #f8fafc; }
.vruumy-buy__swatch.is-active {
	border-color: var(--vruumy-white);
	transform: scale(1.15);
	box-shadow: 0 0 0 3px rgba(0, 178, 255, .5);
}

/* Formulário de compra */
.vruumy-buy__form {
	display: flex;
	align-items: stretch;
	gap: 1rem;
}
.vruumy-buy__qty {
	display: flex;
	align-items: center;
	border: 1px solid var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	overflow: hidden;
}
.vruumy-buy__qty-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 100%;
	padding: 0;
	border: none;
	background: rgba(255, 255, 255, .04);
	color: var(--vruumy-white);
	font-size: 1.2rem;
	cursor: pointer;
	transition: background .2s, color .2s;
}
.vruumy-buy__qty-btn:hover { background: rgba(0, 178, 255, .12); color: var(--vruumy-blue); }
.vruumy-buy__qty input[type="number"],
.vruumy-buy__qty .qty {
	width: 52px !important;
	height: 100%;
	padding: .75rem .25rem;
	border: none;
	border-left: 1px solid var(--vruumy-border);
	border-right: 1px solid var(--vruumy-border);
	background: transparent;
	color: var(--vruumy-white);
	font-family: var(--vruumy-font-heading);
	font-size: .95rem;
	text-align: center;
	-moz-appearance: textfield;
}
.vruumy-buy__qty input[type="number"]::-webkit-inner-spin-button,
.vruumy-buy__qty input[type="number"]::-webkit-outer-spin-button { display: none; }

.vruumy-buy__actions {
	display: flex;
	flex-direction: column;
	gap: .65rem;
	flex: 1;
}

.vruumy-buy__cta {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .65rem;
	padding: .9rem 1.75rem;
	border: none;
	border-radius: var(--vruumy-radius);
	background: var(--vruumy-gradient);
	box-shadow: var(--vruumy-glow-pink);
	color: var(--vruumy-white);
	font-family: var(--vruumy-font-heading);
	font-size: .82rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: box-shadow .3s var(--vruumy-ease), transform .3s var(--vruumy-ease), filter .3s var(--vruumy-ease);
}
.vruumy-buy__cta .vruumy-icon { width: 20px; height: 20px; }
.vruumy-buy__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 0 30px rgba(255, 45, 142, .55), 0 8px 24px rgba(0, 0, 0, .35);
	filter: brightness(1.1);
}

.vruumy-buy__cta-plain {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	padding: .7em 1.25em;
	border-radius: var(--vruumy-radius);
	border: 1px solid var(--vruumy-border);
	background: transparent;
	color: var(--vruumy-text-muted);
	font-family: var(--vruumy-font-heading);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	cursor: pointer;
	transition: border-color .25s var(--vruumy-ease), color .25s var(--vruumy-ease), background .25s var(--vruumy-ease);
}
.vruumy-buy__cta-plain .vruumy-icon svg { width: 16px; height: 16px; }
.vruumy-buy__cta-plain:hover {
	border-color: rgba(0, 178, 255, .4);
	color: var(--vruumy-white);
	background: rgba(0, 178, 255, .06);
}

.vruumy-buy__out-of-stock {
	margin: 0;
	padding: 1rem 1.5rem;
	border: 1px dashed var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	color: var(--vruumy-text-muted);
	font-size: .88rem;
	text-align: center;
}

.vruumy-buy__shipping {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin: 0;
	font-size: .8rem;
	color: var(--vruumy-text-muted);
	flex-wrap: wrap;
}
.vruumy-buy__shipping .vruumy-icon { color: var(--vruumy-blue); width: 17px; height: 17px; }
.vruumy-buy__shipping-sep { opacity: .4; margin: 0 .15rem; }

/* ==========================================================================
   Selos de qualidade
   ========================================================================== */
.vruumy-product-seals {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	max-width: 1320px;
	margin: 0 auto 0;
	border-top: 1px solid var(--vruumy-border);
	border-bottom: 1px solid var(--vruumy-border);
	background: var(--vruumy-border);
}
.vruumy-product-seals__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .6rem;
	padding: 1.75rem 1rem;
	background: var(--vruumy-gray);
	text-align: center;
	font-family: var(--vruumy-font-heading);
	font-size: .7rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--vruumy-white);
}
.vruumy-product-seals__item .vruumy-icon { width: 26px; height: 26px; color: var(--vruumy-blue); }
.vruumy-product-seals__item:nth-child(2n) .vruumy-icon { color: var(--vruumy-pink); }

/* ==========================================================================
   Descrição + Especificações técnicas
   ========================================================================== */
.vruumy-product-details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	max-width: 1320px;
	margin: 0 auto;
	padding: clamp(3rem, 6vw, 4.5rem) clamp(1.25rem, 3vw, 2.5rem);
}

.vruumy-product-desc { display: flex; flex-direction: column; gap: 1.5rem; }
.vruumy-product-desc .vruumy-section-title { margin-bottom: 1rem; }
.vruumy-product-desc__text {
	font-size: .94rem;
	line-height: 1.8;
	color: var(--vruumy-text-muted);
}
.vruumy-product-desc__text p { margin: 0 0 .9rem; }
.vruumy-product-desc__text p:last-child { margin-bottom: 0; }
.vruumy-product-desc__highlights ul {
	display: flex;
	flex-direction: column;
	gap: .65rem;
	margin: 1.25rem 0 0;
	padding: 0;
	list-style: none;
}
.vruumy-product-desc__highlights li {
	display: flex;
	align-items: center;
	gap: .65rem;
	font-size: .88rem;
	color: var(--vruumy-text-muted);
}
.vruumy-product-desc__highlights li::before {
	content: '';
	flex-shrink: 0;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--vruumy-gradient);
	box-shadow: var(--vruumy-glow-blue);
}

.vruumy-product-specs { display: flex; flex-direction: column; gap: 1.5rem; }
.vruumy-product-specs .vruumy-section-title { margin-bottom: 1rem; }
.vruumy-product-specs__table {
	width: 100%;
	border-collapse: collapse;
	font-size: .86rem;
}
.vruumy-product-specs__table tr { border-bottom: 1px solid var(--vruumy-border); }
.vruumy-product-specs__table tr:last-child { border-bottom: none; }
.vruumy-product-specs__table th,
.vruumy-product-specs__table td {
	padding: .75rem 0;
	text-align: left;
	vertical-align: baseline;
}
.vruumy-product-specs__table th {
	width: 44%;
	font-family: var(--vruumy-font-heading);
	font-size: .72rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
	padding-right: 1rem;
}
.vruumy-product-specs__table td { color: var(--vruumy-white); }

/* ==========================================================================
   Mini-configurador de personalização do produto
   ========================================================================== */

/* Campos compartilhados com a home (definidos aqui para o contexto do produto) */
.vruumy-configurator__field {
	display: flex;
	flex-direction: column;
	gap: .35rem;
}
.vruumy-configurator__label {
	font-size: .7rem;
	font-family: var(--vruumy-font-heading);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--vruumy-blue);
}
.vruumy-configurator__input {
	width: 100%;
	padding: .6rem .85rem;
	background: rgba(0, 178, 255, .06);
	border: 1px solid rgba(0, 178, 255, .3);
	border-radius: var(--vruumy-radius);
	color: var(--vruumy-white);
	font-family: var(--vruumy-font-body);
	font-size: .9rem;
	outline: none;
	transition: border-color .2s, box-shadow .2s;
	box-sizing: border-box;
}
.vruumy-configurator__input::placeholder { color: rgba(255, 255, 255, .28); }
.vruumy-configurator__input:focus {
	border-color: var(--vruumy-blue);
	box-shadow: 0 0 0 3px rgba(0, 178, 255, .15);
}
.vruumy-configurator__input--number { max-width: 100px; }
#vruumy-product-photo-input { display: none; }
.vruumy-configurator__upload {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .55rem 1rem;
	background: transparent;
	border: 1px dashed rgba(0, 178, 255, .4);
	border-radius: var(--vruumy-radius);
	color: rgba(255, 255, 255, .6);
	font-family: var(--vruumy-font-body);
	font-size: .85rem;
	cursor: pointer;
	transition: border-color .2s, color .2s, background .2s;
	align-self: flex-start;
}
.vruumy-configurator__upload:hover {
	border-color: var(--vruumy-blue);
	color: var(--vruumy-white);
	background: rgba(0, 178, 255, .08);
}
.vruumy-configurator__upload.is-loaded {
	border-style: solid;
	border-color: rgba(0, 178, 255, .65);
	color: var(--vruumy-blue);
	background: rgba(0, 178, 255, .1);
}
.vruumy-configurator__upload .vruumy-icon { opacity: .7; }
.vruumy-configurator__upload-hint {
	font-size: .7rem;
	color: var(--vruumy-text-muted);
	margin-top: .1rem;
}
.vruumy-configurator__upload-error {
	font-size: .75rem;
	color: #ff5a5a;
	margin-top: .25rem;
}
.vruumy-configurator__remove-photo {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	background: none;
	border: none;
	color: #ff5a5a;
	font-size: .72rem;
	font-family: inherit;
	cursor: pointer;
	padding: .15rem 0;
	margin-top: .3rem;
	opacity: .75;
	transition: opacity .2s;
}
.vruumy-configurator__remove-photo:hover { opacity: 1; }

/* Wrapper do configurador */
.vruumy-product-configurator {
	margin-bottom: 1.5rem;
	padding: 1.25rem 1.35rem;
	border: 1px solid rgba(0, 178, 255, .18);
	border-radius: calc(var(--vruumy-radius) + 2px);
	background: rgba(0, 178, 255, .04);
}
.vruumy-product-configurator__head {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1.1rem;
	font-family: var(--vruumy-font-heading);
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--vruumy-blue);
}
.vruumy-product-configurator__head .vruumy-icon { opacity: .8; }

/* Layout: campos (esq) + previews (dir) */
.vruumy-product-configurator__layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
	align-items: start;
}
.vruumy-product-configurator__fields {
	display: flex;
	flex-direction: column;
	gap: .85rem;
}
.vruumy-product-configurator__previews {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

/* Tagline do configurador */
.vruumy-product-configurator__tagline {
	margin: -.25rem 0 1rem;
	font-size: .82rem;
	line-height: 1.55;
	color: var(--vruumy-text-muted);
}

/* Label sobre cada preview */
.vruumy-product-configurator__preview-item {
	display: flex;
	flex-direction: column;
	gap: .4rem;
}
.vruumy-product-configurator__preview-label {
	font-family: var(--vruumy-font-heading);
	font-size: .58rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
}

/* Nota de compra sem personalização */
.vruumy-buy__personalization-note {
	display: flex;
	align-items: flex-start;
	gap: .5rem;
	margin: .5rem 0 0;
	padding: .65rem .9rem;
	border-radius: var(--vruumy-radius);
	background: rgba(255, 45, 142, .07);
	border: 1px solid rgba(255, 45, 142, .2);
	font-size: .78rem;
	color: rgba(255, 255, 255, .65);
	line-height: 1.45;
}
.vruumy-buy__personalization-note .vruumy-icon { flex-shrink: 0; opacity: .7; color: var(--vruumy-pink); }

/* Foto preview dentro da CNH mini */
.vruumy-cnh__photo.has-photo { padding: 0; overflow: hidden; }
.vruumy-cnh__photo-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ============================================================
   CNH --mini  (versão compacta para o produto)
   ============================================================ */
.vruumy-cnh--mini {
	padding: .75rem .85rem .65rem;
	border-radius: 6px;
}
.vruumy-cnh--mini .vruumy-cnh__header { padding-bottom: .5rem; margin-bottom: .5rem; }
.vruumy-cnh--mini .vruumy-cnh__header span  { font-size: .52rem; }
.vruumy-cnh--mini .vruumy-cnh__header strong { font-size: .62rem; }
.vruumy-cnh--mini .vruumy-cnh__body { gap: .65rem; margin-bottom: .5rem; }
.vruumy-cnh--mini .vruumy-cnh__photo {
	width: 42px;
	height: 52px;
	border-radius: 3px;
}
.vruumy-cnh--mini .vruumy-cnh__photo .vruumy-icon { width: 20px; height: 20px; }
.vruumy-cnh--mini .vruumy-cnh__fields { gap: .28rem; }
.vruumy-cnh--mini .vruumy-cnh__fields dt { font-size: .5rem; }
.vruumy-cnh--mini .vruumy-cnh__fields dd { font-size: .62rem; }
.vruumy-cnh--mini .vruumy-cnh__footer { padding-top: .55rem; }
.vruumy-cnh--mini .vruumy-cnh__brand   { font-size: .7rem; }
.vruumy-cnh--mini .vruumy-cnh__seal .vruumy-icon { width: 14px; height: 14px; }

/* ============================================================
   Placa --mini
   ============================================================ */
.vruumy-plate--mini {
	padding: .45rem .7rem;
	border-radius: 6px;
	gap: .4rem;
}
.vruumy-plate--mini .vruumy-plate__lights {
	width: 8px;
	height: 24px;
}
.vruumy-plate--mini .vruumy-plate__strip { font-size: .46rem; padding: .2rem .4rem; }
.vruumy-plate--mini .vruumy-plate__brand { font-size: .42rem; }
.vruumy-plate--mini .vruumy-plate__number {
	padding: .3rem .7rem;
	font-size: .85rem;
	letter-spacing: .18em;
}

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width: 1024px) {
	.vruumy-single-product__inner { grid-template-columns: 1fr; gap: 2rem; }
	.vruumy-product-details { grid-template-columns: 1fr; gap: 2.5rem; }
	.vruumy-product-seals { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
	.vruumy-buy__form { flex-direction: column; }
	.vruumy-buy__qty { width: 100%; justify-content: center; height: 54px; }
	.vruumy-product-seals { grid-template-columns: repeat(2, 1fr); }
	/* No mobile: campos em cima, previews embaixo (já é o fluxo natural da coluna) */
	.vruumy-product-configurator__layout { grid-template-columns: 1fr; }
}
