/***************************************************************
bootstrap, ng-bootstrapのコンポーネントのスタイル設定

(可能であればbootstrapの汎用クラスの指定を直接上書きするのでなく、
新たな汎用クラスを追加する。上書きする場合、別の場所で上書きする
汎用クラスが使用されていないか確認する)
****************************************************************/


/**************************************************************
btn
****************************************************************/
.btn {
  border-radius: 0;
}

.btn-primary {
  color: white;
  background-color: #505050;
  border-color: #505050;
}

/* 
.btn-primary:hover {
  color: white;
  background-color: #505050;
  border-color: #505050;
} */

/**************************************************************
btn-xs
****************************************************************/
.btn-group-xs>.btn,
.btn-xs {
  padding: .2rem .5rem;
  font-size: 0.8rem;
  line-height: 1.2;
  border-radius: .2rem;
}

.btn-group>.nsi2-btn:last-child:not(:first-child)>.btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.btn-group>.nsi2-btn:first-child:not(:last-child):not(.dropdown-toggle)>.btn {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}


/**********************************************
各種コントロール(form-control, col-form-label )
***********************************************/


.col-form-label {
  padding-top: calc(0.26rem + 4px);
  padding-bottom: calc(0.26rem + 4px);
}

.col-form-input {
  padding-top: 4px;
  padding-bottom: 4px;
}

.col-form-input-radio {
  padding-top: calc(0.26rem + 4px);
  padding-bottom: calc(0.26rem + 4px);
  font-size: inherit;
  line-height: 1.5;
}

.col-form-input-check {
  padding-top: 6px;
  padding-bottom: 3px;
  font-size: inherit;
  line-height: 1.5;
}

.form-control {
  /** 入力コントロールの角丸を無効にする */
  border-radius: 0;
  border: 1px solid #505050;
  padding: .175rem .75rem;
  color: #111;
}

.radio-inline >  input[type=radio] {
  margin: 3px 0 1px 0;
  margin-right: .25rem!important;
}

@media (min-width: 576px) {
  .form-inline>div>nsi2-cmn-date-picker>div>input.form-control {
    width: calc(100% - 16px);
  }
}


.form-group.row .col-form-table {
  margin-bottom: 10px;
}

/** 非活性状態のためborderの色を変更する */
div.form-control,
span.form-control {
  border: 1px solid #D2D2D2;
}


select.form-control {
  border: 0;
  outline: 1px solid #6D6D6D;
  outline-offset: -1px;
  padding-left: 3px;
}

select.form-control:focus {
  outline: 1px solid #6D6D6D;
}

.form-group {
  margin-bottom: 1px;
}

.form-group .col-form-input input[type=checkbox] {
  margin: 7px 0px 5px 0px;
}

.form-group .form-check-label input[type=checkbox] {
  margin: 5px 0px 7px 0px;
}


select.form-control:not([size]):not([multiple]) {
  height: calc(1.7rem + 2px);
}

nsi2-cmn-color-picker .form-control {
  height: calc(1.7rem + 2px);
  padding: 0.8rem 0.5rem;
}


input[type=text].form-control,
input[type=password].form-control,
input[type=number].form-control {
  /**  bottom/top  left/right */
  padding: .24rem .5rem;
  height: calc(1.7rem + 2px);
}

.dropdown-item {
  color: #111;
}

.input-group {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: stretch;
  align-items: stretch;
  width: 100%;
  flex-wrap: nowrap;
}

/** 入力Controlのエラー表示 */

/** tooltipの背景色 */
.tooltip>.tooltip-inner {
  background-color: #ffffff;
  border: 1px solid #000000;
  color: #000000;
}

.tooltip.bs-tooltip-auto[x-placement^=right] .arrow::before,
.tooltip.bs-tooltip-right .arrow::before {
  border-right-color: #000000;
}

.tooltip.bs-tooltip-auto[x-placement^=top] .arrow::before,
.tooltip.bs-tooltip-top .arrow::before {
  border-top-color: #000000;
}

.tooltip.bs-tooltip-auto[x-placement^=bottom] .arrow::before,
.tooltip.bs-tooltip-bottom .arrow::before {
  border-bottom-color: #000000;
}

.tooltip.bs-tooltip-auto[x-placement^=left] .arrow::before,
.tooltip.bs-tooltip-left .arrow::before {
  border-left-color: #000000;
}

/** tooltipのエラーメッセージの文字 */
.nsi2-error-tooltip-wrapper {
  min-width: 200px;
}
span.nsi2-error-tooltip {
  color: red;
}

nsi2-cmn-radio.nsi2-input-error div.input-error label {
  text-decoration: underline;
  text-decoration-color: red;
}

.nsi2-input-error input.input-error {
  border-width: 1px !important;
  border-color: rgba(255, 99, 71, 1) !important;
}

textarea.input-error {
  border-width: 1px !important;
  border-color: rgba(255, 99, 71, 1) !important;
}

select.input-error {
  border-width: 1px !important;
  border-color: rgba(255, 99, 71, 1) !important;
  outline: 1px solid rgba(255, 99, 71, 1) !important;
}

/** 日付入力(datepicker) */
ngb-datepicker.dropdown-menu {
  z-index: 99999999999;
}

ngb-datepicker-navigation-select>select:nth-of-type(1) {
  /** 2018年08月の表示にするために 月入力を右側にする */
  position: relative;
  left: 66px;
  width: 40px;
}

ngb-datepicker-navigation-select>select:nth-of-type(2) {
  position: relative;
  left: -59px;
  width: 45px;
}

ngb-datepicker>>>ngb-datepicker-month-view>>>.ngb-dp-week:nth-child(2) {
  justify-content: flex-end;
}


/** ダイアログ */

.modal {
  text-align: center;
}

@media screen and (min-device-width: 768px) {
  .modal:before {
    display: inline-block;
    vertical-align: middle;
    content: " ";
    height: 100%;
  }
}

.modal-dialog {
  position: absolute;
  display: inline-block;
  text-align: left;
  vertical-align: middle;
  width: 100%;
  top: 100px;
  left: 0;
  right: 0;
  margin: auto;
  max-height: 68%;
}

.modal-content {
  text-align: left;
  width: 100%;
}

.modal-header {
  padding: 6px 15px;
  background: #505050;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  color: white;
}

.modal-header .modal-title {
  font-size: 1.1rem;
}


.modal-header .close {
  padding: 15px;
  margin: -16px -15px -15px auto;

  font-weight: 100;
  text-shadow: none;
  opacity: 1;
  color: white;
  font-size: 1.3rem;

  outline: 0px auto -webkit-focus-ring-color;
}

.modal-header .close:focus {
  outline: none;
  color: rgb(91 140 247);
}

.modal-body .container {
  padding-left: 0px;
  padding-right: 0px;
  overflow: auto;
}

.modal-body .container .row {
  margin-right: 0px;
  margin-left: 0px;
}

div.modal-content div.d-inline-block>button {
  min-width: 200px;
}

div.modal-content .form-group {
  /* margin-bottom: 2px; */
}

div.modal-content div.col-form-input {
  padding-right: 15px;
  /* padding-top: 7px; */
}

div.modal-content div.col-form-time {
  width: 100px;
}

div.modal-content input[type='text'],
div.modal-content input[type='number'] {
  /* padding-top: 3px;
  padding-bottom: 3px; */
}

ngb-modal-window.modal.show {
  background: #33333399;
}

/**********************************************
テーブル内の日付ピッカーのダイアログ
***********************************************/
ngb-modal-window.modal.nsi2-datepicker > div.modal-dialog {
  width: 220px;
}


/**********************************************
ツールチップ (全体で共通で問題ないか)
***********************************************/
.tooltip>.tooltip-inner {
  font-size: 1rem;
}

.tooltip.error-tooltip {
  background-color: red;
}

/**********************************************
ページネーション
***********************************************/

.pagination {
  margin-bottom: 0.2rem;
}

.pagination .page-link {
  padding: .2rem .75rem;
}

.pagination .page-link:focus {
  outline: none;
  /* background-color: transparent;
  border-color: #ddd; */
  /*color: #0056b3; */
  /* text-decoration: none; */
  /* background-color: #e9ecef; */
  /* border-color: #ddd; */
}

.pagination .page-link>span {
  padding: .2rem .4rem;
}

span.paging-item-count {
  padding-left: 1rem;
  padding-top: 0.3rem;
  margin-bottom: 0.2rem !important;
}

/**********************************************
タブ
***********************************************/

ngb-tabset ul.nav.nav-tabs {
  border-top-color: #DDDDDD;
  border-top-style: solid;
  border-top-width: 1px;
  border-right-color: #DDDDDD;
  border-right-style: solid;
  border-right-width: 1px;
  border-bottom-color: transparent;
  border-bottom-style: solid;
  border-bottom-width: 0px;
  border-left-color: #DDDDDD;
  border-left-style: solid;
  border-left-width: 1px;

  /* display: -webkit-box; */
  display: flex;

}

.nav-tabs .nav-item {
  /* -webkit-box-flex: 1;
  box-flex: 1; */
  flex-grow: 1;
  /* width: 100%; */
  margin-right: 2px;
  text-align: center;
}

.nav-tabs .nav-item:last-child {
  /* .nav-tabs::last-child { */
  margin-right: 0px;
}

.nav-tabs .nav-link {
  color: #323232c2;
  border-top-left-radius: 0;
  border-top-right-radius: 0;

  background: #d3d3d3;

  border: 0;
  border-bottom-color: transparent;
  border-bottom-style: solid;
  border-bottom-width: 1px;
}

.nav-tabs .nav-link:hover {
  border-bottom-color: #DDDDDD;
  border-bottom-style: solid;
  border-bottom-width: 1px;

}

.nav-tabs .nav-link.active {
  color: #323232;

  background: white;

  border-bottom-color: #F2F2F2;
  border-bottom-style: solid;
  border-bottom-width: 1px;
}

ngb-tabset div.tab-content {
  border-top-color: transparent;
  border-top-style: solid;
  border-top-width: 0px;
  border-right-color: #DDDDDD;
  border-right-style: solid;
  border-right-width: 1px;
  border-bottom-color: #DDDDDD;
  border-bottom-style: solid;
  border-bottom-width: 1px;
  border-left-color: #DDDDDD;
  border-left-style: solid;
  border-left-width: 1px;
}

/**********************************************
タイプアヘッドコンポーネント（オートコンプリート）
***********************************************/
ngb-typeahead-window.dropdown-menu {
  max-height: 250px;
  overflow: auto;
  z-index: 99999999999;
}

/**********************************************
ツリーテーブル
***********************************************/

.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight {
  background: #C9E7FF;
}


/**********************************************
ツリーテーブル
***********************************************/


.angular-tree-component {
  font-size: 0.9rem;

}



/**************************************************************
ボーダー色修正
****************************************************************/
.card {
  border-color: rgba(0, 0, 0, .3);
}

.card-header {
  border-bottom-color: rgba(0, 0, 0, .3);
}

.page-link {
  /* border: 1px solid #ddd; */
  border-color: rgba(0, 0, 0, .3);
}

.border {
  border-color: rgba(0, 0, 0, .3) !important;
}

.nav-tabs .nav-item.show .nav-link,
.nav-tabs .nav-link.active {
  border-color: rgba(0, 0, 0, .3) rgba(0, 0, 0, .3) #fff;
}

.nav-tabs .nav-link.active {
  border-bottom-color: #F2F2F2;
}

ngb-tabset ul.nav.nav-tabs {
  border-top-color: rgba(0, 0, 0, .3);
  border-right-color: rgba(0, 0, 0, .3);
  border-left-color: rgba(0, 0, 0, .3);
}

ngb-tabset div.tab-content {
  border-right-color: rgba(0, 0, 0, .3);
  border-bottom-color: rgba(0, 0, 0, .3);
  border-left-color: rgba(0, 0, 0, .3);
}
