.sub-tabs {
  background: white;
  border-bottom: 1px solid #e1e1e4;
}
.sub-tabs .container {
  height: 3.75rem;
  display: flex;
  align-items: center;
}
.sub-tabs .container .tabs-wrap {
  display: flex;
  gap: 0.25rem;
  height: 100%;
}
.sub-tabs .container .tabs-wrap .tab-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem;
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 500;
  color: #505050;
  border-bottom: 2px solid transparent;
  transition: all 0.2s;
}
.sub-tabs .container .tabs-wrap .tab-item:hover {
  color: var(--primary);
}
.sub-tabs .container .tabs-wrap .tab-item.active {
  color: var(--primary);
  font-weight: 700;
  border-bottom-color: var(--primary);
}
@media only screen and (max-width: 767px) {
  .sub-tabs .container {
    height: 3rem;
  }
  .sub-tabs .container .tabs-wrap .tab-item {
    font-size: 0.875rem;
  }
}

.sec-01 .container {
  padding-top: 5rem;
  padding-bottom: 10rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container {
    padding-top: 3.75rem;
    padding-bottom: 7.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container {
    padding-top: 2.5rem;
    padding-bottom: 5rem;
  }
}
.sec-01 .container .title-area {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .title-area {
    margin-bottom: 1rem;
    gap: 1rem;
  }
}
.sec-01 .container .title-area .title-icon {
  position: relative;
  width: 27.314px;
  height: 27.314px;
  flex-shrink: 0;
  line-height: 0;
}
.sec-01 .container .title-area .title-icon img {
  position: absolute;
  width: 27.314px;
  height: 27.314px;
}
.sec-01 .container .title-area .title-icon img:first-child {
  left: 0;
  top: 0;
}
.sec-01 .container .title-area .title-icon img.icon-rotate {
  left: 5.31px;
  top: 5px;
  transform: rotate(180deg);
}
.sec-01 .container .title-area h3 {
  font-size: 2rem;
  line-height: normal;
  font-weight: 700;
  color: #111111;
  margin: 0;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .title-area h3 {
    font-size: 1.5rem;
  }
}
.sec-01 .container .post-count {
  font-size: 1rem;
  line-height: 1.5;
  color: #505050;
  margin-bottom: 1rem;
}
.sec-01 .container .post-count strong {
  color: var(--primary);
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .post-count {
    font-size: 0.875rem;
    margin-bottom: 0.75rem;
  }
}
.sec-01 .container h3 {
  font-size: var(--f3);
  line-height: var(--l3);
  margin-bottom: 1.875rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container h3 {
    font-size: 2rem;
    line-height: 1.3;
    margin-bottom: 1.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container h3 {
    font-size: 1.5rem;
    line-height: 1.3;
    margin-bottom: 1.25rem;
  }
}
.sec-01 .container .list {
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .list {
    margin-bottom: 1.875rem;
  }
}
.sec-01 .container .list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 0.5rem;
  border-bottom: 0.0625rem solid #e1e1e4;
  background: white;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .list li {
    padding: 1.25rem 0.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .list li {
    padding: 1rem 0.5rem;
  }
}
.sec-01 .container .list li:hover {
  background-color: #F8F8FA;
}
.sec-01 .container .list li .tit {
  flex: 1;
  display: flex;
  gap: 0.625rem;
  align-items: center;
}
.sec-01 .container .list li .tit a {
  display: block;
  flex: 1;
  min-width: 0;
}
.sec-01 .container .list li .tit a h4 {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 1.125rem;
  line-height: 1.625rem;
  font-weight: 600;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .list li .tit a h4 {
    font-size: 1rem;
    line-height: 1.5rem;
  }
}
.sec-01 .container .list li .date {
  width: 5.625rem;
  text-align: center;
  font-size: 1rem;
  line-height: 1.5rem;
  color: #767676;
  flex-shrink: 0;
  display: flex;
  gap: 0.625rem;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .list li .date {
    display: none;
  }
}
.sec-01 .container .list + .btn-area.adm {
  display: flex;
  justify-content: flex-end;
}
.sec-01 .container .gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .gallery {
    -moz-column-gap: 0.625rem;
         column-gap: 0.625rem;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery {
    gap: 1.25rem;
    margin-bottom: 1.875rem;
  }
}
.sec-01 .container .gallery li {
  width: 25rem;
  background: white;
  border-radius: 1.25rem;
  transition: all 0.3s ease;
  cursor: pointer;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .gallery li {
    width: calc(50% - 0.625rem);
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li {
    width: 100%;
    padding: 1rem;
  }
}
.sec-01 .container .gallery li:hover {
  box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.1);
  transform: translateY(-0.25rem);
}
.sec-01 .container .gallery li:hover .press-card-arrow .arrow-default {
  opacity: 0;
}
.sec-01 .container .gallery li:hover .press-card-arrow .arrow-hover {
  opacity: 1;
}
.sec-01 .container .gallery li:hover .press-card-arrow img {
  transform: translateX(0.25rem);
}
.sec-01 .container .gallery li a {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  border: 0.0625rem solid #E1E1E4;
  border-radius: 1.25rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li a {
    gap: 1rem;
  }
}
.sec-01 .container .gallery li .press-card-img {
  width: 100%;
  height: 15rem;
  border-radius: 1.25rem 1.25rem 0 0;
  overflow: hidden;
  background: #f8f8fa;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .gallery li .press-card-img {
    width: 100%;
    height: auto;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li .press-card-img {
    width: 100%;
    height: auto;
    aspect-ratio: 360/270;
  }
}
.sec-01 .container .gallery li .press-card-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.sec-01 .container .gallery li .press-card-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0 1.25rem 1.25rem 1.25rem;
}
.sec-01 .container .gallery li .press-card-content .press-card-text {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.sec-01 .container .gallery li .press-card-content .press-card-text .press-card-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.sec-01 .container .gallery li .press-card-content .press-card-text .press-card-info h3 {
  font-size: 1.125rem;
  line-height: 1.5;
  font-weight: 700;
  color: #111111;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li .press-card-content .press-card-text .press-card-info h3 {
    font-size: 1rem;
  }
}
.sec-01 .container .gallery li .press-card-content .press-card-text .press-card-info p {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #767676;
  height: 2.625rem;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li .press-card-content .press-card-text .press-card-info p {
    font-size: 0.8125rem;
  }
}
.sec-01 .container .gallery li .press-card-content .press-card-text .press-card-date {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #767676;
  margin: 0;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .gallery li .press-card-content .press-card-text .press-card-date {
    font-size: 0.8125rem;
  }
}
.sec-01 .container .gallery li:hover .press-card-arrow .arrow-default {
  opacity: 0;
}
.sec-01 .container .gallery li:hover .press-card-arrow .arrow-hover {
  opacity: 1;
}
.sec-01 .container .gallery + .btn-area.adm {
  display: flex;
  justify-content: flex-end;
}
.sec-01 .container .view {
  border-top: 0.125rem solid var(--line1);
  margin-bottom: 1.875rem;
}
.sec-01 .container .view .cont-01 {
  height: 5rem;
  display: flex;
  padding: 1.6875rem 2rem;
  justify-content: space-between;
  border-bottom: 0.0625rem solid var(--line2);
  font-size: var(--f6);
  line-height: var(--l6);
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-01 {
    height: auto;
    min-height: 4rem;
    padding: 1.25rem 1.5rem;
    flex-wrap: wrap;
    gap: 0.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-01 {
    height: auto;
    padding: 1rem;
    flex-flow: column nowrap;
    gap: 0.625rem;
  }
}
.sec-01 .container .view .cont-01 h4 {
  font-weight: 500;
  width: calc(100% - 8.25rem);
  margin-right: 2rem;
  word-break: break-word;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-01 h4 {
    width: 100%;
    margin-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-01 h4 {
    width: 100%;
    margin-right: 0;
  }
}
.sec-01 .container .view .cont-01 span {
  width: 6.25rem;
  text-align: right;
  color: var(--font3);
  flex-shrink: 0;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-01 span {
    width: auto;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-01 span {
    font-size: 0.875rem;
    text-align: unset;
  }
}
.sec-01 .container .view .cont-02 {
  padding: 2.5rem 2rem 3.75rem;
  border-bottom: 0.0625rem solid var(--line2);
  word-break: break-word;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-02 {
    padding: 2rem 1.5rem 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 {
    padding: 1.5rem 1rem 2rem;
  }
}
.sec-01 .container .view .cont-02 img {
  max-width: 100%;
  width: auto;
  display: block;
  height: auto;
  margin: auto;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-02 img {
    max-width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 img {
    max-width: 100%;
  }
}
.sec-01 .container .view .cont-02 p {
  font-size: 1rem;
  line-height: 1.625;
  word-break: break-word;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-02 p {
    font-size: 0.9375rem;
    line-height: 1.6;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 p {
    font-size: 0.875rem;
    line-height: 1.6;
  }
}
.sec-01 .container .view .cont-02 .ql-editor, .sec-01 .container .view .cont-02 .ql-container {
  font-size: 1rem;
  overflow-wrap: break-word;
  word-break: break-word;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view .cont-02 .ql-editor, .sec-01 .container .view .cont-02 .ql-container {
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 .ql-editor, .sec-01 .container .view .cont-02 .ql-container {
    font-size: 0.875rem;
  }
}
.sec-01 .container .view .cont-02 .ql-editor img, .sec-01 .container .view .cont-02 .ql-container img {
  max-width: 100% !important;
  height: auto !important;
  display: block;
  margin: 1rem auto;
}
.sec-01 .container .view .cont-02 .ql-editor iframe, .sec-01 .container .view .cont-02 .ql-editor video, .sec-01 .container .view .cont-02 .ql-container iframe, .sec-01 .container .view .cont-02 .ql-container video {
  max-width: 100% !important;
  height: auto !important;
}
.sec-01 .container .view .cont-02 .ql-editor table, .sec-01 .container .view .cont-02 .ql-container table {
  max-width: 100%;
  overflow-x: auto;
  display: block;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 .ql-editor table, .sec-01 .container .view .cont-02 .ql-container table {
    font-size: 0.8125rem;
  }
}
.sec-01 .container .view .cont-02 .thumbnail-view {
  width: 31.25rem;
  height: auto;
  margin: auto;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 .thumbnail-view {
    width: 100%;
    height: auto;
  }
}
.sec-01 .container .view .cont-02 .thumbnail-view img {
  max-width: 100%;
  width: 100%;
  height: auto;
}
.sec-01 .container .view .cont-02 > img {
  max-width: 100% !important;
  height: auto !important;
}
.sec-01 .container .view .cont-02 iframe, .sec-01 .container .view .cont-02 video, .sec-01 .container .view .cont-02 embed, .sec-01 .container .view .cont-02 object {
  max-width: 100% !important;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view .cont-02 iframe, .sec-01 .container .view .cont-02 video, .sec-01 .container .view .cont-02 embed, .sec-01 .container .view .cont-02 object {
    height: auto !important;
  }
}
.sec-01 .container .view .cont-03 > div {
  height: 3.125rem;
  display: flex;
  align-items: center;
  color: var(--font2);
}
.sec-01 .container .view .cont-03 > div img {
  width: 2.5rem;
  height: 2.5rem;
}
.sec-01 .container .view .cont-03 > div span {
  display: block;
}
.sec-01 .container .view .cont-03 > div span:first-of-type {
  width: 1.875rem;
  margin-right: 2rem;
}
.sec-01 .container .view .cont-03 > div a {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: calc(100% - 6.275rem);
}
.sec-01 .container .view + .btn-area {
  display: flex;
  gap: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view + .btn-area {
    flex-direction: column;
    gap: 0.75rem;
  }
}
.sec-01 .container .view + .btn-area.adm {
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view + .btn-area.adm {
    flex-direction: row;
  }
}
.sec-01 .container .view + .btn-area.adm .adm {
  display: flex;
  gap: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view + .btn-area.adm .adm {
    flex-direction: row;
    gap: 0.75rem;
  }
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .view + .btn-area .main-btn, .sec-01 .container .view + .btn-area .sub-btn, .sec-01 .container .view + .btn-area .go-all, .sec-01 .container .view + .btn-area .go-modify, .sec-01 .container .view + .btn-area .delete {
    padding: 0.75rem 1.5rem;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .view + .btn-area .main-btn, .sec-01 .container .view + .btn-area .sub-btn, .sec-01 .container .view + .btn-area .go-all, .sec-01 .container .view + .btn-area .go-modify, .sec-01 .container .view + .btn-area .delete {
    width: -moz-fit-content;
    width: fit-content;
    padding: 0.875rem 1rem;
    font-size: 0.875rem;
  }
}
.sec-01 .container .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  background: white;
  padding: 8px 20px;
  border-radius: 113px;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .pagination {
    padding: 6px 16px;
    gap: 2px;
  }
}
.sec-01 .container .pagination a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: #505050;
  font-size: 18px;
  line-height: 1.5;
  font-weight: 400;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .pagination a {
    width: 32px;
    height: 32px;
    font-size: 16px;
  }
}
.sec-01 .container .pagination a.page-num {
  padding: 11px 18px;
}
.sec-01 .container .pagination a.page-num.current {
  color: var(--primary);
  font-weight: 700;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
  text-underline-position: from-font;
}
.sec-01 .container .pagination a.page-first svg, .sec-01 .container .pagination a.page-prev svg, .sec-01 .container .pagination a.page-next svg, .sec-01 .container .pagination a.page-last svg {
  width: 40px;
  height: 40px;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .pagination a.page-first svg, .sec-01 .container .pagination a.page-prev svg, .sec-01 .container .pagination a.page-next svg, .sec-01 .container .pagination a.page-last svg {
    width: 32px;
    height: 32px;
  }
}
.sec-01 .container .pagination a img {
  border: 0.0625rem solid var(--line2);
}
.sec-01 .container .form {
  border-top: 0.125rem solid var(--line1);
}
.sec-01 .container .form article {
  border-bottom: 0.0625rem solid var(--line2);
  margin-bottom: 1.875rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article {
    margin-bottom: 1.25rem;
  }
}
.sec-01 .container .form article > div {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div {
    flex-direction: column;
  }
}
.sec-01 .container .form article > div .tit {
  width: 12.5rem;
  line-height: 3.75rem;
  text-align: center;
  background: rgba(var(--main-rgb), 0.08);
  font-size: var(--f6);
  border-bottom: 0.0625rem solid #fff;
  flex-shrink: 0;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article > div .tit {
    width: 10rem;
    line-height: 3.25rem;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div .tit {
    width: 100%;
    line-height: 2.5rem;
    font-size: 0.875rem;
    border-bottom: none;
  }
}
.sec-01 .container .form article > div .cont {
  width: calc(100% - 12.5rem);
  border-bottom: 0.0625rem solid var(--line2);
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article > div .cont {
    width: calc(100% - 10rem);
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div .cont {
    width: 100%;
  }
}
.sec-01 .container .form article > div .cont label {
  display: block;
  height: 100%;
  cursor: pointer;
  line-height: 3.75rem;
  padding: 0 2rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article > div .cont label {
    line-height: 3.25rem;
    padding: 0 1.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div .cont label {
    line-height: 2.5rem;
    padding: 0 1rem;
  }
}
.sec-01 .container .form article > div.cont-03 .cont {
  min-height: 43.75rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article > div.cont-03 .cont {
    min-height: 31.25rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div.cont-03 .cont {
    min-height: 25rem;
  }
}
.sec-01 .container .form article > div.cont-03 .cont .ql-toolbar.ql-snow {
  border: none;
  border-bottom: 0.0625rem solid var(--line2);
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div.cont-03 .cont .ql-toolbar.ql-snow {
    padding: 0.5rem;
  }
}
.sec-01 .container .form article > div.cont-03 .cont #editor {
  height: calc(100% - 2.625rem);
  border: none;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div.cont-03 .cont #editor {
    font-size: 0.875rem;
  }
}
.sec-01 .container .form article > div:last-of-type .tit, .sec-01 .container .form article > div:last-of-type .cont {
  border-bottom: none;
}
.sec-01 .container .form article > div input:focus {
  outline: none;
}
.sec-01 .container .form article > div input[type=file] {
  display: none;
}
.sec-01 .container .form article > div input[type=text] {
  border: none;
  width: 100%;
  height: 100%;
  padding: 0 2rem;
  font-size: 1rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article > div input[type=text] {
    padding: 0 1.5rem;
    font-size: 1rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article > div input[type=text] {
    padding: 1rem;
    font-size: 1rem;
  }
}
.sec-01 .container .form article .file-label {
  display: flex;
  height: 100%;
  padding: 0.5rem 0;
  align-items: center;
  font-size: var(--f8);
  line-height: var(--l8);
  color: var(--color-font3);
  cursor: pointer;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article .file-label {
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article .file-label {
    font-size: 0.875rem;
    padding: 0.375rem 0;
  }
}
.sec-01 .container .form article .file-label .button {
  padding: 0.375rem 1rem;
  background: #F1F1F5;
  display: inline-block;
  box-shadow: none;
  border: none;
  font-size: var(--f8);
  line-height: var(--l8);
  margin-right: 8px;
  letter-spacing: -0.025em;
  color: var(--color-font1);
  font-weight: 400;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article .file-label .button {
    padding: 0.375rem 0.875rem;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article .file-label .button {
    padding: 0.3125rem 0.75rem;
    font-size: 0.875rem;
    margin-right: 0.5rem;
  }
}
.sec-01 .container .form article .filelist {
  margin: 0.7969rem 2rem;
  height: 2.1563rem;
  padding: 0.375rem 2.25rem 0.375rem 1rem;
  position: relative;
  background: #F8F8FA;
  vertical-align: middle;
  display: inline-block;
  font-size: 0;
  font-weight: 400;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article .filelist {
    margin: 0.625rem 1.5rem;
    height: auto;
    min-height: 2rem;
    padding: 0.375rem 2rem 0.375rem 0.875rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article .filelist {
    margin: 0.5rem 1rem;
    padding: 0.375rem 1.75rem 0.375rem 0.75rem;
  }
}
.sec-01 .container .form article .filelist span {
  max-width: 60.25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: inline-block;
  font-size: var(--f8);
  line-height: var(--l8);
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article .filelist span {
    max-width: 23.25rem;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article .filelist span {
    max-width: calc(100vw - 6rem);
    font-size: 0.875rem;
  }
}
.sec-01 .container .form article .filelist .remove {
  position: absolute;
  width: 1.25rem;
  height: 1.25rem;
  right: 0.5rem;
  top: 50%;
  margin-top: -0.625rem;
  text-indent: -9999px;
  background: url(../../../images/bbs/x.svg) no-repeat center center/80%;
  border: none;
  box-shadow: none;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article .filelist .remove {
    width: 1rem;
    height: 1rem;
    margin-top: -0.5rem;
  }
}
.sec-01 .container .form article + .btn-area {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article + .btn-area {
    flex-direction: column;
    gap: 0.75rem;
  }
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .sec-01 .container .form article + .btn-area .main-btn, .sec-01 .container .form article + .btn-area .sub-btn {
    padding: 0.75rem 1.5rem;
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 767px) {
  .sec-01 .container .form article + .btn-area .main-btn, .sec-01 .container .form article + .btn-area .sub-btn {
    width: 100%;
    padding: 0.875rem 1rem;
    font-size: 0.875rem;
  }
}
.sec-01 .container .form input[type=checkbox] {
  display: none;
}

.modal_bg {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 9999;
  justify-content: center;
  align-items: center;
}
.modal_bg.pop {
  display: flex;
}

.modal-content {
  background: white;
  border-radius: 1rem;
  padding: 2.5rem;
  max-width: 33.25rem;
  width: 90%;
  box-shadow: 0 0.25rem 1.25rem rgba(0, 0, 0, 0.15);
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .modal-content {
    padding: 2rem 1.5rem;
    max-width: calc(100% - 2rem);
  }
}
.modal-content h3 {
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 700;
  color: #111111;
  margin: 0 0 1.25rem 0;
}
@media only screen and (max-width: 767px) {
  .modal-content h3 {
    font-size: 1.25rem;
    margin-bottom: 1rem;
  }
}
.modal-content p {
  font-size: 1rem;
  line-height: 1.6;
  color: #505050;
  margin: 0 0 0.5rem 0;
}
@media only screen and (max-width: 767px) {
  .modal-content p {
    font-size: 0.9375rem;
  }
}
.modal-content p:last-of-type {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 767px) {
  .modal-content p:last-of-type {
    margin-bottom: 1.5rem;
  }
}
.modal-content .btn-wrap {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  .modal-content .btn-wrap {
    gap: 0.5rem;
  }
}
.modal-content .btn-wrap a {
  flex: 1;
  padding: 0.875rem 1.5rem;
  border-radius: 0.5rem;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
  border: none;
}
@media only screen and (max-width: 767px) {
  .modal-content .btn-wrap a {
    padding: 0.75rem 1rem;
    font-size: 0.9375rem;
  }
}
.modal-content .btn-wrap a.cancel {
  background: #f1f1f5;
  color: #505050;
}
.modal-content .btn-wrap a.cancel:hover {
  background: #e1e1e4;
}
.modal-content .btn-wrap a.deleteBtn, .modal-content .btn-wrap a.registrationBtn, .modal-content .btn-wrap a.unregisterBtn {
  background: var(--primary);
  color: white;
}
.modal-content .btn-wrap a.deleteBtn:hover, .modal-content .btn-wrap a.registrationBtn:hover, .modal-content .btn-wrap a.unregisterBtn:hover {
  background: #2563eb;
}

.delete-modal .btn-wrap a.deleteBtn {
  background: #ef4444;
}
.delete-modal .btn-wrap a.deleteBtn:hover {
  background: #dc2626;
}