@charset "UTF-8";

.lower-visual {
	height: 195px;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.8rem;
}

.lower-title {
	font-size: 3.2rem;
	color: #fff;
}

.no-intro {
	margin-bottom: 4rem;
}

.intro {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin: 0rem 1.4rem 4rem;
	padding: 4rem 2rem;
	border-bottom: 2px solid #3D4041;
}

.intro-sentence {
	display: block;
	font-size: 1.8rem;
	max-width: 1080px;
	width: 100%;
}

.intro-quote {
	background: #eee;
	padding: 2rem;
	max-width: 1080px;
	width: 100%;
	margin-bottom: 1.6rem;
}

.reference-box {
	display: flex;
	background: #eeeeee;
	width: calc(100%/2 - 4px);
	margin-bottom: 0.8rem;
	border-radius: 2px;
}

.rf-wdh100 {
	width: 100%;
}

.rf_in-intro {
	width: 100%;
	max-width: 1080px;
	margin-top: 2rem;
}

.reference-icon {
	display: block;
	min-width: 48px;
	max-width: 48px;
	background: url("../img/common/file-icon.svg")no-repeat center center;
	background-color: #3D4041;
	border-radius: 2px 0 0 2px;
}

.reference-icon img {
	object-fit: contain;
	width: 48px;
	height: 100%;
}

.reference-link {
	display: flex;
	align-items: center;
	padding: 1.6rem;
	font-size: 1.6rem;
}

.one-line-ptn {
	width: 100%;
	margin-bottom: 4rem;
}

.page-link {
	display: block;
	color: #fff;
	background: #3D4041;
	font-size: 1.8rem;
	text-align: center;
	width: 100%;
	padding: 1.6rem;
	position: relative;
}

.page-link:hover {
	background: #35AAD1;
}

.page-link::after {
	content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		right: 16px;
		margin: auto;
		vertical-align: middle;
		width: 8px;
		height: 8px;
		border-top: 1px solid #fff;
		border-right: 1px solid #fff;
		-moz-transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
}

/*sub-contents*/
.sub-contents {
	position: relative;
	border: 2px solid #3D4041;
	padding: 4rem;
	margin: 4rem 1.4rem;
	display: flex;
	justify-content: center;
	flex-direction: column;
}

.sub-head {
	position: absolute;
	top: -2.4rem;
	left: 50%;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
	display: block;
	margin: auto;
	text-align: center;
	background: #fff;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 0 0.8rem;
	white-space: nowrap;
	overflow: hidden;
}

.sub-head_two {
	top: -4.2rem;
	text-align: left;
}

.sub-cnt-box {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.sub-cnt-p {
	padding-bottom: 2rem;
}

.sub-cnt-center {
	justify-content: center;
}

.inner-between {
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.fig-box {
	width: 100%;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-wrap: wrap;
	padding-bottom: 2rem;
}

.fig-box img {
	padding: 0 0.4rem;
	max-width: 100%;
}

.fig-cap {
	display: block;
	width: 100%;
	font-size: 1.4rem;
	font-weight: 700;
	text-align: center;
	padding: 0.8rem;
}

.sub-cnt-box .page-link {
	width: calc(100%/2 - 7px);
}

.sub-cnt-sentence {
	background: #eeeeee;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	padding: 2.4rem;
	width: 100%;
	margin-bottom: 2rem;
}

.sub-cnt-sentence p {
	max-width: 1080px;
}

.more-info {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    background: #35AAD1;
    color: #fff;
    padding: 1.2rem 1.6rem;
    text-align: center;
    margin: 2.4rem 0 2rem;
    position: relative;
}

.more-info::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 12px;
    margin: auto;
    vertical-align: middle;
    width: 8px;
    height: 8px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

/*list*/
.dot-list li::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	vertical-align: middle;
	background: #3D4041;
	margin-right: 0.8rem;
	margin-bottom: 0.2rem
}

.dot-list li {
	text-indent: -1.2rem;
	margin-left: 1.2rem;
}

.pure-list li,
.intro-list li {
	text-indent: -2em;
	margin-left: 2em;
}

.pure-list {
	padding-bottom: 2rem;
}

.intro-list {
	width: 100%;
	max-width: 1080px;
	padding-top: 2rem;
}

.time-line dt {
	font-weight: 700;
}
.time-line dd {
    margin-top: -1.7em;
    padding: 0 0 0.8rem 7rem;
	border-bottom: 1px solid;
    margin-bottom: 0.8rem;
}

/*table*/

.pure-table th,
.pure-table td {
	padding: 0.4rem 0.8rem;
	border-bottom: 1px solid #3D4041;
	border-top: 1px solid #3D4041;
}
.pure-table th:nth-of-type(1),
.pure-table td:nth-of-type(1) {
	border-right: 1px solid #3D4041;
}


.pure-table td {
	background: #eee;
}

.small-title {
	font-size: 1.8rem;
	font-weight: 700;
	margin: 2rem 0 0.8rem;
	padding-bottom: 0.4rem;
	border-bottom: 1px solid #3D4041;
	width: 100%;
}

.smallest-title {
	padding: 1.6rem 0 0.4rem;
	color: #ff7600;
}

.video-wrap {
	max-width: 480px;
	margin: 0 auto;
	padding: 2rem 0;
}

.video {
	position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}

.video-cap {
	display: block;
	text-align: center;
	padding-top: 0.4rem;
}

.video iframe {
	width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}


@media only screen and (max-width: 1460px) {
	.lower-visual {
		height: 172px;
	}
	.lower-title {
		font-size: 3.2rem;
	}
	.sub-head {
		top: -2rem;
		font-size: 2.4rem;
		font-weight: 700;
	}
	.sub-head_two {
		top: -3.8rem;
	}
	.intro-sentence {
		font-size: 1.7rem;
	}
}

@media only screen and (max-width: 1024px) {
	
}

@media only screen and (max-width: 768px) {
	.lower-visual {
		height: 20vh;
	}
	.lower-title {
		font-size: 1.8rem;
	}
	.intro {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
		margin: 0rem 0.8rem 2.8rem;
		padding: 2.8rem 0.8rem;
		border-bottom: 2px solid #3D4041;
	}
	.intro-sentence {
		font-size: 1.5rem;
	}
	.page-link {
		font-size: 1.5rem;
		padding: 1.6rem;
	}
	.reference-box {
		width: 100%;
	}

	.reference-link {
		padding: 1.4rem;
		font-size: 1.3rem;
	}
	
	/*sub-contents*/
	.sub-head {
		top: -1.5rem;
		font-size: 1.7rem;
		white-space: nowrap;
	}
	
	.sub-head_two {
		top: -2.8rem;
	}
	
	.sub-head_br_rp {
		top: -2.8rem;
		text-align: left;
	}
	
	.sub-contents {
		padding: 2.8rem 1.6rem 1.2rem;
		margin: 2.8rem 0.8rem;
	}
	.sub-cnt-sentence {
		font-size: 1.5rem;
	}
	.sub-cnt-box .page-link {
		width: 100%;
		margin-bottom: 1.6rem;
	}
	/*list*/
	.time-line dd {
		margin-top: 0;
		padding: 0 0 0.8rem;
	}
	.small-title {
		font-size: 1.5rem;
	}
}


