/* 검색 영역 */
.board-search {
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(90deg, #fffefd 0%, #e1d8cd 63.5%, #ffffff 100%);
  padding: 46px var(--spacing-m);
}

.board-search-form {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  max-width: 540px;
  width: 100%;
  height: 72px;
  padding: 0 var(--spacing-s);
  border-radius: var(--radius-s);
  border: 2px solid var(--earth-200);
  box-shadow: 0px 0px 40px 0px var(--earth-100);
  background: var(--white);
}

.board-search-form:hover {
  border: 2px solid var(--earth-500);
}

.board-search-category-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-left: var(--spacing-xs);
  min-width: 82px;
  background-image: url('/site/basic/img/board/icon-select.svg');
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 10px 7px;
  font-weight: var(--medium);
  font-size: var(--body-1);
  color: var(--gray-900);
  word-break: keep-all;
  border: none;
  background-color: transparent;
}

.board-search-category-icon {
  display: flex;
}

.board-search-divider {
  width: 1px;
  height: 15px;
  background-color: var(--gray-200);
}

.board-search-input-wrapper {
  flex: 1;
  display: flex;
  align-items: center;
}

.board-search-input {
  background: transparent;
  font-weight: var(--medium);
  font-size: var(--body-2);
  color: var(--gray-400);
  border: none;
  outline: none;
  flex: 1;
  width: 100%;
}

.board-search-input::placeholder {
  color: var(--gray-400);
}

.board-search-icon {
  width: 40px;
  height: 40px;
}

/* 게시판 콘텐츠 */
.board-main {
  margin-top: var(--spacing-3xl);
}

.board-main .outline-card {
  margin-bottom: var(--spacing-m);
}

.board-controls {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--spacing-m);
}

.board-profile-card {
  margin: auto 0 var(--spacing-m);
}

.board-search-result {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  margin-top: var(--spacing-lm);
}

.board-search-result-title {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: normal;
  letter-spacing: 0px;
}

.board-search-filter-select {
  font-size: var(--H4);
  color: var(--violet-500);
}

/* 페이지 정보 */
.board-page-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  margin-bottom: var(--spacing-m);
}

.board-page-current {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  background-color: var(--gray-100);
  border-radius: var(--radius-xs);
}

.board-page-current-num {
  font-weight: var(--bold);
  font-size: var(--body-2);
  color: var(--gray-600);
}

.board-page-divider,
.board-page-total {
  font-weight: var(--medium);
  font-size: var(--body-2);
  color: var(--gray-400);
}

.board-total-count {
  font-weight: var(--medium);
  font-size: var(--body-1);
  color: var(--gray-600);
}

.board-total-count-num {
  font-weight: var(--bold);
  font-size: var(--body-1);
  color: var(--earth-500);
}

/* 게시판 테이블 */
.board-table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
}

.board-table-header-cell.title {
  padding-left: var(--spacing-m);
  text-align: left;
}

.board-table-header-cell {
  padding: var(--spacing-xs) var(--spacing-s);
  text-align: center;
  font-weight: var(--bold);
  font-size: var(--body-1);
  color: var(--white);
  line-height: 100%;
  background-color: var(--gray-600);
  width: inherit;
  box-sizing: border-box;
}

.board-table-cell {
  padding: var(--spacing-s);
  text-align: center;
  vertical-align: middle;
  width: inherit;
  box-sizing: border-box;
}

/* 구분선 */
.board-divider {
  width: 100%;
  height: 4px;
  box-shadow: inset 0px 0px 0px 1px var(--civic-gold);
}

.board-table-body {
  background-color: var(--white);
}

.board-table-row {
  height: 92px;
  border-bottom: 1px solid var(--gray-100);
}

.board-table .board-title {
  font-weight: var(--medium);
  font-size: var(--H6);
  color: var(--gray-900);
  text-decoration: none;
  line-height: 140%;
  letter-spacing: -0.5px;
}

.board-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  padding: var(--spacing-2xs) var(--spacing-xs);
  background-color: var(--gray-100);
  border-radius: var(--radius-xs);
  font-weight: var(--bold);
  font-size: var(--body-2);
  color: var(--gray-400);
  line-height: normal;
  letter-spacing: -0.5px;
}

.board-table-row:hover {
  background-color: var(--gray-50);
}

.board-animation:hover .push-right {
  padding-left: var(--spacing-xs);
  transition: var(--spring-transition);
}

.board-animation:hover .board-title {
  color: var(--gray-900);
  font-weight: var(--bold) !important;
  transition: var(--basic-transition);
  transform: scaleY(1.05);
}

.board-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px var(--spacing-s);
  margin: 1.5px 0;
  background-color: var(--violet-500);
  border-radius: var(--radius-xs);
  font-weight: var(--bold);
  font-size: var(--body-2);
  color: var(--white);
  height: 32px;
  word-break: keep-all;
  line-height: normal;
  letter-spacing: -0.5px;
}

.board-category.open {
  background-color: var(--earth-500);
}

.board-category.notice {
  background-color: var(--violet-900);
}

.board-category.closed {
  background-color: var(--gray-200);
  color: var(--gray-600);
}

.board-category.received {
  background-color: var(--white);
  color: var(--gray-600);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
}

.board-category.reviewing {
  background-color: var(--opinion-reviewing);
}

.board-category.completed {
  background-color: var(--opinion-completed);
}

.board-table .board-title-wrapper {
  padding-left: var(--spacing-xs);
}

.board-title-wrapper {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.board-title-wrapper .board-attachment-icon {
  min-width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.board-title-wrapper .board-lock-icon {
  min-width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.board-author {
  font-weight: var(--medium);
  font-size: var(--body-1);
  color: var(--gray-900);
  line-height: normal;
  letter-spacing: -0.5px;
}

.board-date {
  font-weight: var(--medium);
  font-size: var(--body-2);
  color: var(--gray-400);
  line-height: normal;
  letter-spacing: -0.5px;
}

.board-photo {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-ms);
  overflow: hidden;
}

.board-animation:hover .board-photo img {
  transform: scale(1.1);
  transition: var(--spring-transition);
}

.board-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: var(--spacing-2xs) var(--spacing-xs);
  font-weight: var(--semi-bold);
  font-size: var(--body-2);
  line-height: normal;
  letter-spacing: 0px;
  background-color: var(--gray-100);
  border-radius: var(--radius-xs);
}

.board-label.reviewing {
  background-color: var(--opinion-reviewing);
  color: var(--white);
}

.board-label-dot {
  --bg-color: var(--gray-200);
  display: inline-block;
  margin-right: var(--spacing-2xs);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--bg-color);
}

/* 5분 자유발언 */

.board-speech .board-post-content {
  gap: var(--spacing-m);
}

.board-speech-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  padding: var(--spacing-lm) 0;
}

.board-list .board-speech-item .board-title {
  line-height: 160%;
}

.board-speech-number {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 35px;
}

.board-speech-meta {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: var(--spacing-xs);
  min-width: 100px;
}

.board-speech-term {
  padding: var(--spacing-2xs) var(--spacing-xs);
  font-weight: var(--bold);
  font-size: var(--body-2);
  line-height: 100%;
  color: var(--civic-gold);
}

.board-speech-content {
  display: flex;
  gap: var(--spacing-ml);
}

.board-speaker-info {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 0 var(--spacing-2xs);
  gap: var(--spacing-xs);
}

.board-speaker-name {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: 26px;
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: -0.5px;
}

.board-speech-item:hover .board-photo img {
  transform: scale(1.1);
}

.board-animation:hover .board-speech-item .board-title {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.board-animation:hover .board-speech-item .board-label {
  background-color: var(--violet-500);
  color: var(--white);
  transition: var(--spring-transition);
}

/* 페이징 및 버튼 영역 */
.board-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.board-bottom-command {
  display: flex;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-lm);
}

.board-bottom-pagination {
  margin-top: var(--spacing-2xl);
}

.board-pagination {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}

.board-pagination-nav {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}

.board-pagination-btn {
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--white);
  border-radius: var(--radius-xs);
}

.board-pagination-btn:hover {
  background-color: var(--earth-50);
}

.board-pagination-btn#board-first-btn img,
.board-pagination-btn#board-last-btn img {
  width: 32px;
  height: 32px;
}

.board-pagination-btn#board-last-btn img {
  transform: rotate(180deg);
}

.board-pagination-btn#board-prev-btn img,
.board-pagination-btn#board-next-btn img {
  width: 24px;
  height: 24px;
}

.board-pagination-btn#board-prev-btn img {
  transform: rotate(180deg);
}

.board-pagination-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2xs);
  flex-wrap: wrap;
}

.board-pagination-number {
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: var(--radius-xs);
  font-weight: var(--bold);
  font-size: var(--body-2);
  text-decoration: none;
  line-height: 100%;
  letter-spacing: -0.5px;
}

.board-pagination-number.active {
  background-color: var(--earth-500);
  color: var(--white);
}

.board-pagination-number:not(.active) {
  background-color: var(--gray-50);
  color: var(--gray-600);
}

.board-pagination-number:not(.active):hover {
  background-color: var(--gray-100);
}

/* 게시글 상세 뷰 */

.board-main-content {
  display: flex;
  padding: var(--spacing-l) var(--spacing-m);
  border-top: 2px solid var(--gray-100);
  gap: var(--spacing-2xl);
}

.board-post-content {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  flex: 1;
  gap: var(--spacing-lm);
}

.speech-meta-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.speech-meta-title {
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: normal;
  letter-spacing: 0px;
  color: var(--gray-900);
}

.board-post-member {
  position: relative;
  align-self: flex-start;
  width: 320px;
  flex-shrink: 0;
  padding: var(--spacing-ml) var(--spacing-m);
  background-color: var(--gray-50);
  border-radius: var(--radius-l);
  padding: var(--spacing-ml) var(--spacing-m);
  overflow: hidden;
}

.board-post-member:after {
  content: '';
  display: block;
  width: 276px;
  height: 48px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  position: absolute;
  background: repeating-linear-gradient(
    to right,
    #e7e4e1 0px,
    #e7e4e1 3px,
    transparent 3px,
    transparent 12px
  );
  z-index: 1;
}

.board-post-member .member-profile {
  position: relative;
  z-index: 2;
}

.board-post-member .sub-member-btns {
  margin-top: var(--spacing-s);
}

.board-post-member .member-profile-row {
  justify-content: space-between;
}

.board-post-member .member-profile-photo {
  max-width: 144px;
  height: 201px;
  margin: 0 auto var(--spacing-m);
}

.board-post-member .member-profile-name {
  flex-direction: column;
  font-size: var(--H5);
}

.board-post-member .member-profile-role {
  margin-left: auto;
  margin-right: auto;
}

.board-post-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.board-post-header-bg {
  background: linear-gradient(90deg, #fffefd 0%, #e1d8cd 63.5%, #ffffff 100%);
  height: 16px;
  width: 100%;
}

.board-post-header-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-s);
  padding: var(--spacing-xl) var(--spacing-m);
}

.board-post-title-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
}

.board-post-title {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 0;
}

.board-post-title-text {
  color: var(--gray-900);
  font-weight: var(--bold);
  font-size: var(--H3);
  line-height: 140%;
  letter-spacing: 0;
  text-align: center;
}

.board-post-info {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-m);
}

.board-post-author {
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--earth-500);
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: -0.03em;
}

.board-post-meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-m);
}

.board-post-meta-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.board-post-meta-icon {
  display: flex;
  align-items: center;
  width: 24px;
  height: 24px;
}

.board-post-meta-text {
  color: var(--gray-500);
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 100%;
  letter-spacing: -0.03em;
}

.board-post-images {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-s);
}

.board-post-image {
  max-width: 720px;
  max-height: 480px;
  background: var(--gray-100);
  object-fit: cover;
  width: 100%;
}

.board-post-text {
  width: 100%;
  color: var(--gray-600);
  font-weight: var(--regular);
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: -0.03em;  
}
.board-post-text * {
  font-family: 'Pretendard' !important;
  line-height: 160% !important;
  font-size: 16px !important;
}

.board-attachments-box {
  display: flex;
  gap: var(--spacing-m);
  background: var(--gray-50);
  border-radius: var(--radius-ms);
  padding: var(--spacing-ml) var(--spacing-m);
}

.board-attachments-title {
  display: flex;
  align-items: center;
  height: 24px;
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 100%;
  letter-spacing: 0;
  flex-shrink: 0;
}

.board-attachments-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}

.board-attachment-item {
  display: flex;
  gap: var(--spacing-xs);
}

.board-attachment-wrapper {
  display: flex;
  align-items: flex-start;
  padding: 2px 0;
}

.board-attachments-box .board-attachment-icon {
  width: 24px;
  height: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.board-attachment-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
}

.board-attachment-text {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}

.board-attachment-name {
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: -0.03em;
  transition: all var(--basic-transition);
}

.board-attachment-download:hover .board-attachment-name {
  -webkit-text-stroke: 0.5px var(--gray-600);
}

.board-attachment-size {
  color: var(--gray-400);
  font-size: var(--body-2);
  line-height: 160%;
  letter-spacing: -0.03em;
}

.board-attachment-link {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-2xs);
  padding-left: var(--spacing-xs);
  height: 28px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xs);
}

.board-attachment-link:hover {
  background: var(--gray-100);
}

.board-attachment-link:active {
  background: var(--gray-200);
}

.board-attachment-link-text {
  color: var(--gray-600);
  font-size: var(--body-2);
  font-weight: var(--medium);
  line-height: 100%;
  letter-spacing: -0.05em;
}

.board-attachment-arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
}

.board-buttons {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--spacing-lm);
}

.board-button-manage {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
}

.board-nav {
  margin-top: var(--spacing-3xl);
}

.board-nav-line {
  background: #f9f7f1;
  border: 1px solid var(--civic-gold);
  height: 4px;
}

.board-nav-content {
  border-bottom: 1px solid var(--gray-100);
  display: flex;
  flex-direction: column;
}

.board-nav-item {
  display: flex;
  align-items: center;
  gap: 26px;
}

.board-nav-item:hover .board-nav-content-title {
  padding-left: var(--spacing-xs);
  font-weight: var(--bold);
}

.board-nav-title {
  display: flex;
  align-items: center;
}

.board-nav-icon {
  width: 24px;
  height: 24px;
}

.board-nav-icon.board-nav-up {
  transform: rotate(-90deg);
}

.board-nav-icon.board-nav-down {
  transform: rotate(90deg);
}

.board-nav-label {
  color: var(--gray-400);
  font-weight: var(--bold);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.03em;
  padding: 0 var(--spacing-2xs) 0 var(--spacing-xs);
  word-break: keep-all;
}

.board-nav-text {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-s) 0;
  flex: 1;
}

.board-nav-content-title {
  font-weight: var(--medium);
  font-size: var(--Subtitle-2);
  line-height: 140%;
  letter-spacing: -0.5px;
  flex: 1;
  transition: padding-left var(--spring-transition);
}

.board-nav-content-date {
  color: var(--gray-500);
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.03em;
}

/* 게시판 에디터 */

/* 에디터 제목 */
.board-create-title {
  margin-bottom: var(--spacing-m);
  font-weight: var(--bold);
  font-size: var(--H4);
  line-height: 160%;
  letter-spacing: -0.5px;
  color: var(--violet-900);
}

/* 폼 내부 버튼 */

.board-create-form-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--gray-600);
  color: var(--white);
  font-weight: var(--bold);
  text-align: center;
  border: none;
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.05em;
  border-radius: var(--radius-xs);
}

.board-create-form-btn:hover {
  background-color: var(--gray-900);
}

/* 라벨 컴포넌트 */
.board-create-label {
  width: 120px;
  flex-shrink: 0;
}

.board-create-label-wrapper {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding-top: 15px;
}

.board-create-label-text {
  font-weight: var(--bold);
  font-size: var(--Subtitle-2);
  line-height: normal;
  letter-spacing: -0.05em;
  color: var(--gray-600);
}

.board-create-required {
  color: var(--warning);
}

/* 폼 레이아웃 */

.board-create-form-inner {
  display: flex;
  flex-direction: column;
  background-color: var(--gray-50);
  border-radius: var(--radius-ms);
  padding: var(--spacing-ml);
}

.board-create-form-inner:not(:last-child) .agenda-add-meeting-btn {
  display: none;
}

.board-create-field-wrapper {
  display: flex;
  padding: var(--spacing-ml) 0;
  border-bottom: 1px solid var(--gray-100);
}

.board-create-field-wrapper:last-child {
  border-bottom: none;
}

.board-create-field {
  flex: 1;
  display: flex;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

.board-create-field:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.board-create-field.title {
  height: 64px;
  padding: 0;
  border-bottom: none;
}

.board-create-field.title .board-create-input-wrapper {
  font-size: var(--H6);
}

.board-create-field-inner {
  flex: 1;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

/* 입력 래퍼 */

.board-create-input-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  align-self: stretch;
  flex: 1;
  min-height: 48px;
  min-width: 100px;
  gap: var(--spacing-xs);
  box-shadow: inset 0 0 0 1px var(--gray-100);
  border-radius: var(--radius-xs);
  color: var(--gray-600);
  font-weight: var(--medium);
  font-size: var(--body-2);
  background-color: var(--white);
  overflow: hidden;
}

.board-create-field.title .board-create-input-wrapper {
  min-height: 64px;
  border-radius: var(--radius-s);
}

.board-create-input-wrapper.with-padding {
  padding: 0 var(--spacing-s);
}

.board-create-input-wrapper.small {
  max-width: 220px;
}

.board-create-input-wrapper:hover {
  box-shadow: inset 0 0 0 1px var(--violet-900);
  font-weight: var(--bold);
  color: var(--gray-900);
}

/* 입력 요소 */
.board-create-form input,
.board-create-form textarea {
  padding: 0 var(--spacing-s);
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  color: inherit;
  background-color: transparent;
  border: none;
  width: 100%;
  height: 100%;
  line-height: 100%;
  letter-spacing: -0.05em;
}

.board-create-form textarea {
  padding: var(--spacing-s);
  width:100% !important;
}

.board-create-form input:read-only,
.board-create-form textarea:read-only {
  background-color: var(--gray-200);
}

.board-create-form select:focus,
.board-create-form input:focus,
.board-create-form textarea:focus {
  outline: none;
}

.board-create-form input::placeholder,
.board-create-form textarea::placeholder {
  color: var(--gray-600);
}

.board-create-input-wrapper:hover input::placeholder,
.board-create-input-wrapper:hover textarea::placeholder {
  color: var(--gray-900);
}

.board-create-textarea {
  padding: var(--spacing-s) 0;
  min-height: 180px;
  font-size: var(--body-2);
  line-height: 160%;
  resize: none;
}

/* 체크박스 */
.board-create-checkbox-wrapper {
  display: flex;
  align-items: center;
  height: fit-content;
  gap: var(--spacing-xs);
  padding: 0;
}

.board-create-checkbox-check {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border: 2px solid var(--gray-200);
  border-radius: 50%;
  background-color: var(--white);
  cursor: pointer;
  appearance: none;
}

.board-create-checkbox-check::after {
  content: '';
  margin-top: -2px;
  width: 6px;
  height: 4px;
  border: 2px solid #c9cdd2;
  border-top: none;
  border-right: none;
  transform: rotate(-45deg);
}

.board-create-checkbox-label {
  display: flex;
  align-items: center;
  padding-left: var(--spacing-s);
  width: 100%;
  height: 46px;
  gap: var(--spacing-xs);
}

.board-create-checkbox-text {
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: 0;
  color: var(--gray-600);
}

.board-create-checkbox:checked + .board-create-checkbox-label {
  background-color: var(--violet-500);
}

.board-create-checkbox:checked + .board-create-checkbox-label .board-create-checkbox-text {
  color: var(--white);
}

.board-create-checkbox:checked + .board-create-checkbox-label .board-create-checkbox-check,
.board-create-checkbox:checked + .board-create-checkbox-label .board-create-checkbox-check::after {
  border-color: var(--violet-500);
}

/* 셀렉트 */
.board-create-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  height: 100%;
  background-image: url('/site/basic/img/board/icon-select.svg');
  background-repeat: no-repeat;
  background-position: right center;
  background-color: transparent;
  border: none;
}

/* 날짜 입력 */
.board-create-date-input {
  line-height: 100%;
  letter-spacing: -0.05em;
  gap: var(--spacing-xs);
}

.board-create-date-icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 시간 입력 */
.board-create-time-wrapper {
  display: flex;
  align-items: center;
  max-width: 165px;
}

.board-create-input-wrapper .board-create-time-input {
  height: 32px;
  border: 1px solid var(--gray-100);
  padding: 0;
  text-align: center;
  border-radius: var(--radius-2xs);
}

.board-create-input-wrapper:hover .board-create-time-input {
  background: var(--gray-100);
}

.board-create-time-separator {
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.05em;
  color: var(--gray-600);
}

/* 인원 입력 */
.board-create-person-text {
  margin-right: var(--spacing-s);
}

/* 주소 입력 */

.board-create-address-zipcode {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  width: 100%;
}

.board-create-address-btn {
  height: 48px;
  max-width: 161px;
  width: 100%;
}

/* 체크박스 */
.board-create-checkbox-block {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex: 1;
}

/* 파일 입력 */
.board-create-file-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  flex: 1;
}

.board-create-file-item {
  margin-top: var(--spacing-xs);
}

.board-create-input-wrapper .board-create-file-input {
  color: var(--gray-600);
  font-weight: var(--medium);
}

.board-create-file-input {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  cursor: pointer;
}

.board-create-file-icon {
  width: 16px;
  height: 16px;
}

.board-create-file-name {
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 140%;
  letter-spacing: -0.05em;
}

.board-create-file-text {
  max-width: 48px;
  width: 100%;
  height: 28px;
  padding: 4px 8px;
}

.board-create-file-delete {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--spacing-xs);
  width: 100%;
}

.board-create-file-delete:hover .board-create-form-btn {
  background-color: var(--gray-900);
}

.board-create-file-delete:active .board-create-form-btn {
  background-color: var(--error);
}

.board-create-file-delete:active .board-create-file-name {
  color: var(--error);
}

/* 버튼 */

.board-create-form-footer {
  margin-top: var(--spacing-2xl);
}

.board-create-form-btns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
}

/* 에디터 툴바 */

.board-create-editor-sample {
  max-width: 872px;
  width: 100%;
  height: 74px;
  object-fit: cover;
  margin-top: 12px;
  margin-bottom: 6px;
  margin-left: 8px;
}

.board-create-field.editor {
  border-bottom: 1px solid var(--gray-100);
  padding: var(--spacing-m) 0;
}

.board-create-field.editor .board-create-input-wrapper {
  flex-direction: column;
  align-items: flex-start;
  min-height: auto;
  border-radius: 0;
}

.board-create-editor-toolbar {
  width: 100%;
  border-bottom: 1px solid var(--gray-100);
}

.board-create-step-footer {
  margin-top: 10px;
  padding-top: var(--spacing-m);
}

.board-create-step-btns {
  display: flex;
  gap: var(--spacing-2xs);
}

/* 달력 인풋 */

.dt-picker-container {
  position: relative;
}

.dt-calendar-popup {
  display: none;
  position: absolute;
  padding: 16px;
  top: calc(100% + var(--spacing-xs));
  max-width: 280px;
  min-width: 252px;
  font-family: Inter;
  line-height: 100%;
  letter-spacing: -0.05em;
  background: rgba(232, 235, 237, 0.7);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-ms);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100), 10px 10px 40px 0px rgba(0, 0, 0, 0.1);
  z-index: 1000;
}

.dt-calendar-popup.dt-calendar--visible {
  display: block;
}

.dt-calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-s);
}

.dt-nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xs);
  border-radius: 50%;
  background-color: var(--white);
  border: none;
}

.dt-nav-button:hover {
  background-color: var(--gray-200);
}

.dt-nav-button-icon {
  width: 24px;
  height: 24px;
}

.dt-nav-button.disabled .dt-nav-button-icon {
  opacity: 0.5;
}

#dt-prev-month .dt-nav-button-icon,
.dt-prev-month .dt-nav-button-icon{
  transform: rotate(180deg);
}

.dt-year-month-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}

.dt-year-month-select {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 32px;
  min-width: 72px;
  padding-left: var(--spacing-xs);
  border-radius: var(--radius-xs);
  font-size: var(--body-2);
  font-weight: var(--bold);
  color: var(--gray-900);
  background: var(--white) url('/site/basic/img/icons/icon-breadcrumb-arrow.svg') no-repeat right
    center / 24px 24px;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.dt-calendar-grid {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.dt-weekdays {
  display: flex;
  gap: var(--spacing-2xs);
}

.dt-weekday {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  font-size: var(--Caption);
  font-weight: var(--bold);
  color: var(--gray-600);
}

.dt-dates {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2xs);
}

.dt-date {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-2xs);
  background-color: var(--white);
  font-size: var(--body-2);
  font-weight: var(--medium);
  color: var(--gray-600);
  border: none;
}

.dt-date:hover {
  background-color: var(--gray-200);
}

.dt-date.dt-date-today {
  color: var(--gray-900);
  font-weight: var(--bold);
  border: 1px solid var(--gray-900);
}

.dt-date.dt-date-selected {
  background-color: var(--violet-500);
  font-weight: var(--bold);
  color: var(--white);
}

.dt-date.dt-date-selected-end {
  background-color: var(--earth-500);
  font-weight: var(--bold);
  color: var(--white);
}

.dt-date.dt-date-in-range {
  background-color: var(--violet-100);
}

.dt-calendar-footer {
  display: flex;
  justify-content: flex-end;
  border-top: 1px solid var(--gray-100);
  padding-top: var(--spacing-xs);
  margin-top: var(--spacing-s);
}

.dt-close-button {
  width: 64px;
  height: 28px;
  background-color: var(--white);
  border: none;
  border-radius: var(--radius-xs);
  color: var(--gray-600);
  font-weight: var(--bold);
  font-size: var(--body-2);
  text-align: center;
}

.dt-close-button:hover {
  background-color: var(--gray-50);
}

.dt-input:focus-visible,
.dt-nav-button:focus-visible,
.dt-year-month-select:focus-visible,
.dt-date:focus-visible,
.dt-close-button:focus-visible {
  outline: none;
}

.dt-calendar-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex: 1;
  max-width: 467px;
  flex-wrap: wrap;
}

.calendar-trigger {
  position: relative;
}

/* 게시판 리스트 */
.board-list {
  display: flex;
  flex-direction: column;
}

.board-list .board-list-item {
  border-bottom: 1px solid var(--gray-100);
}

.board-list .board-list-content {
  display: flex;
  gap: var(--spacing-ml);
  padding: var(--spacing-m) 0;
}

.board-list .board-session {
  display: flex;
  align-items: center;
  align-self: flex-start;
  justify-content: center;
  padding: var(--spacing-2xs) var(--spacing-xs);
  min-width: 92px;
  width: fit-content;
  background-color: var(--gray-600);
  border-radius: var(--radius-xs);
  font-size: var(--H6);
  font-weight: var(--bold);
  line-height: 100%;
  color: var(--white);
  transition: all var(--spring-transition);
}

.board-animation:hover .board-session,
.board-session.session-olive {
  background-color: var(--olive);
}

.board-list .board-body {
  flex: 1;
}

.board-list .board-header {
  margin-bottom: var(--spacing-m);
}

.board-list .board-title {
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: 140%;
  letter-spacing: -0.5px;
  margin-bottom: var(--spacing-s);
}

.board-list .board-title.fw-md {
  font-weight: var(--medium);
}

.board-list .board-date {
  display: flex;
  font-weight: var(--bold);
  font-size: var(--body-2);
  line-height: normal;
  letter-spacing: 0px;
  color: var(--gray-400);
}

.board-list .board-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2xs);
  padding: var(--spacing-s);
  background-color: var(--gray-50);
  border-radius: var(--radius-s);
}

.board-list .board-tag {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  font-size: var(--body-2);
  font-weight: var(--bold);
}

.board-list .board-tag-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.board-top-caption {
  font-size: var(--body-2);
}

.board-filter-wrapper {
  margin-bottom: var(--spacing-m);
}

.board-filter {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.board-filter-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

/* 보도자료 */

.news-list {
  display: flex;
  flex-direction: column;
}

.news-item {
  display: flex;
  gap: var(--spacing-ml);
  padding: var(--spacing-m) 0;
  border-bottom: 1px solid var(--gray-100);
}

.news-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
}

.article-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}

.article-meta {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.article-category {
  color: var(--violet-500);
  font-size: var(--body-2);
  font-weight: var(--bold);
  line-height: 100%;
  letter-spacing: 0px;
}

.article-title {
  color: var(--gray-900);
  font-size: var(--H5);
  font-weight: var(--bold);
  line-height: 140%;
  letter-spacing: 0px;
}

.article-date {
  color: var(--gray-400);
  font-size: var(--body-2);
  font-weight: var(--medium);
  line-height: 160%;
  letter-spacing: 0px;
}

.board-participations {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
}

.participation-label {
  font-size: var(--Subtitle-2);
  font-weight: var(--bold);
  line-height: 160%;
  letter-spacing: 0px;
}

.participant-list {
  display: flex;
  gap: var(--spacing-2xs);
}

.participant-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  overflow: hidden;
}

.participant-image {
  object-fit: cover;
}

.participation-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  width: calc(100% - 44px);
  overflow-x: auto;
  padding-bottom: 4px;
}

.group-name,
.member-count {
  color: var(--gray-600);
  font-size: var(--Subtitle-2);
  font-weight: var(--medium);
  line-height: 160%;
  letter-spacing: 0px;
}

.news-image {
  max-width: 376px;
  width: 100%;
  height: 199px;
  border-radius: var(--radius-ms);
  background-color: var(--gray-50);
  overflow: hidden;
  flex-shrink: 0;
}

.news-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.board-news-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
  min-width: 160px;
  margin-right: var(--spacing-2xs);
}

.board-news-info-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.board-news-info-text {
  font-weight: var(--medium);
  font-size: var(--Subtitle-1);
  line-height: 100%;
  letter-spacing: 0px;
}

.board-news-info-time-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}

.board-news-info-time {
  width: fit-content;
  padding: var(--spacing-xs);
  font-weight: var(--semi-bold);
  font-size: var(--body-1);
  line-height: normal;
  letter-spacing: 0px;
  border-radius: var(--radius-xs);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
}

.board-news-participants {
  align-self: flex-start;
  max-width: 200px;
  border-radius: var(--radius-ms);
  padding: var(--spacing-m) var(--spacing-ms);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
}

.board-news-participants-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  font-weight: var(--medium);
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: 0px;
  word-break: keep-all;
}

.board-news-participants-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2xs);
  margin-top: var(--spacing-s);
}

/* 커스텀 셀렉트 박스 */

.cs-select-label-wrapper {
  display: flex;
  align-items: center;
}

.cs-select {
  position: relative;
  width: fit-content;
}

.cs-select-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cs-select.bordered {
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
  padding: var(--spacing-xs);
  padding-left: var(--spacing-s);
  border-radius: var(--radius-s);
  background-color: var(--white);
}

.cs-select.bordered.cs-open {
  box-shadow: inset 0px 0px 0px 1px var(--gray-900);
}

.cs-select.with-img {
  padding-left: var(--spacing-xs);
}

.cs-select-img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin-right: var(--spacing-xs);
  border-radius: var(--radius-ms);
  overflow: hidden;
}

.cs-select.size-small .cs-select-text {
  min-width: 56px;
  margin-right: 10px;
  font-weight: var(--bold);
  font-size: var(--body-2);
  line-height: 160%;
  letter-spacing: -0.5px;
  color: var(--gray-600);
}

/* 네이티브 select 숨기기 */
.cs-select .cs-select-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 1;
}

.cs-select-box[aria-expanded='true'] .cs-arrow-icon,
.dropdown-trigger[aria-expanded='true'] .cs-arrow-icon {
  transform: rotate(-90deg);
}

.cs-select-text {
  font-weight: var(--bold);
  font-size: var(--H4);
  line-height: 160%;
  letter-spacing: -0.5px;
}

.cs-arrow-icon {
  display: flex;
  width: 24px;
  height: 24px;
  transform: rotate(90deg);
  transition: all var(--spring-transition);
}

.cs-select:hover .cs-select-text {
  color: var(--gray-900);
}

.cs-select-content:focus .cs-arrow-icon {
  transform: rotate(90deg);
}

/* 커스텀 셀렉터 드롭다운 */
.cs-dropdown {
  position: absolute;
  top: calc(100% + var(--spacing-xs));
  left: 0;
  max-height: 433px;
  box-shadow: 0px 0px 40px 0px #00000033;
  backdrop-filter: var(--header-blur);
  border-radius: var(--radius-l);
  overflow: hidden;
  z-index: 100;
}

.cs-dropdown-content {
  display: flex;
  flex-direction: column;
}

.cs-select-dropdown .cs-select-text {
  color: var(--gray-900);
}

.cs-dropdown-header {
  margin: var(--spacing-m);
  margin-bottom: var(--spacing-xs);
}

.cs-dropdown-header .modal-close-style {
  top: var(--spacing-m);
  right: var(--spacing-m);
  width: 32px;
  height: 32px;
}

.cs-term-selector {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  height: 32px;
}

.cs-term-text {
  font-weight: var(--bold);
  font-size: var(--Subtitle-1);
  line-height: 100%;
  letter-spacing: -0.05em;
  color: var(--gray-600);
}

.cs-term-arrow {
  width: 8px;
  height: 4px;
}

/* 의원 목록 */
.cs-member-list-container {
  width: 100%;
  max-height: 360px;
  overflow-y: auto;
  padding: var(--spacing-s) var(--spacing-m) var(--spacing-m);
}

.cs-member-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs);
}
.cs-member-list .member-popup-item {
  opacity: 1;
}
.cs-member-list .member-popup-item:hover {
  scale: 1;
  position: relative;
  z-index: 2;
}

.cs-member-item .member-popup-link {
  padding-right: var(--spacing-ml);
}

/* 의원 다중 선택 의원 목록 */
.cs-multiple-select {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.cs-member-multiple-select .board-label {
  font-weight: var(--medium);
}

.cs-member-multiple-dropdown,
.cs-member-multiple-dropdown .cs-member-list-container {
  max-height: unset;
}

.cs-member-multiple-dropdown .cs-member-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  padding-bottom: 0;
  gap: var(--spacing-2xs);
}

.cs-member-checkbox-block {
  display: flex;
  gap: var(--spacing-2xs);
  margin-bottom: var(--spacing-ms);
}

.cs-member-input-wrapper {
  border-radius: var(--radius-xs);
  background-color: var(--gray-100);
  overflow: hidden;
}

.cs-member-input-wrapper .board-create-checkbox-label {
  padding: var(--spacing-2xs) var(--spacing-xs);
  height: auto;
}

.board-create-checkbox-count {
  font-weight: var(--regular);
  font-size: var(--Caption);
  padding-bottom: 2px;
  letter-spacing: -0.05em;
  vertical-align: bottom;
}

.cs-member-multiple-dropdown .member-photo-wrap {
  width: 36px;
  height: 36px;
  margin: 0;
}

.cs-member-multiple-dropdown .member-name {
  color: var(--gray-400);
  font-size: var(--body-2);
  transition: all var(--spring-transition);
}

.cs-member-multiple-dropdown .cs-member-item .member-popup-link {
  width: 130px;
}

.cs-member-multiple-dropdown .member-popup-item:hover .member-name {
  color: var(--gray-600);
  padding-left: var(--spacing-xs);
}

.cs-member-multiple-dropdown .member-popup-item:hover .member-popup-link:not(.selected) {
  background-color: var(--gray-100);
  box-shadow: inset 0px 0px 0px 1px var(--gray-200);
}

.cs-member-multiple-dropdown .member-popup-link.selected .member-name {
  color: var(--gray-600);
}

.cs-member-multiple-dropdown .member-popup-link.selected {
  box-shadow: inset 0px 0px 0px 1px var(--gray-600);
}

.cs-member-multiple-selected {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2xs);
}

.cs-command-btns {
  display: flex;
  padding: 0 var(--spacing-m) var(--spacing-m);
  gap: var(--spacing-2xs);
}

/* 라이브 방송 섹션 */
.schedule_live {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-m) var(--spacing-ml);
  margin-bottom: var(--spacing-2xl);
  border-radius: var(--radius-ms) var(--radius-2xl) var(--radius-2xl) var(--radius-ms);
  background: var(--violet-900);
}

.schedule_live_info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs);
}

.schedule_live_status {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.schedule_live_badge {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-2xs) var(--spacing-xs);
  color: var(--white);
  font-weight: var(--bold);
  font-size: var(--body-2);
  background: var(--olive);
  border-radius: var(--radius-2xs);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_live_date {
  display: flex;
  align-items: center;
  height: 27px;
  color: var(--olive);
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_live_title {
  display: flex;
  align-items: center;
  height: 51px;
  gap: var(--spacing-xs);
  color: var(--white);
}

.schedule_live_heading {
  font-weight: var(--bold);
  font-size: var(--H5);
  line-height: 100%;
  letter-spacing: -0.05em;
}

.schedule_live_heading_separator {
  color: var(--gray-400);
  font-weight: var(--bold);
  font-size: var(--H4);
}

.schedule_live_link {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  padding: var(--spacing-s) var(--spacing-lm);
  border: 1px solid var(--violet-500);
  border-radius: var(--radius-l);
  background: linear-gradient(
    90deg,
    var(--violet-900) 0%,
    var(--violet-500) 63.5%,
    var(--violet-900) 100%
  );
}

.schedule_live_play_icon {
  width: 22px;
  height: 24px;
}

.schedule_live_text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs);
}

.schedule_live_text_title {
  color: var(--white);
  font-weight: var(--bold);
  font-size: var(--body-1);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_live_text_desc {
  color: var(--violet-200);
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: 0px;
}

/* 회기 일정 섹션 */
.schedule_header {
  display: flex;
  align-items: center;
  margin-bottom: var(--spacing-m);
  gap: var(--spacing-s);
}

.schedule_title {
  color: var(--gray-900);
  font-weight: var(--bold);
  font-size: var(--H4);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_view_toggle {
  display: flex;
  padding: 3px;
  gap: var(--spacing-2xs);
  background: var(--gray-100);
  border-radius: var(--radius-ms);
}

.schedule_view_btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: var(--spacing-xs) var(--spacing-s);
  border: none;
  border-radius: var(--radius-ms);
  background: none;
  color: var(--gray-400);
  font-size: var(--body-2);
  font-weight: var(--bold);
  background: var(--white);
  transition: all var(--spring-transition);
}

.schedule_view_icon {
  width: 18px;
  height: 18px;
  color: var(--gray-400);
}

.schedule_view_btn:hover {
  color: var(--gray-600);
}

.schedule_view_btn:hover .schedule_view_icon {
  color: var(--gray-600);
}

.schedule_view_btn.is_active {
  background: var(--gray-600);
  color: var(--white);
}

.schedule_view_btn.is_active .schedule_view_icon {
  color: var(--white);
}

.schedule-content[data-view='calendar'] {
  display: flex;
  background: var(--gray-50);
  box-shadow: 0px 0px 0px 4px var(--gray-100);
  border-radius: var(--radius-l);
  overflow: hidden;
}

/* 왼쪽 상세 일정 */
.schedule-left {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  max-width: 304px;
  width: 100%;
  flex-shrink: 0;
  border-radius: var(--radius-ms);
  background-color: var(--white);
  padding: var(--spacing-ml) var(--spacing-m);
}

.schedule_date {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.schedule_date_text {
  color: var(--olive);
  font-weight: var(--bold);
  font-size: var(--H5);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_date_title {
  color: var(--gray-900);
  font-weight: var(--medium);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_timeline {
  position: relative;
  margin-top: var(--spacing-ml);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  z-index: 0;
}

.schedule_timeline:before {
  position: absolute;
  top: 0;
  left: var(--spacing-s);
  content: '';
  display: inline-block;
  width: 1px;
  height: 100%;
  background: var(--gray-100);
  z-index: -1;
}

.schedule_timeline_item {
  display: flex;
  justify-content: space-between;
  border-radius: var(--radius-xs);
  box-shadow: inset 0px 0px 0px 1px #e6e6e6;
  background: var(--white);
  padding: var(--spacing-xs) var(--spacing-s);
}

.schedule_timeline_item.disabled {
  background: var(--gray-200);
}

.schedule_timeline_item.disabled .schedule_timeline_time:before {
  background: var(--gray-400);
}

.schedule_timeline_item.disabled .schedule_timeline_time {
  color: var(--gray-400);
}

.schedule_timeline_item.disabled .schedule_timeline_content {
  color: var(--gray-400);
  background: var(--gray-200);
}

.schedule_timeline_time {
  display: flex;
  align-items: center;
  color: var(--gray-600);
  font-weight: var(--semi-bold);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule_timeline_time:before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  background: var(--gray-600);
  margin-right: var(--spacing-xs);
  border-radius: 50%;
}

.schedule_timeline_content {
  padding: var(--spacing-2xs) var(--spacing-xs);
  color: var(--white);
  font-weight: var(--semi-bold);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: 0px;
  border-radius: var(--radius-xs);
}

.schedule_detail_actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.schedule_detail_actions .command-btn:first-child {
  width: 100%;
}

/* 빈 일정일 경우 */

.schedule-left-empty {
  justify-content: flex-start;
  gap: var(--spacing-ml);
}

.schedule-left-empty .empty-state {
  display: flex;
}

.schedule-left-empty .schedule_date_title,
.schedule-left-empty .schedule_timeline,
.schedule-left-empty .schedule_detail_actions {
  display: none;
}

/* 오른쪽 캘린더 */
.schedule-right {
  flex: 1;
  padding: var(--spacing-ml);
}

.schedule-calendar {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.schedule-calendar-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-m);
  margin-bottom: var(--spacing-m);
}

.schedule-calendar-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xs);
  background: var(--white);
  border-radius: 50%;
  transition: all var(--spring-transition);
}

.schedule-calendar-btn:hover {
  background: var(--gray-200);
}

.schedule-calendar-btn-icon {
  width: 24px;
  height: 24px;
}

.schedule-calendar-btn-prev .schedule-calendar-btn-icon {
  transform: rotate(180deg);
}

.schedule-calendar-title {
  font-size: var(--H3);
  font-weight: var(--T-black);
  color: var(--gray-900);
  line-height: 100%;
  letter-spacing: -0.05em;
}

.schedule-calendar-row-week {
  display: flex;
  height: 40px;
  background: var(--gray-600);
  border-radius: var(--radius-ms) var(--radius-ms) var(--radius-xs) var(--radius-xs);
}

.schedule-calendar-cell-week {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 0;
  color: var(--gray-200);
  font-weight: var(--bold);
  font-size: var(--Subtitle-2);
  line-height: 100%;
  letter-spacing: -0.05em;
}

.schedule-calendar-cell-week.sun {
  color: #fc6259;
}

.schedule-calendar-cell-week.sat {
  color: #4c93fd;
}

.schedule-calendar-table {
  width: 100%;
}

.schedule-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: minmax(45px, auto);
  gap: var(--spacing-2xs);
  margin-top: var(--spacing-xs);
}

.schedule-calendar-row {
  display: contents;
}

.schedule-calendar-cell {
  background: var(--white);
  border-radius: var(--radius-xs);
  overflow: hidden;
  min-height: 88px;
}

.schedule-calendar-cell.disabled {
  background: var(--gray-100);
}

.schedule-calendar-cell.sun {
  color: #fc6259;
}

.schedule-calendar-cell.sat {
  color: #4c93fd;
}

.schedule-calendar-cell.has-event {
  background: #d8e0ba;
  color: #3b4519;
}

.schedule-calendar-cell.selected {
  background: #9aaf4e;
}

.schedule-calendar-cell.selected .schedule-calendar-cell-date {
  color: var(--white);
}

.schedule-calendar-cell-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding: var(--spacing-xs);
  width: 100%;
  height: 100%;
  background: none;
  border: none;
  font: inherit;
  color: inherit;
  cursor: pointer;
}

.schedule-calendar-cell-btn:focus {
  outline: none;
}

.schedule-calendar-cell-btn:disabled {
  background: var(--gray-100);
  color: var(--gray-400);
  cursor: not-allowed;
}

.schedule-calendar-cell-date {
  height: 19px;
  color: var(--gray-600);
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.05em;
}

.schedule-calendar-cell.has-event .schedule-calendar-cell-date,
.schedule-calendar-cell.selected .schedule-calendar-cell-date {
  font-weight: var(--bold);
}

.schedule-calendar-cell.disabled .schedule-calendar-cell-date {
  color: var(--gray-400);
}

.schedule-calendar-event {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-2xs);
  color: var(--white);
}

.schedule-calendar-event-title {
  display: flex;
  align-items: center;
  height: 22px;
  padding: var(--spacing-2xs);
  border-radius: var(--radius-2xs);
  background: #2f3f61;
  font-size: var(--Caption);
  font-weight: var(--bold);
  line-height: 100%;
  color: var(--white);
}

.schedule-calendar-cell.disabled .schedule-calendar-event-title {
  background: var(--gray-400);
}

.schedule-calendar-event-dots {
  display: flex;
  width: fit-content;
  gap: 2px;
  padding: var(--spacing-2xs);
  background: var(--white);
  border-radius: var(--radius-xs);
}

.schedule-calendar-cell.disabled .schedule-calendar-event-dots {
  background: var(--gray-400);
}

.schedule-calendar-cell.disabled .schedule-calendar-dot {
  background: var(--gray-100);
}

.schedule-calendar-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--violet-500);
}

.event-calendar .schedule-calendar-event-dots {
  display: flex;
}

.event-calendar .schedule_timeline {
  max-height: 493px;
  overflow-y: auto;
}

.event-calendar .schedule_timeline_item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  padding: var(--spacing-s);
  background: var(--gray-50);
}

.event-calendar .schedule_timeline_content {
  padding: var(--spacing-xs);
  font-weight: var(--medium);
  font-size: var(--Subtitle-1);
  line-height: 160%;
  letter-spacing: 0px;
  background: var(--white);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
  color: var(--gray-900);
}

.event-calendar .schedule-left {
  max-width: 360px;
}

.main {
  background: var(--committee-main);
}

.operate {
  background: var(--committee-operate);
}

.plan {
  background: var(--committee-plan);
}

.culture {
  background: var(--committee-culture);
}

.economy {
  background: var(--committee-economy);
}

.budget {
  background: var(--committee-budget);
}

.schedule-calendar-legend {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  gap: var(--spacing-2xs);
  margin-top: var(--spacing-xs);
  padding: var(--spacing-xs) 0;
}

.schedule-calendar-legend-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  border-radius: var(--radius-xs);
  background: var(--white);
  padding: var(--spacing-2xs) var(--spacing-xs);
}

.schedule-calendar-legend-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.schedule-calendar-legend-label {
  font-size: var(--Caption);
  color: var(--gray-600);
  font-weight: var(--bold);
  line-height: 100%;
  letter-spacing: 0px;
}

/* 일정 상세 보기 */

.schedule-view-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lm);
}

.schedule-view-info {
  display: flex;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

.schedule-view-title-area {
  width: 120px;
}

.schedule-view-title {
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
  color: var(--gray-900);
}

.schedule-view-details {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}

.schedule-period-card {
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  height: 32px;
  background: var(--olive);
  border-radius: var(--radius-xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  gap: var(--spacing-xs);
}

.schedule-period-days {
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
  color: var(--white);
}

.schedule-period-dates {
  font-weight: var(--medium);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
  color: var(--white);
}

.schedule-period-dot {
  width: 4px;
  height: 4px;
  background: var(--white);
  border-radius: 50%;
}

.schedule-view-notice {
  font-size: var(--body-2);
  line-height: 100%;
  letter-spacing: -0.05em;
  color: var(--gray-600);
}

.schedule-view-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lm);
}

.schedule-view-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5xl);
}

.schedule-view-day {
  display: flex;
  gap: var(--spacing-lm);
  align-items: flex-start;
  animation: refresh-r 0.6s forwards cubic-bezier(0.25, 0.99, 0.24, 1);
}

.schedule-view-date-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--spacing-ms);
  position: sticky;
  top: calc(var(--header-high) + 40px);
  z-index: 1;
}

.schedule-view-date-info {  
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  font-weight: var(--bold);
  font-size: var(--H4);
}

.schedule-view-date {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  margin-right: var(--spacing-2xs);
  width: 136px;
}

.schedule-view-date-number {
  color: var(--gray-600);
}

.schedule-view-date-separator {
  color: var(--gray-400);
}

.schedule-view-date-day {
  color: var(--earth-500);
}

.schedule-view-day-content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
  padding: var(--spacing-2xs) 0;
  z-index: 0;
}

.schedule-view-day-content:before {
  content: '';
  position: absolute;
  left: var(--spacing-s);
  width: 0;
  height: 100%;
  border-left: 1px solid var(--gray-100);
  z-index: -1;
}

.schedule-view-timeline {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-m);
}

.schedule-view-timeline:last-child:before {
  content: '';
  position: absolute;
  left: var(--spacing-s);
  width: 100%;
  height: 100%;
  background: var(--white);
  z-index: -1;
}

.schedule-view-timeline:last-child .schedule-view-time-dot {
  display: none;
}

.schedule-view-time-block {
  display: flex;
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-xs);
  padding: var(--spacing-xs) var(--spacing-xs) var(--spacing-xs) var(--spacing-s);
  width: 100px;
  position: sticky;
  top: calc(var(--header-high) + 48px);
}

.schedule-view-time-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.schedule-view-time-dot {
  width: 4px;
  height: 4px;
  background: var(--gray-600);
  border-radius: 50%;
}

.schedule-view-time-text {
  font-weight: var(--semi-bold);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule-view-sessions {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  padding: var(--spacing-xs) 0 0;
  flex: 1;
}

.schedule-view-session-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.schedule-view-session-badge {
  background: var(--white);
  border-radius: var(--radius-xs);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.schedule-view-session-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.schedule-view-session-name {
  font-weight: var(--bold);
  font-size: var(--H6);
  line-height: 100%;
  letter-spacing: 0px;
}

.schedule-view-session-number {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 27px;
  border-radius: var(--radius-xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  font-weight: var(--bold);
  font-size: var(--body-1);
  letter-spacing: 0px;
  color: var(--white);
}

.schedule-view-agenda-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.schedule-view-agenda-item {
  display: flex;
  width: fit-content;
  background: var(--gray-50);
  border-radius: var(--spacing-s);
  padding: var(--spacing-s);
}

.schedule-view-agenda-box {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.schedule-view-agenda-box-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
}

ul.bullet-list > li.schedule-view-agenda-item {
  margin-left: 0;
}

.schedule-view-agenda-title {
  white-space: nowrap;
  font-weight: var(--semi-bold);
  font-size: var(--Subtitle-2);
  letter-spacing: 0px;
  margin-right: var(--spacing-xs);
}

.schedule-view-agenda-title-area {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
}

.schedule-view-agenda-tag {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--gray-400);
  border-radius: var(--radius-xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  font-weight: var(--medium);
  font-size: var(--body-2);
  line-height: 120%;
  letter-spacing: 0px;
  color: var(--white);
}

.schedule-view-agenda-description {
  padding: var(--spacing-xs);
  margin-left: calc(-1 * var(--spacing-s));
  font-size: var(--body-1);
  line-height: 160%;
  letter-spacing: -0.5px;
}

/* 일정 어드민 */

.schedule-create-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  margin-bottom: var(--spacing-2xl);
}

.schedule-create-title {
  display: flex;
  align-items: center;
  gap: 10px;
}

.schedule-create-title-divider {
  color: var(--gray-400);
  font-size: var(--H4);
  font-weight: var(--bold);
  line-height: 160%;
  letter-spacing: -0.5px;
}

.schedule-create-title-type {
  font-size: var(--H5);
  font-weight: var(--medium);
  line-height: 160%;
  letter-spacing: -0.5px;
}

.schedule-create-steps {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lm);
}

.schedule-create-step {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
}

.schedule-create-step-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  width: 100%;
}

.schedule-create-step-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 24px;
  background-color: var(--violet-900);
  border-radius: var(--radius-xs);
  color: var(--white);
  font-size: var(--body-2);
  font-weight: var(--bold);
  line-height: normal;
  letter-spacing: 0.05em;
}

.schedule-create-step-text {
  font-size: var(--H5);
  font-weight: var(--bold);
  color: var(--violet-900);
  line-height: normal;
  letter-spacing: -0.05em;
}

.schedule-create-meeting-types {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-2xs);
  padding-bottom: var(--spacing-ms);
}

.schedule-create-meeting-type {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
  border-radius: var(--radius-xs);
  box-shadow: inset 0px 0px 0px 1px var(--gray-100);
  background-color: var(--white);
}

.schedule-create-meeting-type.active {
  background-color: var(--bg-color);
  box-shadow: none;
}

.schedule-create-meeting-type.active .schedule-create-meeting-color {
  background-color: var(--white);
}

.schedule-create-meeting-type.active .schedule-create-meeting-name {
  color: var(--white);
}

.schedule-create-meeting-color {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.agenda-form-field {
  margin-top: 10px;
  flex-direction: column;
  gap: var(--spacing-s);
}

.agenda-input-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  padding: var(--spacing-m);
  padding-bottom: var(--spacing-xs);
  border-radius: var(--radius-ms);
  background: var(--white);
  border: 1px solid var(--gray-200);
}

.agenda-item-wrapper {
  display: flex;
  flex-direction: column;
  border-top: 2px solid var(--gray-900);
}

.agenda-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-xs);
  padding: var(--spacing-ms) 0;
  border-bottom: 1px solid var(--gray-100);
}

.agenda-item:last-child {
  border-bottom: none;
}

.agenda-item-content {
  display: flex;
  flex: 1;
  gap: var(--spacing-xs);
}

.agenda-inputs {
  display: flex;
  gap: var(--spacing-xs);
  width: 100%;
}

.agenda-delete-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: var(--form-input-high);
  transition: var(--spring-transition);
}

.agenda-delete-btn:hover svg path {
  stroke: var(--error);
  transition: var(--spring-transition);
}

.agenda-delete-btn:hover svg {
  transform: rotate(-180deg);
}

.agenda-delete-icon {
  width: 20px;
  height: 20px;
}

.agenda-delete-icon svg {
  transition: var(--spring-transition);
}

.schedule-create-detail-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
  width: 100%;
}

.schedule-create-agenda-inputs {
  display: flex;
  gap: var(--spacing-xs);
  width: 100%;
}

/* 안건 드래그 앤 드롭 관련 */
.agenda-drag-handle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: var(--form-input-high);
  cursor: grab;
  transition: var(--basic-transition);
}

.agenda-drag-handle:active,
.agenda-dragging .agenda-drag-handle {
  cursor: grabbing;
}

.agenda-drag-icon {
  width: 18px;
  height: 18px;
  opacity: 0.6;
  transition: var(--basic-transition);
}

.agenda-drag-handle:hover .agenda-drag-icon {
  opacity: 1;
}

.agenda-dragging {
  position: relative;
}

.agenda-sortable-ghost {
  opacity: 0.4;
  background-color: var(--violet-100);
  border-radius: var(--radius-xs);
}

.agenda-sortable-chosen {
  transform: scale(1.02);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  border-radius: var(--radius-xs);
  z-index: 1000;
}

.agenda-sortable-drag {
  transform: rotate(3deg);
  transition: none !important;
}

/* 공통 드래그 앤 드롭 스타일 */
.dragging {
  position: relative;
}

.sortable-ghost {
  opacity: 0.4;
  background-color: var(--violet-100);
  border: 2px dashed var(--violet-500);
  border-radius: var(--radius-xs);
}

.sortable-chosen {
  transform: scale(1.02);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  border-radius: var(--radius-xs);
  z-index: 1000;
}

.sortable-drag {
  transform: rotate(3deg);
  transition: none !important;
}

/* 공통 드래그 핸들 스타일 */
.drag-handle {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
  transition: var(--basic-transition);
}

.drag-handle:hover {
  background-color: var(--gray-100);
  border-radius: var(--radius-xs);
}

.drag-handle:active,
.dragging .drag-handle {
  cursor: grabbing;
}

.drag-icon {
  opacity: 0.6;
  transition: var(--basic-transition);
}

.drag-handle:hover .drag-icon {
  opacity: 1;
}

/* 캘린더 폼 가이드 */

.schedule-create-guide {
  position: absolute;
  width: fit-content;
  padding: 10px;
  font-weight: var(--bold);
  font-size: var(--body-2);
  line-height: 100%;
  color: var(--success);
  background: #3e7bfd1a;
  box-shadow: inset 0px 0px 0px 1px var(--success);
  border-radius: var(--radius-xs);
  backdrop-filter: blur(10px);
}

.agenda-guide {
  position: absolute;
  width: 100%;
  top: 35px;
}

.schedule-create-guide[data-target='agenda-guide-1'] {
  top: 0;
  left: 0;
}

.schedule-create-guide[data-target='agenda-guide-2'] {
  top: 199px;
  left: 114px;
}

.schedule-create-guide[data-target='agenda-guide-3'] {
  top: 775px;
  left: 191px;
}

.schedule-create-guide[data-target='agenda-guide-4'] {
  top: 914px;
  left: 89px;
}

.schedule-create-guide[data-target='agenda-guide-5'] {
  top: 990px;
  left: 113px;
}

.schedule-create-guide[data-target='agenda-guide-6'] {
  top: 1220px;
  left: 120px;
}

/* 연간 일정 */

.annual-title-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--spacing-xs);
}

.annual-meta-section {
  display: flex;
  align-items: center;
  gap: var(--spacing-m);
  font-size: var(--body-2);
  font-weight: var(--bold);
  line-height: 100%;
  letter-spacing: 0px;
}

.annual-legend-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.annual-legend-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: var(--spacing-2xs) var(--spacing-xs);
}

.annual-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.annual-blue {
  background: var(--committee-main);
}

.annual-orange {
  background: var(--orange);
}

.annual-summary-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--gray-50);
  border-radius: var(--radius-s);
  padding: var(--spacing-s);
  gap: var(--spacing-s);
  flex-wrap: wrap;
  line-height: normal;
}

.annual-total-section {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.annual-total {
  line-height: 160%;
  letter-spacing: 0px;
  font-weight: var(--bold);
  font-size: var(--H6);
}

.annual-summary-text {
  font-size: var(--Subtitle-1);
  font-weight: var(--medium);
  color: var(--gray-600);
  letter-spacing: 0px;
}

.annual-breakdown-section {
  display: flex;
  align-items: center;
  gap: var(--spacing-m);
}

.annual-breakdown-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: var(--body-1);
}

.annual-type-label {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}

.annual-type-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gray-400);
}

.annual-type-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.annual-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-400);
  border-radius: var(--radius-xs);
  padding: var(--spacing-2xs);
  font-weight: var(--bold);
  color: var(--white);
}

.annual-days {
  font-weight: var(--bold);
}

.annual-days-text {
  font-size: var(--body-1);
  font-weight: var(--bold);
  line-height: normal;
  letter-spacing: 0px;
}

.annual-days-style-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  border-radius: var(--radius-xs);
  box-shadow: inset 0 0 0 1px var(--gray-100);
  padding: var(--spacing-2xs) var(--spacing-xs);
  background: var(--white);
}

.annual-color-blue {
  color: var(--committee-main);
}

.annual-color-orange {
  color: var(--orange);
}

.annual-board {
  margin-top: var(--spacing-lm);
}

.annual-board-badge {
  margin-top: var(--spacing-xs);
}

.annual-agenda-card {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  padding: var(--spacing-s);
  background: var(--gray-50);
  border-radius: var(--radius-s);
  font-size: var(--body-1);
}

.annual-agenda-header {
  padding-top: var(--spacing-2xs);
  font-weight: var(--bold);
  line-height: normal;
  letter-spacing: 0px;
}
