@charset "UTF-8";
.search-result .swiper-button-prev, .search-result .swiper-button-next {
  z-index: 3;
  opacity: 1;
  margin-top: calc(var(--swiper-navigation-size) * -1 - 1rem);
  padding: 0;
  border: 0;
  width: var(--swiper-navigation-size);
  height: var(--swiper-navigation-size);
  background-color: transparent;
  background-position: center;
  background-repeat: no-repeat;
  background-size: auto var(--swiper-navigation-size);
  overflow: hidden;
  font-size: 0;
  text-indent: -999px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.faq-list .question .category {
  justify-content: center;
  align-items: center;
  width: auto;
}

.login-form .login-button > *, .search-result .more-contents > *, .search-result .swiper-controls span {
  position: relative;
  z-index: 1;
  border-width: 0;
  border-style: solid;
  border-color: transparent;
}

.login-form .login-button > *:before, .login-form .login-button > *:after, .search-result .more-contents > *:before, .search-result .more-contents > *:after, .search-result .swiper-controls span:before, .search-result .swiper-controls span:after {
  content: "";
  position: absolute;
  top: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}

.search-result .swiper-controls span:first-of-type {
  margin-left: 0;
}

.search-result .swiper-controls span:last-of-type {
  margin-right: 0;
}

/*** SUB COMMON
========================================== ***/
.sub-header {
  --container-padding-x: 20px;
  position: sticky;
  top: var(--header-height);
  z-index: 4;
  padding-inline: var(--section-padding-x);
  border-bottom: 1px solid #dcdcdc;
  width: 100%;
  height: 54px;
  background-color: #FFFFFF;
  transition: all 0.2s ease-in-out;
}
.sub-header .inner {
  margin: 0 auto;
  padding-block: 12px;
  padding-inline: var(--container-padding-x);
  max-width: calc(var(--contents-width) + var(--container-padding-x) * 2);
  display: flex;
  justify-content: space-between;
  --gap: 4px;
  gap: var(--gap);
}
.sub-header .breadcrumb {
  align-items: center;
  min-height: 20px;
}
.sub-header .breadcrumb > *:first-child {
  width: 16px;
  height: 16px;
  overflow: hidden;
  font-size: 0;
  text-indent: -9999px;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 16px;
  background-image: url(/thearts/images/common/ico_home.png);
}
.sub-header .breadcrumb > *:not(:first-child, .num) {
  padding-left: var(--icon-size);
  background-position: 0 50%;
}

.breadcrumb {
  --icon-size: 20px;
  position: relative;
  display: flex;
  align-items: flex-start;
}
.breadcrumb > * {
  display: inline-block;
  line-height: var(--icon-size) !important;
  vertical-align: middle;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.03em;
}
.breadcrumb > *:not(:first-child, .num) {
  padding-left: calc(var(--icon-size) + 16px);
  background-position: 8px 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_arrow_drop_right.png);
}
.breadcrumb > *:not(:first-child, .num):before {
  content: "";
  width: var(--icon-size);
  height: var(--icon-size);
}
.breadcrumb > *:last-child {
  color: #066fef;
  font-weight: 700;
}
.breadcrumb > *.num {
  margin-top: -3px;
  margin-left: 4px;
  font-family: "Anonymous Pro", "Pretendard";
  color: #0C121A;
  /* Date font */
  font-size: 12px;
  font-weight: 400;
  line-height: 1.25em;
  vertical-align: 5px;
}

.head-user {
  --icon-size: 16px;
  display: flex;
  --gap: 8px;
  gap: var(--gap);
}
.head-user .name {
  display: inline-block;
  padding-left: calc(var(--icon-size) + 8px);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  line-height: 20px;
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_head_user.png);
}
.head-user .name span {
  vertical-align: 0;
}
.head-user .login-button {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  line-height: 20px;
}
.head-user .login-button:where(:hover, :focus) {
  color: #066fef;
}

.sub-title {
  display: flex;
}
.sub-title h1 {
  word-wrap: break-word;
  word-break: break-all;
}
.sub-title .desc {
  text-align: center;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.sub-title .line-noti,
.sub-title .toggle-info-wrap {
  margin-bottom: 0;
  width: 100%;
}
.sub-title.line-bottom {
  border-bottom: 1px solid #000;
}

.sub-title:not(.type-2, .type-3) {
  align-items: center;
  gap: 32px;
  border-bottom: 1px solid #000;
}
.sub-title:not(.type-2, .type-3) h1, .sub-title:not(.type-2, .type-3) .h1 {
  font-size: 40px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.sub-title:not(.type-2, .type-3):not(.center) {
  min-height: 160px;
}
.sub-title:not(.type-2, .type-3).center {
  justify-content: center;
  min-height: 160px;
}
.sub-title:not(.type-2, .type-3):has(.desc) {
  gap: 16px;
}
.sub-title:not(.type-2, .type-3):has(.desc) h1 {
  width: 50%;
}
.sub-title:not(.type-2, .type-3):has(.desc) .desc {
  display: flex;
  align-items: flex-end;
  width: 50%;
  min-height: 55px;
}
.sub-title:not(.type-2, .type-3):has(.desc) .desc:empty {
  display: none;
}

.sub-title.type-2 {
  gap: 28px;
  margin-top: 92px;
  padding-block: 40px 0;
  border-top: 1px solid #000;
  min-height: 160px;
}
.sub-title.type-2 > .category {
  flex-shrink: 0;
  width: 308px;
  font-size: 40px;
  line-height: 1.25em;
  color: #DCDCDC;
  letter-spacing: -0.03em;
  font-weight: 800;
}
.sub-title.type-2 .title {
  flex-grow: 1;
}
.sub-title.type-2 .title .category {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  line-height: 1.25em;
  color: #066fef;
  font-weight: 700;
}
.sub-title.type-2 h1, .sub-title.type-2 .h1 {
  font-size: 40px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.sub-title.type-2 .date {
  margin-top: 8px;
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}

.sub-title.type-3 {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 28px;
  padding-block: 20px;
  min-height: 240px;
}
.sub-title.type-3 > .category {
  flex-shrink: 0;
  width: 308px;
  font-size: 40px;
  line-height: 1.25em;
  color: #DCDCDC;
  letter-spacing: -0.03em;
  font-weight: 800;
}
.sub-title.type-3 .title {
  flex-grow: 1;
}
.sub-title.type-3 .title .category {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  line-height: 1.25em;
  color: #066fef;
  font-weight: 700;
}
.sub-title.type-3 h1, .sub-title.type-3 .h1 {
  font-size: 40px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.sub-title.type-3 .total-search-wrap {
  width: 100%;
  min-height: 0;
}

.sub-cont {
  position: relative;
  padding-block: 16px 120px;
}

.sub-title.sr-only ~ .sub-cont {
  margin-top: 40px;
}

/*** SUB 
========================================== ***/
/* 소개 */
.about {
  position: relative;
}
.about .img {
  position: relative;
}
.about .cont-wrap {
  row-gap: 12px !important;
  padding-block: 0;
  min-height: 60vh;
  display: flex;
  flex-wrap: wrap;
  --gap: 40px;
  gap: var(--gap);
}
.about .cont-wrap .side-area {
  flex-shrink: 0;
  padding-top: 32px;
  border-top: 1px solid #dcdcdc;
  width: 308px;
}
.about .cont-wrap .leading-area {
  flex-grow: 1;
  width: calc(100% - 308px - 40px);
}
.about .cont-wrap .leading-area h3 {
  margin-bottom: 24px;
  font-style: normal;
  font-size: 24px;
  font-weight: 700;
  line-height: 125%; /* 30px */
  letter-spacing: -0.24px;
}
.about .cont-wrap dl ~ dl {
  margin-top: 24px;
}
.about .cont-wrap dl dt {
  display: block;
  margin-bottom: 12px;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.about .cont-wrap dl dd {
  display: block;
  margin-bottom: 24px;
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.about .cont-wrap dl .download-file {
  display: block;
}

.masonry {
  width: 100%;
  overflow: hidden;
}

.masonry-grid {
  position: relative;
  margin-inline: -10px;
  width: calc(100% + 20px);
}
.masonry-grid .m-item {
  position: absolute;
  width: 33%;
}
.masonry-grid .m-item img {
  width: 100%;
}

.about-platform {
  --spacing: 54px;
  padding-top: 32px;
}
.about-platform .head {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  margin-bottom: 64px;
  text-align: center;
}
.about-platform .box {
  position: relative;
  flex-grow: 1;
  font-size: 14px;
  line-height: 1.25em;
  color: inherit;
}
.about-platform .box .title {
  margin-bottom: 8px;
  font-size: 16px;
  line-height: 1.25em;
  color: inherit;
}
.about-platform .box:nth-child(1) {
  width: 30%;
}
.about-platform .box:nth-child(2) {
  order: -2;
  padding-bottom: var(--spacing);
  width: 100%;
}
.about-platform .box:nth-child(3) {
  order: -1;
  padding-right: var(--spacing);
  width: 33.3%;
  height: 100%;
}
.about-platform .box:nth-child(4) {
  padding-left: var(--spacing);
  width: 33.3%;
  height: 100%;
}
.about-platform .box:nth-child(5) {
  padding-top: var(--spacing);
  width: 100%;
}
.about-platform .box:not(:nth-child(1)):before {
  content: "";
  position: absolute;
  width: 40px;
  height: 40px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
}
.about-platform .box:nth-child(3):before, .about-platform .box:nth-child(4):before {
  background-image: url(/thearts/images/sub/thearts_arw_hor.svg);
}
.about-platform .box:nth-child(2):before, .about-platform .box:nth-child(5):before {
  background-image: url(/thearts/images/sub/thearts_arw_ver.svg);
}
.about-platform .box:nth-child(2):before {
  left: calc(50% - 20px);
  bottom: 0;
}
.about-platform .box:nth-child(3):before {
  top: calc(50% - 20px);
  right: 0;
}
.about-platform .box:nth-child(4):before {
  top: calc(50% - 20px);
  left: 0;
}
.about-platform .box:nth-child(5):before {
  top: 0;
  left: calc(50% - 20px);
}
.about-platform .box .bullet-list {
  display: inline-block;
}
.about-platform .box .bullet-list li ~ li {
  margin-top: 0;
}
.about-platform .arts-logo img {
  width: 226px;
}
.about-platform .description-1 {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 24px 16px;
  border: 1px solid #F4F4F4;
  border-radius: 4px;
  background-color: #f8f8f8;
}
.about-platform .description-2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  padding: 40px 16px;
  border: 1px solid #F4F4F4;
  border-radius: 200px;
  max-width: 380px;
  height: 100%;
  min-height: 420px;
  background: linear-gradient(108deg, #FFE4E4 0%, #FFF6E0 100%), #f8f8f8;
}
.about-platform .description-3 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-right: auto;
  padding: 40px 16px;
  border: 1px solid #F4F4F4;
  border-radius: 200px;
  max-width: 380px;
  height: 100%;
  min-height: 420px;
  background: linear-gradient(106deg, #FFE4E4 1.61%, #E0FFED 100%), #f8f8f8;
}
.about-platform .description-4 {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 16px;
  border: 1px solid #F4F4F4;
  border-radius: 4px;
  background: #f8f8f8;
}
.about-platform .description-4 .flexy-row {
  justify-content: center;
  gap: 36px;
  width: 100%;
}
.about-platform .description-4 .flexy-col {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 20px;
  border: 1px solid #F4F4F4;
  border-radius: 4px;
  min-width: 130px;
  background: #FFFFFF;
}
.about-platform .description-4 .flexy-col:not(:nth-child(1)):before {
  content: "";
  position: absolute;
  top: calc(50% - 8px);
  left: -28px;
  display: inline-block;
  width: 16px;
  height: 16px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 16px;
  background-image: url(/thearts/images/sub/thearts_ico_plus.svg);
}

.teaser-link-img {
  max-height: 84px;
}

/*** BOARD 
========================================== ***/
.board-wrap.type-2 .leading-area {
  order: -1;
}

body:has(.side-nav) .sub-cont {
  padding-block: 0;
}
body:has(.side-nav) .side-area {
  border-right: 1px solid #dcdcdc;
}
body:has(.side-nav) .leading-area {
  padding-block: 16px 120px;
}
body:has(.side-nav) .footer {
  border-top: 1px solid #dcdcdc;
}

.side-nav {
  --icon-size: 24px;
  position: relative;
}
.side-nav > ul {
  margin-top: -1px;
  display: flex;
  flex-direction: column;
}
.side-nav > ul > li {
  opacity: 0.2;
  margin-right: -1px;
  border-block: 1px solid transparent;
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.side-nav > ul > li > a {
  padding-block: 16px;
  padding-right: var(--icon-size);
  padding-left: calc(var(--icon-size) + 12px);
  min-height: 48px;
  display: flex;
  align-items: center;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: var(--icon-size);
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.side-nav > ul > li:nth-child(1) {
  border-top-color: #0C121A !important;
}
.side-nav > ul > li:nth-child(1) > a {
  background-image: url(/thearts/images/sub/ico_sidenav_userInfo.png);
}
.side-nav > ul > li:nth-child(2) > a {
  background-image: url(/thearts/images/sub/ico_sidenav_supportProgram.png);
}
.side-nav > ul > li:nth-child(3) > a {
  background-image: url(/thearts/images/sub/ico_sidenav_inquiry.png);
}
.side-nav > ul > li.is-active {
  opacity: 1;
  background-color: #fff;
  border-block-color: #dcdcdc;
}
.side-nav > ul > li.is-active ul {
  display: block;
}
.side-nav > ul ul {
  display: none;
}
.side-nav > ul ul > li {
  border-top: 1px solid #F4F4F4;
  border-top: 1px solid #F4F4F4;
  background-position: calc(var(--icon-size) + 8px) 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_sidenav_on.png);
}
.side-nav > ul ul > li > a {
  padding-block: 16px;
  padding-left: calc(var(--icon-size) + 32px);
  min-height: 48px;
  display: flex;
  align-items: center;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: var(--icon-size);
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.side-nav > ul ul > li.is-active {
  background-color: #F4F4F4;
}
.side-nav .badge {
  margin-left: 5px;
  padding-inline: 5px;
  border-radius: 3px;
  font-weight: 700;
  line-height: 16px;
}
.side-nav .badge.gr {
  border-color: #D5DBE1 !important;
  background-color: #EBEEF1 !important;
  color: #6A7384 !important;
}
.side-nav .badge.yg {
  border-color: #D7F7C2 !important;
  background-color: #ECFED7 !important;
  color: #228403 !important;
}

.side-nav.is-open ul {
  visibility: inherit;
  opacity: 1;
}

.mobile-side-nav-toggle {
  display: none;
  padding-block: 16px;
  padding-right: var(--icon-size);
  padding-left: 12px;
  width: 100%;
  min-height: 48px;
  border-block: 1px solid #dcdcdc;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: var(--icon-size);
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_sidenav_toggle.png);
}

.side-pic {
  margin-inline: auto;
  max-width: 360px;
}
.side-pic.thumb {
  width: 100%;
}
.side-pic.thumb:not([class*=ratio-]) {
  aspect-ratio: 1;
}
.side-pic.thumb:not([class*=ratio-]) img {
  aspect-ratio: inherit;
}

.search-input {
  --icon-size: 16px;
  position: relative;
  z-index: 2;
  padding-inline: calc(24px + var(--icon-size)) 16px;
  border: 1px solid #DCDCDC;
  border-radius: 4px;
  height: 40px;
  background-color: transparent;
  font: inherit;
  transition: all 0.2s ease-in-out;
  background-position: 16px 50%;
  background-repeat: no-repeat;
  background-size: 16px;
  background-image: url(/thearts/images/common/ico_search.png);
  font-size: 16px;
  line-height: 1em;
  color: #0C121A;
  font-weight: 600;
}
.search-input.full {
  width: 100%;
}
.board-wrap > .search-input {
  width: 100%;
}
.search-input:disabled:disabled {
  background-color: #F4F4F4;
  user-select: none;
  pointer-events: none;
}
.search-input:disabled:disabled::placeholder {
  color: #DCDCDC;
}
.search-input:hover:hover {
  box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.1);
}
.search-input:hover:hover::placeholder {
  color: #B1B1B1;
}
.search-input:focus:focus {
  border-color: #000;
  box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.1);
  outline: 0;
  filter: drop-shadow(0px 0px 0px 2px rgba(0, 0, 0, 0.1));
}
.search-input:focus:focus::placeholder {
  color: #B1B1B1;
}

.sub-tabs + .list-top {
  margin-top: 16px;
}

.list-top {
  position: relative;
  width: 100%;
}
.list-top:not(.type-2) {
  padding-top: 32px;
  padding-bottom: 16px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  --gap: 24px;
  gap: var(--gap);
}
.list-top:not(.type-2) .search-input {
  max-width: 340px;
}
.list-top.type-2 {
  padding-bottom: 16px;
}
.list-top.type-2 .search-input {
  width: 100%;
}
.list-top.type-2 .sub-tabs {
  margin-top: 16px;
}

.list-info {
  padding-block: 12px;
}
.list-info p {
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}

.board-list {
  --icon-size: 20px;
}
.board-list ul {
  position: relative;
}
.board-list ul li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
}
.board-list ul li a {
  padding-right: calc(12px + var(--icon-size) + 10px);
  text-decoration: none;
  background-position: calc(100% - 10px) 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_arrow_right.png);
  display: flex;
  flex-wrap: wrap;
  --gap: 6px;
  gap: var(--gap);
}
.board-list ul li a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.board-list ul li .fix {
  --icon-size: 12px;
  display: inline-block;
  margin-right: 8px;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  background-color: #0C121A;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_fixed_noti.png);
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
}
.board-list ul li .new {
  display: inline-block;
  margin-right: 8px;
  padding-inline: 8px;
  border-radius: 2px;
  height: 20px;
  background-color: #066fef;
  text-align: center;
  font-size: 12px;
  line-height: 1.25em;
  color: #FFFFFF;
  line-height: 20px;
}
.board-list ul li .title {
  width: 100%;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  white-space: nowrap;
}
.board-list ul li .info {
  display: flex;
  align-items: center;
}
.board-list ul li .info span {
  position: relative;
  display: inline-block;
  padding-inline: 12px;
}
.board-list ul li .info span:first-child {
  padding-left: 0;
}
.board-list ul li .info span:not(:first-child):before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
  width: 1px;
  height: 8px;
  background-color: rgba(0, 0, 0, 0.1);
}
.board-list ul li .info .name {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.board-list ul li .info .type {
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.board-list ul li .info .date {
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.board-list ul li .info .hit {
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 300;
}

.contest-list {
  overflow: hidden;
}
.contest-list .item {
  padding-block: 12px;
  width: 100%;
}
.contest-list a {
  --icon-size: 20px;
  display: block;
  text-decoration: none;
  background-position: 100% 0;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_external_link.png);
}
.contest-list a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.contest-list .badges {
  margin-bottom: 16px;
}
.contest-list .title {
  max-height: 5.25em;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  white-space: nowrap;
}
.contest-list .date {
  margin-block: 4px;
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.contest-list .info {
  padding-bottom: 12px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  flex-wrap: wrap;
}
.contest-list .info span {
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
}
.contest-list .info span:not(:last-child):after {
  content: "";
  display: inline-block;
  margin-inline: 8px;
  width: 1px;
  height: 8px;
  background-color: #B1B1B1;
}
.contest-list .hit {
  display: block;
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 300;
}
.contest-list .info .hit {
  margin-top: 0;
  margin-left: auto;
}

.gallery-list a {
  text-decoration: none;
}
.gallery-list a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.gallery-list .badge {
  border-color: rgba(12, 18, 26, 0.8);
  min-width: 40px;
  background-color: rgba(12, 18, 26, 0.8);
  color: #FFFFFF;
  backdrop-filter: blur(2px);
}
.gallery-list .badges {
  position: absolute;
  top: 4px;
  left: 0;
  z-index: 2;
  padding-inline: 4px;
}
.gallery-list .title {
  margin-block: 16px 8px;
  max-height: 2.5em;
  max-height: 3em;
  line-height: 1.5em;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  word-break: break-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.gallery-list p ~ p {
  margin-top: 4px;
}
.gallery-list .thumb {
  width: 100%;
}
.gallery-list .desc {
  max-height: 3em;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  word-break: break-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.gallery-list .date {
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.gallery-list .date-2 {
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  letter-spacing: 1px;
  font-weight: 500;
}
.gallery-list .team {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
}
.gallery-list .info {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}
.gallery-list .info span {
  position: relative;
  display: inline-block;
}
.gallery-list .info span:not(:last-child) {
  padding-right: 16px;
}
.gallery-list .info span:not(:last-child):after {
  content: "";
  position: absolute;
  top: 5px;
  right: 8px;
  width: 1px;
  height: 7px;
  background: #dcdcdc;
}
.gallery-list .info:has(strong) {
  gap: 4px;
}
.gallery-list .hit {
  display: block;
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 300;
}
.gallery-list .info .hit {
  margin-top: 0;
  margin-left: auto;
}
.gallery-list ul {
  row-gap: 32px !important;
  padding-bottom: 32px;
  --num: 4;
  --gap: 16px;
  flex-wrap: wrap;
  gap: var(--gap);
  display: flex;
}
.gallery-list ul > * {
  width: calc(100% / var(--num) - (var(--gap) - var(--gap) * 1 / var(--num)));
}
.gallery-list ul li {
  position: relative;
}
.gallery-list .swiper-wrapper {
  height: auto;
}
.gallery-list.col-5 ul {
  --num: 5;
}
.gallery-list.col-6 ul {
  --num: 6;
}

.faq-list ul {
  display: flex;
  flex-direction: column;
}
.faq-list ul li {
  border-left: 1px solid transparent;
}
.faq-list ul li ~ li {
  border-top: 1px solid #dcdcdc;
}
.faq-list ul li p {
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 400;
}
.faq-list ul li p ~ p {
  margin-top: 8px;
}
.faq-list .question {
  --icon-size: 20px;
  position: relative;
  padding-block: 24px;
  padding-inline: 24px calc(36px + var(--icon-size) * 2);
  border-bottom: 1px solid transparent;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  background-position: calc(100% - 24px - var(--icon-size) / 2) 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_arrow_down_sm.png);
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.faq-list .question:active {
  background-color: #f9f9f9;
}
.faq-list .question .category {
  margin-bottom: 12px;
  height: 28px;
  display: inline-flex;
  padding-block: 2px;
  padding-inline: 16px;
  border: 0.5px solid #F4F4F4;
  border-radius: 32px;
  background-color: #F4F4F4;
  min-height: 20px;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}
.faq-list .answer {
  --icon-size: 16px;
  display: none;
  padding: 24px;
  border-radius: 0 0 0.5rem 0.5rem;
  font-size: 1rem;
  line-height: 1.875em;
}
.faq-list .answer .title {
  display: block;
  margin-bottom: 12px;
  padding-left: calc(8px + var(--icon-size));
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_answer.png);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}
.faq-list li.is-open {
  border-left-color: #0C121A;
  background-color: #F8F8F8;
}
.faq-list li.is-open .question {
  transition: border-color 0.3s 0.1s;
  background-image: url(/thearts/images/sub/ico_arrow_up_sm.png);
}
.faq-list li.is-open .answer {
  display: block;
}

.pc-genere {
    display:grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    border-radius:10px;
    border:solid 1px #E1E1E1;
}

.pc-genere li {
    border-right:solid 1px #E1E1E1;
}

.pc-genere li:first-child {
    border-radius:10px 0 0 10px;
}

.pc-genere li:last-child {
    border-right:0;
    border-radius:0 10px 10px 0;
}

.pc-genere a {
    display:block;
    width:100%;
    padding:26px 0;
    text-align:center;
}

.pc-genere a h3 {
    font-size:18px;
    font-weight:700;
}

.pc-genere a p {
    font-size:14px;
    margin-top:-8px;
}

.pc-genere li:has(a.active) {
    background-color:#0084FF;
    color:#fff;
}

.pc-genere li:has(a.disabled) {
    background-color:#F4F4F4;
    color:#B1B1B1;
}

.mo-genere {
    background-color:#0084FF;
    border-radius:8px;
    border:solid 1px #E1E1E1;
    padding:16px;
    color:#fff;
    width:100%;
    font-size:14px;
    background-image: url(/thearts/images/common/arw_select_white.svg);
    display:none;
}

/* 선택 리스트 화면 (옵션) */
.mo-genere option {
  background-color: white;   /* 흰 바탕 */
  color: black;              /* 검은 글자 */
}

.list-top:has(ul.order) {
    flex-direction:column;
}

.list-top ul.filter {
    display:flex;
    gap:16px;
    width:100%;
    margin-top:16px;
    flex-wrap:wrap;
}

.list-top ul.filter li {
    display:grid;
    grid-template-columns:auto 140px;
    align-items:center;
    column-gap:32px;
    font-size:18px;
    font-weight:700;
    margin-left:32px;
}

.list-top ul.filter select {
    position: relative;
    z-index: 2;
    border: 1px solid #DCDCDC;
    border-radius: 4px;
    height: 40px;
    background-color: #fff;
    font: inherit;
    transition: all 0.2s ease-in-out;
    font-size: 16px;
    line-height: 1em;
    color: #0C121A;
    font-weight: 600;
    padding:0 16px;
    width:100%;
    max-width:140px;
}

.list-top ul.order  {
    display:flex;
    gap:8px;
    margin-left:auto;
}

.list-top ul.order a {
    font-size:18px;
}

.list-top ul.order a.active {
    text-decoration:underline;
    font-weight:700;
}

.output-list {
  overflow: hidden;
}

.output-list ul {
  display: flex;
  flex-direction: column;
}
.output-list ul li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
}

.output-list-half ul {
  display: grid;
  grid-template-columns:repeat(auto-fit, minmax(min(550px,100%), 1fr));
  gap:16px;
}
.output-list-half ul li {
  flex: 1 1;
  border-radius:10px;
  border:solid 1px #000;
  padding:24px 24px 20px 24px
}
.output-list .item {
  --icon-size: 20px;
  padding-right: var(--icon-size);
  width: 100%;
  background-position: 100% 8px;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_external_link.png);
}
.output-list a {
  display: block;
  text-decoration: none;
}
.output-list a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.output-list .badge.plus {
  display: inline-flex !important;
}
.output-list .badges {
  margin-bottom: 12px;
}
.output-list .fix {
  --icon-size: 20px;
  display: inline-block;
  margin-right: 8px;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  background-color: #FFFFFF;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_fixed.png);
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
}
.output-list .title {
  width: 100%;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  white-space: nowrap;
}
.output-list .date {
  margin-block: 4px;
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.output-list .info {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
}
.output-list .info span {
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
}
.output-list .info span:not(:last-child):after {
  content: "";
  display: inline-block;
  margin-inline: 8px;
  width: 1px;
  height: 8px;
  background-color: #B1B1B1;
}

.breadcrumb-list {
  --icon-size: 20px;
}
.breadcrumb-list ul {
  display: flex;
  flex-direction: column;
}
.breadcrumb-list ul li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
}
.breadcrumb-list .item {
  --icon-size: 20px;
  row-gap: 4px;
  padding-right: var(--icon-size);
  width: 100%;
  background-position: 100% 0;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_arrow_right_sm.png);
}
.breadcrumb-list a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  text-decoration: none;
}
.breadcrumb-list .item > div:not(.badges) {
  display: inline-block;
  line-height: var(--icon-size) !important;
  vertical-align: middle;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.03em;
}
.breadcrumb-list .item > div:not(.badges):not(:first-child) {
  padding-left: calc(var(--icon-size) + 16px);
  background-position: 8px 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_arrow_drop_right.png);
}
.breadcrumb-list .item > div:not(.badges):not(:first-child):before {
  content: "";
  width: var(--icon-size);
  height: var(--icon-size);
}

/* 공모·소식 > 전시·행사·공연·교육 */
.line-calendar-wrap {
  margin-top: -1rem;
  margin-bottom: 16px;
  padding-block: 24px;
  background-color: #FAFAFA;
}
.line-calendar-wrap .month-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.line-calendar-wrap .month-container h3 {
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}
.line-calendar-wrap .month-container button[class^=month-button] {
  --icon-size: 20px;
  z-index: 3;
  opacity: 0.5;
  padding: 0;
  border: 0;
  width: var(--icon-size);
  height: var(--icon-size);
  overflow: hidden;
  font-size: 0;
  text-indent: -999px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  background-color: transparent;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.line-calendar-wrap .month-container .month-button-prev {
  order: -1;
  background-image: url(/thearts/images/sub/ico_month_prev.png);
}
.line-calendar-wrap .month-container .month-button-next {
  order: 2;
  background-image: url(/thearts/images/sub/ico_month_next.png);
}
.line-calendar-wrap .days-container {
  position: relative;
  margin-top: 1rem;
  padding-inline: 24px;
  overflow: hidden;
}
.line-calendar-wrap .days-container button[class^=swiper-button] {
  --swiper-navigation-size: 42px;
  --icon-size: 24px;
  z-index: 2;
  opacity: 1;
  margin-top: calc(var(--swiper-navigation-size) * -1 / 2);
  padding: 0;
  border: 0;
  width: calc(var(--swiper-navigation-size) * 0.67);
  overflow: hidden;
  font-size: 0;
  text-indent: -999px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  backdrop-filter: blur(2px);
  background-color: rgba(250, 250, 250, 0.6);
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.line-calendar-wrap .days-container button[class^=swiper-button]:after {
  display: none;
}
.line-calendar-wrap .days-container .days-wrap {
  position: relative;
}
.line-calendar-wrap .days-container .swiper-button-prev {
  left: 0;
  background-position: 4px 50% !important;
  mask-image: linear-gradient(270deg, transparent 0%, #000 40%);
  background-image: url(/thearts/images/sub/ico_month_prev.png);
}
.line-calendar-wrap .days-container .swiper-button-next {
  right: 0;
  background-position: calc(100% - 4px) 50% !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 40%);
  background-image: url(/thearts/images/sub/ico_month_next.png);
}
.line-calendar-wrap .days-container .swiper-button-disabled {
  visibility: hidden;
  opacity: 0 !important;
}
.line-calendar-wrap .days-container .days {
  justify-content: center;
  height: auto;
  text-align: center;
}
.line-calendar-wrap .days-container .days li {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: 0.5px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  width: auto;
  background: #FFF;
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}
.line-calendar-wrap .days-container .days li button {
  padding-inline: 10px;
  width: 100%;
  height: 40px;
}
.line-calendar-wrap .days-container .days li.current {
  background-color: #000;
  color: #FFF;
}
.line-calendar-wrap .days-container .days li.disabled {
  user-select: none;
  pointer-events: none;
}
.line-calendar-wrap .days-container .days li.disabled button {
  user-select: inherit;
  pointer-events: inherit;
}

.line-calendar-wrap .days-container button[class^=swiper-button] {
  display: none;
}
.line-calendar-wrap .days-container .days {
  --num: 15;
  --gap: 4px;
  flex-wrap: wrap;
  gap: var(--gap);
}
.line-calendar-wrap .days-container .days li {
  flex-grow: 1;
  flex-shrink: 1;
}
.line-calendar-wrap .days-container .days li:nth-child(n+1):nth-child(-n+15) {
  width: calc(100% / var(--num) - (var(--gap) - var(--gap) * 1 / var(--num)));
}

/*기관운영사이트 */
.related-site-list-1 {
  --icon-size: 16px;
  position: relative;
}
.related-site-list-1 ul {
  display: flex;
  flex-direction: column;
}
.related-site-list-1 ul li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
}
.related-site-list-1 ul li a {
  padding-right: 16px;
  display: flex;
  align-items: center;
  --gap: 12px;
  gap: var(--gap);
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_external_link_lg.png);
}
.related-site-list-1 ul li a .thumb {
  flex: none;
  border-radius: 0;
  width: 128px;
  aspect-ratio: 4;
  background-image: url(/thearts/images/common/noimg_128x32.png);
}
.related-site-list-1 ul li a .thumb img {
  border-radius: inherit;
  aspect-ratio: inherit;
}
.related-site-list-1 .title {
  flex-grow: 1;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}

.related-site-list-2 {
  --icon-size: 12px;
  position: relative;
}
.related-site-list-2 .thumb {
  border-radius: 0;
}
.related-site-list-2 .thumb img {
  display: block;
  border-radius: inherit;
  width: 100%;
  aspect-ratio: inherit;
}
.related-site-list-2 .title {
  margin-top: 16px;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}
.related-site-list-2 .external-link {
  margin-block: 4px 20px;
}
.related-site-list-2 .desc {
  font-size: 15px;
  line-height: 1.75em;
}
.related-site-list-2 ul {
  row-gap: 140px !important;
  padding-block: 32px;
  --num: 2;
  --gap: 5.2vw;
  flex-wrap: wrap;
  gap: var(--gap);
  display: flex;
  justify-content: space-between;
}
.related-site-list-2 ul > * {
  width: calc(100% / var(--num) - (var(--gap) - var(--gap) * 1 / var(--num)));
}
.related-site-list-2 ul li {
  max-width: 520px;
}
.related-site-list-2 ul li:nth-child(odd) {
  text-align: left;
}
.related-site-list-2 ul li:nth-child(odd) .thumb,
.related-site-list-2 ul li:nth-child(odd) .thumb img {
  margin-right: 0;
}
.related-site-list-2 ul li:nth-child(even) {
  padding-top: 160px;
  text-align: right;
}
.related-site-list-2 ul li:nth-child(even) .thumb,
.related-site-list-2 ul li:nth-child(even) .thumb img {
  margin-left: 0;
}
.related-site-list-2 ul li:nth-child(4n+3) {
  padding-left: 4.167vw;
}
.related-site-list-2 ul li:nth-child(4n) {
  padding-right: 4.167vw;
}

.related-site-list {
  --icon-size: 12px;
  position: relative;
}
.related-site-list img {
  display: block;
  margin-bottom: 16px;
  border-radius: inherit;
  width: 40px;
  height: 40px;
  aspect-ratio: 1;
  object-fit: contain;
}
.related-site-list .title {
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}
.related-site-list .domain {
  margin-block: 4px 16px;
  word-break: break-word;
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 300;
}
.related-site-list .desc {
  max-height: 10.5em;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  word-break: break-all;
  -webkit-line-clamp: 6;
  -webkit-box-orient: vertical;
  font-size: 16px;
  line-height: 1.25em;
  color: #767676;
  letter-spacing: -0.03em;
  line-height: 1.75em;
}
.related-site-list .more-view {
  display: block;
  margin-top: 6px;
  margin-left: auto;
  margin-bottom: -20px;
  border-bottom: 1px solid #767676;
  text-align: right;
  font-size: 16px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 500;
}
.related-site-list .external-link {
  margin-top: 20px;
  padding: 0;
  width: 20px;
  height: 20px;
  background-position: 0% 100%;
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
}
.related-site-list ul {
  padding-block: 32px;
  --num: 4;
  --gap: 24px;
  flex-wrap: wrap;
  gap: var(--gap);
  display: flex;
}
.related-site-list ul > * {
  width: calc(100% / var(--num) - (var(--gap) - var(--gap) * 1 / var(--num)));
}
.related-site-list ul li {
  padding: 16px;
  border: 1px solid #F4F4F4;
  transition: 0.2s ease-in-out;
}
.related-site-list ul li:hover, .related-site-list ul li:has(button:focus, a:focus) {
  border-color: #DCDCDC;
}
.related-site-list ul li.is-expanded .desc {
  max-height: 100%;
  -webkit-line-clamp: unset;
}

.no-result {
  --icon-size: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block: 40px;
  width: 100% !important;
  height: 300px;
  color: var(--gray-100300, #B1B1B1);
  font-size: var(--Body-2, 16px);
  font-weight: 500;
  line-height: 1.25em;
  text-align: center;
}
.no-result p:before {
  content: "";
  display: block;
  margin-bottom: 16px;
  height: var(--icon-size);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_no_result.png);
}

.no-result-2 {
  color: #B1B1B1;
}

.no-result-text {
  color: #B1B1B1 !important;
  text-align: center !important;
}

.line-title {
  margin-bottom: 12px;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}

.line-info-list {
  border-top: 1px solid #0C121A;
}
.line-info-list ul li {
  padding-block: 14px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  --gap: 12px;
  gap: var(--gap);
}
.line-info-list .title {
  flex-shrink: 0;
  width: 25.75%;
  min-width: 120px;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 700;
}
.line-info-list .cont {
  flex-grow: 1;
  word-break: break-all;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 500;
}
.line-info-list ~ .desc-mini {
  margin-block: 12px;
}
.line-info-list p ~ p {
  margin-top: 24px;
}
.line-info-list.no-line {
  border-top: 0;
}

.sns-links {
  --icon-size: 24px;
  display: flex;
  --gap: 12px;
  gap: var(--gap);
}
.sns-links .sns-link {
  display: block;
  width: var(--icon-size);
  height: var(--icon-size);
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.sns-links .sns-link.facebook {
  background-image: url(/thearts/images/sub/ico_sns_facebook.png);
}
.sns-links .sns-link.instagram {
  background-image: url(/thearts/images/sub/ico_sns_instagram.png);
}
.sns-links .sns-link.youtube {
  background-image: url(/thearts/images/sub/ico_sns_youtube.png);
}
.sns-links .sns-link.nblog {
  background-image: url(/thearts/images/sub/ico_sns_nblog.png);
}
.sns-links .sns-link.twitter {
  background-image: url(/thearts/images/sub/ico_sns_twitter.png);
}

.hashtags {
  --icon-size: 20px;
  margin-block: 16px;
  line-height: 0;
  display: flex;
  flex-wrap: wrap;
  --gap: 12px;
  gap: var(--gap);
}
.hashtags span {
  position: relative;
  display: inline-block;
  align-items: center;
  padding-block: 8px;
  padding-inline: calc(4px + var(--icon-size) + 4px) 12px;
  padding-inline: 12px;
  border-radius: 38px;
  background-color: #F4F4F4;
  white-space: nowrap;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.hashtags span:before {
  content: "# ";
  font-size: 0.85em;
  vertical-align: 1px;
}
.hashtags .btn-close {
  position: absolute;
  top: 8px;
  left: 8px;
  display: inline-block;
  width: var(--icon-size);
  height: var(--icon-size);
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 12px;
  background-image: url(/thearts/images/sub/ico_del_hashtag.png);
}

/* pagination navigation */
.pagination {
  --icon-size: 24px;
  display: inline-flex;
  justify-content: center;
  margin-top: 1.75rem;
  padding-block: 16px;
  width: 100%;
  text-align: center;
}
.pagination .page-link {
  display: block;
  margin-inline: 4px;
  padding: 0;
  border-radius: 4px;
  min-width: var(--icon-size);
  height: var(--icon-size);
}
.pagination .page-link.pagemove {
  font-size: 16px;
  line-height: 1em;
  color: #0C121A;
  letter-spacing: 0;
  font-weight: 600;
  line-height: var(--icon-size);
}
.pagination .page-link.pagemove.on {
  background-color: #0C121A;
  color: #FFFFFF;
}
.pagination .page-link.direction,
.pagination .page-link.pagemore {
  opacity: 1;
  overflow: hidden;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  white-space: nowrap;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.pagination .page-link.first {
  background-image: url(/thearts/images/sub/ico_page_first.png);
}
.pagination .page-link.prev {
  background-image: url(/thearts/images/sub/ico_page_prev.png);
}
.pagination .page-link.next {
  background-image: url(/thearts/images/sub/ico_page_next.png);
}
.pagination .page-link.last {
  background-image: url(/thearts/images/sub/ico_page_last.png);
}
.pagination .page-link.pagemore {
  background-size: calc(var(--icon-size) / 2);
  background-image: url(/thearts/images/sub/ico_page_more.png);
}
.pagination .page-link:where([disabled], [aria-disabled=true]) {
  opacity: 0.3 !important;
  border-color: #dddddd !important;
  background-color: #f9f9f9 !important;
  color: var(--mono-04-light, #767676) !important;
  cursor: default !important;
  user-select: none !important;
}

.pagination-type-2 {
  --icon-size: 20px;
  margin-inline: auto;
  padding-block: 12px;
  border-top: 1px solid #000;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  --gap: 4px;
  gap: var(--gap);
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.pagination-type-2 .pagemove {
  display: flex;
  align-items: center;
  --gap: 16px;
  gap: var(--gap);
}
.pagination-type-2 .page-link.prev {
  padding-left: calc(var(--icon-size) + 4px);
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_page_prev_2.png);
}
.pagination-type-2 .page-link.next {
  padding-right: calc(var(--icon-size) + 4px);
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_page_next_2.png);
}

/* board detail */
.board-wrap:has(.side-area) {
  row-gap: 12px !important;
  padding-block: 0;
  min-height: 60vh;
  display: flex;
  flex-wrap: wrap;
  --gap: 40px;
  gap: var(--gap);
}
.board-wrap:has(.side-area) .side-area.line,
.board-wrap:has(.side-area) .leading-area.line {
  padding-top: 32px;
  border-top: 1px solid #dcdcdc;
}
.board-wrap:has(.side-area) .side-area {
  position: relative;
  flex-shrink: 0;
  width: 308px;
}
.board-wrap:has(.side-area) .side-area .sticky {
  position: sticky;
  top: calc(var(--header-height) + 58px);
}
.board-wrap:has(.side-area) .side-area .confirm-wrap > ul {
  margin-bottom: 32px;
  display: flex;
  flex-direction: column;
  --gap: 32px;
  gap: var(--gap);
}
.board-wrap:has(.side-area) .side-area .confirm-wrap > ul > li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  justify-content: space-between;
  align-items: center;
  --gap: 12px;
  gap: var(--gap);
}
.board-wrap:has(.side-area) .side-area .confirm-wrap .form-control-wrap {
  padding-block: 12px;
  border-bottom: 1px solid #F4F4F4;
}
.board-wrap:has(.side-area) .side-area .confirm-wrap .form-control-wrap ~ .form-control-wrap {
  margin-top: 4px;
}
.board-wrap:has(.side-area) .side-area .confirm-wrap .title {
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.board-wrap:has(.side-area) .side-area .confirm-wrap .cont {
  margin-top: 4px;
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.board-wrap:has(.side-area) .side-area .confirm-wrap .ui-button {
  flex-shrink: 0;
  white-space: nowrap;
}
.board-wrap:has(.side-area) .leading-area {
  flex-grow: 1;
  width: calc(100% - 308px - 40px);
}
.board-wrap:has(.side-area) .detail-info ~ .detail-info {
  margin-top: 24px;
}
.board-wrap:has(.side-area) .detail-info dt {
  display: block;
  margin-bottom: 12px;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.board-wrap:has(.side-area) .detail-info dd {
  display: block;
  margin-bottom: 24px;
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.board-wrap:has(.side-area) .detail-info .download-file {
  display: block;
}
.board-wrap:has(.side-area) .detail-info .external-link {
  display: block;
  padding-right: 24px;
  background-size: 24px;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.02em;
  font-weight: 400;
  background-image: url(/thearts/images/sub/ico_external_link_lg.png);
}

.side-area:not(:has(*)) {
  /* 사이드 컨텐츠 없을때 본문 너비 넓어짐 */
  display: none;
}

.board-detail {
  position: relative;
  max-width: 100%;
  min-height: 20vh;
  overflow-x: auto;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 400;
}
.board-detail:not(:has(.bodycopy)) {
  margin-bottom: 40px;
}
.board-detail * {
  font-family: "Pretendard";
  vertical-align: 0 !important;
}
.board-detail iframe {
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16/9;
}
.board-detail table {
  width: 100% !important;
}
.board-detail .sub-headline {
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}
.board-detail .bodycopy,
.board-detail .bullet-list {
  margin-block: 16px;
}
.board-detail .detail-head .category {
  display: inline-block;
  margin-bottom: 0.5rem;
  color: #FFFFFF;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1rem;
}
.board-detail .detail-head .title {
  margin-bottom: 0.5rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 2.5rem;
  letter-spacing: -0.02em;
}
.board-detail .detail-head .date {
  display: inline-block;
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 500;
}
.board-detail .detail-body {
  line-height: 1.75rem;
}
.board-detail .detail-foot {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-top: 2.5rem;
}
.board-detail .files {
  position: relative;
  margin-top: 1.5rem;
}
.board-detail .files a {
  display: inline-block;
  margin-top: 0.25rem;
  margin-right: 1rem;
  color: #F8F8F8;
  font-size: 0.938rem;
  font-weight: 500;
}
.board-detail .btn-back-to-list {
  display: inline-block;
  padding-left: 2.25rem;
  height: 2.25rem;
  color: #767676;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 2.25rem;
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 1.5rem;
  background-image: url(/thearts/images/sub/ico_btn_list.png);
}
.board-detail .page-move-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.875rem;
}
.board-detail .page-move-wrap a {
  display: inline-block;
  height: 2.25rem;
  color: #767676;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 2.25rem;
}
.board-detail .page-move-wrap a.btn-page-prev {
  padding-left: 2.25rem;
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 1.5rem;
  background-image: url(/thearts/images/sub/btn_page_prev.png);
}
.board-detail .page-move-wrap a.btn-page-next {
  padding-right: 2.25rem;
  background-position: right center;
  background-repeat: no-repeat;
  background-size: 1.5rem;
  background-image: url(/thearts/images/sub/btn_page_next.png);
}

.info-comment-num {
  position: fixed;
  right: 12px;
  bottom: 20px;
  z-index: 1000;
  padding-inline: 16px 32px;
  border: 0.5px solid #B1B1B1;
  border-color: #D7F7C2;
  border-color: #228403;
  border-radius: 8px;
  height: 3rem;
  box-shadow: 0 0 20px rgba(30, 30, 30, 0.1);
  overflow: hidden;
  color: #228403;
  letter-spacing: -0.02em;
  text-align: left;
  transition: all 0.4s;
  background-color: #ECFED7;
  background-position: calc(100% - 12px) 50%;
  background-repeat: no-repeat;
  background-size: 14px;
  background-image: url(/thearts/images/sub/ico_arrow_down_sm_gr.png);
}
.info-comment-num span {
  line-height: inherit;
}
.info-comment-num:hover {
  border-color: #228403;
  box-shadow: 10px 10px 30px rgba(40, 40, 40, 0.3);
}
.info-comment-num.on {
  transform: translateX(calc(-3rem - 8px));
}

.info-comment-num-2 {
  margin-top: 0.5rem;
  overflow: hidden;
  background-color: #ECFED7;
  background-position: calc(100% - 12px) 50%;
  background-repeat: no-repeat;
  background-size: 14px;
  background-image: url(/thearts/images/sub/ico_arrow_down_sm_bk.png);
}
.info-comment-num-2 span {
  margin-left: 2px;
  line-height: inherit;
}

.move-article {
  position: relative;
  margin: 64px auto 32px;
  padding-block: 16px;
  border-top: 1px solid #0C121A;
  display: flex;
  --gap: 24px;
  gap: var(--gap);
}
.move-article .prev-article {
  width: 50%;
}
.move-article .next-article {
  width: 50%;
  text-align: right;
}
.move-article span {
  display: block;
  margin-bottom: 4px;
  font-size: 14px;
  line-height: 1.25em;
  color: #066fef;
  font-weight: 400;
}
.move-article a {
  display: block;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  letter-spacing: -0.02em;
  font-weight: 700;
}

.article-related {
  position: relative;
  width: 100%;
}
.leading-area ~ .article-related {
  margin-block: 40px 0;
}
.article-related .head-title {
  margin-bottom: 32px;
  padding-block: 12px;
  font-size: 32px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
}
.article-related ul {
  row-gap: 32px !important;
  --num: 4;
  --gap: 24px;
  flex-wrap: wrap;
  gap: var(--gap);
  display: flex;
}
.article-related ul > * {
  width: calc(100% / var(--num) - (var(--gap) - var(--gap) * 1 / var(--num)));
}
.article-related a {
  position: relative;
  display: block;
  text-decoration: none;
}
.article-related a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.article-related .title {
  margin-block: 12px 8px;
  max-height: 2.5em;
  max-height: 3em;
  line-height: 1.5em;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  word-break: break-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.article-related p ~ p {
  margin-top: 8px;
}
.article-related .desc {
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
}
.article-related .date {
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.article-related .date-2 {
  font-family: "Anonymous Pro", "Pretendard";
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  letter-spacing: 1px;
  font-weight: 500;
}
.article-related .info {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}
.article-related .info span {
  position: relative;
  display: inline-block;
}
.article-related .info span:not(:last-child) {
  padding-right: 16px;
}
.article-related .info span:not(:last-child):after {
  content: "";
  position: absolute;
  top: 5px;
  right: 8px;
  width: 1px;
  height: 7px;
  background: #dcdcdc;
}
.article-related .info:has(strong) {
  gap: 4px;
}
.article-related .badge {
  border-color: rgba(12, 18, 26, 0.8);
  background-color: rgba(12, 18, 26, 0.8);
  color: #FFFFFF;
  backdrop-filter: blur(2px);
}
.article-related .badges {
  position: absolute;
  top: 4px;
  left: 0;
  z-index: 2;
  padding-inline: 4px;
}
.article-related .thumb {
  width: 100%;
}
.article-related.ratio-vertical .thumb {
  aspect-ratio: 3/4;
}
.article-related.ratio-vertical .thumb img {
  aspect-ratio: inherit;
}
.article-related:not(.ratio-vertical) .thumb {
  aspect-ratio: 1;
}
.article-related:not(.ratio-vertical) .thumb img {
  aspect-ratio: inherit;
}

.output-description-area {
  position: relative;
  margin-bottom: 24px;
  border: 1px solid #dcdcdc;
}
.output-description-area .tabs-nav {
  border-bottom: 1px solid #dcdcdc;
  line-height: 0;
}
.output-description-area .tabs-nav ul {
  display: flex;
  padding-inline: 8px;
}
.output-description-area .tabs-nav ul li {
  position: relative;
  padding-inline: 8px;
}
.output-description-area .tabs-nav button {
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 40px;
  text-decoration: none;
  white-space: nowrap;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
}
.output-description-area .tabs-nav button:after {
  content: "";
  position: absolute;
  left: var(--x, 110%);
  bottom: -1px;
  opacity: 0;
  width: 100%;
  height: 2px;
  background-color: #0C121A;
  transition: opacity 0.05s ease, left 0.3s ease-out;
}
.output-description-area .tabs-nav ul li.is-active button,
.output-description-area .tabs-nav ul li button:where(:hover, :focus) {
  font-weight: 600;
}
.output-description-area .tabs-nav ul li.is-active button:after {
  --x: 0;
  content: "";
  opacity: 1;
  animation: opacity 0.05s ease, stretch-animate 0.3s ease-out 0.17s;
}
.output-description-area .tabs-nav ul li.is-active ~ li button:after {
  --x: -110%;
}

.output-description {
  position: relative;
  padding: 16px;
  display: flex;
  align-items: flex-start;
  --gap: 24px;
  gap: var(--gap);
}
.output-description .media-area {
  position: relative;
  flex-shrink: 0;
  width: 64.64%;
  background-color: #f7f7f7;
  overflow: hidden;
}
.output-description .media-area:before, .output-description .media-area:after {
  content: "";
  position: absolute;
  top: 1px;
  bottom: 1px;
  z-index: 2;
  width: 1px;
  background-color: rgba(0, 0, 0, 0.1);
}
.output-description .media-area:before {
  left: 0;
}
.output-description .media-area:after {
  right: 0;
}
.output-description .media-area .swiper-container:before, .output-description .media-area .swiper-container:after {
  content: "";
  position: absolute;
  right: 0;
  left: 0;
  z-index: 2;
  height: 1px;
  background-color: rgba(0, 0, 0, 0.1);
}
.output-description .media-area .swiper-container:before {
  top: 0;
}
.output-description .media-area .swiper-container:after {
  bottom: 0;
}
.output-description .media-area .swiper-slide {
  position: relative;
  width: 100%;
  line-height: 0;
}
.output-description .media-area button[class^=swiper-button] {
  --swiper-navigation-size: 40px;
  --icon-size: 24px;
  z-index: 3;
  opacity: 1;
  margin-top: calc(var(--swiper-navigation-size) * -1 / 2);
  padding: 0;
  border: 0;
  width: var(--swiper-navigation-size);
  overflow: hidden;
  font-size: 0;
  text-indent: -999px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  background-color: #FFFFFF;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.output-description .media-area button[class^=swiper-button]:after {
  display: none;
}
.output-description .media-area .swiper-button-prev {
  background-image: url(/thearts/images/sub/chevron_media_prev.png);
}
.output-description .media-area .swiper-button-next {
  background-image: url(/thearts/images/sub/chevron_media_next.png);
}
.output-description .media-area .swiper-button-disabled {
  opacity: 0.3 !important;
  pointer-events: none;
}
.output-description .media-area .swiper-button-lock {
  display: block;
}
.output-description .media-area .img-wrap,
.output-description .media-area .video-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
  aspect-ratio: 3/2;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(/thearts/images/common/noimg_596x366.png);
}
.output-description .media-area .img-wrap .thumb,
.output-description .media-area .img-wrap img,
.output-description .media-area .img-wrap video,
.output-description .media-area .video-wrap .thumb,
.output-description .media-area .video-wrap img,
.output-description .media-area .video-wrap video {
  aspect-ratio: inherit;
  object-fit: contain;
}
.output-description .media-area .btn-link {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  z-index: 2;
}
.output-description .description-area {
  flex-grow: 1;
  flex-shrink: 1;
  width: calc(35.36% - 24px);
}
.output-description .description-area li {
  margin-bottom: 12px;
}
.output-description .description-area .title {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}
.output-description .description-area .cont {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.output-description .description-area .cont span:has(.file-download-action) {
  display: block;
}
.output-description .description-area .cont .file-download-action {
  display: inline-block;
  font-weight: 500;
  text-decoration: underline;
}

.line-description {
  margin-bottom: 32px;
  border-top: 1px solid #0C121A;
}
.line-description.c-black p, .line-description.c-black dl dd {
  color: #0C121A;
}
.line-description.no-line {
  border-top: 0;
}
.line-description + .desc-mini {
  margin-top: -20px;
}
.line-description p {
  flex-grow: 1;
  font-size: 18px;
  line-height: 1.75em;
  color: #767676;
  font-weight: 500;
}
.line-description > p {
  margin-top: 14px;
}
.line-description p ~ p {
  margin-top: 4px;
}
.line-description dl {
  padding-block: 14px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  --gap: 12px;
  gap: var(--gap);
}
.line-description dl dt {
  flex-shrink: 0;
  width: 25.75%;
  min-width: 120px;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 700;
}
.line-description dl dd {
  flex-grow: 1;
  word-break: break-all;
  font-size: 18px;
  line-height: 1.75em;
  color: #767676;
  font-weight: 500;
}
.line-description .external-link {
  font-size: inherit;
}
.line-description .thumb:has(img.sr-only) + p {
  margin-top: 0;
}
.line-description .thumb + p {
  margin-top: 12px;
}
.line-description .user-name {
  margin-bottom: 4px;
}
.line-description .user-date {
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 400;
}

.line-description-sm {
  margin-bottom: 12px;
  border-top: 1px solid #0C121A;
}
.line-description-sm.c-black dl dd {
  color: #0C121A;
}
.line-description-sm.no-line {
  border-top: 0;
}
.line-description-sm dl {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  --gap: 12px;
  gap: var(--gap);
}
.line-description-sm dl dt {
  flex-shrink: 0;
  width: 20%;
  min-width: 120px;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.line-description-sm dl dd {
  flex-grow: 1;
  word-break: break-all;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 600;
}
.line-description-sm .external-link {
  font-size: inherit;
}

.additional-description {
  border-top: 1px solid #0C121A;
}
.additional-description ul li {
  padding-block: 12px;
  border-bottom: 1px solid #dcdcdc;
  display: flex;
  --gap: 12px;
  gap: var(--gap);
}
.additional-description .title {
  flex-shrink: 0;
  width: 25.75%;
  min-width: 120px;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 700;
}
.additional-description .cont {
  flex-grow: 1;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 500;
}
.additional-description.no-line {
  border-top: 0;
}

.paragraph-format {
  margin-bottom: 40px;
  display: flex;
  --gap: 16px;
  gap: var(--gap);
}
.paragraph-format .l-cont {
  flex-shrink: 0;
  padding-block: 8px;
  width: 20%;
}
.paragraph-format .r-cont {
  flex-grow: 1;
  padding-block: 8px;
}
.paragraph-format .line-info-list.no-line ul li:nth-child(1) {
  padding-top: 0;
}

#reply-area:has(+ .title-md) {
  margin-bottom: 32px;
}

.line-noti {
  --icon-size: 20px;
  margin-bottom: 16px;
  padding-block: 8px;
  padding-inline: calc(16px + var(--icon-size) + 8px) 16px;
  border-radius: 4px;
  min-height: calc(var(--icon-size) + 16px);
  background-color: #FFE39E;
  display: flex;
  align-items: center;
  --gap: 24px;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: var(--icon-size);
  background-position: 16px 8px;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/sub/ico_line_noti.png);
}
.line-noti:has(+ .sub-cont) {
  margin-bottom: 0;
}

.line-noti-2 {
  margin-bottom: 16px;
  padding-block: 8px;
  padding-inline: 16px;
  border-radius: 4px;
  background-color: #FFE39E;
  display: flex;
  align-items: center;
  --gap: 24px;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}

.side-noti {
  margin-bottom: 16px;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: 1.5em;
}
.side-noti p {
  line-height: 28px;
}
.board-wrap:not(.type-2) .side-noti {
  padding-right: 40px;
}
.board-wrap.type-2 .side-noti {
  padding-left: 40px;
}

.toggle-info-wrap {
  position: relative;
  margin-bottom: 16px;
}
.toggle-info-wrap .toggle-info-title {
  position: relative;
  padding-right: 56px !important;
  min-height: 24px;
  cursor: pointer;
}
.toggle-info-wrap .toggle-info-title.line-noti {
  margin-bottom: 2px;
}
.toggle-info-wrap .toggle-info-title * {
  cursor: pointer;
}
.toggle-info-wrap .toggle-info-title::after {
  content: "";
  position: absolute;
  top: calc(50% - 12px);
  right: 16px;
  width: 24px;
  height: 24px;
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(/thearts/images/sub/ico_chevron_down.png);
}
.toggle-info-wrap .toggle-info-cont {
  position: absolute;
  visibility: hidden;
  opacity: 0;
  padding-block: 12px;
  padding-inline: 16px;
  background-color: rgba(244, 244, 244, 0.5019607843);
  transition: 0.3s ease-in-out;
}

.toggle-info-wrap.is-open .toggle-info-title::after {
  background-image: url(/thearts/images/sub/ico_chevron_up.png);
}
.toggle-info-wrap.is-open .toggle-info-cont {
  position: relative;
  visibility: inherit;
  opacity: 1;
}

.table-box {
  position: relative;
  margin-inline: auto;
  width: 100%;
  overflow-x: auto;
}
.table-box .data-table {
  min-width: 930px;
}

.data-table {
  border: 0;
  width: 100%;
  background-color: #FFFFFF;
  overflow: hidden;
  letter-spacing: -0.03em;
  border-block: 1px solid #0C121A;
}
.data-table th, .data-table td {
  padding: 12px 8px;
  width: max-content;
  max-width: 12rem;
  height: 40px;
  text-align: center;
}
.data-table thead {
  border-bottom: 1px solid #dcdcdc;
}
.data-table thead th {
  vertical-align: middle;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: 1.25em;
}
.data-table thead tr:first-child th {
  border-top: 1px solid #0C121A;
}
.data-table tbody th {
  vertical-align: middle;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
  line-height: 1.25em;
}
.data-table tbody td {
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 500;
  line-height: 1.25em;
}
.data-table tbody td p, .data-table tbody td a {
  max-width: 100%;
}
.data-table tbody td a:where(:hover, :focus) {
  text-decoration: underline;
}
.data-table th:first-child, .data-table td:first-child {
  border-left: 0;
}
.data-table th:last-child, .data-table td:last-child {
  border-right: 0;
}
.data-table .ta-l {
  text-align: left;
}
.data-table .ta-r {
  text-align: right;
}
.data-table .ta-c {
  text-align: center;
}
.data-table .bd-l {
  border-left: 1px solid #F4F4F4;
}
.data-table .bd-r {
  border-right: 1px solid #F4F4F4;
}
.data-table .bg {
  background-color: rgba(244, 244, 244, 0.5019607843);
}

.default-table {
  border: 0;
  width: 100%;
  background-color: #FFFFFF;
  overflow: hidden;
}
.default-table th, .default-table td {
  padding: 8px 8px;
  padding: 14px 8px;
  border-bottom: 1px solid #dcdcdc;
  width: max-content;
  max-width: 12rem;
  height: 40px;
  text-align: left;
}
.default-table thead th {
  vertical-align: middle;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 700;
}
.default-table thead tr:first-child th {
  border-top: 1px solid #0C121A;
}
.default-table tbody th {
  vertical-align: middle;
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 700;
}
.default-table tbody td {
  font-size: 18px;
  line-height: 1.75em;
  color: #0C121A;
  font-weight: 500;
}
.default-table tbody td p, .default-table tbody td a {
  max-width: 100%;
}
.default-table tbody td a:where(:hover, :focus) {
  text-decoration: underline;
}
.default-table th:first-child, .default-table td:first-child {
  border-left: 0;
}
.default-table th:last-child, .default-table td:last-child {
  border-right: 0;
}
.default-table .ta-l {
  text-align: left;
}
.default-table .ta-r {
  text-align: right;
}
.default-table .ta-c {
  text-align: center;
}
.default-table .bd-l {
  border-left: 1px solid #F4F4F4;
}
.default-table .bd-r {
  border-right: 1px solid #F4F4F4;
}
.default-table .bg {
  background-color: rgba(244, 244, 244, 0.5019607843);
}

.status-table-list {
  position: relative;
  margin-bottom: 16px;
  text-align: center;
  border-block: 1px solid #0C121A;
  display: flex;
}
.status-table-list .head {
  width: 25%;
  background-color: #F8F8F8;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  --gap: 4px 12px;
  gap: var(--gap);
}
.status-table-list .head span {
  display: block;
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: 1.25em;
}
.status-table-list .head strong {
  display: block;
  order: -1;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
  line-height: 1.25em;
}
.status-table-list .body {
  border-right: 1px solid #F4F4F4;
  width: 25%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.status-table-list .body span {
  display: block;
  padding-block: 12px;
  width: 100%;
}
.status-table-list .body strong {
  display: block;
  padding-block: 12px;
  width: 100%;
}
.status-table-list .body > span {
  border-bottom: 1px solid #dcdcdc;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: 1.25em;
}
.status-table-list .cont {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.status-table-list .cont span {
  border-bottom: 1px solid #dcdcdc;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: 1.25em;
}
.status-table-list .cont strong {
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 700;
  line-height: 1.25em;
}
.status-table-list .inner-cont {
  flex-grow: 1;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.status-table-guide {
  margin-bottom: 40px;
}

.flexy-paragraph-row {
  position: relative;
  align-content: flex-start;
  row-gap: 12px !important;
  padding-top: 32px;
  border-top: 1px solid #0C121A;
  display: flex;
  flex-wrap: wrap;
  --gap: 24px;
  gap: var(--gap);
}
.flexy-paragraph-row ~ .flexy-paragraph-row {
  margin-top: 40px;
}
.flexy-paragraph-row.no-line {
  border-top: 0;
}
.flexy-paragraph-row .side-area {
  position: relative;
  flex-shrink: 0;
  width: 40%;
  min-width: 308px;
}
.flexy-paragraph-row .side-area .sticky {
  position: sticky;
  top: calc(var(--header-height) + 58px);
}
.flexy-paragraph-row .leading-area {
  flex-grow: 1;
  width: calc(60% - 24px);
}

.inquiry-answer {
  margin-block: 64px;
}
.inquiry-answer .title {
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 1.5em;
  color: #066fef;
  font-weight: 700;
  line-height: 1.25em;
}
.inquiry-answer .cont {
  padding-left: 32px;
  border-left: 4px solid #DDEEFF;
}
.inquiry-answer .download-file-wrap {
  margin-block: 32px 0;
  padding-block: 0;
  padding-inline: 0;
  border: 0;
}
.inquiry-answer .download-file-wrap .file-title {
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
}
.inquiry-answer .download-file-wrap .file-cont {
  font-size: 16px;
  line-height: 1.25em;
  color: #0C121A;
}
.inquiry-answer .download-file.ico {
  color: #066fef;
  background-image: url(/thearts/images/sub/ico_download_bl.png);
}

.file-upload-wrap {
  margin-bottom: 5rem;
}
.file-upload-wrap input[type=file] {
  position: absolute;
  top: -1px;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden;
  white-space: nowrap;
  clip: rect(0, 0, 0, 0);
}

.upload-btn {
  display: flex;
  gap: 4px;
}
.upload-btn button {
  flex-shrink: 0;
}
.upload-btn input[type=file] {
  position: absolute;
  top: -1px;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden;
  white-space: nowrap;
  clip: rect(0, 0, 0, 0);
}
.upload-btn input[type=text] {
  order: -1;
  flex: 1;
}

.article-group ~ .article-group {
  margin-top: 5rem;
}

.create-wrap p ~ p {
  margin-top: 4px;
}

.byteLimit {
  display: flex;
  justify-content: flex-end;
  margin: 0.25rem 0;
  width: 100%;
  color: #767676;
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.5em;
  letter-spacing: 0.03em;
}

.byteLimit .nowChar {
  font-weight: 500;
}

/* kogl 공공누리인증서 */
.kogl-type {
  margin-block: 2rem;
  padding: 0.75rem 1rem;
  border: 1px solid #dcdcdc;
  border-radius: 8px;
  display: flex;
  align-items: center;
  --gap: 1rem;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
  letter-spacing: -0.03em;
  font-weight: 400;
}
.kogl-type a {
  display: block;
  flex-shrink: 0;
}
.kogl-type .kogl-text a {
  color: #0C121A;
  font-weight: 700;
}

/* ---- filter --------------------------------*/
.board-wrap.type-2 .leading-area .filter-wrap {
  margin-top: -16px;
  border-top: 0;
}

.filter-wrap {
  position: relative;
  z-index: 3;
  padding-block: 16px;
  border-top: 1px solid #0C121A;
  border-bottom: 1px solid #dcdcdc;
}
.filter-wrap.bg {
  padding-inline: 8px;
  background-color: #F4F4F4;
}
.filter-wrap .inner-cont {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-wrap .buttons-group {
  gap: 3px;
  margin-left: 0;
}

.filter-layer-box {
  position: relative;
}
.filter-layer-box .filter-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-block: 4px;
  padding-inline: 8px 10px;
  border: 1px dashed #DCDCDC;
  border-radius: 24px;
  background-color: #FFFFFF;
  transition: 0.2s ease-in-out;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.03em;
  font-weight: 700;
}
.filter-layer-box .filter-toggle:where(:hover, :active) {
  background-color: #F4F4F4;
}
.filter-layer-box .filter-toggle:focus {
  box-shadow: 0px 0px 0px 4px rgba(1, 150, 237, 0.36);
}
.filter-layer-box .filter-toggle .ico {
  display: inline-block;
  border-radius: 50%;
  width: 12px;
  height: 12px;
  vertical-align: middle;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 12px;
  background-image: url(/thearts/images/common/ico_filter_circle.svg);
}
.filter-layer-box .filter-value {
  display: none;
  font-size: 14px;
  line-height: 1.25em;
  color: #066fef;
  letter-spacing: -0.03em;
  font-weight: 700;
}
.filter-layer-box .filter-value:first-of-type:before {
  content: "";
  display: inline-block;
  margin-right: 6px;
  border-radius: 2px;
  width: 1px;
  height: var(--text-xs, 12px);
  background: var(--Icon-Disabled, #C1C9D2);
  vertical-align: -2px;
}
.filter-layer-box .filter-layer {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  z-index: 2;
  visibility: hidden;
  opacity: 0;
  padding-block: 8px;
  border: 1px solid #DCDCDC;
  border-radius: var(--radius, 8px);
  width: max-content;
  min-width: 80px;
  background-color: #FFFFFF;
  box-shadow: 0px 4px 24px 0px rgba(0, 0, 0, 0.2);
  overflow-x: hidden;
  overflow-y: auto;
  font-size: 13px;
  font-weight: 500;
  line-height: 20px;
  transition: 0.25s ease-in-out;
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.03em;
  font-weight: 500;
}
.filter-layer-box .filter-layer:has(.input-group) {
  padding-inline: 8px;
}
.filter-layer-box .filter-layer .form-control:not(.ico-datepicker) {
  margin-block: 0;
  min-width: 230px;
}
.filter-layer-box .filter-layer .option-list {
  max-height: 260px;
}
.filter-layer-box .buttons {
  margin-inline: -8px;
  margin-top: 8px;
  padding-inline: 8px;
  padding-top: 8px;
  border-top: 1px solid #DCDCDC;
  display: flex;
  --gap: 8px;
  gap: var(--gap);
}
.filter-layer-box .buttons .ui-button {
  flex-grow: 1;
}

.btn-filter-delete {
  position: absolute;
  top: 4px;
  left: 5px;
  visibility: hidden;
  opacity: 0;
  display: inline-block;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  overflow: hidden;
  font-size: 0;
  text-indent: -9999px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 12px;
  background-image: url(/thearts/images/common/ico_filter_circle_remove.svg);
}
.btn-filter-delete:where(:hover, :active) {
  background-color: #DCDCDC;
}

.btn-filter-reset {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding-inline: 12px;
  border: 1px solid #DCDCDC;
  border-radius: 100px;
  height: 24px;
  background-color: #FFFFFF;
  color: var(--frame-bg, #0F1B2A);
  font-size: var(--text-xs, 12px);
  font-weight: 600;
  line-height: 22px;
  letter-spacing: -0.03em;
  transition: 0.2s ease-in-out;
}
.btn-filter-reset:where(:hover, :active) {
  background-color: var(--gray-100, #EBEEF1);
}

.filter-layer-box.is-show .filter-toggle {
  border-style: solid;
}
.filter-layer-box.is-show .filter-layer {
  visibility: visible;
  opacity: 1;
}

.filter-layer-box.is-selected .filter-toggle {
  border-style: solid;
}
.filter-layer-box.is-selected .filter-toggle .ico {
  background-image: none;
}
.filter-layer-box.is-selected .filter-value:last-of-type {
  padding-right: 16px;
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: 8px;
  background-image: url(/thearts/images/common/ico_filter_chevron.svg);
}
.filter-layer-box.is-selected .filter-value:not(:last-of-type):after {
  content: ",";
  margin-left: 1px;
}
.filter-layer-box.is-selected .btn-filter-delete {
  visibility: inherit;
  opacity: 1;
}

.option-wrap {
  display: flex;
  overflow-x: hidden;
  overflow-y: auto;
}

.option-list:not([class*=depth]) li {
  padding-block: 4px;
}

.option-list {
  position: relative;
  min-width: 140px;
}
.option-list li {
  padding-inline: 7px;
  line-height: 20px;
}
.option-list .ui-check[type=checkbox i].lg-bl ~ label,
.option-list .ui-check[type=radio i].lg-bl ~ label {
  display: block;
  color: #066fef;
  /* label/sm/600 */
  font-size: 14px !important;
  font-weight: 600;
}

.option-calendar {
  position: relative;
  padding-inline: 7px;
  min-width: 140px;
  height: 100%;
  background-color: #FFFFFF;
  box-shadow: 0px 15px 35px 0px rgba(60, 66, 87, 0.12), 0px 5px 15px 0px rgba(0, 0, 0, 0.08);
  overflow-x: auto;
}
.option-calendar .form-control-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.option-calendar .form-control-wrap ~ .form-control-wrap {
  margin-top: 0;
}
.option-calendar .form-control {
  min-width: 100px;
}
.option-calendar .flexy-row {
  gap: 6px;
}

.option-calendar2 {
  position: relative;
  margin-inline: auto;
  padding-inline: 7px;
  border: 1px solid rgba(177, 177, 177, 0.5019607843);
  border-radius: 8px;
  min-width: 140px;
  max-width: 340px;
  background-color: #FFFFFF;
  box-shadow: 0px 15px 35px 0px rgba(60, 66, 87, 0.12), 0px 5px 15px 0px rgba(0, 0, 0, 0.08);
}

.ui-calendar.fc {
  --fc-border-color: transparent;
  --fc-today-bg-color: transparent;
  margin-inline: auto;
  width: 100%;
  max-width: 280px;
}
.ui-calendar.fc .fc-toolbar.fc-header-toolbar {
  margin-bottom: 4px;
}
.ui-calendar.fc .fc-toolbar {
  --icon-size: 16px;
  justify-content: center;
  gap: 16px;
  padding-block: 10px;
}
.ui-calendar.fc .fc-toolbar .fc-button {
  padding: 0;
  border: 0;
  width: calc(var(--icon-size) + 4px);
  height: calc(var(--icon-size) + 4px);
  user-select: auto;
  background-color: transparent;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
}
.ui-calendar.fc .fc-toolbar .fc-button span:before {
  display: none;
}
.ui-calendar.fc .fc-toolbar-title {
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 600;
}
.ui-calendar.fc .fc-prev-button {
  background-image: url(/thearts/images/sub/btn_cal_prev.png);
}
.ui-calendar.fc .fc-next-button {
  background-image: url(/thearts/images/sub/btn_cal_next.png);
}
.ui-calendar.fc .fc .fc-scrollgrid, .ui-calendar.fc .fc .fc-scrollgrid table {
  width: max-content;
  min-width: 100%;
}
.ui-calendar.fc .fc-theme-standard td, .ui-calendar.fc .fc-theme-standard th {
  border: 0;
}
.ui-calendar.fc .fc-daygrid-day-frame {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  aspect-ratio: 1;
}
.ui-calendar.fc .fc-daygrid-day-top {
  justify-content: center;
  flex-grow: 1;
  width: 100%;
  height: 100%;
}
.ui-calendar.fc .fc-col-header-cell.fc-day {
  font-size: 14px;
  line-height: 1.25em;
  color: #B1B1B1;
  font-weight: 600;
}
.ui-calendar.fc .fc-daygrid-day-number {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  margin: 2px;
  border-radius: 50%;
  width: calc(100% - 4px) !important;
  white-space: nowrap;
  aspect-ratio: 1;
  font-size: 20px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.03em;
  font-weight: 500;
}
.ui-calendar.fc .fc-day-disabled .fc-daygrid-day-number {
  color: #767676 !important;
  cursor: default !important;
}
.ui-calendar.fc .fc-daygrid-day-events {
  display: none;
  margin-bottom: 0;
}
.ui-calendar.fc .fc-day-other .fc-daygrid-day-top {
  opacity: 1;
}
.ui-calendar.fc .fc-day-other .fc-daygrid-day-top .fc-daygrid-day-number {
  color: #B1B1B1;
}
.ui-calendar.fc .fc-day-today .fc-daygrid-day-number {
  color: #066fef;
}
.ui-calendar.fc .fc-selected-date .fc-daygrid-day-number {
  background-color: #066fef !important;
  color: #FFFFFF !important;
}
.ui-calendar.fc .fc-range-start .fc-daygrid-day-number,
.ui-calendar.fc .fc-range-end .fc-daygrid-day-number {
  background-color: #066fef !important;
  color: #FFFFFF !important;
}
.ui-calendar.fc .fc-range-selected .fc-daygrid-day-top:after {
  content: "";
  position: absolute;
  inset-block: 2px;
  inset-inline: -1px;
  z-index: -1;
  display: block;
  border-radius: 0;
  background-color: #DDEEFF !important;
}
.ui-calendar.fc tr:has(.fc-range-end) .fc-range-start .fc-daygrid-day-top:after,
.ui-calendar.fc .fc-range-end .fc-daygrid-day-top:after {
  content: "";
  position: absolute;
  inset-block: 2px;
  inset-inline: -1px;
  z-index: -1;
  display: block;
  border-radius: 0;
  background-color: #DDEEFF !important;
}
.ui-calendar.fc .fc-range-start .fc-daygrid-day-top:after {
  left: 50% !important;
}
.ui-calendar.fc .fc-range-end .fc-daygrid-day-top:after {
  right: 50%;
}
.ui-calendar.fc tr td:last-child.fc-range-selected .fc-daygrid-day-top:after {
  right: 0;
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
}
.ui-calendar.fc tr td:first-child.fc-range-selected .fc-daygrid-day-top:after {
  left: 0;
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
}
.ui-calendar.fc .fc-daygrid-day-events::after,
.ui-calendar.fc .fc-daygrid-day-events::before,
.ui-calendar.fc .fc-daygrid-day-frame::after,
.ui-calendar.fc .fc-daygrid-day-frame::before,
.ui-calendar.fc .fc-daygrid-event-harness::after,
.ui-calendar.fc .fc-daygrid-event-harness::before {
  display: none;
}

.filter-layer-box.is-show .option-calendar .flatpickr-calendar {
  visibility: visible !important;
}

.filter-layer-box .filter-layer:has(.flatpickr-calendar),
.option-wrap:has(.flatpickr-calendar),
.option-calendar:has(.flatpickr-calendar) {
  overflow-y: hidden;
}

.option-calendar .flatpickr-calendar {
  visibility: hidden !important;
}
.option-calendar .flatpickr-calendar.inline {
  top: 1px;
  margin-bottom: 2px;
}

.flatpickr-calendar .flatpickr-months {
  justify-content: center;
  gap: 4px;
  margin-top: 6px;
}
.flatpickr-calendar .flatpickr-month {
  flex: unset;
}
.flatpickr-calendar .flatpickr-current-month {
  position: relative;
  left: unset;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  width: auto;
  font-size: 18px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 600;
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-calendar .flatpickr-current-month .numInputWrapper {
  height: 100%;
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months {
  order: 1;
  margin: 0;
  padding-inline: 8px 16px !important;
  width: 3.6875rem;
  background-image: url(/thearts/images/common/arw_select.svg);
  background-position: calc(100% - 2px) 50%;
  background-repeat: no-repeat;
  background-size: 14px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months option {
  background-color: #fff;
  font-size: 1rem;
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months:hover {
  background-image: url(/thearts/images/common/arw_select.svg);
  background-position: calc(100% - 2px) 50%;
  background-repeat: no-repeat;
  background-size: 14px;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper {
  order: 0;
  width: 3.5rem;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper input.cur-year {
  padding-inline: 4px;
  height: 100%;
  font-weight: 500;
  text-align: center;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper span {
  display: none;
  height: 14px;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper span.arrowUp {
  top: calc(50% - 14px);
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months:focus,
.flatpickr-calendar .flatpickr-current-month input.cur-year:focus {
  outline: inset;
  outline-style: auto;
  outline-color: rgba(1, 150, 237, 0.4);
  outline-offset: -1px;
}
.flatpickr-calendar .flatpickr-prev-month,
.flatpickr-calendar .flatpickr-next-month {
  position: static;
  border-radius: 4px;
}
.flatpickr-calendar .flatpickr-prev-month.flatpickr-disabled,
.flatpickr-calendar .flatpickr-next-month.flatpickr-disabled {
  display: block;
  cursor: not-allowed;
}
.flatpickr-calendar .flatpickr-prev-month.flatpickr-disabled svg,
.flatpickr-calendar .flatpickr-next-month.flatpickr-disabled svg {
  fill: #ccc;
}
.flatpickr-calendar .flatpickr-prev-month svg,
.flatpickr-calendar .flatpickr-next-month svg {
  vertical-align: top;
  fill: #066fef;
}
.flatpickr-calendar .flatpickr-prev-month:hover:not(.flatpickr-disabled),
.flatpickr-calendar .flatpickr-next-month:hover:not(.flatpickr-disabled) {
  background-color: #f4f4f4;
}
.flatpickr-calendar .flatpickr-prev-month:hover:not(.flatpickr-disabled) svg,
.flatpickr-calendar .flatpickr-next-month:hover:not(.flatpickr-disabled) svg {
  fill: #066fef;
}
.flatpickr-calendar .flatpickr-day {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: -0.03em;
  transition: all 0.1s ease-in-out;
}
.flatpickr-calendar .flatpickr-day:not(:where(.prevMonthDay, .nextMonthDay, .flatpickr-disabled)) {
  color: #0C121A;
}
.flatpickr-calendar .flatpickr-day.inRange,
.flatpickr-calendar .flatpickr-day.prevMonthDay.inRange,
.flatpickr-calendar .flatpickr-day.nextMonthDay.inRange,
.flatpickr-calendar .flatpickr-day.today.inRange,
.flatpickr-calendar .flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-calendar .flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-calendar .flatpickr-day:hover,
.flatpickr-calendar .flatpickr-day.prevMonthDay:hover,
.flatpickr-calendar .flatpickr-day.nextMonthDay:hover,
.flatpickr-calendar .flatpickr-day:focus,
.flatpickr-calendar .flatpickr-day.prevMonthDay:focus,
.flatpickr-calendar .flatpickr-day.nextMonthDay:focus {
  border-color: #f2f2f2;
  background: #f2f2f2;
  outline: initial;
}
.flatpickr-calendar .flatpickr-day.today {
  border-color: #767676;
}
.flatpickr-calendar .flatpickr-day.today:hover, .flatpickr-calendar .flatpickr-day.today:focus {
  border-color: #0C121A;
  background: #f2f2f2;
  color: #0C121A;
}
.flatpickr-calendar .flatpickr-day.selected,
.flatpickr-calendar .flatpickr-day.startRange,
.flatpickr-calendar .flatpickr-day.endRange,
.flatpickr-calendar .flatpickr-day.selected.inRange,
.flatpickr-calendar .flatpickr-day.startRange.inRange,
.flatpickr-calendar .flatpickr-day.endRange.inRange,
.flatpickr-calendar .flatpickr-day.selected:focus,
.flatpickr-calendar .flatpickr-day.startRange:focus,
.flatpickr-calendar .flatpickr-day.endRange:focus,
.flatpickr-calendar .flatpickr-day.selected:hover,
.flatpickr-calendar .flatpickr-day.startRange:hover,
.flatpickr-calendar .flatpickr-day.endRange:hover,
.flatpickr-calendar .flatpickr-day.selected.prevMonthDay,
.flatpickr-calendar .flatpickr-day.startRange.prevMonthDay,
.flatpickr-calendar .flatpickr-day.endRange.prevMonthDay,
.flatpickr-calendar .flatpickr-day.selected.nextMonthDay,
.flatpickr-calendar .flatpickr-day.startRange.nextMonthDay,
.flatpickr-calendar .flatpickr-day.endRange.nextMonthDay {
  border-color: #066fef;
  background: #066fef;
  color: #fff;
}
.flatpickr-calendar .flatpickr-day.today.flatpickr-disabled,
.flatpickr-calendar .flatpickr-day.today.flatpickr-disabled:hover {
  border-color: rgba(57, 57, 57, 0.1);
  background-color: #fff;
  color: rgba(57, 57, 57, 0.1);
}
.flatpickr-calendar .flatpickr-rContainer {
  width: 100%;
}
.flatpickr-calendar .flatpickr-monthSelect-month {
  position: relative;
  display: inline-block;
  margin: 4px;
  padding: 10px;
  border: 1px solid transparent;
  border-radius: 4px;
  width: calc(33% - 8px);
  background: none;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.03em;
  text-align: center;
  transition: all 0.1s ease-in-out;
  cursor: pointer;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
}
.flatpickr-calendar .flatpickr-monthSelect-month:where(:hover, :focus) {
  background-color: #f2f2f2;
}
.flatpickr-calendar .flatpickr-monthSelect-month:not(:where(.prevMonthDay, .nextMonthDay, .flatpickr-disabled)) {
  color: #0C121A;
}
.flatpickr-calendar .flatpickr-monthSelect-month.today {
  border-color: #959ea9;
}
.flatpickr-calendar .flatpickr-monthSelect-month.selected {
  border-color: #066fef;
  background: #066fef;
  color: #fff;
}
.flatpickr-calendar .flatpickr-monthSelect-month.flatpickr-disabled,
.flatpickr-calendar .flatpickr-monthSelect-month.flatpickr-disabled:hover {
  color: rgba(57, 57, 57, 0.1);
  cursor: not-allowed;
}
.flatpickr-calendar .flatpickr-monthSelect-month.today.flatpickr-disabled,
.flatpickr-calendar .flatpickr-monthSelect-month.today.flatpickr-disabled:hover {
  border-color: rgba(57, 57, 57, 0.1);
  background-color: #fff;
  color: rgba(57, 57, 57, 0.1);
}

input[type=date] {
  text-align: left !important;
}

input.ico-datepicker {
  position: relative;
  padding-right: 2rem !important;
  background-repeat: no-repeat;
  text-align: left;
  background-position: calc(100% - 0.75rem) 50%;
  background-repeat: no-repeat;
  background-size: 20px;
  background-image: url(/thearts/images/sub/ico_btn_calendar.png);
}
input.ico-datepicker::-webkit-clear-button, input.ico-datepicker::-webkit-inner-spin-button {
  display: none;
}
input.ico-datepicker::-webkit-calendar-picker-indicator {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  color: transparent;
}

.operation-site {
  --icon-size: 12px;
  margin-bottom: 24px;
  padding-block: 32px;
  border-bottom: 1px solid #dcdcdc;
}
.operation-site .site-list {
  padding-block: 16px 24px;
  padding-inline: 20px;
  background-color: #F4F4F4;
}
.operation-site .title-sm {
  margin-bottom: 16px;
  padding-left: 8px;
}
.operation-site ul {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.operation-site ul li {
  width: 100%;
}
.operation-site ul li a {
  display: flex;
  align-items: center;
  gap: 8px 32px;
  padding: 8px;
  border-radius: 48px;
  background-color: #FFFFFF;
  box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.15);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  letter-spacing: -0.02em;
  line-height: 1.5em;
}
.operation-site ul li a:where(:hover, :focus) .site-name {
  color: #066fef;
}
.operation-site ul li span {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  width: 186px;
}
.operation-site img {
  flex-shrink: 0;
  width: 24px;
}
.operation-site .site-name {
  display: inline-block;
  padding-right: calc(4px + var(--icon-size));
  width: 100%;
  font-weight: 700;
  background-position: 100% 50%;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/main/ico_external_link_bl.png);
}
.operation-site p {
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  white-space: nowrap;
}

/* 검색결과 목록 */
.search-result .swiper-controls {
  --swiper-navigation-size: 24px;
  display: flex;
  --gap: 4px;
  gap: var(--gap);
}
.search-result .swiper-controls span {
  width: calc(var(--swiper-navigation-size) + 4px);
  margin-inline: 15px;
  border-radius: 4px;
  height: 28px;
  background-color: #F4F4F4;
  line-height: 28px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.search-result .swiper-controls span:before, .search-result .swiper-controls span:after {
  background-color: #F4F4F4;
  transform: skewX(-12.8deg);
}
.search-result .swiper-controls span:before {
  left: -15px;
  border-radius: 4px 0 0 4px;
}
.search-result .swiper-controls span:after {
  right: -15px;
  border-radius: 0 4px 4px 0;
}
.search-result .swiper-controls span:nth-of-type(odd)::before {
  transform: skewX(12.8deg);
}
.search-result .swiper-controls span:nth-of-type(even)::after {
  transform: skewX(12.8deg);
}
.search-result .swiper-controls span:first-of-type {
  padding-left: 12px;
}
.search-result .swiper-controls span:first-of-type:before {
  display: none;
}
.search-result .swiper-controls span:last-of-type {
  padding-right: 12px;
}
.search-result .swiper-controls span:last-of-type:after {
  display: none;
}
.search-result .swiper-button-prev, .search-result .swiper-button-next {
  inset: 0;
  top: auto;
  right: auto;
  left: auto;
  display: inline-block;
  margin-top: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.search-result .swiper-button-prev:after, .search-result .swiper-button-next:after {
  display: none;
}
.search-result .swiper-button-prev {
  background-image: url(/thearts/images/main/ico_chevron_left.png);
}
.search-result .swiper-button-next {
  background-image: url(/thearts/images/main/ico_chevron_right.png);
}
.search-result .swiper-button-disabled {
  opacity: 0.4 !important;
  user-select: none;
  pointer-events: none;
}
.search-result .project-swiper {
  padding-block: 12px;
}
.search-result .project-swiper .swiper-slide {
  padding-right: 12px;
}
.search-result .project-swiper a {
  text-decoration: none;
}
.search-result .project-swiper a img {
  position: relative;
  width: 100%;
  transition: 0.2s ease-in-out;
  aspect-ratio: 3/4;
  object-fit: cover;
}
.search-result .project-swiper a:where(:hover, :focus) .title {
  text-decoration: underline;
}
.search-result .project-swiper .badge {
  margin-top: 24px;
  border-color: rgba(220, 220, 220, 0.5019607843);
  border-radius: 12px;
  background-color: rgba(220, 220, 220, 0.5019607843);
  font-size: 12px;
  line-height: 1.25em;
  color: #767676;
  font-weight: 700;
}
.search-result .project-swiper .title {
  margin-block: 16px;
  max-height: 2.5em;
  max-height: 3em;
  line-height: 1.5em;
  font-size: 18px;
  line-height: 1.25em;
  color: #000;
  font-weight: 700;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  word-break: break-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.search-result .project-swiper .hashtag {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  --gap: 8px;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #767676;
}
.search-result .project-swiper .hashtag span:before {
  content: "# ";
}
.search-result .view-more {
  display: flex;
  justify-content: flex-end;
  padding-block: 16px;
  padding-inline: var(--section-padding-x);
}
.search-result .more-contents {
  --icon-size: 16px;
  display: flex;
  gap: 4px;
  white-space: nowrap;
}
.search-result .more-contents > * {
  margin-inline: 15px;
  border-radius: 4px;
  height: 28px;
  background-color: #F4F4F4;
  line-height: 28px;
}
.search-result .more-contents > *:before, .search-result .more-contents > *:after {
  background-color: inherit;
  transform: skewX(-12.8deg);
}
.search-result .more-contents > *:before {
  left: -15px;
  border-radius: 4px 0 0 4px;
}
.search-result .more-contents > *:after {
  right: -15px;
  border-radius: 0 4px 4px 0;
}
.search-result .more-contents > *:nth-of-type(odd) {
  margin-left: 0;
  padding-left: 12px;
}
.search-result .more-contents > *:nth-of-type(odd):before {
  display: none;
}
.search-result .more-contents > *:nth-of-type(even) {
  margin-right: 0;
  padding-right: 12px;
}
.search-result .more-contents > *:nth-of-type(even):after {
  display: none;
}
.search-result .more-contents span {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  line-height: 1.25em;
  color: #7a7a7a;
  font-weight: 600;
}
.search-result .more-contents.type2 span {
  color: #0C121A;
}
.search-result .more-contents.type2 span:last-child {
  width: 29px;
}
.search-result .more-contents.type2 span:last-child img {
  max-width: none;
}

.result-group {
  position: relative;
  padding-block: 32px;
  border-bottom: 1px solid #dcdcdc;
  overflow: hidden;
}
.result-group:nth-of-type(1) {
  margin-top: -32px;
}

.total-search-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 200px;
  margin-bottom: 10px;
}
.total-search-wrap .inner {
  margin-inline: auto;
  width: 100%;
  max-width: 726px;
}
.total-search-wrap .search-keyword {
  --icon-size: 24px;
  position: relative;
  z-index: 2;
  width: 100%;
  background-size: var(--icon-size) !important;
  position: relative;
  z-index: 2;
  padding-inline: calc(44px + var(--icon-size)) 20px;
  border: 1px solid #DCDCDC;
  border-radius: 8px;
  height: 64px;
  background-color: #fff;
  font: inherit;
  transition: all 0.2s ease-in-out;
  background-position: 16px 50%;
  background-repeat: no-repeat;
  background-size: 16px;
  background-image: url(/thearts/images/common/ico_search_lg.png);
  margin-top:16px;
}
.total-search-wrap .search-keyword .search-input {
  border: 0 !important;
  width: 100%;
  background-image: none !important;
  background-size: var(--icon-size) !important;
  color: #0C121A;
  font-size: 18px !important;
  font-weight: 500 !important;
  position: relative;
  z-index: 2;
  padding-inline: 0;
  border: 1px solid transparent;
  border-radius: 8px;
  height: 64px;
  background-color: transparent;
  font: inherit;
  transition: all 0.2s ease-in-out;
  background-position: 16px 50%;
  background-repeat: no-repeat;
  background-size: 16px;
  background-image: url(/thearts/images/common/ico_search.png);
}
.total-search-wrap .search-keyword .search-input::-webkit-search-decoration, .total-search-wrap .search-keyword .search-input::-webkit-search-cancel-button, .total-search-wrap .search-keyword .search-input::-webkit-search-results-button, .total-search-wrap .search-keyword .search-input::-webkit-search-results-decoration {
  display: none;
}
.total-search-wrap .search-keyword .search-input:autofill, .total-search-wrap .search-keyword .search-input:autofill:hover, .total-search-wrap .search-keyword .search-input:autofill:focus, .total-search-wrap .search-keyword .search-input:autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px transparent inset;
  box-shadow: 0 0 0px 1000px transparent inset;
  transition: background-color 5000s ease-in-out 0s;
}
.total-search-wrap .search-keyword .search-input:-internal-autofill-selected {
  background-image: inherit !important;
}
.total-search-wrap .search-keyword .search-input:focus {
  border-color: transparent !important;
  box-shadow: none !important;
  outline: 0;
  filter: none !important;
}
.total-search-wrap .search-keyword .search-input:hover {
  box-shadow: none !important;
}
.total-search-wrap .search-keyword:has(.search-input:focus) {
  border-color: #000;
  box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.1);
  filter: drop-shadow(0px 0px 0px 2px rgba(0, 0, 0, 0.1));
}
.total-search-wrap .search-keyword:has(.search-input:hover) {
  box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.1);
}
.total-search-wrap .search-keyword .btn-clear {
  --icon-size: 20px;
  position: absolute;
  top: calc(50% - var(--icon-size) / 2);
  right: 20px;
  z-index: 2;
  display: none !important;
  width: var(--icon-size);
  height: var(--icon-size);
  overflow: hidden;
  font-size: 1px;
  text-indent: -9999px;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/common/ico_clear.png);
}
.total-search-wrap .search-keyword .type-animation {
  position: absolute;
  top: 50%;
  left: 0;
  padding-inline: 68px 12px;
  color: #767676;
  font-size: 18px;
  font-weight: 500;
  line-height: 20px;
  transform: translateY(-50%);
  transition: opacity 0.2s ease-in-out, visibility 0.2s;
}
.total-search-wrap .search-keyword .type-animation strong {
  opacity: 0.88;
  display: inline-block;
  color: #0C121A;
  font-weight: 600;
  vertical-align: 0;
}
.total-search-wrap .search-history {
  position: relative;
  display: none;
  margin-top: -8px;
  padding-block: 16px 8px;
  padding-inline: 20px;
  border: 0.5px solid rgba(0, 0, 0, 0.1);
  border-radius: 0 0 8px 8px;
  background-color: #F4F4F4;
  display: flex;
  --gap: 8px 10px;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.total-search-wrap .search-history strong {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: 1.375em;
}
.total-search-wrap .search-history span {
  --icon-size: 12px;
  position: relative;
  display: inline-block;
  margin-right: 10px;
  padding-right: calc(var(--icon-size) + 4px);
  line-height: inherit;
}
.total-search-wrap .search-history .btn-delete {
  position: absolute;
  top: calc(50% - var(--icon-size) / 2);
  right: 0;
  z-index: 2;
  width: var(--icon-size);
  height: var(--icon-size);
  overflow: hidden;
  font-size: 1px;
  text-indent: -9999px;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: var(--icon-size);
  background-image: url(/thearts/images/common/ico_history_delete.png);
}
.total-search-wrap .search-noti {
  position: relative;
  display: none;
  margin-top: -8px;
  padding-block: 16px 8px;
  padding-inline: 20px;
  border: 0.5px solid rgba(0, 0, 0, 0.1);
  border-radius: 0 0 8px 8px;
  background-color: #F4F4F4;
  display: flex;
  --gap: 8px 10px;
  gap: var(--gap);
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
}
.total-search-wrap .search-noti strong {
  font-size: 14px;
  line-height: 1.25em;
  color: #0C121A;
  font-weight: 400;
  line-height: 1.375em;
}

.total-search-wrap .recommended-keyword {
    width:100%;
}

.total-search-wrap .recommended-keyword dl {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-left: 90px;
  margin: 0;
}

.total-search-wrap .recommended-keyword dl dt {
  position: absolute;
  left: 0;
  top: 4px;
  margin: 0;
}

.total-search-wrap .recommended-keyword dl dd {
  margin: 0;
}

.total-search-wrap .recommended-keyword dl dd a {
  display: inline-block;
  font-size: 14px;
  color: #366DEC;
  font-weight: 700;
  border-radius: 10px;
  background-color: #E0F0FF;
  padding: 4px 10px;
  white-space: nowrap;
}

.advanced-search {
    margin-top:10px;
}

.advanced-search a {
    display:flex;
    gap:6px;
    align-items:center;
}
.advanced-search .ico_arrow {
    display:block;
    background-color:#c4c4c4;
    border-radius:50%;
    width:25px;
    height:25px;
}

.advanced-search .ico_arrow::after {
    content:"";
    display:block;
    width:25px;
    height:25px;
    background:url(/thearts/images/sub/ico_arrow_down_sm.png) no-repeat transparent center;
    filter:invert(1);
}

.advanced-search .up .ico_arrow::after {
    transform: rotate(180deg);
}

.advanced-search-wrap {
  background-color: #F8F9FA;
  width: 100%;
  border-top: 1px solid #EBEBEB;
  border-bottom: 1px solid #EBEBEB;
  margin-bottom: 10px;
  box-sizing: border-box;
 /* display: none;*/
}

.advanced-search-wrap * {
  box-sizing: border-box;
}

.advanced-search-wrap .inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 20px 20px;
}

.advanced-search-wrap .search-refine {
  display: flex;
  align-items: flex-start;
}

.advanced-search-wrap .search-refine .refine-input-group {
  flex: 1;
}

.advanced-search-wrap .search-refine .refine-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 5px;
}

.advanced-search-wrap .search-refine .refine-tags .tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  background-color: #F8F9FA;
  border: 1px solid #E9ECEF;
  border-radius: 20px;
  font-size: 14px;
  color: #333;
}

.advanced-search-wrap .search-refine .refine-tags .btn-del {
  background: none;
  border: none;
  padding: 0;
  font-size: 12px;
  color: #999;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.advanced-search-wrap .search-refine .refine-tags .btn-del:hover {
  color: #111;
}

.search-summary-wrap {
  margin: 10px auto 10px;
  font-size: 20px;
  color: #111;
  word-break: keep-all;
}

.search-summary-wrap p span,
.search-summary-wrap p strong {
  vertical-align: baseline !important;
}

.search-summary-wrap .highlight {
  color: #366DEC;
  font-weight: 700;
}

.search-summary-wrap strong {
  font-weight: 700;
}

.advanced-search-wrap dl {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 16px;
  margin-bottom: 15px;
  align-items: center;
}

.advanced-search-wrap dt,
.advanced-search-wrap .search-refine label {
  font-size: 16px;
  font-weight: 700;
  color: #333;
}

.advanced-search-wrap .search-refine label {
  flex-shrink: 0;
  white-space: nowrap;
  margin-right: 20px;
}

.advanced-search-wrap dd {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  margin: 0;
}

.advanced-search-wrap input[type=text],
.advanced-search-wrap select {
  border: 1px solid #DCDCDC;
  border-radius: 4px;
  height: 42px;
  background-color: #fff;
  font-size: 15px;
  color: #333;
  padding: 0 16px;
  width: 100%;
  transition: border-color 0.2s;
  outline: none;
}

.advanced-search-wrap input[type=text]:focus,
.advanced-search-wrap select:focus {
  border-color: #111;
}

.advanced-search-wrap select {
  max-width: 200px;
  cursor: pointer;
}

.advanced-search-wrap dd label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  font-size: 15px;
  color: #444;
}

.advanced-search-wrap dd label input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #C4C4C4;
  background-color: #fff;
  margin: 0;
  cursor: pointer;
  position: relative;
  transition: all 0.2s;
}

.advanced-search-wrap dd label input[type="radio"]:checked {
  border-color: #007AFF;
  background-color: #007AFF;
}

.advanced-search-wrap dd label input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
}

.advanced-search-wrap .period-group {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 12px;
}

.advanced-search-wrap .date-inputs {
  display: flex;
  align-items: center;
  gap: 8px;
}

.advanced-search-wrap .ico-datepicker {
  width: 140px;
}

.advanced-search-wrap .tilde {
  font-weight: 500;
  color: #666;
}

.advanced-search-wrap .buttons-group {
  display: flex;
  flex-wrap: nowrap;
  white-space: nowrap;
  gap: 6px;
  align-items: center;
}

.advanced-search-wrap .ui-button.sm {
  height: 36px;
  padding: 0 16px;
  border-radius: 18px;
  font-size: 14px;
  font-weight: 600;
  border: 1px solid #DCDCDC;
  background: #fff;
  color: #666;
  cursor: pointer;
  transition: all 0.2s;
}

.advanced-search-wrap .ui-button.sm.primary {
  background: #111;
  color: #fff;
  border-color: #111;
}

.advanced-search-wrap .ui-button.sm.outline-primary:hover {
  border-color: #111;
  color: #111;
}

.advanced-search-wrap .bottom-btn-group {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}

.advanced-search-wrap .btn-submit-search,
.advanced-search-wrap .btn-reset-search {
  width: 100%;
  max-width: 160px;
  height: 48px;
  font-size: 16px;
  font-weight: 700;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.advanced-search-wrap .btn-submit-search {
  background-color: #111;
  color: #fff;
  border: none;
}

.advanced-search-wrap .btn-submit-search:hover {
  background-color: #333;
}

.advanced-search-wrap .btn-reset-search {
  background-color: #fff;
  color: #444;
  border: 1px solid #DCDCDC;
}

.advanced-search-wrap .btn-reset-search:hover {
  background-color: #F4F4F4;
}

.search-top {
  padding-block: 16px;
  width: 100%;
}
.search-top .inner {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  --gap: 24px;
  gap: var(--gap);
}
.search-top .breadcrumb {
  --line-h: 30px;
}
.search-top .breadcrumb > *:not(.num) {
  line-height: var(--line-h) !important;
  font-size: 24px;
  line-height: 1.5em;
  color: #0C121A;
  font-weight: 700;
}

.search-list {
  position: relative;
  overflow: hidden;
}

body:has(.login-cont) {
  background: #F4F4F4;
}

.login-cont {
  position: relative;
  display: flex;
  padding-block: 32px 120px;
}

.login-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  margin-inline: auto;
  padding: 40px 32px;
  border: 0.5px solid var(--gray-100100, #F4F4F4);
  border-radius: var(--radius-rg, 8px);
  width: 100%;
  max-width: 540px;
  background-color: #fff;
  overflow: hidden;
}
.login-box .title {
  text-align: center;
}
.login-box .title h1 {
  color: var(--gray-100500, #0C121A);
  /* Display/Heading/Heading-3 */
  font-size: var(--Heading-3, 36px);
  font-weight: 800;
  line-height: 125%; /* 45px */
  letter-spacing: -0.36px;
}

.login-form .input-wrap {
  position: relative;
  border: 1px solid #DCDCDC;
  border-radius: 8px;
  overflow: hidden;
}
.login-form .form-input {
  position: relative;
  padding-inline: var(--spacing-md, 12px);
  border: 0;
  border-radius: 0;
  width: 100%;
  height: var(--form-lg, 40px);
  font-size: var(--fontsize-form-lg, 16px);
  line-height: normal;
}
.login-form .form-input ~ .form-input {
  border-top: 1px solid #DCDCDC;
}
.login-form .form-input:first-child {
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
}
.login-form .form-input:last-child {
  border-bottom-right-radius: 6px;
  border-bottom-left-radius: 6px;
}
.login-form .save-id-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  margin-block: 16px;
}
.login-form .find-id-link {
  display: inline-block;
  color: var(--gray-100500, #0C121A);
  /* Body/Body-2 */
  font-size: var(--Body-2, 16px);
  font-weight: 500;
  line-height: 125%; /* 20px */
  text-align: right;
  text-decoration-line: underline;
}
.login-form .login-button {
  justify-content: center;
  width: 100%;
  display: flex;
  gap: 6px;
  white-space: nowrap;
}
.login-form .login-button > * {
  margin-inline: 22px;
  border-radius: 6px;
  height: 48px;
  background-color: #000;
  line-height: 48px;
}
.login-form .login-button > *:before, .login-form .login-button > *:after {
  background-color: inherit;
  transform: skewX(-12.8deg);
}
.login-form .login-button > *:before {
  left: -22px;
  border-radius: 6px 0 0 6px;
}
.login-form .login-button > *:after {
  right: -22px;
  border-radius: 0 6px 6px 0;
}
.login-form .login-button > *:nth-of-type(odd) {
  margin-left: 0;
  padding-left: 14px;
}
.login-form .login-button > *:nth-of-type(odd):before {
  display: none;
}
.login-form .login-button > *:nth-of-type(even) {
  margin-right: 0;
  padding-right: 14px;
}
.login-form .login-button > *:nth-of-type(even):after {
  display: none;
}
.login-form .login-button span {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  line-height: 1em;
  color: #FFFFFF;
  font-weight: 600;
}
.login-form .login-button span:first-child {
  justify-content: flex-start;
  gap: 10px;
  flex-grow: 1;
}
.login-form .login-button span:last-child {
  background-color: #D6007F;
}
.login-form .alert-danger {
  margin-top: 16px;
  padding-block: 12px;
  border-radius: 6px;
  background-color: #f0f0f0;
  color: #7A7A7A;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
}
.login-form .not-member {
  margin-block: 32px;
  text-align: center;
}
.login-form .register-link {
  color: var(--gray-100500, #0C121A);
  /* Body/Body-2 */
  font-size: var(--Body-2, 16px);
  font-weight: 500;
  line-height: 125%; /* 20px */
}
.login-form .bullet-list {
  position: relative;
  color: var(--gray-100300, #B1B1B1);
  /* Body/Body-3 */
  font-size: var(--Body-3, 14px);
  font-weight: 400;
  line-height: 125%; /* 17.5px */
}
.login-form .bullet-list li:before {
  background-color: var(--gray-100300, #B1B1B1);
}

body:has(.page-not-found) {
  background: #F4F4F4;
}

.page-not-found {
  display: flex;
  justify-content: center;
  padding-bottom: 64px;
  min-height: 80vh;
  text-align: center;
}
.page-not-found h1 {
  margin-top: 12px;
  font-size: 32px;
  line-height: 1.25em;
  color: #0C121A;
}
.page-not-found p {
  margin-top: 12px;
  font-size: 18px;
  line-height: 1.25em;
  color: #767676;
}

@keyframes stretch-animate {
  0% {
    transform: scale(1, 1);
  }
  28% {
    transform: scale(1.15, 0.85);
  }
  50% {
    transform: scale(0.9, 1.1);
  }
  100% {
    transform: scale(1, 1);
  }
}
@keyframes fade-in {
  0% {
    transform: scale(1, 1);
  }
  28% {
    transform: scale(1.15, 0.85);
  }
  50% {
    transform: scale(0.9, 1.1);
  }
  100% {
    transform: scale(1, 1);
  }
}