.menu {
	background: rgba(255,255,255,0.5);
	border: 1px solid rgba(91,58,36,0.12);
	border-radius: var(--radius);
	box-shadow: var(--shadow-sm);
	padding: 0.6rem;
}
.accordion {
	background: #fff8f1;
	border: 1px solid rgba(91,58,36,0.12);
	border-radius: 12px;
	margin: 0.6rem 0;
	overflow: hidden;
}
.accordion[open] { background: #fff; }
.accordion > summary {
	list-style: none;
	cursor: pointer;
	padding: 0.8rem 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.accordion > summary::-webkit-details-marker { display: none; }
.accordion > summary h2 {
	margin: 0;
	font-size: 1.4rem;
}
.accordion > summary::after {
	content: "▾";
	font-size: 1.1rem;
	color: var(--brown-700);
	transition: transform .2s ease;
}
.accordion[open] > summary::after { transform: rotate(-180deg); }

.menu-list {
	margin: 0;
	padding: 0.2rem 0.8rem 0.9rem 0.8rem;
	list-style: none;
	display: grid;
	gap: 0.35rem;
}
.menu-list li {
	display: grid;
	grid-template-columns: 1fr minmax(30px, 1fr) auto auto;
	align-items: baseline;
	gap: 0.4rem;
	padding: 0.35rem 0.2rem;
	border-bottom: 1px dashed rgba(91,58,36,0.15);
}
.menu-list li .dots {
	height: 1px;
	border-bottom: 1px dotted rgba(91,58,36,0.35);
	align-self: center;
}
.menu-list .price {
	justify-self: end;
	font-weight: 600;
}
.menu-list .price--empty { visibility: hidden; }
.menu-note {
	margin: 0.6rem 0 0 0.2rem;
	font-size: 0.95rem;
	opacity: 0.9;
}
@media (max-width: 640px) {
	.menu-list li {
		grid-template-columns: 1fr auto;
	}
	.menu-list li .dots { display: none; }
	.menu-list li .price + .price { margin-left: 0.6rem; }
}

