@charset "utf-8";

/* ==========================================================================
   access
   ========================================================================== */
@media (min-width: 960px){
#page_access .contents_wrap .wrap{
	max-width: calc(1000px + 10vw + 10vw);
	padding: 0 10vw;
}
}


/* hours
============================================================ */
#access .hours table{
	width: 100%;
	border-collapse: collapse;
	margin: 0;
	padding: 0;
}

#access .hours table tr{
	line-height: 1;
}

#access .hours table tr td{
	width: 8.0%;
	font-size: 1.4rem;
	letter-spacing: 0.04em;
	text-align: center;
	padding: 16px 0;
}
@media (min-width: 440px){
#access .hours table tr td{
	width: 10.5%;
	font-size: 1.8rem;
  padding: 28px 0;
}
}

#access .hours table tr td.column-1{
	color: #222;
	width: 22.0%;
	text-align: left;

}
@media (min-width: 440px){
#access .hours table tr td.column-1{
	width: 24%;
}
}

#access .hours table tr.row-1 td{
	color: #fff;
	font-size: 1.3rem;
	font-weight: 400;
	vertical-align: middle;
	line-height: 1;
	padding: 10px 4px 10px 0;
	background-color: #4f926d;
	border-bottom: 0px solid #ddd;
}
@media (min-width: 440px){
#access .hours table tr.row-1 td{
	font-size: 1.6rem;
	letter-spacing: 0.08em;
	text-align: center;
	padding: 20px 0;
}
}

#access .hours table tr.row-2 td{
	color: #4f926d;
	font-size: 1.4rem;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 900;
	vertical-align: middle;
	border-bottom: 1px solid #ddd;
}
@media (min-width: 440px){
#access .hours table tr.row-2 td{
	font-size: 1.8rem;
}
}

#access .hours table tr.row-1 td.column-1{
	font-size: 1.4rem;
	padding: 10px 0 10px 6px;
}
@media (min-width: 440px){
#access .hours table tr.row-1 td.column-1{
	font-size: 1.9rem;
	padding: 20px 0;
}
}

#access .hours table tr.row-2 td.column-1{
	color: #222;
	font-size: 1.5rem;
	font-family: "Prompt", sans-serif;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.1;
}
@media (min-width: 440px){
#access .hours table tr.row-2 td.column-1{
	font-size: 2.0rem;
	text-align: center;
	letter-spacing: 0.08em;
	line-height: 1.2;
	padding-left: 3px;
}
}

#access .hours table tr.row-2 td.column-1 span{
	font-size: 1.2rem;
	font-weight: 400;
	letter-spacing: 0;
	font-feature-settings: "palt" 1;
}
@media (min-width: 440px){
#access .hours table tr.row-2 td.column-1 span{
	font-size: 1.5rem;
	text-align: center;
	letter-spacing: 0.04em;
	padding-left: 0.2em;
}
}


/* shop_img
============================================================ */
#access ul.shop_img{
	display: flex;
	flex-direction: column;
	align-items: center;
}
@media (min-width: 440px){
#access ul.shop_img{
	flex-direction: row;
	align-items: flex-start;
	justify-content: space-between;
}
}

#access ul.shop_img li{
	width: 100%;
}
@media (min-width: 440px){
#access ul.shop_img li{
	width: 48.4%;
}
}

#access ul.shop_img li img{
	border-radius: 10px;
}


/* overview
============================================================ */
#access .overview .wrap{
	width: 100%;
	padding: 0 6vw;
	box-sizing: border-box;
}
@media (min-width: 960px){
#access .overview .wrap{
	width: 900px;
	padding: 0;
	margin: 0 auto;
}
}

#access .overview table{
	width: 100%;
	border-collapse: collapse;
	margin: 0;
	padding: 0;
}

#access .overview table tr{
	line-height: 2.0;
}

#access .overview table tr td{
	line-height: 1.6;
	letter-spacing: 0.06em;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	padding: 16px 0 16px 16px;
}
@media (min-width: 440px){
#access .overview table tr td{
	height: 46px;
	letter-spacing: 0.08em;
	box-sizing: border-box;
	padding: 20px 0 20px 22px;
}
}

#access .overview table tr td span{
	font-size: 92%;
	display: inline-block;
	line-height: 1.4!important;
	text-indent: -1em;
  padding-left: 1em;
}

#access .overview table tr td.column-1{
	color: #fff;
	width: 23%;
	font-weight: 500;
	text-align: center;
	vertical-align: middle;
	padding-left: 2px;
	background-color: #4f926d;
}
@media (min-width: 440px){
#access .overview table tr td.column-1{
	width: 20%;
	text-align: left;
	padding: 0 0 0 20px;
}
}


/* map
============================================================ */
#page_access .map{
	height: 460px;
	border-radius: 20px 0px 0px 20px;
	overflow: hidden;
	margin-right: calc(50% - 50vw);
}
@media (min-width: 440px){
#page_access .map{
	height: 500px;
}
}

#page_access .map iframe{
	width: 100%;
	height: 460px;
}
@media (min-width: 440px){
#page_access .map iframe{
	height: 500px;
}
}

#googlemap_btn .btn{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

#googlemap_btn .btn a{
	color: #fff;
	width: 100%;
	height: 50px;
	font-size: 1.4rem;
  font-weight: 500;
	line-height: 1;
  letter-spacing: 0.06em;
	text-align: center;
  display: flex;
	align-items: center;
	justify-content: center;
  position: relative;
	background-color: #4f926d;
	border-radius: 7px;
	box-sizing: border-box;
	transition: all 0.2s ease;
}
@media (min-width: 440px){
#googlemap_btn .btn a{
	width: 280px;
	height: 58px;
  font-size: 1.6rem;
}
}

#googlemap_btn .btn a::after{
	content: "";
	width: 13px;
	height: 13px;
	background-image: url(../img/common/icon-arrow-rp.svg);
	background-size: 13px 13px;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	right: 20px;
	margin: -6.5px 0 0 0;
}
@media (min-width: 440px){
#googlemap_btn .btn a::after{
	width: 13px;
	height: 13px;
	background-size: 13px 13px;
  margin: -6.5px 0 0 0;
}
}

@media (min-width: 960px){
#googlemap_btn .btn a:hover{
	color: rgba(255, 255, 255, 0.6);
}
}


/* root
============================================================ */

#root div.line{
	width: 100%;
	height: 1px;
	background-color: #DDD;
	margin: 30px 0 34px 0;
}

#root ul.root_block{
	display: flex;
	flex-direction: column;
	align-items: center;
}
@media (min-width: 440px){
#root ul.root_block{
	flex-direction: row;
	align-items: flex-start;
	justify-content: space-between;
}
}

#root h4{
	font-size: 1.5rem;
	font-weight: 500;
	margin: 10px 0 0 0;
}
@media (min-width: 440px){
#root h4{
	font-size: 1.6rem;
}
}

#root h4 span{
	color: #4f926d;
}

#root ul.root_block li{
	width: 100%;
}
@media (min-width: 440px){
#root ul.root_block li{
	width: 30%;
}
}

#root ul.root_block li.line{
	border-top: 0;
	margin: 10px 0;
}
@media (min-width: 440px){
#root ul.root_block li.line{
	width: 5%;
	border-top: 2px dotted #4f926d;
	margin: 105px 0 0 0;
}
}

#root ul.root_block li img{
	border-radius: 10px;
}

#root ul.root_block li p{
	font-size: 1.3rem;
	margin: 10px 0 0 0;
}
