@charset "utf-8";

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

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

.recommend {
	background-color: #fff;
	padding: 30px 50px;
	border-radius: 35px;
	border: 4px solid #FDE9DD;
	text-align: left;
	font-size: 18px;
	margin-top: 50px;
	font-weight: bold;
}

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

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

.comment .comment_title {
	font-size: 32px;
	font-weight: bold;
}

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

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

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

.comment p.txt_pink {
	color: #EB6BA4;
	font-size: 24px;
}

.comment .img.ranko {
	max-width: 70%;
	width: 100%;
}

.comment .img.movie {
	max-width: 30%;
	width: 100%;
}

.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;
}

.lead_under{
	font-size: 28px;
        font-weight: 700;
        text-align: left;
        margin: 30px 0 40px 0;
}
.lead_under_center{
	font-size: 28px;
        font-weight: 700;
        text-align: center;
        margin: 30px 0 40px 0;
}
.lead_under span,.lead_under_center span{
		border-bottom: 4px solid #e5004a;
}
.kome_t{
	font-size: 10px;
	vertical-align: top;
}
.kome_m{
	font-size: 11px;
	color: #000;
	text-align: right;
	margin-top: 10px;
}

/* .recommend_wrap */

.recommend_wrap{
	border: 3px solid #a9a8d3;
	border-radius: 20px;
	position: relative;
	margin-bottom: 70px;
}
.reco_ttl{
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	background-color: #a9a8d3;
	padding: 20px;
	border-radius: 13px 13px 0 0;
}
.reco_ttl span{
	font-size: 28px;
}
.reco_type{
	position: absolute;
	max-width: 180px;
    width: 100%;
    top: -50px;
    right: 20px;
}
.reco_catch{
	font-size: 24px;
	text-align: left;
	font-weight: 500;
	margin: 30px 0;
	padding-left: 30px;
}
.feature{
	margin: 0 20px 30px;
	border-radius: 15px;
	background-color: #bec5e4;
	padding: 20px;
}
.fea_ttl{
	text-align: left;
	margin-bottom: 20px;
}
.fea_ttl span{
	padding: 10px 30px;
	border-radius: 100vmax;
	background-color: #edebec;
	font-size: 18px;
	font-weight: 700;
}
.feature ul li{
	font-size: 18px;
	text-align: left;
	font-weight: 700;
	padding-left: 1em;
	text-indent: -1em;
}
.feature ul li::before{
	content: '●';
}
.fea_ttl_red span{
	padding: 10px 30px;
	border-radius: 100vmax;
	background-color: #e5004a;
	font-size: 18px;
	font-weight: 700;
	color: #fff;
}
.recommend_wrap.gr{
	border: 3px solid #b2dab8;
}
.recommend_wrap.gr .reco_ttl{
	background-color: #b2dab8;
}
.recommend_wrap.gr .feature{
	background-color: #daeddc;
}
.recommend_wrap.pi{
	border: 3px solid #f4aebd;
}
.recommend_wrap.pi .reco_ttl{
	background-color: #f4aebd;
}
.recommend_wrap.pi .feature{
	background-color: #fad9df;
}
.recommend_wrap.yel{
	border: 3px solid #fed844;
}
.recommend_wrap.yel .reco_ttl{
	background-color: #fed844;
}
.recommend_wrap.yel .feature{
	background-color: #feebad;
}
.recommend_wrap.bl{
	border: 3px solid #b0def1;
}
.recommend_wrap.bl .reco_ttl{
	background-color: #b0def1;
}
.recommend_wrap.bl .feature{
	background-color: #dbf0f9;
}
.recommend_wrap.chart{
	border: 3px solid #d5c9c2;
	background-color: #fcefd9;
}
.recommend_wrap.chart .reco_ttl{
	background-color: #d5c9c2;
}
.recommend_wrap.chart .lead,.recommend_wrap.chart .img_chart{
	padding: 0 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: #fcefd9;
		position: relative
	}

	.dt_hs_container div.each h2 p.topic {
		font-size: 15px;
		font-weight: 700;
		color: #fff;
		background-color: #8d5f52;
		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: #8d5f52;
		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;
		margin-bottom: 3px;
	}

	.dt_hs_container div.each h2 ul li.blue {
		background-color: #33bbce;
	}
	.dt_hs_container div.each h2 ul li.blue02 {
		background-color: #3f7ec1;
	}

	.dt_hs_container div.each h2 ul li.orange {
		background-color: #ed6d00;
	}

	.dt_hs_container div.each h2 ul li.green {
		background-color: #65b95d;
	}

	.dt_hs_container div.each h2 ul li.purple {
		background-color: #b96eaa;
	}

	.dt_hs_container div.each h2 ul li.pink {
		background-color: #ec6d79;
	}
	.dt_hs_container div.each h2 ul li.gray {
		background-color: #bcb6ba;
	}
	.dt_hs_container div.each h2 ul li.gray02 {
		background-color: #a1967e;
	}
	
	.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/hakusyo2024/intro.png) no-repeat center top/100%;
		font-size: 0;
		padding-top: calc(237/940*100%);
		margin-top: 60px;
	}

	.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: #fcf1dc;
		border-radius: 30px;
		padding: 60px 60px;
		overflow: hidden;
		margin-bottom: 50px;
	}

	.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: 200px;
		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 h2 {
		text-align: left;
		width: 100%;
		padding: 5vw 6vw;
		box-sizing: border-box;
		background-color: #fcefd9;
		position: relative
	}

	.dt_hs_container div.each.n2 h2 {
		padding: 20vw 6vw 5vw;
	}

	.dt_hs_container div.each h2 p.topic {
		font-size: 3.2vw;
		font-weight: 700;
		color: #fff;
		background-color: #8d5f52;
		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: #8d5f52;
		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;
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		justify-content: flex-end;
	}

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

	.dt_hs_container div.each.n2 h2 ul li {
		display: flex;
		align-items: center;
	}

	.dt_hs_container div.each.n2 h2 ul li.hit {
		height: 1.5em;
	}

	.dt_hs_container div.each h2 ul li.blue {
		background-color: #33bbce;
	}
	.dt_hs_container div.each h2 ul li.blue02 {
		background-color: #3f7ec1;
	}

	.dt_hs_container div.each h2 ul li.orange {
		background-color: #ed6d00;
	}

	.dt_hs_container div.each h2 ul li.green {
		background-color: #65b95d;
	}

	.dt_hs_container div.each h2 ul li.purple {
		background-color: #b96eaa;
	}

	.dt_hs_container div.each h2 ul li.pink {
		background-color: #ec6d79;
	}
	.dt_hs_container div.each h2 ul li.gray {
		background-color: #bcb6ba;
	}
	.dt_hs_container div.each h2 ul li.gray02 {
		background-color: #a1967e;
	}

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

	.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: #fcf1dc;
		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;
	}

	.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;
	}

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

	.comment .inner {
		padding: 30px 15px;
		border-radius: 20px;
	}

	.comment p {
		line-height: 1.7;
		margin: 0;
	}

	.comment p.txt_pink {
		color: #EB6BA4;
		font-size: 21px;
		line-height: 1.4;
		margin-bottom: 20px;
	}

	.comment .comment_title {
		font-size: 28px;
		text-align: center;
		line-height: 1.2;
		margin-top: 20px;
	}

	.comment .img {
		max-width: 100%;
		margin: 20px auto;
	}

	.recommend {
		width: 90%;
		box-sizing: border-box;
		margin: 40px auto;
		padding: 30px;
	}

	.comment .img.movie {
		max-width: 80%;
		width: 100%;
	}

	.lead_under{
		font-size: 22px;
	}
	.lead_under_center{
		font-size: 22px;
			text-align:left;
			padding: 0 10px;
	}
	/* .recommend_wrap */
	.reco_ttl{
		font-size: 18px;
		padding: 10px;
	}
	.reco_ttl span{
		font-size: 22px;
	}
	.reco_type{
		display: none;
	}
	.reco_catch{
		font-size: 18px;
		padding-left: 10px;
	}
}