@charset "UTF-8";
/* ======================================================= */
/********** text color **********/
.color-black {
  color: var(--black) !important;
}

.color-white {
  color: var(--white) !important;
}

.color-red {
  color: var(--red) !important;
}

.color-dark-red {
  color: var(--dark-red) !important;
}

.color-green {
  color: var(--green) !important;
}

.color-dark-green {
  color: var(--dark-green) !important;
}

.color-blue {
  color: var(--blue) !important;
}

.color-dark-blue {
  color: var(--dark-blue) !important;
}

.color-yellow {
  color: var(--yellow) !important;
}

.color-dark-yellow {
  color: var(--dark-yellow) !important;
}

.color-orange {
  color: var(--orange) !important;
}

.color-dark-orange {
  color: var(--dark-orange) !important;
}

.color-purple {
  color: var(--purple) !important;
}

.color-dark-purple {
  color: var(--dark-purple) !important;
}

.color-aqua {
  color: var(--aqua) !important;
}

.color-dark-aqua {
  color: var(--dark-aqua) !important;
}

.color-gray {
  color: var(--gray) !important;
}

.color-dark-gray {
  color: var(--dark-gray) !important;
}

/********** text color end **********/
/* ======================================================= */
/********** background color **********/
.background-color-black {
  background-color: var(--black) !important;
}

.background-color-white {
  background-color: var(--white) !important;
}

.background-color-red {
  background-color: var(--red) !important;
}

.background-color-dark-red {
  background-color: var(--dark-red) !important;
}

.background-color-green {
  background-color: var(--green) !important;
}

.background-color-dark-green {
  background-color: var(--dark-green) !important;
}

.background-color-blue {
  background-color: var(--blue) !important;
}

.background-color-dark-blue {
  background-color: var(--dark-blue) !important;
}

.background-color-yellow {
  background-color: var(--yellow) !important;
}

.background-color-dark-yellow {
  background-color: var(--dark-yellow) !important;
}

.background-color-orange {
  background-color: var(--orange) !important;
}

.background-color-dark-orange {
  background-color: var(--dark-orange) !important;
}

.background-color-purple {
  background-color: var(--purple) !important;
}

.background-color-dark-purple {
  background-color: var(--dark-purple) !important;
}

.background-color-aqua {
  background-color: var(--aqua) !important;
}

.background-color-dark-aqua {
  background-color: var(--dark-aqua) !important;
}

.background-color-gray {
  background-color: var(--gray) !important;
}

.background-color-dark-gray {
  background-color: var(--dark-gray) !important;
}

/********** background color end **********/
/* ======================================================= */
/********** border color **********/
.border-color-black {
  border-color: var(--black) !important;
}

.border-color-white {
  border-color: var(--white) !important;
}

.border-color-red {
  border-color: var(--red) !important;
}

.border-color-dark-red {
  border-color: var(--dark-red) !important;
}

.border-color-green {
  border-color: var(--green) !important;
}

.border-color-dark-green {
  border-color: var(--dark-green) !important;
}

.border-color-blue {
  border-color: var(--blue) !important;
}

.border-color-dark-blue {
  border-color: var(--dark-blue) !important;
}

.border-color-yellow {
  border-color: var(--yellow) !important;
}

.border-color-dark-yellow {
  border-color: var(--dark-yellow) !important;
}

.border-color-orange {
  border-color: var(--orange) !important;
}

.border-color-dark-orange {
  border-color: var(--dark-orange) !important;
}

.border-color-purple {
  border-color: var(--purple) !important;
}

.border-color-dark-purple {
  border-color: var(--dark-purple) !important;
}

.border-color-aqua {
  border-color: var(--aqua) !important;
}

.border-color-dark-aqua {
  border-color: var(--dark-aqua) !important;
}

.border-color-gray {
  border-color: var(--gray) !important;
}

.border-color-dark-gray {
  border-color: var(--dark-gray) !important;
}

/********** border color end **********/
/* ======================================================= */
/********** radius **********/
/********** 0 2 4 6 10 12 16 20 24 28 32 64 100(%) - circle **********/
.radius-0 {
  border-radius: 0px !important;
}

.radius-2 {
  border-radius: 2px !important;
}

.radius-4 {
  border-radius: 4px !important;
}

.radius-6 {
  border-radius: 6px !important;
}

.radius-8 {
  border-radius: 8px !important;
}

.radius-10 {
  border-radius: 10px !important;
}

.radius-12 {
  border-radius: 12px !important;
}

.radius-16 {
  border-radius: 16px !important;
}

.radius-20 {
  border-radius: 20px !important;
}

.radius-24 {
  border-radius: 24px !important;
}

.radius-28 {
  border-radius: 28px !important;
}

.radius-32 {
  border-radius: 32px !important;
}

.radius-64 {
  border-radius: 64px !important;
}

.radius-100,
.radius-circle {
  border-radius: 100% !important;
}

/********** radius **********/
/* ======================================================= */
*,
*:after,
*:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-family: 'Open Sans', 'Noto Sans KR', sans-serif;
  color: var(--text-color);
}

a {
  text-decoration: none;
  cursor: pointer;
  color: var(--text-color);
}

a:focus {
  outline: none;
}

li {
  list-style: none;
}

ol:after,
ul:after {
  content: '';
  display: block;
  clear: both;
}

iframe,
img {
  display: block;
}

img {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

input,
textarea {
  color: var(--text-color);
  font-family: 'Open Sans', 'Noto Sans KR', sans-serif;
}

button {
	all: unset;
	cursor: pointer;
	box-sizing: border-box;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  font-family: 'Open Sans', 'Noto Sans KR', sans-serif;
  border-radius: 0;
  cursor: pointer;
  color: var(--text-color);
}

select:focus {
  background-image: url("../images/arrow_down.png");
}

select::-ms-expand {
  display: none !important;
}

/* input */
input[type="text"],
input[type="password"],
input[type="time"],
input[type="date"],
input[type="email"],
input[type="search"],
input[type="image"],
input[type="tel"],
textarea {
  -webkit-appearance: none;
  -webkit-tap-highlight-color: transparent;
  border-radius: 0;
  background-color: var(--box-color);
}

input[type="color"] {
  border: none !important;
  padding: 0 !important;
}

/* input range */
input[type=range] {
  width: 100%;
}

input[type=range] {
  -webkit-appearance: none;
}

input[type=range]:focus {
  outline: none;
}

input[type=range]::-webkit-slider-runnable-track {
  width: 100%;
  height: 4px;
  cursor: pointer;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  background-color: #eee;
}

input[type=range]::-webkit-slider-thumb {
  width: 14px;
  height: 14px;
  border-radius: 100%;
  cursor: pointer;
  -webkit-appearance: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  background: var(--main-color);
  /* chrome의 경우 */
  margin-top: -5px;
}

input[type=range]::-webkit-slider-thumb:hover,
input[type=range]::-webkit-slider-thumb:focus {
  -webkit-filter: saturate(80%);
          filter: saturate(80%);
}

input[type=range]:focus::-webkit-slider-runnable-track {
  background: #ddd;
}

.selectbox {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: var(--box-color);
  display: inline-block;
  text-align: left;
  position: relative;
  cursor: pointer;
  border-radius: 6px;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--border-color);
}

.selectbox p {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-align: left;
  padding: 8px 44px 8px 16px;
  font-size: 15px;
  color: var(--text-color);
  min-height: 40px;
}

.selectbox p::after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-size: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 16px;
  -webkit-transition: -webkit-transform .35s;
  transition: -webkit-transform .35s;
  transition: transform .35s;
  transition: transform .35s, -webkit-transform .35s;
}

.selectbox .option {
  width: 100%;
  background-color: var(--box-color);
  border-radius: 6px;
  padding: 8px 0px;
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--border-color);
  display: block;
  z-index: -99;
  pointer-events: none;
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: opacity .35s, -webkit-transform .35s;
  transition: opacity .35s, -webkit-transform .35s;
  transition: opacity .35s, transform .35s;
  transition: opacity .35s, transform .35s, -webkit-transform .35s;
  overflow-y: auto;
  max-height: 173px;
}

.selectbox .option a {
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-align: left;
  padding: 6px 16px;
  font-size: 14px;
  color: var(--text-light-color);
  word-break: break-all;
  text-decoration: none !important;
  display: none;
}

.selectbox .option a:hover {
  color: var(--text-color);
}

.selectbox .option a.selected {
  color: var(--main-color) !important;
  font-weight: 500;
}

.selectbox:focus, .selectbox:hover {
  outline: none;
  border-color: var(--main-color);
}

.selectbox:focus p, .selectbox:hover p {
  color: var(--main-color);
}

.selectbox.active {
  border-color: var(--main-color);
}

.selectbox.active p {
  color: var(--main-color);
}

.selectbox.active p::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.selectbox.active .option {
  z-index: 99;
  pointer-events: auto;
  opacity: 1;
  -webkit-transform: translateY(0px);
          transform: translateY(0px);
}

.selectbox.active .option a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.modal .selectbox.active .option {
  z-index: 9999;
}

.selectbox_button {
  padding: 0 !important;
  min-height: auto !important;
}

.selectbox_button > a {
  width: 100%;
  padding: 8px 16px;
  min-height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 8px;
}

.selectbox_button .option {
  width: 100%;
  background-color: var(--box-color);
  border-radius: 6px;
  padding: 8px 0px;
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--border-color);
  display: block;
  z-index: -99;
  pointer-events: none;
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: opacity .35s, -webkit-transform .35s;
  transition: opacity .35s, -webkit-transform .35s;
  transition: opacity .35s, transform .35s;
  transition: opacity .35s, transform .35s, -webkit-transform .35s;
}

.selectbox_button .option a {
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  text-align: left;
  padding: 6px 16px;
  font-size: 14px;
  color: var(--text-light-color) !important;
  word-break: break-all;
  display: none;
}

.selectbox_button .option a span {
  font-size: 14px;
  color: var(--text-light-color);
}

.selectbox_button .option a:hover * {
  color: var(--text-color);
}

.selectbox_button.active {
  border-color: var(--main-color) !important;
}

.selectbox_button.active > a {
  color: var(--main-color) !important;
}

.selectbox_button.active > a * {
  color: var(--main-color) !important;
}

.selectbox_button.active .option {
  z-index: 99;
  pointer-events: auto;
  opacity: 1;
  -webkit-transform: translateY(0px);
          transform: translateY(0px);
}

.selectbox_button.active .option a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.selectbox_button:focus, .selectbox_button:hover {
  outline: none;
  border-color: var(--main-color);
}

.option img.icon {
  width: 24px;
}

.option i {
  color: var(--text-light-color);
}

.datebox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px 16px;
  position: relative;
}

.inputbox {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: var(--box-color);
  display: inline-block;
  text-align: left;
  position: relative;
  border-radius: 6px;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
  cursor: pointer;
  z-index: 98;
}

.inputbox::after {
  content: attr(data-value);
  position: absolute;
  right: 6px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-size: 15px;
  background-color: var(--box-color);
  padding: 0px 10px;
}

.inputbox:hover input {
  border-color: var(--main-color);
}

.inputbox input {
  width: 100%;
  font-size: 15px;
  border: none;
  background: none;
  padding: 8px 16px;
  min-height: 40px;
  border: 1px solid var(--border-color);
  border-radius: 6px;
}

.inputbox input:focus {
  outline: none;
  border-color: var(--main-color);
}

.inputbox.button_inputbox input {
  padding-right: 48px;
}

.inputbox.button_inputbox > a {
  height: calc(100% - 2px);
  position: absolute;
  right: 1px;
  top: 1px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  padding: 0 16px;
  background-color: var(--box-color);
  border-radius: 100%;
}

.inputbox.button_inputbox > a i {
  font-size: 16px;
  font-weight: 400;
}

.inputbox.button_inputbox:focus-within i, .inputbox.button_inputbox:hover i {
  color: var(--main-color);
}

/* radiobox */
.radiobox_area {
  width: 100%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}

.radiobox_area .radiobox input[type="radio"] {
  display: none;
}

.radiobox_area .radiobox input[type="radio"]:checked ~ label {
  color: var(--text-color) !important;
}

.radiobox_area .radiobox input[type="radio"]:checked ~ label::before {
  border-color: var(--main-color) !important;
}

.radiobox_area .radiobox input[type="radio"]:checked ~ label::after {
  opacity: 1 !important;
  -webkit-transform: scale(1) !important;
          transform: scale(1) !important;
}

.radiobox_area .radiobox label {
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
  font-size: 15px;
  font-weight: 400 !important;
  position: relative !important;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center !important;
      -ms-flex-align: center !important;
          align-items: center !important;
  cursor: pointer !important;
  color: var(--text-light-color) !important;
  -webkit-transition: all .35s;
  transition: all .35s;
  min-height: 24px !important;
}

.radiobox_area .radiobox label:hover {
  color: var(--text-color) !important;
}

.radiobox_area .radiobox label::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-color: #fff;
  border: 1px solid var(--border-color);
  margin-right: 6px;
  -webkit-transition: all .35s;
  transition: all .35s;
  border-radius: 100%;
}

.radiobox_area .radiobox label::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background: var(--main-color);
  border-radius: 100%;
  position: absolute;
  left: 4px;
  opacity: 0;
  -webkit-transform: scale(0);
          transform: scale(0);
  -webkit-transition: all .35s;
  transition: all .35s;
}

/* checkbox */
.checkbox.circle label::before {
  border-radius: 100%;
}

.checkbox input[type="checkbox"] {
  display: none;
}

.checkbox input[type="checkbox"]:checked ~ label {
  color: #8080c0 !important;
}

.checkbox input[type="checkbox"]:checked ~ label::before {
  background: var(--main-color);
  border-color: var(--main-color);
}

.checkbox input[type="checkbox"]:checked ~ label::after {
  opacity: 1;
}

.checkbox label {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.6rem;
  font-weight: 500;
  position: relative;
  cursor: pointer;
  color: var(--text-light-color);
  -webkit-transition: all .2s;
  transition: all .2s;
  /*
        &.large {
            font-size: 2.2rem;
            font-weight: 600;

            &::before {
                min-width: 16px;
                min-height: 16px;
            }

            &::after {
                left: 8px;
                top: 10px;
                width: 6px;
                height: 12px;
            }
        }
        */
}

.checkbox label:hover {
  color: #8080c0;
}

.checkbox label::before {
  content: "";
  display: inline-block;
  min-width: 16px;
  min-height: 16px;
  background: #fff;
  border: 1px solid #d8d8d8;
  -webkit-transition: all .2s;
  transition: all .2s;
  -webkit-transform: translateY(2px);
          transform: translateY(2px);
}

.checkbox label::after {
  content: "";
  display: inline-block;
  position: absolute;
  left: 6px;
  top: 3px;
  width: 5px;
  height: 9px;
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all .2s;
  transition: all .2s;
  opacity: 0;
}

.select {
  width: 100%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.select:after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  position: absolute;
  right: 0;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 400;
  pointer-events: none;
  background-color: transparent;
}

.select select {
  height: var(--size);
  font-weight: 400;
  cursor: pointer;
  border-color: var(--border-color);
  background-color: #fff;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  background: none !important;
  color: var(--text-color);
}

.select select option {
  background-color: var(--box-color);
}

.select select::-ms-expand {
  display: none !important;
}

.select:hover::after {
  color: var(--main-color);
}

.select:hover select {
  color: var(--main-color) !important;
  border-color: var(--main-color);
  outline: none;
}

.select:focus-within::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  color: var(--main-color);
}

.select:focus-within select {
  color: var(--main-color) !important;
  border-color: var(--main-color);
  outline: none;
}

.select:focus-within select option {
  color: var(--text-color);
}

.necessary {
  color: var(--red);
  margin-right: 2px;
  font-size: 15px !important;
  font-weight: 400 !important;
}
