
/* 基本パーツ */
/* ----------------------------------------------------- */

input[type="submit"]::-moz-focus-inner,
input[type="button"]::-moz-focus-inner{
    border :0px;
}

/* WEB選択画面 */
/* ----------------------------------------------------- */
ul.web-select{
	margin: 0 0 0;
	padding-top: 20px;
}
ul.web-select li{
	width: 90%;
	margin: 0 auto 25px;
}
/*　ボタン */
/* ----------------------------------------------------- */
a.reg-btn,
button.reg-btn{
	width: 50%;
	padding: 10px 0;
	text-align: center;
	color: #fff;
	display: block;
	text-decoration: none;
	font-size: 16px;
	font-weight: bold;
	background: #2cb2eb;
	border-radius: 100px;
	margin: 0 auto;
}
a.reg-btn2{
	width: 50%;
	padding: 10px 0;
	text-align: center;
	color: #2cb2eb;
	border: 2px solid #2cb2eb;
	display: block;
	text-decoration: none;
	font-size: 16px;
	font-weight: bold;
	background: #fff;
	border-radius: 100px;
	margin: 0 auto;
}
a.reg-btn3{
	width: 50%;
	padding: 10px 0;
	text-align: center;
	color: #fff;
	display: block;
	text-decoration: none;
	font-size: 16px;
	font-weight: bold;
	background: #80c646;
	border-radius: 100px;
	margin: 0 auto;
}
/* ショップIDセット */
/* ----------------------------------------------------- */

div.shop-id{
	background: #fff;
	border-radius: 6px;
	width: 90%;
	margin: 60px auto 0;
	padding: 20px 0 20px;
	mini-height:220px;
}
div.shop-id dt{
	text-align: center;
	font-size: 22px;
	font-weight: bold;
	border-bottom: 1px solid #ccc;
	margin: 0 0 30px;
	padding-bottom: 10px;
}
div.shop-id dd{
	text-align: center;
	margin: 0 0 20px;
}
div.shop-id dd.name{
	font-size: 22px;
	font-weight: bold;
}
div.shop-id dd img{
	width: inherit;
	max-width: 180px;
}
div.shop-id dd.txt{
	margin: 0 20px;
	font-weight: bold;
	font-size: 18px;
}
/* 会員登録画面 */
/* ----------------------------------------------------- */
dl.logo-area{
	background: #fff;
	width: 90%;
	margin: 10px auto 0;
	padding: 0 0 10px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
}
dl.logo-area dt{
	margin: 0 0;
	text-align: center;
}
dl.logo-area dt img{
	width: inherit;
	max-width: 180px;
}
dl.logo-area dd{
	text-align: center;
	font-weight: bold;
	font-size: 22px;
	margin: 0;
}
div.reg-wrap{
	width: 90%;
	background: #fff;
	padding: 0 0 20px;
	margin: 0 auto 25px;
	border-bottom-left-radius: 6px;
	border-bottom-right-radius: 6px;
}
div.reg-wrap dt{
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	border-bottom: 1px solid #ccc;
	margin: 0 0 16px;
	padding-bottom: 10px;
	color: #2cb2eb;
}
div.reg-wrap dd{
	margin: 0 0 15px;
	text-align: center;
}

div.reg-wrap dd.ttl{
	font-size: 18px;
	width: 90%;
	margin: 0 auto 15px;
	font-weight: bold;
	text-align: left;
}
div.reg-wrap dd.txt br{
	display: none;
}
div.reg-wrap dd.under20{
	margin-bottom: 20px;
}
div.reg-wrap dd.under30{
	margin-bottom: 35px;
}
div.reg-wrap dd.sns{
	width: 90%;
	border: 1px solid #ccc;
	border-radius: 6px;
	text-align: center;
	font-size: 16px;
	margin: 0 auto 10px;
}
div.reg-wrap dd.sns a{
	padding: 15px 10px;
	display: block;
	box-sizing: border-box;
	text-decoration: none;
	color: #333;
}
div.reg-wrap dd.sns img{
	width: inherit;
}
div.reg-wrap dd.sns_apple{
	width: 82%;
	margin: 0 auto 15px;
}
div.reg-wrap dd.sns_apple img{
	width: 100%;
}
div.reg-wrap dd.a-left{
	text-align: center;
	width: 50%;
	margin: 0 auto 20px;
}
div.reg-wrap dd.a-left a{
	color: #333;
	text-decoration: none;
	border: 1px solid #ccc;
	padding: 10px 0;
	display: block;
	box-sizing: border-box;
	border-radius: 100px;
}

/* 基本情報 */
/* ----------------------------------------------------- */
div.basic-info{
	width: 90%;
	margin: 40px auto;
	padding: 20px 4%;
	background: #fff;
	box-sizing: border-box;
	border-radius: 6px;
}
div.basic-info h2{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 0 15px;
	font-size: 22px;
	text-align: left;
}
div.basic-info div.wrap{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	margin: 0 0 12px;
}
div.basic-info div.wrap dl{
	margin: 0 12px 0 0;
}
div.basic-info div.wrap dl:last-child{
	margin: 0;
}
div.basic-info div.wrap dt{
	font-weight: bold;
}
div.basic-info div.wrap dd label{
	font-weight: bold;
}
div.basic-info div.wrap dd.miss input{
	background: rgba(255,242,242,1.00);
}
div.basic-info dl.add{
	margin: 0 0 10px;
}
div.basic-info dl.add dt{
	font-weight: bold;
}
div.basic-info dl.add dd{
	margin: 0 0 6px;
}

div.basic-info dl.confirm{
	margin: 0 0 15px;
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
}
div.basic-info dl.confirm dt{
	font-weight: bold;
}
div.basic-info dl.confirm dd img{
	width: 80%;
	max-width: 500px;
}
/* コンテンツ共通 */
/* ----------------------------------------------------- */
p.error{
	color: rgba(251,66,69,1.00);
}
p.other{
	font-weight: bold;
	font-size: 18px;
	margin: 0 4% 12px;
}
p.con-info{
	font-weight: bold;
	font-size: 18px;
}
p.con-info span{
	font-size: 16px;
}
p.con-info span.sb{
	margin-left: 20px;
}
div.base-col{
	width: 94%;
	margin: 0 auto 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
}
div.base-col h2{
	font-size: 16px;
	margin: 0 0 10px;
	padding: 10px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	background: #ecf8fd;
	border-bottom: 1px solid #2db3eb;
	text-align: left;
	clear: both;
}
div.base-col h2 span{
	font-size: 15px;
	font-weight: normal;
	float: right;
}
div.base-col h2 span a.select-btn{
	text-decoration: none;
	color: #333;
	padding: 6px 8px;
	display: inline-block;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 4px;
}
div.base-col h3{
	text-align: left;
	margin: 0 2% 8px;
	padding: 6px 0;
	border: none;
	background: none;
}
div.base-col h3.ttl{
	color: #2cb2eb;
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 2% 10px;
	font-size: 20px;
}
div.base-col p{
	margin: 0 2% 15px;
}
div.base-col p.send-btn{
	margin: 0 0 25px;
}
div.base-col ul{
	margin: 0 0 20px;
}
div.base-col ul li{
	padding: 0 0 10px;
	border-bottom: 1px solid #ccc;
	margin: 0 2% 12px;
	font-weight: bold;
}
div.base-col ul li span{
	width: 100px;
	text-align: left;
	color: #2cb2eb;
	display: inline-block;
}
div.base-col ul li span.nomal{
	font-weight: normal;
	color: #333;
	width: auto;
}
div.base-col ul li:last-child{
	border-bottom: none;
	padding-bottom: 0;
}
div.base-col ul.marker01{
	margin: 0 0 30px;
}
div.base-col ul.marker01 li{
	margin: 0 2% 7px;
	font-weight: normal;
	padding: 0;
	border-bottom: none;
}

/* div.wrap */
div.base-col div.wrap{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	margin: 0 3% 12px;
}
div.base-col div.wrap dl{
	margin: 0 12px 0 0;
}
div.base-col div.wrap dl:last-child{
	margin: 0;
}
div.base-col div.wrap dt{
	font-weight: bold;
}
div.base-col div.wrap dd label{
	font-weight: bold;
}
div.base-col div.wrap dd.miss input{
	background: rgba(255,242,242,1.00);
}
div.base-col div.wrap:last-child{
	margin: 0 3% 40px;
}

/* div.wrap2 */
div.base-col div.wrap2{
	margin: 0 3% 12px;
}
div.base-col div.wrap2 dl{
	margin: 0 12px 0 0;
}
div.base-col div.wrap2 dl:last-child{
	margin: 0;
}
div.base-col div.wrap2 dt{
	font-weight: bold;
}
div.base-col div.wrap2 dd label{
	font-weight: bold;
}
div.base-col div.wrap2 dd.miss input{
	background: rgba(255,242,242,1.00);
}
div.base-col div.wrap2:last-child{
	margin: 0 3% 40px;
}
div.base-col dl.add{
	margin: 0 0 10px;
}
div.base-col dl.add dt{
	font-weight: bold;
}

div.base-col table.conf-t{
	width: 96%;
	margin: 0 auto;
}
div.base-col table.conf-t th{
	color: #2cb2ed;
	width: 100px;
	font-weight: bold;
	border-bottom: 1px solid #ccc;
	padding: 8px 0;
}
div.base-col table.conf-t td{
	font-weight: bold;
	border-bottom: 1px solid #ccc;
	padding: 8px 0;
}
div.base-col table.conf-t tr.last th,
div.base-col table.conf-t tr.last td{
	border-bottom: none;
}
/* ----------------------------------------------------- */
/* トップページ */
/* ----------------------------------------------------- */
/* 順番予約 */
dl.top-news{
	border: 1px solid #ccc;
	border-radius: 6px;
	width: 94%;
	margin: 0 auto 15px;
}
dl.top-news dt{
	font-size: 18px;
	font-weight: bold;
	padding: 8px 6px;
	box-sizing: border-box;
	background: #ecf7e3;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	border-bottom: 1px solid #72d231;
}
dl.top-news dt i{
	font-weight: normal;
	color: #5eb026;
	font-size: 16px;
}
dl.top-news dd{
	margin: 0;
	background: #fff;
	border-bottom-left-radius: 6px;
	border-bottom-right-radius: 6px;
}
dl.top-news dd ul{
	margin: 0;
}
dl.top-news dd ul li{	
	box-sizing: border-box;
	font-size: 16px;
	border-bottom: 1px solid #ccc;
}
dl.top-news dd ul li.none{
	padding: 10px;
	box-sizing: border-box;
}
dl.top-news dd ul li a{
	text-decoration: none;
	color: #333;
	display: block;
	padding: 10px;
}
dl.top-news dd ul li:last-child{
	border-bottom: none;
}

#status-wrap{
	border: 1px solid #ccc;
	border-radius: 6px;
	width: 94%;
	margin: 0 auto 15px;
}
#status-wrap h2{
	background: #ecf8fd;
	padding: 10px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	text-align: left;
	font-size: 18px;
	margin: 0 0;
	border-bottom: 1px solid #2db3eb;
	clear: both;
}
#status-wrap h2 span{
	float: right;
	width: 80px;
	text-align: center;
	font-size: 16px;
	margin-top: -6px;
}
#status-wrap h2 span a{
	padding: 7px 0;
	display: block;
	border: 1px solid #ccc;
	color: #333;
	font-weight: bold;
	font-size: 14px;
	text-decoration: none;
	border-radius: 6px;
	background: #fff;
}
#status-wrap div.col{
	background: #fff;
	padding: 3% 3% 2%;
	box-sizing: border-box;
}

#status-wrap div.col p.time-txt{
	color: #2db3eb;
	font-size: 17px;
	margin: 0 0 10px;
	font-weight: bold;
	text-align: center;
}

#status-wrap div.col ul.sum{
	margin: 0 0 22px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	justify-content:space-between;
}
#status-wrap div.col ul.sum li{
	width: 47%;
	padding: 10px 0;
	border: 3px solid #3eb8ec;
	border-radius: 6px;
	font-size: 20px;
	text-align: center;
	line-height: 1.2;
	font-weight: bold;
}
#status-wrap div.col ul.sum li span{
	font-size: 30px;
}
#status-wrap div.col ul.sum li.blue{
	background: #3eb8ec;
	color: #fff;
}
#status-wrap div.col p.catch{
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	margin: 0 0 10px;
	color: #80c646;
}
#status-wrap div.col div.txt-list{
	margin: 0 0 15px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}
#status-wrap div.col div.txt-list dl{
	border-top: 1px solid #ccc;
	padding: 10px;
	box-sizing: border-box;
}
#status-wrap div.col div.txt-list dt{
	font-size: 16px;
	float: left;
}
#status-wrap div.col div.txt-list dd{
	font-size: 16px;
	float: right;
}
dl.number{
	margin: 0 0 20px;
	padding: 10px 0;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	border-bottom: 2px solid #3eb8ec;
	border-top: 2px solid #3eb8ec;
}
dl.number dd{
	width: 50%;
	text-align: center;
	font-size: 24px;
	font-weight: bold;
	margin: 0;
	line-height: 1.2;
	border-right: 1px solid #3eb8ec;
}
dl.number dd.big{
	font-size: 24px;
}
dl.number dd:last-child{
	border-right: none;
}
dl.number dd span{
	font-size: 18px;
}
/* 診療科目選択 */
/* ----------------------------------------------------- */
div.base-col ul.sub-list{
	margin: 0;
}
div.base-col ul.sub-list li{
	font-weight: bold;
	clear: both;
	border-bottom: 1px solid #ccc;
}
div.base-col ul.sub-list li:last-child{
	border-bottom: none;
}
div.base-col ul.sub-list li i{
	font-weight: normal;
	font-size: 14px;
	float: right;
}
div.base-col ul.sub-list li a{
	padding: 12px 3%;
	display: block;
	text-decoration: none;
	color: #333;
	box-sizing: border-box;
}
/* 担当者選択 */
/* ----------------------------------------------------- */
div.base-col #tanto{
	margin: 0 auto 20px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow:row wrap;
}
div.base-col #tanto dl{
	width: 46%;
	padding: 0;
	margin: 0 1.5% 20px;
}
div.base-col #tanto dt{
	float: left;
	width: 86%;
	font-weight: bold;
	border: 1px solid #ccc;
	border-radius: 4px;
}
div.base-col #tanto dt a{
	padding: 12px 3%;
	display: block;
	box-sizing: border-box;
	text-decoration: none;
	color: #333;
}
div.base-col #tanto dd{
	font-size: 24px;
	color: #80c646;
	float: right;
	width: 12%;
	text-align: center;
	cursor: pointer;
}
#case-wrap{
}
#case-wrap div{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 0 15px;
}
#case-wrap div p.case-img{
	float: left;
	width: 180px;
	margin: 0 15px 8px 0;
}
#case-wrap div p.case-img img{
	width: 100%;
}
#case-wrap div h4{
	background: none;
	padding: 0;
	margin: 0 0 10px;
	font-size: 16px;
	font-weight: bold;
	color: #333;
}
#case-wrap div p{
	margin: 0;
	font-size: 14px;
}
#case-wrap div p.case-img2{
	float: none;
	width: 90%;
	margin: 0 5% 5px;
	text-align: center;
}
#case-wrap div p.case-img2 img{
	width: 100%;
}
/* カレンダー選択 */
/* ----------------------------------------------------- */
#calender-col{
	width: 94%;
	margin: 0 auto 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
}
#calender-col h2{
	font-size: 18px;
	margin: 0 0 10px;
	padding: 8px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	background: #ecf8fd;
	border-bottom: 1px solid #2db3eb;
	text-align: left;
}
#calender-col p.ttl{
	text-align: center;
	font-weight: bold;
	margin: 0 0 10px;
	padding-bottom: 6px;
	font-size: 18px;
	border-bottom: 1px solid #ddd;
	
}
#calender-col ul.ttl{
	width: 94%;
	margin: 0 auto 8px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	justify-content:space-between;
}
#calender-col ul.ttl li{
	text-align: center;
	font-weight: bold;
}
#calender-col ul.ttl li a{
	display: block;
	padding: 7px 12px;
	text-decoration: none;
	border: 1px solid #ccc;
	border-radius: 6px;
	color: #333;
}
table.cal{
	margin:0 auto 12px;
	width: 99%;
	table-layout: fixed;
	background: #f8f8f8;
}
table.cal th{
	padding: 5px 0;
	text-align: center;
	font-weight: bold;
	background: #3eb8ec;
	color: #fff;
}
table.cal td{
	padding: 5px;
	text-align: center;
	font-weight: bold;
	font-size: 14px;
	border:4px solid #fff;
	border-radius: 6px;
	height: 48px;
}
table.cal td a{
	color: #111;
	text-decoration: none;
	display: block;
	width: 100%;
	height: 100%;
}
table.cal td span{
	font-size: 22px;
	color: #dd465c;
}
table.cal td p{
	font-size: 22px;
	margin:3% 0 0 0;
	color: #dd465c;
}

table.cal td.san-hol{
	background: #ddd;
}

table.cal td.none{
	background: #fff;
	font-size: 12px;
}
table.cal td.today{
	background: #effaa7;
	padding: 3px;
}
table.cal td.today a{
	background: #fcfeef;
}

/* カレンダー選択 新しいやつ */
/* ----------------------------------------------------- */
#calender-col2{
	width: 94%;
	margin: 0 auto 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
	padding: 8px 0 0;
}
#calender-col2 h2{
	font-size: 18px;
	margin: 0 0 10px;
	padding: 8px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	background: #ecf8fd;
	border-bottom: 1px solid #2db3eb;
	text-align: left;
}
#calender-col2 p.ttl{
	text-align: center;
	font-weight: bold;
	margin: 0 0 10px;
	padding-bottom: 6px;
	font-size: 18px;
	border-bottom: 1px solid #ddd;
	
}
#calender-col2 ul.ttl{
	width: 94%;
	margin: 0 auto 8px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	justify-content:space-between;
	border-bottom: 1px solid #ccc;
	padding-bottom: 8px;
}
#calender-col2 ul.ttl li{
	text-align: center;
	font-weight: bold;
}
#calender-col2 ul.ttl li.year{
	font-weight: bold;
	font-size: 14px;
	margin-top: 5px;
}
#calender-col2 ul.ttl li a{
	display: block;
	padding: 4px 8px;
	text-decoration: none;
	border: 1px solid #ccc;
	border-radius: 6px;
	color: #333;
	font-weight: normal;
	background: linear-gradient(#ffffff, #eeeeee);
}
#calender-col2 ul.t-select{
	width: 94%;
	margin: 0 auto 8px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	justify-content:space-around;
}
#calender-col2 ul.t-select li{
	font-weight: bold;
	font-size: 14px;
	text-align: center;
}
#calender-col2 ul.t-select li a{
	color: #333;
}
table.cal-time{
	margin:0 auto 12px;
	width: 99%;
	table-layout: fixed;
	background: #fff;
}

table.cal-time thead th{
	 /* 縦スクロール時に固定する */
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  /* tbody内のセルより手前に表示する */
  z-index: 1;
}
table.cal-time th{
	padding: 5px 0;
	text-align: center;
	font-weight: bold;
	background: #3eb8ec;
	color: #fff;
	vertical-align: middle;
	font-size: 14px;
	border-right: 1px solid #fff;
	white-space: nowrap;
}
table.cal-time th.time{
	width: 60px;
}
table.cal-time th.san{
	color: #ff1313;
}
table.cal-time th.sut{
	color: #0040ff;
}
table.cal-time td{
	padding: 5px;
	text-align: center;
	font-weight: bold;
	font-size: 14px;
	height: 40px;
	line-height: 40px;
	vertical-align: middle;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}
table.cal-time td:last-child{
	border-right: none;
}
table.cal-time td a{
	color: #111;
	text-decoration: none;
	display: block;
	width: 100%;
	height: 100%;
	color: #dd465c;
}
table.cal-time td span{
	font-size: 20px;
	color: #dd465c;
}
table.cal-time td p{
	font-size: 20px;
	margin:3% 0 0 0;
	color: #dd465c;
}
table.cal-time td.time{
	white-space: nowrap;
	width: 60px;
	vertical-align: middle;
}
table.cal-time td.san-hol{
	background: #ddd;
}

table.cal-time td.none{
	background: #eee;
	color: #999;
	font-size: 20px;
}
table.cal-time td.today{
	background: #effaa7;
	padding: 3px;
}
table.cal-time td.today a{
	background: #fcfeef;
}
/* 時間選択 */
/* ----------------------------------------------------- */
#time-col{
	width: 94%;
	margin: 0 auto 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
}
#time-col h2{
	font-size: 20px;
	margin: 0 0 10px;
	padding: 10px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	background: #ecf8fd;
	border-bottom: 1px solid #2db3eb;
	text-align: left;
}
#time-col h3{
	text-align: left;
	margin: 0 2% 8px;
	padding: 6px 0;
	border: none;
	background: none;
}
#time-col dl{
	border-top: 1px solid #ccc;
}
#time-col dt{
	background: #ace0f7;
	color: #222;
	font-size: 16px;
	font-weight: bold;
	padding: 4px 2%;
	box-sizing: border-box;
}
#time-col dd{
	margin: 0;	
}
#time-col dd li{
	margin: 0;
	border-bottom: 1px solid #ccc;
	clear: both;
}
#time-col dd li a{
	display: block;
	padding: 12px 3%;
	box-sizing: border-box;
	text-decoration: none;
	font-size: 16px;
	color: #333;
}
#time-col dd li i{
	float: right;
}
#time-col dd li.none{
	display: block;
	padding: 12px 3%;
	box-sizing: border-box;
	background: #f4f4f4;
}

/* 症状選択 */
/* ----------------------------------------------------- */
#select-list{
	width: 94%;
	margin: 0 auto 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
}
#select-list h2{
	font-size: 17px;
	margin: 0 0 10px;
	padding: 10px;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	box-sizing: border-box;
	background: #ecf8fd;
	border-bottom: 1px solid #2db3eb;
	text-align: left;
}
#select-list h3{
	text-align: left;
	margin: 0 2% 8px;
	padding: 6px 0;
	border: none;
	background: none;
}
#select-list ul{
	margin: 0 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	justify-content:space-between;
}
#select-list li{
	width: 48%;
	font-size: 15px;
	font-weight: bold;	
	margin-bottom: 22px;
}

#select-list li span{
	font-weight: normal;
	font-size: 14px;
}
#select-list li input{
	position: absolute;
  left: -9999px;
}
#select-list li label{
	position: relative;
	display: block;
  	border-radius: 100px;
  	color: #fff;
  	background-color: #3eb8ec;
  	cursor: pointer;
  	user-select: none;
  	transition: background-color .2s;
	padding: 12px 15px 12px 48px;
}


#select-list li label::before {
  content: '';
  display: block;
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 10px;
  width: 24px;
	height: 24px;
  border: 3px solid #fff;
   border-radius: 100px;
  transition: background-color .2s;
}

#select-list li label:first-of-type {
  transform: translateX(-40px);
}

#select-list li label:last-of-type {
  transform: translateX(0px);
}

#select-list li input:checked + label {
  background-color: #EE6483;
}

#select-list li input:checked + label::before {
  background-color: #fff;
}

/* 会員登録していな予約状況確認 */
/* ----------------------------------------------------- */
dl.tel-send{
	margin: 0 2% 25px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}
dl.tel-send dt{
	width: 80%;
	margin: 0;
}

dl.tel-send dd{
	width: 16%;
	text-align: center;
}
dl.tel-send dd a{
	text-decoration: none;
	background: #80c646;
	color: #fff;
	display: block;
	padding: 4px 12px;
	border-radius: 4px;
}
/* お知らせページ */
/* ----------------------------------------------------- */
div.news-col{
	margin: 0 0 20px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
	justify-content:center;
}
div.news-col dl{
	width: 90%;
	border: 1px solid #ddd;
	background: #fff;
	border-radius: 6px;
	margin: 0 auto 20px;
}
div.news-col dt{
	float: left;
	width: 20%;
	text-align: center;
	position: relative;
}
div.news-col dt span{
	position: absolute;
	width: 57px;
	height: 50px;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;	
}
div.news-col dd{
	padding: 20px;
	border-left: 1px solid #ddd;
	box-sizing: border-box;
}
div.news-col dd h3{
	margin: 0 0 10px;
	font-size: 18px;
	padding: 0;
}
div.news-col dd h3 span{
	font-weight: normal;
	font-size: 11px;
	color: #fff;
	background: rgba(237,39,42,1.00);
	padding: 4px 10px;
	margin-right: 6px;
}
div.news-col dd p{
	margin: 0;
}

div.news-col dd h3 a,
div.news-col dd p a{
	color: #333;
	text-decoration: none;	
}

div.news-detail{
	width: 90%;
	margin: 0 auto 30px;
}
div.news-detail p{
	margin: 0 0 15px;
}
div.news-detail p.a-center{
	margin: 0 auto 15px;
	text-align: center;
}
div.news-detail p.a-center img{
	width: inherit;
	max-width: 100%;	
}
/* マイページ */
/* ----------------------------------------------------- */
#mypage-col{
	width: 100%;
	margin: 25px 0 20px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}
#mypage-col dl{
	width: 48%;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
	margin: 0 1% 2%;
	position: relative;
}
#mypage-col dt{
	padding: 20px 0;
	text-align: center;
	margin: 0;	
}
#mypage-col dt img{
	width: inherit;
}
#patternB #mypage-col dt img{
	color: #44BF6D;
}
#mypage-col dd{
	padding: 0 0 10px;
	text-align: center;
	font-size: 18px;
	margin: 0;
	font-weight: bold;
}
#mypage-col dd a{
	color: #333;
	text-decoration: none;
}
#mypage-col dd.icon{
	position: absolute;
	top: 5%;
	right: 5%;
	font-size: 12px;
	background: rgba(241,47,50,1.00);
	color: #fff;
	padding: 4px 10px;
	border-radius: 4px;
}
ul.txt-list{
	margin: 0 0 10px;
}
ul.txt-list li{
	font-weight: bold;
	border-bottom: 1px solid #ccc;
}
ul.txt-list li:first-child{
	border-top: 1px solid #ccc;
}
ul.txt-list li a{
	padding: 10px 0 10px 4%;
	box-sizing: border-box;
	display: block;
	text-decoration: none;
	color: #333;
	background: #fff;
}

/* 病院管理 */
p.sh-sec{
	margin: 0 5% 15px;	
}
ul.select-shop{
	width: 90%;
	margin: 0 5% 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}
ul.select-shop li{
	border: 1px solid #ccc;
	border-radius: 4px;
	font-weight: bold;
	padding: 15px 3% 10px;
	background: #fff;
	clear: both;
	box-sizing: border-box;
	margin: 0 0 10px;
}

ul.select-shop li span{
	float: right;
	width: 80px;
	font-weight: normal;
	text-align: center;
}
ul.select-shop li span a{
	display: block;
	padding: 4px 0;
	color: #fff;
	text-decoration: none;
	background: #3eb8ec;
	border-radius: 6px;
}
ul.select-shop li span.delete a{
	display: block;
	padding: 4px 0;
	color: #fff;
	text-decoration: none;
	background: #ff4000;
	border-radius: 6px;
}
ul.select-shop li span.on{
	background: #ccc;
	padding: 4px 0;
	border-radius: 6px;
	color: #fff;
}

dl.shop_id{
	margin: 0 2% 20px;
}
/* クーポン */
#coupon-col{
	width: 96%;
	margin: 0 2% 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}

#coupon-col dl{
	width: 30%;
	margin: 0 1% 2%;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
	padding: 15px;
	box-sizing: border-box;
}
#coupon-col dt{
	margin: 0 0 10px;
}
#coupon-col dt img{
	width: 100%;
}
#coupon-col dd{
	margin: 0 0 3px;
	font-size: 14px;
}
#coupon-col dd.ttl{
	margin: 0 0 5px;
	font-weight: bold;
}
#coupon-col dd.detail{
	text-align: center;
	width: 90%;
	margin: 0 auto;
}
#coupon-col dd.detail a{
	display: block;
	padding: 8px 0;
	text-decoration: none;
	color: #fff;
	background: #80c646;
	border-radius: 4px;
}
#coupon-detail{
	width: 94%;
	margin: 20px auto;
	padding: 20px 4%;
	background: #fff;
	box-sizing: border-box;
	border-radius: 6px;
	border: 1px solid #ccc;
}
#coupon-detail p.pic{
	text-align: center;
	margin: 0 0 20px;
}
#coupon-detail p.pic img{
	width: inherit;
	max-width: 100%;
}
#coupon-detail dl.overview{
	margin: 0 0 25px;
}
#coupon-detail dl.overview dt{
	font-weight: bold;
	margin: 0 0 15px;
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
}
#coupon-detail dl.overview dd{
	margin: 0 0 10px;
}
/* 会員情報 */
p.edit{
	margin: 0 4%;
}
p.edit a{
	border: 1px solid #ccc;
	padding: 6px 8px;
	display: inline-block;
	text-decoration: none;
	border-radius: 6px;
	color: #333;
	background: linear-gradient(#ffffff, #EFEFEF);
}

.tel-d{
	color: rgba(40,112,223,1.00);
	font-weight: bold;
}
.tel-link{
	color:#333 !important;
    text-decoration:none !important;
}
div.member-info{
	width: 94%;
	margin: 20px auto;
	padding: 20px 4%;
	background: #fff;
	box-sizing: border-box;
	border-radius: 6px;
	border: 1px solid #ccc;
}
div.member-info h2{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 0 15px;
	font-size: 22px;
	text-align: left;
}
div.member-info div.wrap{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	margin: 0 0 12px;
}
div.member-info div.wrap dl{
	margin: 0 12px 0 0;
}
div.member-info div.wrap dl:last-child{
	margin: 0;
}
div.member-info div.wrap dt{
	font-weight: bold;
}
div.member-info div.wrap dd label{
	font-weight: bold;
}

div.member-info div.wrap dd.picture label{
	width: 100px;
	padding: 10px 0;
    color: #fff;
    background: rgba(81,175,228,1.00);
    text-decoration: none;
	text-align: center;
	font-weight: normal;
	border-radius: 4px;
	display: inline-block;
}
div.member-info div.wrap dd.picture p{
	margin: 0 0 15px;
}
div.member-info div.wrap dd.picture p a{
	text-decoration: none;
	font-weight: bold;
	color: #333;
}
div.member-info div.wrap dd.picture img.w200{
	width: 80%;
	max-width: 500px;
}
div.member-info div.wrap dd.picture p.sample{
	margin: 0 0 10px;
}
div.member-info div.wrap dd.miss input{
	background: rgba(255,242,242,1.00);
}
div.member-info dl.add{
	margin: 0 0 10px;
}
div.member-info dl.add dt{
	font-weight: bold;
}
div.member-info dl.add dd{
	margin: 0 0 6px;
}
div.member-info div.wrap2{
	margin: 0 0 12px;
}
div.member-info div.wrap2 dl{
	margin: 0 12px 0 0;
}
div.member-info div.wrap2 dl:last-child{
	margin: 0;
}
div.member-info div.wrap2 dt{
	font-weight: bold;
}
div.member-info dl.confirm{
	margin: 0 0 8px;
	border-bottom: 1px solid #ccc;
	padding-bottom: 8px;
}
div.member-info dl.confirm dt{
	font-weight: bold;
}
/* スタンプカード */
div.stamp-col{
	width: 90%;
	margin: 20px auto 0;
	padding: 20px;
	box-sizing: border-box;
	background: linear-gradient(#dbf1fb, #ffffff);
	border: 1px solid #ccc;
	border-radius: 6px;
}
div.stamp-col.last{
	margin:20px auto 0;
}
div.stamp-col ul.check{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	margin: 0 0 20px;	
}
div.stamp-col ul.check li{
	text-align: center;
	height:80px;
	width:80px;
	border-radius:50%;
	line-height:70px;
	border: 1px solid #ccc;
	background: #f6f6f6;
	margin: 0 1% 10px;
}
div.stamp-col ul.check li img{
	width: 50px;
	height: 50px;
	vertical-align: middle;
	text-align: center;
}
div.stamp-col ul.check li.visit{
	border: 3px solid #3eb8ec;
	background: #fff;
	font-weight: bold;
	color: #3eb8ec;
}
div.stamp-col p.limit{
	text-align: center;
	font-weight: bold;
}
div.stamp-col p.limit br{
	display: none;
}
dl.come-t{
	width: 90%;
	background: #fff;
	padding: 16px;
	border-bottom: 1px solid #ccc;
	margin: 0 auto;
	box-sizing: border-box;
}
dl.come-t dt{
	font-size: 18px;
	font-weight: bold;
	margin: 0 0 10px;
}
dl.come-t dd{
	margin: 0;
	font-size: 16px;
}
dl.come-t.last{
	margin: 0 auto 35px;
}
/* 家族情報 */
#family-col{
	width: 94%;
	margin: 20px auto;
	padding: 20px 4%;
	background: #fff;
	box-sizing: border-box;
	border-radius: 6px;
	border: 1px solid #ccc;
}
#family-col ul.fa-list{
	
}
#family-col ul.fa-list li{
	width: 90%;
	margin: 0 auto 10px;
	font-size: 17px;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-weight: bold;
}
#family-col ul.fa-list li i{
	float: right;
	font-weight:normal;
}
#family-col ul.fa-list li a{
	display: block;
	padding: 12px 15px;
	text-decoration: none;
	color: #555;
	box-sizing: border-box;
}
/* 病院へ直接相談 */
p.question{
	width: 90%;
	margin: 0 auto 20px;
	font-size: 18px;
	font-weight: bold;
}
p.question i{
	font-weight: normal;
}
p.question a{
	text-align: center;
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 10px 0;
	display: block;
	text-decoration: none;
	background: #3eb8ec;
	color: #fff;
}
div.list-a{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}
div.list-a dl{
	margin: 0 0 15px;
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
}
div.list-a dt{
	font-weight: bold;
	font-size: 16px;
	margin: 0 0 6px;
}
div.list-a dd{
	font-size: 16px;
	line-height: 1.7;
}
dl.answer{
	margin: 0 0 40px;
}
dl.answer dt{
	font-weight: bold;
	margin: 0 0 12px;
	border-bottom: 1px dotted #999;
	padding-bottom: 10px;
	
}
dl.answer dd{
	margin: 0 0 25px;
}
dl.answer dd.pic{
	text-align: center;
}
dl.answer dd.pic img{
	width: inherit;
	max-width: 640px;
}
/* アプリ設定 */
#set-col{
	margin: 0 0 30px;
}
#set-col dl{
	background: #fff;
	padding: 10px 0;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	justify-content:space-between;
	border-bottom: 1px solid #ccc;
	border-top: 1px solid #ccc;
	margin: 0 0 8px;
}
#set-col dd.ttl{
	font-size: 18px;
	font-weight: bold;
	margin: 7px 0 0 12px;
}

/* プライバシーポリシー */
div.privacy-info{
	width: 94%;
	margin: 20px auto;
	padding: 20px 2%;
	background: #fff;
	box-sizing: border-box;
	border-radius: 6px;
	border: 1px solid #ccc;
}
div.privacy-info h2{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 0 15px;
	font-size: 22px;
	text-align: left;
}
div.privacy-info h3{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
}
div.privacy-info p{
	margin: 0 2% 20px;
}

div.privacy-info ul.c-list{
	margin: 0 0 20px;
}
div.privacy-info ul.c-list li{
	margin: 0 3% 7px;
	background: url("../img/commn/icon.png") no-repeat 0 0.4em;
	padding: 0 0 0 20px;
	font-size: 14px;
}
/* 病院情報 */
/* ----------------------------------------------------- */
ul.shop-c{
	width: 94%;
    margin: 0 auto 1px;
    padding: 0;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-flow: row wrap;
}
ul.shop-c li{
    width: 40%;
    margin: 0 0.5% 0 0;
    text-align: center;
    font-weight: bold;
    vertical-align: middle;
    border-top: 1px solid #ccc;
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
}
ul.shop-c li a{
	text-decoration: none;
    color: #222;
    padding: 10px 0;
    background: #f7f7f7;
    display: block;
}
ul.shop-c li a.visible{
	text-decoration: none;
    text-align: center;
    color: #fff;
    background: #3eb8ec;
}
div.about-col{
	width: 96%;
	margin: 0 auto 25px;
}
div.swiper-container{
	margin: 0;
}
div.swiper-container div.swiper-slide{
	margin-bottom: 0;
}
div.swiper-container div.swiper-slide span{
}
div.base-col p.come{
	border-bottom: 1px solid #ccc;
	padding-bottom: 15px;
	margin: 0 3% 25px;
}
div.director-col{
	width: 96%;
	margin: 0 auto 20px;
}
div.director-col p.pic{
	float: left;
	width: 200px;
	margin: 0 20px 8px 0;
}
div.director-col p.pic img{
	width: 100%;
}
div.director-col p{
	margin: 0;
}

dl.add-tel{
	width: 94%;
	margin: 0 auto 10px;
}
dl.add-tel dt{
	font-weight: bold;
	margin: 0 0 8px;
}
dl.add-tel dd{
	font-weight: bold;
	font-size: 20px;
	color: #333;
}
dl.add-tel dt a,
dl.add-tel dd a{
	text-decoration: none;
	color: #333;
}
dl.add-tel dd a{
	color: #333;	
		
}
#staff-wrap{
	width: 94%;
	margin: 0 auto;
}
#staff-wrap div{
	border-bottom: 1px solid #ccc;
	padding-bottom:15px;
	margin: 20px 0 20px;
}
#staff-wrap div:last-child{
	border-bottom: none;
}
#staff-wrap div ul.pic{
	width: 180px;
	float: left;
	margin: 0;
	border: none;
}

#staff-wrap div ul.pic li{
	margin: 0 0 8px;
	border: none;
}
#staff-wrap div ul.pic li img{
	width: 100%;
}
#staff-wrap div ul.pic li.case{
	text-align: center;
	font-size: 16px;
	font-weight: normal;
}
#staff-wrap div ul.pic li.case a{
	display: block;
	padding: 5px 0;
	text-decoration: none;
	color: #fff;
	background: #3eb8ec;
	border-radius: 4px;
}
#staff-wrap div div.text{
	float: right;
	width: 630px;
	margin: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#staff-wrap div div.text h3{
	padding: 0;
	margin: 0 0 15px;
}
#staff-wrap div div.text h3 br{
	display: none;
}
#staff-wrap div div.text h3 span{
	text-align: center;
	font-size: 14px;
	font-weight: normal;
}
#staff-wrap div div.text h3 span a{
	display: inline-block;
	width: 120px;
	padding: 5px 0;
	background: #3eb8ec;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
}
#staff-wrap div div.text dl{
	margin: 0 0 15px;
	border-bottom: 1px solid #ddd;
	padding-bottom: 10px;
}
#staff-wrap div div.text dt{
	font-weight: bold;
	margin: 0 0 5px;
}
#staff-wrap div p.a-right a{
	display: inline-block;
	padding: 5px 20px;
	background: #80c646;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	text-align: center;
	font-size: 16px;
}

/* スタッフ詳細 */

#g-map{
	width: 96%;
	margin: 0 auto 10px;
}
/* 事例紹介 */
#case-list{
	width: 94%;
	margin: 20px auto 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}
#case-list li{
	width: 25%;
	margin: 0;
	border: none;
	padding: 0;
}
#case-list li img{
	width: 100%;
	height: 200px;
	object-fit: cover;
}
div.case-detail{
	width: 90%;
	background: #fff;
	margin: 0 auto 30px;
}
div.case-detail p.pic{
	text-align: center;
	margin: 0 auto;
	max-width: 460px;
	padding: 20px 0;
}
div.case-detail p.pic img{
	width: 100%;
}
div.case-detail dl{
	margin: 0 0;
	border: 1px solid #ddd;
}
div.case-detail dt{
	padding: 7px 10px;
	font-weight: bold;
	box-sizing: border-box;
	background: #f6f6f6;
	border-bottom: 1px solid #ddd;
	margin: 0 0 15px;
}
div.case-detail dd{
	padding: 0 12px 25px;
	box-sizing: border-box;
}
p.back a{
	text-decoration: none;
	color: #333;
}
/* 予約確認 */
/* ----------------------------------------------------- */
div.re-col{
	margin: 0 0;
}
div.re-col dl{
	background: #fff;
	padding: 8px 15px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	justify-content:space-between;
	border-bottom: 1px solid #ccc;
	margin: 0;
	box-sizing: border-box;
}
div.re-col dl:last-child{
	border-bottom: none;
}
div.re-col dl.end{
	background: #f4f4f4;
}
div.re-col dd{
	font-weight: bold;
	font-size: 15px;
	width: 80%;
}
div.re-col dd a{
	width: 100%;
	text-decoration: none;
	color: #333;
	display: inline-block;
}
div.re-col dd span{
	color: #138bbf;
	font-weight: normal;
}
div.re-col dd span a{
	color: #138bbf;
}
div.re-col dd.cancel{
	text-align: center;
	width: 90px;
	font-size: 14px;
}
div.re-col dd.cancel a{
	display: block;
	padding: 7px 0;
	text-decoration: none;
	color: #333;
	background: #f8f8f8;
	border: 1px solid #ddd;
	border-radius: 4px;
}
/* テキスト飾り */
/* ----------------------------------------------------- */
.caution{
	color:#000000;
}
.waku{
	width:92%;
	margin:0 auto 20px;
	border:1px solid #CCC;
	padding:10px 2%;
	box-sizing: border-box;
}
.u-line{
	border-bottom:1px solid #ccc;
	padding-bottom:6px;
}
.big-t{
	font-size:18px;
}


/* 検索ボタン枠 */
/* ----------------------------------------------------- */
#search-sec{
	margin:0 0 15px;
}
#search-sec ul{
	margin:0;
	padding:0;
}
#search-sec li{
	list-style:none;
	padding:0;
	margin:0;
	float:left;
}
#search-sec li.sr-btn{
	margin: 0 15px;
}
#search-sec li.b-right{
	float: right;
}


/* タブの部分 */
/* ----------------------------------------------------- */
#o-tab{
	width: 94%;
	margin:0 auto 1px;
	padding:0;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}

#o-tab li{
	width: 32%;
	margin:0 0.5% 0 0;
	text-align:center;
	font-weight:bold;
	vertical-align:middle;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}
#o-tab li i{
	font-size: 12px;
	font-weight: normal;
}
#o-tab li:nth-child(3n){
	margin: 0;
}
#o-tab li a{
	text-decoration:none;
	color:#222;
	padding: 12px 0;
	background: #f7f7f7;
	display: block;
}
#o-tab li a:hover{
}
#o-tab li a.visible{
	text-decoration:none;
	text-align: center;
	color: #fff;
	background: #3eb8ec;
}

#b-box1,
#b-box2,
#b-box3{
	width:100%;
	margin: 0 0 30px;
}
#b-box2,
#b-box3{
	display:none;
}

/* -----------------------------------------------------
 モーダル
----------------------------------------------------- */
*{
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
.content{
    margin: 0 auto;
    padding: 20px;
}
.modal-col{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
	z-index: 99999;
    width: 100%;
}
.modal__bg{
    background: rgba(0,0,0,0.4);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    left: 50%;
    padding: 20px;
    position: absolute;
    top: 42%;
    transform: translate(-50%,-50%);
    width: 90%;
	max-width: 800px;
}
.modal__content h3.ttl{
	clear: both;
}
.modal__content h3.ttl span{
	float: right;
	margin-right: 10px;
	font-weight: normal;
	font-size: 16px;
}
.modal__content-mid{
    background: #fff;
    left: 30%;
    padding: 25px;
    position: absolute;
    top: 25%;
    transform: translate(-20%,-30%);
    width: 80%;
	max-width: 1260px;
}
.modal__content-mid h3.ttl{
	clear: both;
}
.modal__content-mid h3.ttl span{
	float: right;
	margin-right: 10px;
	font-weight: normal;
	font-size: 16px;
}
.modal__content-long{
    background: #fff;
    left: 25%;
    padding: 25px;
    position: absolute;
    top: 25%;
    transform: translate(-20%,-25%);
    width: 80%;
	max-width: 1580px;
}
.modal__content-long h3.ttl{
	clear: both;
}
.modal__content-long h3.ttl span{
	float: right;
	margin-right: 10px;
	font-weight: normal;
	font-size: 16px;
}
.modal-col p{
	margin: 0 2% 12px;
}
p.clsbtn{
	text-align: center;
	padding-top: 10px;
	font-weight: bold;
}
p.clsbtn a{
	display: inline-block;
	background: #f8f8f8;
	border: 1px solid #ccc;
    border-radius: 4px;
	padding: 10px;
	color: #000;
	font-size: 14px;
	text-decoration: none;
}
p.clsbtn a.jobAdd{
	background: #80c646;
	border: 1px solid #80c646;
	color: #fff;
	padding: 10px;
	display: inline-block;
	font-size: 14px;
	border-radius: 4px;
	text-decoration: none;
}
p.clsbtn a.dele{
	background: #ff4000;
	border: 1px solid #ff4000;
	color: #fff;
	padding: 10px;
	display: inline-block;
	font-size: 14px;
	border-radius: 4px;
	text-decoration: none;
}

/* graph */
/* ----------------------------------------------------- */
#graph{
	margin:0 0 20px;
	width:100%;
}
/* 探す */
/* ----------------------------------------------------- */
.search-kye{
	margin:0 0 15px;
}
.btn-list li{
	margin-right:12px;
}
.btn-list li.btn-default a{
	color:#111;
}

/* アラートボタン */
/* ----------------------------------------------------- */
.swal2-confirm{
	background-color:rgba(3,123,59,1.0) !important;
	border-left-color:rgba(3,123,59,1.0) !important;
	border-right-color:rgba(3,123,59,1.0) !important;
}


.swal2-cancel.swal2-styled{
	color: #777 !important;
	background-color:rgba(238,238,238,1.0) !important;
	border-left-color:rgba(238,238,238,1.0) !important;
	border-right-color:rgba(238,238,238,1.0) !important;
}
.swal2-content{
	font-size: 16px !important;
}


/* ラジオボタンを全て消す */
input[name="tab_item"] {
display: none;
}
/* 選択されているタブのコンテンツのみを表示 */
#rssContinued_content{
	opacity: 0;
	visibility: hidden;
	-webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    transition: all 0.5s ease;
}
#rssContinued_content article{
	display: none!important;
}
#rssContinued:checked ~ #rssContinued_content{
	opacity: 1;
	visibility: visible;
}
#rssContinued:checked ~ #rssContinued_content article{
	display: block!important;
}
/* タブのスタイル（任意） */
.tab_item {
	display: block;
	padding:0 0 20px;
	font-size: 18px;
	text-align: center;
	line-height:1em;
	color: #2e8955;
	font-weight: bold;
	margin:0;
}
/* 選択されているタブのスタイルを変える */
#newsRss input:checked + .tab_item {
	display: none;
}

div.base-col ul.other-list{
	margin: 0 10px 12px;
}
div.base-col ul.other-list li{
	padding: 10px 0;
}

/* 問い合わせフォーム */
/* ----------------------------------------------------- */	
	dl.form-t{
		margin: 0 0 30px;
		width: 100%;
	}
	dl.form-t dt{
		font-weight: bold;
		padding: 0 0 10px;
		font-size: 16px;
	}
dl.form-t dd textarea{
	width: 100%;
	height: 150px;
}
dl.form-t dd textarea.error{
	background: #fdf2f2;
	color: rgba(241,100,102,1.00);
}

dl.confirm-t{
		margin: 0 0 40px;
	}
dl.confirm-t dt{
		font-weight: bold;
		margin: 0 0 20px;
		border-bottom: 1px solid #ccc;
		padding-bottom: 10px;
}
dl.confirm-t dd{
	line-height: 1.7;
}
/* float clear */
/* ----------------------------------------------------- */
.navbar-default:after,
#case-wrap div:after,
div.director-col:after,
#staff-wrap div:after
{
	content:"."; 
	display:block;
	height:0;
	clear:both; 
	visibility:hidden;
}
.navbar-default,
#case-wrap div,
div.director-col,
#staff-wrap div
{
	display:inline-block;
}

/* Hides from IE-mac \*/
* html .navbar-default,
* html #case-wrap div,
* html div.director-col,
* html #staff-wrap div
{
	 height:1%;
}
.navbar-default,
#case-wrap div,
div.director-col,
#staff-wrap div
{
	display:block;
}
/* End hide from IE-mac */

/* PCでは非表示 */
#f-nav-fx{
	display: none;
}

@media only screen and (max-width: 768px){
#f-nav-fx{
	display:block;
	position: fixed;
	bottom: 0;
	width: 100%;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row nowrap;
	justify-content:space-between;
	background: #eee;
	
}
#f-nav-fx li{
	width: 25%;
	text-align: center;
	padding: 6px 0;
	display: block;
	font-size: 13px;
}
	#f-nav-fx li a{
		text-decoration: none;
		color: #333;
	}
	#f-nav-fx li img{
		width: 26px;
	}
#select-list ul{
	margin: 0 auto 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
	justify-content:center;
}
	
#select-list li{
	width: 90%;	
	font-size: 16px;
	font-weight: bold;	
	margin-bottom: 22px;
	margin: 0 auto 15px;
	display: block;
}
	#select-list li label::before{
		height: 24px;
		width: 24px;
		top: 10px;
	}
	div.reg-wrap dd.txt br{
		display: inline;
	}
	

/* マイページ */
/* ----------------------------------------------------- */
#mypage-col{
	width: 96%;
	margin: 20px 2% 15px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	justify-content:space-around;
}
#mypage-col dl{
	width: 48%;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
	margin: 0 0 2%;
}
#mypage-col dt{
	padding: 5px 0 5px;
	text-align: center;
	margin: 0;	
}
#mypage-col dt img{
	width: inherit;
}
#mypage-col dd{
	padding: 0 0 20px;
	text-align: center;
	font-size: 14px;
	margin: 0;
	font-weight: bold;
}

#mypage-col dd a{
	color: #333;
	text-decoration: none;
}
#mypage-col dd br{
		display: inline;
	}
	
#coupon-col dl{
	width: 94%;
	margin: 0 3% 20px;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 6px;
	padding: 12px 10px;
	box-sizing: border-box;
}

/* 担当者選択 */
div.base-col #tanto dl{
	width: 96%;
	padding: 0;
	margin: 0 auto 10px;
}
div.base-col #tanto dt{
	float: left;
	width: 86%;
	font-weight: bold;
	border: 1px solid #ccc;
	border-radius: 4px;
}
div.base-col #tanto dt a{
	padding: 12px 3%;
	display: block;
	box-sizing: border-box;
	text-decoration: none;
	color: #333;
}
div.base-col #tanto dd{
	font-size: 24px;
	color: #80c646;
	float: right;
	width: 12%;
	text-align: center;
	cursor: pointer;
}
#case-wrap{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}
#case-wrap div{
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin: 0 0 15px;
}
	#case-wrap div img.case-img{
		float: left;
		width: 100px;
		margin: 0 15px 8px 0;
	}
	#case-wrap div h4{
		background: none;
		padding: 0;
		margin: 0 0 10px;
		font-size: 16px;
		font-weight: bold;
		color: #333;
	}
	#case-wrap div p{
		margin: 0;
		font-size: 14px;
	}
	#case-wrap div img.case-img2{
		float: none;
		width: 90%;
		margin: 0 5%;
		text-align: center;
	}
/* スタンプカード */
div.stamp-col{
	width: 90%;
	margin: 20px auto 0;
	padding: 20px 10px;
	box-sizing: border-box;
	background: linear-gradient(#dbf1fb, #ffffff);
	border: 1px solid #ccc;
	border-radius: 6px;
}

div.stamp-col ul.check{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
	
}
div.stamp-col ul.check li{
	text-align: center;
	height:80px;
	width:80px;
	border-radius:50%;
	line-height:70px;
	border: 1px solid #ccc;
	background: #f6f6f6;
	margin: 0 1% 10px;
}
div.stamp-col ul.check li.visit{
	border: none;
	background: #fff;
}
div.stamp-col p.limit br{
	display: inline;
}

/* 病院情報 */
/* ----------------------------------------------------- */
div.about-col{
	width: 96%;
	margin: 0 auto 25px;
}
div.swiper-container{
	margin:0;
}
div.base-col p.come{
	border-bottom: 1px solid #ccc;
	padding-bottom: 15px;
	margin: 0 3% 25px;
}
	
div.director-col{
	width: 96%;
	margin: 0 auto 20px;
}
div.director-col p.pic{
	width: 30%;
	margin: 0 3% 1% 0;	
}
div.director-col p.pic img{
	width: 100%;
}
div.director-col p{
	margin: 0;
	font-size: 14px;
}
#staff-wrap{
	width: 94%;
	margin: 0 auto;
}
#staff-wrap div{
	border-bottom: 1px solid #ccc;
	padding-bottom:15px;
	margin: 20px 0 20px;
}
#staff-wrap div ul.pic{
	width: 28%;
	max-width: 360px;
	float: left;
	margin: 0 auto 20px;
}
#staff-wrap div div.text{
	float: right;
	width: 69%;
	margin: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#staff-wrap div div.text h3{
	padding: 0;
	margin: 0 0 15px;
}
	#staff-wrap div div.text h3 br{
		display: inline;
	}
#staff-wrap div div.text h3 span{
	text-align: center;
	font-size: 16px;
	font-weight: normal;
}
#staff-wrap div div.text h3 span a{
	display: inline-block;
	width: 120px;
	padding: 5px 0;
	background: #3eb8ec;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
}
#staff-wrap div div.text dl{
	margin: 0 0 10px;
	border-bottom: none;
	padding-bottom: 0;
}
#staff-wrap div div.text dt{
	font-weight: bold;
	margin: 0 0 6px;
	font-size: 15px;
}
	#staff-wrap div div.text dd{
		font-size: 15px;
	}
	#staff-wrap div p.a-right{
		margin: 0 auto;
		width: 90%;
	}
#staff-wrap div p.a-right a{
	display: inline-block;
	width: 100%;
	padding: 5px 0;
	background: #80c646;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	text-align: center;
	font-size: 16px;
}
/* 事例紹介 */
#case-list{
	width: 98%;
	margin: 0 auto 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: row wrap;
}
#case-list li{
	width: 33%;
	margin: 0;
	border: none;
	padding: 0;
}
#case-list li img{
	width: 100%;
	height: 150px;
	object-fit: cover;
}
/* お知らせ */
/* ----------------------------------------------------- */	

div.news-col dl{
	width: 92%;
	border: 1px solid #ddd;
	background: #fff;
	border-radius: 6px;
	margin: 0 auto 20px;
}
div.news-col dt{
	float: left;
	width: 20%;
	text-align: center;
	position: relative;
}
div.news-col dt span{
	position: absolute;
	width: 57px;
	height: 50px;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;	
}
div.news-col dd{
	padding: 12px;
	border-left: 1px solid #ddd;
	box-sizing: border-box;
}
div.news-col dd h3{
	margin: 0 0 6px;
	font-size: 16px;
	padding: 0;
}
div.news-col dd p{
	margin: 0;
}
/* 予約確認・履歴 */
/* ----------------------------------------------------- */		
div.re-col dd{
	font-weight: bold;
	font-size: 16px;
	width: 100%;
}
/* スタッフ事例 */
/* ----------------------------------------------------- */	
div.case-detail p.pic{
	text-align: center;
	margin: 0 auto;
	max-width: 460px;
	padding: 0 0;
}	
	
/* 会員登録していな予約状況確認 */
/* ----------------------------------------------------- */
dl.tel-send{
	margin: 0 3% 25px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}
dl.tel-send dt{
	width: 100%;
	margin: 0 0 10px;
}
dl.tel-send dd{
	width: 30%;
	margin: 0 auto;
	text-align: center;
}
dl.tel-send dd a{
	text-decoration: none;
	background: #80c646;
	color: #fff;
	display: block;
	padding: 4px 12px;
	border-radius: 4px;
}
/*病院への相談 */
/* ----------------------------------------------------- */		
dl.answer{
	margin: 0 0 25px;
}
dl.answer dt{
	font-weight: bold;
	margin: 0 0 12px;
	border-bottom: 1px dotted #999;
	padding-bottom: 10px;	
}
dl.answer dd{
	margin: 0 0 25px;
}
dl.answer dd.pic{
	text-align: center;
	margin: 0 auto 25px;
}
dl.answer dd.pic img{
	width: 94%;
	max-width: 100%;
}
	
/*　ボタン */
/* ----------------------------------------------------- */
a.reg-btn,
button.reg-btn{
	width: 90%;
}
a.reg-btn2{
	width: 90%;
}
a.reg-btn3{
	width: 90%;
}
	
div.reg-wrap dd.a-left{
	width: 90%;
}
/* Google map */
/* ----------------------------------------------------- */		
/* [iframe]を囲む要素 */
.embed-wrapper {
	width: 96% ;
	max-width: 768px ;			/* 最大の横幅 */
	height: 0 ;					/* 高さは0にする */
	padding-bottom: 80% ;	/* 横幅に対する縦幅の比率 */
	position: relative ;
	top: 0 ;
	left: 0 ;
	right: 0;
	margin: 0 auto;
}

/* [ifram] */
.embed-wrapper iframe {
	width: 100% ;		/* 親要素の余白いっぱい */
	height: 100% ;		/* 親要素の余白いっぱい */
	margin: 0 0;			/* 余白 */
	padding: 0 ;		/* スペース */
	position: absolute ;
	top: 0 ;
	left: 0 ;
}
/* Youtubeの場合 [1:0.5625] */
.embed-youtube {
	padding-bottom: 56.25% ;	/* 横幅に対する縦幅の比率 */
}

/* Vineの場合 [1:1] */
.embed-vine {
	padding-bottom: 100% ;	/* 横幅に対する縦幅の比率 */
}

/* Google Mapsの場合 [自由] */
.embed-googlemaps {
	padding-bottom: 60% ;	/* 横幅に対する縦幅の比率 */
}
	
}

@media only screen and (max-width: 450px){
	
table.cal td{
	padding: 5px;
	text-align: center;
	font-weight: bold;
	font-size: 14px;
	border:4px solid #fff;
	border-radius: 6px;
	height: 64px;
}
	
div.stamp-col ul.check li{
	text-align: center;
	height:56px;
	width:56px;
	border-radius:50%;
	line-height:56px;
	border: 1px solid #ccc;
	background: #f6f6f6;
	font-size: 20px;
	margin: 0 1% 10px;
}
	
/* select-t */
table.select-t{
	width:100%;
	margin:0 auto 20px;
}
table.select-t th{
	width:10%;
	display: block;
	padding:5px 5px 3px 6px;
	border-top:none;
	border-bottom:none;
	border-right:none;
	font-weight:bold;
	white-space:nowrap;
	background:none;
	vertical-align:middle;
	text-align:center;
	box-sizing: border-box;
}
table.select-t td{
	width: 100%;
	display: block;
	box-sizing: border-box;
	padding:5px 6px 5px 6px;
	border-bottom:1px solid #ddd;
	vertical-align:middle;
	word-break:break-all;
	line-height:1.5;
	font-size: 16px;
}
table.select-t td a{
	color: #333;
	text-decoration: none;
}
#o-tab{
	width: 94%;
	margin:0 auto 1px;
	padding:0;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-flow: column wrap;
}

#o-tab li{
	width: 100%;
	margin:0 0 2px;
	text-align:center;
	font-weight:bold;
	vertical-align:middle;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}
/*　ボタン */
/* ----------------------------------------------------- */
a.reg-btn{
	width: 80%;
}
a.reg-btn2{
	width: 80%;
}
a.reg-btn3{
	width: 80%;
}


}

@media only screen and (max-width: 380px){



}
