.map_area_holder {
	width: 100%;
	padding: 100px 0px;
	background-color: #324149;
}

.map_area_holder h3.presentation, .checkpoints_info_holder h3.presentation {
	color: #54656f;
	font-size: 26px;
	font-weight: bold;
	line-height: 1.54;
	text-align: center;
	margin-top: 0;
	margin-bottom: 20px;
	line-height: 30px;
}

.map_area_holder h4.presentation {
	color: #3d4e57;
	font-size: 16px;
	font-weight: 300;
	text-align: center;
	margin-top: 0;
}

.map_area_holder.mobile {
	background: rgba(76, 175, 80, 0);
	padding: 0;
}

.map_area_holder.grey {
	background: #FAFAFA;
}

.vector_map {
	background-color: transparent;
	background-repeat: no-repeat;
	border: 0 none;
	background: url('/website/img/map.svg');
	width: 1146px;
	height: 555px;
	object-fit: contain;
	margin: 40px auto 30px auto;
	position: relative;
}

.checkpoints_btn {
	font-size: 12px;
	line-height: 22px;
	padding: 7px 15px;
	font-family: Montserrat;
	text-align: center;
	cursor: pointer;
	font-weight: normal;
	color: #ffffff;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	border: #2db572 1px solid;
	background-color: #2db572;
	font-weight: 500;
	width: 210px;
	margin: 0px auto;
}

.checkpoints_btn:active {
	text-decoration: underline;
}

.checkpoints_floater {
	position: absolute;
	background: #ffffff;
	border-radius: 4px;
	width: 140px;
	font-size: 15px;
	padding: 15px 5px 15px 5px;
	color: #54656f;
	text-align: center;
	font-weight: normal;
	cursor: pointer;
}

.checkpoint_number {
	font-size: 13px;
}

.bg_grey {
	background: #3d4e57;
}

.bg_green {
	background: #43B176;
}

.bg_red {
	background: #B0413E;
}

.checkpoints_floater.narrow {
	width: 100px;
}

.checkpoints_floater:hover {
	text-decoration: underline;
}

.checkpoints_floater:active {
	color: #d0ffe5;
}

.checkpoints_floater_arrow {
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid #ffffff;
	position: absolute;
	bottom: -10px;
	left: 65px;
}

.checkpoints_floater_arrow.narrow {
	left: 45px;
}

.checkpoints_floater_arrow.green {
	border-top: 10px solid #43B176;
}

.checkpoints_floater_arrow.grey {
	border-top: 10px solid #3d4e57;
}

.checkpoints_floater_arrow.red {
	border-top: 10px solid #B0413E;
}

.checkpoints_floater_arrow_top {
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 10px solid #43B176;
	position: absolute;
	top: -10px;
	left: 45px;
}

.checkpoints_floater_arrow_top.green {
	border-bottom: 10px solid #43B176;
}

.checkpoints_floater_arrow_top.grey {
	border-bottom: 10px solid #3d4e57;
}

.checkpoints_floater_arrow_top.red {
	border-bottom: 10px solid #B0413E;
}


.checkpoints_floater_arrow_left {
	width: 0;
	height: 0;
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
	border-right: 10px solid #43B176;
	position: absolute;
	left: -10px;
	top: 12px;
}

.checkpoints_floater_arrow_left.green {
	border-right: 10px solid #43B176;
}

.checkpoints_floater_arrow_left.grey {
	border-right: 10px solid #3d4e57;
}

.checkpoints_floater_arrow_left.red {
	border-right: 10px solid #B0413E;
}

.bold {
	font-weight: bold;
}

.checkpoints_floater.na {
	left: 125px;
	top: 150px;
}

.checkpoints_floater.europe {
	left: 530px;
	top: 130px;
}

.checkpoints_floater.africa {
	left: 540px;
	bottom: 220px;
}

.checkpoints_floater.sa {
	left: 280px;
	bottom: 140px;
}

.checkpoints_floater.asia {
	right: 250px;
	top: 170px;
}

.checkpoints_floater.oceania {
	right: 100px;
	bottom: 120px;
}

.checkpoints_floater.new_york {
	left: 220px;
	top: 140px;
}

.checkpoints_floater.dallas {
	left: 130px;
	top: 215px;
}

.checkpoints_floater.sanfrancisco {
	left: 75px;
	top: 140px;
}

.checkpoints_floater.stockholm {
	left: 455px;
	top: 70px;
}

.checkpoints_floater.frankfurt {
	left: 445px;
	top: 190px;
}

.checkpoints_floater.london {
	left: 465px;
	top: 130px;
}

.checkpoints_floater.pos1 {
	left: 300px;
	bottom: 130px;
}

.checkpoints_floater.pos2 {
	left: 480px;
	bottom: 100px;
}

.checkpoints_floater.singapore {
	right: 190px;
	top: 240px;
}

.checkpoints_floater.tokyo {
	right: 85px;
	top: 165px;
}

.checkpoints_floater.sydney {
	right: 55px;
	bottom: 85px;
}

.checkpoints_list_div {
	width: 390px;
	margin: 0px auto;
	padding-bottom: 20px;
	display: none;
}

.checkpoint_list_box {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

ul.checkpoints_list {
	margin: auto;
	width: 100%;
	list-style-type: none;
    padding-left:0;
}

ul.checkpoints_list li {
	text-align: center;
	list-style-type: none;
	width: 152px;
    height: 73px;
    border-radius: 4px;
    border: solid 1px #a0adb5;
    background-color: #ffffff;
	margin: 20px 40px;
}

ul.checkpoints_list li a {
	text-decoration: none;
	color: #54656f;
}

ul.checkpoints_list li a:hover {
	text-decoration: underline;
}

ul.checkpoints_list li a:active {
	color: #31AA69;
}

@media screen and (max-width: 1150px) {
	.vector_map {
		display: none;
	}

	.checkpoints_list_div {
		display: flex;
		justify-content: center;
		flex-direction: column;
		align-items: center;
		flex-wrap: wrap;
	}

	.checkpoint_list_div_wrapper{
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		padding-bottom: 20px;
	}

	.checkpoint_button{
		padding: 25px 15px;
		width: 130px;
	    border-radius: 4px;
	    border: solid 1px #a0adb5;
	    background-color: #ffffff;
		margin: 15px;
		text-align: center;
		font-size: 15px;
	    font-weight: bold;
	    font-stretch: normal;
	    font-style: normal;
	    line-height: normal;
	    letter-spacing: normal;
	    text-align: center;
	    color: #54656f;
	}

	.map_area_holder {
		background-image: url('/website/img/map.svg');
	}

	.checkpoint_button:hover{
		text-decoration: underline;
	}

	a:hover {
		color: black;
	}
}

@media screen and (max-width: 400px) {
	.checkpoint_button {
		padding: 25px 15px;
		width: 125px;
	}

	.checkpoints_list_div {
		width: auto;
	}

	.map_area_holder {
		background-image: none;
		padding: 30px 0px;
	}

	.map_area_holder.mobile {
		background-image: url('/website/img/map.svg');
		padding: 30px 0px;
		background-position: bottom;
	}
}

@media screen and (max-width: 375px) {
	.checkpoint_button {
		padding: 25px 10px;
		width: 125px;
	}
}
