* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

body {
	padding-top: 112px;
	font-family: 'Open Sans', sans-serif;
	background-color: #eff0f3;
}
@media (max-width: 768px) {
	body {
		padding-top: 142px;
	}
}

/*
 * nav
 */
nav.nav-custom {
	height: 82px;
	background-color: #34495e;
}
@media (max-width: 768px) {
	nav.nav-custom {
		height: 112px;
	}
}

.nav-logo {
	position: relative;
	top: 10px;
	left: 10px;
	margin-right: 20px;
	display: inline-block;
}

.nav-title {
	position: relative;
	top: 15px;
	font-size: 20pt;
	color: #f7f7f7;
	display: inline-block;
}

.nav-link {
	position: relative;
	top: 20px;
	right: 25px;
	font-size: 14pt;
	display: inline-block;
}
@media (max-width: 768px) {
	.nav-link {
		top: 0px;
	}
}

.nav-link>li>a,
.nav-link>li>a:hover,
.nav-link>li>a:focus {
	background-color: transparent;
	color: #f7f7f7;
	outline: none;
	display: inline-block;
}
.nav-link>li>a:hover {
	color: #aaa;
}

/*
 * sidebar
 */
.sidebar {
	padding: 10px 0px;
	background-color: #ffffff;
    border-radius: 10px;
    border-left: 1px solid #eee;
    border-top: 1px solid #eee;
    border-right: 2px solid #eee;
    border-bottom: 2px solid #eee;
}

.nav-sidebar {
	font-size: 20px;
}

.nav-sidebar>li>a {
	color: #888;
	padding: 20px 25px;
	background-image: linear-gradient(to right, #e0e0e0, #e0e0e0 2px, transparent 1px, transparent 4px);
	background-size: 5px 1px;
	background-position: bottom;
	background-repeat: repeat-x;
}
@media (max-width: 991px) {
	.nav-sidebar>li>a {
		padding: 10px 30px;
	}
}

.nav-sidebar>li:last-child>a {
	background-image: none;
}

.nav-sidebar>li>a,
.nav-sidebar>li>a:hover,
.nav-sidebar>li>a:focus {
	background-color: #ffffff;
	outline: none;
}
.nav-sidebar>li>a:hover {
	background-color: #f5f5f5;
	color: #34495e;
}

.nav-sidebar>.active>a,
.nav-sidebar>.active>a:hover,
.nav-sidebar>.active>a:focus {
	margin-top: -1px;
	font-weight: bold;
	color: #34495e;
	background-color: #d6ebfa;
	outline: none;
}

/*
 * content
 */
.content-box {
	margin-right: 20px;
	padding: 10px 40px 20px 40px;
	background: #fff;
	border-radius: 10px;
	border-left: 1px solid #eee;
	border-top: 1px solid #eee;
	border-right: 2px solid #eee;
	border-bottom: 2px solid #eee;
	margin-bottom: 60px;
}
@media (max-width: 991px) {
	.content-box {
		margin-top: 10px;
		margin-right: 0px;
	}
}

.content-title {
	font-size: 14pt;
	font-weight: bold;
	padding: 16px 25px 15px 25px;
	margin-bottom: 15px;
	color: #34495e;
	background-color: #fcf8e3;
	border: solid 1px #e0e0e0;
	border-radius: 5px;
}

/*
 * login
 */
.form-signin {
	max-width: 350px;
	padding: 35px 45px;
	margin: 0 auto;
	margin-top: 30px;
	border: solid 1px #ccc;
	border-radius: 5px;
	box-shadow: 0px 0px 5px 2px rgba(0, 0, 0, 0.1);
	background-color: #ffffff;
}

.form-signin .form-signin-heading, .form-signin .checkbox {
	margin-bottom: 10px;
}

.form-signin .checkbox {
	font-weight: normal;
}

.form-signin .form-control {
	position: relative;
	height: auto;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding: 10px;
	font-size: 16px;
}

.form-signin .form-control:focus {
	z-index: 2;
}

.form-signin input[type="text"] {
	margin-bottom: -1px;
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
}

.form-signin input[type="password"] {
	margin-bottom: 15px;
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}

.login-alert {
	padding-left: 30px;
	padding-top: 15px;
	padding-bottom: 15px;
	margin-top: 0px;
	margin-left: 150px;
	margin-right: 150px;
	margin-bottom: 15px;
	background-color: #FFFFFF;
	font-size: 20px;
	border-left: 1px solid #888;
	border-right: 1px solid #888;
	border-top: 1px solid #888;
	border-bottom: 1px solid #888;
}

/*
 * table
 */
.table-bordered>thead>tr>th {
	text-align: center;
	background-color: #3C73B6;
	color: #fff;
}

.table-bordered>thead>tr>th,
.table-bordered>tbody>tr>th,
.table-bordered>tbody>tr>td {
	vertical-align: middle!important;
	font-size: 16px;
}

.table-bordered>tbody>tr>th {
	background-color: #3C73B6;
	color: #fff;
}

.custom-modal .table {
	margin-bottom: 5px;
}

/*
 * modal
 */
.custom-modal {
	padding-top: 5%;
}
.custom-modal .modal-header {
	font-size: 18px;
}
.custom-modal .modal-body {
	font-size: 18px;
}

/*
 * bootbox
 */
.bootbox {
	padding-top: 5%;
}
.bootbox.progress-modal {
	padding-top: 10%;
}
.bootbox .modal-header {
	padding: 10px 15px;
}
.bootbox .modal-body {
	font-size: 18px;
}

/*
 * 画面共通
 */

/*
 * 画面タイトル
 */
.function-title-box {
	margin-top: 20px;
	margin-bottom: 20px;
}
.function-title {
	font-size: 28px;
	font-weight: bold;
}

/*
 * 検索条件
 */
.search-conditions-box {
	padding: 12px 15px 17px 25px;
	margin-bottom: 20px;
	border-radius: 10px;
	background-color: #d6ebfa;
}
.search-conditions-container {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: row;
		flex-direction: row;
	-ms-flex-align: end;
		align-items: flex-end;
	-ms-flex-wrap: wrap;
		flex-wrap: wrap;
}

.search-condition-box {
	margin-top: 5px;
	margin-right: 15px;
	display: inline-block;
}
.search-condition-title {
	font-size: 18px;
	font-weight: bold;
	text-align: left;
}
.search-condition-box .bootstrap-select,
.search-condition-box .date,
.search-condition-box .month {
	width: 180px!important;
}
.search-condition-box #search_condition_keyword {
	width: 283px!important;
}
.search-condition-box .search-btn-box {
	vertical-align: bottom;
}
.search-condition-box .date {
	width: 165px!important;
}

/*
 * 操作ボタン
 */
.operation-box {
	margin-bottom: 7px;
	font-size: 22px;
}

/*
 * 戻るボタン
 */
#back_btn {
	font-size: 18px;
}
#back_btn:hover {
	text-decoration: none;
}

/*
 * selectpicker
 */
.bootstrap-select .dropdown-menu {
	max-height: 630px;
}

/*
 * 一覧ヘッダー
 */
.list-header-cell:hover {
	cursor: pointer;
}
.list-header-cell.order-asc,
.list-header-cell.order-desc {
	color: black;
	background-color: rgb(146, 189, 247);
}
.list-header-cell .fa {
	font-size: 20px;
}

/*
 * 編集ダイアログ
 */
#edit_data_modal .checkbox,
#edit_data_modal .radio {
	margin-left: 10px;
}

#edit_data_modal .date {
	width: 165px!important;
}

/*
 * 店舗情報、エリア情報、会員情報
 */
.shop-name-box,
.area-name-box,
.member-name-box {
	margin-left: 0px;
	margin-bottom: 10px;
}
.shop-name,
.area-name,
.member-name {
	font-size: 24px;
}

/*
 * 日付選択
 */
.select-date-btn {
	font-size: 32px;
	cursor: pointer;
}
.select-date-btn:hover {
	text-decoration: none;
}
.select-date-btn#previous_btn {
	margin-right: 10px;
}
.select-date-btn#following_btn {
	margin-left: 10px;
}
#current_month {
	display: inline-block;
	vertical-align: middle;
	margin-bottom: 10px;
}
#calendar_btn {
	display: inline-block;
	vertical-align: middle;
	margin-bottom: 15px;
}

/*
 * カレンダー
 */
.setting-calendar>thead>tr>th {
	width: 14%;
	background-color: #fdfde8;
	color: black;
	font-weight: normal;
}
.setting-calendar>thead>tr>th.saturday {
	background-color: rgb(219, 233, 250);
}
.setting-calendar>thead>tr>th.sunday {
	background-color: rgb(250, 216, 217);
}
.setting-calendar>thead>tr>th.saturday {
	color: blue;
}
.setting-calendar>thead>tr>th.sunday {
	color: red;
}
.setting-calendar,
.setting-calendar>thead>tr>th,
.setting-calendar>tbody>tr>th,
.setting-calendar>tbody>tr>td {
	border-color: #999;
}
.setting-calendar>thead>tr>th {
	border-bottom: none;
}
.setting-calendar>tbody>tr>td {
	height: 145px;
	text-align: left;
	vertical-align: top!important;
	padding: 0;
}
.setting-calendar .entry-cell {
	cursor: pointer;
}
.setting-calendar .day-label {
	font-size: 18px;
	margin-top: 5px;
	margin-left: 7px;
}
.setting-calendar .day-label.saturday {
	color: blue;
}
.setting-calendar .day-label.sunday {
	color: red;
}
.setting-calendar .holiday-label {
	margin-left: 5px;
}
.setting-calendar .exclusion-label {
	color: red;
}

.file-drop-area {
	border: 2px dotted #0B85A1;
	width: 100%;
	color: #d8d8d8;
	text-align: center;
	vertical-align: middle;
	padding: 10px;
	margin-bottom: 5px;
	font-size: 200%;
}
.file_input_label{
	padding: 4px;
	color: black;
	background-color: lightgray;
	border-radius: 4px;
	border: solid 1px lightgray;
}
.file_input_label:hover{
	background-color: lightgray;
	border: groove 1px lightgray;
	cursor: pointer;
}

/* 退会手続き用 */
.app-member-quit-container {
	padding: 5px;
	background-color: #FFF;
	border: 1px solid #0077FF;
}