@charset "utf-8";

/*　769px以上の対応
////////////////////////////////////////////////////*/
@media screen and (min-width:769px) {

#features #wrap{
	width: 100%;
	min-width: 980px;
	margin: 0 auto;
	letter-spacing: 0.06em;
}
#features #wrap #contents{
	width: 100%;
	margin: 0 auto;
}
#features #wrap #contents picture{
	display: block;
}
/* ファーストビューエリア */
.underlayer--firstview__wrap{
	width: 100%;
	min-width: 980px;
	margin: 0 auto 40px;
	background: #F9F1F1;
	padding: 32px 0;
}
.underlayer--firstview__inr{
	width: 980px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
.underlayer--firstview__ttl h1{
	font-size: 38px;
	color: #EA0029;
	letter-spacing: 0.03em;
	margin-bottom: 18px;
}
.underlayer--firstview__ttl h1 span{
	font-size: 16px;
	letter-spacing: 0.06em;
	display: block;
	margin-bottom: 8px;
}
.underlayer--firstview__lead{
	font-size: 14px;
	line-height: 1.86;
	letter-spacing: 0.05em;
	font-weight: 500;
}
.underlayer--firstview__image{
	margin-bottom: 12px;
	position: relative;
}
.underlayer--firstview__image::before{
	content: "資料配布中";
	font-size: 13px;
	letter-spacing: 0.04em;
	text-align: center;
	color: #fff;
	line-height: 78px;
	background: #EA0029;
	border-radius: 50px;
	width: 78px;
	height: 78px;
	position: absolute;
	top: -20px;
	right: -34px;
}
.underlayer--firstview__btn {
	text-align: center;
}
.underlayer--firstview__btn p{
	margin-bottom: 10px;
	font-weight: 500;
	letter-spacing: 0;
}
.underlayer--firstview__btn a{
	display: inline-block;
	letter-spacing: 0;
	color: #fff;
	font-weight: 700;
	background: #185ABC;
	border-radius: 4px;
	padding: 16px 40px;
	position: relative;
	transition: 0.3s;
}
.underlayer--firstview__btn a:hover{
	background-image: linear-gradient(to right, #185ABC, #0c3169);
}
.underlayer--firstview__btn a::before{
	content: "";
	background: url("../../case-studies/img/fv-document-dl-icon.svg");
	width: 18px;
	height: 18px;
	position: absolute;
	top: 14px;
	right: 12px;
}


/* このようなお悩みありませんか？ */
.worries{
	margin-bottom: 60px;
}
#worries h2{
	font-size: 24px;
	font-weight: 500;
	line-height: 1.6;
	text-align: center;
	letter-spacing: .18em;
	margin-bottom: 48px;
}
#worries h2 span{
	font-size: 32px;
	font-weight: 500;
	letter-spacing: .18em;
	padding: 0 0 0 0.2em;
	margin: 0 0.2em;
	border-bottom: 3px solid #EA0029;
}
#worries .worries__inr{
	width: 910px;
	margin: 0 auto 64px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
#worries .worries__left{
	width: 240px;
	border-radius: 10px;
	box-sizing: border-box;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
	text-align: center;
	padding: 40px 0 32px 0;
	position: relative;
}
#worries .worries__left::before{
	content: "";
	background: url("../../features/img/plus.svg");
	width: 48px;
	height: 48px;
	position: absolute;
	top: 274px;
    right: -80px;
}
#worries .worries__left h3{
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 24px;
}
#worries .worries__left div{
	margin-bottom: 24px;
}
#worries .worries__left div:last-child{
	margin-bottom: 0;
}
#worries .worries__left div > div{
	margin-bottom: 8px;
}
#worries .worries__left .worries__no1 figure,
#worries .worries__left .worries__no2 figure,
#worries .worries__left .worries__no3 figure{
	width: 140px;
	height: 128px;
	margin: 0 auto;
}
#worries .worries__left div p{
	font-size: 16px;
	letter-spacing: 0.08em;
}
#worries .worries__right{
	width: 560px;
}
#worries .worries__right h3{
	font-size: 20px;
	letter-spacing: 0.1em;
	line-height: 1.5;
	font-weight: 500;
	margin-bottom: 16px;
}
#worries .worries__right h3 span{
	display: block;
	font-size: 28px;
	font-weight: 700;
	color: #EA0029;
	letter-spacing: 0.08em;
}
#worries .worries__right .worries__right-inr{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 16px;
	margin-bottom: 24px;
}
#worries .worries__right .worries__right-inr div{
	width: 272px;
	border-radius: 10px;
	padding: 16px 8px 16px 16px;
	box-sizing: border-box;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
}
#worries .worries__right .worries__right-inr div .worries__right-introduction{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .06em;
	margin-bottom: 5px;
}
#worries .worries__right .worries__right-inr div .worries__right-answer{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .06em;
	font-weight: 500;
	color: #EA0029;
}
#worries .worries__right-lead{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .1em;
}
#worries .worries__right-lead.worries__lead-message{
	font-weight: 500;
	margin-bottom: 16px;
	letter-spacing: .06em;
	line-height: 1.7;
	font-size: 20px;
}
#worries .worries__right-lead.worries__lead-message .marker{
	background: linear-gradient(transparent 70%, #ffee93 70%);
}
/* イグレックのセルフオーダーが課題を解決できる理由 */
#solve {
	width: 980px;
	margin: 0 auto;
}
#solve h2{
	font-size: 32px;
	line-height: 1.7;
	color: #EA0029;
	letter-spacing: .14em;
	text-align: center;
	margin-bottom: 48px;
}
.solve__point01,
.solve__point02,
.solve__point03{
	margin-bottom: 56px;
}
#solve__inr{
	width: 910px;
	margin: 0 auto 64px;
}
.solve__point01 .solve__pont-inr,
.solve__point02 .solve__pont-inr{
	margin-bottom: 8px;
}
.solve__pont-inr{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.solve__left{
	width: 460px;
	text-align: center;
}
.solve__point01 .solve__pont-inr picture{
	width: 458px;
	height: 350px;
	margin: 0 auto;
}
.solve__point02 .solve__pont-inr picture{
	width: 436px;
	height: 316px;
	margin: 0 auto;
}
.solve__point03 .solve__pont-inr picture{
	width:353px;
	height: 264px;
	margin: 0 auto;
}
.solve__right{
	width: 460px;
}
#solve .solve__right h3{
	font-size: 32px;
	font-weight: 400;
	line-height: 1.4;
	margin-bottom: 16px;
	letter-spacing: .08em;
}
#solve .solve__right h3 span{
	font-size: 62px;
}
#solve .solve__right h3 sup{
	font-size: 12px;
	vertical-align: super;
}
#solve .solve__right p{
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 26px;
}
#solve .solve__right a{
	font-size: 16px;
	font-weight: 700;
	color: #EA0029;
	border-bottom: 1px solid #EA0029;
	position: relative;
}
#solve .solve__right a::before{
	content: "";
	background: url("../../features/img/features-arrow.svg");
	width: 20px;
	height: 20px;
	position: absolute;
	top: 3px;
    right: -26px;
}
#solve .solve__right a:hover{
	border-bottom: none;
}
#solve .attention{
	font-size: 14px;
	line-height: 1.5;
	padding-left: -1em;
	margin-left: 1em;
	position: relative;
}
#solve .attention::before{
	content: "※";
	position: absolute;
	top: 0;
	left: -1em;
	font-size: 14px;
}
.solve--bnr-btn{
	width: 485px;
	height: 94px;
	margin: 0 auto 60px;
}
.solve--bnr-btn a{
	box-shadow: 0px 8px 6px -3px #c8c8c8;
    transition: .3s;
	display: block;
	overflow: hidden;
	border-radius: 5px;
}
.solve--bnr-btn a:hover{
	box-shadow: none;
}
.solve--bnr-btn a img{
	vertical-align: top;
}




/* 導入店舗数は2,300店舗以上、店舗規模を問わずご利用いただけます */
#use {
	width: 980px;
	margin: 0 auto;
}
#use h2{
	font-size: 32px;
	line-height: 1.7;
	color: #EA0029;
	letter-spacing: .14em;
	text-align: center;
	margin-bottom: 48px;
}
#use__inr{
	width: 980px;
	margin: 0 auto;
}
.use-shop-list{
	width: 980px;
	height: 720px;
	margin-bottom: 40px;
}
.use__interview{
	text-align: center;
	font-size: 24px;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1.7;
	margin-bottom: 40px;
}
.use-shop-logo{
	width: 980px;
	height: 494px;
	margin-bottom: 40px;
}
.use__schedule{
	text-align: center;
	font-size: 24px;
	font-weight: 400;
	letter-spacing: 0.1em;
	margin-bottom: 40px;
}
.use__schedule span{
	font-size: 32px;
	font-weight: 400;
	border-bottom: 6px solid #EA0029;
}
.use__schedule span span{
	font-size: 52px;
	font-weight: 400;
	border-bottom: 0;
	padding: 0 .13em;
}
.use__message{
	text-align: center;
}
.use__message p{
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 12px;
	letter-spacing: .1em;
}
.use__message p.use__message-attention{
	font-size: 14px;
}
#use .use--btn {
	text-align: center;
	margin-bottom: 40px;
}
#use .use--btn a{
	font-size: 16px;
	font-weight: 700;
	color: #EA0029;
	border-bottom: 1px solid #EA0029;
	position: relative;
}
#use .use--btn a::before{
	content: "";
	background: url("../../features/img/features-arrow.svg");
	width: 20px;
	height: 20px;
	position: absolute;
	top: 3px;
    right: -26px;
}
#use .use--btn a:hover{
	border: none;
}
.use--bnr-btn{
	width: 485px;
	height: 94px;
	margin: 0 auto 60px;
}
.use--bnr-btn a{
	box-shadow: 0px 8px 6px -3px #c8c8c8;
    transition: .3s;
	display: block;
	overflow: hidden;
	border-radius: 5px;
}
.use--bnr-btn a:hover{
	box-shadow: none;
}
.use--bnr-btn a img{
	vertical-align: top;
}




/* 課題を解決するシステム構成 */
#system {
	width: 100%;
	background: #FFF9EB;
	padding: 60px 0;
}
#system h2{
	font-size: 32px;
	line-height: 1.7;
	color: #EA0029;
	letter-spacing: .14em;
	text-align: center;
	margin-bottom: 48px;
}
.system__inr{
	width: 862px;
	margin: 0 auto;
}
.system__composition01,
.system__composition02,
.system__composition03{
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
    align-items: flex-end;
}
.system__composition01,
.system__composition02{
	margin-bottom: 32px;
}
.system__composition02{
	flex-direction: row-reverse;
}
.system__txt{
	width: 440px;
}
.system__txt h3{
	font-size: 32px;
	font-weight: 400;
	line-height: 1.75;
	letter-spacing: 0.08em;
	margin-bottom: 16px;
}
.system__txt h3 span{
	font-size: 62px;
	line-height: 1;
}
.system__point h4{
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .1em;
	margin-bottom: 16px;
	margin-left: 2em;
	position: relative;
}
.system__point h4::before{
	content: "";
	width: 20px;
	height: 20px;
	border: 2px solid #000;
	box-sizing: border-box;
	position: absolute;
	top: -2px;
	left: -30px;
	font-size: 24px;
	border-radius: 20px;
}
.system__point ul li{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: .1em;
	position: relative;
	margin-bottom: 8px;
	margin-left: 2em;
}
.system__point ul li.system__point01::before{
	content: "1.";
	position: absolute;
	top: -8px;
	left: -30px;
	font-size: 24px;
}
.system__point ul li.system__point02::before{
	content: "2.";
	position: absolute;
	top: -8px;
	left: -30px;
	font-size: 24px;
}
.system__point ul li.system__point03::before{
	content: "3.";
	position: absolute;
	top: -8px;
	left: -30px;
	font-size: 24px;
}
.system__point ul li span{
	color: #EA0029;
}
.system__function{
	width: 380px;
	height: 353px;
	position: relative;
	margin-bottom: 10px;
}
.system__function h3{
	font-size: 16px;
	font-weight: 500;
	border-bottom: 2px solid #000;
	transform: rotate(90deg);
	display: inline-block;
	position: absolute;
	top: 65px;
	left: -20px;
	line-height: 1.5;
}
.system__function ul{
	position: relative;
}
.system__function01,
.system__function02,
.system__function03{
	width: 210px;
	height: 210px;
	position: relative;
	text-align: center;
}
.system__function01{
	position: absolute;
	top: 0;
	left: 85px;
}
.system__function02{
	position: absolute;
	top: 143px;
	left: 0;
}
.system__function03{
	position: absolute;
	top: 143px;
	left: 166px;
}
.system__function01 div,
.system__function02 div,
.system__function03 div{
	font-size: 26px;
	font-weight: 400;
	line-height: 1.3;
	letter-spacing: 0;
	color: #fff;
	position: absolute;
	width: 100%;
	top:50%;
	left:50%;
	transform: translateX(-50%) translateY(-50%);
	z-index: 2;
}



/* よくある質問 */
#faq {
	width: 100%;
	padding: 60px 0;
}
#faq h2{
	font-size: 32px;
	line-height: 1.7;
	color: #EA0029;
	letter-spacing: .14em;
	text-align: center;
	margin-bottom: 48px;
}
.faq__inr{
	width: 768px;
	margin: 0 auto;
}
.faq__inr ul li {
	margin-bottom: 16px;
	border-radius: 18px;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
}
.faq__inr ul li div dl dt{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	color: #fff;
	background: #EA0029;
	position: relative;
	padding: 32px 50px 28px 50px;
	border-radius: 18px 18px 0 0;
}
.faq__inr ul li div dl dt::before{
	content: "Q.";
	font-size: 20px;
	color: #fff;
	position: absolute;
	top: 28px;
	left: 20px;
}
.faq__inr ul li div dl dd{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	position: relative;
	padding: 32px 50px 28px 50px;
}
.faq__inr ul li div dl dd::before{
	content: "A.";
	font-size: 20px;
	position: absolute;
	top: 28px;
	left: 20px;
}
.faq__inr ul li div dl dd a{
	color: #EA0029;
	border-bottom: 1px solid #EA0029;
}
.faq__inr ul li div dl dd a:hover{
	border: none;
}

/* お問い合わせ */
#contact {
	width: 100%;
	padding: 0 0 60px 0;
}
#contact h2{
	font-size: 32px;
	line-height: 1.7;
	color: #EA0029;
	letter-spacing: .14em;
	text-align: center;
	margin-bottom: 48px;
}
.contact__inr{
	width: 480px;
	margin: 0 auto;
}

.form__section{
	margin-bottom: 24px;
}
.form__title {
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 8px;
}
.form__box input {
	font-size: 16px;
	width: 100%;
	height: 50px;
	padding: 5px 10px;
	border-radius: 5px;
	box-sizing: border-box;
	border: 1px solid #ddd;
}
.form__box.form__box-choice label,
.form__entry-check label {
	cursor: pointer;
	width: 100%;
	box-sizing: border-box;
	border-radius: 5px;
	height: 50px;
	display: block;
	line-height: 50px;
	padding-left: 12px;
	border: 1px solid #ddd;
}
.form__box.form__box-choice label:hover,
.form__entry-check label:hover {
	background: #d7d7d7;
}
.form__box.form__box-choice label input {
	font-size: 16px;
	width: 16px;
	height: 16px;
	padding: 0;
	border-radius: 5px;
	box-sizing: border-box;
	border: 1px solid #ddd;
	margin-top: -4px;
	margin-right: 8px;
}
.form__box div{
	font-size: 16px;
}
.form__box div + div{
	margin-top: 8px;
}
.form__entry{
	font-size: 16px;
	line-height: 1.6;
}
.form__entry-text{
	margin-bottom: 8px;
}
.form__entry-text a{
	border-bottom: 1px solid #EA0029;
	color: #EA0029;
}
.form__entry-text a:hover{
	border: none;
}
.form__entry-btn input{
	background: #1870bc;
	width: 100%;
	padding: 20px 0;
	color: #fff;
	border: none;
	font-size: 16px;
	border-radius: 6px;
}
.form__entry-btn input:hover{
	background: #0c3169;
}
input[type="checkbox"], input[type="radio"] {
	border-radius: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	border: 1px solid #ddd;
	background: #fff;
}
input[type="checkbox"]:checked {
	background: #EA0029;
	border-radius: 3px;
}
input[type="checkbox"]:checked:before {
	position: absolute;
	top: 1px;
	left: 5px;
	transform: rotate(50deg);
	width: 3px;
	height: 8px;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
	content: '';
}
.form__entry-check label input {
	cursor: pointer;
	width: 16px;
	height: 16px;
	padding: 0;
	border-radius: 15px;
	margin-top: -4px;
	margin-right: 8px;
}
input[type="radio"]:checked {
	background: #EA0029;
}
input[type="radio"]:checked:before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #fff;
	content: '';
}



}







/*////////////////////////////////////////////////////////////////////////////

　768px以下の対応

////////////////////////////////////////////////////////////////////////////*/

@media screen and (max-width:768px) {
#header{
	padding-bottom: 5%;
}
#features #wrap{
	width: 100%;
	letter-spacing: 0.06em;
}
#features #wrap #contents{
	width: 100%;
	margin: 0 auto 10%;
}
#features #wrap #contents p{
	line-height: 1.6;
	font-size: 16px;
}

/* ファーストビューエリア */
.underlayer--firstview__wrap{
	width: 100%;
	margin-bottom: 9%;
	background: #F9F1F1;
	padding: 10% 0;
}
.underlayer--firstview__inr{
	width: 90%;
	margin: 0 auto;
}
.underlayer--firstview__left{
	margin-bottom: 10%;
}
.underlayer--firstview__ttl h1{
	font-size: 28px;
	color: #EA0029;
	letter-spacing: 0.03em;
	margin-bottom: 3%;
	line-height: 1.3;
}
.underlayer--firstview__ttl h1 span{
	font-size: 16px;
	letter-spacing: 0.06em;
	display: block;
}
.underlayer--firstview__lead{
	font-size: 14px;
	line-height: 1.6;
	letter-spacing: 0.03em;
	font-weight: 400;
}
.underlayer--firstview__image{
	margin-bottom: 1.5%;
	position: relative;
	width: 88%;
	margin: 0 auto 3%;
}
.underlayer--firstview__image::before{
	content: "資料配布中";
	font-size: 12px;
	letter-spacing: 0;
	text-align: center;
	color: #fff;
	line-height: 70px;
	background: #EA0029;
	border-radius: 60px;
	width: 70px;
	height: 70px;
	position: absolute;
	top: -22%;
	right: -7%;
}
.underlayer--firstview__btn {
	text-align: center;
}
.underlayer--firstview__btn p{
	margin-bottom: 10px;
	font-weight: 400;
	letter-spacing: 0;
	font-size: 14px;
	line-height: 1.5;
}
.underlayer--firstview__btn a{
	display: inline-block;
	letter-spacing: 0;
	color: #fff;
	font-weight: 700;
	background: #185ABC;
	border-radius: 5px;
	padding: 6.5% 16%;
	position: relative;
	transition: 0.3s;
	font-size: 14px;
	line-height: 1;
}
.underlayer--firstview__btn a::before{
	content: "";
	background: url("../../case-studies/img/fv-document-dl-icon.svg");
	width: 26px;
	height: 26px;
	position: absolute;
	top: 27%;
	right: 5%;
	background-size: contain;
}


/* このようなお悩みありませんか？ */
.worries{
	margin-bottom: 6%;
}
#worries .worries__inr{
	width: 90%;
	margin: 0 auto 15%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
#worries .worries__left{
	width: 100%;
	border-radius: 10px;
	box-sizing: border-box;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
	text-align: center;
	padding: 6% 0 8% 0;
	position: relative;
	margin-bottom: 22%;
	order: 2;
}
#worries .worries__left::before{
	content: "";
	background: url("../../features/img/plus.svg");
	width: 32px;
	height: 32px;
	position: absolute;
	bottom: -16%;
	left: calc(50% - 16px);
	background-size: cover;
}
#worries .worries__left h3{
	font-size: 20px;
	font-weight: 500;
	margin-bottom: 1%;
}
#worries .worries__shop{
	display: flex;
	flex-flow: wrap-reverse;
	justify-content: center;
}
#worries .worries__left div:first-child{
	margin-bottom: 1%;
}
#worries .worries__left .worries__no1{
	order: 3;
	width: 43%;
}
#worries .worries__left .worries__no1 figure{
	width: 80%;
	height: auto;
	margin: 0 auto;
}
#worries .worries__left .worries__no2{
	order: 1;
	width: 43%;
}
#worries .worries__left .worries__no2 figure{
	width: 80%;
	height: auto;
	margin: 0 auto;
}
#worries .worries__left .worries__no3{
	order: 2;
	width: 43%;
}
#worries .worries__left .worries__no3 figure{
	width: 80%;
	height: auto;
	margin: 0 auto;
}
#features #wrap #contents #worries .worries__left div p{
	font-size: 16px;
	letter-spacing: 0;
	line-height: 1;
}
#worries .worries__right{
	width: 100%;
	display: contents;
}
#worries .worries__right h3{
	font-size: 20px;
	letter-spacing: 0.1em;
	line-height: 1.6;
	font-weight: 500;
	margin-bottom: 5%;
	order: 1;
}
#worries .worries__right h3 span{
	font-size: 26px;
	font-weight: 700;
	line-height: 1.3;
	color: #EA0029;
	letter-spacing: 0.06em;
}
#worries .worries__right .worries__right-inr{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 16px;
	margin-bottom: 10%;
	order: 3;
}
#worries .worries__right .worries__right-inr div{
	width: 48%;
	border-radius: 10px;
	padding: 5%;
	box-sizing: border-box;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
}
#features #wrap #contents #worries .worries__right .worries__right-inr div .worries__right-introduction{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .06em;
	margin-bottom: 3%;
}
#features #wrap #contents #worries .worries__right .worries__right-inr div .worries__right-answer{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .06em;
	font-weight: 700;
	color: #EA0029;
}
#features #wrap #contents #worries .worries__right-lead{
	font-size: 16px;
	line-height: 1.6;
	letter-spacing: .1em;
	order: 4;
}
#features #wrap #contents #worries .worries__right-lead.worries__lead-message{
	font-weight: 500;
	letter-spacing: .06em;
	line-height: 1.7;
	font-size: 20px;
}
#worries .worries__right-lead.worries__lead-message .marker{
	background: linear-gradient(transparent 70%, #ffee93 70%);
}
#features #wrap #contents #worries .worries__right-lead + .worries__right-lead {
	margin-top: 3%;
}
#worries h2{
	width: 90%;
	margin: 0 auto 6%;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.6;
	text-align: center;
	letter-spacing: .06em;
}
#worries h2 span{
	font-size: 24px;
	font-weight: 700;
	letter-spacing: .06em;
	padding: 0 0 0 0.2em;
	margin: 0 0.2em;
	border-bottom: 3px solid #EA0029;
}
#worries .worries__right-lead{
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: .1em;
	width: 98%;
	margin: 0 auto;
}
#worries .worries__right-lead.worries__lead-message{
	font-weight: 500;
	margin-bottom: 2%;
	letter-spacing: .2em;
	line-height: 1.7;
}


/* イグレックのセルフオーダーが課題を解決できる理由 */
#solve {
	width: 90%;
	margin: 0 auto 15%;
}
#solve h2{
	font-size: 24px;
	line-height: 1.4;
	color: #EA0029;
	letter-spacing: .08em;
	text-align: center;
	margin-bottom: 8%;
}
.solve__point01,
.solve__point02{
	margin-bottom: 12%;
	padding-bottom: 12%;
	border-bottom: 1px solid #e3e3e3;
}
.solve__point03{
	margin-bottom: 8%;
}
#solve__inr{
	width: 910px;
	margin: 0 auto 64px;
}
.solve__point01 .solve__pont-inr,
.solve__point02 .solve__pont-inr{
	margin-bottom: 8px;
}
.solve__pont-inr{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.solve__left{
	margin-bottom: 5%;
}
.solve__point01 .solve__pont-inr picture,
.solve__point02 .solve__pont-inr picture,
.solve__point03 .solve__pont-inr picture{
	width: 100%;
	height: auto;
	margin: 0 auto;
	display: block;
}
#solve .solve__right h3{
	font-size: 20px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.08em;
	margin-bottom: 3%;
}
#solve .solve__right h3 span{
	font-size: 32px;
	line-height: 1;
	padding-right: 0.05em;
}

#solve .solve__right h3 sup{
	font-size: 12px;
}
#solve .solve__right p{
	font-size: 16px;
	line-height: 1.6;
	letter-spacing: .06em;
	margin-bottom: 3%;
}
#solve .solve__right a{
	font-size: 16px;
	font-weight: 500;
	line-height: 1.7;
	color: #EA0029;
	position: relative;
	display: inline-block;
}
#solve .solve__right a span{
	background: linear-gradient(to bottom, transparent 0% 95%, #EA0029 95% 0%);
	display: inline;
}
#solve .solve__right a::before{
	content: "";
	background: url("../../features/img/features-arrow.svg");
	background-size: contain;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 4px;
    right: -26px;
}
.solve__point01 a,
.solve__point02 a{
	margin-bottom: 3%;
}
#solve .attention{
	font-size: 14px;
	line-height: 1.5;
	padding-left: -1em;
	margin-left: 1em;
	position: relative;
}
#solve .attention::before{
	content: "※";
	position: absolute;
	top: 0;
	left: -1em;
	font-size: 14px;
}
.solve--bnr-btn{
	width: 100%;
	height: auto;
	margin: 0 auto 6%;
}
.solve--bnr-btn a{
	box-shadow: 0px 8px 6px -3px #c8c8c8;
    transition: .3s;
	display: block;
	overflow: hidden;
	border-radius: 0px;
}
.solve--bnr-btn a img{
	vertical-align: top;
}




/* 導入店舗数は2,300店舗以上、店舗規模を問わずご利用いただけます */
#use {
	width: 90%;
	margin: 0 auto 15%;
}
#use h2{
	font-size: 24px;
	line-height: 1.4;
	color: #EA0029;
	letter-spacing: .08em;
	text-align: center;
	margin-bottom: 8%;
}
#use h2 span{
	display: inline;
}
.use__inr{
	width: 100%;
	margin: 0 auto 8%;
}
.use-shop-list{
	width: 100%;
	height: auto;
	margin-bottom: 6%;
}
.use__interview{
	text-align: center;
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1.7;
	margin-bottom: 6%;
}
.use__interview span{
	display: inline;
}
.use-shop-logo{
	width: 100%;
	height: auto;
	margin-bottom: 8%;
}
.use__schedule{
	text-align: center;
	font-size: 20px;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.06em;
	margin-bottom: 10%;
}
.use__schedule span{
	font-size: 26px;
	font-weight: 400;
	border-bottom: 4px solid #EA0029;
}
.use__schedule span span{
	font-size: 40px;
	font-weight: 400;
	border-bottom: 0;
	padding: 0 .13em;
}
#features #wrap #contents .use__message{
	text-align: left;
	margin: 0 auto;
}
#features #wrap #contents .use__message p{
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 12px;
	letter-spacing: .1em;
}
#features #wrap #contents .use__message p span{
	display: inline;
}

#features #wrap #contents .use__message p.use__message-attention {
	font-size: 14px;
	line-height: 1.5;
	padding-left: -1em;
	margin-left: 1em;
	position: relative;
}
#features #wrap #contents .use__message p.use__message-attention::before {
	content: "※";
	position: absolute;
	top: 0;
	left: -1em;
	font-size: 14px;
}
#use .use--btn a{
	font-size: 16px;
	font-weight: 500;
	line-height: 1.7;
	color: #EA0029;
	position: relative;
	display: inline-block;
}
#use .use--btn a::before{
	content: "";
	background: url("../../features/img/features-arrow.svg");
	background-size: contain;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 4px;
    right: -26px;
}
#use .use--btn a span {
	background: linear-gradient(to bottom, transparent 0% 95%, #EA0029 95% 0%);
	display: inline;
}
.use--bnr-btn{
	width: 100%;
	height: auto;
}
.use--bnr-btn a{
	box-shadow: 0px 8px 6px -3px #c8c8c8;
    transition: .3s;
	display: block;
	overflow: hidden;
	border-radius: 5px;
}
.use--bnr-btn a img{
	vertical-align: top;
}




/* 課題を解決するシステム構成 */
#system {
	width: 100%;
	background: #FFF9EB;
	padding: 12% 0 15%;
}
#system h2{
	font-size: 24px;
	line-height: 1.4;
	color: #EA0029;
	letter-spacing: .08em;
	text-align: center;
	margin-bottom: 8%;
}
.system__inr{
	width: 90%;
	margin: 0 auto;
}
.system__composition01,
.system__composition02,
.system__composition03{
	position: relative;
}
.system__composition01,
.system__composition02{
	margin-bottom: 12%;
}
.system__txt{
	width: 64%;
	margin-left: 36%;
}
.system__txt h3{
	font-size: 20px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.08em;
	margin-bottom: 6%;
}
.system__txt h3 span{
	font-size: 32px;
	line-height: 1;
	padding-right: 0.05em;
}
.system__point h4{
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .1em;
	margin-bottom: 6%;
	margin-left: 1.5em;
	position: relative;
	line-height: 1;
}
.system__point h4::before{
	content: "";
	width: 16px;
	height: 16px;
	border: 2px solid #000;
	box-sizing: border-box;
	position: absolute;
	top: 0em;
	left: -1.5em;
	font-size: 16px;
	border-radius: 16px;
}
.system__point ul li{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: .1em;
	position: relative;
	margin-bottom: 8px;
	margin-left: 1.5em;
}
.system__point ul li.system__point01::before{
	content: "1.";
	position: absolute;
	top: -0.25em;
	left: -1.1em;
	font-size: 20px;
}
.system__point ul li.system__point02::before{
	content: "2.";
	position: absolute;
	top: -0.25em;
	left: -1.1em;
	font-size: 20px;
}
.system__point ul li.system__point03::before{
	content: "3.";
	position: absolute;
	top: -0.25em;
	left: -1.1em;
	font-size: 20px;
}
.system__point ul li span{
	color: #EA0029;
}
.system__function{
	position: absolute;
	top: 16%;
	left: 0;
	width: 35%;
	height: auto;
}
.system__function h3{
	font-size: 16px;
	font-weight: 500;
	border-bottom: 2px solid #000;
	transform: rotate(90deg);
	display: inline-block;
	line-height: 1.5;
	position: absolute;
    top: -1.5em;
}
.system__function ul{
	position: relative;
}
.system__function01,
.system__function02,
.system__function03{
	width: 90%;
	height: 90%;
	position: relative;
	text-align: center;
}
.system__function01 div,
.system__function02 div,
.system__function03 div{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.3;
	letter-spacing: 0;
	color: #fff;
	position: absolute;
	width: 100%;
	top:50%;
	left:50%;
	transform: translateX(-50%) translateY(-50%);
	z-index: 2;
}



/* よくある質問 */
#faq {
	width: 90%;
	margin: 0 auto;
	padding: 12% 0;
}
#faq h2{
	font-size: 24px;
	line-height: 1.4;
	color: #EA0029;
	letter-spacing: .08em;
	text-align: center;
	margin-bottom: 8%;
}
.faq__inr{
	width: 100%;
	margin: 0 auto;
}
.faq__inr ul li {
	margin-bottom: 16px;
	border-radius: 18px;
	box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.12);
}
.faq__inr ul li:last-child{
	margin-bottom: 0;
}
.faq__inr ul li div dl dt{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	color: #fff;
	background: #EA0029;
	position: relative;
	padding: 8% 8% 8% 16%;
	border-radius: 18px 18px 0 0;
}
.faq__inr ul li div dl dt::before{
	content: "Q.";
	font-size: 20px;
	color: #fff;
	position: absolute;
	top: 22px;
	left: 6%;
}
.faq__inr ul li div dl dd{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	position: relative;
	padding: 8% 8% 8% 16%;
}
.faq__inr ul li div dl dd::before{
	content: "A.";
	font-size: 20px;
	position: absolute;
	top: 22px;
	left: 6%;
}
.faq__inr ul li div dl dd a{
	color: #EA0029;
	border-bottom: 1px solid #EA0029;
	display: inline-block;
}

/* お問い合わせ */
#contact {
	width: 90%;
	margin: 0 auto 12%;
}
#contact h2{
	font-size: 24px;
	line-height: 1.4;
	color: #EA0029;
	letter-spacing: .08em;
	text-align: center;
	margin-bottom: 7%;
}
.contact__inr{
	width: 100%;
	margin: 0 auto;
}
.form__section{
	margin-bottom: 3%;
}
.form__title {
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 1%;
}
.form__box input {
	font-size: 16px;
	width: 100%;
	height: 50px;
	padding: 5px 10px;
	border-radius: 5px;
	box-sizing: border-box;
	border: 1px solid #ddd;
}
.form__box.form__box-choice label,
.form__entry-check label {
	cursor: pointer;
	width: 100%;
	box-sizing: border-box;
	border-radius: 5px;
	height: 50px;
	display: block;
	line-height: 50px;
	padding-left: 12px;
	border: 1px solid #ddd;
}
.form__box.form__box-choice label input {
	font-size: 16px;
	width: 16px;
	height: 16px;
	padding: 0;
	border-radius: 5px;
	box-sizing: border-box;
	border: 1px solid #ddd;
	margin-top: -4px;
	margin-right: 8px;
}
.form__box div{
	font-size: 16px;
}
.form__box div + div{
	margin-top: 8px;
}
.form__entry{
	font-size: 16px;
	line-height: 1.6;
}
.form__section.form__section-privacy{
	margin-bottom: 6%;
}
.form__entry .form__entry-text{
	margin-bottom: 1%;
}
.form__entry-text a{
	border-bottom: 1px solid #EA0029;
	color: #EA0029;
	display: inline;
}
.form__entry-btn input{
	background: #1870bc;
	width: 100%;
	padding: 8% 0;
	color: #fff;
	border: none;
	font-size: 18px;
	border-radius: 6px;
}
input[type="checkbox"], input[type="radio"] {
	border-radius: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	border: 1px solid #ddd;
	background: #fff;
}
input[type="checkbox"]:checked {
	background: #EA0029;
	border-radius: 3px;
}
input[type="checkbox"]:checked:before {
	position: absolute;
	top: 1px;
	left: 5px;
	transform: rotate(50deg);
	width: 3px;
	height: 8px;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
	content: '';
}
.form__entry-check label input {
	cursor: pointer;
	width: 16px;
	height: 16px;
	padding: 0;
	border-radius: 15px;
	margin-top: -4px;
	margin-right: 8px;
}
input[type="radio"]:checked {
	background: #EA0029;
}
input[type="radio"]:checked:before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #fff;
	content: '';
}




}