/**
 * Pluggies Variation Swatches — stile frontend.
 * Colori e forme arrivano come CSS variables iniettate da PHP, così il plugin
 * rispetta le impostazioni su qualsiasi tema.
 */

/* Il <select> nativo resta nel DOM (lo usa WooCommerce) ma invisibile. */
.plgvs-hidden-select {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	pointer-events: none !important;
	margin: 0 !important;
	clip: rect(0 0 0 0);
}

.plgvs-swatches {
	box-sizing: border-box;
	margin: 6px 0 4px;
}

.plgvs-swatches *,
.plgvs-swatches *::before,
.plgvs-swatches *::after {
	box-sizing: border-box;
}

/* Dimensioni in base alla taglia scelta (medium = scala 1, identica al passato). */
.plgvs-size-small  { --plgvs-dot: 28px; --plgvs-img: 48px; --plgvs-btn-pad: 10px 8px;  --plgvs-radio-pad: 5px 11px; --plgvs-scale: .88; }
.plgvs-size-medium { --plgvs-dot: 36px; --plgvs-img: 58px; --plgvs-btn-pad: 14px 10px; --plgvs-radio-pad: 7px 14px; --plgvs-scale: 1; }
.plgvs-size-large  { --plgvs-dot: 46px; --plgvs-img: 72px; --plgvs-btn-pad: 18px 12px; --plgvs-radio-pad: 9px 17px; --plgvs-scale: 1.12; }

/* ---------------------------------- Bottoni ---------------------------------- */

.plgvs-type-button {
	display: grid;
	grid-template-columns: repeat(var(--plgvs-cols, 4), minmax(0, 1fr));
	gap: 10px;
}

.plgvs-type-button .plgvs-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--plgvs-gap, 3px);
	padding: var(--plgvs-btn-pad, 14px 10px);
	border: 1.5px solid rgba(0, 0, 0, .14);
	border-radius: var(--plgvs-btn-radius, 14px);
	background: #fff;
	text-align: center;
	cursor: pointer;
	transition: border-color .18s, background .18s, box-shadow .18s, transform .18s;
}

.plgvs-type-button .plgvs-item:hover {
	border-color: var(--plgvs-hover-border, rgba(0, 0, 0, .38));
}

.plgvs-type-button .plgvs-item.plgvs-selected {
	border-color: var(--plgvs-sel-border, #3b6d11);
	background: var(--plgvs-sel-bg, #eaf3de);
}

.plgvs-type-button .plgvs-item.plgvs-selected .plgvs-name,
.plgvs-type-button .plgvs-item.plgvs-selected .plgvs-price,
.plgvs-type-button .plgvs-item.plgvs-selected .plgvs-stock {
	color: var(--plgvs-sel-text, #173404);
}

/* Prezzo accanto al nome (opzione "Posizione del prezzo").
   Il max() impone 6px minimi: uno "Spazio" salvato a 0 (legittimo in verticale)
   qui incollerebbe il prezzo al nome. */
.plgvs-price-inline.plgvs-type-button .plgvs-item {
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: baseline;
	column-gap: max(var(--plgvs-gap, 8px), 6px);
	row-gap: 2px;
}

.plgvs-name { font-weight: 600; font-size: var(--plgvs-name-size, calc(.95rem * var(--plgvs-scale, 1))); line-height: 1.2; white-space: nowrap; }
.plgvs-price { font-size: var(--plgvs-price-size, calc(.82rem * var(--plgvs-scale, 1))); opacity: .78; }
.plgvs-price del { opacity: .55; margin-right: .25em; }
.plgvs-price ins { text-decoration: none; }
.plgvs-stock { font-size: calc(.72rem * var(--plgvs-scale, 1)); opacity: .72; }

/* ----------------------------- Colore / immagine ----------------------------- */

.plgvs-type-color,
.plgvs-type-image,
.plgvs-type-radio {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.plgvs-type-color .plgvs-item {
	width: var(--plgvs-dot, 36px);
	height: var(--plgvs-dot, 36px);
	border-radius: var(--plgvs-radius, 50%);
	cursor: pointer;
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .12);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition: outline-color .18s, transform .18s;
}

.plgvs-type-color .plgvs-item:hover { transform: scale(1.06); }
.plgvs-type-color .plgvs-item.plgvs-selected { outline-color: var(--plgvs-sel-border, #3b6d11); }

.plgvs-type-image .plgvs-item {
	width: var(--plgvs-img, 58px);
	height: var(--plgvs-img, 58px);
	padding: 0;
	border: 1.5px solid rgba(0, 0, 0, .14);
	border-radius: var(--plgvs-radius, 12px);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .8rem;
	cursor: pointer;
	transition: border-color .18s, box-shadow .18s, transform .18s;
}

.plgvs-type-image .plgvs-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.plgvs-type-image .plgvs-item:hover { transform: scale(1.04); }
.plgvs-type-image .plgvs-item.plgvs-selected {
	border-color: var(--plgvs-sel-border, #3b6d11);
	box-shadow: 0 0 0 2px var(--plgvs-sel-border, #3b6d11);
}

/* ----------------------------------- Radio ----------------------------------- */

.plgvs-type-radio .plgvs-item {
	display: inline-flex;
	align-items: center;
	gap: max(var(--plgvs-gap, 8px), 6px); /* i radio sono sempre in riga: minimo 6px */
	padding: var(--plgvs-radio-pad, 7px 14px);
	border: 1.5px solid rgba(0, 0, 0, .14);
	border-radius: 999px;
	cursor: pointer;
	transition: border-color .18s, background .18s;
}

.plgvs-type-radio .plgvs-item::before {
	content: "";
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 2px solid rgba(0, 0, 0, .3);
	flex: none;
}

.plgvs-type-radio .plgvs-item.plgvs-selected {
	border-color: var(--plgvs-sel-border, #3b6d11);
	background: var(--plgvs-sel-bg, #eaf3de);
	color: var(--plgvs-sel-text, #173404);
}

.plgvs-type-radio .plgvs-item.plgvs-selected::before {
	border-color: var(--plgvs-sel-border, #3b6d11);
	background: var(--plgvs-sel-border, #3b6d11);
	box-shadow: inset 0 0 0 3px var(--plgvs-sel-bg, #eaf3de);
}

/* ------------------------------ Etichetta scelta ------------------------------ */

.plgvs-selected-value {
	display: block;
	font-weight: 400;
	opacity: .55;
	margin-top: 2px;
	font-size: .85em;
}

/* ----------------------------- Varianti esaurite ----------------------------- */

.plgvs-item.plgvs-disabled { cursor: not-allowed; pointer-events: none; }
.plgvs-oos-hide { display: none !important; }
.plgvs-oos-disable { opacity: .4; }
.plgvs-oos-blur { opacity: .55; filter: blur(1.4px); }
.plgvs-oos-cross { opacity: .72; }
.plgvs-oos-cross .plgvs-name,
.plgvs-oos-cross .plgvs-price { text-decoration: line-through; }

.plgvs-type-color .plgvs-oos-cross,
.plgvs-type-image .plgvs-oos-cross { position: relative; }
.plgvs-type-color .plgvs-oos-cross::after,
.plgvs-type-image .plgvs-oos-cross::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(to top left, transparent 45%, rgba(170, 0, 0, .65) 46%, rgba(170, 0, 0, .65) 54%, transparent 55%);
}

/* -------------------------------- Preset stile -------------------------------- */

/* Vetro: ombra soffusa sull'opzione selezionata ("apple" fino alla 1.2.1). */
.plgvs-preset-glass.plgvs-type-button .plgvs-item.plgvs-selected {
	box-shadow: 0 6px 16px rgba(0, 0, 0, .08);
}

.plgvs-preset-minimal .plgvs-item { border-radius: 8px; box-shadow: none !important; }
.plgvs-preset-native .plgvs-item { border-radius: 4px; box-shadow: none !important; }

/* Pillola: tutto stondato al massimo. */
.plgvs-preset-pill .plgvs-item { border-radius: 999px; }

/* Contorno: nessun riempimento, parla solo il bordo. */
.plgvs-preset-outline.plgvs-type-button .plgvs-item,
.plgvs-preset-outline.plgvs-type-radio .plgvs-item {
	background: transparent;
	border-width: 2px;
}

.plgvs-preset-outline.plgvs-type-button .plgvs-item.plgvs-selected,
.plgvs-preset-outline.plgvs-type-radio .plgvs-item.plgvs-selected {
	background: transparent;
	border-color: var(--plgvs-sel-border, #3b6d11);
	box-shadow: none;
}

/* Morbido: riempito e senza bordi, stile "chip". */
.plgvs-preset-soft.plgvs-type-button .plgvs-item,
.plgvs-preset-soft.plgvs-type-radio .plgvs-item {
	border-color: transparent;
	background: rgba(0, 0, 0, .05);
}

.plgvs-preset-soft.plgvs-type-button .plgvs-item:hover,
.plgvs-preset-soft.plgvs-type-radio .plgvs-item:hover {
	border-color: transparent;
	background: rgba(0, 0, 0, .09);
}

.plgvs-preset-soft.plgvs-type-button .plgvs-item.plgvs-selected,
.plgvs-preset-soft.plgvs-type-radio .plgvs-item.plgvs-selected {
	border-color: transparent;
	background: var(--plgvs-sel-bg, #eaf3de);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .06);
}

/* Il raggio scelto dall'utente (--plgvs-btn-radius, iniettato da PHP) vince
   sul default del preset, ma solo per i bottoni. */
.plgvs-preset-minimal.plgvs-type-button .plgvs-item { border-radius: var(--plgvs-btn-radius, 8px); }
.plgvs-preset-native.plgvs-type-button .plgvs-item { border-radius: var(--plgvs-btn-radius, 4px); }
.plgvs-preset-pill.plgvs-type-button .plgvs-item { border-radius: var(--plgvs-btn-radius, 999px); }

/* ---------------------------------- Archivi ---------------------------------- */

.plgvs-archive-swatches { margin-top: .55rem; gap: 8px; }
.plgvs-archive-swatches .plgvs-item { text-decoration: none; color: inherit; }
.plgvs-archive-swatches.plgvs-type-button { display: flex; flex-wrap: wrap; }
.plgvs-archive-swatches.plgvs-type-button .plgvs-item { padding: 5px 12px; border-radius: 999px; }

/* Su spazi stretti (mobile, colonne laterali) riduci a 2 colonne anziché comprimere. */
@media (max-width: 520px) {
	.plgvs-type-button { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
