@charset "utf-8";

#wrapper {
	overflow: hidden;
	width: 100%;
}

.img {
	width: 100%;
	margin: 30px auto 40px;
}

#area01 .comment {
	background-color: #EFEFEF;
	padding: 30px 50px;
	border-radius: 35px;
}

.comment p {
	font-size: 20px;
	font-weight: bold;
	text-align: left;
}

.question {
	color: #E5004B;
	font-size: 23px;
	font-weight: bold;
	margin-top: 40px;
	letter-spacing: 0.08em;
	text-indent: 0.08em;
}

#area02 .comment {
	background-color: #FDE9DD;
	padding: 50px;
	border-radius: 35px;
}

#area02 .comment .inner {
	background-color: #fff;
	padding: 50px;
	border-radius: 35px;
}

#area02 .comment p {
	text-align: center;
	line-height: 2;
	letter-spacing: 0.05em;
}

#area02 .comment .img {
	max-width: 40%;
	width: 100%;
}

#area02 .comment .kome {
	text-align: left;
	font-size: 15px;
	margin-top: 50px;
	line-height: 1.7;
}

.subtxt {
	color: #E5004B;
	background-color: #EFEFEF;
	padding: 30px;
	border-radius: 30px;
}

@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.n6 {
		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/hakusyo2022/intro.png) no-repeat center top/100%;
		font-size: 0;
		padding-top: calc(237/940*100%);
		margin-top: 60px;
	}

	.intro.num2 {
		background: url(../images/hakusyo2022/intro2.png) no-repeat center/contain;
		margin-top: 90px;
	}

	.intro p {
		font-size: 16px;
		margin-top: 40px;
		font-weight: bold;
		text-align: left;
		line-height: 1.7;
	}

	.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.n10 {
		background: #F3E0D5;
		border-radius: 30px;
		padding: 60px 60px;
		overflow: hidden;
	}

	.dt_hs_container div.each.n10 p.lead {
		font-size: 20px;
	}

	.dt_hs_container div.each.n10 p.lead span.emphasis {
		font-size: 32px;
	}

	.dt_hs_container div.each.n10 .img {
		margin: 30px auto 0;
	}

	.dt_hs_container div.each.n10 .img img {
		width: 300px;
		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: #F3E0D5;
		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;
		margin: 20px 0;
	}

	.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/hakusyo2022/intro_sp.png) no-repeat center top/100%;
		font-size: 0;
		padding-top: 65%;
		margin: 50px auto 0;
	}

	.intro.num2 {
		background: url(../images/hakusyo2022/intro2.png) no-repeat center/50%;
		padding-top: 50%;
	}

	.intro p {
		font-size: 16px;
		margin-top: 40px;
		font-weight: bold;
		text-align: left;
		line-height: 1.7;
	}

	.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.n10 {
		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.n10 {
		width: 90%;
		box-sizing: border-box;
		margin: 40px auto 0;
	}

	.dt_hs_container div.each.n10 div.unity {
		width: 100%;
	}

	.dt_hs_container div.each.n10 p.lead {
		font-size: 4.2vw;
	}

	.dt_hs_container div.each.n10 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;
	}

	#area01 .comment {
		margin: 20px;
		padding: 30px;
		border-radius: 30px;
	}

	.comment p {
		font-size: 4.2vw;
	}

	.question {
		font-size: 4.5vw;
		margin: 20px 20px 0;
	}

	.question br {
		display: none;
	}

	#area02 .comment {
		padding: 25px;
		border-radius: 30px;
		margin: 20px;
	}

	#area02 .comment .inner {
		padding: 30px 25px;
		border-radius: 20px;
	}

	#area02 .comment p {
		text-align: left;
		line-height: 1.7;
		margin: 0;
	}

	#area02 .comment .img {
		max-width: 50%;
		margin: 0 auto 20px;
	}
}