/**
 * Divilogy Timeline - Front styles.
 */

.divilogy-timeline {
	--dt-color-primary: #333333;
	--dt-color-accent: #ECBB60;
	--dt-font-family: 'Open Sans', sans-serif;
	--dt-top-font-size: 16px;
	--dt-bottom-font-size: 20px;
	--dt-marker-size: 58px;
	--dt-mobile-marker-size: 44px;
	--dt-line-size: 4px;
	--dt-desktop-top-row: 136px;
	--dt-desktop-marker-row: 72px;
	--dt-desktop-max-item-width: 340px;
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	padding: 18px 0 10px;
	font-family: var(--dt-font-family);
	color: var(--dt-color-primary);
}

.divilogy-timeline *,
.divilogy-timeline *::before,
.divilogy-timeline *::after {
	box-sizing: border-box;
}

.divilogy-timeline__inner {
	position: relative;
	display: grid;
	grid-template-columns: repeat(var(--dt-items), minmax(0, 1fr));
	width: 100%;
	max-width: min(100%, calc(var(--dt-items) * var(--dt-desktop-max-item-width)));
	margin: 0 auto;
}

.divilogy-timeline__item {
	position: relative;
	display: grid;
	grid-template-rows: var(--dt-desktop-top-row) var(--dt-desktop-marker-row) auto;
	justify-items: center;
	min-width: 0;
	text-align: center;
}

.divilogy-timeline__item:not(.divilogy-timeline__item--last)::after {
	content: '';
	position: absolute;
	z-index: 1;
	top: calc(var(--dt-desktop-top-row) + (var(--dt-desktop-marker-row) / 2));
	left: 50%;
	right: -50%;
	height: var(--dt-line-size);
	background: var(--dt-color-primary);
	transform: translateY(-50%);
}

.divilogy-timeline__item--before-last::after {
	background: repeating-linear-gradient(
		to right,
		var(--dt-color-primary) 0,
		var(--dt-color-primary) 5px,
		transparent 5px,
		transparent 13px
	) !important;
}

.divilogy-timeline__top {
	z-index: 2;
	align-self: end;
	width: min(100%, 320px);
	padding: 0 14px 30px;
	font-size: var(--dt-top-font-size);
	font-weight: 400;
	line-height: 1.35;
	letter-spacing: 0.01em;
	white-space: pre-line;
}

.divilogy-timeline__marker {
	position: relative;
	z-index: 3;
	align-self: center;
	width: var(--dt-marker-size);
	height: var(--dt-marker-size);
	border-radius: 999px;
	background: var(--dt-color-primary);
	box-shadow: 0 0 0 2px var(--dt-color-primary);
}

.divilogy-timeline__item--last .divilogy-timeline__marker {
	background: var(--dt-color-accent);
}

.divilogy-timeline__bottom {
	z-index: 2;
	width: min(100%, 320px);
	padding: 10px 14px 0;
	font-size: var(--dt-bottom-font-size);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
}

@media (max-width: 980px) {
	.divilogy-timeline {
		--dt-line-size: 3px;
		padding: 10px 0;
	}

	.divilogy-timeline__inner {
		display: block;
		max-width: 760px;
	}

	.divilogy-timeline__item {
		display: grid;
		grid-template-columns: 60px minmax(0, 1fr);
		grid-template-rows: auto auto;
		column-gap: 18px;
		justify-items: stretch;
		min-height: 116px;
		padding: 0 0 34px;
		text-align: left;
	}

	.divilogy-timeline__item:not(.divilogy-timeline__item--last)::after {
		top: calc((var(--dt-mobile-marker-size) / 2) + 4px);
		bottom: -4px;
		left: calc(30px - (var(--dt-line-size) / 2));
		right: auto;
		width: var(--dt-line-size);
		height: auto;
		transform: none;
	}

	.divilogy-timeline__item--before-last::after {
		background: repeating-linear-gradient(
			to bottom,
			var(--dt-color-primary) 0,
			var(--dt-color-primary) 5px,
			transparent 5px,
			transparent 13px
		) !important;
	}

	.divilogy-timeline__top {
		grid-column: 2;
		grid-row: 1;
		align-self: auto;
		width: 100%;
		padding: 0 0 8px;
		font-size: var(--dt-top-font-size);
	}

	.divilogy-timeline__marker {
		grid-column: 1;
		grid-row: 1 / span 2;
		align-self: start;
		justify-self: center;
		width: var(--dt-mobile-marker-size);
		height: var(--dt-mobile-marker-size);
		margin-top: 4px;
	}

	.divilogy-timeline__bottom {
		grid-column: 2;
		grid-row: 2;
		width: 100%;
		padding: 0;
		font-size: var(--dt-bottom-font-size);
		line-height: 1.2;
	}

	.divilogy-timeline__item--last {
		padding-bottom: 0;
	}
}

@media (max-width: 767px) {
	.divilogy-timeline {
		--dt-top-font-size: 15px;
		--dt-bottom-font-size: 18px;
		--dt-mobile-marker-size: 38px;
	}

	.divilogy-timeline__item {
		grid-template-columns: 48px minmax(0, 1fr);
		column-gap: 14px;
		min-height: 104px;
		padding-bottom: 28px;
	}

	.divilogy-timeline__item:not(.divilogy-timeline__item--last)::after {
		left: calc(24px - (var(--dt-line-size) / 2));
	}
}
