/*
 * 規則セット
 */
:root {
	/* 基本 */
	--base-font-family: 'Open Sans', sans-serif;
	--base-bg-color: white;
	--base-border-color: #eee;

	--header-base-color: #161b60;
	--main-base-color: #2d35ad;
	--main-base-light-color: #d6ebfa;
	--main-base-dark-color: #34495e;

	/* 一覧リストの見出し */
	--list-header-cell-order-color: #92bdf7;

	/* ファイルドロップ */
	--file-drop-color: #d8d8d8;
	--file-drop-border-color: #0B85A1;
	--file-drop-btn-color: black;
	--file-drop-btn-bg-color: lightgray;

	/* フォントサイズ */
	--base-font-size: 14px;
	--base-large-font-size: 16px;
	--base-small-font-size: 14px;
	--base-menu-font-size:  15px;
	--base-title-font-size: 18px;
}

/*
 * 基本
 */
* {
	-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: 70px;
	font-family: var(--base-font-family);
	background-color: #eff0f3;
}
@media (max-width: 572px) {
	body {
		padding-top: 130px;
	}
}

/*
 * ヘッダータイトル部：nav
 */
nav.nav-custom {
	height: 60px;
	background-color: var(--base-bg-color);
	border-top: 5px solid var(--header-base-color);
	border-bottom: 5px solid var(--header-base-color);
	font-family : var(--base-font-family);
}
@media (max-width: 441px) {
	nav.nav-custom {
		height: 90px;
	}
}

.nav-logo {
	position: relative;
	left: 10px;
	margin-right: 20px;
	display: inline-block;
}
.nav-logo>img {
	vertical-align: middle;
	margin-top: 14px;
	margin-right: 2px;
}

.nav-link {
	position: relative;
	right: 25px;
	font-size: var(--base-font-size);
	display: inline-block;
	top: 10px;
	font-family: var(--base-font-family);
}
@media (max-width: 441px) {
	.nav-link {
		top: 0px;
	}
}

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

.nav-link>li.active>a,
.nav-link>li.active>a:hover,
.nav-link>li.active>a:focus {
	margin-top: -1px;
	color: #34495e;
	background-color: transparent;
	outline: none;
}

.nav-link-user {
	position: relative;
	right: 25px;
	font-size: var(--base-font-size);
	display: inline-block;
	top: 10px;
	font-family: var(--base-font-family);
}
@media (max-width: 441px) {
	.nav-link-user {
		top: 0px;
	}
}

.nav-link-user>li>a,
.nav-link-user>li>a:hover,
.nav-link-user>li>a:focus {
	outline: none;
	display: inline-block;
}

.nav-link-user>li>a:hover,
.nav-link-user>li>a:focus {
	background-color: #ec971f;
	border-color: #d58512;
}

.nav-link-user>li.active>a,
.nav-link-user>li.active>a:hover,
.nav-link-user>li.active>a:focus {
	margin-top: -1px;
	outline: none;
}

.nav-link-user>li.active>a:hover,
.nav-link-user>li.active>a:focus {
	background-color: #ec971f;
	border-color: #d58512;
}

/*
 * information表示部：infobar
 */
.infobar {
	padding: 0px 15px 2px 15px;
	font-size: var(--base-small-font-size);
}

/*
 * ベースフレームエリア
 */
 .side_frame {
    width: 260px;
    float: left;
}

.main_frame {
    margin-left: -260px;
    width: 100%;
    float: left;
}

.main_frame .main_frame_inner {
    margin-left: 260px;
}

/*
 * メニュー表示部：sidebar
 */
.sidebar {
	margin-left: 20px;
	margin-right: 5px;
	padding: 5px 0px;
	background-color: var(--base-bg-color);
    border-radius: 10px;
    border-left: 1px solid var(--base-border-color);
    border-top: 1px solid var(--base-border-color);
    border-right: 2px solid var(--base-border-color);
    border-bottom: 2px solid var(--base-border-color);
}

.nav-sidebar {
	font-size: var(--base-menu-font-size);
}

.nav-sidebar>li>a {
	color: #888;
	padding: 15px 10px;
	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: var(--base-bg-color);
	outline: none;
}
.nav-sidebar>li>a:hover {
	background-color: #f5f5f5;
	color: var(--main-base-dark-color);
}

.nav-sidebar>.active>a,
.nav-sidebar>.active>a:hover,
.nav-sidebar>.active>a:focus {
	margin-top: -1px;
	font-weight: bold;
	color: var(--main-base-dark-color);
	background-color: var(--main-base-light-color);
	outline: none;
}

/* 
 * サイドバーアイコンサイズ調整
 */
.nav>li>a>.fa,
.nav>li>a>.fas,
.nav>li>a>.far {
	width : 20px;
}

/*
 * メイン表示部：content
 */
.content-box {
	margin-left: 5px;
	margin-right: 20px;
	padding: 10px 40px 20px 40px;
	background: var(--base-bg-color);
	border-radius: 10px;
	border-left: 1px solid var(--base-border-color);
	border-top: 1px solid var(--base-border-color);
	border-right: 2px solid var(--base-border-color);
	border-bottom: 2px solid var(--base-border-color);
	margin-bottom: 60px;
	font-size: var(--base-small-font-size);
}
@media (max-width: 991px) {
	.content-box {
		margin-top: 10px;
		margin-right: 0px;
	}
}

/*
 * ログイン画面：login
 */
.form-signin {
	max-width: 350px;
	padding: 35px 45px;
	margin: 0 auto;
	margin-top: 30px;
	border: solid 1px var(--base-border-color);
	border-radius: 5px;
	box-shadow: 0px 0px 5px 2px rgba(0, 0, 0, 0.1);
	background-color: var(--base-bg-color);
}

.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: var(--base-font-size);
}

.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;
}

/*
 * 一覧リスト表示：table
 */
.table-bordered>thead>tr>th {
	text-align: center;
	background-color: var(--main-base-color);
	color: #fff;
}

.table-bordered>thead>tr>th,
.table-bordered>tbody>tr>th,
.table-bordered>tbody>tr>td {
	vertical-align: middle!important;
	font-size: var(--base-font-size);
}

.table-bordered>tbody>tr>th {
	background-color: var(--main-base-color);
	color: #fff;
}

/* テーブル内の文字列を折り返しで表示する */
.table.table-striped.table-bordered {
	word-break:break-word;
}

/*
 * 一覧リストのソート機能
 */
.list-header-cell:hover {
	cursor: pointer;
}
.list-header-cell.order-asc,
.list-header-cell.order-desc {
	color: black;
	background-color: var(--list-header-cell-order-color);
}
.list-header-cell .fa {
	font-size: var(--base-large-font-size);
}

/*
 * bootbox
 */
.bootbox {
	padding-top: 5%;
}
.bootbox.progress-modal {
	padding-top: 10%;
}
.bootbox .modal-header {
	padding: 10px 15px;
}
.bootbox .modal-body {
	font-size: var(--base-large-font-size);
}

/*
 * 画面共通
 */

/*
 * 画面タイトル
 */
.function-title-box {
	margin-top: 5px;
	margin-bottom: 0px;
}
.function-title {
	font-size: var(--base-title-font-size);
	font-weight: bold;
}

/*
 * 検索条件
 */
.search-conditions-box {
	padding: 12px 15px 17px 25px;
	margin-bottom: 20px;
	border-radius: 10px;
	background-color: var(--main-base-light-color);
}
.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: var(--base-small-font-size);
	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;
}

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

/* 
 * 詳細表示情報
 */
.table-detail > tbody > tr > td {
	background-color: #f5f5f5;
}
.table-detail>thead>tr>th {
	text-align: center;
	background-color: var(--main-base-color);
	color: #fff;
}
.table-detail>tbody>tr>th {
	background-color: var(--main-base-color);
	color: #fff;
}

/* 
 * ダイアログタイトル
 */
.modal-title {
	color: var(--header-base-color);
	font-weight: bold;
	font-size: var(--base-font-size);
}

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

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

/*
 * ファイルドロップエリア
 */
.file-drop-area {
	border: 2px dotted var(--file-drop-border-color);
	width: 100%;
	color: var(--file-drop-color);
	text-align: center;
	vertical-align: middle;
	padding: 10px;
	margin-bottom: 5px;
	font-size: 200%;
}
.file_input_label{
	padding: 4px;
	color: var(--file-drop-btn-color);
	background-color: var(--file-drop-btn-bg-color);
	border-radius: 4px;
	border: solid 1px var(--file-drop-btn-bg-color);
}
.file_input_label:hover{
	background-color: var(--file-drop-btn-bg-color);
	border: groove 1px var(--file-drop-btn-bg-color);
	cursor: pointer;
}

/*
 * 一覧のサムネイル画像
 */
.list_thumb {
	max-height: 100px;
}

/*
 * オペレーションボックス
 */
.operation-box {
	margin-bottom: 7px;
}

/*
 * ボタン
 */
/* 新規登録、編集、検索、削除ボタン */
.new-btn,
.edit-btn,
#search_btn,
#delete_btn {
	font-size: var(--base-small-font-size);
	font-weight: bold;
}

.output-btn {
	font-size: var(--base-small-font-size);
	font-weight: bold;
	margin-left: 40px;
}

/* 保存、戻るボタン */
.save_btn_large,
#back_btn {
	font-size: var(--base-large-font-size);
	font-weight: bold;
}

/* 戻るボタン */
#back_btn:hover {
	text-decoration: none;
	font-weight: bold;
}

/* 送信ボタン */
.notice_btn_large {
	font-size: var(--base-large-font-size);
	font-weight: bold;
}

.form_conf {
    text-align: center;
}
.form_conf form {
    display: inline-block;
    margin: 0 80px;
}

.form_output {
    text-align: left;
}
.form_output form {
    display: inline-block;
}

.btn-primary {
	color: #fff;
	background-color: #2d35ad;
	border-color: #2d35ad;
}

.btn-notice {
	color: #fff;
	background-color: #ff007f;
	border-color: #ff007f;
}

.btn-link {
	font-weight: normal;
	color: #2d35ad;
	border-radius: 0;
}
  
/*
 * 必須ラベル
 */
.label-hissu {
	background-color: #ff007f;
	font-size: 50%;
	margin-left: 2px;
}

/*
 * 変更不可ラベル
 */
.label-fuka {
	background-color: #1f8516;
	font-size: 50%;
	margin-left: 2px;
}

/*
 * 配信対象のチェックボックスのカーソル設定
 */
.label-check, input[type='checkbox'] {
    cursor: pointer;
	font-weight: normal !important;
}

/*
 * 配信対象のラジオボタンのカーソル設定
 */
.label-radio-bold, input[type='radio'] {
    cursor: pointer;
}

.label-radio-normal, input[type='radio'] {
    cursor: pointer;
	font-weight: normal;
}

.label-name {
	font-weight: normal !important;
	color: black;
}

/*
 * プッシュ通知送信済みフラグ設定
 */
.send-flag {
	font-weight: bold;
	color: #ff007f;
}

/*
 * 注意書き
 */
.caution-text {
	font-weight: bold;
	color: #ff0000;
}

/* 
 * etc
 */
.full-width {
	width: 100%;
}

/*
 * フッター（会社情報）
 */
 #company-info-area {
	background-color: #FAF0EB;
 }

 /*
 * フッター（コピーライト）
 */
 #copyright-area {
	background-color: #ED731E;
	color:white;
 }