/********* WZFライブラリCSS *********/
/* input, textarea のバリデーションエラー. */
form input:invalid,
form select:invalid,
form textarea:invalid,
form .input-group:has(:invalid) .input-group-text,
form .input-group:has(:invalid) .input-group-text i,
form .input-group:has(:invalid) input[data-wzf-action="datetimepicker"],
form .input-group:has(:invalid) input[data-wzf-action="datepicker"],
form .input-group:has(:invalid) input[data-wzf-action="timepicker"],
form .input-group:has(:invalid) input[data-wzf-action="daterangepicker"],
form select[data-wzf-action="select2"]:invalid + .nice-select,
form select[data-wzf-action="select2"]:invalid + .nice-select:after {
  color: #fa6767 !important;
  border-color: #fa6767 !important;
  background-color: #fff5f8 !important;
}

form .input-group:has(:invalid) .input-group-text {
  border-color: var(--bs-danger) !important;
}

/* バリデーションメッセージ枠. */
form input + .invalid-message,
form select + .invalid-message,
form textarea + .invalid-message,
form .input-group + .invalid-message {
  margin: .25rem 0 .5rem;;
  height: 1rem;
}

form input + .invalid-message,
form input + .invalid-message i,
form select + .invalid-message,
form select + .invalid-message i,
form textarea + .invalid-message,
form textarea + .invalid-message i,
form .input-group + .invalid-message,
form .input-group + .invalid-message i {
  font-size: .75rem;
  font-weight: 600;
}

/* バリデーションメッセージ for valid. */
form input:valid + .invalid-message,
form input:valid + .invalid-message i,
form select:valid + .invalid-message,
form select:valid + .invalid-message i,
form textarea:valid + .invalid-message,
form textarea:valid + .invalid-message i,
form .input-group:has(:valid) + .invalid-message,
form .input-group:has(:valid) + .invalid-message i {
  opacity: 0;
  transition: opacity 0.75s, display 0.75s
}

/* バリデーションメッセージ for invalid. */
form input:invalid + .invalid-message,
form input:invalid + .invalid-message i,
form select:invalid + .invalid-message,
form select:invalid + .invalid-message i,
form textarea:invalid + .invalid-message,
form textarea:invalid + .invalid-message i,
form .input-group:has(:invalid) + .invalid-message,
form .input-group:has(:invalid) + .invalid-message i {
  color: #fa6767 !important;
  opacity: 1;
  transition: opacity 0.75s, display 0.75s
}

/* チェックボックス・ラジオボタン選択時のラベルテキスト色. */
input[type="checkbox"]:checked + label.form-check-label,
input[type="radio"]:checked + label.form-check-label {
  color: var(--bs-gray-700) !important;
  font-weight: 600 !important;
}

/* チェックボックス・ラジオボタン未選択時のバッジ色. */
input[type="checkbox"]:not(:checked) + label.form-check-label > span.badge {
  color: var(--bs-light-inverse) !important;
  background-color: var(--bs-light) !important;
}

/* チェックボックスの表示位置調整. */
.form-check-inline > input[type="checkbox"].form-check-input {
  margin-top: 1px !important;
}

/* flatpickr */
.flatpickr-current-month input.cur-year {
  font-size: 1.5rem !important;
}

.flatpickr-current-month {
  display: flex !important;
  flex-direction: row-reverse;
  justify-content: center;
}

.flatpickr-calendar .flatpickr-innerContainer .flatpickr-weekdays .flatpickr-weekday:nth-child(7),
.flatpickr-calendar .flatpickr-innerContainer .flatpickr-days .flatpickr-day:not(.flatpickr-disabled):not(.prevMonthDay):not(.nextMonthDay):nth-child(7n) {
  color: #DC143C;
}

form .input-group input[data-wzf-flatpickr-value] {
  display: none;
}

form .input-group input[data-wzf-action="datetimepicker"],
form .input-group input[data-wzf-action="datepicker"],
form .input-group input[data-wzf-action="timepicker"],
form .input-group input[data-wzf-action="daterangepicker"] {
  border-top-right-radius: 5px !important;
  border-bottom-right-radius: 5px !important;
}

.flatpickr-time input.flatpickr-hour, .flatpickr-time input.flatpickr-minute {
  color: #ffffff !important;
  font-size: 1.3rem !important;
}

/* quill */
.ql-toolbar {
  border-top-left-radius: .25rem !important;
  border-top-right-radius: .25rem !important;
}

.ql-container {
  border-bottom-left-radius: .25rem !important;
  border-bottom-right-radius: .25rem !important;
  margin-left: 0 !important;
  height: 400px;
}

/* nice-select2 */
.nice-select {
  height: 44px !important;
  padding: 0.775rem 1rem !important;
  border-radius: 5px !important;
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
  border-color: var(--bs-gray-300) !important;
}

.nice-select.nice-select-sm {
  height: calc(1.5em + 1.1rem + 2px) !important;
  padding: 0.55rem 0.75rem !important;
  font-size: .95rem !important;
  border-radius: 0.425rem !important;
}

.nice-select .optgroup {
  background-color: #F9F9F9 !important;
  padding-left: 9px;
  line-height: 30px;
  font-size: 1rem;
}

select[data-wzf-action="select2"] {
  border: none; /* 段差が生じてしまうため`border`を消す必要あり */
}

/* プルダウンの枠から文字がはみ出てしまうことの制御 */
span.current {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
}

/********* CraftカスタマイズCSS *********/
/* プレースホルダー文字色を薄く. */
::placeholder {
  color: var(--bs-text-gray-300) !important
}

/* スクロール時にヘッダ固定した際、ヘッダ下部に影を追加. */
header[data-kt-sticky-enabled] {
  box-shadow: 0 10px 10px -10px rgba(0, 0, 0, .5) !important;
}

/* トースト通知. */
#toastr-container > div {
  width: 80% !important;
  max-width: 450px !important;
  padding: 1rem 1.25rem 1rem 4.5rem !important;
  box-shadow: 6px 6px 6px #999 !important;
  opacity: 0.9;
}

.toastr .toastr-title {
  font-size: 1rem !important;
  font-weight: 600 !important;
}

.toastr .toastr-message {
  font-size: 1.2rem !important;
  font-weight: 600 !important;
}

/********* アプリCSS *********/
.content-truncate {
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

/* ライセンスプレート Entry. */
.license-plate-entry {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.license-plate-entry > div {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.license-plate-entry > div > div {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.license-plate-entry > div > div > label {
  color: var(--bs-text-danger);
  font-size: 2rem;
  font-weight: 600;
}

.license-plate-entry .area input,
.license-plate-entry .class input,
.license-plate-entry .kana input {
  color: #006400;
  font-size: 2rem;
  font-weight: 600;
  max-height: 60px;
}

.license-plate-entry .digit input {
  color: #006400;
  font-size: 4rem;
  font-weight: 600;
  max-height: 60px;
}

/* ライセンスプレート View. */
.license-plate {
  display: inline-block;
  vertical-align: middle;
  border: solid 1px #92929F;
  border-radius: .25rem;
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.5), inset 0px -3px 6px -2px rgba(0, 0, 0, 0.3);
  background-color: #FFFFFF;
  font-weight: 700 !important;
  color: #006400;
  line-height: 1;
  white-space: nowrap;
  max-height: 90px;
  min-width: 180px;
  padding: 12px;
}

.license-plate.license-plate-sm {
  max-height: 60px;
  min-width: 120px;
  padding: 6px;
}

.license-plate > div:first-child {
  display: flex;
  justify-content: center;
  text-align: center;
  min-height: 22px;
}

.license-plate.license-plate-sm > div:first-child {
  min-height: 16px;
}

.license-plate > div:last-child {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: 48px;
}

.license-plate.license-plate-sm > div:last-child {
  min-height: 32px;
}

.license-plate .area,
.license-plate .class,
.license-plate .kana {
  font-size: 20px;
}

.license-plate.license-plate-sm .area,
.license-plate.license-plate-sm .class,
.license-plate.license-plate-sm .kana {
  font-size: 14px;
}

.license-plate .class {
  font-family: Verdana;
}

.license-plate .digit {
  font-family: Verdana;
  letter-spacing: 0px;
  font-weight: bold;
  margin-left: .25rem;
  text-align: end;
  min-width: 120px;
  font-size: 42px;
}

.license-plate.license-plate-sm .digit {
  min-width: 80px;
  font-size: 28px;
}

.license-plate.yellow {
  color: black !important;
  background-color: #ffd12a !important;
}

.license-plate.green {
  color: #ffffff !important;
  background-color: #174626 !important;
}

.member.unfollow .membership.badge {
  color: var(--bs-light-inverse) !important;
  background-color: var(--bs-light) !important;
}

.member.unfollow .picture.symbol img {
  -webkit-filter: grayscale(1);
  filter: grayscale(1);
}

.model {
  background-color: #FFFFFF;
}

/* 注意文言の箇条書き */
.notice ul li {
  list-style: decimal;
}