@charset "UTF-8";

/*
* admin用 base.css
*
*/


/*
* 共通項目
*/
* {
  font-size: 16px;
}
html {
	font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	margin: 0 !important;
  box-sizing: border-box;
}
body {
	margin: 0;
	padding: 0;
	text-align: justify;
  color: #111111;
	font-size: 16px;
	line-height: 1.6;
	background-color: #F5F5F5;
  box-sizing: border-box;
}
a {
	color: #f19500;
	text-decoration: none;
}
a:hover { opacity: 0.6; }
a.disabled {
	color: #CCCCCC;
	cursor: default;
}
a.disabled:hover {
	opacity: 1;
}
ul, li {
	margin: 0;
	padding: 0;
	list-style: none;
}
hr {
  max-width: calc(100% - 20px);
  margin: 40px auto;
  border: 0;
  border-bottom: #F1F1F1 1px solid;
}
.xdsoft_datetimepicker { z-index: 99999 !important; }

.b { font-weight: 700 !important; }
.c {
	align-items: center !important;
	justify-content: center !important;
	text-align: center !important;
}
.l {
	align-items: flex-start !important;
	justify-content: flex-start !important;
	text-align: left !important;
}
.r {
	align-items: flex-end !important;
	justify-content: flex-end !important;
	text-align: right !important;
}
.gap {
	display: flex;
	gap: 1em;
}
.lineLeft { border-left: #DDDDDD 2px solid !important; }
/* Bootstrap再構築 */
.col-five {
  width: 20%;
  float: left;
}
/* フォント色 */
.cfBlue{
	color: #f19500;
}
.cfDeep {
	color: #175083;
}
.cfOrange {
	color: #fb9333;
}
.cfCash {
	color: #066000 !important;
}
.cfRed {
	color: #CC0000!important;
}
/* 背景色 */
.cbBlue {
	background-color: #f19500;
}
.cbDeep {
	background-color: #175083;
}
.cbLight {
	background-color: #9cc9f2;
}
.cbWhite {
	background-color: #FFFFFF;
}
.cbCash {
	background-color: #066000 !important;
}
/* 幅 */
.wd10 { width: 10% !important; }
.wd20 { width: 20% !important; }
.wd30 { width: 30% !important; }
.wd40 { width: 40% !important; }
.wd50 { width: 50% !important; }
.wd60 { width: 60% !important; }
.wd70 { width: 70% !important; }
.wd80 { width: 80% !important; }
.wd90 { width: 90% !important; }
.wd100 { width: 100% !important; }




/*
* レイアウト
*/
#primaryWrap {
	margin: 0 auto;
	padding: 60px 0 80px 0;
}
#primaryWrap.withMenu {
	padding: 60px 0 80px 0;
}
#primaryWrap.withMenu.withTotal {
	/* padding: 160px 0 120px 0; */
	padding: 130px 0 120px 0;
}
#primaryWrap.withMenu.withTotalColumn {
	padding: 130px 0 170px 0;
}
.secondaryWrap {
	flex: 1;
  width: calc(100% - 20px);
	max-width: 1280px;
	height: auto;
	margin: 0 auto;
	padding: 40px 0;
}
.mainFrame {
	margin: 0;
	padding: 0 0 20px 0;
	background-color: #FFFFFF;
  box-shadow: 0 0 4px 4px #EEEEEE;
}
/* 2分割編集画面 */
.editlist {
	display: flex;
	align-items: flex-start;
	width: 100%;
}
.editlist .left {
	flex: 1;
	width: 50%;
	margin-right: 10px;
}
.editlist .right {
	flex: 1;
	width: 50%;
	margin-left: 10px;
}
/* 横スクロール */
.overflowX {
  width: calc(100% - 20px);
  margin: 0 auto;
  overflow-x: scroll;
}


/*
* ブラインド
*/
#blind {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-blend-mode: screen;
  /*background-color: rgba(249, 213, 114, 0.5);*/
  background-color: rgba(0,0,0,0.2);
  z-index: 91000;
}
#blind.on { display: block; }


/*
* loader
*/
#pageloading-wrap {
  background: #E3E1E1;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  text-align: center;
  display: table;
  z-index: 99999;
}
#pageloading-icon {
  display: table-cell;
  vertical-align: middle;
}
#loadingHide {
  display: none;
}


/*
* ヘッダー
*/
#siteHeader {
	position: fixed;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	width: 100vw;
	height: 60px;
	margin: 0;
	padding: 0;
	background-color: #FFFFFF;
	z-index: 92000;
}
#siteHeader .wrap {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	width: calc(100% - 40px);
	margin: 0 auto;
	padding: 0;
}
/* ロゴ */
#siteHeader h1.logo {
	display: flex;
	align-items: center;
	width: 300px;
	height: auto;
	margin: 0;
	font-size: 24px;
	font-weight: 600;
}
#siteHeader h1.logo img {
	object-fit: contain;
	width: 100%;
	height: 100%;
}
/* ボタン */
#siteHeader ul.button {
	flex: 1;
	display: flex;
	align-items: stretch;
	justify-content: flex-end;
	gap: 0 20px;
	margin: 0;
	padding: 0;
}
#siteHeader ul.button li {
	display: flex;
	margin: 0;
	padding: 0;
}
/* CRM */
#siteHeader ul.button li.buttonCrm {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin: 0;
	padding: 0;
	color: #999999;
	font-size: 24px;
	cursor: pointer;
}
#siteHeader ul.button li.buttonCrm:hover {
	opacity: 0.5;
}
/* アイコン */
#siteHeader ul.button li.icon img {
	width: 36px;
}
#siteHeader ul.button p {
	margin: 0;
	padding: 0;
	font-size: 10px;
}
/* メニュートグル */
#siteHeader ul.button li.toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
	font-size: 30px;
}


/*
* ヘッダーメニュー
*/
#headerMenu {
	position: fixed;
	top: 60px;
	left: 0;
	width: 100%;
	margin: 0;
	padding: 0 0 20px 0;
	z-index: 80000;
}


/*
* 開閉メニュー
*/
#drawerMenu {
  position: fixed;
  top: 60px;
  right: 0;
  transform: translateX(100%);
  transition:ease .3s;
  display: block;
  align-items: center;
  width: 390px;
  height: calc(100vh - 60px);
  margin: 0;
  padding: 20px;
  color: #FFFFFF;
  overflow: scroll;
  background-color: #FFFFFF;
  z-index: 85000;
}
#drawerMenu.open {
  transform: none;
}
#drawerMenu ul.linkWrap {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: auto;
  margin: 0;
  padding: 20px;
  color: inherit;
  background-color: #EEEEEE;
}
#drawerMenu ul.linkWrap li {
  margin: 0;
  padding: 0;
}
#drawerMenu ul.linkWrap li a {
	display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
	margin: 0;
	padding: 20px;
	font-size: 16px;
	font-weight: 600;
	border: #EEEEEE 1px solid;
  border-radius: 10px;
	background-color: #FFFFFF;
	box-sizing: border-box;
}


/*
* ファンクションキー
*/
#fnKey {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: #F5F5F5;
}
#fnKey ul {
	display: flex;
	align-items: stretch;
	justify-content: space-around;
	margin: 0;
	padding: 0 5px;
}
#fnKey ul li {
	flex: 1;
	margin: 0;
	padding: 5px 2px;
	font-size: 12px;
}
#fnKey ul p.cell {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 5px;
	color: #CCCCCC;
	background: #FFFFFF;
	border: #CCCCCC 1px solid;
}
#fnKey ul a.cell {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 5px;
	color: #FFFFFF;
	background: #f19500;
	border: #f19500 1px solid;
}
#fnKey ul a.disabled {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 5px;
	color: #CCCCCC;
	background: #FFFFFF;
	border: #CCCCCC 1px solid;
	cursor: default;
}
#fnKey ul strong {
	width: 2em;
	text-align: center;
	border: #EEEEEE 1px solid;
}
#fnKey ul span {
	flex: 1;
	text-align: center;
}


/*
* フッター ポータル
*/
#pageFooter {
	margin: 0;
	padding: 0;
}


/*
* 見出し
*/
.mainFrame h4.title {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 0 20px 0;
	padding: 10px;
	color: #FFFFFF;
	font-size: 22px;
	font-weight: 600;
	background-color: #f19500;
}
/* リンク（利用なし） */
.mainFrame h4.title a {
	margin: 0 0 0 10px;
	padding: 5px 10px;
	color: #333333;
	font-size: 14px;
	background-color: #EEEEEE;
	border-radius: 5px;
}
.mainFrame h5.title {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
	margin: 20px 10px 5px 10px;
	padding: 5px 10px;
	font-size: 24px;
	font-weight: 600;
	border-left: #999999 5px solid;
}
.mainFrame h5.title a.button {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	margin: 0;
	padding: 3px 5px;
	color: #FFFFFF;
	font-size: 12px;
	font-weight: 400;
	line-height: 1;
	background-color: #f19500;
	border: #f19500 3px solid;
	border-radius: 5px;
}
.mainFrame h6.title {
  display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
	margin: 20px 10px 5px 10px;
	padding: 5px;
	font-size: 18px;
	font-weight: 600;
}


/*
* indexメニュー
*/
.indexWrap {
	display: flex;
  flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	margin: 0;
	padding: 0 20px 20px 20px;
}
.menuIndex {
  width: 100%;
	margin: 0;
	padding: 0;
}
.menuIndex h5.title {
	margin: 20px 10px 10px 0;
}
.menuIndex ul {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin: 0;
	padding: 5px;
	background-color: #F8F8F8;
}
.menuIndex li {
	flex: 1;
	max-width: 50%;
	margin: 0;
	padding: 0;
}
.menuIndex li a {
	display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
	margin: 0;
	padding: 40px 20px;
	font-size: 20px;
	font-weight: 600;
	border: #EEEEEE 1px solid;
  border-radius: 10px;
	background-color: #FFFFFF;
	box-sizing: border-box;
}
.menuIndex li i {
	margin: 0;
	padding: 0;
  font-size: 24px;
}
.menuIndex li span {
	display: block;
	margin: 0;
	padding: 10px;
	color: #CCCCCC;
	font-size: 16px;
	font-weight: 600;
}


/*
* 区切り線
*/
hr.line {
	width: calc(100% - 20px);
	margin: 40px auto;
	padding: 0;
	border: 0;
	border-bottom: #CCCCCC 1px dashed;
}




/*
* エラー
*/
#errText {
	width: calc(100% - 4rem);
	max-width: 1280px;
	margin: 2rem auto;
	padding: 2rem;
	color: #CC0000;
	font-size: 1.6rem;
	border: #CC0000 1px solid;
}
#infoText {
	width: calc(100% - 4rem);
	max-width: 1280px;
	margin: 2rem auto;
	padding: 2rem;
	color: #000000;
	font-size: 1.6rem;
	border: #CCCCCC 1px solid;
}


/*
* フォームメッセージ
*/
#formMessage {
  margin: 0 10px 20px 10px;
  padding: 20px;
  font-size: 16px;
  font-weight: 600;
  border: #CCCCCC 1px solid;
  background-color: #FFFFFF;
}
#formMessage p {
  margin: 0;
  padding: 0;
}
#formMessage p.err {
  margin: 0;
  padding: 0;
  color: #CC0000;
}


/*
* adminフォーム
*/
.baseForm {
	margin: 0;
}
.baseForm p.info {
	margin: 0 0 20px 0;
	padding: 0 20px;
	font-size: 14px;
	font-weight: 300;
}
.baseForm p.err {
	margin: 0 0 20px 0;
	padding: 0 20px;
  color: #FF0000;
	font-size: 14px;
	font-weight: 300;
}
.baseForm ul.normal {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
  gap: 5px 0;
	width: auto;
	margin: 10px;
	padding: 2px;
	font-size: 14px;
	border: #F1F1F1 1px solid;
}
.baseForm ul.normal li {
	flex: 1;
	display: flex;
	align-items: stretch;
  gap: 5px 0;
	margin: 0;
	padding: 0;
}
.baseForm ul.normal li.twoCols {
	flex: none;
	width: 50%;
}
.baseForm ul.normal li.threeCols {
	flex: none;
	width: 33.3%;
}
.baseForm ul.column {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-around;
	width: auto;
	margin: 10px;
	padding: 2px;
	font-size: 14px;
	border: #EEEEEE 1px solid;
}
.baseForm ul.column li {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	margin: 0;
	padding: 5px;
	box-sizing: border-box;
}
.baseForm ul li.strong {
	background-color: #9cc9f2;
}
/* 行番号 */
.baseForm ul li.rowNo {
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  margin-right: 5px;
  color: #FFFFFF;
  font-size: 18px;
  font-weight: 900;
  background-color: #999999;
  border-radius: 9999px;
}
/* 非表示 */
.baseForm ul.hide { display: none; }
.baseForm ul.show { display: flex; }
/* 見出し */
.baseForm ul.normal h5 {
	position: relative;
	display: flex;
	align-items: center;
	width: calc(12em + 0px);
	margin: 0;
	padding: 0 10px;
	font-size: 14px;
	font-weight: 600;
	background-color: #EEEEEE;
	border-left: #999999 3px solid;
}
.baseForm ul.column h5 {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	width: calc(100% - 20px);
	margin: 0 0 5px 0;
	padding: 10px 10px;
	font-size: 14px;
	font-weight: 600;
	background-color: #EEEEEE;
	border-left: #999999 3px solid;
}
/* 必須 */
.baseForm li.req h5 {
	width: calc(12em - 40px);
	padding-right: 50px;
}
.baseForm li.req h5::after {
  content: "必須";
  position: absolute;
  top: 50%;
  right: 5px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 3px 5px;
  color: #FFFFFF;
  font-size: 12px;
  line-height: 1;
	background-color: #53576A;
  border-radius: 3px;
}
.baseForm li.any h5::after {
  content: "任意";
  position: absolute;
  top: 50%;
  right: 5px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 3px 5px;
  color: #FFFFFF;
  font-size: 12px;
  line-height: 1;
	background-color: #999999;
  border-radius: 3px;
}
/* wrap */
.baseForm .wrap {
	display: flex;
	align-items: center;
}
/* ボタン */
.baseForm ul.normal li.button {
	flex: none;
	display: flex;
}
.baseForm ul.normal li.button button {
	min-width: 6em;
	margin: 2px;
	padding: 3px 8px;
	text-align: center;
	color: #FFFFFF;
	font-size: 14px;
	line-height: 1.6;
	border: none;
	background-color: #999999;
	border-radius: 3px;
}
.baseForm ul.normal li.button button.butSearchClear {
	color: inherit;
	border: #999999 1px solid;
	background-color: #FFFFFF;
}
/* wrap */
.baseForm ul.normal .wrap {
	display: flex;
	flex: 1;
  flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
  gap: 5px 10px;
	margin: 0;
	padding: 0 5px;
}
.baseForm .wrap.text {
	align-items: center;
	margin: 0;
	padding: 5px 20px !important;
}
.baseForm .wrap.vertical {
	flex-direction: column !important;
	align-items: flex-start !important;
	justify-content: flex-start !important;
}
.baseForm .wrap.attention {
	margin: 0;
	padding: 10px !important;
  font-size: 14px;
  font-weight: 600;
  background-color: #ffcece;
}
.baseForm .wrap p.comment {
  width: 100%;
	margin: 5px 5px 0 5px;
	padding: 0;
  font-size: 14px;
}
/* 追加ライン */
.baseForm .addLine {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 3px;
	margin: 0;
	padding: 2px 5px;
}
.baseForm .addLine p.line {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 5px;
	margin: 0;
	padding: 0;
}
.baseForm .addLine p.line .name {
	flex: 1;
}
.baseForm .addLine p.line .fee {
	width: 6em;
}
.baseForm .addLine p.line .del {
	padding: 0 1em;
	color: #CCCCCC;
	cursor: pointer;
}
.baseForm .addLine a.add {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	margin: 0;
	padding: 5px;
	border: #CCCCCC 1px solid;
	border-radius: 3px;
}
/* 項目名小 */
.baseForm ul.normal h6 {
	margin: 0 0 5px 0;
	padding: 0 5px;
	font-size: 14px;
	font-weight: 600;
}
/* ノート */
.baseForm p.note {
	margin: 0 0 20px 0;
	padding: 0 20px;
	font-size: 14px;
}
/* span */
.baseForm .wrap span {
	font-size: 14px;
}
/* check確認 */
.baseForm .checkConfirm {
	padding: 5px 20px !important;
}
.baseForm .checkConfirm span {
	margin: 0;
	padding: 3px 10px;
	text-align: center;
	color: #FFFFFF;
	background-color: #f19500;
	border: #f19500 1px solid;
  border-radius: 5px;
}
/* input */
.baseForm input[type='text'],
.baseForm input[type='number'],
.baseForm input[type='tel'],
.baseForm input[type='email'],
.baseForm input[type='password'],
.baseForm textarea {
	display: inline-block;
	width: calc(100% - 10px);
	margin: 2px;
	padding: 7px 5px;
	font-size: 16px;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: none;
	background-color: #F1F1F1;
	border-radius: 3px;
}
.baseForm :disabled {
	color: #444444;
  cursor: default;
}
.baseForm :disabled + label {
  cursor: default !important;
}
.baseForm textarea {
	line-height: 1.6;
	background-color: #F1F1F1;
}
/* placeholder */
.baseForm ::placeholder { color: #CCCCCC; }
/* select */
.baseForm select:not(.inputableSelect) {
  display: inline-block;
  width: auto;
	max-width: 100%;
	margin: 2px;
	padding: 2px 5px;
  font-size: 14px;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: #F7F7F7 1px solid;
	border-radius: 3px;
	overflow: hidden;
}
/* selectArrow */
.baseForm .selectArrow {
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 0;
}
.baseForm .selectArrow select {
  padding-right: 25px;
	background-color: #F1F1F1;
}
.baseForm .selectArrow::after {
  content: "";
	position:absolute;
	top: 50%;
  right: 10px;
	transform: translateY(-50%);
  display: block;
  width: 0;
  height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #5F5F5F;
	pointer-events: none;
}
/* inputableSelect */
.baseForm .inputableSelect {
	display: inline-block;
	width: 22px;
	margin: 0;
	padding: 3px 8px;
	background-color: #FFFFFF;
	border: none;
	border: #F7F7F7 1px solid;
	border-radius: 0;
}
/* chosen */
.baseForm .chosen-container {
  /*width: auto !important;*/
	width: 100% !important;
  height: auto !important;
  font-size: 14px;
	background-color: #F1F1F1 !important;
}
.baseForm .chosen-container-single .chosen-single {
  width: auto !important;
  height: auto !important;
  padding: 3px 8px;
  font-size: 14px;
	background: none;
	border: 0;
	box-shadow: none;
	box-sizing: border-box;
}
.baseForm .chosen-container-single .chosen-single span {
  font-size: 14px;
}
.baseForm .chosen-single div {
  top: 50% !important;
  transform: translateY(-50%);
  height: 22px !important;
}
.chosen-container-active.chosen-with-drop .chosen-single {
	padding: 2px 8px;
}
.baseForm .chosen-container-single .chosen-search input[type="text"] {
  background: none !important;
}
.baseForm .active-result {
  margin: 0 !important;
  padding: 5px 10px !important;
}
.baseForm .result-selected {
  margin: 0 !important;
  padding: 5px 10px !important;
}
.baseForm .chosen-choices {
	padding: 5px 10px !important;
  font-size: 14px !important;
	background: none !important;
	border: 0 !important;
	background: none !important;
	background-color: #F1F1F1 !important;
}
.baseForm li.search-choice {
	background: none !important;
	background-color: #FFFFFF !important;
}
/* radio 大 */
.baseForm .radioBig {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 5px;
	margin: 0;
	padding: 5px 7px !important;
}
.baseForm .radioBig label {
	margin: 0;
	padding: 3px 10px;
	text-align: center;
	color: #FFFFFF;
	background-color: #f19500;
	border: #f19500 1px solid;
  border-radius: 5px;
	cursor: pointer;
}
.baseForm .radioBig input { display: none; }
.baseForm .radioBig input[type='radio']:not(:checked) + label {
	color: #f19500;
	background-color: #FFFFFF;
}
.baseForm .radioBig input[type='radio']:disabled + label {
	color: #CCCCCC;
	background-color: #FFFFFF;
  border: #CCCCCC 1px solid;
}
/* checkbox大 */
.baseForm .checkboxBig {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 5px;
	margin: 0;
	padding: 5px 7px !important;
}
.baseForm .checkboxBig label {
	margin: 0;
	padding: 3px 10px;
	text-align: center;
	color: #f19500;
	background-color: #FFFFFF;
	border: #f19500 1px solid;
  border-radius: 5px;
	cursor: pointer;
}
.baseForm .checkboxBig input { display: none; }
.baseForm .checkboxBig input[type='checkbox']:checked + label {
  color: #FFFFFF;
  background-color: #f19500;
}
.baseForm .checkboxBig input[type='checkbox']:disabled + label {
  color: #CCCCCC;
	border-color: #CCCCCC;
}
/* checkbox Single */
.baseForm .checkSingle {
	margin: 0;
	padding: 5px 7px !important;
}
.baseForm .checkSingle input[type="checkbox"] {
  display: none;
}
.baseForm .checkSingle label {
  display: block;
  position: relative;
  margin: 0;
  padding: 0 0 0 26px;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .checkSingle label::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  width: 16px;
	height: 16px;
  background-color: #FFFFFF;
	border: #B1B1B1 2px solid;
  border-radius: 5px;
  transition: background-color .1s;
}
.baseForm .checkSingle label::after {
	content: '';
  display: block;
	position: absolute;
  top: calc(50% - 2px);
	left: 6px;
  transform: translateY(-50%) rotate(45deg);
  width: 6px;
  height: 9px;
  border-right: 3px solid #f19500;
  border-bottom: 3px solid #f19500;
  opacity: 0;
}
.baseForm .checkSingle input:checked + label::after {
  opacity: 1;
}
/* file */
.baseForm .file input[type="file"] {
  display: none;
}
.baseForm .file label {
	display: inline-block;
	margin: 0 1rem 0 0;
  padding: 0.8rem 2rem;
	text-align: center;
	color: #094DB0;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1;
	background-color: #FFFFFF;
	border: #094DB0 1px solid;
  border-radius: 9999px;
	cursor: pointer;
}
.baseForm .file span.filename {
  color: #000000;
  font-size: 1.2rem;
}
/* 画像 */
.baseForm .itemPict {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
}
.baseForm .pictCell {
  width: calc(25% - 20px);
  margin: 10px;
  padding: 10px;
  border: #E6E6E6 1px solid;
}
.baseForm .pictCell img.pict {
  object-fit: contain;
  width: 100%;
  height: 150px;
}
/* 小ボタン */
.baseForm .buttonSingleMini {
	margin: 0;
	padding: 3px 10px;
	text-align: center;
	color: #f19500;
	background-color: #FFFFFF;
	border: #f19500 1px solid;
  border-radius: 5px;
}
/* 学年・帽子 */
.baseForm p.gakunen {
  margin: 0;
  padding: 0;
}
.baseForm .boushi {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin: 0;
  padding: 0;
  color: #FFFFFF;
  font-size: 10px;
  font-weight: 600;
  border-radius: 9999px;
}
/* 規約エリア */
.baseForm .lawBody {
  margin: 0 0 10px 0;
  padding: 10px;
  width: calc(100% - 20px);
  max-height: 200px;
  font-size: 12px;
  font-weight: 300;
  background-color: #FFFFFF;
  border: #E6E6E6 1px solid;
	border-radius: 0;
  overflow-y: scroll;
}
.baseForm .lawBody h3 {
  margin: 20px 0;
  padding: 0;
  font-size: 16px;
  font-weight: 600;
}
.baseForm .lawBody h4 {
  margin: 20px 0 10px 0;
  padding: 0;
  font-size: 12px;
  font-weight: 600;
  border: 0;
}
.baseForm .lawBody p {
  margin: 0 0 10px 0;
  padding: 0;
}
.baseForm .lawBody ul {
  margin: 0 0 20px 0;
  padding: 0 0 0 10px;
}
.baseForm .lawBody li {
  margin: 0 0 5px 0 !important;
  padding: 0 !important;
}
/* 同意チェックボックス */
.baseForm .agreeCK {
  display: flex;
  align-items: last baseline;
  justify-content: flex-start;
  margin: 0;
	padding: 0;
}
.baseForm .agreeCK input {
  position: absolute;
  display: none;
}
.baseForm .agreeCK label {
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 0 0 0 30px;
	font-size: 14px;
	font-weight: 600;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .agreeCK label::before {
	content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 18px;
	height: 18px;
  background-color: #FFFFFF;
	border: #E6E6E6 1px solid;
  border-radius: 3px;
  transition: .1s;
}
.baseForm .agreeCK input:checked + label::after {
	content: '';
	display: block;
  position: absolute;
  top: calc(50% - 10px);
  left: 6px;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 7px;
	height: 12px;
	border-right: 3px solid #094DB0;
  border-bottom: 3px solid #094DB0;
	transform: rotate(45deg);
	transition: .1s;
}



/*
* 基本ボタン
*/
.baseButton {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 20px 0;
}
.baseButton.mini {
	padding: 0;
}
.baseButton a,
.baseButton button {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 10px;
	padding: 10px 20px;
	font-size: 16px;
	font-weight: 600;
	border: 0;
	border-radius: 10px;
}
.baseButton.mini a,
.baseButton.mini button {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 5px 10px;
	font-size: 14px;
	font-weight: 600;
	border: 0;
	border-radius: 10px;
}
.baseButton .prime {
	color: #FFFFFF;
	background-color: #f19500;
	border: #f19500 3px solid;
}
.baseButton .second {
	color: #CCCCCC;
	background-color: #FFFFFF;
	border: #CCCCCC 1px solid !important;
}


/*
* 基本table - リスト
*/
.listStyle {
	width: 100%;
	/* table-layout: fixed; */
	margin: 0;
	padding: 0;
	font-size: 16px;
	line-height: 1.2;
  border-collapse: separate;
  border-spacing: 5px;
}
.listStyle a + a { margin-left: 1rem;}
.listStyle thead th {
	margin: 0;
	padding: 10px 0;
	font-weight: 300;
	background-color: #EEEEEE;
  border: #999999 1px solid;
  border-radius: 5px;
}
.listStyle thead th.ord {
	position: relative;
	color: #f19500;
	cursor: pointer;
}
.listStyle thead th.ord.asc,
.listStyle thead th.ord.desc {
	font-weight: 600;
}
.listStyle thead th.ord.asc::after,
.listStyle thead th.ord.desc::after {
	position: absolute;
	top: 50%;
	right: 0.2em;
	transform: translate(0,-50%);
	font-size: 50%;
}
.listStyle thead th.ord.asc::after {
	content: "▼";
}
.listStyle thead th.ord.desc::after {
	content: "▲";
}
.listStyle tbody tr.select {
	cursor: pointer;
}
.listStyle tbody tr.select:hover {
	opacity: 0.6;
}
.listStyle tbody tr:nth-child(2n+1) {
	background-color: #F4F8FF;
}
.listStyle tbody tr.active {
	color: #FFFFFF;
	background-color: #f19500;
}
.listStyle tbody tr.selected {
	color: #FFFFFF;
	background-color: #cb6c15;
}
.listStyle tbody tr.active.selected {
	color: #FFFFFF;
	background-color: #5a15cb;
}
.listStyle .sortableArea tr {
	cursor: grab;
}
.listStyle tbody th {
	padding: 10px;
	white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
	border: #CCCCCC 1px solid;
}
.listStyle tbody td {
	margin: 0;
	padding: 10px;
	vertical-align: top;
	font-weight: 300;
  line-height: 1.4;
	white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
	border: #CCCCCC 1px solid;
  border-radius: 5px;
}
.listStyle tbody td p.row {
	margin: 0 0 5px 0;
	padding: 0;
}
.listStyle tbody td p.row:last-child {
  margin: 0;
}
.listStyle tbody td strong {
	display: inline-block;
	min-width: 18px;
  margin: 0 5px 0 0;
	padding: 2px 5px;
	text-align: center;
	color: #FFFFFF;
	font-size: 14px;
	font-weight: 600;
	line-height: 1;
	background-color: #FF0000;
	border-radius: 3px;
}
.listStyle tbody .full {
	white-space: normal;
}
/* dl dt dd */
.listStyle tbody dl {
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 0 0 5px 0;
  padding: 0;
}
.listStyle tbody dl:last-child {
  margin: 0;
}
.listStyle tbody dt {
  margin: 0;
  padding: 0 2px;
  color: #FFFFFF;
  background-color: #666666;
}
.listStyle tbody dd {
  margin: 0;
  padding: 0;
}
/* フォームselect */
.listStyle select {
	margin: 0 !important;
	padding: 5px !important;
}
.listStyle .selectArrow {
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 0;
}
.listStyle .selectArrow select {
  padding-right: 20px;
}
.listStyle .selectArrow::after {
  content: "";
	position:absolute;
	top: 50%;
  right: 10px;
	transform: translateY(-50%);
  display: block;
  width: 0;
  height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #5F5F5F;
	pointer-events: none;
}
/* 処理中 */
.listStyle td.process {
	width: 100%;
	height: 450px;
	vertical-align: middle;
	text-align: center;
	color: #CCCCCC;
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.1em;
}


/*
* リスト絞り込み
*/
.listSelect {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 5px 10px;
  margin: 10px 0;
  padding: 0 10px;
}
.listSelect h6 {
  margin: 0;
  padding: 0;
  font-size: 16px;
}
.listSelect li {
  margin: 0;
  padding: 2px 10px;
  background: #F1F1F1;
  border: #f19500 1px solid;
  border-radius: 5px;
}
.listSelect li.active {
  color: #FFFFFF;
  background: #f19500;
}



/*
* 検索モーダルオープンボタン
*/
a.searchModalOpen {
	margin: 0 2px 0 0;
	padding: 3px 6px;
	font-size: 12px;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}
a.searchModalOpen:focus-visible {
	outline: 0;
}
a.searchModalOpen:focus {
	border: 0;
	border: #f19500 2px solid;
}


/*
* ページネーション
*/
#pager {
	margin: 20px 0;
	padding: 0;
	color: #000000;
	font-size: 16px;
	text-align: center;
	line-height: 100%;
}
#pager .pages {
	display: inline-block;
	margin: 0 0 0 10px;
	padding: 10px 10px;
	background-color: #EEEEEE;
	border-radius: 5px;
}
#pager .prev {
	display: inline-block;
	margin: 0 5px 0 0;
	padding: 10px 10px;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 5px;
}
#pager .next {
	display: inline-block;
	margin: 0 0 0 5px;
	padding: 10px 10px;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 5px;
}
#pager a.page {
	display: inline-block;
	margin: 0 2px;
	padding: 10px 10px;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 5px;
}
#pager span.page {
	display: inline-block;
	margin: 0 2px;
	padding: 10px 10px;
	color: #FFFFFF;
	text-decoration: none;
	background-color: #f19500;
	border-radius: 5px;
}


/*
* タブ
*/
#tabControle {
	margin: 0;
	padding: 0;
}
#tabControle ul {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin: 0;
	padding: 0 10px;
	border-bottom: #CCCCCC 1px solid;
}
#tabControle h5.title + ul {
  margin-top: 10px;
}
#tabControle ul li {
	margin: 0 5px -1px 0;
	padding: 5px 20px;
	font-size: 20px;
	border: #CCCCCC 1px solid;
	border-bottom: #CCCCCC 1px solid;
	border-radius: 5px 5px 0 0;
	background-color: #FFFFFF;
	cursor: pointer;
}
#tabControle ul li.active {
	color: #FFFFFF;
	font-weight: 600;
	border-color: #f19500;
	background-color: #f19500;
}
#tabControle ul li:not(.active):hover {
	background-color: #F1F1F1;
}
#tabControle ul li.hidden {
	display: none;
}
/* ボタン */
#tabControle .tabButton {
  margin: 0 0 0 10px;
  padding: 0;
  font-size: 20px;
  line-height: 1;
}
#tabControle .tabButton i {
  font-size: 25px;
}
/* タブコンテンツ */
.tabBody {
	display: none;
	margin: 0;
	padding: 0;
}
.tabBody.active {
	display: block;
}


/*
* 集計
*/
#totalling {
	position: fixed;
	bottom: 40px;
	left: 0;
	width: 100%;
	background-color: #FFFFFF;
}
/* テーブルスタイル */
#totalling table.listStyle {
	margin: 5px;
}

/* カラムスタイル */
#totalling ul.column {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-around;
	width: auto;
	margin: 10px;
	padding: 2px;
	border: #CCCCCC 1px solid;
}
#totalling ul.column li {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	margin: 0;
	padding: 5px;
	box-sizing: border-box;
}
#totalling ul.column h5 {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: calc(100% - 20px);
	margin: 0 0 5px 0;
	padding: 5px 10px;
	font-size: 14px;
	font-weight: 600;
	background-color: #EEEEEE;
	border: #999999 1px solid;
}
#totalling ul.column .wrap {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	width: calc(100% - 20px);
	margin: 0;
	padding: 5px 10px;
	font-size: 14px;
	line-height: 1.2;
	border: #999999 1px solid;
}


/*
* モーダルスタイル
*/
.bwpModal {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	display: none;
	max-width: 90vw;
	/* height: 100%; */
	/* max-height: 60vh; */
	padding: 0 0 20px 0;
	background-color: #FFFFFF;
	border-radius: 10px;
	box-shadow: 0 0 10px 1px rgba(0,0,0,0.1);
	z-index: 99999;
	overflow: scroll;
}
/* ヘッダー */
.bwpModal .modalHeader {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 40px;
	margin: 0 0 10px 0;
	padding: 0 10px;
	color: #FFFFFF;
	background-color: #f19500;
}
.bwpModal .modalHeader h3 {
	margin: 0;
	padding: 0;
	font-size: 16px;
	font-weight: 600;
}
.bwpModal .modalHeader a.modalClose {
	margin: 0;
	padding: 0;
	color: #FFFFFF;
	font-size: 20px;
}
/* コンテンツ */
.bwpModal .modalContent {
	max-height: calc(100vh - 200px);
	overflow-y: scroll;
}
/* ボタン */
.bwpModal .baseButton {
	padding-bottom: 0;
}
.bwpModal .buttonNew {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	max-width: 20em;
	margin: 0 10px 10px 10px;
	padding: 5px 10px;
	color: #FFFFFF;
	font-size: 14px;
	font-weight: 600;
	background-color: #f19500;
	border: #f19500 3px solid;
	border-radius: 10px;
}
/* フッター */
.bwpModal .modalFooter {
	position: fixed;
	bottom: 0;
	margin: 0;
	padding: 0;
}


/*
* ブラインド
*/
#blind {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-blend-mode: screen;
  background-color: rgba(0,0,0,0.8);
  z-index: 80000;
}
#blind.on { display: block; }


/*
* メディアアップローダー
*/
#modalUpload {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	display: none;
	width: 60vw;
	height: 60vh;
	background-color: #FFFFFF;
	z-index: 99999;
}
#modalUpload .file-drop-area {
  display: flex;
  justify-content: center;
  align-items: center;
	height: calc(100% - 60px);
  border: #707070 5px dashed;
  border-radius: 15px;
}
#modalUpload .file-drop-area.drag-enter {
  border: #094DB0 5px dashed;
  background-color: #F1F1F1;
}


/*
* イニシャルリスト
*/
.modalInitialList {
	margin: 0 0 10px 0;
	padding: 0 8px;
}
.modalInitialList ul {
	display: flex;
	align-items: stretch;
	justify-content: space-around;
	margin: 0;
	padding: 0;
}
.modalInitialList ul li {
	flex: 1;
	margin: 0 2px;
	padding: 10px;
	text-align: center;
	color: #CCCCCC;
  background-color: #FFFFFF;
  border: #CCCCCC 2px solid;
	cursor: pointer;
}
.modalInitialList ul li.active {
	color: #f19500;
  border: #f19500 2px solid;
}
/* リスト */
.modalInitialList table .select {
	cursor: pointer;
}
.modalInitialList table .select:hover {
	opacity: 0.6;
}


/*
* フリーワード検索
*/
#schFreeWord {
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 10px;
	margin: 0 10px 10px 10px;
	padding: 0;
}
#schFreeWord ul {
  flex: 1;
  gap: 5px;
  margin: 0;
  padding: 0;
}
#schFreeWord .button {
  display: flex;
  align-items: center;
  justify-content: center;
	margin: 0 2px 0 0;
	padding: 5px 10px;
	font-size: 12px;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}


/*
* 抽出条件
*/
.conditionWrap {
	display: none;
	margin: 0 10px 10px 10px;
	padding: 10px;
	border: #CCCCCC 2px solid;
	border-radius: 5px;
}
.conditionWrap.active {
	display: block;
}
.conditionWrap dl {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin: 0;
	padding: 0;
}
.conditionWrap dt {
	margin: 0 10px 0 0;
	padding: 0 10px;
	background-color: #F1F1F1;
}
.conditionWrap dd.body {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
	flex: 1;
	margin: 0;
	padding: 0;
}
.conditionWrap dd.body span {
	display: inline-block;
	margin: 0;
	padding: 0;
}
.conditionWrap dd.reset {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
}













/*
* タブレット用
*/


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




  /*
  * adminフォーム
  */
  .baseForm {
    margin: 0;
  }
  .baseForm ul.normal {
    flex-direction: column;
    gap: 10px;
    border: 0;
  }
  .baseForm ul.normal li {
    flex-direction: column;
  }
  .baseForm ul.normal li.threeCols {
    flex: none;
    width: 100%;
  }
  /* wrap */
  .baseForm ul.normal .wrap {
    flex: none;
    flex-wrap: wrap;
    gap: 5px 10px;
    max-width: 100%;
  }
  /* 見出し */
  .baseForm ul.normal h5 {
    width: calc(100% - 20px) !important;
  }
  .baseForm li.req h5 {
    width: calc(100% - 60px) !important;
  }





}
