@charset "UTF-8";

/*
* member用 base.css
*
*/


/*
* 共通項目
*/
html {
	font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	margin: 0px !important;
	font-size: 62.5%;
}
body {
	margin: 0;
	padding: 0;
	font-size: 1.6rem; /* 16px*/
	line-height: 2;
	background-color: #F5F5F5;
}
a {
	color: inherit;
	text-decoration: none;
}
a:hover {
	color: inherit;
	opacity: 0.6;
}
ul, li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.b { font-weight: 700; }
.c { text-align: center; }
.l { text-align: left; }
.r { text-align: right; }
.lineLeft { border-left: #DDDDDD 2px solid !important; }
/* Bootstrap再構築 */
.col-five {
  width: 20%;
  float: left;
}
/* 幅 */
.wd30 {
	width: 30% !important;
	max-width: 30% !important;
}

/*
* レイアウト
*/
#pageWrap {
	position: static;
	width: 100%;
	height: auto;
	margin: 8rem 0 0 0;
	padding: 5rem 0;
	z-index: 1;
}
#pageWrap.twoCol {
	display: flex;
	max-width: 1280px;
  margin-left: auto;
	margin-right: auto;
}
#pageWrap.noHeader {
	margin: 0;
	padding: 0;
}
#pageWrap.twoCol .contentsWrap {
  width: calc( 100% - 300px );
}
#sidebarWrap {
	width: 300px;
	padding-right: 20px;
	min-height: 50vh;
}
.inner {
	width: calc(100% - 4rem);
	max-width: 1280px;
  margin: 0 auto;
	padding: 0;
}
.mainFrame {
	background-color: #FFFFFF;
  box-shadow: 0 0 4px 4px #EEEEEE;
}


/*
* ヘッダー
*/
header#pageHeader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	margin: 0;
	padding: 0;
	z-index: 99999;
}
/* スーパーヘッダー */
#superHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
	height: 8rem;
  margin: 0;
  padding: 0 4rem;
	font-size: 0;
	background-color: #054DB0;
}
/* ロゴ */
#superHeader .logoWhite {
	margin: 0;
	padding: 0;
  color: #FFFFFF;
  line-height: 1;
}
#superHeader .logoWhite small {
	display: block;
	margin: 0 0 0.5rem 0;
	padding: 0;
  font-size: 2rem;
  font-weight: 500;
}
#superHeader .logoWhite strong {
	display: block;
	margin: 0;
	padding: 0;
  font-size: 2.4rem;
  font-weight: 800;
}

#superHeader .buttonWrap {
	flex: 1;
  height: 100%;
	margin: 0;
	padding: 0;
}
/* ボタン */
#superHeader ul.button {
	display: flex;
  justify-content: flex-end;
	margin: 0;
	padding: 0;
}
#superHeader li {
	margin: 0;
	padding: 0;
	font-size: 1.2rem;
	cursor: pointer;
}
#superHeader li a {
	display: block;
}
#superHeader li.mypage {
	width: 10rem;
	margin: 0;
	padding: 1rem 0;
	text-align: center;
	color: #FFFFFF;
	font-size: 1.2rem;
	font-weight: 700;
}
#superHeader li.mypage img {
	display: block;
	width: 4rem;
	height: 4rem;
	margin: 0 auto;
	padding: 0;
}



/*
* フッター
*/
nav#footer {
	height: 70px;
	margin: 0;
	padding: 0;
	background-color: #FFFFFF !important;
	border-top: #EAEAEA 1px solid;
	z-index: 99000;
}
nav#footer ul {
	width: 100%;
	height: 70px;
	margin: 0;
	padding: 0;
	list-style: none;
}
nav#footer li {
	margin: 0;
	padding: 7px 0;
	text-align: center;
	box-sizing: border-box;
}
nav#footer li:last-child {
	border-right: none;
}
nav#footer li img {
	display: block;
	height: 55px;
	margin: 0 auto;
}
nav#footer li.info {
	position: relative;
}
nav#footer li.info p.counter {
	position: absolute;
	top: 52%;
	left: calc(50% + 15px);
	transform: translateX(-60%) translateY(-52%);
	width: 20px;
	height: 20px;
	margin: 0;
	padding: 5px 0 0 0;
	text-align: center;
	color: #FFFFFF;
	font-size: 10px;
	line-height: 100%;
	background-color: #FF0000;
	border-radius: 1000px;
}



/*
* サイドメニュー
*/
#sideMenu {
	width: 100%;
	margin: 0;
	padding: 0;
}
#sideMenu section.menuSec {
	margin: 0;
	padding: 0;
	border-bottom: #CCCCCC 1px dashed;
}
#sideMenu section.menuSec:last-of-type {
	border: none;
}
#sideMenu h5 {
	margin: 0;
	padding: 0;
}
#sideMenu h5 a {
	position: relative;
	display: block;
	margin: 0;
	padding: 1.5rem 2rem 1.5rem 1.5rem;
	color: #054DB0;
	font-size: 1.8rem;
	font-weight: 700;
	cursor: pointer;
}
#sideMenu h5 a::after {
	content: "";
	position: absolute;
	top: calc(50% - 0.45rem);
	right: 1.5rem;
	width: 1.8rem;
	height: 0.9rem;
	margin: 0;
	padding: 0;
	background-image: url(/img/common/arrowDownBlue01.svg);
	background-position: center right;
	background-size: cover;
	transition: 0.5s;
}
#sideMenu h5 a[aria-expanded="true"] {
	color: #FFFFFF;
	background-color: #054DB0;
}
#sideMenu h5 a[aria-expanded="true"]::after {
	transform-origin: center center;
	transform: rotate(180deg);
}
#sideMenu ul {
	margin: 0.6rem 0;
	padding: 0;
}
#sideMenu li {
	margin: 0;
	padding: 0;
}
#sideMenu li a {
	position: relative;
	display: block;
	margin: 0;
	padding: 0.2rem 0rem 0.2rem 3rem;
	color: #054DB0;
	font-size: 1.6rem;
	font-weight: 400;
	text-decoration: none;
	cursor: pointer;
}
#sideMenu li a:hover {
	background-color: #F1F1F1;
}





/*
* エラー・見出し
*/
.errText {
	margin: 0 2rem 2rem 2rem;
	padding: 2rem;
	color: #CC0000;
	font-size: 1.6rem;
	border: #CC0000 1px solid;
}
.infoText {
	margin: 0 2rem 2rem 2rem;
	padding: 2rem;
	color: #000000;
	font-size: 1.6rem;
	border: #CCCCCC 1px solid;
}

h1 {
	margin: 2rem 0;
	color: #000000;
	font-size: 2.0rem;
	font-weight: bold;
}

.mainFrame h4.title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0;
	padding: 2rem;
	color: #054DB0;
	font-size: 2.0rem;
	font-weight: 700;
}
.mainFrame h4.title a {
	margin: 0 0 0 1rem;
	padding: 0.5rem 1rem;
	color: #333333;
	font-size: 1.4rem;
	background-color: #EEEEEE;
	border-radius: 0.5rem;
}



/*
* タブ
*/
#tab {
	margin: 2rem 0;
	padding: 0;
}


/*
* 基本table - リスト
*/
.listStyle {
	table-layout: fixed;
	width: 100%;
	margin: 0;
	padding: 0;
	font-size: 1.4rem;
	white-space: nowrap;
}
.listStyle th,
.listStyle td {
	border-right: #E6E6E6 1px solid;
	border-bottom: #E6E6E6 1px solid;
	overflow: hidden;
	text-overflow: ellipsis;
}
.listStyle th.visible,
.listStyle td.visible {
	overflow: visible;
}
.listStyle tr th:last-child,
.listStyle tr td:last-child {
	border-right: none;
}
.listStyle a {
	color: #054DB0;
}
.listStyle thead {
	margin: 0;
	padding: 0;
	border-top: #E6E6E6 1px solid;
	border-bottom: #E6E6E6 3px solid;
}
.listStyle thead th {
	margin: 0;
	padding: 0.5rem 1rem 0.5rem 1rem;
	font-weight: 700;
}
.listStyle tbody tr:nth-child(2n+1) {
	background-color: #F4F8FF;
}
.listStyle tbody th {
	margin: 0;
	padding: 0.5rem 1rem 0.5rem 1rem;
	font-weight: 700;
}
.listStyle tbody td {
	margin: 0;
	padding: 0.5rem 1rem;
	font-weight: 400;
}
.listStyle tbody td .sep {
	margin-right: 0.5rem;
}


/*
* 基本table - 編集
*/
.section {
	margin-bottom: 2rem;
}

.baseEdit {
	width: calc(100% - 2rem);
	margin: 0 1rem 2rem 1rem;
	padding: 0;
	font-size: 1.6rem;
	border-collapse: separate;
	border-spacing: 1rem;
}
.baseEdit th {
	width: 20%;
	max-width: 40%;
	margin: 0;
	padding: 0.5rem 1rem;
	vertical-align: top;
	color: #054DB0;
	background-color: #EEEEEE;
	border-radius: 0;
}
.baseEdit td {
	margin: 0;
	padding: 0;
}
.baseEdit td span,
.baseEdit td a {
	display: inline-block;
	margin: 0px;
	padding: 10px 10px 8px 10px;
}
.baseEdit td hr {
	height: 1px;
	border: none;
	border-top: #CCCCCC 1px dotted;
}
/* ２カラム */
.baseEdit .colTwo th,
.baseEdit .colTwo td {
	width: 25%;
}


/*
* 基本form - 編集
*/
.baseForm ul.normal {
	width: 100%;
	margin: 0;
	padding: 0;
}
.baseForm ul.normal .cell {
	margin: 0 0 1rem 0;
	padding: 0;
	font-size: 1.6rem;
}
.baseForm ul.twoCol {
	width: calc(100% + 2rem);
	margin-left: -1rem;
	margin-right: -1rem;
	padding: 0;
}
.baseForm ul.twoCol .cell {
	padding-left: 1rem;
	padding-right: 1rem;
	font-size: 1.6rem;
}

.baseForm input[type='text'],
.baseForm input[type='number'],
.baseForm input[type='tel'],
.baseForm input[type='email'],
.baseForm input[type='password'],
.baseForm input[type='checkbox'],
.baseForm textarea {
	margin: 0;
	padding: 0.5rem 1rem;
	font-size: 1.6rem;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: none;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}
.baseForm ::placeholder { color: #A5A5A5; }
.baseForm label {
	display: block;
	margin: 0;
	padding: 0 0 0.6rem 0;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 140%;
}
.baseForm input:focus,
.baseForm select:focus {
	outline: 0;
	box-shadow: 0 0 0 0.2rem #FD7B22 inset;
}
/* 選択ボタン */
.baseForm ul.sqButton {
	width: calc(100% + 2rem);
	margin-left: -1rem;
	margin-right: -1rem;
}
.baseForm ul.sqButton li.cell {
	padding-left: 1rem;
	padding-right: 1rem;
}
.baseForm ul.sqButton label {
	width: 100%;
	margin: 0;
  padding: 5rem 0;
	text-align: center;
	color: #FFFFFF;
	font-size: 2.4rem;
	font-weight: 700;
	background-color: #FD7B22;
  border-radius: 1rem;
	cursor: pointer;
}
.baseForm ul.sqButton input { display: none; }
.baseForm ul.sqButton input[type='radio']:not(:checked) + label {
	color: #666666 !important;
	background-color: #CCCCCC !important;
}
/* select */
.baseForm select {
  display: block;
	margin: 0;
	padding: 0.5rem 1rem;
	font-size: 1.6rem;
	background-color: transparent;
	border: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}
.baseForm .selectArrow {
  position: relative;
  display: inline-block;
	width: 100%;
  margin: 0;
  padding: 0;
}
.baseForm .selectArrow::after {
  content:"";
	position:absolute;
  right: 1.5rem;
  top: calc(50% - 7px);
  display: block;
  width:10px;
  height:10px;
  border-bottom:#333 2px solid;
  border-right:#333 2px solid;
  transform:rotate(45deg);
  z-index: 50000;
}
.baseForm .selectArrow select {
  position: relative;
  padding-right: 3rem;
  z-index: 50001;
}
/* checkbox水平 */
.baseForm .checkbox input {
  position: absolute;
  left: -9999px;
}
.baseForm .checkbox label {
  display: inline-block;
  position: relative;
  margin: 0 0 1rem 0;
  padding: 1.5rem 1.5rem 1.5rem 4rem;
	font-size: 1.6rem;
	line-height: 120%;
  border-radius: 0.6rem;
  background-color: #FFFFFF;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .checkbox label::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 1rem;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 2rem;
	height: 2rem;
  background-color: #EDEDED;
  border-radius: 100px;
  transition: background-color .1s;
}
.baseForm .checkbox input:checked + label::before {
  background-color: #054DB0;
}
/* checkbox分割 */
.baseForm .checkSeparate input {
  position: absolute;
  left: -9999px;
}
.baseForm .checkSeparate label {
  display: block;
  position: relative;
  margin: 0 0 1rem 0;
  padding: 1.5rem 1.5rem 1.5rem 4rem;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 120%;
  border-radius: 0.6rem;
  background-color: #FFFFFF;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .checkSeparate label::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 1rem;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 2rem;
	height: 2rem;
  background-color: #EDEDED;
  border-radius: 100px;
  transition: background-color .1s;
}
.baseForm .checkSeparate input:checked + label::before {
  background-color: #FD7B22;
}
/* checkboxグループ */
.baseForm .checkGroup input {
  position: absolute;
  left: -9999px;
}
.baseForm .checkGroup label {
  display: block;
  position: relative;
  margin: 0;
  padding: 1.5rem 1.5rem 1.5rem 4.5rem;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 120%;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .checkGroup label::before {
	content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 1.5rem;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 2rem;
	height: 2rem;
  background-color: #EDEDED;
  border-radius: 100px;
  transition: background-color .1s;
}
.baseForm .checkGroup input:checked + label::before {
  background-color: #FD7B22;
}
/* checkbox Single */
.baseForm .checkSingle input {
  position: absolute;
  left: -9999px;
}
.baseForm .checkSingle label {
  display: block;
  position: relative;
  margin: 0;
  padding: 2rem 2rem 2rem 5rem;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 140%;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
.baseForm .checkSingle label::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 2rem;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
  width: 2rem;
	height: 2rem;
  background-color: #FFFFFF;
	border: #C7C7C7 1px solid;
  border-radius: 0.5rem;
  transition: background-color .1s;
}
.baseForm .checkSingle label::after {
	content: '';
  display: block;
	position: absolute;
  top: calc(50% - 0.2rem);
	left: 2.5rem;
  transform: translateY(-50%) rotate(45deg);
  width: 1.0rem;
  height: 1.5rem;
  border-right: 0.4rem solid #FD7B22;
  border-bottom: 0.4rem solid #FD7B22;
  opacity: 0;
}
.baseForm .checkSingle input:checked + label::after {
  opacity: 1;
}
/* ファイル */
.baseForm input[type='file'] {
  display: inline-block !important;
}
.baseForm img.thumb {
  display: inline-block;
  object-fit: contain;
  width: 50px;
  height: 50px;
  margin: 0 10px 0 0;
  padding: 2px;
  border: #EEEEEE 1px solid;
}
/* フォーム長 */
.baseForm .length100 { width: 100% !important; }
.baseForm .length90 { width: 90% !important; }
.baseForm .length70 { width: 70% !important; }
.baseForm .length50 { width: 50% !important; }
.baseForm .length30 { width: 30% !important; }
.baseForm .length15 { width: 15% !important; }
.baseForm .colorWhite { background-color: #FFFFFF !important; }


/*
* 基本ボタン
*/
.baseButton {
	margin: 0;
	padding: 4rem 0;
	text-align: center;
}
.baseButton .buttonBlue {
	display: inline-block;
	width: auto;
	margin: 0 0.5rem;
	padding: 0.8rem 2rem;
	text-align: center;
	color: #FFFFFF;
	font-size: 1.8rem;
	font-weight: 700;
	background-color: #054DB0;
	border: #054DB0 3px solid;
	border-radius: 1rem;
	box-sizing: border-box;
}
.baseButton .buttonWhite {
	display: inline-block;
	width: auto;
	margin: 0 0.5rem;
	padding: 0.8rem 2rem;
	text-align: center;
	color: #054DB0;
	font-size: 1.8rem;
	font-weight: 700;
	background-color: #FFFFFF;
	border: none;
	border: #054DB0 3px solid;
	border-radius: 1rem;
}
.baseButton .buttonGray {
	display: inline-block;
	width: auto;
	margin: 0 0.5rem;
	padding: 0.8rem 2rem;
	text-align: center;
	color: #666666;
	font-size: 1.8rem;
	font-weight: 700;
	background-color: #EEEEEE;
	border: #EEEEEE 3px solid;
	border-radius: 1rem;
	box-sizing: border-box;
}


/*
* ページネーション
*/
.pager {
	margin: 0;
	padding: 4rem 0;
	color: #000000;
	font-size: 1.6rem;
	text-align: center;
	line-height: 100%;
}
.pager::after {
	content: "";
	display: block;
	clear: both;
	float: none;
}
.pager .pages {
	display: inline-block;
	margin: 0 0 0 2rem;
	padding: 0.5rem 1rem;
	background-color: #EEEEEE;
	border-radius: 0.5rem;
}
.pager .prev {
	display: inline-block;
	margin: 0 0.5rem 0 0;
	padding: 0.5rem 1rem;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 0.5rem;
}
.pager .next {
	display: inline-block;
	margin: 0 0 0 0.5rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 0.5rem;
}
.pager a.page {
	display: inline-block;
	margin: 0 0.2rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
	border: #CCCCCC 1px solid;
	border-radius: 0.5rem;
}
.pager span.page {
	display: inline-block;
	margin: 0 0.2rem;
	padding: 0.5rem 1rem;
	color: #FFFFFF;
	text-decoration: none;
	background-color: #054DB0;
	border-radius: 0.5rem;
}


/*
* 抽出条件
*/
#searchWrap {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	margin: 0 1rem 1rem 1rem;
	padding: 1rem;
	font-size: 1.4rem;
	background-color: #F5F5F5;
	border-radius: 0.5rem;
}
#searchWrap dl {
	display: flex;
	flex-direction: column;
	flex: 1;
	margin: 0;
	padding: 0 0.5rem;
}
#searchWrap dt {
	width: 100%;
	margin: 0;
	padding: 0 0 0 0.5rem;
	font-weight: 600;
	text-align: left;
}
#searchWrap dd {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
}
#searchWrap dl.notyetWrap {
	flex: none;
	width: 5em;
	text-align: center;
}
#searchWrap dl.notyetWrap dt {
	text-align: center;
}
/* select */
#searchWrap select {
  display: block;
	width: 100%;
	margin: 0;
	padding: 0.5rem 1rem;
	background-color: transparent;
	border: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}
#searchWrap .selectArrow {
  position: relative;
  display: inline-block;
	width: 100%;
  margin: 0;
  padding: 0;
	background-color: #FFFFFF;
	border-radius: 0.6rem;
}
#searchWrap .selectArrow::after {
  content:"";
	position:absolute;
  right: 1.5rem;
  top: calc(50% - 7px);
  display: block;
  width:10px;
  height:10px;
  border-bottom:#333 2px solid;
  border-right:#333 2px solid;
  transform:rotate(45deg);
  z-index: 50000;
}
#searchWrap .selectArrow select {
  position: relative;
  padding-right: 3rem;
  z-index: 50001;
}
#searchWrap input[type='checkbox'] {
	width: 18px;
	height: 18px;
	margin: 10px 0;
	border: #E6E6E6 2px solid;
	border-radius: 0.6rem;
}




/*
* 帳票印刷ボタン
*/
#receiptButton {
	display: flex;
	justify-content: flex-end;
	margin: 0 auto 1rem auto;
	padding: 0 2rem;
}
#receiptButton ul {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0.5rem 0;
	border: #CCCCCC 1px solid;
	border-radius: 3px;
}
#receiptButton li {
	margin: 0 0.5rem;
	padding: 0 1rem;
	font-size: 1.4rem;
	font-weight: 600;
	background-color: #F1F1F1;
	border-radius: 3px;
	cursor: pointer;
}
#receiptButton li:hover { opacity: 0.6; }
#receiptButton li.disabled { opacity: 0.3; }


/*
* モーダル設定
*/
.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: none;
	width: auto;
	height: auto;
  margin: 0;
  padding: 0;
  background-color: #FFFFFF;
  border: none;
  z-index: 99999;
}
.modal .modalWrap {
  position: relative;
  margin: 0;
  padding: 20px;
  background-color: #FFFFFF;
  border: none;
  overflow-y: scroll;
  z-index: 99999;
}
.modal .shadeBlack {
  content: "";
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 100vw;
  height: 100vh;
  background-color: rgba(0,0,0,0.8);
  z-index: 1;
}
