@charset "utf-8";
.history_lead {
		line-height: 2.2;
		margin: 0 0 80px;
		text-align: justify;
		font-weight: 600;
}
.history_section_wrap {
		position: relative;
		margin-bottom: 120px;
		display: flex;
		align-items: flex-start;
}
.history_section_wrap .history_bar {
		position: sticky;
		left: 0;
		top: 0;
		height: 60vh;
		width: 22px;
		z-index: -1;
}
.history_bar::after {
		content: '';
		display: block;
		position: absolute;
		top: 0px;
		left: 0;
		width: 22px;
		height: 100%;
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 22px;
		background-image: url("../images/history_arw_pc.png");
		pointer-events: none;
}
.history_cont {
		margin-left: 109px;
		position: relative;
		top: -25px;
		z-index: 10
}
.history_title_wrap {
		margin: 20px 0 40px;
		position: relative;
		z-index: 10
}
.history_title_wrap .history_year_circle {
		position: absolute;
		left: -160px;
		top: calc(50% - 40px);
		width: 80px;
		height: 80px;
		background: #fff;
		border: 1px solid #3DAE35;
		border-radius: 50%;
		display: flex;
		justify-content: center;
		align-items: center;
		color: #3DAE35;
		font-weight: 600;
		font-size: 20px;
		letter-spacing: 0;
}
.history_title_wrap .history_year_circle.extra {
		top: 260px;
}
.history_title_wrap .history_year_circle.dot {
		width: 20px;
		height: 20px;
		left: -131px;
		top: calc(50% - 10px);
}
.history_year_circle {
		line-height: 1.3;
}
.history_year_circle span {
		display: block;
		text-align: center;
		font-size: 16px;
}
.history_title {
		background: #fff;
		border-radius: 10px;
		padding: 15px 25px;
		position: relative;
}
.history_title::before {
		content: '';
		display: block;
		position: absolute;
		top: calc(50% - 1px);
		left: -110px;
		width: 110px;
		height: 2px;
		background-repeat: repeat-x;
		background-position: 0 0;
		background-size: 11px;
		background-image: url("../images/dash_line.png")
}
.history_title dl {
		display: flex;
		justify-content: center;
		align-items: center;
}
.history_title dt {
		color: #3DAE35;
		font-size: 32px;
		font-weight: 500;
		margin-right: 25px;
		line-height: 1.2;
		width: 78px;
		text-align: center;
		letter-spacing: 0
}
.history_title dt span {
		font-size: 16px;
		display: block;
		text-align: center;
}
.history_title dd {
		line-height: 1.8;
		flex: 1;
}
.history_grid {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 50px 20px;
		margin-bottom: 60px;
		max-width: 680px;
}
.history_flex {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		margin-bottom: 50px;
}
.history_flex.double {
		max-width: 727px;
}
.history_flex_large {
		width: calc(61% - 10px);
}
.history_flex_small {
		width: calc(39.5% - 10px);
}
.history_flex_ex .history_flex .history_tile {
		width: 100%;
}
.history_tile {
		text-align: center;
}
.history_tile.wide {
		max-width: 560px;
		margin-bottom: 60px;
}
.history_tile_figure {
		margin-bottom: 15px;
		position: relative;
}
.history_tile_figure.extra {
		margin-bottom: 17px;
}
.history_tile_figure img {
		width: 100%;
		height: auto;
}
.history_tile_figure p {
		position: absolute;
		bottom: 10px;
		left: 10px;
		font-size: 14px;
		font-weight: 500;
		line-height: 1.6;
		text-align: left !important;
		color: #fff;
		margin: 0 !important;
		padding: 0 !important;
		text-shadow: 1px 1px 5px #000;
}
.history_tile_year {
		font-family: sans-serif;
		font-size: 24px;
		font-weight: 600;
		color: #3DAE35;
		margin: 0 0 5px;
}
.history_tile_year + p {
		line-height: 1.8;
		margin: 0 0 5px;
}
.history_tile h5 {
		font-size: 15px;
		font-weight: 500;
		color: #3DAE35;
}
.award {
		display: flex;
		justify-content: center;
		position: relative;
		align-items: center;
		margin-top: 20px;
		height: 50px;
}
.award h6 {
		font-size: 15px;
		font-weight: 500;
		color: #3DAE35;
		text-align: center;
		line-height: 1.6;
		position: relative;
}
.award h6::before, .award h6::after {
		content: '';
		display: block;
		position: absolute;
		top: calc(50% - 25px);
		width: 14px;
		height: 50px;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 14px;
}
.award h6::before {
		background-image: url("../images/history_award_l.png");
		left: -30px;
}
.award h6::after {
		right: -30px;
		background-image: url("../images/history_award_r.png")
}
/* ============= */
.history_title_wrap .history_year_circle {
		transition: opacity 0.3s;
		opacity: 0
}
.history_title_wrap.isActive .history_year_circle {
		opacity: 1
}
.history_title::before {
		transform-origin: left center;
		transform: scaleX(0);
		transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.history_title_wrap .history_title {
		transition: background 0.3s;
		background: rgba(255, 255, 255, 0);
}
.history_title_wrap.isActive .history_title::before {
		transform: scaleX(1)
}
.history_title dl {
		transition: opacity 0.3s;
		transition-delay: 0.1s;
		opacity: 0
}
.history_title_wrap.isActive .history_title dl {
		opacity: 1
}
.history_title_wrap.isActive .history_title {
		background: rgba(255, 255, 255, 1);
}
.history_tile {
		transition: opacity 0.5s;
		opacity: 0;
}
.history_tile.isActive {
		opacity: 1
}
@media(max-width: 1100px) {
		.history_cont {
				margin-left: 90px;
				top: -25px
		}
		.history_bar::after {
				top: 17px;
				left: 30px;
		}
		.history_bar.isActive::after {
				top: -20px
		}
		.history_title_wrap .history_year_circle {
				position: absolute;
				left: -110px;
				top: calc(50% - 40px);
				width: 80px;
				height: 80px;
				font-size: 20px;
		}
		.history_title_wrap .history_year_circle.dot {
				left: -80px;
		}
		.history_title::before {
				left: -80px;
				width: 80px;
		}
		.history_title dt {
				font-size: 26px;
				margin-right: 15px;
				width: 65px;
		}
		.history_title dt span {
				font-size: 13px;
		}
}
@media(max-width: 767px) {
		.history_bar::after {
				top: 40px;
				left: 16px;
				height: calc(100% - 50px)
		}
		.history_cont {
				margin-left: 70px;
				top: -25px;
		}
		.history_title_wrap .history_year_circle {
				left: -80px;
				top: -4px;
				width: 60px;
				height: 60px;
				font-size: 15px;
		}
		.history_title_wrap .history_year_circle.dot {
				left: -59px;
				top: 14px;
		}
		.history_year_circle span {
				font-size: 12px;
		}
		.history_title {
				padding: 13px;
		}
		.history_title::before {
				top: 24px;
				left: -50px;
				width: 50px;
		}
		.history_title dl {
				display: block;
		}
		.history_title dt {
				font-size: 22px;
				margin: 0 0 10px;
				text-align: left;
		}
		.history_title dt span {
				text-align: left !important;
		}
		.history_grid {
				display: block;
				gap: 0 0;
				margin-bottom: 50px;
				max-width: inherit;
				width: 100%;
		}
		.history_flex {
				display: block;
				margin-bottom: 50px;
		}
		.history_flex_large {
				width: 100%;
		}
		.history_flex_small {
				width: 100%
		}
		.history_grid .history_tile, .history_flex .history_tile {
				width: 100%;
				margin: 0 0 30px
		}
		.history_tile.wide {
				max-width: inherit;
				margin-bottom: 50px;
		}
		.history_tile_figure, .history_tile_figure.extra {
				margin-bottom: 10px;
		}
		.history_tile_figure p {
				bottom: 10px;
				left: 10px;
				font-size: 13px;
		}
		.history_tile_year {
				font-size: 22px;
		}
		.history_tile h5 {
				font-size: 15px;
				font-weight: 500;
				color: #3DAE35;
		}
		.history_title dt {
				font-size: 22px;
		}
		.history_title dd {
				font-size: 14px;
		}
		.award {
				display: flex;
				justify-content: center;
				position: relative;
				align-items: center;
				margin-top: 20px;
				height: 50px;
		}
		.award h6 {
				font-size: 14px;
		}
		.award h6::before {
				left: -20px;
		}
		.award h6::after {
				right: -20px;
		}
}