body.layout-mode main section {
	position: relative;
}

body.layout-mode [data-config-id] {
	outline: var(--cms-layout) dashed 4px;
	outline-offset: -4px;
}

body.layout-mode [data-config-id]:hover,
body.layout-mode section:has(.layout-buttons:hover) [data-config-id] {
	position: relative;
}

body.layout-mode [data-config-id]:hover:after,
body.layout-mode section:has(.layout-buttons:hover) [data-config-id]:after {
	content: '';
	width: 100%;
	height: 100%;
	background: var(--cms-layout);
	opacity: 40%;
	position: absolute;
	top: 0;
	left: 0;
}

.layout-buttons {
	display: flex;
	gap: 4px;
	position: absolute;
	top: 50%;
	right: 32px;
	transform: translateY(-50%);
	z-index: 90;
	background: var(--cms-dark);
	padding: 4px;
	border-radius: 4px;
	box-shadow: var(--cms-box-shadow);
}

.layout-buttons .display-toggle {
	display: flex;
	align-items: center;
	padding: 2px 12px;
	background: var(--cms-cta);
	color: var(--cms-light);
	border: 0;
	border-radius: 4px;
	cursor: pointer;
}

.order-input {
	display: flex;
	gap: 4px;
}

.layout-buttons .order-input input {
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
	appearance: textfield;
	border: 0;
	border-radius: 4px;
	margin: 0;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	color: var(--cms-text-color);
	background: var(--cms-light);
	border: 1px solid var(--cms-border-color);
	padding: 4px;
	box-sizing: border-box;
	min-width: 48px;
}

.order-input input::-webkit-inner-spin-button,
.order-input input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.layout-buttons .order-input input:focus {
	outline-color: var(--cms-cta);
}

.order-input .arrows {
	display: grid;
	grid-template-rows: 22px 22px;
	row-gap: 4px;
}

.order-input .arrows button {
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	width: 22px;
	padding: 0;
	background: var(--cms-cta);
	color: var(--cms-light);
	border: 0;
	border-radius: 4px;
	cursor: pointer;
}

.layout-buttons .display-toggle svg {
	height: 24px;
}

.order-input .arrows svg {
	height: 16px;
}

.layout-buttons .display-toggle:hover,
.order-input .arrows button:hover {
	background: var(--cms-dark-active);
}

body:not(.layout-mode) .layout-buttons {
	display: none;
}

body.layout-mode [data-config-display='false'] {
	opacity: 20%;
}

body:not(.layout-mode) [data-config-display='false'] {
	display: none;
}
