@charset "UTF-8";

/* theme */

:root {
  --backgroundColor: #fff;
  --color: #000;
  --borderColor: #e5e5e5;
}

.dark_mode {
  --backgroundColor: #202124;
  --color: #fff;
  --borderColor: #37383a;
}

/* text color */

/* shadow */

/* transition */

html,
body {
  background-color: var(--backgroundColor) !important;
}

/* ---------------------------------------------------
    BASIC STYLE
----------------------------------------------------- */

html,
body,
div,
ul,
li,
span,
em,
i {
  word-break: keep-all;
}

html,
body {
  width: 100%;
  height: 100%;
}

/* ---------------------------------------------------
    LAYOUT STYLE
----------------------------------------------------- */

.wrap {
  height: 100%;
  max-width: 1600px;
  margin: 0 auto;
}

.wrap.full .max-width {
  max-width: 100% !important;
}

.contents-area {
  width: 100%;
  height: calc(100% - 74px);
}

.max-width {
  max-width: 980px;
}

/* ---------------------------------------------------
    SIDEBAR STYLE
----------------------------------------------------- */

.wrapper {
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
}

/* ---------------------------------------------------
    SIDEBAR STYLE
----------------------------------------------------- */

/* ---------------------------------------------------
    CONTENT STYLE
----------------------------------------------------- */

#content {
  position: relative;
  width: 100%;
  height: calc(100% - 72px);
  min-height: 100%;
  padding: 15px 25px;
}

#content.new-form {
  max-width: 1280px;
  margin: 0 auto;
}

#content.new-form.blue {
  color: #0472ca;
}

#content.view_summary .tbl.list {
  right: 450px;
  border-radius: 5px 0 0 5px;
}

#content.view_summary .summary-view {
  right: 0;
}

#content > .head {
  padding-bottom: 1rem;
  width: 100%;
}

#content > .head > .row {
  flex-wrap: nowrap !important;
}

.con {
  position: relative;
  height: calc(100% - 3.5rem);
  border-top: 1px solid #ddd;
}

/* ---------------------------------------------------
    FOOTER STYLE
----------------------------------------------------- */

#footer {
  width: 100%;
  height: 50px;
  font-size: 12px;
  padding: 0 25px;
  vertical-align: middle;
}

#footer .max-width {
  max-width: 930px;
}

#footer .d1 {
  display: grid;
  position: relative;
  color: #6a737d;
  width: 100%;
  margin: 0 auto;
  height: 50px;
  padding-left: 250px;
  align-items: center;
  transition: all 0.3s cubic-bezier(0.945, 0.02, 0.27, 0.665);
}

#footer .d1 .logo {
  position: absolute;
  left: 0;
  text-align: right;
}

#footer .d1 .logo img {
  margin-right: 10px;
}

#footer .d1 .address {
  color: #aaa;
  text-align: right;
}

#footer .d1 .address span {
  margin-left: 30px;
}

/* ---------------------------------------------------
    MEDIAQUERIES
----------------------------------------------------- */

.one-page .content {
  max-width: 1100px;
  margin: 0 auto;
}

.one-page .pagehead {
  margin-bottom: 20px;
  border-bottom: 1px solid #e1e4e8;
}

.one-page .pagehead .box {
  max-width: 1100px;
  margin: 0 auto;
}

.one-page .pagehead .title {
  font-size: 1.125rem;
  padding-bottom: 15px;
}

.one-page .pagehead .title .loc {
  color: #0366d6;
  font-weight: 400;
}

.one-page .pagehead .title .loc b {
  font-weight: 500;
}

.one-page .pagehead .title .loc em {
  color: #111;
  margin: 0 0.25em;
}

.one-page .pagehead .tabmenu ul {
  margin-bottom: 0;
}

.one-page .pagehead .tabmenu ul li {
  cursor: pointer;
  display: inline-block;
  padding: 7px 15px 8px;
  border-style: none;
}

.one-page .pagehead .tabmenu ul li.active {
  position: relative;
  top: 1px;
  border-style: solid;
  border-color: #e36209 #e1e4e8 transparent;
  border-width: 3px 1px 1px;
  border-radius: 3px 3px 0 0;
  background-color: #fff;
}

.one-page .pagehead .tabmenu ul li i {
  margin-right: 5px;
}

.ta_l {
  text-align: left;
}

.ta_c {
  text-align: center;
}

.ta_r {
  text-align: right;
}

/* common */

.ico_corp {
  display: inline-block;
  overflow: hidden;
  line-height: 0;
  background: url("/img/icon_pack.png") no-repeat;
  text-indent: -9999px;
  vertical-align: top;
}

.clear {
  width: 100%;
  clear: both;
}

.disabled {
  opacity: 0.8;
}

.disabled button {
  background-color: #eee !important;
}

.fl {
  float: left;
}

.fr {
  float: right;
}

.tx_l {
  text-align: left;
}

.tx_r {
  text-align: right;
}

.none {
  display: none;
}

.br-0 {
  border-right: 0 !important;
}

html,
body {
  font-size: 12px;
  transition: background-color 0.5s ease;
}

pre {
  white-space: pre-wrap;
  word-wrap: break-word;
  margin-bottom: 0 !important;
}

a.blue {
  cursor: pointer;
  color: #0366d6 !important;
}

a.blue:hover {
  text-decoration: underline !important;
}

.link {
  cursor: pointer;
  color: #0366d6 !important;
  text-decoration: underline;
}

.btn-delete {
  cursor: pointer;
  color: #ff0000 !important;
}

.pointer {
  cursor: pointer;
}

.no-border {
  border: 0 !important;
}

.custom-checkbox {
  font-size: 0;
}

.custom-control-label {
  font-size: 1rem;
}

.custom-control-input.custom-input ~ input[type=text] {
  display: none;
  background: transparent;
  border-top: 0;
  border-left: 0;
  border-right: 0;
  border-bottom: 1px solid #999;
  border-radius: 0;
  padding: 5px 0;
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  width: 100%;
  box-shadow: none;
  outline: none;
}

.custom-control-input.custom-input:checked ~ input[type=text] {
  display: block;
}

.btn-success.gradation {
  color: #fff;
  background-color: #28a745;
  background-image: linear-gradient(-180deg, #34d058 0%, #28a745 90%);
}

.btn-success.gradation:focus,
.btn-success.gradation.focus {
  box-shadow: 0 0 0 0.2em rgba(52, 208, 88, 0.4);
}

.btn-success.gradation:hover,
.btn-success.gradation.hover {
  background-color: #269f42;
  background-image: linear-gradient(-180deg, #2fcb53 0%, #269f42 90%);
  background-position: -0.5em;
  border-color: rgba(27, 31, 35, 0.5);
}

.btn-success.gradation:active,
.btn-success.gradation.selected,
[open] > .btn-success.gradation {
  background-color: #279f43;
  background-image: none;
  border-color: rgba(27, 31, 35, 0.5);
  box-shadow: inset 0 0.15em 0.3em rgba(27, 31, 35, 0.15);
}

.btn-success.gradation:disabled,
.btn-success.gradation.disabled {
  color: rgba(255, 255, 255, 0.75);
  background-color: #94d3a2;
  background-image: none;
  border-color: rgba(27, 31, 35, 0.2);
  box-shadow: none;
}

.btn-sm,
.btn-group-sm > .btn {
  padding: 0.25rem 0.725rem !important;
}

hr {
  margin-top: 1rem;
  margin-bottom: 1rem;
  border: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

/* 구분선 */

hr {
  height: 0;
  margin: 15px 0;
  overflow: hidden;
  background: transparent;
  border: 0;
  border-bottom: 1px solid #dfe2e5;
}

hr.dash {
  border-top: 1px dashed rgba(0, 0, 0, 0.2);
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

hr.sec {
  border-top: 1px dashed #c3c3c3;
  margin: 4rem 0;
}

/* 셀렉트박스 */

.switch {
  cursor: pointer;
  height: 16px;
}

.switch.on label {
  background-color: #0366d6;
}

.switch.on label:after {
  left: 2px;
  transform: translateX(0);
  margin-left: 0;
}

.switch.on label:active:after {
  margin-left: 0;
}

.switch input[type=checkbox] {
  width: 0;
  height: 0;
  visibility: hidden;
}

.switch label {
  position: relative;
  display: inline-block;
  cursor: pointer;
  text-indent: -9999px;
  width: 28px;
  height: 16px;
  background-color: #ddd;
  border-radius: 100px;
  transition: all 0.5s ease;
  margin-bottom: 0;
}

.switch label::before {
  opacity: 0 !important;
}

.switch label:active:after {
  width: 26px;
  transform: translateX(0);
}

.switch label:after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  background-color: #fff;
  border-radius: 22px;
  transition: 0.3s;
  transform: translateX(100%);
}

.select-elem {
  float: left;
  position: relative;
  cursor: pointer;
  border: 0;
  height: 28px;
  border-radius: 0.25em;
  transition: all 0.3s ease-in-out;
  overflow: hidden;
  color: #24292e;
  border: 1px solid #ccc;
}

.select-elem:hover {
  border-color: #0d151d;
  box-shadow: inset 0 0 0 rgba(0, 0, 0, 0), 0 2px 6px 0 rgba(49, 49, 93, 0.2), 0 0 2px 0 rgba(0, 0, 0, 0.4) !important;
}

.select-elem select {
  float: left;
  width: 100%;
  height: 100%;
  padding: 0 20px 0 10px;
  border: none;
  box-shadow: none;
  background-color: #e1e8ec;
  background: url("/img/select-arrow.png") right 10px center no-repeat, linear-gradient(-180deg, #fafbfc 0%, #e1e8ec 90%);
  -webkit-appearance: none;
  border-radius: 0;
}

.select-elem select::-ms-expand {
  display: none;
}

.select-elem i {
  position: absolute;
  color: #7e8b9d !important;
  font-size: 14px;
  top: 7px;
  right: 5px;
}

.select-elem.opt {
  border-radius: 0.25em 0 0 0.25em;
}

.select-elem.opt + input {
  margin-left: -7px;
}

.select-elem.opt.right {
  border-radius: 0 0.25em 0.25em 0;
  margin-left: -7px;
}

/* 버튼 */

a.button {
  display: inline-table;
  justify-content: center;
  position: relative;
  padding: 0 15px;
  font-size: 0.75rem;
  border-radius: 4px;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
  color: #24292e;
  background-color: #eff3f6;
  background-image: linear-gradient(-180deg, #fafbfc 0%, #eff3f6 90%);
  border: 1px solid rgba(27, 31, 35, 0.2);
  height: 28px;
  line-height: 26px;
}

a.button:hover {
  border: 1px solid rgba(27, 31, 35, 0.6);
}

a.button.green {
  background-color: #28a745;
  color: #fff;
}

a.button.red {
  background-color: #fff;
  color: #ff0000;
}

a.button.point {
  color: #fff;
  background-color: #28a745;
  background-image: linear-gradient(-180deg, #34d058 0%, #28a745 90%);
}

a.button.point:hover {
  background-image: linear-gradient(-180deg, #2abd4c 0%, #1d9038 90%);
}

a.button.icon {
  padding-left: 35px !important;
}

a.button i {
  position: absolute;
  left: 10px;
  margin-right: 10px;
  font-size: 18px;
}

/* Textarea */

textarea {
  border: 1px solid #d9e1e9;
  transition: all 0.3s ease-in-out;
}

textarea:hover,
textarea:focus {
  border: 1px solid #0d151d;
}

/* Input */

.frm_input {
  min-height: 34px;
  padding: 6px 8px;
  font-size: 0.875rem;
  line-height: 20px;
  color: #24292e;
  vertical-align: middle;
  background-color: #fafbfc;
  background-repeat: no-repeat;
  background-position: right 8px center;
  border: 1px solid #d1d5da;
  border-radius: 3px;
  outline: none;
  box-shadow: inset 0 1px 2px rgba(27, 31, 35, 0.075);
}

.form-control {
  box-shadow: inset 0 1px 2px rgba(27, 31, 35, 0.075);
}

/* 테이블 */

.tbl {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  border-radius: 5px;
}

.tbl .no-result {
  position: absolute;
  text-align: center;
  top: 50%;
  width: 100%;
  margin-top: -60px;
}

.tbl .custom-control {
  min-height: 1.3rem;
}

.tbl thead th {
  padding: 0 4px;
  color: #1e1e1e;
}

.tbl.list .thead {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 35px;
  overflow-x: hidden;
  overflow-y: scroll;
}

.tbl.list .thead table {
  position: absolute;
  table-layout: fixed;
  width: 100%;
  background-color: #fff;
}

.tbl.list .thead tr th {
  position: relative;
  text-align: left;
  height: 34px;
  font-weight: 400;
  border-bottom: 1px solid #e5e5e5;
  color: #777;
}

.tbl.list .thead tr th.link {
  text-decoration: none;
}

.tbl.list .thead tr th em {
  position: absolute;
  right: 10px;
}

.tbl.list .thead tr th.check {
  padding: 0;
  text-align: center;
}

.tbl.list .tbody {
  position: absolute;
  top: 35px;
  left: 0;
  right: 0;
  bottom: 51px;
  border-top: 0;
  background-color: #fff;
  overflow-y: scroll;
}

.tbl.list .tbody table {
  table-layout: fixed;
  width: 100%;
}

.tbl.list .tbody tr:hover {
  background-color: #fafafa;
}

.tbl.list .tbody tr.alert {
  background-color: #fff9e6;
}

.tbl.list .tbody tr.select,
.tbl.list .tbody tr.select:hover {
  background-color: #f2f5fb;
}

.tbl.list .tbody tr.selected,
.tbl.list .tbody tr.selected:hover {
  background-color: #e9f5fa;
}

.tbl.list .tbody tr td {
  text-align: left;
  color: #4a4a4a;
  border-bottom: 1px solid #e5e5e5;
  padding: 4px;
  height: 35px;
  cursor: pointer;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tbl.list .tbody tr td.check {
  padding: 0;
  text-align: center;
}

.tbl.list .tbody tr td.white-normal {
  white-space: normal;
}

.tbl.list .tbody tr td input[type=text] {
  width: 100%;
}

.tbl.list .tbody tr td em.r {
  color: #ff0000;
}

.tbl.list .tbody tr td em.b {
  color: #009dff;
}

.tbl.list .tbody tr td.ticket {
  color: #ddd !important;
}

.tbl.list .tbody tr td.ticket .stock {
  display: inline-block;
  color: #666;
}

.tbl.list .tbody tr td.ticket .using {
  display: inline-block;
  color: #e34c26;
}

.tbl.list .tbody tr td.ticket .left {
  display: inline-block;
  color: #2b7489;
}

.tbl.list .tbody tr td .custom-checkbox input[type=checkbox] {
  left: 50%;
}

.tbl.list .tdetail {
  position: absolute;
  top: 51px;
  left: 0;
  right: 0;
  bottom: 0;
  overflow-y: auto;
  border-top: 0;
  background-color: #fff;
  overflow-y: scroll;
}

.tbl.list .tfoot {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 51px;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  padding-right: 16px;
}

.tbl.list .tfoot td {
  padding: 10px 6px;
}

td .opt-value {
  width: 100%;
  display: inline-block;
  font-size: 16px;
  border-radius: 30px;
  border: 1px solid #ddd;
  padding: 3px 15px;
  margin: 3px 5px 3px 0;
}

/* rich text editor */

i.fa {
  font-family: FontAwesome !important;
}

/* 셀렉트박스 */

.opt_comm {
  float: left;
  position: relative;
  border-bottom: 1px solid #4d4d4d;
  /* 2017-11-13 추가 */
  /* 2017-11-13 추가 */
}

.opt_comm .link_selected {
  display: block;
  overflow: hidden;
  position: relative;
  padding: 2px 20px 5px 0;
  font-weight: bold;
  font-size: 1.125rem;
  color: #1e1e1e;
  text-decoration: none;
  background-color: #fff;
}

.opt_comm .link_selected .ico_arrow {
  position: absolute;
  top: 11px;
  right: 0;
  width: 12px;
  height: 8px;
  background-position: 0 -20px;
}

.opt_comm .box_opt {
  display: none;
  overflow: hidden;
  position: absolute;
  top: 34px;
  left: 0;
  right: 0;
  width: auto;
  border: 1px solid #4d4d4d;
  background: #fff;
}

.opt_comm .inner_opt {
  overflow: hidden;
  width: 100%;
  max-height: 170px;
  margin-top: 5px;
  padding-bottom: 5px;
}

.opt_comm .list_opt {
  position: relative;
}

.opt_comm .list_opt li {
  padding: 6px 15px;
}

.opt_comm .list_opt .link_option {
  display: block;
  line-height: 22px;
  color: #666;
}

.opt_comm .list_opt .link_option:hover {
  color: #1e1e1e;
}

.opt_comm .list_opt .on .link_option {
  color: #1e1e1e;
  text-decoration: underline;
}

.opt_comm .wrap_opt {
  position: relative;
}

.opt_comm .wrap_opt .box_opt {
  top: 0;
}

.opt_comm .scroll_bar {
  display: none;
  overflow: hidden;
  position: absolute;
  right: 0px;
  top: 3px;
  bottom: 3px;
}

.opt_comm .scroll_bar .bg_bar {
  display: block;
  position: relative;
  width: 5px;
  background-color: #1e1e1e;
}

.opt_comm2 {
  float: none;
  border: 0 none;
}

.opt_comm2 .link_selected {
  height: 38px;
  padding: 0 20px 0 10px;
  font-weight: normal;
  font-size: 1rem;
  line-height: 38px;
  border: 1px solid #d4d4d4;
}

.opt_comm2 .link_selected .ico_arrow {
  top: 16px;
  right: 9px;
}

.opt_comm2 .box_opt {
  top: 39px;
  border-color: #d4d4d4;
}

.opt_comm2 .inner_opt {
  max-height: 180px;
}

.opt_comm2 .list_opt li {
  padding: 7px 10px;
}

.opt_open {
  z-index: 10;
}

.opt_open .link_selected .ico_arrow {
  background-position: -20px -20px;
}

.opt_open .box_opt {
  display: block;
}

.opt_fix {
  position: fixed;
  top: 116px;
}

/* Range Slider */

.rangeSlider {
  position: relative;
  padding: 14px 0;
  margin-top: 14px;
  cursor: pointer;
}

.rangeSlider .handle {
  z-index: 2;
  position: absolute;
  cursor: pointer;
  width: 20px;
  height: 20px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.2);
  border: 1px solid #ddd;
  margin-top: -4px;
  margin-left: -10px;
  transition: all 100ms ease-in;
}

.rangeSlider .handle:hover {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.4);
}

.rangeSlider .slider {
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #ccc;
  margin-top: 6px;
}

.rangeSlider .slider::before {
  content: "\AC00";
  position: absolute;
  font-size: 11px;
  bottom: 8px;
  left: -5px;
}

.rangeSlider .slider::after {
  content: "\AC00";
  position: absolute;
  font-size: 16px;
  bottom: 8px;
  right: -8px;
}

.rangeSlider .thumb {
  position: absolute;
  top: 16px;
  width: 1px;
  height: 9px;
  background-color: #999;
}

/* 옵션메뉴 */

.optbox {
  z-index: 99;
  position: absolute;
  text-align: left;
  font-size: 0.8125rem;
}

.optmenu .optbox {
  display: none;
  z-index: 999;
  background-color: #fff;
  margin: 12px 0 20px 0;
  box-shadow: 0 50px 100px rgba(50, 50, 93, 0.1), 0 15px 35px rgba(50, 50, 93, 0.15), 0 5px 15px rgba(0, 0, 0, 0.1);
  border: 1px solid #ccc;
}

.optmenu .optbox::before {
  z-index: 9;
  position: absolute;
  content: "";
  top: -12px;
  margin-left: -6px;
  border-top: 6px solid transparent;
  border-bottom: 6px solid #fff;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
}

.optmenu .optbox::after {
  z-index: 8;
  position: absolute;
  content: "";
  top: -14px;
  margin-left: -7px;
  border-top: 7px solid transparent;
  border-bottom: 7px solid #aaa;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
}

.optmenu .optbox.left::before {
  left: 13px;
  margin-left: 0;
}

.optmenu .optbox.left::after {
  left: 12px;
  margin-left: 0;
}

.optmenu .optbox > ul {
  padding: 5px 0;
}

.optmenu .optbox > ul > li {
  cursor: pointer;
  padding: 10px 24px;
  font-size: 0.875rem;
  color: #586069;
  vertical-align: middle;
}

.optmenu .optbox > ul > li:hover {
  background: #eee;
  color: #000;
}

.optmenu .optbox.icon {
  min-width: 200px;
}

.optmenu .optbox.icon > ul > li {
  padding: 14px 24px 14px 42px;
}

.optmenu .optbox.icon > ul > li.line {
  border-bottom: 1px solid #e5e5e5;
}

.optmenu .optbox.icon > ul > li > i {
  position: absolute;
  left: 12px;
  font-size: 1.25rem;
  margin-top: 1px;
  margin-right: 10px;
}

.optmenu.on .optbox {
  display: block;
}

/* 페이징 */

.pagination_total {
  position: absolute;
  font-size: 0.875rem;
  color: #999;
  margin-top: 14px;
}

.pagination_total span {
  color: #000;
}

.pagination {
  display: inline-block;
  padding-left: 0;
  margin-top: 5px;
  margin-bottom: 0;
}

.pagination > li {
  display: inline;
}

.pagination > li > a,
.pagination > li > span {
  float: left;
  outline: none;
  width: 32px;
  height: 32px;
  line-height: 32px;
  text-align: center;
  color: #0366d6;
  text-decoration: none;
  background-color: #fff;
  border-radius: 50%;
}

.pagination > li:first-child > a,
.pagination > li:first-child > span {
  margin-left: 0;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
}

.pagination > li:last-child > a,
.pagination > li:last-child > span {
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}

.pagination > li > a:hover,
.pagination > li > a:focus,
.pagination > li > span:hover,
.pagination > li > span:focus {
  z-index: 3;
  color: #23527c;
  background-color: #eee;
  border-color: #ddd;
}

.pagination > .active > a,
.pagination > .active > a:hover,
.pagination > .active > a:focus,
.pagination > .active > span,
.pagination > .active > span:hover,
.pagination > .active > span:focus {
  z-index: 2;
  color: #fff;
  cursor: default;
  background-color: #0366d6;
  border-color: #0366d6;
}

.pagination > .disabled > span,
.pagination > .disabled > span:hover,
.pagination > .disabled > span:focus,
.pagination > .disabled > a,
.pagination > .disabled > a:hover,
.pagination > .disabled > a:focus {
  color: #777;
  cursor: not-allowed;
  background-color: #fff;
  border-color: #ddd;
}

/* Sort */

.sort-brank-space {
  background-color: #ccc;
  border: 2px solid #111;
}

.sort-move {
  opacity: 0.6;
}

/* Modal */

.modal .buttons {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  border-top: 1px solid #ddd;
}

.modal .buttons button {
  width: 100%;
  padding: 20px 0;
  background-color: #fff;
  text-align: center;
  border-right: 1px solid #ddd;
  font-size: 1rem;
}

.modal .buttons button:last-child {
  border-right: 0;
}

.v--modal-overlay {
  overflow-y: auto;
  background: rgba(0, 0, 0, 0.5) !important;
}

/* Datepicker */

.calendar-hour {
  width: 100%;
  padding: 4px 10px;
  text-align: center;
  border: 1px solid #aaa !important;
}

.calendar-date-out {
  color: #ccc !important;
}

.datepicker-popup {
  padding: 12px 14px !important;
}

.datepicker-popup,
.calendar-head .calendar-year-select,
.calendar-head .calendar-month-select {
  font-size: 1rem !important;
}

.calendar-head {
  height: auto !important;
  line-height: 20px !important;
  border-bottom: 1px solid #eee;
  padding-bottom: 10px;
  margin-bottom: 10px;
}

.calendar-date-selected,
.calendar-date-selected:hover {
  color: #fff !important;
}

.calendar-title {
  margin-top: -40px !important;
  height: 40px !important;
  line-height: 40px !important;
  border-bottom: 1px solid #eee;
}

.schedule-table {
  width: 100%;
}

.schedule-table thead tr th {
  font-weight: 500;
  font-size: 12px;
  height: 34px;
  padding: 6px;
  border-bottom: 1px solid #e5e5e5;
}

.schedule-table tbody tr td {
  padding: 10px 6px;
  border-bottom: 1px solid #e5e5e5;
}

.schedule-table tfoot tr td {
  padding: 10px 6px;
  border-bottom: 1px solid #e5e5e5;
}

.dropdown-item .color-picker {
  transform: translateY(25%);
}

hr.light {
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.mx-datepicker .mx-input {
  height: 36px;
}

.calendar-range {
  width: 282px !important;
  box-shadow: 0 8px 10px rgba(0, 0, 0, 0.2);
  border: 1px solid #ccc !important;
  margin-top: -1px;
}

.label {
  font-size: 12px;
  font-weight: 500;
  padding: 1px 0;
  border-radius: 30px;
  float: left;
  text-align: center;
  margin-right: 8px;
  width: 56px;
}

.label.type0 {
  background-color: #daffb0;
  border: 2px solid #daffb0;
  color: #274800;
}

.label.type1 {
  background-color: #b2e7ff;
  border: 2px solid #b2e7ff;
  color: #004465;
}

.label.share {
  border: 2px solid #278cff;
  color: #278cff;
}

.label.return {
  border: 2px solid #ff0000;
  color: #ff0000;
}

.label.new {
  width: 40px;
  background-color: #eee;
  border: 2px solid #eee;
  color: #278cff;
}

.label.renew {
  width: 40px;
  background-color: #eee;
  border: 2px solid #eee;
  color: #4caf50;
}

.error .form-control {
  border: 1px solid #ff0000;
}

.required {
  font-size: 13px;
  color: #ff0000;
}

.router-link-active {
  color: #0366d6 !important;
  text-decoration: underline;
}

.btn-outline-primary.router-link-active {
  text-decoration: none !important;
}

.btn-outline-primary.router-link-active:hover {
  color: #fff !important;
}

.option-table {
  border: 1px solid #ddd;
}

.option-table th,
.option-table td {
  padding: 10px 18px;
}

.option-table td {
  background-color: #fff;
}

.blue input,
.blue .btn,
.blue textarea {
  background-color: #e8f3ff !important;
}

.yellow input,
.yellow .btn {
  background-color: #fff8e2 !important;
}

.v--modal-overlay .v--modal-box {
  overflow: visible !important;
}

.v--modal-overlay .v--modal-box .modal-title {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid #eee;
}

.dark_mode .bootstrap-select .btn {
  background-color: #181b1d !important;
  color: #ddd !important;
  border: 0 !important;
}

.dark_mode .bootstrap-select .dropdown-toggle:focus {
  outline: none !important;
  box-shadow: none !important;
}

.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.5s;
}

.fade-enter,
.fade-leave-to {
  opacity: 0;
}

.form-control {
  border: 1px solid #f6f6f6 !important;
}

.form-control:focus {
  border: 1px solid #1e88e5 !important;
}

.form-control:hover {
  box-shadow: none !important;
}

.form-control:active,
.form-control:focus {
  background-color: #fff;
}

.bootstrap-select .btn {
  border: 1px solid #f6f6f6 !important;
}

.bootstrap-select .btn:hover {
  box-shadow: none !important;
}

.vdp-datepicker input {
  background-color: #f6f6f6 !important;
}

.vdp-datepicker input:disabled {
  background-color: #fff !important;
}

.vdp-datepicker .cell {
  position: relative;
}

.vdp-datepicker .cell.day {
  border-radius: 50%;
}

.vdp-datepicker .cell.day.selected {
  background-color: #0366d6;
  color: #fff;
}

.vdp-datepicker .cell.today::after {
  content: "Today";
  position: absolute;
  bottom: -13px;
  left: 0;
  text-align: center;
  font-size: 9px;
  width: 100%;
  color: #0366d6;
}

.form-control:disabled,
.form-control[readonly] {
  background-color: #fff !important;
  border: 1px solid #ddd !important;
}

.form-control:disabled:focus,
.form-control[readonly]:focus {
  border: 1px solid #ddd !important;
}

.editor {
  height: 360px;
}

.editor .ql-container {
  height: 300px;
}

.cell.day.disabled.weekend.sat {
  color: #c9e1ff;
}

.cell.day.disabled.weekend.sun {
  color: #ffc9c9;
}

.profile-icon {
  position: relative;
  padding-left: 40px;
}

.profile-icon span {
  position: absolute;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  overflow: hidden;
  margin-right: 10px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background-position: center center;
  background-size: cover;
  border: 1px solid #ddd;
  background-size: cover;
}

.profile-icon span img {
  width: 30px;
  margin-top: -5px;
}

.status {
  display: inline-block;
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 8px;
  transform: translateY(-1px);
}

.status.all {
  background-color: #fff;
}

.status.planed {
  background-color: #0062d9;
}

.status.in_progress {
  background-color: #f0e204;
}

.status.completed {
  background-color: #6cff00;
}

.status.canceled {
  background-color: #ff0000;
}

.status.holding {
  background-color: #ffb400;
}

.status.production {
  background-color: #ea00ff;
}

.status.others {
  background-color: #aaa;
}

.tbl .status {
  margin-right: 0;
}

.head .custom-select {
  border: 1px solid #aaa !important;
  border-radius: 0.25rem 0 0 0.25rem;
  border-right: 0 !important;
}

.head input {
  border: 1px solid #aaa !important;
}

.head .search-keyword {
  border-bottom: 1px solid #0366d6;
}

.head .input-group-append button {
  border: 1px solid #aaa !important;
}

.head .custom-select {
  border: 0 !important;
  background-color: #fff !important;
  padding-left: 0;
}

.head .custom-select .btn-light {
  border: 0 !important;
  background-color: #fff !important;
  padding-left: 0 !important;
  color: #0366d6;
}

.head .form-control {
  border: 0 !important;
  background-color: #fff !important;
}

.detail-view {
  overflow-y: auto;
  border-left: 1px solid #eee;
}

.detail-view h1 {
  font-size: 18px;
  font-weight: 700;
  color: #111;
}

.detail-view h2 {
  font-size: 18px;
  font-weight: 300;
  color: #111;
}

.detail-view .bt-save {
  background-color: #c6c6c6;
  color: #fff;
  width: 70px;
  border: 0;
}

.detail-view .bt-save:hover {
  background-color: #0366d6;
}

.detail-view .ql-toolbar.ql-snow,
.detail-view .ql-container.ql-snow {
  border: 1px solid #ddd;
}

.detail-view .ql-editor,
.detail-view .ql-toolbar {
  line-height: 2;
  font-size: 12px;
}

.detail-view .head {
  position: relative;
}

.detail-view .head .bt-area {
  position: absolute;
  right: 0;
}

svg.remove {
  cursor: pointer;
  opacity: 0.4;
  fill: #0366d6;
}

svg.remove:hover {
  opacity: 1;
}

svg.close {
  fill: #0366d6;
  margin-left: 10px;
}

.btn.disabled,
.btn:disabled {
  opacity: 0.2 !important;
}

.ck {
  word-break: break-all;
}

.ck.ck-heading-dropdown {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.ck.ck-toolbar {
  background-color: #fff !important;
  border-left: 1px solid #ddd !important;
  border-right: 1px solid #ddd !important;
  border-top: 1px solid #ddd !important;
  border-bottom: 1px solid #eee !important;
}

.ck.ck-toolbar svg {
  width: 15px !important;
  height: 15px !important;
}

.ck.ck-toolbar svg.ck-dropdown__arrow {
  width: 10px !important;
  height: 10px !important;
}

.ck.ck-content {
  border-left: 1px solid #ddd !important;
  border-right: 1px solid #ddd !important;
  border-bottom: 1px solid #ddd !important;
  border-top: 0 !important;
  padding: 0 15px !important;
  word-break: keep-all;
}

.ck.ck-content p {
  margin-bottom: 0;
}

.ck.ck-toolbar__separator {
  background-color: #eee !important;
}

.ck.ck-focused {
  box-shadow: none !important;
}

.ck.ck-editor__editable_inline {
  min-height: 160px;
}

.ck h1 {
  font-size: 26px !important;
  font-weight: 700;
}

.ck h2 {
  font-size: 22px !important;
  font-weight: 600;
}

.ck h3 {
  font-size: 17px !important;
  font-weight: 600;
}

.ck h4 {
  font-size: 14px !important;
  font-weight: 600;
}

.document .ck-content {
  min-height: calc(100vh - 188px) !important;
}

.alert.alert-success {
  z-index: 9999999;
  position: absolute;
  top: 13px;
  left: 35px;
  right: 35px;
}

.project-name-input {
  font-size: 18px;
  font-weight: 700;
  border-top: 0;
  border-left: 0;
  border-right: 0;
}

.project-name-input:focus {
  outline: none;
  border-bottom: 2px solid #2c6bc8;
}

.ck-editor__top {
  position: -webkit-sticky !important;
  position: sticky !important;
  top: 0;
}

.work-duration {
  position: relative;
  padding-left: 14px;
}

.work-duration::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  background-color: #55af33;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.lunch-duration {
  position: relative;
  padding-left: 14px;
}

.lunch-duration::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  background-color: #fcba40;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.tracker-line {
  z-index: 1;
  position: absolute;
  top: 23px;
  height: 6px;
  background-color: #55af33;
}

.tracker-line.lunch {
  z-index: 2;
  background-color: #fcba40;
}

.tracker-line.lunch.added {
  background-color: #d4a856;
}

.tracker-line .warning.front {
  position: absolute;
  left: 2px;
  width: 18px;
  height: 18px;
  margin-top: -19px;
}

.tracker-line .warning.back {
  position: absolute;
  right: 2px;
  width: 18px;
  height: 18px;
  margin-top: -19px;
}

.tracker-time {
  z-index: 1;
  position: absolute;
  top: 30px;
  width: 100px;
  font-size: 11px;
  font-weight: 500;
  color: #000;
}

.tracker-time.lunch {
  margin-left: 100px;
  margin-top: -23px;
  color: #aaa;
}

.tracker-time.lunch.left {
  text-align: right;
  margin-left: 0;
}

.tracker-time.right {
  text-align: right;
}

.holiday_name {
  font-weight: 600;
}

.alert-msg .warning,
.alert-msg .memo {
  margin-left: 4px;
}

.view-detail .date .red {
  display: flex;
  color: #ff0000;
  align-items: center;
}

.view-detail .date .red svg {
  margin-right: 5px;
}

.view-detail .date .detail-alert div {
  margin-bottom: 5px;
}

@media (max-width: 767.98px) {
  .vdp-datepicker__calendar {
    bottom: 30px;
  }

  .mobile-none {
    display: none;
  }
}

