@charset "UTF-8";
/* CSS Document */


/*
	common
*/
bbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:0 0}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}nav ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:0 0}ins{background-color:#ff9;color:#000;text-decoration:none}mark{background-color:#ff9;color:#000;font-style:italic;font-weight:700}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}.clearfix::after {content: "";display: block;clear: both;}

html{
	font-size:62.5%;
}

*{
	max-height:99999px;
}

body{
	font-family: "Noto Sans JP","ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	-webkit-text-size-adjust: 100%;
	font-size:1.4rem;
	color: #000;
	font-weight: 200;
	line-height: 1.75;
	background: #fff;
}
/*.min {
  font-family: 'Noto Serif JP', serif;
  font-weight: 900
}*/
img,video{
	vertical-align:bottom;
	max-width: 100%;
}
li{
	list-style:none;
}
a{
	text-decoration:none;
}
a:hover{
	opacity:0.6;
}

.wrap{
	overflow:hidden;
	max-width: 375px;
	margin: 0 auto;
}
.relative{
	position:relative;
}
.absolute{
	position:absolute;
}
.inline{
	display:inline-block;
}
.left{
	float:left;
}
.right{
	float:right;
}
.in{
	width:335px;
	margin:0 auto;
	position: relative;
}
.flex{
	display: flex;
}
.flex_w{
	flex-wrap: wrap;
}

.sec_ttl{
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #1D267C;
	font-size: 2.6rem;
	color: #fff;
	letter-spacing: 2px;
	font-weight: bold;
	line-height: 1.25;
	text-align: center;
}


.m_u_cta{
	padding: 10px 0 20px;
}

#cp{
	padding-bottom: 40px;
  margin-top: -10px;
}
#cp h3{
	padding: 20px 0;
}
.cp_bnr{
	margin-bottom: 10px;
}
#cp .ac_c{
	border-left: 2px solid #AC9255;
	border-right: 2px solid #AC9255;
	box-sizing: border-box;
}
.ac_c{
	display: none;
}
.ac_btn{
	background: #AC9255;
	padding: 5px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: bold;
	box-sizing: border-box;
	color: #fff;
	position: relative;
}
.ac_btn::after{
	content: "";
	display: block;
	position: absolute;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	right: 10px;
	transform: rotate(135deg);
	top: 10px;
}
.ac_btn.open::after {
    transform: rotate(-45deg);
    top: 16px;
}
#cp .cp_bnr span.txt{
	font-size: 1.0rem;
	line-height: 1.1;
	margin-top: 10px;
	font-weight: bold;
	display: inline-block;
}
.txt_link{
	margin-top: 20px;
	border-bottom: 2px solid #000;
	display: table;
	color: #000;
	font-size: 1.6rem;
	font-weight: bold;
	margin: 20px auto 0;
}

#trouble{
	padding-bottom: 0px;
	border: 8px solid #27833A;
	padding-bottom: 7.5%;
}
#trouble .imgarea{
	margin-bottom: 30px;
	padding: 7.5% 5% 0;
}

#shucho{
	padding: 40px 0;
}
#shucho .ac_c{
	padding: 0px 10px 20px;
	background: #EAE2C3;
}
#shucho .ac_c .txt_link{
	margin-bottom: 20px;
}
.ac_02_con{
	height: 140px;
	overflow: hidden;
	margin-bottom: 10px;
	position: relative;
}
.ac_02_con:after{
	position: absolute;
	z-index: 1;
	bottom:-5px;
	content: "";
	display: block;
	background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,1));
	width: 100%;
	height: 40px;
}
.ac_02_con.open{
	height: auto;
}
.ac_02_con.open:after{
	display: none;
}
.ac_btn_02{
	width: 70%;
	background: #00205d;
	padding: 5px;
	font-size: 1.4rem;
	font-weight:bold;
	color: #fff;
	display: block;
	margin: auto;
	text-align: center;
	border-radius: 100px;
	position: relative;
}
.ac_btn_02:before{
	content: "";
	background: url(../images/ginza0914/arrow_02.png);
	width: 15px;
	height: 15px;
	background-size: cover;
	display: block;
	position: absolute;
	top: 50%;
	left: 10px;
	transform: translate(0,-50%) rotate(180deg);
}
.ac_btn_02.open:before{
	transform: translate(0,-50%) rotate(0deg);
}


#about{
	margin-bottom: 30px;
}
#about h2{
	margin-bottom: 5%;
}
#about .shopimg{
	justify-content:space-between;
	margin-bottom: 20px;
}
#about .shopimg img{
	width: 49%;
}
.access_map{
	margin: 20px 0;
}
.access_map iframe{
	width: 100%;
}
.access_txt{
	margin-bottom: 20px;
}
.access_txt th{
	width: 30%;
	background: #CBE2F5;
	color: #1D267C;
	padding: 10px;
	border-bottom: 2px solid #fff;
	vertical-align: middle;
	font-size: 1.3rem;
}
.access_txt td{
	background: #f0f0f0;
	padding: 10px;
	border-bottom: 2px solid #fff;
	vertical-align: middle;
	font-size: 1.3rem;
}
.to_gmap{
	width: 300px;
	display: block;
	margin:0 auto 20px;
}



.route .btn_area{
	display: flex;
	margin-bottom: 20px;
	justify-content: space-between;
}
.route .btn_area p{
	background: #f0f0f0;
    border-radius: 10px;
    padding: 10px;
    margin-right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.25;
    font-size: 1.2rem;
    letter-spacing: -1px;
    font-weight: bold;
}
.route .tab_btn{
	text-align: center;
	width: 30%;
}
.route .btn_area p.active{
	background: #080059;
	color:#fff;
}
.route .panel_area .route_w{
	display: none;
}
.route .panel_area .route_w.active{
	display: block;
}
.route_i .imgarea img {
    object-fit: cover;
    height: 200px;
    width: 100%;
}
.panel_area{
	position: relative;
}
.swiper-button-prev, .swiper-container-rtl .swiper-button-next{
	left: -6%;
	background: url(../images/ginza0914/slide_arrow_l.png);
	width: 29px;
	height: 32px;
	background-size: cover;
}
.swiper-button-next, .swiper-container-rtl .swiper-button-next{
	right: -6%;
	background: url(../images/ginza0914/slide_arrow_r.png);
	width: 29px;
	height: 32px;
	background-size: cover;
}
.swiper-button-prev:after, .swiper-container-rtl .swiper-button-prev:after,
.swiper-button-next:after, .swiper-container-rtl .swiper-button-prev:after{
	display: none;
}

.about_ttl{
	font-size: 1.8rem;
	color: #1D267C;
	font-weight: bold;
	margin-bottom: 20px;
	border-bottom: 2px solid #1D267C;
}

.tencho{
	margin-bottom: 30px;
}
.tencho .imgarea{
	width: 33%;
	margin: 0 0 5% 5%;
	border-radius: 10px;
	overflow: hidden;
}
.tencho p{
	line-height: 1.5;
}









#covid{
	margin-bottom: 30px;
}

#reason_02{
	padding-bottom:40px;
	padding-bottom: 40px;
}
#reason_02 h2{
	margin-bottom: 40px;
}
.reason_02_i{
	background: #fff;
	margin-bottom: 20px;
}
.reason_02_i:nth-last-of-type(1){
	margin-bottom: 0;
}
.reason_02_i .ttl_w{
	padding: 10px;
	color: #fff;
	background: #1D267C;
}
.reason_02_i .ttl_w{
	position: relative;
}
.reason_02_i .ttl_w::after{
	content: "";
	background: url(../images/ginza0914/arrow_02.png);
	width: 20px;
	height: 20px;
	background-size: cover;
	display: block;
	position: absolute;
	bottom: 0px;
	right: 10px;
	transform: translate(0,-50%) rotate(180deg);
}
.reason_02_i .ttl_w.open::after{
	transform: translate(0,-50%) rotate(0deg);
}
.reason_02_i .ttl_w .num{
	width: 30px;
	text-align: center;
	font-size: 2.2rem;
	font-weight: bold;
	border-right: 2px solid #fff;
	margin-right: 10px;
}
.reason_02_i .ttl_w h3{
	font-size: 2.2rem;
	line-height: 1.25;
	margin-bottom: 5px;
}
.reason_02_i .ttl_w p{
	font-size: 1.6rem;
	line-height: 1.25;
	font-weight: bold;
}
.reason_02_i_con{
	padding: 20px;
	display: none;
}
.reason_02_i_con h4{
	font-size: 1.6rem;
	line-height: 1.5;
	margin-bottom: 15px;
}
.reason_02_i_con p{
	line-height: 1.5;
}
.reason_02_i_con .imgarea{
	margin-top: 20px;
}


#voice .voice_h {
    margin-bottom: 40px;
}




.cta{
	padding: 20px 0 40px;
}
.cta .in a{
	display: inline-block;
	margin-top: 20px;
}


#idcard{
	padding-bottom: 30px;
}
#idcard .l_txt{
	margin-bottom: 20px;
	line-height: 1.5;
	margin-top: 30px;
}
#idcard .l_txt .m{
	font-size: 2.0rem;
	font-weight: bold;
}
#idcard .l_txt .l{
	font-size: 2.6rem;
	font-weight: bold;
	color: #1D267C;
	background:linear-gradient(transparent 60%, #FFEF00 60%);
}
#idcard .imgarea{
	margin: 20px 0;
}
#idcard .s_txt{
	font-size: 1.2rem;
	line-height: 1.5;
}


#faq{
	padding: 20px 0 40px;
}
#faq h2{
	margin-bottom: 30px;
}
#faq dl{
	padding: 15px 0;
}
#faq dt{
	position: relative;
	background: #DBDBDB;
	padding:15px 10px;
	padding-right: 40px;
	box-sizing: border-box;
	border-radius: 10px;
	margin-bottom: 10px;
}
#faq dt:before{
	background: #05255c;
	width: 10px;
	height: 2px;
	content: "";
	display: block;
	position: absolute;
	right: 10px;
	top:50%;
	transform: translate(0,-50%);
}
#faq dt:after{
	background: #05255c;
	width: 2px;
	height: 10px;
	content: "";
	display: block;
	position: absolute;
	right: 14px;
	top:50%;
	transform: translate(0,-50%);
}
#faq dt.open:after{
	display: none;
}
#faq dt.flex{
	align-items: center;
}
#faq dt .q_icon{
	width: 30px;
	flex-shrink: 0;
	margin-right: 15px;
}
#faq dt .q_icon span{
	width: 30px;
	height: 30px;
	display:flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	background: #1D267C
}
#faq dt .q_txt{
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.25;
}
#faq dd{
	line-height: 1.5;
	display: none;
	margin-bottom: 20px;
}
#faq dd .a_icon{
	width: 30px;
	flex-shrink: 0;
	margin-right: 15px;
	font-size: 1.6rem;
	color: #E50011;
	text-align: center;
	font-weight: bold;
}
#faq dd .a_icon span{
	width: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.faq_utxt{
	margin-top: 20px;
}


#shops{
}
#shops .sec_ttl_02{
	margin-bottom: 20px;
	text-align: center;
}
#shops .sec_ttl_02 img{
	width: 50px;
}
#shops .sec_ttl_02 span {
    display: block;
    font-size: 2.6rem;
    margin-top: 20px;
    font-weight: 900;
		line-height: 1.2;
}
.shops_w{
	justify-content:space-between;
}
.shops_i{
	width: 48%;
	margin-bottom: 30px;
}
.shops_i h3 {
	font-size: 2.0rem;
	color: #080059;
	margin-top: 20px;
	font-weight: 900;
	padding-bottom: 10px;
	border-bottom: 3px solid;
	margin-bottom: 20px;
}
.shops_i table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 5px 5px;
	margin-bottom: 20px;
}
.shops_i table th {
	background: #dad9e6;
	padding:10px 20px;
	color: #080059;
}
.shops_i table td {
  padding-left: 15px;
}
.shops_i a{
	display: block;
	padding: 10px 20px;
	text-align: center;
	background: #080059;
	border-radius: 5px;
	color: #fff;
}

.shops_tab_w{
	justify-content: space-between;
}
.shops_tab_i{
	width: 30%;
}
.shops_tab_i h3{
	background: #080059;
	padding: 10px;
	color: #fff;
	text-align: center;
	margin-bottom: 10px;
}
.shops_tab_i ul li{
	border-bottom: 1px solid #444;
}
.shops_tab_i ul li a,
.shops_tab_i ul li span{
	display: block;
	width: 100%;
	padding: 10px 0;
}
.shops_tab_i ul li a:hover,
.shops_tab_i ul li span:hover{
	opacity: 0.6;
}
.shops_tab_area li,
.shops_tab_area_02 li{
	display: flex;
	align-items:center;
	justify-content: space-between;
	padding-right: 5px;
}
.shops_tab_area li.active,
.shops_tab_area_02 li.active{
	background: #efedff;
}
.shops_tab_area li:after,
.shops_tab_area_02 li:after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 7.5px 0 7.5px 10px;
	border-color: transparent transparent transparent #080059;
}
.shops_tab_area_02 .parent{
	display:none;
}
.shops_tab_area_02 .parent.active{
	display: block;
}
.shops_tab_shop li{
	display: none;
}

.shops_ac_w h3{
	background: #080059;
	padding: 10px;
	color: #fff;
	margin-bottom: 10px;
	font-size: 1.6rem;
	display: flex;
	align-items:center;
	justify-content: space-between;
	padding-right: 10px;
}
.shops_ac_w h3:after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 7.5px 0 7.5px;
	border-color:#fff transparent transparent transparent;
}
.shops_ac_w .area_parent_w{
	display: none;
}
.shops_ac_w .parent > li span{
	background: #efedff;
	font-size: 1.6rem;
	padding: 10px;
	display: block;
}
.shops_ac_w .parent > li{
	margin-bottom: 5px;
}
.shops_ac_w .shop_i{
	display: none;
}
.shops_ac_w .shop_i li{
	border-bottom: 1px solid #ccc;
}
.shops_ac_w .shop_i li a{
	padding:20px;
	display:block;

}
@media screen and (max-width: 640px) {
	.shops_i{
		width: 100%;
		margin-bottom: 30px;
	}
	.shops_i h3{
		font-size: 3.2rem;
	}
}

footer{
	padding-bottom: 120px;
	background: #dfdfdf;
	padding-top: 40px;
	text-align: center;
}
footer .cp_name{
	margin-bottom: 20px;
	font-weight: bold;
	font-size: 2.0rem;
}

.sp_foot {
  position: fixed;
  bottom: 0;
  width: 375px;
  box-sizing: border-box;
  z-index: 9999;
  text-align: center;
  display: flex;
  justify-content: space-between;
	display: none;
}

.sp_foot>a {
  display: block;
}
.totop{
	position: absolute;
right: 10px;
bottom: 80px;
width: 50px;
}


.item_w{
	padding: 30px 0;
}















