@charset "utf-8";
/*===============================================
 画面の横幅が769px以上
===============================================*/

.cx:after{
	clear: both;
	content: ".";
	display: block;
	height: 0;
	visibility: hidden;
}

/*選ばれている理由 reason*/
.reason ul.cmncard li h3{
	padding: 32px 12px 29px 12px;
	text-align: center;
	font-size: 20px;
	font-size: 1.25rem;
	box-sizing: border-box;
	line-height: 1.2;
	margin: 0;
}

.reason ul.cmncard li h3 strong{
	color: #bc000f;
}

.reason ul.cmncard li .detail{
	padding: 0 0 22px 0;
}

.reason ul.cmncard li .detail .img{
	margin-bottom: 12px;
}

.reason ul.cmncard li .detail .img img{
	width: 100%;
	height: auto;
}

.reason ul.cmncard li .detail .text{
	margin-bottom: 12px;
	line-height: 1.6;
	padding: 0 24px ;
	box-sizing: border-box;
}

.reason h3{
	font-size: 36px;
	font-size: 2.25rem;
	margin-bottom: 12px;
	text-align: center;
	line-height: 1.2;
}

.reason table{
	border-spacing: 12px 0;
	width: 100%;
	line-height: 1.6;
	padding-bottom: 12px;
	text-align: center;
	border-spacing: 6px 0;
	table-layout: fixed;
}

.reason table tr th,
.reason table tr td{
	padding: 20px 5px;
	box-sizing: border-box;
	border-bottom: 1px solid #ddd;
	font-size: 16px;
	font-size: 1rem;
	text-align: center;
}

.reason table tr td{
	background: #efefef;
}

.reason table thead tr th{
	background: #ddd;
	border-radius: 6px 6px 0 0;
}

.reason table thead tr th:nth-child(1){
	background: none;
	width: 20%;
}

.reason table thead tr th:nth-child(2){
	background: #bc000f;
	color: #fff;
}

.reason table tbody tr th{
	background: #fff;
	font-weight: normal;
}

.reason table tbody tr td:nth-child(2){
	background: #f8e5e7;
}

/*店舗一覧*/
ul.store_list_icon{
	display: flex;
	margin-bottom: 6px;
	flex-wrap: wrap;
}

ul.store_list_icon li{
	display: flex;
	align-items: center;
	margin-right: 20px;
	margin-bottom: 6px;
	font-weight: bold;
}

ul.store_list_icon li p{
	margin-right: 6px;
}

ul.store_list{
	background: #fff;
	border-radius: 12px;
	padding: 12px 24px;
	box-sizing: border-box;
	box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.25);
}

ul.store_list li a,
ul.store_list li .no-link{
	border-bottom: 1px dotted #999;
	display: block;
	padding: 12px 6px;
	box-sizing: border-box;
}

ul.store_list li:last-child a{
	border-bottom: 0px dotted #999;
}

ul.store_list li .shop_detail{
	display: flex;
	align-items: center;
}

ul.store_list li .shop_detail .detail{
	width: calc(100% - 448px);
}

ul.store_list li .service_type{
	width: 448px;
}

ul.store_list li .service_type ul{
	display: flex;
}

ul.store_list li .service_type ul li{
	margin-right: 6px;
}

ul.store_list li h3{
	font-size: 18px;
	font-size: 1.125rem;
	margin: 6px 0 8px 0;
	line-height: 1.2;
}

ul.store_list li p{
	display: flex;
	align-items: center;
	color: #333;
	margin-bottom: 3px;
}

ul.store_list li p span{
	margin-right: 6px;
}

ul.store_list li p.open{
	color: #bc000f;
	line-height: 1.3;
}

/*動画バナー*/
.banner_contents .movie_banner{
	width: 728px;
	margin: 0 auto;
}

.banner_contents .movie_banner a{
	background: #333;
	border-radius: 6px;
	display: block;
	padding: 22px 24px 20px 130px;
	box-sizing: border-box;
	color: #fff;
	position: relative;
}

.banner_contents .movie_banner a:before {
  content: '';
  width: 45px;
  height: 45px;
  background: #d32f2f;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 36px;
  bottom: 0;
  margin-top: -22px;
}

.banner_contents .movie_banner a:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 0 8px 12px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 50%;
  left: 55px;
  bottom: 0;
  margin-top: -7px;
}

.banner_contents .movie_banner h2{
	font-size: 24px;
	font-size: 1.5rem;
	margin: 0 0 8px 0;
}

/*お知らせ*/
.news dl.news_list {
	background: #fff;
	border-radius: 12px;
	padding: 22px 36px;
	box-sizing: border-box;
	line-height: 1.6;
	display: flex;
	flex-wrap: wrap;
	height: 232px;
	overflow: auto;
}

.news div.news_box{
	position: relative;
	z-index: 10;
	border-radius: 12px;
}

.news div.news_box:before,
.news div.news_box:after{
	content: '';
    width: 100%;
    height: 20px;
	position: absolute;
	z-index: 100;
}

.news div.news_box:before{
	background: linear-gradient(rgba(255,255,255,1),rgba(255,255,255,0));
	top: 0;
	left: 0;
	border-radius: 12px 12px 0 0;
}

.news div.news_box:after{
	background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,1));
	bottom: 0;
	left: 0;
	border-radius: 0 0 12px 12px;
}

.news dl.news_list  dt{
	margin: 0;
	width: 120px;
	padding: 6px 0;
}

.news dl.news_list  dd{
	width: calc(100% - 120px);
	margin: 0;
	padding: 6px 0;
}

.news dl.news_list  dd a{
	text-decoration: underline;
}
  
  
  
