@charset "utf-8";

:root {
	/* base colors */
	--color-main: #3D62AD; /* 佐川印刷カラー */
	--color-text: #333333;
	--color-subtext: #666666;
	--color-background: #FAFAFA;
	--color-primary: #007BFF;
	--color-primary-light: color-mix(in srgb, var(--color-primary) 80%, white 20%);
	--color-primary-dark: color-mix(in srgb, var(--color-primary) 80%, black 20%);
	--color-success: #28A745;
	--color-success-light: color-mix(in srgb, var(--color-success) 80%, white 20%);
	--color-success-dark: color-mix(in srgb, var(--color-success) 80%, black 20%);
	--color-danger: #DC3545;
	--color-danger-light: color-mix(in srgb, var(--color-danger) 80%, white 20%);
	--color-danger-dark: color-mix(in srgb, var(--color-danger) 80%, black 20%);
	--color-info: #17A2B8;
	--color-info-light: color-mix(in srgb, var(--color-info) 80%, white 20%);
	--color-info-dark: color-mix(in srgb, var(--color-info) 80%, black 20%);
	--color-gray: #6C757D;
	--color-gray-light: color-mix(in srgb, var(--color-gray) 80%, white 20%);
	--color-gray-dark: color-mix(in srgb, var(--color-gray) 80%, black 20%);

	/* form */
	--color-form-background: #DDDDDD;
	--color-input-background: #FFFFFF;
	--color-input-background-error: #FFE6E6;
	--color-input-border: #CCCCCC;
	--color-input-border-error: #FF0000;
	--color-input-focus-border: #007BFF;

	/* button */
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-gray);
	--color-button-background-hover: var(--color-gray-dark);
	--color-button-disabled-background: var(--color-gray-light);

	/* toggle-button */
	--color-toggle-button-background: var(--color-primary);

	/* sidebar */
	--color-sidebar-background: #444444;
	--color-sidebar-text-color: #FFFFFF;

	/* table */

	/* modal */
	--color-modal-background: #FFFFFF;


	/* Drag and Drop */
	--dropzone-text-color: #666;
	--dropzone-bg-color: #f0f8ff;
	--dropzone-border-color: #3399ff;
	--dropzone-text-color-dragover: #000;
	--dropzone-bg-color-dragover: #ffe6e6;
	--dropzone-border-color-dragover: #ff0000;
}

/* フォント */
@font-face {
	font-family: "Local Noto Sans JP";
	src: local("Noto Sans JP");
}
@font-face {
	font-display: swap;
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	src: url('/fonts/noto-sans-jp-v54-22663bb3520fe55576f86e993a7c7742.woff2') format('woff2');
}

/***** 共通スタイル *****/
html, body {
	cursor: auto;
	color: var(--color-text);
	background-color: var(--color-background);
	font-family: 'Local Noto Sans JP', 'Noto Sans JP', sans-serif;
	height: 100%;
}

body {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
main {
	flex: 1;
	display: flex;
	overflow: hidden;
}
.sub-text {
	font-size: 0.8rem;
	color: var(--color-subtext);
	min-height: 20px;
}
ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.hide {
	display: none !important;
	visibility: hidden !important;
}
.text-left {
	text-align: left !important;
}
.text-right {
	text-align: right !important;
}
.text-center {
	text-align: center !important;
}
.align-top {
	vertical-align: top !important;
}
.align-middle {
	vertical-align: middle!important;
}
.align-bottom {
	vertical-align: bottom!important;
}
.pointer {
	cursor: pointer !important;
}
.message {
	margin: 20px 0;
	padding: 20px;
	border: 1px solid;
	border-color: var(--color-text);
}
.message.message-error {
	background-color: #f8d7da;
	border-color: #f58085;
	color: #58151c;
}
.message.message-primary {
	background-color: #cfe2ff;
	border-color: #9ec5fe;
	color: #052c65;
}

/*** フォーム ***/
input,
textarea {
	flex: 1;
	padding: 8px;
	border: 1px solid var(--color-input-border);
	border-radius: 6px;
	background-color: var(--color-input-background);
}
textarea {
	line-height: 20px;
	min-height: 40px;
}
input[type="radio"] {
	margin-right: 5px;
}
input:has(+ .fa-solid.fa-eye),
input:has(+ .fa-solid.fa-eye-slash) {
	padding-right: 40px;
}

/* エラー表示 */
.error input,
.error textarea,
.error .selectbox select {
	border-color: var(--color-input-border-error);
	background-color: var(--color-input-background-error);
}
.error .sub-text:not(.info-text) {
	color: var(--color-input-border-error);
}

/* プルダウン */
.selectbox {
	display: inline-flex;
	align-items: center;
	position: relative;
}
.selectbox::after {
	position: absolute;
	right: 12px;
	width: 10px;
	height: 7px;
	background-color: var(--color-subtext);
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	content: '';
	pointer-events: none;
}
.selectbox select {
	appearance: none;
	width: auto;
	height: 33px;
	padding: .4em calc(.8em + 30px) .4em .8em;
	border: 1px solid var(--color-input-border);
	border-radius: 6px;
	background-color: var(--color-input-background);
	font-size: 13px;
	cursor: pointer;
}

/* select2 */
.select2-selection--single:focus-visible {
	outline: 2px solid;
	outline-color: var(--color-input-focus-border);
}
.select2-container--default .select2-selection--single {
	border-radius: 6px;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	color: #000;
	font-size: 13px;
	position: relative;
	top: 2px;
}
.select2-container--default .select2-selection--single .select2-selection__arrow{
	top: 3px;
}
.select2-results__option {
	color: #000;
	font-size: 13px;
	min-height: 32px;
}
.select2-search input {
	border-radius: 0;
}
.select2-search.select2-search--dropdown {
	border-bottom: 1px solid var(--color-input-border) !important;
}
.select2-container--default .select2-selection--multiple,
.select2-container--default.select2-container--focus .select2-selection--multiple {
	border-color: var(--color-input-border) !important;
}
.select2-container--default .select2-selection--single {
	border-color: var(--color-input-border) !important;
	min-height: 33px !important;
}
.error .select2-container--default .select2-selection--single {
	border-color: var(--color-input-border-error) !important;
	background-color: var(--color-input-background-error);
}
.select2-selection.select2-selection--multiple {
	min-height: 36px !important;
}
.select2-container .select2-search--inline .select2-search__field {
	margin-top: 8px !important;
}
/* select2 を Bootstrap の幅に合わせる */
.select2-container {
	width: 100% !important;
}
.js-select2-wrapper {
	position: relative;
	overflow: visible;
}

/* flatpickr */
/* 年と月の表示順を逆にする */
.flatpickr-current-month {
	display: flex !important;
	justify-content: center !important;
	flex-direction:row-reverse !important;
}
/* 日付に色を設定 */
.dayContainer .flatpickr-day.today { border-color: #569ff7; }
.dayContainer .flatpickr-day.today:hover { background: #569ff7; }
.flatpickr-weekday:nth-child(1) { color: rgba(255, 0, 0, 0.6); }
.flatpickr-weekday:nth-child(7) { color: rgba(0, 0, 255, 0.6); }
.flatpickr-day.saturday:not(.selected) { color: rgb(0, 0, 255); }
.flatpickr-day.prevMonthDay.saturday:not(.selected),
.flatpickr-day.nextMonthDay.saturday:not(.selected),
.flatpickr-day.flatpickr-disabled.saturday:not(.selected) { color: rgba(0, 0, 255, 0.2); }
.flatpickr-day.sunday:not(.selected),
.flatpickr-day.holiday:not(.selected) { color: rgb(255, 0, 0); }
.flatpickr-day.prevMonthDay.sunday:not(.selected),
.flatpickr-day.nextMonthDay.sunday:not(.selected),
.flatpickr-day.prevMonthDay.holiday:not(.selected),
.flatpickr-day.nextMonthDay.holiday:not(.selected),
.flatpickr-day.flatpickr-disabled.sunday:not(.selected),
.flatpickr-day.flatpickr-disabled.holiday:not(.selected) { color: rgba(255, 0, 0, 0.2); }
/* クリアボタン */
.flatpickr-calendar .clear-button {
	padding: 5px;
	color: var(--color-subtext);
	cursor: pointer;
}
.flatpickr-calendar .clear-button:hover {
	background-color: var(--color-background);
}

/* フォーカスが当たった場合 */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
#pagination > span:focus-visible {
	outline: 2px solid;
	outline-color: var(--color-input-focus-border);
	z-index: 1;
}
input[type="radio"],
input[type="checkbox"] {
	accent-color: blue;
	-ms-transform: scale(1.25, 1.25);
	-webkit-transform: scale(1.25, 1.25);
	transform: scale(1.25, 1.25);
	transform-origin: top left;
}

/* readonly */
select[readonly],
input[type="radio"][readonly],
input[type="checkbox"][readonly]{
	pointer-events: none;
}

/* disabled */
input[type="checkbox"]:not([disabled]),
input[type="checkbox"]+label {
	cursor: pointer;
}
[aria-disabled="true"], [disabled] {
	cursor: auto;
	background-color: #e9ecef !important;
	color: #545454 !important;
}

/* required */
label.required {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.required::before {
	content: "必須";
	font-size: 0.75em;
	margin: 0 5px;
	padding: 0 5px;
	background-color: red;
	color: #FFF;
	display: inline-block;
}

/*** ボタン ***/
button {
	cursor: pointer;
	border: none;
	background-color: var(--color-button-background);
	border-radius: 4px;
	color: var(--color-button-text);
	font-size: 14px;
	padding: 8px 16px;
	transition: background-color 0.1s ease;
}
button:hover {
	background-color: var(--color-button-background-hover);
}
button:disabled {
	background-color: var(--color-button-disabled-background);
	cursor: auto;
	pointer-events: none;
}
button.btn-outline {
	background-color: #FFFFFF;
	border: 1px solid var(--color-button-background);
	color: var(--color-button-background);
	padding: 6px 14px;
}
button.btn-outline:hover {
	background-color: var(--color-button-background);
	color: var(--color-button-text);
}
button.btn-outline:disabled {
	background-color: transparent;
	color: var(--color-button-disabled-background);
	border-color: var(--color-gray-light);
}
button.btn-primary {
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-primary);
	--color-button-background-hover: var(--color-primary-dark);
	--color-button-disabled-background: var(--color-gray-light);
}
button.btn-success {
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-success);
	--color-button-background-hover: var(--color-success-dark);
	--color-button-disabled-background: var(--color-gray-light);
}
button.btn-danger {
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-danger);
	--color-button-background-hover: var(--color-danger-dark);
	--color-button-disabled-background: var(--color-gray-light);
}
button.btn-info {
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-info);
	--color-button-background-hover: var(--color-info-dark);
	--color-button-disabled-background: var(--color-gray-light);
}
button.btn-gray {
	--color-button-text: #FFFFFF;
	--color-button-background: var(--color-gray);
	--color-button-background-hover: var(--color-gray-dark);
	--color-button-disabled-background: var(--color-gray-light);
}
a:has(button) {
	font-size: 0;
}

/*** トグルボタン ***/
label.toggle-button {
	--w: 50px; /* デフォルト幅 */
	--h: 25px; /* デフォルト高さ */
	--knob: var(--h);
	display: inline-block;
	position: relative;
	width: var(--w);
	height: var(--h);
	border-radius: var(--h);
	background-color: #ddd;
	cursor: pointer;
	transition: background-color .2s;
}
label.toggle-button:has(:checked) {
	background-color: var(--color-toggle-button-background);
}
label.toggle-button::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: var(--knob);
	height: var(--knob);
	border-radius: 50%;
	background-color: #fff;
	box-shadow: 0 0 5px rgb(0 0 0 / 20%);
	transition: left .2s;
}
label.toggle-button:has(:checked)::after {
	left: calc(var(--w) - var(--knob));
}
label.toggle-button input {
	display: none;
}
label.toggle-button.w-100 {
	width: 100%;
	--w: 100%; /* ノブ位置の計算用 */
}
label.toggle-button:focus-visible {
	outline: 2px solid;
	outline-color: var(--color-input-focus-border);
}
label.toggle-success {
	--color-toggle-button-background: var(--color-success);
}
label.toggle-danger {
	--color-toggle-button-background: var(--color-danger);
}
label.toggle-info {
	--color-toggle-button-background: var(--color-info);
}
label.toggle-gray {
	--color-toggle-button-background: var(--color-gray);
}

/*** パスワードアイコン ***/
/* Edgeの標準アイコンを非表示とする */
::-ms-reveal {
	display: none;
}
.fa-eye-slash,
.fa-eye {
	position: relative;
	top: 10px;
	right: 30px;
	cursor: pointer;
	color: var(--color-subtext);
	width: 0;
	z-index: 1;
}
.password-wrapper {
	display: inline-flex;
	width: 100%;
}

.gap-0 {
	gap: 0!important
}
.gap-1 {
	gap: .25rem!important
}
.gap-2 {
	gap: .5rem!important
}
.gap-3 {
	gap: 1rem!important
}
.gap-4 {
	gap: 1.5rem!important
}
.gap-5 {
	gap: 3rem!important
}
.row-gap-0 {
	row-gap: 0!important
}
.row-gap-1 {
	row-gap: .25rem!important
}
.row-gap-2 {
	row-gap: .5rem!important
}
.row-gap-3 {
	row-gap: 1rem!important
}
.row-gap-4 {
	row-gap: 1.5rem!important
}
.row-gap-5 {
	row-gap: 3rem!important
}
.column-gap-0 {
	-moz-column-gap: 0!important;
	column-gap: 0!important
}
.column-gap-1 {
	-moz-column-gap: 0.25rem!important;
	column-gap: .25rem!important
}
.column-gap-2 {
	-moz-column-gap: 0.5rem!important;
	column-gap: .5rem!important
}
.column-gap-3 {
	-moz-column-gap: 1rem!important;
	column-gap: 1rem!important
}
.column-gap-4 {
	-moz-column-gap: 1.5rem!important;
	column-gap: 1.5rem!important
}
.column-gap-5 {
	-moz-column-gap: 3rem!important;
	column-gap: 3rem!important
}
body .w-100 { width: 100%;}

/***** ヘッダー *****/
header {
	background-color: #333;
	color: white;
	padding: 0 20px;
	height: 40px;
}
header .header-left img.logo {
	height: 30px;
	background-color: #FFFFFF;
	padding: 2px;
}
header .header-left .env {
	padding: 2px 10px;
	margin-left: 10px;
	border: 1px solid;
	font-size: 0.75em;
}
header .header-left .env.test{
	border-color: #ef6c00;
	color: #ef6c00;
	font-weight: bold;
}

header .header-menu li {
	display: flex;
	padding: 0 20px;
	border-left: 1px solid #FFFFFF;
	align-items: center;
	cursor: pointer;
}
header .header-menu li:first-child {
	border-left: none;
	padding-left: 0;
}
header .header-menu li:last-child {
	padding-right: 0;
}
header .header-menu li i {
	margin-right: 2px;
}
header .header-right .tooltip {
	position: absolute;
	top: 40px;
	right: 0px;
	background-color: #fff;
	color: #333;
	border: 1px solid;
	border-color: #CCC;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
	min-width: 170px;
	font-size: 0.9em;
	z-index: 2000;
}
header .header-right .tooltip ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
header .header-right .tooltip li:hover {
	background-color: #F0F0F0;
}
header .header-right .user-tooltip li {
	padding: 8px 15px;
	cursor: pointer;
}
header .header-right .tooltip a {
	padding: 8px 15px;
	cursor: pointer;	color: inherit;
	text-decoration: none;
	display: block;
}
header .header-right .user-tooltip {
	right: 15px;
}
header .header-right .maintenance-tooltip {
	right: 142px;
	max-height: calc(90% - 40px);
	overflow-y: hidden;
}
header .header-right .maintenance-tooltip:hover {
	overflow-y: auto;
}

/* パスワード変更 */
header #formChangePassword {
	width: 580px;
}

/* お知らせベル */
header a {
	color: #FFFFFF;
	text-decoration: none;
}
header .fa-bell {
	font-size: 1.4em;
}
header .header-right li {
	position: relative;
}
header .header-right .badge {
	position: absolute;
	top: -3px;
	right: 7px;
	background-color: red;
	border-radius: 8px;
	font-size: 0.7em;
	font-weight: bold;
	word-break: keep-all;
	padding: 0 3px;
	min-width: 17px;
	text-align: center;
}

/* お知らせ */
#header-notice-container {
	position: fixed;
	overflow: hidden;
	z-index: 10;
	top: 40px;
	right: -415px;
	width: 400px;
	height: calc(100vh - 40px);
	box-shadow: -5px 0 10px rgba(0, 0, 0, .3);
	background-color: #FFF;
	color: var(--color-text);
	transition: right 0.3s ease;
}
#header-notice-container.is-open {
	right: 0;
}
@media (max-width: 768px) {
	#header-notice-container.is-open {
		width: 100%;
	}
}
#header-notice-container .notice-header {
	background-color: var(--color-main);
	color: #FFF;
	height: 45px;
}
#header-notice-container .notice-header h3 {
	margin: 0;
}
#header-notice-container .notice-all-read-wrapper {
	transform: scale(0.75);
}

#header-notice-container .notice-content {
	overflow-y: auto;
	height: calc(100% - 45px);
}
#header-notice-container .fa-xmark {
	font-size: 1.25em;
	cursor: pointer;
}
#header-notice-container .notice-list-item {
	background-color: #FFF;
	border-bottom: 1px solid #cecece;
}
#header-notice-container .notice-list-item:hover {
	background-color: #fffde3;
}
#header-notice-container .notice-list-item.is-read {
	background-color: #ececec;
}
#header-notice-container .notice-list-item.is-read:hover {
	background-color: #f3f3f3;
}

#header-notice-container .notice-list-link {
	padding: 10px;
	color: var(--color-text);
	display: flex;
	justify-content: space-between;
}
#header-notice-container .notice-list-info {
	font-size: 0.8em;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-ms-flex-negative: 1;
	flex-shrink: 1;
	min-width: 0;
	width: 100%;
}
#header-notice-container .notice-list-data {
	font-size: 0.8em;
	min-width: 70px;
	display: flex;
	flex-direction: column;
	align-items: end;
	gap: 10px;
}
#header-notice-container .notice-list-data .unread {
	background-color: var(--color-danger);
	border-radius: 8px;
	color: #FFFFFF;
	display: block;
	width: 45px;
	text-align: center;
}
#header-notice-container .notice-list-title {
	font-weight: bold;
	margin-bottom: 5px;
}
#header-notice-container .notice-list-title,
#header-notice-container .notice-list-text {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
#header-notice-container .notice-list-text {
	display: -webkit-box;
	overflow: hidden;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	white-space: normal !important;
}

/* ヘッダー右側のユーザー情報 */
header .header-right .username {
	margin-left: 8px;
}
header .icon-user {
	display: inline-block;
	position: relative;
	border-radius: 50%;
	background-color: #89baeb;
	width: 1em;
	height: 1em;
	font-size: 30px;
	overflow: hidden;
}
header .icon-user::before,
header .icon-user::after {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	border-radius: 50%;
	background-color: #3388dd;
	content: "";
}
header .icon-user::before {
	top: 0.15em;
	width: 0.4em;
	height: 0.4em;
}
header .icon-user::after {
	bottom: -0.4em;
	width: 0.8em;
	height: 0.8em;
}
header .icon-user.active::before {
	top: 0.1em;
}
header .icon-user.active::after {
	bottom: -0.45em;
}

/***** フッター *****/
footer {
	text-align: center;
	padding: 5px;
	background-color: #444;
	color: #FFFFFF;
	font-size: 14px;
}

/***** サイドメニュー *****/
/* 開いている時 */
.sidebar {
	background-color: var(--color-sidebar-background);
	color: var(--color-sidebar-text-color);
	width: 223px;
	padding: 10px;
	height: 100%;
	overflow-y: hidden;
	position: relative;
	scrollbar-gutter: stable;
	scrollbar-width: thin;
}
/* 閉じた時 */
.sidebar.closed {
	width: 50px;
}
/* 開閉アイコン表示部（ヘッダー部） */
.sidebar-toggle {
	background-color: var(--color-sidebar-background); /* 同色にしてヘッダー固定を再現 */
	position: fixed;
	z-index: 1;
	width: inherit;
	height: 40px;
	top: 40px;
	left: -10px;
	padding: 10px 20px;
}
/* 余白を含めて開閉アイコン表示部の高さ分だけズラす */
.menu-section {
	padding-top: 30px;
}
/* 開閉アイコン */
.sidebar-toggle .fa-angle-right,
.sidebar-toggle .fa-xmark {
	font-size: 1.5em;
	cursor: pointer;
}
.sidebar-toggle .fa-xmark {
	position: absolute;
	right: 10px;
}
/* スクロールできるようにする */
.sidebar:hover {
	overflow-y: auto;
}
/* スクロールバーのデザイン */
/* .sidebar::-webkit-scrollbar {
	width: 8px;
}
.sidebar::-webkit-scrollbar-track {
	background: transparent;
}
.sidebar::-webkit-scrollbar-thumb {
	background-color: rgba(255, 255, 255, 0.3);
	border-radius: 4px;
} */
.sidebar .active {
	background-color: #555;
}
.sidebar .menu-item {
	position:relative;
	cursor: pointer;
	margin-bottom: 20px;
}
.sidebar .menu-item.disabled {
	background-color: #333;
	color: #666;
}
/* 折りたたみアイコン */
.sidebar .menu-item > .menu-title::after {
	content: '';
	position: absolute;
	right: 10px;
	top: 14px;
	color: #FFF;
	width: 8px;
	height: 8px;
	border: 0.1em solid;
	border-left: 0;
	border-bottom: 0;
	transform: translateY(-25%) rotate(-45deg);
}
/* 折りたたみアイコン（閉じている時） */
.sidebar .menu-item > .menu-title.close::after {
	top: 8px;
	transform: translateY(-25%) rotate(135deg);
}
/* 子コンテンツを持っていない要素に折りたたみアイコンを表示しない */
.sidebar .menu-item:not(:has(> .submenu-section)) > .menu-title::after {
	content: none;
}
/* 子コンテンツ位置調整 */
.sidebar .menu-item:has(> .submenu-section) {
	padding-left: 10px;
}
.sidebar .submenu-section a {
	padding-left: 15px;
}
/* リンク */
.sidebar a {
	color: inherit;
	text-decoration: none;
	display: block;
	padding: 5px 0;
	padding-left: 10px;
}
.sidebar .menu-item:not(.disabled) a:hover {
	background-color: #666;
}
/* バッチ */
.sidebar .menu-name {
	position: relative;
}
.sidebar .badge {
	position: absolute;
	top: -3px;
	background-color: red;
	border-radius: 8px;
	font-size: 0.7em;
	font-weight: bold;
	word-break: keep-all;
	padding: 0 3px;
	margin-left: 3px;
	min-width: 17px;
	text-align: center;
}
/* 仕入先一覧モーダル */
#modal-supplier-list .modalContent {
	min-width: 50%;
	max-height: 90%;
}
#modal-supplier-list .modalFooter button {
	width: 120px;
}
/* エラーアラート */
.menu-title a .fa-circle-exclamation {
	color: red;
	position: absolute;
	top: 10px;
}
.menu-title a .fa-circle-exclamation::after {
	content: "";
	display: block;
	width: 5px;
	height: 13px;
	background-color: #FFF;
	top: -14px;
	position: relative;
	left: 7px;
	z-index: -1;
}
.menu-title a .fa-circle-exclamation + span {
	margin-left: 20px;
	color:red;
	font-weight: bold;
}

/***** メインコンテンツ *****/
.main-content-wrapper {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow-y: auto;
	padding: 0;
}
.main-content {
	flex-grow: 1;
	padding: 15px;
}
.main-content h3 {
	border-left: 10px solid red;
	padding: 0 10px;
}
.fw-bold {
	font-weight: bold;
}

/***** 一覧テーブル *****/
.table-list-controller {
	margin-top: 30px;
}
.table-list-controller .result-label {
	font-weight: bold;
	margin-right: 20px;
}
.table-list-wrapper {
	display: table;
	width: 100%;
}
.table-list {
	width: 100%;
	font-size: 0.85em;
	background-color: #AAAAAA;
	border-collapse: collapse;
}
.table-list th {
	padding: 5px;
}
.table-list th.sortable {
	cursor: pointer;
}
.sort-column-title {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 5px;
}
.table-list td {
	padding: 10px 5px;
}
.table-list th,
.table-list td {
	border-left: 1px solid #AAAAAA; /* 左の列罫線だけ表示 */
}
.table-list th:first-child,
.table-list td:first-child {
	border-left: none; /* 一番左のセルは罫線なし */
}
.table-list thead th {
	background-color: #D4D4D6;
}
.table-list tbody tr:nth-child(odd) {
	background-color: #FFFFFF;
}
.table-list tbody tr:nth-child(even) {
	background-color: #f2f2f2;
}
.table-list tbody tr.selected {
	background-color: #c2e7ff;
	color: #004a77;
}
.table-sticky thead th {
	position: sticky;
	z-index: 1;
	top: 0px;
}
tr.drag-over {
	box-shadow: inset 0 0 0 2px #007bff;
	background-color: #d0ecff !important;
}
tr#nodata td,
tr.nodata td {
	text-align: center;
	padding: 20px !important;
}

/***** ページネーション *****/
.pagination-container {
	display: flex;
	align-items: center;
	gap: 0px;
	flex-wrap: wrap;
	height: 35px;
	font-size: 14px;
}
.pagination-wrapper .selectbox::before {
	content: "表示件数:";
	font-size: 14px;
	padding-right: 10px;
}
.page-link {
	height: 100%;  /* 親要素の高さにフィット */
	display: flex; /* 中央揃え */
	align-items: center;
	justify-content: center;
	border: 1px solid #ccc;
	background-color: #f9f9f9;
	color: #333;
	text-decoration: none;
	cursor: pointer;
	border-radius: 0px;
	width: 45px;
	user-select: none;
}
.page-link:hover {
	background-color: #eee;
}

.page-current {
	font-weight: bold;
	background-color: var(--color-info);
	color: white;
	border-color: var(--color-info);
	cursor: default;
}
.page-current:hover {
	background-color: var(--color-info-dark);
}
.first-page,
.last-page {
	font-size: 0.8em;
	line-height: 1;
}
.ellipsis {
	pointer-events: none;
	opacity: 1;
}

/***** モーダル *****/
body.no-scroll {
	overflow: hidden;
}
/* 背景 */
.screenOverlay:not(.hide) {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1000;
}
/* 本体 */
.screenOverlay .modalContent {
	background-color: var(--color-modal-background);
	color: var(--color-text);
	font-size: 15px;
	display: none;
	width: 500px;
	max-height: 95vh;
	box-sizing: border-box;
	flex-direction: column;
	box-shadow: 0 0 12px rgba(0, 0, 0, 0.5);
	position: relative;
	padding: 15px;
}
.screenOverlay .active {
	display: flex;
}
.screenOverlay .modalHeader {
	font-weight: bold;
	margin-bottom: 20px;
}
.screenOverlay .modalBody {
	overflow: hidden auto;
}

/* モーダル内フッター */
.screenOverlay .modalFooter {
	margin-top: 20px;
}
.modalFooter button {
	margin-left: 10px;
	min-width: 100px;
}
/* モーダル内テーブル */
.modalBody table {
	border-collapse: collapse;
	width: 100%;
}
.modalBody thead th {
	background-color: #D4D4D6;
}
.modalBody tbody tr:nth-child(even) {
	background-color: #f2f2f2;
}
.modalBody tbody td {
	padding: 5px 10px;
}

/***** 既読確認モーダル *****/
#confirm-notice-all-read .modalFooter button {
	width: 120px;
}

/***** スピナー *****/
#spinner-wrapper {
	z-index: 10000;
}
.spinner {
	border-style: solid;
	border-color: #fff;
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}
.spinner--lg {
	width: 80px;
	height: 80px;
	border-width: 10px;
}
.spinner--sm {
	width: 40px;
	height: 40px;
	border-width: 5px;
}
@keyframes spin {
	to { transform: rotate(360deg); }
}

/***** ページトップに戻る *****/
#pagetop {
	position: fixed;
	right: 40px;
	bottom: 40px;
	z-index: 2;
	width: 50px;
	height: 50px;
	cursor: pointer;
	background: rgba(0, 0, 0, .5);
	transition: .5s;
	display: flex;
	justify-content: center;
	align-items: center;
}
#pagetop i {
	color: #FFF;
	font-size: 2.5rem;
}

/***** トースト通知 *****/
#toast-container {
	z-index: 9999;
	position: fixed;
	/* 右下 */
	/*
	bottom: 2rem;
	right: 2rem;
	*/
	/* 中央 */
	top: 50%;
	margin: auto 50%;
}
.toast {
	background-color: #FFF;
	color: var(--color-text);
	padding: 12px 20px;
	margin-top: 10px;
	opacity: 0;
	transform: translateY(20px);
	animation: toastFadeInOut 5s ease-in-out forwards;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
	min-width: 200px;
}
.toast.success {
	background-color: var(--color-success);
	color: #FFF;
}
.toast.danger {
	background-color: var(--color-danger);
	color: #FFF;
}
@keyframes toastFadeInOut {
	0% {
		opacity: 0;
		transform: translateY(20px);
	}
	5% {
		opacity: 1;
		transform: translateY(0);
	}
	95% {
		opacity: 1;
		transform: translateY(0);
	}
	100% {
		opacity: 0;
		transform: translateY(20px);
	}
}
