@charset "UTF-8";
/* tag */
html.seal {
  overflow: hidden;
  overscroll-behavior: contain;
}

body {
  letter-spacing: -0.85px;
}
body.seal {
  overflow: hidden;
  overscroll-behavior: contain;
}

input {
  position: relative;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  input {
    font-size: 15px;
  }
}
input[type=date], input[type=time], input.date:not([type=date]), input.time:not([type=time]) {
  position: relative;
  height: 30px;
  border: none;
}
input[type=date]::-webkit-clear-button, input[type=date]::-webkit-inner-spin-button, input[type=time]::-webkit-clear-button, input[type=time]::-webkit-inner-spin-button, input.date:not([type=date])::-webkit-clear-button, input.date:not([type=date])::-webkit-inner-spin-button, input.time:not([type=time])::-webkit-clear-button, input.time:not([type=time])::-webkit-inner-spin-button {
  display: none;
}
input[type=date]::-webkit-calendar-picker-indicator, input[type=time]::-webkit-calendar-picker-indicator, input.date:not([type=date])::-webkit-calendar-picker-indicator, input.time:not([type=time])::-webkit-calendar-picker-indicator {
  cursor: pointer;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  color: transparent;
}
input[type=date]:valid::before, input[type=time]:valid::before, input.date:not([type=date]):valid::before, input.time:not([type=time]):valid::before {
  display: none;
}
div:has(> input[type=date])::before,
label:has(> input[type=date])::before,
div:has(> input[type=time])::before,
label:has(> input[type=time])::before {
  content: attr(data-placeholder);
  position: absolute;
  top: 50%;
  right: 0px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  font-family: "Pretendard", sans-serif;
  color: rgba(30, 30, 30, 0.7);
  background-color: #fff;
  box-sizing: border-box;
}

button {
  font-family: "Pretendard", sans-serif;
  font-size: 17px;
  letter-spacing: -0.85px;
}

select {
  font-family: "Pretendard", sans-serif;
  font-size: 17px;
  letter-spacing: -0.85px;
}

/* tag */
.wrap-sub {
  overflow-x: hidden;
}
.wrap-sub .logo {
  margin: 0;
  margin-bottom: 10px;
  width: auto;
}

.layout {
  position: relative;
  width: 100%;
  margin: 0 auto;
}
@media only screen and (max-width: 1495px) {
  .layout {
    width: 100%;
  }
}
.layout-outer {
  width: 1067.5px;
  min-height: 100svh;
  overflow: hidden;
}
@media only screen and (max-width: 1067.5px) {
  .layout-outer {
    width: 100%;
  }
}
.layout-inner {
  position: relative;
  width: 100%;
  padding: 0 40px;
  padding: 0 40rem;
}

.main {
  position: relative;
  background-color: #fff;
}

.tag {
  font-size: 11px;
  letter-spacing: -0.77px;
}
.tag-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 800px;
  padding: 2px 8px 3px;
}
.tag-wrap.red {
  background-color: #fbecf1;
  color: #F66572;
}
.tag-wrap.green {
  border: 1px solid #1A973C;
  color: #1A973C;
}
.tag-wrap.orange {
  border: 1px solid #FF5C00;
  color: #FF5C00;
}
.tag-wrap.skyblue {
  border: 1px solid #00AEBF;
  color: #00AEBF;
}
.tag-wrap.bg-green {
  background-color: #10B565;
  color: #fff;
}
.tag-wrap.bg-orange {
  background-color: #E46253;
  color: #fff;
}
.tag-wrap.bg-darkblue {
  background-color: #00155E;
  color: #fff;
}

.sect-link .btn-wrap {
  height: 60px;
}
@media only screen and (max-width: 767px) {
  .sect-link .btn-wrap {
    height: 46px;
  }
}

.sect-tit {
  display: none;
}
.sect-tit.active {
  display: block;
}

.tit-bottommenu {
  font-weight: 700;
  font-size: 40px;
  letter-spacing: -2.4px;
}

.info-wrap {
  display: flex;
  align-items: flex-start;
  gap: 5px;
}
.info-wrap .icon {
  flex: 0 0 15px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 15px;
  aspect-ratio: 1/1;
  margin-top: 1.5px;
}
.info-wrap .icon img {
  width: 100%;
}
.info-wrap .txt {
  font-size: 16px;
  letter-spacing: -0.8px;
}

.size-60 {
  max-width: 60px;
}
.size-90 {
  max-width: 90px;
}
.size-120 {
  max-width: 120px;
}
.size-150 {
  max-width: 150px;
}
.size-180 {
  max-width: 180px;
}
.size-210 {
  max-width: 210px;
}
.size-240 {
  max-width: 240px;
}
.size-270 {
  max-width: 270px;
}
.size-300 {
  max-width: 300px;
}
.size-330 {
  max-width: 330px;
}
.size-360 {
  max-width: 360px;
}
.size-390 {
  max-width: 390px;
}
.size-420 {
  max-width: 420px;
}
.size-450 {
  max-width: 450px;
}
.size-480 {
  max-width: 480px;
}
.size-510 {
  max-width: 510px;
}
.size-540 {
  max-width: 540px;
}
.size-570 {
  max-width: 570px;
}
.size-600 {
  max-width: 600px;
}
.size-630 {
  max-width: 630px;
}
.size-660 {
  max-width: 660px;
}
.size-690 {
  max-width: 690px;
}
.size-720 {
  max-width: 720px;
}
.size-750 {
  max-width: 750px;
}
.size-780 {
  max-width: 780px;
}
.size-810 {
  max-width: 810px;
}
.size-840 {
  max-width: 840px;
}
.size-870 {
  max-width: 870px;
}
.size-900 {
  max-width: 900px;
}
.size-930 {
  max-width: 930px;
}

.color-black {
  color: #1E1E1E;
}
.color-blackOp60 {
  color: rgba(30, 30, 30, 0.6);
}
.color-orange {
  color: #E46253;
}
.color-green {
  color: #10B565;
}

/* scss 버튼 */
.btn {
  cursor: pointer;
  font-family: "Pretendard", sans-serif;
}
.btn-wrap {
  height: 50px;
}
@media only screen and (max-width: 767px) {
  .btn-wrap {
    height: 40px;
  }
}
.btn-wrap .btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
.btn-rounding {
  border-radius: 5px;
  border: 1px solid #DDDDDD;
}
.btn-rounding:not(:has(.btn)) {
  padding: 0px 45px;
}
.btn-rounding .btn {
  padding: 0px 45px;
}
.btn-bg-black {
  border: 1px solid #1E1E1E;
  background-color: #1E1E1E;
  font-weight: 500;
  color: #fff;
}
.btn-bg-darkblue {
  border: 1px solid #00155E;
  background-color: #00155E;
  font-weight: 500;
  color: #fff;
}
.btn-bg-darkblue .btn .txt {
  color: #fff;
}
.btn-bg-white {
  font-weight: 500;
  color: #1E1E1E;
}
.btn-black {
  border: 1px solid #1E1E1E;
  background-color: #fff;
  font-weight: 500;
  color: #1E1E1E;
}
@media only screen and (max-width: 767px) {
  .btn-post {
    font-size: 15px;
  }
}
.btn-post-wrap {
  width: 100%;
  max-width: 180px;
}
@media only screen and (max-width: 767px) {
  .btn-post-wrap {
    height: 40px;
    max-width: 90px;
  }
}
.btn-post-wrap.btn-rounding {
  padding: 0;
}
.btn-post-wrap .btn-post {
  padding: 0;
}

.sect-link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 70px;
}
@media only screen and (max-width: 767px) {
  .sect-link {
    padding-top: 20px;
  }
}

/* scss 버튼 */
/* scss 탭 */
.tab {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 100%;
  height: 100%;
  font-weight: 500;
  font-size: 17px;
  color: #444;
}
@media only screen and (max-width: 767px) {
  .tab {
    font-size: 16px;
  }
}
.tab-container {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
@media only screen and (max-width: 767px) {
  .tab-container {
    justify-content: flex-start;
    gap: 5px;
    flex-wrap: wrap;
  }
}
.tab-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 50px;
  border: 1px solid #DDDDDD;
}
.tab-wrap.round {
  min-width: 100px;
  border-radius: 800px;
}
@media only screen and (max-width: 767px) {
  .tab-wrap.round {
    flex: 0 0 calc((100% - 5px * (2 - 1)) * 0.5);
    min-width: unset;
    height: 45px;
    border-radius: 7px;
    padding: 10px 20px;
  }
}
.tab-wrap.round .tab {
  border-radius: 800px;
  padding: 0 30px;
}
@media only screen and (max-width: 767px) {
  .tab-wrap.round .tab {
    border-radius: 7px;
    padding: 10px 20px;
  }
}
.tab-wrap.active {
  box-shadow: 10px 15px 30px #00155E4D;
  background-color: #00155E;
  border: unset;
}
.tab-wrap.active .tab {
  color: #fff;
}

.sect-tab:has(+ *) {
  padding-bottom: 60px;
}
@media only screen and (max-width: 767px) {
  .sect-tab:has(+ *) {
    padding-bottom: 40px;
  }
}

/* scss 탭 */
/* scss 게시판 */
.board {
  display: grid;
  grid-template-columns: 1fr;
  font-size: 17px;
  color: #666666;
  transition: all 0.3s;
}
@media only screen and (max-width: 767px) {
  .board {
    font-size: 14px;
    letter-spacing: -0.75px;
  }
}
.board[data-type=list][data-list-type=normal] .board-card {
  min-height: 66px;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list][data-list-type=normal] .board-card {
    min-height: 50px;
  }
}
.board[data-type=list][data-list-type=normal] .board-card.head {
  min-height: 66px;
  font-weight: 700;
  color: #1E1E1E;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list][data-list-type=normal] .board-card.head {
    min-height: 50px;
  }
}
.board[data-type=list][data-list-type=normal] .board-col {
  gap: 5px;
}
.board[data-type=list][data-list-type=normal] .board-col[data-col-idx=num] .img-wrap.notice {
  display: block;
  height: 22px;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list][data-list-type=normal] .board-col[data-col-idx=num] .img-wrap.notice {
    height: 16px;
  }
}
.board[data-type=list][data-list-type=normal] .board-col[data-col-idx=num] .img-wrap.notice img {
  height: 100%;
}
.board[data-type=list][data-list-type=normal] .board-col:not([data-col-idx=tit]) {
  flex: 0.078125 0.078125 70px;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list][data-list-type=normal] .board-col:not([data-col-idx=tit]) {
    flex: 0.0651890482 0.0651890482 30px;
  }
}
.board[data-type=list][data-list-type=normal] .board-col .img-wrap {
  display: flex;
}
.board[data-type=list][data-list-type=lefthead] dt.board-col {
  flex: 0.05 0.05 120px;
  position: relative;
  padding-left: 14px;
  color: rgba(30, 30, 30, 0.5);
}
.board[data-type=list][data-list-type=lefthead] dt.board-col::before {
  content: "";
  position: absolute;
  left: 0%;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #8E8E8E;
}
.board[data-type=list][data-list-type=lefthead] .board-card {
  min-height: 60px;
  padding: 5px 20px;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list][data-list-type=lefthead] .board-card {
    min-height: 46px;
  }
}
.board[data-type=list][data-list-type=lefthead] .board-col {
  justify-content: flex-start;
}
.board[data-type=list][data-list-type=lefthead] .board-col .img-wrap {
  display: flex;
}
.board[data-type=list][data-list-type=lefthead] .board-cols {
  font-weight: 500;
  color: #1E1E1E;
}
.board[data-type=list] .board-card {
  border-bottom: 1px solid #ddd;
  padding: 5px 0;
}
.board[data-type=list] .board-card.head {
  min-height: 30px;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list] .board-card.head {
    display: none;
  }
}
.board[data-type=list] .board-card.head .board-col[data-col-idx=tit] {
  justify-content: center;
}
.board[data-type=list] .board-card[data-idx=empty] {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 20px;
  height: auto;
  padding: 100px 30px;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list] .board-card[data-idx=empty] {
    gap: 10px;
    padding: 30px 10px;
  }
}
.board[data-type=list] .board-card[data-idx=empty] .txt {
  font-size: 16px;
  letter-spacing: -0.64px;
  color: rgba(30, 30, 30, 0.3);
}
@media only screen and (max-width: 767px) {
  .board[data-type=list] .board-card[data-idx=empty] .txt {
    font-size: 13px;
  }
}
.board[data-type=list] .board-col {
  flex: 1;
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.board[data-type=list] .board-col[data-col-idx=tit] {
  justify-content: flex-start;
}
.board[data-type=list] .board-col[data-col-idx=tit] .col-plate {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.board[data-type=list] .board-col[data-col-idx=tit] .info-list {
  display: flex;
  align-items: center;
  gap: 20px;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0;
}
@media only screen and (max-width: 767px) {
  .board[data-type=list] .board-col[data-col-idx=tit] .info-list {
    font-size: 13px;
  }
}
.board[data-type=list] .board-col[data-col-idx=tit] .info-list dt {
  color: rgba(30, 30, 30, 0.4);
}
.board[data-type=list] .board-col[data-col-idx=tit] .info-list dd {
  color: rgba(30, 30, 30, 0.7);
}
.board[data-type=list] .board-cols {
  display: flex;
  gap: 5px;
  height: 100%;
}
.board[data-type=grid] {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.board[data-type=grid][data-grid-type=normal] .board-card {
  border: 2px solid #ddd;
  padding: 15px 10px;
}
.board[data-type=grid][data-grid-type=normal] .board-col[data-col-idx=num] {
  display: none;
}
.board[data-type=grid][data-grid-type=normal] .board-col[data-col-idx=thumbnail] {
  aspect-ratio: 300/240;
  overflow: hidden;
}
.board[data-type=grid][data-grid-type=normal] .board-col[data-col-idx=thumbnail] img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: block;
  object-fit: cover;
  min-width: 360px;
  min-height: 288px;
  height: 100%;
}
.board[data-type=grid][data-grid-type=normal] .board-col[data-col-idx=tit] {
  margin-top: 10px;
  margin-bottom: 6px;
}
.board[data-type=grid] .board-card.head {
  display: none;
}
.board-wrap {
  position: relative;
}
.board-wrap:has(.board[data-type=list]) {
  border-top: 1px solid #1E1E1E;
}
.board-card {
  min-width: 0;
  transition: all 0.3s;
}
.board-col {
  position: relative;
  transition: all 0.3s;
}
.board-col[data-col-idx=tit] {
  color: #1E1E1E;
  overflow: hidden;
}
.board-col[data-col-idx=tit] p {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.board-col > img {
  width: 100%;
}
.board-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 0;
}
.board-total {
  font-size: 16px;
  color: rgba(30, 30, 30, 0.7);
  letter-spacing: 0;
}
@media only screen and (max-width: 767px) {
  .board-total {
    font-size: 13px;
  }
}
.board-total-num {
  font-weight: 700;
  color: #00155E;
}
.board-controller {
  display: flex;
  align-items: center;
  gap: 8px;
}
.board-controller .icon {
  font-size: 18px;
}

/* scss 게시판 */
/* scss 폼 */
input {
  font-weight: 500;
}

input.date:not([type=date]),
input[type=date],
input.time:not([type=time]),
input[type=time] {
  width: 100%;
  height: 48px;
  border-radius: 5px;
  outline: 1px solid transparent;
  padding: 0 15px;
  font-size: 17px;
}
@media only screen and (max-width: 767px) {
  input.date:not([type=date]),
  input[type=date],
input.time:not([type=time]),
input[type=time] {
    height: 38px;
    font-size: 13px;
    padding: 0px 10px;
  }
}
@supports (-webkit-touch-callout: none) {
  input.date:not([type=date]),
  input[type=date],
input.time:not([type=time]),
input[type=time] {
    background-color: unset;
    -webkit-padding-start: 10px;
    padding-left: 10px;
  }
}
input.date:not([type=date])::before,
input[type=date]::before,
input.time:not([type=time])::before,
input[type=time]::before {
  content: unset;
}
input.date:not([type=date])::after,
input[type=date]::after,
input.time:not([type=time])::after,
input[type=time]::after {
  content: unset;
}

input.date:not([type=date])::before,
input.time:not([type=time])::before {
  display: none;
}

input[type=date]:not([type=date])::-webkit-date-and-time-value,
input[type=time]:not([type=time])::-webkit-date-and-time-value {
  text-align: left;
  padding: 0;
  }
input[type=date]:not([type=date])::-webkit-datetime-edit-text, input[type=date]:not([type=date])::-webkit-datetime-edit-year-field, input[type=date]:not([type=date])::-webkit-datetime-edit-month-field, input[type=date]:not([type=date])::-webkit-datetime-edit-day-field,
input[type=time]:not([type=time])::-webkit-datetime-edit-text,
input[type=time]:not([type=time])::-webkit-datetime-edit-year-field,
input[type=time]:not([type=time])::-webkit-datetime-edit-month-field,
input[type=time]:not([type=time])::-webkit-datetime-edit-day-field {
  color: #1E1E1E;
}

.date-wrap, .time-wrap {
  position: relative;
  width: 100%;
    border: 1px solid #ddd;
    background-color: #fff;
    border-radius: 5px;
  margin: 0;
  padding: 0;
}
.date-wrap:not([class*=size-]), .time-wrap:not([class*=size-]) {
  max-width: calc((100% - 10px * 2 - 16px) *0.5);
}
  .date-wrap::after, .time-wrap::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0px;
    transform: translateY(-50%);
    width: 20px;
    height: 100%;
    z-index: 0;
    border-left: 1px solid rgba(30, 30, 30, 0.7);
    pointer-events: none;
    border-radius: 0 5px 5px 0;
    border-left: 1px solid #ddd;
    padding: 0 16px;
  }
  @media only screen and (max-width: 767px) {
    .date-wrap::after, .time-wrap::after {
      padding: 0 10px;
    }
  }
  @media only screen and (max-width: 425px) {
    .date-wrap::after, .time-wrap::after {
      padding: 0 5px;
    }
  }
.date-wrap:has(> input[type=date]:disabled), .date-wrap:has(> input.date:disabled) {
  background-color: #F9F9F9;
}
.date-wrap:has(> input[type=date]:disabled)::before, .date-wrap:has(> input.date:disabled)::before {
  display: none;
}
.date-wrap:has(> input[type=date]:disabled)::after, .date-wrap:has(> input.date:disabled)::after {
  background: #F9F9F9 url("/images/user/icon_calendar_black.svg") no-repeat center center/20px auto;
}
.date-wrap:has(> input[type=date])::before {
    content: attr(data-placeholder);
    position: absolute;
    top: 50%;
    right: 0px;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    width: 100%;
    height: 100%;
    border-radius: 5px;
    background-color: #fff;
    font-family: "Pretendard", sans-serif;
    color: rgba(30, 30, 30, 0.7);
    box-sizing: border-box;
    font-weight: 500;
  font-size: 17px;
    padding: 15px 17px 17px;
  }
  @media only screen and (max-width: 767px) {
  .date-wrap:has(> input[type=date])::before {
      padding: 0 10px;
    }
  }
.date-wrap:has(> input[type=date])::after, .date-wrap:has(> input.date:not([type=date]))::after {
  background: #fff url("/images/user/icon_calendar_black.svg") no-repeat center center/20px auto;
}

.time-wrap:has(> input[type=time]:disabled), .time-wrap:has(> input.time:disabled) {
  background-color: #F9F9F9;
}
.time-wrap:has(> input[type=time]:disabled)::before, .time-wrap:has(> input.time:disabled)::before {
  display: none;
}
.time-wrap:has(> input[type=time]:disabled)::after, .time-wrap:has(> input.time:disabled)::after {
  background: #F9F9F9 url("/images/user/icon_clock_black.svg") no-repeat center center/20px auto;
}
.time-wrap:has(> input[type=time])::before {
  content: attr(data-placeholder);
  position: absolute;
  top: 50%;
  right: 0px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  background-color: #fff;
  font-family: "Pretendard", sans-serif;
  color: rgba(30, 30, 30, 0.7);
  box-sizing: border-box;
  font-weight: 500;
  padding: 15px 17px 17px;
}
@media only screen and (max-width: 767px) {
  .time-wrap:has(> input[type=time])::before {
    padding: 0 10px;
  }
}
.time-wrap:has(> input[type=time])::after, .time-wrap:has(> input.time:not([type=date]))::after {
  background: #fff url("/images/user/icon_clock_black.svg") no-repeat center center/20px auto;
}

.radio {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: none;
  background: transparent;
}
.radio:checked + .radio-icon {
  border: 1px solid #10B565;
}
.radio:checked + .radio-icon::before {
  background-color: #10B565;
}
.radio-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.radio-wrap input[type=radio] {
  display: none;
}
.radio-icon {
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid #ccc;
  background-color: #fff;
  padding: 8px;
}
@media only screen and (max-width: 767px) {
  .radio-icon {
    width: 19px;
    height: 19px;
    padding: 3px;
  }
}
.radio-icon::before {
  content: "";
  position: relative;
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 50%;
  background-color: transparent;
}
.radio-txt {
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .radio-txt {
    font-size: 15px;
  }
}

.check {
  width: 0;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: none;
  background: transparent;
}
.check:checked + .check-icon {
  border: 1px solid #10B565;
}
.check:checked + .check-icon::before {
  background: url("/images/user/icon_check_green.svg") no-repeat center;
  background-size: cover;
}
.check-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.check-wrap input[type=checkbox] {
  display: none;
}
.check-icon {
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid #ccc;
  background-color: #fff;
  padding: 6px;
}
@media only screen and (max-width: 767px) {
  .check-icon {
    width: 19px;
    min-width: 19px;
    height: 19px;
    padding: 3px;
  }
}
.check-icon::before {
  content: "";
  position: relative;
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 50%;
  background: url("/images/user/icon_check_gray.svg") no-repeat center;
  background-size: cover;
}
.check-txt {
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .check-txt {
    font-size: 15px;
  }
}

.typing {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: none;
  background: transparent;
  width: 100%;
  height: 100%;
  outline: unset;
}
.typing-wrap {
  position: relative;
  width: 100%;
  padding: 15px 17px 17px;
}
@media only screen and (max-width: 767px) {
  .typing-wrap {
    padding: 0px 10px;
  }
}
.typing-wrap:has(.typing) {
  padding: 0;
}
.typing-wrap:has(.typing) .typing {
  width: 100%;
  height: 100%;
  padding: 15px 17px 17px;
}
@media only screen and (max-width: 767px) {
  .typing-wrap:has(.typing) .typing {
    padding: 0px 10px;
  }
}
.typing-wrap:has(.typing:focus), .typing-wrap:has(.select:open) {
  border: 1px solid #1E1E1E;
}
.typing-wrap:has(.typing:disabled) {
  background-color: rgba(30, 30, 30, 0.05);
}
.typing-wrap:has(> input:disabled), .typing-wrap:has(select:disabled) {
  background-color: rgba(30, 30, 30, 0.05);
}
.typing-wrap:has(> input:disabled) input, .typing-wrap:has(> input:disabled) select, .typing-wrap:has(select:disabled) input, .typing-wrap:has(select:disabled) select {
  background-color: transparent;
}
.typing-wrap:has(select:not(:has(option))) {
  background-color: rgba(30, 30, 30, 0.05);
}
.typing-wrap:has(select:not(:has(option))) input, .typing-wrap:has(select:not(:has(option))) select {
  background-color: transparent;
}
.typing-box {
  display: flex;
  width: 100%;
  height: 50px;
  border-radius: 5px;
  border: 1px solid #E5E5E5;
  background-color: #FFFFFF;
}
.typing-box:has(textarea) {
  height: auto;
  min-height: 300px;
}
@media only screen and (max-width: 767px) {
  .typing-box {
    height: 40px;
  }
}

.select {
  cursor: pointer;
  position: relative;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: none;
  background: transparent;
  width: 100%;
  padding: 0 15px;
  outline: unset;
  font-size: 17px;
}
@media only screen and (max-width: 767px) {
  .select {
    font-size: 14px;
    padding: 0 10px;
  }
}
.select-wrap {
  position: relative;
  display: flex;
  width: 100%;
}
.select-wrap:has(.select:open)::after {
  transform: translateY(-50%) rotate(180deg);
}
.select-wrap:has(+ *) {
  max-width: 95px;
}
@media only screen and (max-width: 767px) {
  .select-wrap:has(+ *) {
    max-width: 75px;
  }
}
.select-wrap::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 12px;
  height: 100%;
  background: url("/images/user/icon_arrow_bottom_black.svg") no-repeat center;
  transition: transform 0.3s;
  pointer-events: none;
}
@media only screen and (max-width: 767px) {
  .select-wrap::after {
    width: 10px;
    right: 12px;
  }
}
.select-wrap + .typing-wrap::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 1px;
  height: 100%;
  background-color: #DDDDDD;
}

.sect-cate.date .detail-cate-plate {
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .sect-cate.date .date-wrap {
    width: 100%;
    max-width: 100%;
  }
}
.sect-cate.date .date-wrap + .img-wrap {
  width: 16px;
}
@media only screen and (max-width: 767px) {
  .sect-cate.date .date-wrap + .img-wrap {
    width: 12px;
  }
}
@media only screen and (max-width: 767px) {
  .sect-cate.date .time-wrap:has(+ .img-wrap) {
    max-width: calc((100% - 12px - 10px * 2) * 0.5);
  }
}
@media only screen and (max-width: 767px) {
  .sect-cate.date .time-wrap:has(+ .img-wrap) ~ .time-wrap {
    max-width: calc((100% - 12px - 10px * 2) * 0.5);
  }
}
.sect-cate.date .time-wrap + .img-wrap {
  width: 16px;
}
@media only screen and (max-width: 767px) {
  .sect-cate.date .time-wrap + .img-wrap {
    width: 12px;
  }
}
.sect-cate.date img {
  width: 100%;
}

.detail-plate {
  display: flex;
  flex-direction: column;
  gap: 11px;
  flex-wrap: wrap;
  padding: 30px 40px;
}
@media only screen and (max-width: 767px) {
  .detail-plate {
    padding: 15px;
    padding: 15px 0;
  }
}
.detail-cate-plate {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
}
.detail-cate-plate:has(.radio-wrap) {
  gap: 20px;
  flex-wrap: wrap;
}
.detail-cate-plate:has(.info-wrap) {
  gap: 20px;
  flex-wrap: wrap;
}
.detail-cate-box .txt {
  font-weight: 500;
  color: #1E1E1E;
}
.detail-cate-box .txt .point {
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -1.1px;
  color: #10B565;
}
.detail-cate-name {
  display: flex;
  align-items: center;
  gap: 5px;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: -0.8px;
  color: rgba(0, 0, 0, 0.502);
}
@media only screen and (max-width: 767px) {
  .detail-cate-name {
    font-size: 13px;
    letter-spacing: -0.65px;
  }
}
.detail-cate-cont {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .detail-cate-cont:has(.info-wrap) {
    flex-wrap: wrap;
    gap: 5px;
  }
}
@media only screen and (max-width: 767px) {
  .detail-cate-cont:has(.info-wrap) .detail-cate-plate {
    flex: 0 0 100%;
  }
}

/* scss 폼 */
/* scss 달력 */
.calendar {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
@media only screen and (max-width: 767px) {
  .calendar {
    grid-template-columns: repeat(1, 1fr);
  }
}
.calendar:has(+ .calendar-legend) {
  padding-bottom: 20px;
}
@media only screen and (max-width: 767px) {
  .calendar:has(+ .calendar-legend) {
    padding-bottom: 15px;
  }
}
.calendar-top {
  padding-bottom: 24px;
}
@media only screen and (max-width: 767px) {
  .calendar-top {
    padding-bottom: 15px;
  }
}
.calendar-top-date {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 22.5px;
}
.calendar-top-date .date-plate {
  font-family: "Ibarra Real Nova", sans-serif;
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0;
  color: #1E1E1E;
  line-height: 37.5px;
}
@media only screen and (max-width: 767px) {
  .calendar-top-date .date-plate {
    font-size: 22px;
  }
}
.calendar-bottom .tel-plate {
  display: flex;
  align-items: center;
  border-radius: 800px;
  border: 1px solid #00155E;
  background-color: #F9F9F9;
  padding: 8px 20px;
  font-weight: 500;
}
@media only screen and (max-width: 767px) {
  .calendar-bottom .tel-plate {
    font-size: 14px;
    letter-spacing: -0.7px;
  }
}
.calendar-bottom .tel-plate dl {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
}
.calendar-bottom .tel-plate dt {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  list-style: 1.2;
}
.calendar-bottom .tel-plate dt .icon {
  display: flex;
  justify-content: center;
  align-items: center;
}
.calendar-bottom .tel-plate a {
  font-weight: 500;
}
@media only screen and (max-width: 767px) {
  .calendar-bottom .tel-plate a {
    font-size: 14px;
    letter-spacing: -0.7px;
  }
}
.calendar-bottom-container {
  display: flex;
  padding-top: 20px;
}
@media only screen and (max-width: 767px) {
  .calendar-bottom-container {
    padding-top: 15px;
  }
}
.calendar-head {
  position: relative;
  padding: 20px 10px;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0;
  color: #000;
}
@media only screen and (max-width: 767px) {
  .calendar-head {
    display: none;
  }
}
.calendar-head::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  display: block;
  width: calc(100% - 20px);
  height: 1px;
  background-color: #000;
}
.calendar-box {
  position: relative;
  min-width: 0;
  min-height: 155px;
  border: 1px solid #E3E3E3;
  padding: 12px;
}
@media only screen and (max-width: 767px) {
  .calendar-box {
    display: flex;
    gap: 20px;
    min-height: 85px;
    padding: 10px;
    border: unset;
    border-bottom: 1px solid #dddddd;
  }
}
.calendar-box:nth-child(n+15) {
  border-top: unset;
}
.calendar-box:not(:nth-child(7n)) {
  border-right: unset;
}
.calendar-box.today::before {
  content: "Today";
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;
  height: 25px;
  background-color: #00155E;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  font-family: "Ibarra Real Nova", serif;
}
@media only screen and (max-width: 767px) {
  .calendar-box.today::before {
    display: none;
  }
}
.calendar-box.today-head {
  display: none;
}
@media only screen and (max-width: 767px) {
  .calendar-box.today-head {
    display: flex;
    border-top: 1px solid #222;
    border-bottom: 1px solid #222;
  }
}
@media only screen and (max-width: 767px) {
  .calendar-box.box-before, .calendar-box.box-after {
    display: none;
  }
}
.calendar-date {
  font-family: "Ibarra Real Nova", serif;
  font-size: 18px;
  color: #444;
}
.calendar-date-wrap {
  position: relative;
}
@media only screen and (max-width: 767px) {
  .calendar-date-wrap {
    flex: 0 0 70px;
    display: flex;
    justify-content: center;
    flex-direction: column;
  }
  .calendar-date-wrap::before {
    content: "";
    position: absolute;
    right: 0px;
    top: 0px;
    width: 1px;
    height: 100%;
    background-color: #dddddd;
  }
}
.calendar-day {
  display: none;
  font-family: "Ibarra Real Nova", serif;
}
@media only screen and (max-width: 767px) {
  .calendar-day {
    display: flex;
    font-size: 13px;
    color: rgba(30, 30, 30, 0.3);
  }
}
.calendar-event {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 5px;
  min-width: 0;
  font-size: 17px;
}
.calendar-event:not(.btn) .txt {
  font-weight: 500;
}
.calendar-event .icon {
  position: relative;
  width: 20px;
  min-width: 20px;
  height: 20px;
}
.calendar-event .icon img {
  width: 100%;
  height: 100%;
}
.calendar-event .txt {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: break-all;
}
@media only screen and (max-width: 1340px) {
  .calendar-event .txt {
    white-space: unset;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}
@media only screen and (max-width: 767px) {
  .calendar-event .txt {
    font-size: 15px;
    line-height: 20px;
  }
}
.calendar-event .tag-wrap {
  margin-top: 3px;
}
.calendar-events {
  display: flex;
  flex-direction: column;
  gap: 9px;
  min-width: 0;
  margin-top: 10px;
}
@media only screen and (max-width: 767px) {
  .calendar-events {
    justify-content: center;
    gap: 12px;
    margin-top: unset;
  }
}
.calendar-legend {
  display: flex;
  justify-content: flex-end;
  gap: 20px;
}
@media only screen and (max-width: 767px) {
  .calendar-legend {
    font-size: 15px;
  }
}
.calendar-legend-box {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}

/* scss 달력 */
/* 모달 공통 */
.modal {
  position: relative;
  background: transparent;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  pointer-events: all;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 99;
}
.modal.close {
  opacity: 0;
}
.modal .btn-close {
  position: absolute;
  right: 0;
  bottom: -40px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  width: 78px;
  aspect-ratio: 1/1;
  z-index: 99;
}
@media only screen and (max-width: 767px) {
  .modal .btn-close {
    width: 40px;
    right: 27px;
    bottom: 5px;
    bottom: -7px;
    background-color: transparent;
  }
}
@media only screen and (max-height: 425px) {
  .modal .btn-close {
    width: 50px;
  }
}
.modal .btn-close .icon {
  width: 28px;
  aspect-ratio: 1/1;
}
@media only screen and (max-width: 767px) {
  .modal .btn-close .icon {
    width: 24px;
    width: 18px;
  }
}
@media only screen and (max-height: 425px) {
  .modal .btn-close .icon {
    width: 24px;
    width: 18px;
  }
}
.modal .btn-close .icon img {
  width: 100%;
  aspect-ratio: 1/1;
}
.modal .btn-close .txt {
  display: none;
}
.modal .layout {
  flex-direction: column;
  padding-bottom: 30px;
}
.modal-wrap {
  position: fixed;
  left: 0;
  top: 0;
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  z-index: 1010;
  transition: all 0.3s;
  overflow: hidden;
}
@media only screen and (max-width: 1340px) {
  .modal-wrap {
    overflow: auto;
  }
}
.modal-wrap::before {
  content: "";
  position: fixed;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0;
  background-color: #000000B3;
  transition: all 0.3s;
  pointer-events: none;
}
.modal-wrap.move-to-up {
  left: 0;
  top: calc(var(--vh, 1vh) * 100);
  opacity: 0;
}
.modal-wrap.move-to-up.active {
  top: 0;
  opacity: 1;
}
.modal-wrap.move-to-right {
  left: -100vw;
  top: 0;
  opacity: 0;
}
.modal-wrap.move-to-right.active {
  left: 0;
  opacity: 1;
}
.modal-wrap.active::before {
  opacity: 1;
}
.modal-top {
  position: relative;
  z-index: 99;
}
.modal-controller {
  position: relative;
}
@media only screen and (max-width: 767px) {
  .modal-controller {
    margin-bottom: 10px;
  }
}
.modal-main {
  flex: 1;
  width: 100%;
  height: 0;
  position: relative;
}
.modal-bottom {
  position: relative;
}
.modal-layout {
  position: relative;
  display: flex;
  flex-direction: column;
  max-width: 1280px;
  overflow-y: auto;
  scrollbar-color: transparent transparent;
  scrollbar-width: none;
}
.modal-layout::-webkit-scrollbar {
  display: none;
}
@media only screen and (max-width: 1707.5px) {
  .modal-layout {
    max-width: 100%;
  }
}
.modal-tab {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 60px;
  padding: 4px 30px 0;
  font-size: 20px;
  line-height: 1;
  word-break: keep-all;
}
@media only screen and (max-width: 1340px) {
  .modal-tab {
    height: 48px;
    padding: 0 14px;
    font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  .modal-tab {
    height: 40px;
    padding: 0 22px;
    font-size: 16px;
    font-weight: 700;
  }
}
@media only screen and (max-width: 425px) {
  .modal-tab {
    height: 32px;
    padding: 0 14px;
    padding: 1px 16px 0 14px;
    font-weight: 700;
    font-size: 14px;
  }
}
@media only screen and (max-height: 767px) {
  .modal-tab {
    height: 40px;
    padding: 0 22px;
    font-size: 16px;
    font-weight: 700;
  }
}
@media only screen and (max-height: 767px) and (max-width: 425px) {
  .modal-tab {
    height: 32px;
    padding: 0 14px;
    padding: 1px 16px 0 14px;
    font-weight: 700;
    font-size: 14px;
  }
}
.modal-tabs {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media only screen and (max-width: 767px) {
  .modal-tabs {
    gap: 5px;
  }
}
.modal-tab-wrap {
  border-radius: 800px;
  border: 2px solid #333333;
  color: #333333;
  transition: all 0.3s;
}
.modal-tab-wrap.active {
  color: #fff;
}
.modal-tab-wrap.active .modal-tab {
  color: #fff;
}

/* //모달 공통 */
/* scss 수정 */
.modal {
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .modal {
    margin-top: 0;
  }
}
@media only screen and (max-height: 425px) {
  .modal {
    margin-top: 0;
  }
}
@media only screen and (max-width: 767px) {
  .modal .layout {
    padding: 60px 30px 0px;
    padding: 0px 20px 0px;
  }
}
.modal .popup-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(auto, 290px));
  gap: 40px;
}
@media only screen and (max-height: 1340px) {
  .modal .popup-list {
    padding: 50px 0;
  }
}
@media only screen and (max-width: 1340px) {
  .modal .popup-list {
    grid-template-columns: repeat(2, minmax(auto, 1fr));
    gap: 20px;
    padding: 120px 0;
  }
}
@media only screen and (max-width: 1340px) and (max-height: 1340px) {
  .modal .popup-list {
    padding: 50px 0;
  }
}
@media only screen and (max-width: 767px) {
  .modal .popup-list {
    padding: 50px 0;
  }
}
.modal .popup-list > li {
  width: 100%;
}
.modal .popup-img-wrap {
  width: 100%;
}
.modal .popup-img-wrap > img {
  width: 100%;
}
.modal .btn-close {
  position: relative;
  left: unset;
  top: unset;
  right: unset;
  bottom: unset;
  background-color: transparent;
  width: 78px;
  height: 78px;
  pointer-events: all;
}
.modal .btn-close .icon {
  max-width: 24px;
}
.modal .btn-hide {
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  pointer-events: all;
}
.modal .btn-hide .icon {
  width: 22px;
  aspect-ratio: 1/1;
  border: 1px solid #fff;
  border-radius: 3px;
}
.modal .btn-hide-wrap {
  padding-left: 27px;
}
.modal .btn-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  height: auto;
}
.modal-top {
  flex: 0;
  pointer-events: none;
}
.modal-main {
  display: flex;
  justify-content: center;
  align-items: center;
  height: auto;
  flex: unset;
}
.modal-popup {
  background: transparent;
  scrollbar-color: transparent transparent;
  scrollbar-width: none;
  pointer-events: none;
}
.modal-popup::-webkit-scrollbar {
  display: none;
}
.modal-popup-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100dvh;
  background-color: #0000002f;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 10010;
  overflow-y: auto;
}
@supports (-moz-appearance: none) {
  .modal-popup-wrap {
    height: calc(var(--vh, 1vh) * 100);
  }
}
.modal-popup-wrap::before {
  content: unset;
}
.modal-controller {
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
}

.swiper-popup {
  pointer-events: all;
  width: 1230px;
  max-height: calc(100dvh - 100px * 2);
}
.swiper-popup:has(swiper-slide:nth-child(2):last-child) {
  width: 829px;
}
.swiper-popup:has(swiper-slide:nth-child(1):last-child) {
  width: 414px;
}
@media only screen and (max-width: 1495px) {
  .swiper-popup {
    width: 815px;
  }
  .swiper-popup:has(swiper-slide:nth-child(1):last-child) {
    width: 414px;
  }
}
@media only screen and (max-width: 1340px) {
  .swiper-popup {
    width: 735px;
  }
  .swiper-popup:has(swiper-slide:nth-child(1):last-child) {
    width: 374px;
  }
}
@media only screen and (max-width: 767px) {
  .swiper-popup {
    width: calc(100% - 15px * 2);
  }
  .swiper-popup:has(swiper-slide:nth-child(1):last-child) {
    width: calc(100% - 15px * 2);
  }
}
.swiper-popup[data-swiper-slides-count="1"] {
  width: 360px;
  max-height: calc(100dvh - 100px * 2);
}
@media only screen and (max-width: 1495px) {
  .swiper-popup[data-swiper-slides-count="1"] {
    width: 400px;
  }
}
@media only screen and (max-width: 1340px) {
  .swiper-popup[data-swiper-slides-count="1"] {
    width: 360px;
  }
}
@media only screen and (max-width: 425px) {
  .swiper-popup[data-swiper-slides-count="1"] {
    width: calc(100% - 15px * 2);
  }
}
.swiper-popup[data-swiper-slides-count="2"] {
  width: 735px;
  max-height: calc(100dvh - 100px * 2);
}
.swiper-popup[data-swiper-slides-count="2"]:has(swiper-slide:nth-child(1):last-child) {
  width: 374px;
}
@media only screen and (max-width: 1495px) {
  .swiper-popup[data-swiper-slides-count="2"] {
    width: 815px;
  }
  .swiper-popup[data-swiper-slides-count="2"]:has(swiper-slide:nth-child(1):last-child) {
    width: 414px;
  }
}
@media only screen and (max-width: 1340px) {
  .swiper-popup[data-swiper-slides-count="2"] {
    width: 735px;
  }
  .swiper-popup[data-swiper-slides-count="2"]:has(swiper-slide:nth-child(1):last-child) {
    width: 374px;
  }
}
@media only screen and (max-width: 767px) {
  .swiper-popup[data-swiper-slides-count="2"] {
    width: calc(100% - 15px * 2);
  }
  .swiper-popup[data-swiper-slides-count="2"]:has(swiper-slide:nth-child(1):last-child) {
    width: calc(100% - 15px * 2);
  }
}
.swiper-popup::part(button-prev) {
  width: var(--swiper-navigation-size);
  background: url("/assets/images/common/btn-arrow-tail-swiper-prev-gray.svg") no-repeat center;
  color: transparent;
  left: -60px;
}
.swiper-popup::part(button-next) {
  width: var(--swiper-navigation-size);
  background: url("/assets/images/common/btn-arrow-tail-swiper-next-black.svg") no-repeat center;
  color: transparent;
  right: -60px;
}
.swiper-popup swiper-slide {
  width: auto;
}

.swiper-popup-img {
  width: 100%;
}
.swiper-popup-img img {
  width: 100%;
}
.swiper-popup-pagination {
  --swiper-pagination-bottom: -30px;
}
.swiper-popup-controller {
  width: 1390px;
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
  top: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  justify-content: space-between;
  min-height: 100px;
  z-index: 1;
}
.swiper-popup-controller:has(swiper-slide:nth-child(2):last-child) {
  width: 989px;
}
.swiper-popup-controller:has(swiper-slide:nth-child(1):last-child) {
  width: 574px;
}
@media only screen and (max-width: 1495px) {
  .swiper-popup-controller {
    width: 975px;
  }
  .swiper-popup-controller:has(swiper-slide:nth-child(1):last-child) {
    width: 554px;
  }
}
@media only screen and (max-width: 1340px) {
  .swiper-popup-controller {
    width: 815px;
  }
  .swiper-popup-controller:has(swiper-slide:nth-child(1):last-child) {
    width: 494px;
  }
}
@media only screen and (max-width: 920.4px) {
  .swiper-popup-controller {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .swiper-popup-controller {
    width: calc(100% - 15px * 2 + 60 * 2);
  }
  .swiper-popup-controller:has(swiper-slide:nth-child(1):last-child) {
    width: calc(100% - 15px * 2);
  }
}
.swiper-pagination {
  pointer-events: none;
}
.swiper-pagination-bullet {
  width: 18px;
  width: 8px;
  pointer-events: all;
}
.swiper-pagination-bullet-active {
  background-color: #fff;
  --swiper-pagination-color: #fff;
}
.swiper-btn-prev, .swiper-btn-next {
  --swiper-navigation-sides-offset: 0px;
  position: relative;
  background: url("/images/user/icon-swiper-arrow-right-white.svg") no-repeat center;
  background-size: contain;
  pointer-events: all;
}
.swiper-btn-prev::after, .swiper-btn-next::after {
  display: none;
}
.swiper-btn-prev {
  transform: scale(-1);
}
.swiper-btn-prev.swiper-button-prev {
  position: relative;
  left: unset;
  top: unset;
}

.sect-place:has(+ *) {
  margin-bottom: 54px;
}
@media only screen and (max-width: 767px) {
  .sect-place:has(+ *) {
    margin-bottom: 30px;
  }
}
.sect-board {
  padding-top: 60px;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .sect-board {
    padding-top: 46px;
  }
}
.sect-board.hide {
  height: 0;
  padding: 0;
  margin: 0;
}
.sect-link {
  overflow: hidden;
}
.sect-link.hide {
  height: 0;
  padding: 0;
  margin: 0;
}

.place.radio-wrap {
  gap: 10px;
}
@media only screen and (max-width: 767px) {
  .place.radio-wrap {
    gap: 8px;
    justify-content: flex-start;
    align-items: flex-start;
  }
}
.place.radio-wrap .radio:checked + .radio-icon {
  width: 12px;
  height: 9px;
  border-radius: unset;
  border: 0px solid transparent;
  background: transparent;
}
.place.radio-wrap .radio:checked + .radio-icon::before {
  opacity: 0;
}
.place.radio-wrap .radio:checked + .radio-icon::after {
  opacity: 1;
}
.place.radio-wrap .radio:checked ~ .radio-txt {
  color: #1e1e1e;
  line-height: 1.2;
}
.place.radio-wrap .radio-icon {
  width: 4px;
  min-width: 4px;
  height: 4px;
  min-height: 4px;
  border: unset;
  border: 0px solid transparent;
  background: transparent;
  padding: 0;
  transition: width 0.3s, height 0.3s;
}
@media only screen and (max-width: 767px) {
  .place.radio-wrap .radio-icon {
    margin-top: 5px;
  }
}
.place.radio-wrap .radio-icon::before {
  width: 4px;
  min-width: 4px;
  height: 4px;
  min-height: 4px;
  border-radius: 50%;
  background-color: #767676;
  opacity: 1;
  transition: opacity 0.3s;
}
.place.radio-wrap .radio-icon::after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 12px;
  height: 9px;
  background: url("/images/user/icon_check_green.svg") no-repeat center bottom 3px/10px auto;
  background-size: cover;
  opacity: 0;
  transition: opacity 0.3s;
}
.place.radio-wrap .radio-txt {
  font-weight: 500;
  color: rgba(30, 30, 30, 0.6);
  transition: color 0.3s;
}
.places {
  display: flex;
  align-items: center;
  gap: 10px 30px;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .places {
    gap: 10px 15px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 10px;
    align-items: flex-start;
  }
}
.place-container {
  position: relative;
  display: block;
  border-radius: 20px;
  background-color: #F9F9F9;
  padding: 40px;
}
@media only screen and (max-width: 767px) {
  .place-container {
    padding: 30px;
  }
}

@media only screen and (max-width: 767px) {
.calendar {
  border-top: 1px solid #ddd;
}
}
@media only screen and (max-width: 767px) {
  .calendar-top {
    padding-bottom: 25px;
  }
}

/* scss 수정 */


/* css 수정 */
/* css 수정 */