@charset "utf-8";
/*===============================================
sp.css  画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:768px){

/*SP開始******************************************/

/*切り替え*/

.sp{display:block !important;}
.pc{display:none;}

.cx:after,
.store_search .store_contents .area ul:after,
.store_search .store_contents:after{
	clear: both;
	content: ".";
	display: block;
	height: 0;
	visibility: hidden;
}

/*header*/
.header{
	height: auto;
}

.header .header-in{
	width:100%;
	padding:5px 0;
	position: relative;
}

.header .header-in .logo{
	margin-left:5px;
}

.header .header-in .logo img{
	width:auto;
	height: 41px;
}

.header .header-in .head_cont{
	padding-top:4px;
}

.header .header-in .head_cont .button{
	margin-right:10px;
}

.header .header-in .head_cont .button a{
	font-size: 14px;
	font-size: 0.875rem;
	padding:10px 10px;
}

.header .header-in .head_cont .tel{
	margin-right: 5px;
	margin-top:8px;
}

.main_button .main_button_in .tel a{
	color: #332623;
}

.header .header-in .head_cont .tel img{
	height: 15px;
}

.header .header-in .head_cont .button.line{
	display: none;
}
	
/* hdr_menu */
.header{
  position: relative;
}

.hdr_menu_btn,
.hdr_close_btn {
  width: 50px;
  height: 50px;
  position: absolute;
  cursor: pointer;
  right: 0;
  top: 0;
}

.hdr_menu_btn span,
.hdr_close_btn span {
  display: block;
  margin: 0;
  border: none;
  width: 26px;
  height: 2px;
  background: #090909;
  transform-origin: 0% 50%;
  position: absolute;
  top: 14px;
  left: 10px;
  transition: .3s;
}

.hdr_close_btn span{
  left: 15px;
}

.hdr_close_btn span {
  width: 24px;
}

.hdr_menu_btn span:nth-of-type(2),
.hdr_close_btn span:nth-of-type(2) {
  top: 24px;
}

.hdr_menu_btn span:nth-of-type(3),
.hdr_close_btn span:nth-of-type(3) {
  top: 34px;
}

.hdr_menu_btn.is-active span:nth-of-type(1),
.hdr_close_btn.is-active span:nth-of-type(1) {
  transform: rotate(45deg);
  top: 16px;/*18px*/
}

.hdr_menu_btn.is-active span:nth-of-type(2),
.hdr_close_btn.is-active span:nth-of-type(2) {
  opacity: 0;
}

.hdr_menu_btn.is-active span:nth-of-type(3),
.hdr_close_btn.is-active span:nth-of-type(3) {
  transform: rotate(-45deg);
  top: 33px;/*35px*/
}

.hdr_load_wrap {
  width: 80%;
  position: fixed;
  top: 0;
  background: #fff;
  z-index: 2001;
  transition: .3s;
  overflow-y: scroll;
  overflow-x: hidden;
  height: 100vh;
}

.hdr_load_menu_wrap {
  right: 0;
  transform: translateX(100%);
}

.hdr_load_wrap.is-active {
  transform: translateX(0);
  box-shadow: 0px 0px 15px -5px #777;
}

.hdr_load_wrap .hdr_close_btn_wrap {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2000;
}

.hdr_overlay,
.hdr_scroll_overlay {
  width: 100%;
  height: 120%;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 2000;
  display: none;
}

.hdr_overlay.is-active,
.hdr_scroll_overlay.is-active {
  display: block;
}
/* //hdr_menu */

/*menu*/
.header .menu_contents{
	padding-top: 52px;
}

.header .innner{
	width: 100%;
}

.header .innner ul.navi{
	display: block;
	text-align: left;
	border-top: 1px solid #efefef;
	margin-bottom: 20px;
}

.header .innner ul.navi li{
	margin-right: 0;
	border-bottom: 1px solid #efefef;
}

.header .innner ul.navi li a{
	padding-left: 0;
	display: block;
	padding: 16px 16px;
	box-sizing: border-box;
}

.header .innner ul.navi li a:before{
	right: 12px;
	left: auto;
	width: 5px;
	height: 5px;
}

.header .innner ul.cv_button{
	padding: 0 16px;
	margin-bottom: 12px;
}

.header .innner ul.cv_button li{
	margin-bottom: 12px;
}

.header .innner ul.cv_button li.simulation a,
.header .innner ul.cv_button li.reservation a, 
.header .innner ul.cv_button li.search_store a{
	font-size: 16px;
	font-size: 1rem;
}

.header .innner ul.cv_button li.reservation strong, 
.header .innner ul.cv_button li.search_store strong,
.header .innner ul.cv_button li.reservation strong span, 
.header .innner ul.cv_button li.search_store strong span{
	font-size: 22px;
	font-size: 1.375rem;
}

.header .innner ul.cv_button li.reservation a, 
.header .innner ul.cv_button li.search_store a{
	padding: 10px 20px 4px 20px;
}

.header .innner ul.cv_button li.reservation a{
	box-shadow: 0px 3px 0px 0px #8b030d;
}

.header .innner ul.cv_button li.search_store a{
	box-shadow: 0px 3px 0px 0px #00276f;
}

/*block*/
section .inner{
	max-width: 100%;
	min-width: 100%;
	margin: 0 auto 36px auto;
	padding: 0 16px;
}

/*card*/
ul.cmncard{
	display: block;
}

ul.cmncard.card3 li,
ul.cmncard.card4 li{
	width: 100%;
	margin: 0 0 12px 0;
}

ul.cmncard li:nth-child(even){
	margin: 0 0 12px 0;
}

/*
ul.cmncard li{
	border-radius: 0;
}
*/

/*title*/
section h2{
	font-size: 28px;
	font-size: 1.75rem;
}

/*予約・お問い合わせボタン　cv_button*/
ul.cv_button li.simulation{
	margin-bottom: 12px;
}

ul.cv_button li.simulation a{
	width: 100%;
	margin: 0 auto;
}

ul.cv_button li.reservation,
ul.cv_button li.search_store{
	width: 100%;
	margin: 0 0 16px 0;
}

ul.cv_button li.reservation a,
ul.cv_button li.search_store a{
	padding: 14px 20px 6px 20px;
	font-size: 20px;
	font-size: 1.25rem;
}

ul.cv_button li a:after,
ul.cv_button li.search_store a:after,
.fixed_contents .button_box .fixed_button a:after{
	right: 8px;
	width: 6px;
	height: 6px;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
	margin-top: 1px;
}

ul.cv_button li.reservation strong,
ul.cv_button li.search_store strong{
	font-size: 28px;
	font-size: 1.75rem;
}

ul.cv_button li.reservation strong span,
ul.cv_button li.search_store strong span{
	font-size: 28px;
	font-size: 1.75rem;
}

/*画面固定ボタン*/
.fixed_contents{
	padding: 8px 0;
}

.fixed_contents .button_box{
	width: calc(100% - 24px);
	padding: 0;
}

.fixed_contents .button_box .fixed_button{
	padding: 0 4px;
}

.fixed_contents .button_box .fixed_button a{
	padding: 6px 14px 2px 6px;
	font-size: 20px;
	font-size: 1.25rem;
}

.fixed_contents .button_box .fixed_button a p{
	font-size: 16px;
	font-size: 1rem;
}

.fixed_contents .button_box .fixed_button a span{
	font-size: 20px;
	font-size: 1.25rem;
}

.fixed_contents .button_box .fixed_button.reservation a{
	border-bottom: 3px solid #8b030d;
}

.fixed_contents .button_box .fixed_button.reservation a:hover{
	border-bottom: 3px solid #a8424a;
}

.fixed_contents .button_box .fixed_button.search_shop a{
	border-bottom: 3px solid #00276f;
}

.fixed_contents .button_box .fixed_button.search_shop a:hover{
	border-bottom: 3px solid #405d93;
}

/*main*/
.main{
	height:auto;	
}

.main .inner{
	padding: 0;
}

.main .contents{
	padding-top: 12px;
	width: 100%;
}

.main .contents .main_contents{
	display: flex;
	align-items: center;
}

.main .contents .text_contents{
	width: calc(100% - 162px);
}

.main .contents h1{
	font-size: 16px;
	font-size: 1rem;
	padding: 8px 12px 7px 12px;	
	margin: 0 auto 12px auto;
	width: 100%;
	max-width: 360px;
}

.main .contents h2{
	font-size: 32px;
	font-size: 2rem;
	line-height: 1.4;
	margin-bottom: 6px;
}

.main .contents h1 strong,
.main .contents h2 p.satisfaction,
.main .contents h2 span.top{
	display: inline-block;
}

.main .contents h2 p.satisfaction{
	margin-top: 0;
}

.main .contents h2 strong{
	font-size: 42px;
	font-size: 2.625rem;
	line-height: 1;
	margin-bottom: 0;
}

.main .contents h2 em{
	font-size: 58px;
	font-size: 3.625rem;
}

.main .contents p.text{
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 1.2;
}

.main .contents p.text strong span{
	font-size: 22px;
	font-size: 1.375rem;
	letter-spacing: -1px;
	margin-right: 2px;
}

.main .contents .character{
	position: static;
	padding-left: 6px;
}

.main .contents .character p img{
	width: 150px;
	height: auto;
}

.main .movie{
	position: static;
}

.main .movie p.title{
	border-radius: 0px;
}

.main .badge{
	width: 370px;
	margin: 0 auto 8px auto;
}

.main .badge ul{
	flex-wrap: wrap;
    justify-content: center;
}

.main .badge ul li{
	margin-right: 0;
	float: left;
	margin-bottom: 6px;
	position: relative;
}

.main .badge ul li p{
	position: absolute;
	bottom: -8px;
	text-shadow: 1px 1px 0 #fff, -1px 1px 0 #fff, -1px -1px 0 #fff, 1px -1px 0 #fff;
}

.main .badge ul li img{
	width: 120px;
	height: auto;
}

.main .movie{
	background: #efefef;
}

.main .movie p.title{
	padding: 10px 12px;
}

.main .movie p.movie_button{
	width: 234px;
	margin: 0 auto 12px auto;
}

/*車種別の車検料金 price*/
.price ul.price_table{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

.price ul.price_table li{
	width:100%;
}

.price ul.price_table li .title{
	height: auto;
	padding: 16px;
	box-sizing: border-box;
}

.price ul.price_table li .contents .car{
	height: auto;
}

.price ul.read-container{
	display: block;
}

.price ul.read-container li{
	padding: 22px 22px;
	width: 100%;
}

.price ul.read-container li:nth-child(odd){
	width: 100%;
	margin-right: 0px;
}

.price ul.read-container li:nth-child(even) {
	width: 100%;
	margin-left: 0px;
}

.price ul.read-container li h3{
	font-size: 22px;
	font-size: 1.375rem;
	margin-bottom: 6px;
	margin-top: 0;
}

/*流れ flow*/
.flow ul{
	display: block;
}

.flow ul.cmncard.card5 li{
	padding: 0;
	margin-right: 0px;
	margin-left: 0px;
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	background: #f8e5e7;
	width: 100%;
	border-radius: 12px;
}

.flow ul li:after{
	top: auto;
	bottom: -22px;
	right: 50%;
	border-right: 0px solid #bc000f;
	border-left: 3px solid #bc000f;
	border-bottom: 3px solid #bc000f;
	transform: translateY(-50%) rotate(-45deg);
	margin-top: 0;
	margin-right: -4px;
}

.flow ul li .icon{
	margin-bottom: 14px;
	padding: 12px 16px 10px 16px;
	box-sizing: border-box;
	width: 30%;
	text-align: center;
	border-radius: 12px 0 0 12px;
	margin-bottom: 0;
}

.flow ul li dl{
	width: calc(100% - 30%);
	padding: 18px 14px 16px 14px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 0 12px 12px 0;
}

.flow ul li dl dt{
	color: #bc000f;
	margin-bottom: 4px;
	line-height: 1.2;
	font-weight: bold;
	text-align: left;
}

.flow ul li dl dd{
	margin: 0;
	line-height: 1.4;
	text-align: left;
}

/*よくある質問 FAQ*/
/*よくある質問 knowledge*/
.faq ul li,
.knowledge_list ul li{
	padding: 18px 16px;
}

/*お客様の声　reviews*/
.reviews ul{
	display: block;
}

.reviews ul.cmncard.card3 li{
	margin-right: 0px;
	padding: 12px 16px;
}

.reviews ul li .customer .detail .store strong{
	display: block;
	margin-bottom: 3px;
}

/*他サービス other_services*/
section.other_services .inner{
	padding: 18px 16px;
}

section.other_services h2 p{
	margin-bottom: 8px;
}

section.other_services ul{
	display: block;
}

section.other_services ul.cmncard.card4 li{
	margin-right: 0px;
	margin-left: 0;
	margin-bottom: 12px;
	border-radius: 12px;
	width: 100%;
}

section.other_services ul.cmncard.card4 li:first-child, 
section.other_services ul.cmncard.card4 li:last-child{
	margin-left: 0;
    margin-right: 0;
}

section.other_services ul li:last-child{
	margin-bottom: 0;
}

section.other_services ul li a{
	padding: 18px 20px;
	border-radius: 12px;
}

/*店舗*/
.store_search .store_contents{
	display: block;
	padding: 18px 16px 0 16px;
}

.store_search .store_contents .area{
	padding: 0;
	width: 100%;
}

.store_search .store_contents .area h3{
	margin-top: 0;
	margin-bottom: 16px;
}

.store_search .store_contents .area ul li{
	font-size: 16px;
	font-size: 1rem;
	margin-right: 16px;
	margin-bottom: 16px;
}


.store_search .store_contents .area ul li a,
.store_search .store_contents .area ul li span{
	padding: 14px 14px 12px 14px;
}

.store_search .store_contents .map{
	display: none;
}

/*foot*/
.footer{
	padding-bottom: 72px;
}

.footer .inner{
	width:100%;
	max-width: 100%;
	min-width: 100%;
	padding: 24px 0 0 0;
}

.footer .inner .lead{
	display: block;
	padding: 0 12px 8px 12px;
	box-sizing: border-box;
}

.footer .inner .lead .logo{
	width: 100%;
	margin-bottom: 12px;
}

.footer .inner .lead .logo img{
	width: 140px;
	height: auto;
}

.footer .inner .lead .text{
	width: 100%;
	padding-left: 0;
}

.footer .inner .menu{
	display: block;
	padding: 0;
	background: #fff;
	border-top: 1px solid #fff;
}

.footer .inner .menu dl{
	margin: 0;
}

.footer .inner .menu dl dt{
	margin-bottom:0;
	padding: 8px 12px;
	box-sizing: border-box;
	background: #bc000f;
}

.footer .inner .menu dl dd{
	margin: 0;
}

.footer .inner .menu dl dd ul{
	display: flex;
	flex-wrap: wrap;
}

.footer .inner .menu dl dd ul li{
	width: 50%;
	display: flex;
}

.footer .inner .menu dl dd ul li a{
	color: #333;
	text-decoration: none;
	padding: 15px 8px 12px 12px;
	display: block;
	box-sizing: border-box;
	border-bottom:1px solid #efefef;
	width: 100%;
    align-items: center;
    display: flex;
}

.footer .inner .menu dl dd ul li a:nth-child(odd){
	border-right:1px solid #efefef;
}

.footer .copy{
	padding: 32px 0;
}



/*//SP終了******************************************/
}
