@charset "utf-8";

/* PC_style  (PCのみのスタイル) */
.shop .secPartnerList .link ul li {
	width: 15%;
}

/* ★★ スマホ以下 ★★ */
@media screen and (max-width: 767px) {

	.shop .secPartnerList .link ul li {
		margin-top: 4px;
		margin-left: 2%;
		width: 32%;
	}

	.shop .secPartnerList .link ul li:nth-child(3n+1) {
		clear: both;
		margin-left: 0;
	}
}


.secMap .blockTit{
	margin-bottom:0!important;
}
/*
.secMap .blockTit > .search-tit{
	background: url(/images/shop/tit-search-footer02_pc.png) no-repeat center 0;
	height: 0;
	margin-bottom: 12px;
	overflow: hidden;
	padding-top: 31px;
	font-size:14px;
}

.secMap .blockTit > .search-tit > span{
	display:none;
}*/

.secAreasearch{
	padding-top:50px;
}

.secAreasearch > .tit{
	background: url(/images/shop/tit-search-footer02_pc.png) no-repeat center 0;
    height: 0;
    margin-bottom: 19px;
    overflow: hidden;
    padding-top: 31px;
}

@media screen and (max-width: 767px) {
	/*.secMap .blockTit > .search-tit{
		background-image: url(/images/shop/tit-search-footer02_sp.png);
		background-size: auto 19px;
		margin-bottom: 14px;
		padding-top: 19px;
	}

	.secSearchFooter+.secMap{
		padding-top:60px;
	}*/

	.secAreasearch{
		margin:0 20px;
		padding-top:0;
	}

	ol.searchStep{
		padding-bottom:60px;
	}

	.secAreasearch > .tit{
		 background-image: url(/images/shop/tit-search-footer02_sp.png);
		background-size: auto 19px;
		margin-bottom: 17px;
		padding-top: 19px;
	}

	.container .secAreasearch{
		margin:0;
	}

}

.pageTit .container {
	display: block;
	width: 100%;
}

.pageTit .pageTitWrap {
	display: block;
	display: flex;
	align-items: center;
	height: 200px;
	line-height: 1.1;
	vertical-align: middle;
}

.pageTit .pageTitWrapDetail {
	display: flex;
	align-items: center;
	height: 200px;
	line-height: 1.1;
	vertical-align: middle;
	width: 100%;
	max-width: 800px;
}

.pageTit .tit {
  display: inherit;
  vertical-align: inherit;
}

.pageTit span:before {
	background: rgba(177, 177, 177, 0.7);
	content: '';
	display: inline-block;
	height: 20px;
	margin: 0 19px 0 2px;
	width: 1px;
}

.pageTit span {
	display: inline-block;
	vertical-align: middle;
	color: rgba(255, 255, 255, 0.7);
	font-size: 22px;
}

.shop .secShopDetail .secDetail .service .productInfo li {
	border-radius: 4px;
	color: #fff;
	float: left;
	font-size: 11px;
	font-weight: bold;
	margin: 7px 7px 0 0;
	padding: 7px 0;
	text-align: center;
	width: 225px;
}

.shop .secShopDetail .secDetail .service .productInfo li.productH {
	background: #474747;
}

/*
.shop .secShopDetail .secDetail .service .productInfo li.productNR {
  background: #12a6ea;
}

.shop .secShopDetail .secDetail .service .productInfo li.productHF {
  background: #296da1;
}

*/
.shop .secShopDetail .secDetail .service .productInfo li.productRR {
	background: #60A0E0 ;
}

.shop .secShopDetail .secDetail .service .productInfo li.productRH {
	background: #dc143c;
}

.shop .secShopDetail .secDetail .service .productInfo li.productGG {
	background: #6D6D6D;
}

@media screen and (max-width: 767px) {
	.pageTit {
		font-size: 22px;
		width: 100%;
	}
	.pageTit .container {
		margin: 0;
		box-sizing: content-box;
		width: 100%;
		padding: 0 20px;
	}
	.pageTit .pageTitWrap, .pageTit .pageTitWrapDetail {
		height: 100px;
	}
	.pageTit .tit {
		display: block;
	}
	.pageTit span {
		display: block;
		font-size: 11px;
		margin-top: 3px;
	}
	.pageTit span:before {
		display: none;
	}
}
#header #globalNav .searchBtn {
	border-radius: 13px;
	border: none;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 27px;
	width: 115px;
}

#header #globalNav .searchBtn a {
	border-radius: 13px;
	background: #f1880d;
	background: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YwODIwMSIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2YxOGUxOSIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==");
	background: -webkit-gradient(linear, left top, left bottom, from(#f08201), to(#f18e19));
	background: linear-gradient(#f08201, #f18e19);
	*zoom: 1;
	filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFF08201', endColorstr='#FFF18E19');
	color: #fff;
	display: block;
	font-size: 12px;
	font-weight: bold;
	padding: 1px;
  }

#header #globalNav .searchBtn a span {
	border-radius: 13px;
	background: url(/images/common/ico-search.png) no-repeat 12px 5px;
	background-size: 12px auto;
	border: 1px solid #f39d38;
	display: block;
	border-width: 1px 0 0;
	padding: 2px 0 3px 6px;
}

@media screen and (max-width: 1040px){
    #header #globalNav .searchBtn {
		border-radius: 0;
		background: #111110;
		padding: 20px 0;
		position: relative;
		right: auto;
		top: auto;
		width: 100%;
	}
	#header #globalNav .searchBtn a {
		-webkit-transition: background 0.3s;
		transition: background 0.3s;
		border-radius: 23px;
		background: transparent;
		-webkit-filter: none;
		filter: none;
		border: 1px solid rgba(255, 255, 255, 0.4);
		margin: 0 auto;
		text-align: center;
		width: 280px;
	}
	#header #globalNav .searchBtn a span {
		background: url(/images/common/ico-search.png) no-repeat 0 center;
		background-size: 20px 20px;
		border-color: transparent;
		display: inline-block;
		font-size: 12px;
		padding: 12px 0 11px 25px;
	}
	.no-touch #header #globalNav .searchBtn a:hover {
		background: rgba(255, 255, 255, 0.3);
		opacity: 1;
	}
}

.shop .secShopDetail .btnArea {
	background: #f5f5f5;
	border: none;
	padding: 30px 0 34px;
}

.shop .secShopDetail .btnInquiry {
	border-radius: 30px;
	background-image: url(/images/shop/btn-inqury-large_pc.png);
	background-size: 100% 100%;
	margin-top: 30px;
	max-width: 485px;
}

.shop .secShopDetail .btnInquiry a {
	border-radius: 30px;
	border: none;
	font-size: 22px;
	padding: 12px;
}

.shop .secShopDetail .btnInquiry a span {
	/*background-size: auto 18px;*/
	/*padding-left: 35px;*/
}

.shop .secShopDetail .secDetail .topInfo .btnInquiry a {
	border-radius: 15px;
	font-size: 12px;
	padding: 6px;
}

.shop .secShopDetail .secDetail .topInfo .btnInquiry a span {
	background-size: auto 10px;
	padding-left: 18px;
	font-size: inherit;
}

.consent {
	margin-top: 60px;
}

.consent h2 {
	font-size: 21px;
	color: #000;
	font-weight: bold;
	background-color: #f3f5f7;
	padding: 15px 15px 13px 15px;
	margin-bottom: 20px;
}

.consent .privacy {
	border: 1px solid #d0d5da;
	padding: 25px 30px;
	overflow-y: scroll;
	height: 280px;
	box-sizing: border-box;
	color: #333;
	line-height: 28px;
	margin-bottom: 40px;
}

.consent .privacy ul {
	list-style: decimal;
	padding: 0 40px 0 60px;
	margin-bottom: 60px;
}

.consent .privacy ul li:not(:last-child) {
	margin-bottom: 20px;
}

/*同意するボタン*/
.consentCheck{
	width: 730px;
	height: 80px;
	color: #e60012;
	font-size: 16px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto 20px;
	box-sizing: border-box;
	border: 1px solid #e60012;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	cursor: pointer;
	transition: background 0.12s;
}

.consentCheck:hover {
	background-color: #f8e2e3;
}

.consent input[type="checkbox"] {
	display: none;
}

.consent .checkBox{
	text-align: center;
	display: inline-block;
	width: 15px;
	height: 15px;
	border: 1px solid #d0d5da;
	margin-right: 15px;
	position: relative;
	top: -1px;
	background-color: #fff;
}

.consent .checkBox::after{
	content: '';
	display: inline-block;
	position: absolute;
	width: 11px;
	height: 7px;
	border-left: 2px solid #e60012;
	border-bottom: 2px solid #e60012;
	transform: rotate(-45deg);
	top: 0;
	left: 1px;
	opacity: 0;
	transition: opacity 0.12s;
}
.consent input[type="checkbox"]:checked + .checkBox::after{ opacity: 1;}

.secAreasearch > .tit-3 {
	background: url(/images/shop/tit-search-footer03_pc.png) no-repeat center 0;
	height: 0;
	margin-bottom: 19px;
	overflow: hidden;
	padding-top: 31px;
}

@media(max-width:767px) {
	.consentCheck {
		width: 100%;
		font-size: 14px;
		margin: 0 auto 20px;
	}
	.secAreasearch > .tit-3 {
		background-image: url(/images/shop/tit-search-footer03_sp.png);
		background-size: auto 14px;
		margin-bottom: 17px;
		padding-top: 19px;
		margin-top: 15px;
	}
}

.consent .error {
	text-align: center;
	color: #cb2929;
	font-size: 13px;
}

/* システムメッセージ */
.alert-info {
	color: #0c5460;
	font-size: 14px;
	border: 2px solid #abdde5;
	padding: 12px;
	background-color:#d1ecf1;
	position: relative;
	z-index: 1000;
}

.alert-success {
	color: #3c763d;
	background-color: #dff0d8;
	font-size: 14px;
	border: 2px solid #c5d8b5;
	padding: 12px;
	position: relative;
	z-index: 1000;
}

.alert-warn {
	color: #856404;
	background-color: #fff3cd;
	font-size: 14px;
	border: 2px solid #ffe8a1;
	padding: 12px;
	position: relative;
	z-index: 1000;
}

.alert-danger {
	color: #ed5b00;
	font-size: 14px;
	border: 2px solid #ed5b00;
	padding: 12px;
	background-color:#ffefef;
	position: relative;
	z-index: 1000;
}

/* 参考施工価格モーダルのadd_style.cssによる定義に手を出せないので無理やり上書きする */
.priceModal .priceSearch .searchArea .notesArea .notesListData:before {
	content: none !important;
}

.priceModal .priceSearch .searchArea .notesArea .notesListData {
	text-indent: 0 !important;
}

/*店舗詳細ページにてマップ上のタイトルとマップの間にマージンが無いとのこと対応*/
.secMap.shopDetail .blockTit{
	margin-bottom: 25px!important;
}

/*フォーム関連SP時テキストが小さい件対応*/
@media(max-width:767px) {
	.inquiry {
		.secInquiry {
			.formTable {
				th,td,select,input,textarea {
					font-size: 15px;
				}
			}

			.btnArea {
				.btnSubmit,
				a,
				.btnReturn {
					font-size: 15px;
				}

				.btnReturn {
					padding-bottom: 12px;
					padding-top: 13px;
				}
			}
		}
	}
}

.commentArea .totalRt {
	color: black;
	font-size: 18px;
}
