.topInfo {
	background-color: #FFFFFF;
	padding: 1em;
	margin-bottom: 70px;
	/*margin-bottom: 10px;*/
	/*border-radius: 5px;*/
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}
.topInfo p {
	line-height: 200%;
}
.topInfo img {
	margin-right: 5px;
}

/* 混在しないように分けたファイル */
.slideView {
	min-height: 246px;
	min-width: 246px;
	position: relative;
}
.slideView::before{
	content:"";
  display: block;
  padding-top: calc((100% - 24px) / 4);
}
/* 650px以下 */
@media screen and (max-width: 761px) {.slideView::before{padding-top: calc((100% - 16px) / 3);}}
/* 523px以下 */
@media screen and (max-width: 634px) {.slideView::before{padding-top: calc((100% - 8px) / 2);}}
.slideView > div {
	position: absolute;
  top: 0;
  left: -4px;
  bottom: 0;
  right: -4px;
}
.slick p {
	width:calc((100% -16px) / 3);
	overflow:hidden;
	margin:0 4px;
}
.slick p img {
	width:100%;
	height:100%;
	object-fit:cover;
}
.slick-prev::before, .slick-next::before {
	color: gray !important;
}
.padding10 { padding:10px; }
.padding15 { padding:15px; }
.padding20 { padding:20px; }

.btnSmall { padding:5px 10px; }

.flexWidth50 {
	width:50%;
}
.selectPadding10{
	padding:10px;
	border:1px solid #999;
}
.selectDownButton {
	appearance: auto;
	background-position: right -10px center;
}

.listIcon {
	background-color:#999;
	border-radius: 50%;
	width: 24px !important;
	height: 24px;
	line-height:24px;
}
.myIcon {
	vertical-align: middle;
	display: inline !important;
	margin-right: 3px;
}
.errorMessagebox {
	border:3px solid #b5221f;
	background-color:#fbf5f5;
	padding:2em;
	color:#b5221f;
	font-size:14px;
	line-height:20px;
}
.successMessagebox {
	border:3px solid #54adcd;
	background-color:#f7fcfe;
	padding:2em;
	color:#54adcd;
	font-size:14px;
	line-height:20px;
}
/* tooltip */

/* 画像のトリミング */
#cropper-area {
	max-width: calc(100vw - 20px);
	width: 600px;
	height: calc(100vh - 300px);
	min-height: 200px;
	background-color:#fff;
	border:5px solid #333;
	box-sizing:content-box;
	border-radius:4px;
}
#cropper-area p.cropper-p {
	max-width: calc(100vw - 20px);
	width: 600px;
	height: calc(100vh - 300px);
	min-height: 200px;
	overflow:hidden;
}
.cropper-button {
	margin-top:0px !important;
	text-align:center;
}
.cropper-button button {
	margin:5px auto;
}
/* weeks */
.bgRotund {
	display:inline-block;
	width:36px;
	height:36px;
	border-radius:18px;
	line-height:34px;
	text-align:center;
}
.bgRotundSmall{
	display:inline-block;
	width:24px;
	height:24px;
	border-radius:12px;
	line-height:22px;
	text-align:center;
	margin-right:2px;
}
.bgRotund +.bgRotund {margin-left: 3px;}
@media screen and (max-width: 768px) {
	.bgRotund{
		display:inline-block;
		width:24px;
		height:24px;
		border-radius:12px;
		line-height:20px;
		font-size: 12px;
	}
	.bgRotundSmall{
		display:inline-block;
		width:24px;
		height:24px;
		border-radius:12px;
		line-height:20px;
		font-size: 12px;
	}
}

.bgGray {
	background-color:#ebebeb;
}
.bgGray2 {
	background-color:#f1f1f1;
}
.bgBrown {
	background-color:#4C3100;
}
.bgBrown2 {
	background-color:#332100;
}
.bgYellow {
	background-color:#ff6;
}
.bgBlue {
	background-color:#54adcd;
}
.bgBlue2 {
	background-color:#0655e5;
}
.bgOrange {
	background-color:#F4AD27;
}
.pointer {
	cursor: pointer;
}
.alignLeft  { text-align: left; }
.alignCenter{ text-align: center; }
.alignRight { text-align: right; }

.marginCenter {
	margin:0px auto;
}
.nonUnderline { text-decoration:none; }

.borderBottom {
	border-bottom: 1px solid #BABABA;
	padding: 17px 0 21px 0;
}
.blockLink:hover {
	background-color: #ffd;
}
textarea.formBgPink,
input.formBgPink {
	background-color:pink !important;
}

.int {
	text-align:right;
}

.fontColorBlack{ color: #000000; }
.fontColorBlue { color: #54adcd; }
.fontColorRed  { color: #cb2d2d; }
.fontColorGray { color: #888888; }
.fontColorGray2{ color: #727272; }
.fontColorDarkGray { color: #aaa; }
.fontColorLightGray { color: #ccc; }
.fontColorWhite { color: #FFF; }
.fontBold { font-weight:bold; }

.lineHeight100{ line-height:100%; }
.lineHeight140{ line-height:140%; }
.lineHeight180{ line-height:180%; }
.lineHeight200{ line-height:200%; }
.lineHeight240{ line-height:240%; }

/* プラン登録 */
.plan-edit .radio >  label            { margin-right:30px; }
.plan-edit .radio >  label:last-child { margin-right: 0px; }
.plan-edit .radio2 > label            { margin-right:30px; }
.plan-edit .radio2 > label:last-child { margin-right:15px; }
.plan-edit .radio3 > label            { margin-right:15px; }
.plan-edit .radio3 > label:last-child { margin-right: 0px; }
.radioGroup > label                   { margin-right:30px; }
.radioGroup >  label:last-child { margin-right: 0px; }

/* パンくず */
.breadcrumb {
  list-style: none;
  margin-bottom:20px;
}

.breadcrumb li {
  display: inline;
  list-style: none;
}

.breadcrumb li:after {
  content: ' > ';
  padding: 0 0.2em;
  color: #999;
}

.breadcrumb li:last-child:after {
  content: '';
}

.breadcrumb li a {
  text-decoration: none;
  color: #333;
}

.breadcrumb li:first-child a:before {
  font-weight: normal;
  font-size: 1.1em;
  color: #2e7fea;
}

.breadcrumb li a:hover {
  text-decoration: underline;
}

/* modal window */
#lean_overlay{
	position: fixed;
	z-index:100; 
	top: 0px;
	left: 0px;
	height: 100%;
	width: 100%;
	background: #000;
	display: none;
}

.w40 {
	width:40px;
}
.w80 {
	width:80px;
}
.w120 {
	width:120px;
}
.w100p {
	width:100%;
}
.vh80 {
	height:80vh;
}
.vh60 {
	height:60vh;
}
.informationPanel {
	background-color:#f1f1f1;
	padding:10px;
}
/* cropper.js */
.cropper-area img {
  display: block;
  max-width: 100%;
}
.errorBox {
	border:1px solid #f00;
	background-color:pink;
	padding:10px;
	font-weight:normal;
	margin-bottom:50px;
	color:red;
}
.successBox {
	border:1px solid #4395bf;
	background-color:#d4e4ec;
	padding:10px;
	font-weight:normal;
	margin-bottom:50px;
	color:#4395bf;
}
/* mypage menu */
.mypageMenu {
	width: 100%;
	background-color:#4a4a4a;
}
.mypageMenu ul {
	width: 100%;
	display: flex;
	list-style: none;
}
.mypageMenu ul li {
	min-width:180px;
	padding: 10px;
	box-sizing: border-box;
	border-right: 1px solid #808080;
	text-align: center;
}
.mypageMenu ul li a {
	text-decoration: none;
	color: #FFF;
}
/* slick の調整 */
.slick-track {
	margin:0px !important;
}
table.tableWidth100{
	width:100%;
}

.tableScrollWrap {
	overflow: auto;
	width: 100%;
}
.tableScroll {min-width: 800px;}

table.tableVertical th{
	width:initial;
	background-color:#F5F5F5;
	padding: 10px 5px !important;
}
table.tableVertical th,
table.tableVertical td {
  border: 1px solid #C4C4C4;
  font-weight: 400;
  font-size: 14px;
}

.modalWindow {
	width:600px;
	max-width: calc(100% - 20px);
	background-color:#fff;
	z-index:10000;
	padding:20px;
}
.modalWindow h5{
	font-size:18px;
	font-weight:400;
}
.bdRadius5{
	border-radius: 5px;
}
/* 購入モーダル */
.modalPriceBlock {
	box-sizing: border-box;
	padding: 62px 58px 70px;
}
table.priceTable  {
	box-sizing: border-box;
	margin-top: 10px;
	width: 100%;
}
table.priceTable th {
	text-align: left;
	font-weight: normal;
	clear: both;
}
table.priceTable td::before {
	content: "：";
	margin-right:10px;
}
table.priceTable th,
table.priceTable td {
	font-size: 18px;
	padding: 10px;
}
table.priceTable select {
	padding:10px;
}
#popularsDetailShop p.location::before  {
	content: url(../img/common/location.svg);
	vertical-align: middle;
	padding-right: 10px;
}
#popularsDetailShop p.phone::before  {
	content: url(../img/common/phone.svg);
	vertical-align: middle;
	padding-right: 10px;
}
#popularsDetailShop p.opentime::before  {
	content: url(../img/common/clock.svg);
	vertical-align: middle;
	padding-right: 10px;
}
#popularsDetailShop p.desktop::before  {
	content: url(../img/common/desktop.svg);
	vertical-align: middle;
	padding-right: 10px;
}
#popularsDetailShop p.data {flex:1}
#popularsDetailShop p.data::before  {
	content: "：";
	padding-right: 10px;
	overflow-wrap: break-word;
  word-wrap: break-word;
}
@media only screen and (max-width: 480px){
	.modalPriceBlock {
		box-sizing: border-box;
	 	padding: 20px;
		width:90%;
		max-height:75vh;
		overflow-y:auto;
	}
	table.priceTable th {
		font-weight:700;
		margin-top:20px;
	}
	table.priceTable td {
		margin-top:5px;
	}
	table.priceTable td::before {
		content: "";
		margin-right:0px;
	}
	table.priceTable th {
		border-bottom:1px solid #ccc;
	}
	table.priceTable th,
	table.priceTable td {
		display: block;
		width: 100%;
		padding: 0px;
	}
	#popularsDetailShop div {
		display: block;
	}
	#popularsDetailShop p {
		white-space:normal;
		width:100% !important;
	}
	#popularsDetailShop p.title {
		border-bottom: 1px solid #ccc;
	}
	#popularsDetailShop p.data {
		margin-bottom: 30px;
	}
	#popularsDetailShop p.data::before {
		content: "";
		padding-right: 0px;
	}
	#popularsDetailShop p.message-gray {
		padding: 10px;
	}
}




/* スケジュール参加者 */
#planScheduleList {
	position: absolute;
	width:360px;
	max-height:360px;
	overflow-y:auto;
	padding:12px;
	background-color: #fff;
	border:1px solid #ccc;
	line-height:20px;
	font-size:14px;
}
.planScheduleListClose{
	float: right;
	height:20px;
	width:20px;
	text-align:center;
	border:1px solid #ccc;
	border-radius: 10px;
	line-height:17px;
	color:#ccc;
}
.newsSeparator{
	border-bottom:1px solid #ddd;
	margin-bottom:30px;
	padding-bottom:30px;
}

#footerSitemap {
	width: 1080px;
	max-width: 100%;
	margin:0px auto;
}

#footerSitemap .footerSitemapbox {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-around;
    justify-content: space-around;
}
#footerSitemap .footerSitemapbox div {
	box-sizing:border-box;
	padding:20px;
	width: 28%;
}
#footerSitemap .footerSitemapbox h6 {
	font-size:14px;
	line-height: 240%;
	font-weight:normal;
	border-bottom: 1px solid #999;
}

.mapComInfo {margin-top: 50px;}

#footerSitemap .footerSitemapbox ul {
	margin-top:10px;
	margin-left: 14px;
	list-style-image:url(../img/common/chevron-right.svg)
}
#footerSitemap .footerSitemapbox ul li {
	font-size:14px;
	line-height: 180%;
}
#footerSitemap .footerSitemapbox ul li a {
	color: #FFF;
	text-decoration:none;
}
#footerSitemap .footerSitemapbox ul li a:hover {
	color: #999;
	text-decoration:underline;
}

@media screen and (max-width: 857px) {
	#footerSitemap .footerSitemapbox {
    -webkit-justify-content: start;
    justify-content: start;
		flex-direction: column;
		padding: 15px 0;
	}
	#footerSitemap .footerSitemapbox div {
		box-sizing:border-box;
		padding:5px 20px;
		width: 100%;
	}
	.mapComInfo {margin-top: 20px;}
}
/* ショップのメニュー部分 */
.shop-width {
	max-width: 900px;
	margin: 0 auto;
}
.shop-menu > div {
  width: 281px;
  height: 172px;
  /*background-color: #fff;*/
  border: 1px solid #4D4D4D;
  padding: 22px 30px;
  margin-bottom: 29px;
}
.shop-menu > div .hyperlink{text-decoration: none;}
.shop-menu > div > div > p:first-of-type {font-size: 20px;}
.shop-menu > div > div > p:first-of-type > img {
  display: inline-block;
  margin-left: 10px;
  height: 18px;
  vertical-align: bottom;
}
.shop-menu > div > div:first-of-type {margin-bottom: 18px;}
.regi-tag {
  font-size: 12px;
  color: #fff;
  padding: 4px 8px 5px;
  border-radius: 7px;
}
.shop-menu .prepared{
	background-color:#f1f1f1;
	color:#aaa;
}
@media screen and (max-width: 930px) {
  .shop-menu > div {
    margin: 0 0 29px;
    width: 48%;
  }
}
@media screen and (max-width: 620px) {
  .shop-menu > div {
    width: 100%;
  }
}

/* Mypage */
table.width100 {
	width: 100%;
}
tr.bdBottom {
	border-bottom: 1px solid #d4d4d4;
}
tr.dbdBottom {
	border-bottom: 3px solid #999;
}
tr.dbdTop {
	border-top: 3px solid #999;
}
table.paymentTable {min-width: 645px;}
table.paymentTable th,
table.paymentTable td {
	padding: 1em;
}
table.subscTable th,
table.subscTable td {
	padding: 1em;
}

table.historyTable {min-width: 645px;}
table.historyTable th,
table.historyTable td {
	padding: 1em;
}
table.historyTable th:nth-child(1),
table.historyTable td:nth-child(1) {width: 8em;}
@media screen and (max-width: 768px) {
	table.historyTable {min-width: 0;}
	table.historyTable th,
	table.historyTable td {
		box-sizing:border-box;
		padding: 2px;
	}
	table.historyTable td:nth-child(2) > div {
		width: calc(100vw - 210px);
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	table.historyTable th:nth-child(3),
	table.historyTable td:nth-child(3) {width: 4.5em;}
	table.historyTable th {font-size:12px;}
	table.historyTable td {font-size:10px;}
	.sp-form-min {
		font-size: 12px!important;
		padding: 6px 10px 7px 10px!important;
		height: 37px!important;
	}

	table.subscTable th,
	table.subscTable td {
		padding: 1em 0.2em;
	}

	table.subscTable tr td:last-of-type {width: 96px;text-align: right;}
	table.subscTable tr td:first-of-type {min-width: calc(100vw - 128px);width: calc(100% - 90px);border-right:  1px solid #d4d4d4;}
}
.message .msgListHeader{
	height: 30px;
	background-color: #f5f5f5;
	border: 1px solid #D9D9D9;
}
.message .msgListHeader p {
	line-height: 30px;
	color: #333333;
	font-size: 14px;
}
.message .listAdd {
	background-color:#FFF;
	border-right: 1px solid #D9D9D9;
	border-bottom: 1px solid #D9D9D9;
	border-left: 1px solid #D9D9D9;
}
.listAdd .unread{
	background-color:#ffffff;
}
.listAdd .readed{
	background-color:#f0f0f0;
}
.listAdd .readed p{
	color: #999 !important;
}
.unReadCount{
	width: 18px;
	height: 18px;
	background-color: #f50505;
	border-radius: 9px;
	color: #FFF;
	text-align: center;
	line-height: 14px;
	font-size:10px;
	font-weight: bold;
	position: absolute;
	bottom: 0;
	right: 0;
}
table.detail_shop_list {
	width: 100%;
	border-collapse: collapse;
	border-bottom:1px solid #dedede;
}
table.detail_shop_list tr {
	border-top:1px solid #dedede;
}
table.detail_shop_list th {
	min-width: 30%;
	border-right: 1px solid #dedede;
}
.nowrap {
	white-space: nowrap;
}
