/* ABOUTME: Itinerary block items and equipment addon styles for the booking wizard. */
/* ABOUTME: Grid-based checkbox block layout with checked/focus states. */

/* ---------- Itinerary blocks list ---------- */

.itinerary-blocks-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.block-category h3,
.block-category h5 {
	padding-bottom: 0.5rem;
	border-bottom: 2px solid var(--color-dark-blue);
	margin-bottom: 0;
}

/* Contain the absolutely positioned checkbox within the item */
.block-item {
	position: relative;
}

/* Hide native checkbox visually but keep in-place to prevent scroll jump on focus */
.block-item > input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

/* Label as grid row */
.block-item > label {
	display: grid;
	grid-template-columns: 24px 1fr auto;
	grid-template-rows: auto auto;
	column-gap: 0.75rem;
	row-gap: 0.25rem;
	align-items: center;
	padding: 0.75rem 0.5rem;
	border-bottom: 1px solid #e0e0e0;
	cursor: pointer;
	border-radius: 4px;
	transition: background-color 0.15s ease;
}

.block-category .block-item:last-child > label {
	border-bottom: none;
}

/* Custom checkbox box */
.block-checkbox {
	grid-row: 1;
	grid-column: 1;
	width: 20px;
	height: 20px;
	border: 2px solid #999;
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: white;
	transition: all 0.15s ease;
	flex-shrink: 0;
}

.block-checkbox svg {
	width: 14px;
	height: 14px;
	opacity: 0;
	transition: opacity 0.15s ease;
	color: white;
}

.block-item > label:hover .block-checkbox {
	border-color: var(--color-dark-blue);
}

/* Module name */
.block-name {
	grid-row: 1;
	grid-column: 2;
	font-weight: 500;
	line-height: 1.35;
}

/* Duration badge */
.block-time {
	grid-row: 1;
	grid-column: 3;
	background-color: var(--color-regular-grey);
	padding: 0.2rem 0.6rem;
	border-radius: 3px;
	font-size: 0.75rem;
	font-weight: 600;
	color: #555;
	white-space: nowrap;
	transition:
		background-color 0.15s ease,
		color 0.15s ease;
}

/* Description spans columns 2–3 */
.block-description {
	grid-row: 2;
	grid-column: 2 / 4;
	font-size: 0.85rem;
	color: #666;
	line-height: 1.5;
}

/* Checked state */
.block-item > input[type="checkbox"]:checked + label {
	background-color: var(--color-light-turquoise);
}

.block-item > input[type="checkbox"]:checked + label .block-checkbox {
	background-color: var(--color-dark-blue);
	border-color: var(--color-dark-blue);
}

.block-item > input[type="checkbox"]:checked + label .block-checkbox svg {
	opacity: 1;
}

.block-item > input[type="checkbox"]:checked + label .block-name {
	font-weight: 600;
}

.block-item > input[type="checkbox"]:checked + label .block-time {
	background-color: var(--color-dark-blue);
	color: white;
}

/* Focus state for keyboard accessibility */
.block-item > input[type="checkbox"]:focus-visible + label {
	outline: 2px solid var(--color-regular-turquoise);
	outline-offset: 2px;
}

/* Allow <p> tags inside descriptions */
.block-description p {
	margin: 0;
}

/* ---------- Equipment addons list ---------- */

.equipment-addons-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Range variant within block-item */
.block-item-range {
	padding: 0.75rem 0.5rem;
	border-bottom: 1px solid #e0e0e0;
	border-radius: 4px;
}

.block-category .block-item-range:last-child {
	border-bottom: none;
}

.block-item-range .form-field {
	margin: 0;
}

.block-item-range .block-description {
	display: block;
	margin-top: 0.25rem;
}

/* Equipment addons have no item borders */
.equipment-addons-list .block-item > label {
	border-bottom: none;
}

.equipment-addons-list .block-item-range {
	border-bottom: none;
}

/* ---------- Catering checkbox ---------- */

.catering-checkbox {
	background: #e5f4f5;
	border: none;
	border-radius: 6px;
	padding: 1rem;
}

.catering-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	cursor: pointer;
	min-height: 44px;
	line-height: 1.4;
	font-weight: bold;
}

.catering-checkbox input[type="checkbox"] {
	width: 22px;
	height: 22px;
	flex-shrink: 0;
	margin-top: 2px;
	accent-color: var(--color-dark-blue);
}

/* ---------- Equipment two-column grid (desktop) ---------- */

@media screen and (min-width: 1024px) {
	.equipment-addons-list .block-category {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 0 1.5rem;
	}

	.equipment-addons-list .block-category h5 {
		grid-column: 1 / -1;
	}
}
