.ofp-programme {
	max-width: 820px;
	margin: 0 auto;
	padding: 32px 20px 64px;
}

.ofp-programme__title {
	margin: 0 0 4px;
}

.ofp-programme__date {
	color: #8a5a2b;
	font-weight: 600;
	margin: 0 0 24px;
	text-transform: capitalize;
}

.ofp-programme__intro {
	margin: 0 0 24px;
}

.ofp-programme__closed {
	background: #fdecea;
	border: 1px solid #f5c6c0;
	color: #8a1c12;
	padding: 12px 16px;
	border-radius: 8px;
	margin: 0 0 24px;
}

.ofp-group {
	margin: 0 0 32px;
}

.ofp-group__title {
	border-bottom: 2px solid #e7d6c4;
	padding-bottom: 8px;
	margin: 0 0 16px;
}

.ofp-group__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 12px;
}

.ofp-product {
	display: flex;
	align-items: center;
	gap: 16px;
	border: 1px solid #ece3d8;
	border-radius: 10px;
	padding: 12px 16px;
}

.ofp-product__media img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: 8px;
	display: block;
}

.ofp-product__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ofp-product__name {
	font-weight: 600;
}

.ofp-product__desc {
	color: #666;
	font-size: 0.9em;
}

.ofp-product__price {
	color: #8a5a2b;
	font-weight: 600;
}

.ofp-product__qty input {
	width: 72px;
	text-align: center;
	padding: 8px;
	border: 1px solid #cbb89f;
	border-radius: 8px;
	font-size: 1em;
}

.ofp-group__hint {
	color: #666;
	margin: 0 0 12px;
	font-style: italic;
}

.ofp-plat {
	border: 1px solid #ece3d8;
	border-radius: 10px;
	padding: 12px 16px;
	list-style: none;
}

.ofp-plat .ofp-product {
	border: 0;
	padding: 0;
}

.ofp-plat__comps {
	margin: 12px 0 0;
	padding: 12px 0 0;
	border-top: 1px dashed #e0d3c2;
	display: grid;
	gap: 8px;
}

.ofp-comp__label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.92em;
	color: #555;
}

.ofp-comp__select {
	flex: 1;
	padding: 8px;
	border: 1px solid #cbb89f;
	border-radius: 8px;
}

.ofp-form__actions {
	position: sticky;
	bottom: 0;
	background: #fff;
	padding: 16px 0;
	border-top: 1px solid #ece3d8;
	text-align: right;
}

.ofp-form__submit {
	display: inline-block;
	font-size: 1.05em;
	padding: 12px 28px;
	border: none;
	border-radius: 5px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	background: var(--brand-red, #d40000);
	color: #fff;
	transition: all 0.3s ease;
}

.ofp-form__submit:hover {
	background: #b50000;
	color: #fff;
	transform: translateY(-2px);
}

@media (max-width: 540px) {
	.ofp-product {
		flex-wrap: wrap;
	}
	.ofp-product__qty {
		margin-left: auto;
	}
}
