.top-title {
	color: #2578b2;
	position: absolute;
	left: 0%;
	top: 0.5%;
	width: 100%;
	padding-bottom: 1.5%;
	z-index: 15;
	font-size: 5vw;
	font-family: andika;
	border-bottom: 0.4vmin solid #434343;
}
@media(min-aspect-ratio:4/3){
	.top-title{
		font-size: 6.5vh;
	}
}




.numline-block{
	position: absolute;
	top: 12.5%;
	left: 2.5%;
	width: 95%;
	height: 20%;
	/*overflow: hidden;*/
}


.numline-2{
	top: 25%;
}
.numline-3{
	top: 35%;
}
.numline-4{
	top: 55%;
}
.numline-5{
	top: 32.5%;
}
.numline-6{
	top: 35%;
}

#line-svg{
	width: 100%;
	height: 100%;
	/*z-index: 2;*/
}
.main-line{
	position: absolute;
	top: 45%;
	left: 2%;
	width: 96%;
	height: 1.5%;
	transform: translateY(-50%);
	background-color: black;
	min-height: 2px;
}
.mark-container{
	position: absolute;
	top: 45%;
	left: 2.5%;
	width: 95%;
	height: 20%;
	transform: translateY(-50%);
	overflow: hidden;
}

.label-container{
	position: absolute;
	top: 60%;
	left: 2.5%;
	width: 95%;
	height: 20%;
	transform: translateY(-50%);
}
.mark-element{
	position: absolute;
	width: 4.5%;
	height: 100%;
	top: 0%;
	transform: translateX(-50%);
}
.mark-line{
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: 0%;
	height: 100%;
	width: 0.1vw;
	background-color: black;
}
.mark-element>p{
	position: absolute;
	text-align: center;
	left: 0%;
	top: 110%;
	width: 100%;
	font-size: 2vw;
}

@media(min-aspect-ratio:4/3){
	.mark-element>p{
		font-size: 2.8vh;
	}
}

.mark-hollow-circle, .mark-filled-circle{
	position: absolute;
	left: 50%;
	top: 50%;
	width: 60%;
	height: 89.3%;
	border: 0.3vmin solid #44546a;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	z-index: 5;
}
.mark-filled-circle{
	background-color: #000000;
}
.slanted-line{
	position: absolute;
	width: 0.2vw;
	bottom: 50%;
	left: 50%;
	background-color: #44546a;
	transform-origin: 50% 100%;
}
.straight-line{
	position: absolute;
	width: 0.2vw;
	bottom: 50%;
	left: 50%;
	height: 150%;
	transform: translateX(-50%);
	background-color: #44546a;
}
.roof-1, .roof-2{
	position: absolute;
	transform: translateY(50%);
	height: 200%;
	width: 200%;
	bottom: 200%;
}
.roof-1>p, .roof-2>p{
	position: absolute;
	bottom: 50%;
	width: 100%;
	left: 0%;
	text-align: center;
	font-size: 2vw;
	font-family: abeezee;
	font-weight: normal;
}
.roof-1>img, .roof-1>svg, .roof-2>img, .roof-2>svg{
	position: absolute;
	top: 50%;
	height: 25%;
	transform: translateY(-50%);
	width: 100%;
	left: 0%;
}
@media(min-aspect-ratio:4/3){
	.small-text{
		font-size: 2.8vh;
	}
	.roof-1>p, .roof-2>p{
		font-size: 2.5vh;
	}
}
.join-roof{
	position: absolute;
	transform: translateY(50%);
	height: 10%;
	background-color: black;
	bottom: 200%;
}
.mark-container-2{
	overflow: visible;
}





.s1-text-1{
	position: absolute;
	top: 15%;
	width: 92%;
	left: 4%;
	text-align: center;
	font-size: 3.5vw;
	font-family: andika;
}
@media(min-aspect-ratio:4/3){
	.s1-text-1{
		font-size: 4.6vh;
	}
}
.bottom-text-dark{
	position: absolute;
	bottom: 0%;
	left: 0%;
	background-color: #666666;
	width: 100%;
	/* padding: 0% 3%; */
	color: white;
	font-family: andika;
	font-size: 3.3vw;
}
@media(min-aspect-ratio:4/3){
	.bottom-text-dark{
		font-size: 4.4vh;
	}
}
.hl-bold{
	font-weight: bold;
	font-size: 3.9vw;
}

@media(min-aspect-ratio:4/3){
	.hl-bold{
		font-size: 5.1vh;
	}
}

.s2-text-1{
	position: absolute;
	top: 15%;
	width: 92%;
	left: 4%;
	text-align: center;
	font-size: 5vw;
	font-family: andika;
	color: #090089;
	font-weight: bold;
}
@media(min-aspect-ratio:4/3){
	.s2-text-1{
		font-size: 6.5vh;
	}
}
.bottom-text-light{
	position: absolute;
	top: 55%;
	left: 10%;
	background-color: #d9d2e9;
	width: 80%;
	height: 40%;
	border-radius: 5vmin;
	padding: 0% 3%;
	color: #323232;
	font-size: 3.3vw;
	font-family: andika;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-around;
}
@media(min-aspect-ratio:4/3){
	.bottom-text-light{
		font-size: 4.4vh;
	}
}

.s2-text-2{
	position: absolute;
	bottom: 65%;
	width: 20%;
	right: 11%;
	text-align: center;
	font-size: 2.4vw;
	font-family: andika;
	color: #274e13;
	font-weight: bold;
	opacity: 0;
}
@media(min-aspect-ratio:4/3){
	.s2-text-2{
		font-size: 3.2vh;
	}
}

.s2-text-3, .s2-text-4{
	position: absolute;
	width: 90%;
	left: 5%;
	text-align: center;
	font-size: 3.2vw;
	font-family: andika;
	color: #090089;
}
@media(min-aspect-ratio:4/3){
	.s2-text-3, .s2-text-4{
		font-size: 4.4vh;
	}
}
.s2-text-3{
	top: 17%;
}

.s2-text-4{
	top: 65%;
}

























.bottom-texts{
	position: absolute;
	top: 55%;
	left: 2.5%;
	width: 95%;
	background-color: #d9ead3;
	border-radius: 5vmin;
	font-size: 2.4vw;
	font-family: andika;
	height: 42.5%;
	padding: 2%;
}
.bottom-texts>p{
	width: 100%;
	text-align: center;
}
@media(min-aspect-ratio:4/3){
	.bottom-texts{
		font-size: 3.2vh;
	}
}
.bottom-texts-2{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-around;
	color: #090089;
}
.text-list-1{
	color: #674ea7;
}
.text-list-2{
	color: #7f6000;
}
.text-list-3{
	color: #ff6627;
}

.bottom-list{
	margin: 2% 5%;
	text-align: left;
	list-style-type: decimal;
}
.bottom-list>li{
	margin: 3% 0%;
}
.label-highlight{
	animation: label-highlight 1s linear 0s 2;
	-webkit-animation: label-highlight 1s linear 0s 2;
}
@-webkit-keyframes
label-highlight {
	50% {color: red;font-weight:bold;}
}
@keyframes
label-highlight {
	50% {color: red;font-weight:bold;}
}
.dot-highlight{
	animation: dot-highlight 1s linear 0s 2;
	-webkit-animation: dot-highlight 1s linear 0s 2;
}
@-webkit-keyframes
dot-highlight {
	50% {border-color: red;}
}
@keyframes
dot-highlight {
	50% {border-color: red;}
}
.disc-highlight{
	animation: disc-highlight 1s linear 0s 2;
	-webkit-animation: disc-highlight 1s linear 0s 2;
}
@-webkit-keyframes
disc-highlight {
	50% {border-color: red; background-color: red;}
}
@keyframes
disc-highlight {
	50% {border-color: red; background-color: red;}
}







