.frankeileen-timeline-container {
	position: relative;
	margin: 0 auto;
	padding: 20px 0;
	
	display: flex;
    flex-direction: column;
    flex-wrap: wrap;
	
	max-width: 700px;
}

.frankeileen-timeline-item {
	position: relative;
	margin: 0;
	padding: 0;
	
	display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr 1fr;
	
	column-gap: 12vw;
	row-gap: 9vw;
	
	padding-top: 3vw;
    padding-bottom: 3vw;
}
.frankeileen-timeline-container > .frankeileen-timeline-item:first-child {
	padding-top: 0;
}
.frankeileen-timeline-container > .frankeileen-timeline-item:last-child {
	padding-bottom: 0;
}

.frankeileen-timeline-item:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%; /* Adjust for desired line position */
	width: 3px;
	background-color: var( --e-global-color-ffaf2cd );
	transform: translateX(-50%);
}
.frankeileen-timeline-item.timeline-item-first:before {
	top: 50%;
}
.frankeileen-timeline-item.timeline-item-last:before {
	bottom: 50%;
}

.frankeileen-timeline-item:after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 83px;
	height: 3px;
	background-color: var( --e-global-color-ffaf2cd );
	transform: translateX(-26px) translateY(-2px);
}
.timeline-image-second.frankeileen-timeline-item:after {
	transform: translateX(-57px) translateY(-2px);
}

.frankeileen-timeline-image {
	order: 1;
	width: 75%;
	
	display: flex;
	align-items: center;
    justify-self: end;
	
	/* design quirk of circle icons */
	justify-self: center;
}

.frankeileen-timeline-content {
	order: 2;
	width: 100%;
	
	display: flex;
	align-items: center;
	justify-self: start;
}

.timeline-image-first .frankeileen-timeline-content {
	transform: translateX(20px);
}

.timeline-image-second .frankeileen-timeline-image {
	order: 2;
	
	justify-self: start;
	
	transform: translateX(-20px);
}

.timeline-image-second .frankeileen-timeline-content {
	order: 1;
	
	justify-self: end;
}

.frankeileen-timeline-content {
	display: flex;
    flex-direction: column;
    align-items: center;
	color: #fff;
}

.frankeileen-timeline-desc {
	text-align: center;
	color: #fff;
	text-align: center;
	padding: 0;
}

.frankeileen-timeline-desc p,
.frankeileen-timeline-desc > * {
	margin: 0 !important;
}

.frankeileen-timeline-date,
.elementor-kit-7 h3.frankeileen-timeline-date {
	font-family: "Canela", Sans-serif;
	color: #fff;
	text-align: center;
	
	font-size: 32px;
	
	margin: 0 0 0.5vw 0 !important;
}

/* late dev, when centered date spanning across timeline line */
.frankeileen-timeline-image.frankeileen-timeline-image-with-second-text-below {
	display: flex;
	flex-direction: column;
	row-gap: 1vw;
}

/* at 475px and below is just a single vertical column */
/*
@media (min-width: 476px) {
*/
	.timeline-year-positioned-spanning-across .frankeileen-timeline-content-centered-date {
		order: 2;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.timeline-year-positioned-spanning-across .frankeileen-timeline-content {
		order: 3;
	}

	.timeline-year-positioned-spanning-across .frankeileen-timeline-content-centered-date .frankeileen-timeline-date, 
	.elementor-kit-7 .timeline-year-positioned-spanning-across .frankeileen-timeline-content-centered-date h3.frankeileen-timeline-date {
		margin-bottom: 0 !important;
		font-size: 50px;
	}

	.frankeileen-timeline-item.timeline-year-positioned-spanning-across:after {
		display: none;
	}

	.frankeileen-timeline-item.timeline-year-positioned-spanning-across.timeline-item-last:before {
		bottom: 60%;
	}

	.frankeileen-timeline-item.timeline-year-positioned-spanning-across {
		display: grid;
		align-items: center;
		grid-auto-columns: 1fr max-content 1fr;
		column-gap: 1vw;
	}

	.timeline-year-positioned-spanning-across .frankeileen-timeline-desc.frankeileen-timeline-desc-below-image {
		margin-top: 10px;
	}
/*
}
*/

@media (min-width: 1024px) {
	.frankeileen-timeline-item.timeline-year-positioned-spanning-across {
		grid-row-gap: 0;
		grid-auto-rows: 1fr max-content 1fr;
	}
	
    .frankeileen-timeline-item.timeline-year-positioned-spanning-across.timeline-item-last:before {
        width: 13%;
    }
	
	.frankeileen-timeline-item.timeline-year-positioned-spanning-across:after {
        display: none;
    }
	
	.timeline-year-positioned-spanning-across.timeline-image-first .frankeileen-timeline-image {
        transform: translateY(-10px);
    }
	
	.timeline-year-positioned-spanning-across .frankeileen-timeline-content {
		transform: translateX(0) translateY(15px) !important;
		margin-bottom: auto;
    	margin-top: 1vw;
	}
}

@media (max-width: 767px) {
	.frankeileen-timeline-desc {
		font-size: 80%;
	}
	
	.timeline-image-first .frankeileen-timeline-content {
		transform: translateX(10px);
		transform: translateX(0);
	}
	
	.timeline-image-second .frankeileen-timeline-image {
		transform: translateX(-10px);
	}
	
	.frankeileen-timeline-item:after {
		width: 42px;
		transform: translateX(-13px) translateY(-2px);
	}
	.timeline-image-second.frankeileen-timeline-item:after {
		transform: translateX(-29px) translateY(-2px);
	}
}

@media (min-width: 1024px) {
	.frankeileen-timeline-container {
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		
		max-width: 2000px;
		row-gap: 15vw;
	}
	
	.frankeileen-timeline-item {
		grid-auto-flow: row;
		grid-auto-rows: 1fr 1fr;
		
		padding-left: 10px;
        padding-right: 10px;
		
		row-gap: 9.5vw;
		
		padding-top: 0;
    	padding-bottom: 0;
	}
	
	.frankeileen-timeline-image {
		width: 100%;
		
		align-items: flex-end;
		justify-content: center;
	}
	
	.frankeileen-timeline-content {
		
	}
	
	.frankeileen-timeline-desc {
		padding: 0 30px;
	}
	.frankeileen-timeline-desc-wider .frankeileen-timeline-desc {
		padding: 0;
	}
	
	.timeline-image-first .frankeileen-timeline-content {
		transform: translateX(0);
	}
	
	.timeline-image-first .frankeileen-timeline-image {
		transform: translateY(20px);
	}
	
	.timeline-image-second .frankeileen-timeline-image {
		justify-self: auto;
		align-items: flex-start;
		transform: translateX(0) translateY(-20px);
	}
	
	.timeline-image-square .frankeileen-timeline-image .frankeileen-timeline-img {
		max-height: 225px;
		max-height: 8.78vw;
	}
	.timeline-image-rect-landscape .frankeileen-timeline-image .frankeileen-timeline-img {
		max-height: 170px;
		max-height: 6.64vw;
	}

	.timeline-image-second .frankeileen-timeline-content {
		order: 1;

		justify-self: auto;
		justify-content: flex-end;
	}
	
	.frankeileen-timeline-item:before {
		top: 50%;
		bottom: auto;
		left: 0;
		height: 3px;
		width: 100%;
		transform: translateY(-50%);
	}
	.frankeileen-timeline-item.timeline-item-first:before {
		left: 50%;
		width: 50%;
	}
	.frankeileen-timeline-item.timeline-item-last:before {
		right: 50%;
		width: 50%;
	}

	.frankeileen-timeline-item:after {
		height: 83px;
		width: 3px;
		transform: translateX(-2px) translateY(-26px);
	}
	.timeline-image-second.frankeileen-timeline-item:after {
		transform: translateX(-2px) translateY(-57px);
	}
	
	.frankeileen-timeline-content {
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}
}

@media (min-width: 1024px) and (max-width: 1500px) {
	.frankeileen-timeline-content,
	.frankeileen-timeline-desc.frankeileen-timeline-desc-below-image {
		font-size: 80%;
	}
}

@media (min-width: 1024px) and (max-width: 1300px) {
	.frankeileen-timeline-item {
		row-gap: 12.5vw;
	}
}

/* at 475px and below is just a single vertical column */
/*
@media (max-width: 475px) {
	.frankeileen-timeline-item {
		grid-auto-flow: row;
		grid-auto-columns: 1fr;
		padding-left: 40px;
		row-gap: 10px;
	}
	
	.timeline-image-second.frankeileen-timeline-item {
		padding-left: 66px;
	}
	
	.frankeileen-timeline-img {
		max-width: 100px !important;
	}
	
	.frankeileen-timeline-item:before {
		left: 10px;
	}
	
	.frankeileen-timeline-item:after,
	.timeline-image-second.frankeileen-timeline-item:after {
		left: 0;
		transform: translateX(8px) translateY(-2px);
		width: 23px;
	}
	
	.timeline-image-second.frankeileen-timeline-item:after {
		width: 46px;
	}
	
	.frankeileen-timeline-image {
		justify-self: flex-start;
		align-items: flex-start;
		width: 100%;
	}
	
	.frankeileen-timeline-content {
    	align-items: flex-start;
	}
	
	.frankeileen-timeline-desc {
		text-align: left;
	}
	
	.timeline-image-first .frankeileen-timeline-content {
		transform: translateX(0);
	}
	
    .timeline-image-second .frankeileen-timeline-image {
        transform: translateX(0);
    }
	
	.frankeileen-timeline-date, 
	.elementor-kit-7 h3.frankeileen-timeline-date {
		text-align: left;
	}
	
	.timeline-image-second .frankeileen-timeline-image {
		order: 1;
	}
	
	.timeline-image-second .frankeileen-timeline-content {
    	order: 2;
	}
}
*/
/* at 475px and and below just make text tiny to fit, yes, really */
@media (max-width: 475px) {
	.elementor-widget-frankeileen01-timeline {
		margin-left: -5px;
        margin-right: -5px;
        width: calc(100% + 10px);
	}
	
	.frankeileen-timeline-desc {
        font-size: 12px;
    }
	
	.frankeileen-timeline-content {
    	max-width: 95%;
	}
}
@media (max-width: 374.75px) {
	.frankeileen-timeline-desc {
        font-size: 10px;
    }
}