/*----------------------------------
　モーダル共通　　
----------------------------------*/
.sp {display: none;}

body {
	min-width: 0;
	font-size: 13px;
}

.inner {
	max-width: 820px;
	margin: 20px auto 0;
	padding-bottom: 50px;
}
.inner:after {
	content: "";
	display: block;
	clear: both;
}
.border_b {
	border-bottom: 2px solid #c7c7c7;
	padding-bottom: 2em;
}
.pink {
	font-size: 15px;
	color: #b50081;
}
.ml_em {
	margin-left: 1.5em;
}
.mt_1em {
	margin-top: 1em;
}


h1,th {
	font-weight: normal;
}

h1 {
	width: 100%;
	background: #b50081;
	padding-top: 9px;
  padding-bottom: 8px;
}
h1 span {
	display: inline-block;
	height: 28px;
	line-height: 28px;
	font-size: 18px;
	color: #fff;
	vertical-align: middle;
}
h1 span:before {
	content: "";
	display: inline-block;
	height: 28px;
	width: 62px;
	margin-left: 6px;
	background-position: center center;
	background-repeat: no-repeat;
	vertical-align: middle;
}

h1 + p {
	font-size: 14px;
	margin-top: 10px;
	margin-bottom: 10px;
}

p + article {
	margin-top: 10px;
}
h2 {
	padding-left: 12px;
	height: auto;
	line-height: 1.2em;
	padding-top: 13px;
	padding-bottom: 10px;
	font-size: 15px;
	color: #fff;
	background: #333;
}
/*h2 {
	padding-left: 12px;
	height: 41px;
	line-height: 41px;
	font-size: 15px;
	color: #fff;
	background: #333;
}*/

.cont {
	margin: 18px 19px 0;
}
.cost-table-cont {
	overflow: hidden;
}

small {
	font-size: 12px;
}

table {
	width: 100%;
	text-align: left;
}
/*table thead th {
	padding-left: 12px;
	height: 41px;
	font-size: 15px;
	color: #fff;
	background: #333;
	text-align: left;
}*/
table tbody {
	font-size: 13px;
}
table tbody th {
	height: 39px;
	padding-left: 14px;
	background: #f2d7ea;
}
table tbody tr + tr th {
	border-top: 1px solid #fff;
}
table tbody tr:last-child th {
	border-bottom: 1px solid #f2d7ea;
}
table tbody td {
	padding-left: 13px;
}
table tbody td.row_2nd {
	border-right: 1px solid #e6e6e6;
}
table tbody td {
	border-top: 1px solid #e6e6e6;
}
table tbody tr:last-child td {
	border-bottom: 1px solid #e6e6e6;
}
h2 + table tr:first-child th, h2 + table tr:first-child td {
	border-top: none;
}

article + article {
	margin-top: 30px;
}


@media (min-width: 769px) {
	body {
	    min-width: 0px;
	}
}


a.btn {
	display: inline-block;
	width: 378px;
	padding-top: 3px;
	padding-bottom: 2px;
	border: 2px solid #b50081;
	border-radius: 4px;
	background-color: #b50081;
	font-size: 13px;
	color: #fff;
	margin-top: 1em;
}
a.btn:after {
	content: "";
	display: inline-block;
	width: 15px;
	height: 15px;
	background-image: url(../images/modal/btn_icon.png);
	background-position: top;
	position: relative;
	right: -20px;
	top: 3px;
}
a.btn:hover {
	color: #b50081;
	background-color: #fff;
}
a.btn:hover:after {
	background-position: bottom;
}
a.btn span {
	margin-left: 18px;
}

/*----------------------------------
　シャトルバス
----------------------------------*/
.bus table tbody th {
	width: 150px;
}
.bus h1 span:before {
	background-image: url(../images/modal/icon01.png); 
}

.map {
	line-height: 0;
}

.bus_map {
	position: relative;
}

.bus_map img {
	display: inline-block;
	width: 100%;
	font-size: 0;
	line-height: 0;
}

.bus article + article h2 {
	position: relative;
	margin-top: 54px;
}

.bus .map + article h2:before {
	content: "";
	display: block;
	height: 2px;
	width: 100%;
	background-image: url(../images/modal/dot-border.gif);
	position: absolute;
	top: -31px;
	left: 0;
}


/*----------------------------------
　駐車場
----------------------------------*/
.park table tbody th {
	width: 150px;
}
.park h1 span:before {
	background-image: url(../images/modal/icon02.png); 
}


/*----------------------------------
　配送
----------------------------------*/
.delivery h1 span:before {
	background-image: url(../images/modal/icon03.png); 
}
.delivery h1 + p {
    margin-top: 20px;
    margin-bottom: 20px;
}
.mb_em p {
	margin-bottom: 1em;
}
.mb_em .cont {
	overflow: hidden;
}

/*----------------------------------
　リサイクル
----------------------------------*/

.recycle h1 span:before {
    width: 0px;
}

/*----------------------------------
 ATM
----------------------------------*/

.atm h1 span:before {
    width: 0px;
}

/*----------------------------------
　スマホ版
----------------------------------*/
@media (max-width:768px){
	.sp {display: block;}

	.inner {
		padding-left: 15px;
		padding-right: 15px;
		box-sizing: border-box;
		padding-bottom: 37px;
	}

	h1 {
		box-sizing: border-box;
		padding-left: 1em;
		padding-right: 1em;
	}

	h1 span {
		height: auto;
		font-size: 15px;
		line-height: 19px;
		padding-left: 28px;
    text-indent: -28px;
	}

	h1 + p {
    font-size: 12px;
    margin-top: 10px;
    margin-bottom: 10px;
	}

	h1 span:before {
		height: 19px;
		width: 28px;
		margin-left: 0px;
	}

	h2 {
		height: auto;
		line-height: 1.2em;
		padding-top: 6px;
		padding-bottom: 5px;
		font-size: 13px;
	}

	table tbody {
    font-size: 12px;
	}
	table tbody th,
	table tbody td {
		padding-top: 7px;
		padding-bottom: 6px;
		vertical-align: top;
	}
	table tbody th {
    height: auto;
    padding-left: 9px;
  }

  article + article {
    margin-top: 19px;
	}

	small {
	font-size: 10px;
	}


/*---シャトルバス---*/
	.bus h1 span:before {
    background-image: url(../images/modal/icon01_sp.png);
	}
	.bus table tbody th {
    width: 23.96%;
	}


/*---駐車場---*/
	.park h1 span:before {
    background-image: url(../images/modal/icon02_sp.png);
	}
	.park table tbody th {
    width: 23.96%;
	}

	.bus article + article h2 {
	position: relative;
	margin-top: 30px;
	}

	.bus article + article h2:before {
	top: -20px;
	}


/*---配送---*/
	.delivery {
		font-size: 12px;
	}
	.delivery .cont {
		margin-left: 0;
		margin-right: 0;
	}
	.delivery h1 span:before {
		background-image: url(../images/modal/icon03_sp.png); 
	}
	.delivery a.btn span {
    margin-left: 2px;
    display: inline-block;
    padding-left: 1em;
    text-indent: -1em;
	}
	a.btn {
		width: 269px;
		margin: 0 auto;
		display: block;
	}
	a.btn:after {
		right: -2px;
    top: -6px;
	}
	.pink {
    font-size: 13px;
	}

}

@media (max-width:768px){
		a.btn {
		width: 246px;
	}
}

#shopAddress + #info { height: 300px; }
@media (min-width:769px){
	#shopAddress + #info {
		float: left;
		width: 50%;
	}
	#shopAddress ~ #side {
		float: right;
		width: 45%;
	}
	#shopAddress ~ #side .inner {
		margin: 0;
	}
	#shopAddress ~ #side .button-group {
		margin-top: 10px;
	}
}


/*----------------------------------
　配送サービス料金表追加/190328
----------------------------------*/
.delivery-cost-table {
	text-align: center;
	margin-bottom: 20px;
	width: auto;
	float: left;
}
.delivery-cost-table + .delivery-cost-table {
	float: right;
}
.delivery-cost-table tr {
}
.delivery-cost-table th,
.delivery-cost-table td {
	text-align: center;
	padding: 5px !important;
	vertical-align: middle;
}
.delivery-cost-table th {
	color: #000;
	border: 1px solid #333;
	background: #f2d7ea;
}
.delivery-cost-table tbody th {
	padding-left: 0;
	height: auto;
}
.delivery-cost-table tbody td {
    padding-left: 0;
    border: 1px solid #333;
}
.delivery-cost-table tbody tr:last-child td,
.delivery-cost-table tbody tr:last-child th {
    border-bottom: 1px solid #333;
}
@media (max-width:768px){ 
	.delivery-cost-table {
		width: 100%;
	}
}