/* === Restaurant Menu Widget — Override (NB4) === */

.menu-widget {
	width: 100%;
	padding: 20px;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-item) {
	display: block;
	width: 100%;
	margin-bottom: 15px;
	padding-bottom: 15px;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-row) {
	display: flex;
	flex-direction: var(--img-dir, column);
	gap: 10px;
	width: 100%;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-content) {
	flex: 1 1 0;
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-media) {
	width: 100%;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-media img) {
	display: block;
	max-width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: 0;
}

.menu-widget :where(.rmw-header) {
	display: grid;
	grid-template-columns: minmax(0, auto) minmax(24px, 1fr) auto;
	align-items: center;
	column-gap: 0.75rem;
	width: 100%;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-title-wrap) {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
	max-width: 100%;
}

.menu-widget :where(.rmw-title) {
	grid-column: 1;
	margin: 0;
	min-width: 0;
	line-height: 1.3;
	overflow-wrap: anywhere;
	word-break: break-word;
}

.menu-widget :where(.rmw-badges) {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
}

.menu-widget :where(.rmw-badges img) {
	display: inline-block;
	width: 16px;
	height: 16px;
	object-fit: contain;
	flex: 0 0 auto;
}

.menu-widget :where(.rmw-separator) {
	grid-column: 2;
	align-self: center;
	min-width: 24px;
	height: 1px;
	margin-right: 0.25rem;
	border-bottom-style: dotted;
	border-bottom-width: 1px;
	border-bottom-color: currentColor;
	box-sizing: border-box;
}

.menu-widget :where(.rmw-price) {
	grid-column: 3;
	justify-self: end;
	margin: 0;
	padding-left: 0.25rem;
	white-space: nowrap;
}

.menu-widget :where(.rmw-description) {
	margin-top: 0;
	font-size: 14px;
	color: #666;
}

.menu-widget :where(.rmw-allergens) {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 0;
}

.menu-widget :where(.rmw-allergens .rmw-allergen) {
	display: inline-block;
	width: 20px;
	height: 20px;
	object-fit: contain;
	flex: 0 0 auto;
}

/* Layout migliore quando immagine a sinistra */
.menu-widget :where(.rmw-row[style*="row"] .rmw-media) {
	flex: 0 0 auto;
	width: auto;
}

.menu-widget :where(.rmw-row[style*="row"] .rmw-content) {
	flex: 1 1 auto;
}

/* Specificità volutamente bassa:
   gli stili copiati/incollati da Elementor devono poter sovrascrivere questi default. */