@charset "UTF-8";
/* CSS Document */

/************************************************
small-sofa.css 202207
************************************************ */
#small-sofa{
	width: 1000px;
	line-height: 1.4;
	margin: 0 auto;
}
#small-sofa a{
	text-decoration: none;
	color: #333;
}
#small-sofa a:hover{
	opacity: 0.7;
}
#small-sofa img{
	max-width: 100%;
}
#small-sofa .intro{
	position: relative;
	margin: 0 auto 50px;
}
#small-sofa .intro p{
	width: 96%;
	/*font-family: 'Noto Sans JP', sans-serif;*/
	font-size: 15px;
	line-height: 1.8;
	text-align: center;
	margin: 50px auto;
}
#small-sofa h2 img{
	width: 100%;
}
#small-sofa .h2-box{
	position: relative;
}
#small-sofa h2.txt{
	position: absolute;
	left: 0;
	bottom: 10px;
	font-family: 'Kaisei Opti', serif;
	line-height: 1.3;
}
#small-sofa h2 .txt1{
	display: block;
	font-size: 35px;
}
#small-sofa h2 .txt2{
	font-size: 52px;
}
.topics{
	width: 900px;
	border-top: 1px solid #666;
	border-bottom: 1px solid #666;
	padding: 30px 20px;
	margin: 0 auto 80px;
	text-align: center;
	display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	align-items: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
}
.topics p{
	position: relative;
	font-size: 40px;
	font-weight: 400;
	font-family: 'Outfit', sans-serif;
	line-height: 1.0;
	color: #666;
	width: 30%;
}
.topics p:after{
	content: "";
	position: relative;
	top: -10px;
	display: inline-block;
	padding: 0 .6em;
	background: #999;
	height: 1px;
	transform: rotate(-60deg);
}

#small-sofa .topics ul{
	padding: 0;
	margin: 0 auto;
	text-align: left;
	width: 68%;
}
#small-sofa .topics li{
	font-size: 20px;
	font-weight: 500;
	margin: 0 auto 3px;
}
#small-sofa .topics li:last-child{
	margin: 0 auto;
}
#small-sofa .topics li:before{
	content: "〇";
	position: relative;
	top: 1px;
	margin-right: .3em;
}

#small-sofa h3{
	padding: 100px 0 0;
	margin: -80px auto 40px;
	border: none;
	font-size: 24px;
	font-weight: 400;
	letter-spacing: .05em;
	text-align: center;
	/*background: #f0f0f0;*/
}

.section-box{
	width: 100%;
	margin: 0 auto 50px;
}
.section-box:last-child{
	margin: 0 auto 20px;
}
.lead-txt{
	margin: 0 auto 50px;
}
.lead-txt p{
	font-size: 15px;
	line-height: 1.6;
}
.feature-box{
	padding: 20px 15px;
	margin: 0 auto;
	border-top: 1px solid #666;
	display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	align-items: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
}
.feature-box:last-child{
	border-bottom: 1px solid #666;
}
.feature-box p.ttl{
	position: relative;
	width: 31%;
	font-size: 16px;
	letter-spacing: .08em;
	line-height: 1.3;
	margin: 0;
}
.feature-box p.ttl span.en{
	position: relative;
	font-size: 30px;
	font-family: 'Outfit', sans-serif;
	color: #666;
}
.feature-box p.ttl span.jp{
	position: relative;
	top: -.2em;
	font-size: 16px;
	text-indent: 2em;
}
.feature-box p.ttl span.en:after{
	content: "";
	position: relative;
	top: -8px;
	display: inline-block;
	padding: 0 .5em;
	background: #999;
	height: 1px;
	transform: rotate(-60deg);
}
.feature-box p.txt{
	width: 65%;
	font-size: 14px;
	margin: 0;
}

.recom-box{
	display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding: 50px 0;
	margin: 0 auto;
	border-top: 1px solid #666;
}

.recom-box:last-child{
	border-bottom: 1px solid #666;
}
.recom-box .item{
	width: 48%;
	margin: 0 auto 30px;
}
.recom-box.item-img{

}
.recom-box .item-txt-box{
	display: flex;
	display: -webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 30px 0 0;
}
.recom-box .item-txt{
	width: 60%;
}
.recom-box .item-txt .ttl{
	font-size: 16px;
	margin: 0 0 20px;
}
.recom-box .item-txt .txt{
	font-size: 13px;
	line-height: 1.5;
}
.recom-box .item-txt-img{
	width: 38%;
}

.check{
  position: relative;
  z-index: 1;
}
.check span{
	background: linear-gradient(to right, #f0f0f0 50%, transparent 50%) 100% bottom no-repeat;
  background-size: 200% 100%;
  transition: all 0.8s;
	padding: .2em .4em;
}
.checked span{
  background-position: 0% bottom;
}

h3.check span{
	padding: .3em 1em;
}

.footer-txt{
	padding: 20px;
	margin: 0 auto 50px;
	background: #f0f0f0;
}
.footer-txt p{
	font-size: 14px;
	line-height: 1.6;
}

@media screen and (max-width: 896px){
	#small-sofa{
		width: 100%;
	}
	#small-sofa h2.txt{
		position: absolute;
		left: 0.5em;
		bottom: 1vw;
	}
	#small-sofa h2 .txt1{
		font-size: 3vw;
	}
	#small-sofa h2 .txt2{
		font-size: 4.5vw;
	}
	#small-sofa .intro{
		width: 92%;
		text-align: left;
		margin: 40px auto;
	}
	#small-sofa .intro p{
		width: 100%;
		font-size: 13px;
		line-height: 1.6;
		margin: 0 auto;
		text-align: left;
	}
	#small-sofa .intro p br{
		display: none;
	}
	
	#small-sofa .topics{
		width: 100%;
		padding: 20px 3%;
		margin: 0 auto 60px;
	}
	#small-sofa .topics p{
		font-size: 36px;
	}
	#small-sofa .topics li{
		font-size: 15px;
		line-height: 1.6;
	}

	#small-sofa h3{
		width: 100%;
		padding: 60px 0 0;
		margin: -40px auto 0;
		font-size: 18px;
	}

	.section-box{
		width: 100%;
		padding: 0;
		margin: 0 auto 40px;
	}
	.section-box:last-child{
		margin: 0 auto 20px;
	}
	.lead-txt{
		margin: 0 auto 40px;
	}
	.lead-txt p{
		font-size: 13px;
	}
	.feature-box{
		padding: 20px 4%;
	}
	.feature-box p.ttl{
		position: relative;
		width: 38%;
		font-size: 15px;
		letter-spacing: .05em;
	}
	.feature-box p.ttl span.en{
		font-size: 26px;
	}
	.feature-box p.ttl span.jp{
		font-size: 14px;
		text-indent: 2em;
	}
	.feature-box p.txt{
		width: 60%;
		font-size: 13px;
		margin: 0;
	}
	.section-box h4 {
    width: 12%;
	}
	.section-box h4 span.en{
		font-size: 24px;
		margin: 0;
	}
	.section-box h4 span.jp{
		display: block;
		font-size: 13px;
		margin: 20px 0 0;
	}
	
	.recom-box{
		padding: 30px 0;
	}
	.recom-box .item{
		padding: 0;
		margin: 0 auto 20px;
	}
	.recom-box .item-txt-box{
		margin: 20px auto 0;
	}
	.recom-box .item-txt{
	}
	.recom-box .item-txt .ttl{
		font-size: 15px;
		margin: 0 0 10px;
	}
	.recom-box .item-txt .txt{
		font-size: 13px;
	}
	.check span{
		display: inline-block;
		padding: .4em .5em;
	}
	h3.check span{
		display: block;
		padding: .6em .5em;
	}
	
	.footer-txt{
		width: 96%;
		padding: 15px;
		margin: 0 auto 20px;
	}
	.footer-txt p{
		font-size: 13px;
		line-height: 1.6;
	}
	.pagetop-anc{
		width: 96%;
	}
}

@media screen and (max-width: 568px){
	#small-sofa h2.txt{
		position: absolute;
		left: 0.4em;
		bottom: 4vw;
		line-height: 1.2;
	}
	#small-sofa h2 .txt1{
		font-size: 3.6vw;
	}
	#small-sofa h2 .txt2{
		font-size: 6vw;
	}
	#small-sofa h3{
		font-size: 4.5vw;
		letter-spacing: .03em;
		margin: 0 auto 25px
	}
	#small-sofa .intro{
		margin: 20px auto;
	}
	#small-sofa .intro p{
		font-size: 3.4vw;
	}
	#small-sofa .topics{
		margin: 0 auto 50px;
	}
	#small-sofa .topics p{
		width: 100%;
		font-size: 7.2vw;
		text-align: left;
		margin: 0 0 10px;
	}
	#small-sofa .topics ul{
		width: 100%;
	}
	#small-sofa .topics li{
		font-size: 3.5vw;
		margin: 0;
	}

	#small-sofa h3{
		padding: 60px 0 0;
		margin: -60px auto 0;
		font-size: 4.0vw;
	}

	.section-box{
		width: 100%;
		margin: 0 auto 40px;
	}
	.section-box:last-child{
		margin: 0 auto;
	}
	.lead-txt{
		margin: 0 auto 30px;
	}
	.lead-txt p{
		font-size: 3.2vw;
		line-height: 1.6;
	}
	.feature-box{
		padding: 20px 3%;
	}
	.feature-box p.ttl{
		position: relative;
		width: 100%;
		font-size: 3.4vw;
		letter-spacing: .05em;
		margin-bottom: 10px;
	}
	.feature-box p.ttl span.en{
		display: inline-block;
		font-size: 6.5vw;
	}
	.feature-box p.ttl span.jp{
		font-size: 3.4vw;
	}
	.feature-box p.txt{
		width: 100%;
		font-size: 3.2vw;
		line-height: 1.6;
		margin: 0;
	}
	.section-box h4 {
    width: 96%;
	}
	.section-box h4 br{
    display: none;
	}
	.section-box h4 span.en{
		display: inline-block;
		font-size: 6.5vw;
		margin: 0;
	}
	.section-box h4 span.jp{
		display: inline-block;
		font-size: 3.4vw;
		margin: 0;
	}
	.recom-box{
		padding: 0;
	}
	.recom-box .item{
		width: 100%;
		margin: 0 auto 20px;
	}
	.recom-box .item-txt-box{
		width: 92%;
	}
	.recom-box .item-txt {
 	 	width: 60%;
	}
	.recom-box .item-txt .ttl{
		font-size: 3.4vw;
		margin: 0 0 10px;
	}
	.recom-box .item-txt .txt{
		font-size: 3.2vw;
	}

	.footer-txt p{
		font-size: 3.4vw;
		line-height: 1.6;
	}
}