/**
 * MG Shipping Methods Manager - Stylesheet
 * Version: 1.4.0
 *
 * Stile: card bordate stile Poliottica
 * - Box bordo grigio chiaro per ogni metodo
 * - Layout orizzontale: radio · logo · nome · GRATIS
 * - Selezione: bordo brand scuro
 * - Descrizione: solo su hover/selezione (subtle)
 *
 * Palette Mastrogeppetto: #9d8b78 brand · #2d7a4f success
 * ============================================================ */

:root {
	--mg-ship-brand:     #9d8b78;
	--mg-ship-brand-dk:  #2a2520;
	--mg-ship-text:      #2a2520;
	--mg-ship-muted:     #6a6a6a;
	--mg-ship-line:      #e0ddd8;
	--mg-ship-line-soft: #ebe8e2;
	--mg-ship-paper:     #ffffff;
	--mg-ship-success:   #2d7a4f;
	--mg-ship-success2:  #3a8c5d;
	--mg-ship-easing:    cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ============================================================
   LISTA: rimuove pallini default e padding tabella Flatsome
   ============================================================ */

ul#shipping_method.shipping__list,
ul#shipping_method {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

/* ============================================================
   CARD METODO
   ============================================================ */

li.shipping__list_item {
	position: relative;
	display: block !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 1px solid var(--mg-ship-line) !important;
	border-radius: 8px;
	background: var(--mg-ship-paper);
	transition: all 0.25s var(--mg-ship-easing);
	overflow: hidden;
}

li.shipping__list_item:hover {
	border-color: var(--mg-ship-brand) !important;
	box-shadow: 0 2px 8px rgba(42, 37, 32, 0.05);
}

/* Stato selezionato: bordo nero spesso, leggera tinta */
li.shipping__list_item:has(input[type="radio"]:checked) {
	border-color: var(--mg-ship-brand-dk) !important;
	box-shadow: 0 0 0 1px var(--mg-ship-brand-dk);
	background: #fafaf9;
}

/* ============================================================
   RADIO BUTTON + LABEL — riga orizzontale
   ============================================================ */

li.shipping__list_item > input[type="radio"].shipping_method {
	position: absolute;
	left: 1rem;
	top: 50%;
	transform: translateY(-50%);
	margin: 0;
	accent-color: var(--mg-ship-brand-dk);
	width: 16px;
	height: 16px;
	cursor: pointer;
	z-index: 2;
}

/* Se c'è descrizione visibile, allinea radio in alto */
li.shipping__list_item:hover > input[type="radio"].shipping_method,
li.shipping__list_item:has(input:checked) > input[type="radio"].shipping_method {
	top: 1.05rem;
	transform: none;
}

li.shipping__list_item > label.shipping__list_label {
	display: flex !important;
	align-items: center;
	gap: 0.65rem;
	margin: 0 !important;
	padding: 0.85rem 1rem 0.85rem 2.65rem !important;
	font-weight: 400 !important;
	color: var(--mg-ship-text);
	cursor: pointer;
	width: 100%;
	min-height: 48px;
	box-sizing: border-box;
}

/* ============================================================
   CONTENUTO LABEL — wrapper .mg-ship
   ============================================================ */

.mg-ship {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	width: 100%;
	min-width: 0;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Logo box (giallo InPost / monocromo DHL) */
.mg-ship__logo {
	display: inline-block;
	height: 24px;
	width: auto;
	max-width: 56px;
	object-fit: contain;
	flex-shrink: 0;
	border-radius: 3px;
}

.mg-ship__logo--inpost {
	height: 22px;
	max-width: 56px;
}

.mg-ship__logo--dhl {
	height: 18px;
	max-width: 56px;
}

/* Icona SVG ritiro */
.mg-ship__icon {
	width: 22px;
	height: 22px;
	color: var(--mg-ship-brand-dk);
	flex-shrink: 0;
	stroke-width: 1.5;
}

/* Nome metodo */
.mg-ship__name {
	font-size: 14px;
	font-weight: 500;
	color: var(--mg-ship-text);
	letter-spacing: 0;
	line-height: 1.35;
	flex: 1;
	min-width: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Prezzo (quando non gratis) */
.mg-ship__price {
	font-size: 14px;
	font-weight: 600;
	color: var(--mg-ship-text);
	margin-left: auto;
	flex-shrink: 0;
	white-space: nowrap;
}

.mg-ship__price .amount,
.mg-ship__price .woocommerce-Price-amount {
	color: inherit !important;
	font-weight: inherit !important;
}

/* ============================================================
   BADGE "GRATIS" — pill verde piena
   ============================================================ */

.mg-ship__badge {
	display: inline-flex;
	align-items: center;
	height: 22px;
	padding: 0 10px;
	margin-left: auto;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 11px;
	background: linear-gradient(135deg, var(--mg-ship-success) 0%, var(--mg-ship-success2) 100%);
	color: #ffffff;
	white-space: nowrap;
	flex-shrink: 0;
	position: relative;
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(45, 122, 79, 0.2);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.mg-ship__badge::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
	animation: mg-shimmer 3.5s var(--mg-ship-easing) infinite;
}

/* Variante "quiet" per ritiro */
.mg-ship__badge--quiet {
	background: #fafaf9;
	color: var(--mg-ship-success);
	border: 1px solid var(--mg-ship-success);
	box-shadow: none;
	font-weight: 600;
}

.mg-ship__badge--quiet::before {
	display: none;
}

/* ============================================================
   DESCRIZIONE — visibile solo su hover o selezione
   ============================================================ */

.mg-ship-description {
	display: block;
	font-size: 12px;
	line-height: 1.55;
	color: var(--mg-ship-muted);
	padding: 0 1rem 0.85rem 2.65rem;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.3s var(--mg-ship-easing),
	            opacity 0.25s var(--mg-ship-easing),
	            padding 0.3s var(--mg-ship-easing);
}

li.shipping__list_item:hover .mg-ship-description,
li.shipping__list_item:has(input:checked) .mg-ship-description {
	max-height: 80px;
	opacity: 1;
	padding-bottom: 0.85rem;
}

.mg-ship-description strong {
	color: var(--mg-ship-text);
	font-weight: 600;
}

/* ============================================================
   ANIMAZIONI
   ============================================================ */

@keyframes mg-shimmer {
	0%      { left: -100%; }
	50%, 100% { left: 100%; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 600px) {
	li.shipping__list_item > label.shipping__list_label {
		padding: 0.75rem 0.85rem 0.75rem 2.5rem !important;
		min-height: 44px;
	}

	li.shipping__list_item > input[type="radio"].shipping_method {
		left: 0.85rem;
	}

	.mg-ship {
		gap: 0.55rem;
	}

	.mg-ship__name {
		font-size: 13px;
	}

	.mg-ship__logo {
		height: 20px;
	}

	.mg-ship__logo--inpost {
		height: 18px;
	}

	.mg-ship__logo--dhl {
		height: 16px;
	}

	.mg-ship__badge {
		height: 20px;
		font-size: 9px;
		padding: 0 8px;
	}

	.mg-ship-description {
		padding-left: 2.5rem;
		padding-right: 0.85rem;
		font-size: 11.5px;
	}

	li.shipping__list_item:hover .mg-ship-description,
	li.shipping__list_item:has(input:checked) .mg-ship-description {
		max-height: 100px;
	}
}

@media (max-width: 380px) {
	.mg-ship {
		gap: 0.4rem;
	}

	.mg-ship__name {
		font-size: 12px;
	}

	.mg-ship__badge {
		padding: 0 6px;
		font-size: 8.5px;
	}
}

/* ============================================================
   ACCESSIBILITÀ
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
	.mg-ship__badge::before,
	.mg-ship-description,
	li.shipping__list_item {
		animation: none !important;
		transition: none !important;
	}
}
