@charset "utf-8";
#wrapper {
	overflow: hidden;
	width: 100%;
}

@media screen and (min-width:769px) {
	.dt_hs_container {
		padding: 0 0 110px 0;
		text-align: center
	}

	.dt_hs_container a:hover {
		opacity: .7;
		-webkit-transition: all .3s;
		transition: all .3s;
		text-decoration: none
	}

	.dt_hs_container h1 p {
		display: inline-block;
		vertical-align: top;
		font-size: 0
	}

	.dt_hs_container div.each {
		font-size: 0;
		margin: 60px 0 0 0
	}

	.dt_hs_container div.each:nth-of-type(n+2) {
		margin: 90px 0 0 0
	}

	.dt_hs_container div.each h2 {
		text-align: left;
		width: 100%;
		padding: 25px 30px;
		box-sizing: border-box;
		background-color: #FDE9DD;
		position: relative
	}

	.dt_hs_container div.each h2 p.topic {
		font-size: 15px;
		font-weight: 700;
		color: #fff;
		background-color: #7e5448;
		border-radius: 13px;
		display: inline-block;
		vertical-align: top;
		padding: 3px 14px
	}

	.dt_hs_container div.each h2 p.mainTxt {
		font-size: 28px;
		font-weight: 700;
		line-height: 1.3;
		color: #7e5448;
		margin: 14px 0 0 0
	}
	.dt_hs_container div.each h2 p.mainTxt.no_topics{
		margin: 0;
	}
	.dt_hs_container div.each h2 ul {
		position: absolute;
		top: 24px;
		right: 20px
	}

	.dt_hs_container div.each h2 ul li {
		font-size: 12px;
		font-weight: 700;
		color: #fff;
		display: inline-block;
		vertical-align: top;
		padding: 3px 5px;
		letter-spacing: .1em
	}

	.dt_hs_container div.each h2 ul li.blue {
		background-color: #056085
	}

	.dt_hs_container div.each h2 ul li.red {
		background-color: #DA472C
	}

	.dt_hs_container div.each h2 ul li.gray {
		background-color: #6f7071
	}

	.dt_hs_container div.each p.lead {
		font-size: 23px;
		font-weight: 700;
		text-align: left;
		margin: 30px 0 40px 0;
		letter-spacing: -.02em
	}
	.dt_hs_container div.each p.lead.centering{
		text-align: center;
		color: #5f4138;
		font-size: 26px;
	}

	.dt_hs_container div.each.n6 div.unity.n3 p.lead {
		display: inline-block;
		vertical-align: top
	}

	.dt_hs_container div.each p.lead span {
		color: #e0355e
	}

	.dt_hs_container div.each p.lead span.emphasis {
		font-size: 40px;
		vertical-align: -3px
	}

	.dt_hs_container div.each div.unity {
		position: relative
	}

	.dt_hs_container.data1 div.each.n7 div.unity.n2, .dt_hs_container.data1 div.each.n7 div.unity.n3 {
		text-align: left
	}

	.dt_hs_container div.each div.unity.separate {
		width: 50%;
		display: inline-block;
		vertical-align: top
	}

	.dt_hs_container div.each.n6 div.unity:nth-of-type(n+2) {
		padding: 0;
		margin: 0;
		border: none
	}

	.dt_hs_container div.each.n6 div.unity.float {
		text-align: left
	}

	.dt_hs_container div.each div.unity p.obj {
		display: inline-block;
		vertical-align: top;
		position: absolute
	}

	.dt_hs_container div.each div.unity p.img {
		display: inline-block;
		vertical-align: top
	}
	.dt_hs_container div.each p.moreView {
		font-size: 15px;
		font-weight: 700;
		padding: 0 0 15px 0;
		margin: 48px auto 0 auto;
		color: #f3843a;
		display: inline-block;
		vertical-align: top;
		position: relative
	}

	.dt_hs_container div.each p.moreView:hover {
		opacity: .7;
		-webkit-transition: all .3s;
		transition: all .3s;
		cursor: pointer
	}

	.dt_hs_container div.each p.moreView::after {
		content: "";
		position: absolute;
		bottom: 0;
		right: 0;
		left: 0;
		margin: auto;
		vertical-align: middle;
		width: 5px;
		height: 5px;
		border-top: 2px solid #f3843a;
		border-left: 2px solid #f3843a;
		-webkit-transform: rotate(225deg);
		transform: rotate(225deg);
		-webkit-transition: all .3s;
		transition: all .3s
	}

	.dt_hs_container div.each p.detail {
		font-size: 14px;
		color: #221815;
		line-height: 2;
		font-weight: 700;
		text-align: left;
		margin: 24px 0 0 0;
		display: none
	}

	/* �ɲ�css
	-------------------------------------------------- */
	.intro{
		display: block;
		background: url(../images/hakusyo2021/intro.jpg) no-repeat center/100%;
		font-size: 0;
		padding-top: 25%;
		margin-top: 60px;
	}
	.intro.num2{
		background: url(../images/hakusyo2021/intro2.jpg) no-repeat center/100%;
		margin-top: 90px;
		padding-top: 30%;
	}
	.img_list{
		margin: 30px 0 40px 0;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		font-size: 14px;
		text-align: left;
		font-weight: bold;
	}
	.img_list li{
		width: 48%;
	}
	.img_list.col3 li{
		width: 33%;
	}
	.img_list li p{
		margin-bottom: 20px;
	}
	.graph_txt1 img{
		width: auto;
		height: 75px;
		margin-left: auto;
	}
	.graph_txt2 img{
		width: auto;
		height: 75px;
		margin-left: auto;
	}
	.graph_txt2{
		margin-bottom: 50px;
	}
	.dt_hs_container div.each .txt{
		font-size: 14px;
		text-align: left;
	}
	.dt_hs_container div.each.n7{
		background: #FBE0D2;
		border-radius: 30px;
		padding: 60px 60px;
		overflow: hidden;
	}
	.dt_hs_container div.each.n7 p.lead{
		font-size: 20px;
	}
	.dt_hs_container div.each.n7 p.lead span.emphasis{
		font-size: 32px;
	}
	.dt_hs_container div.each.n7 .img img{
		width: 400px;
		margin: 0 auto;
	}
	.detail_txt{
		font-size: 16px;
		font-weight: bold;
		text-align: left;
		line-height: 1.8;
		overflow: hidden;
	}
	.detail_txt p:nth-of-type(2){
		flex-shrink: 0;
		margin-left: 20px;
		width: 100px;
	}
}

@media screen and (max-width:768px) {
	.dt_hs_container {
		text-align: center;
		margin: 0 0 10vw 0
	}

	.dt_hs_container div.each {
		font-size: 0;
		margin: 15vw 0 0 0
	}

	.dt_hs_container div.each:nth-of-type(1) {
		margin: 0
	}

	.dt_hs_container div.each h2 {
		text-align: left;
		width: 100%;
		padding: 5vw 6vw;
		box-sizing: border-box;
		background-color: #FDE9DD;
		position: relative
	}

	.dt_hs_container div.each h2 p.topic {
		font-size: 3.2vw;
		font-weight: 700;
		color: #fff;
		background-color: #7e5448;
		border-radius: 3vw;
		display: inline-block;
		vertical-align: top;
		padding: .5vw 3vw
	}

	.dt_hs_container div.each h2 p.mainTxt {
		font-size: 4.6vw;
		font-weight: 700;
		line-height: 1.6;
		color: #7e5448;
		margin: 3vw 0 0 0
	}
	.dt_hs_container div.each h2 p.mainTxt.no_topics{
		margin: 0;
	}

	.dt_hs_container div.each h2 ul {
		position: absolute;
		top: 5vw;
		right: 3vw
	}

	.dt_hs_container div.each h2 ul li {
		font-size: 2.5vw;
		font-weight: 700;
		color: #fff;
		padding: .5vw 2vw;
		text-align: center
	}

	.dt_hs_container div.each h2 ul li.blue {
		background-color: #056085
	}

	.dt_hs_container div.each h2 ul li.red {
		background-color: #DA472C
	}

	.dt_hs_container div.each h2 ul li.gray {
		background-color: #6f7071
	}

	.dt_hs_container div.each h2 dd span {
		font-size: 3vw;
		font-weight: 700;
		display: inline-block;
		vertical-align: top;
		padding: 2vw 0 0 0
	}

	.dt_hs_container div.each p.lead {
		font-size: 4.2vw;
		font-weight: 700;
		text-align: left;
		margin: 6vw 0 10vw 0;
		position: relative
	}
	.dt_hs_container div.each p.lead.centering{
		width: 90%;
		font-size: 4.4vw;
		color: #5f4138;
		text-align: center;
		margin-left: auto;
		margin-right: auto;
	}
	.dt_hs_container.data1 div.each.n6 p.lead {
		margin: 6vw 0
	}

	.dt_hs_container div.each div.unity {
		width: 92vw;
		margin: 0 auto
	}

	.dt_hs_container.data1 div.each.n6 div.unity:nth-of-type(n+2) {
		margin-top: 15vw
	}

	.dt_hs_container div.each p.lead span {
		color: #e0355e
	}

	.dt_hs_container div.each p.lead span.emphasis {
		font-size: 6vw
	}

	.dt_hs_container div.each div.unity p.img {
		display: inline-block;
		vertical-align: top
	}

	.dt_hs_container div.each p.moreView {
		font-size: 3.6vw;
		font-weight: 700;
		padding: 0 0 3.6vw 0;
		margin: 8vw auto 0 auto;
		color: #f3843a;
		display: inline-block;
		vertical-align: top;
		position: relative
	}

	.dt_hs_container div.each p.moreView:hover {
		opacity: .7;
		-webkit-transition: all .3s;
		transition: all .3s;
		cursor: pointer
	}

	.dt_hs_container div.each p.moreView::after {
		content: "";
		position: absolute;
		bottom: 0;
		right: 0;
		left: 0;
		margin: auto;
		vertical-align: middle;
		width: 1vw;
		height: 1vw;
		border-top: 2px solid #f3843a;
		border-left: 2px solid #f3843a;
		-webkit-transform: rotate(225deg);
		transform: rotate(225deg);
		-webkit-transition: all .3s;
		transition: all .3s
	}

	.dt_hs_container div.each p.detail {
		font-size: 3.6vw;
		color: #221815;
		line-height: 2;
		font-weight: 700;
		text-align: left;
		margin: 4vw auto 0 auto;
		width: 92vw;
		display: none
	}

	.dt_hs_container div.each p.dlBtn {
		margin: 8vw 0 0 0
	}

	/* �ɲ�css
	-------------------------------------------------- */
	.intro{
		width: 90%;
		display: block;
		background: url(../images/hakusyo2021/intro_sp.jpg) no-repeat center/100%;
		font-size: 0;
		padding-top: 65%;
		margin: 50px auto 0;
	}
	.intro.num2{
		background: url(../images/hakusyo2021/intro2_sp.jpg) no-repeat center/100%;
		padding-top: 115%;
		margin-top: 60px;
	}
	.img_list{
		margin: 30px 0 0;
		display: block;
		justify-content: space-between;
		font-size: 14px;
		text-align: left;
		font-weight: bold;
	}
	.img_list li{
		width: 100%;
		margin-bottom: 40px;
	}
	.img_list li p{
		margin-bottom: 20px;
	}
	.img_list.sp_layout li:nth-child(1){
		padding-left: 12%;
		box-sizing: border-box;
	}
	.img_list.sp_layout li:nth-child(2){
		padding: 0 5%;
		box-sizing: border-box;
	}
	.dt_hs_container div.each.n7{
		background: #FBE0D2;
		border-radius: 20px;
		padding: 30px;
		overflow: hidden;
	}
	.graph_txt1 img{
		width: 45%;
		margin-left: auto;
	}
	.graph_txt2{
		margin-bottom: 50px;
	}
	.dt_hs_container div.each.n3 p.lead{
		margin-bottom: 0;
	}
	.dt_hs_container div.each.n7{
		width: 90%;
		box-sizing: border-box;
		margin: 40px auto 0;
	}
	.dt_hs_container div.each.n7 div.unity{
		width: 100%;
	}
	.dt_hs_container div.each.n7 p.lead{
		font-size: 4.2vw;
	}
	.dt_hs_container div.each.n7 p.lead span.emphasis{
		font-size: 5.2vw;
	}
	.detail_txt{
		font-size: 4vw;
		font-weight: bold;
		text-align: left;
		line-height: 1.8;
	}
	.detail_txt p:nth-of-type(2){
		margin: 20px auto 0;
		text-align: center;
		width: 80px;
	}
}
