/* body {
  padding: 5px 50px 20px 50px;
  font: 14px 'Lucida Grande', Helvetica, Arial, sans-serif;
}

a {
  color: #00b7ff;
}

div.row {
  padding: 10px 0px 10px 0px;
}

div.row:hover {
  padding: 10px 0px 10px 0px;
} */

html {
  font-size: 16px;
}

.page-editor .inactive {
  opacity: 0.2;
}

.ct-bg-bunker {
  background-color: #222831 !important;
}

.ct-bg-cloud-burst {
  background-color: #393e46 !important;
}

.ct-bg-iris-blue {
  background-color: #00adb5 !important;
}

.ct-bg-whisper {
  background-color: #eeeeee !important;
}

.modalWrap {
  padding: 30px 20px;
  background-color: #222;
}

.page-title-text {
  font-size: 1.4rem;
  font-weight: bold;
}

.input-btn {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
  gap: 10px;
}

.input-btn button {
  width: 100px;
  height: 40px;
  font-weight: bold;
}

.count-font {
  font-weight: bold;
  color: #667eea;
}

body input {
  height: 40px;
}

.notice-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid #d3d8e5;
}

.notice-title {
  width: 65%;
  min-width: 150px;
  font-weight: bold;
  font-size: 25px;
  margin-left: 10px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.notice-header .btn-area {
  margin: 5px;
}

.post-area {
  min-height: 400px;
}

.post-header {
  padding-bottom: 10px !important;
}

.post-body {
  padding: 10px !important;
  margin-top: 10px;
  height: auto;
  min-height: 500px;
  border-radius: 0.25rem;
  border: 1px solid #d3d8e5;
}

.comment-list {
  margin-top: 10px;
  border-top: 1px solid #d3d8e5;
}

.comment-item {
  margin: 10px 0px;
  border: 1px solid #d3d8e5;
  border-radius: 0.25rem;
}

.commet-item-top {
  padding: 0.375rem 0.75rem;
  border-bottom: 1px solid #d3d8e5;
  background-color: #f4f6fa;
}

.commet-item-bottom {
  padding: 0.375rem 0.75rem;
}

.comment-item-tools {
  display: flex;
  align-items: flex-start;
}

.comment-btn {
  height: 80px;
  font-size: 14px;
  background-color: #365ab8;
  color: #fff;
}

@media (max-width: 640px) {
  .comment-btn {
    margin-top: 10px;
    height: 40px;
  }
}

.profile-icon {
  width: 35px;
  height: 35px;
  background-color: #fff;
  border-radius: 50px;
  padding: 3px;
  margin-top: 3px;
}

#tab-content1 .item-container {
  display: flex;
  overflow-x: auto;
  white-space: nowrap;
  /* margin-bottom: 5px; */
}

#tab-content1 .item-container>.item {
  flex: 0 0 auto;
  margin-right: 10px;
  /* Adjust spacing between items as needed */
  display: flex;
  align-items: center;
  border: 1px solid #ddd;
  /* Add border to distinguish items */
  padding: 10px;
  /* Add padding inside each item */
  border-radius: 5px;
  /* Optional: Add rounded corners */
  background-color: #f9f9f9;
  /* Optional: Add background color */
}

#tab-content1 .item-container>.item.active {
  border-color: #007bff;
  /* Change border color for active item */
}

#tab-content1 .item>img {
  width: 100px;
  height: 100px;
  display: inline-block;
}

#tab-content1 .item-info {
  display: inline-block;
  width: 150px;
  margin-left: 10px;
  /* Adjust spacing between image and text as needed */
}

#tab-content1 .item-info>p {
  font-weight: bold;
}

#tab-content1 .item-info>div {
  width: 100%;
  font-size: 0.8rem;
  max-width: 150px;
  /* Limit the width of the description */
  overflow: hidden;
  /* Hide overflow text */
  text-overflow: ellipsis;
  /* Add ellipsis (...) for overflow text */
  white-space: nowrap;
  /* Prevent text from wrapping */
}

#tab-content1 .item-info>button {
  margin-top: 5px;
  /* Adjust spacing above the button as needed */
}

@media (max-width: 640px) {
  .notice-title {
    width: 100%;
    position: relative;
    top: 0;
  }

  .notice-header {
    display: block;
  }
}

@media (max-width: 860px) {

  .table-contact table th:nth-child(3),
  .table-contact table td:nth-child(3),
  .table-contact table th:nth-child(4),
  .table-contact table td:nth-child(4),
  .table-contact table th:nth-child(5),
  .table-contact table td:nth-child(5),
  .table-contact table th:nth-child(6),
  .table-contact table td:nth-child(6) {
    display: none;
  }

  .table-boarder table th:nth-child(1),
  .table-boarder table td:nth-child(1),
  .table-boarder table th:nth-child(2),
  .table-boarder table td:nth-child(2),
  .table-boarder table th:nth-child(4),
  .table-boarder table td:nth-child(4) {
    display: none;
  }

  .widget-chart .widget-numbers {
    font-size: 1.5rem;
  }
}

@media (max-width: 860px) {

  .table-contact table th:nth-child(3),
  .table-contact table td:nth-child(3),
  .table-contact table th:nth-child(4),
  .table-contact table td:nth-child(4) {
    display: none;
  }

  .table-boarder table th:nth-child(1),
  .table-boarder table td:nth-child(1),
  .table-boarder table th:nth-child(2),
  .table-boarder table td:nth-child(2),
  .table-boarder table th:nth-child(4),
  .table-boarder table td:nth-child(4) {
    display: none;
  }
}

/* 공통 */

.hoverTextDe:hover h4 {
  text-decoration: underline;
}

.title {
  font-size: 35px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 1px;
}

.subtitle {
  margin-top: -8px;
  text-align: center;
}

.displaynone {
  display: none;
}

.new-select-style {
  appearance: none;
  padding-right: 20px;
  height: 36px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  background: url('/image/arrow-down-icon.png') no-repeat right center;
  background-position: calc(100% - 10px) center;
}

/* 기본 스타일 */
/* ===== 검색 영역 — 디자인 가이드 검색 컴포넌트(옵션 B: 라벨 상단) =====
   가이드 .ds-filterbar 와 동일: 라벨 상단, 가이드 입력/포커스 링, 연결바·칸막이 제거,
   surface-alt 패널, 좁은 폭 자연 줄바꿈, 날짜범위 겹침 방지, 검색/초기화 우측·하단.
   구조상 .search-buttons 가 .search-row 안/밖 모두인 화면을 함께 대응. */
.defalut-search-form {
  margin-top: 10px;
  width: 100%;
  font-size: 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  padding: 16px;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}

.search-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  flex: 1 1 auto;
}

/* 개별 입력 그룹 — 라벨 상단(세로) */
.search-group {
  flex: 1 1 200px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}

/* 라벨 — 가이드 .ds-label */
.search-group label {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
  padding: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--slate-700);
}

/* 입력/셀렉트 — 가이드 .ds-input/.ds-select */
.search-group input,
.search-group select {
  width: 100%;
  height: auto;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
  transition: border-color 0.12s, box-shadow 0.12s;
}
.search-group input:focus,
.search-group select:focus {
  outline: none;
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px var(--brand-100);
}
.search-group input::placeholder {
  color: var(--text-subtle);
}

/* 입력 컨테이너 */
.search-input-group {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}
.search-input-group input,
.search-input-group select {
  flex: 1;
  min-width: 0;
}

/* 날짜 범위 그룹 — 입력 2개라 더 넓게(겹침 방지) */
.search-group:has(.search-date-input-group) {
  flex: 2 1 320px;
  min-width: 320px;
}

/* 버튼 — 우측·하단 정렬 (초기화=보조, 검색=주요) */
.search-buttons {
  display: flex;
  align-items: center;
  gap: 8px;
  align-self: flex-end;
  margin-left: auto;
}
.search-buttons button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  height: 40px;
  font-size: 14px;
  border-radius: var(--r-sm);
  padding: 0 16px;
  transition: all 0.2s;
}
.search-buttons button:first-child {
  background: var(--surface);
  border: 1px solid var(--border-strong);
}

/* 좁은 화면: 그룹 전체폭, 버튼 가로 꽉 */
@media (max-width: 640px) {
  .search-group,
  .search-group:has(.search-date-input-group) {
    flex-basis: 100%;
    min-width: 0;
  }
  .search-buttons {
    width: 100%;
    margin-left: 0;
  }
  .search-buttons button {
    flex: 1;
  }
}

.contents-wrap {
  padding: 0;
  border-radius: 0;
}

.contents-wrap .contents-header {
  padding: 0 0 5px 0;
  height: auto;
  border-bottom: none;
  border-radius: 10px;
}

.contents-header .contents-body-tabs {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin: 0;
  list-style: none;
}

.contents-body-tabs .nav-item {
  min-width: 100px;
  /* 너무 작아지지 않도록 최소 너비 설정 */
  text-align: center;
}

.contents-body-tabs .nav-link {
  display: block;
  padding: 10px 5px;
  margin: 2px;
  border-radius: 4px;
  font-size: 14px;
  white-space: nowrap;
}

.contents-body-tabs .nav-link.active {
  background-color: var(--brand-500);
  color: white;
}

.contents-desc {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 860px) {
  .contents-header .contents-body-tabs {
    display: flex;
  }

  .contents-body-tabs .nav-link {
    width: 100px;
  }
}

@media (max-width: 860px) {
  .contents-body-tabs .nav-item {
    width: 33%;
  }

  .contents-body-tabs .nav-link {
    width: 100%;
    text-align: center;
  }
}

.contents-wrap .contents-body {
  padding: 0;
  width: 100%;
}

.contents-wrap .contents-body .content-tools-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  margin-bottom: 0px;
}

@media (max-width: 640px) {
  .contents-wrap .contents-body .contact-content-tools-area {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .contents-wrap .contents-body .contact-content-tools-area .btn-create-wrap {
    width: 100%;
  }

  .contents-wrap .contents-body .contact-content-tools-area button {
    width: 50%;
  }
}

.data-cell {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.contents-wrap .contents-body .content-list-area {
  padding: 0;
  width: 100%;
}

.contents-wrap .contents-body .content-list-area .contents-list-table {
  margin-top: 0px !important;
  width: 100%;
  border-collapse: collapse;
  border: none;
}

.contents-wrap .contents-body .content-list-area .contents-list-table thead {
  background-color: var(--surface-alt);
  border-top: 1px solid var(--border-strong);
  border-bottom: 1px solid var(--border-strong);
  border-radius: 0;
}

.contents-wrap .contents-body .content-list-area .contents-list-table tbody tr {
  border-bottom: 1px solid var(--border);
  height: 40px !important;
  max-height: 40px;
}

.contents-wrap .contents-body .content-list-area .contents-list-table th,
.contents-wrap .contents-body .content-list-area .contents-list-table td {
  padding: 0 10px !important;
  height: 40px !important;
  border-radius: 0 !important;
  border: none !important;
  font-size: 14px;
  color: var(--text);
}

.contents-wrap .contents-body .content-list-area .contents-list-table td select {
  padding: 0 10px;
  width: 140px;
  height: 32px;
  border-radius: 4px;
  border: 1px solid var(--border-strong);
}

.contents-wrap .contents-total {
  margin: 0;
  margin-top: 10px;
  color: var(--text-muted);
}

.contents-wrap .contents-total span {
  color: var(--slate-700);
}

/* =============================================================================
   알림(alert) · 상태 뱃지(badge) — 가이드 의미색 소프트 정렬
   -----------------------------------------------------------------------------
   가이드(/guide/design-system.html): 연한 -bg 배경 + 같은 계열 -fg 텍스트 + -border.
   Bootstrap .bg-* 유틸(!important)을 이기기 위해 .badge 스코프에 !important 사용.
   ※ 가이드의 점(::before) 마커는 카운트 뱃지("N"·숫자)와 충돌해 전역 적용에서 제외.
   ============================================================================= */
/* --- 알림 --- */
.alert {
  border-radius: var(--r-md);
  border: 1px solid transparent;
}
.alert-success { background-color: var(--success-bg); border-color: var(--success-border); color: var(--success-fg); }
.alert-warning { background-color: var(--warning-bg); border-color: var(--warning-border); color: var(--warning-fg); }
.alert-danger  { background-color: var(--danger-bg);  border-color: var(--danger-border);  color: var(--danger-fg); }
.alert-info    { background-color: var(--info-bg);    border-color: var(--info-border);    color: var(--info-fg); }
.alert-success .alert-link,
.alert-warning .alert-link,
.alert-danger .alert-link,
.alert-info .alert-link { color: inherit; }

/* --- 상태 뱃지 (솔리드 → 소프트) --- */
.badge {
  font-weight: var(--fw-semibold);
  border-radius: var(--r-pill);
}
.badge.bg-success,   .badge-success   { background-color: var(--success-bg) !important; color: var(--success-fg) !important; }
.badge.bg-warning,   .badge-warning   { background-color: var(--warning-bg) !important; color: var(--warning-fg) !important; }
.badge.bg-danger,    .badge-danger    { background-color: var(--danger-bg) !important;  color: var(--danger-fg) !important; }
.badge.bg-info,      .badge-info      { background-color: var(--info-bg) !important;    color: var(--info-fg) !important; }
.badge.bg-primary,   .badge-primary   { background-color: var(--brand-50) !important;   color: var(--brand-700) !important; }
.badge.bg-secondary, .badge-secondary { background-color: var(--slate-100) !important;  color: var(--slate-600) !important; }

/* 헤더 사용자 버튼(개인정보·로그아웃): 모바일(≤640) 라벨→아이콘 — 좁은 폭 줄바꿈 방지 */
.header-user-info .btn-small { white-space: nowrap; }
.header-user-info .btn-small .btn-ico { display: none; line-height: 0; }
.header-user-info .btn-small .btn-ico svg { display: block; }
@media (max-width: 640px) {
  .header-user-info .btn-small .btn-label { display: none; }
  .header-user-info .btn-small .btn-ico { display: inline-flex; align-items: center; }
}

/* LNB 최하단 앱 버전 (헤더에서 이관) — 메뉴 아래 빈 공간을 채워 바닥에 고정 */
.app-sidebar__inner { display: flex; flex-direction: column; height: 100%; }
.app-sidebar__version {
  margin-top: auto;
  padding: 10px 14px;
  font-size: 11px;
  line-height: 1;
  color: var(--text-subtle);
  border-top: 1px solid var(--border);
}

.content-list-area .contents-list-table {
  --bs-table-hover-bg: var(--brand-50);
  --bs-table-hover-color: var(--slate-900);
}

/* 수치 고정폭(tabular) — 표·통계 가독성 (가이드 02: ERP 수치는 tabular) */
.contents-list-table td,
.number {
  font-variant-numeric: tabular-nums;
}

/* ===== 디자인 가이드(라이트) 정렬 — Phase 3 (테이블 헤더·페이지네이션·검색 반응형) ===== */
/* 테이블 — 가이드 .ds-table 완전 정렬: 헤더 12px/700/muted/좌측, 여유 패딩, 둥근 카드 컨테이너.
   (헤더/셀 좌측정렬은 EHDGrid JS 인라인으로 처리, 여기선 패딩·외곽 담당) */
.contents-wrap .contents-body .content-list-area .contents-list-table thead th {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.02em;
  text-align: left;
  padding: 12px 16px !important;
  height: auto !important;
}
/* 둥근 테두리 카드 컨테이너 (가이드 .ds-table-wrap) — EHDGrid 가 테이블을 이 div 로 감쌈 */
.content-list-area .contents-list-table-wrap {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
/* 래퍼가 외곽선 담당 → 헤더 상단 보더 제거(이중선 방지), 행은 여유 패딩 */
.content-list-area .contents-list-table thead {
  border-top: none;
}
.contents-wrap .contents-body .content-list-area .contents-list-table tbody tr {
  height: auto !important;
  max-height: none !important;
}
.contents-wrap .contents-body .content-list-area .contents-list-table tbody td {
  padding: 13px 16px !important;
  height: auto !important;
  color: var(--slate-700);
}

/* ===== TABLE2 (1 레코드 = 주행 + 보조행 2행) — EHDGrid TABLE2 모드 =====
   구조: <tbody.grid-record> ▸ <tr.grid-main-row>(컬럼별 td) + <tr.grid-sub-row>(colspan 1칸)
   주행·보조행 사이 보더를 지워 한 레코드로 묶고, 레코드 구분선은 보조행 하단이 담당.
   보조행은 들여쓰기 + 왼쪽 액센트선 + 연한 배경으로 '디테일 스트립'처럼 보이게 묶는다. */
.contents-wrap .contents-body .content-list-area .contents-list-table-double .grid-main-row {
  border-bottom: none;
}
.contents-wrap .contents-body .content-list-area .contents-list-table-double .grid-main-row > td {
  padding-bottom: var(--space-2) !important; /* 보조행과 밀착(한 레코드로 묶임) */
}
/* 보조행: 들여쓰기 + 연한 배경 + 작은 글씨/약한 색 */
.contents-wrap .contents-body .content-list-area .contents-list-table-double .grid-sub-row > td {
  position: relative;
  padding: var(--space-1) var(--space-4) var(--space-3) var(--space-8) !important;
  font-size: var(--fs-13);
  color: var(--text-muted);
  background-color: var(--surface-alt);
}
/* 왼쪽 세로 액센트선 (들여쓰기 위치에) */
.contents-list-table-double .grid-sub-row > td::before {
  content: '';
  position: absolute;
  left: var(--space-4);
  top: var(--space-1);
  bottom: var(--space-3);
  width: 2px;
  border-radius: 1px;
  background-color: var(--brand-200);
}
.contents-list-table-double .grid-sub-row .sub-desc { color: var(--text); font-weight: var(--fw-medium); }
.contents-list-table-double .grid-sub-row .sub-meta {
  margin-left: var(--space-2);
  color: var(--text-subtle);
}
/* hover: table-hover 는 tr 단위라 레코드(tbody)가 분리돼 보임 → 주행+보조행 동시 강조.
   sub-row 배경(5클래스)을 이기도록 동일 prefix(6클래스)로 작성. */
.contents-wrap .contents-body .content-list-area .contents-list-table-double .grid-record:hover > tr > td {
  background-color: var(--brand-50);
  color: var(--slate-900);
}

/* 페이지네이션: 가이드 .ds-pagination/.ds-page (36px 정사각, 현재페이지 brand-500, ‹ › + 생략부호) */
.content-list-area .pagination {
  gap: 6px;
  align-items: center;
}
.content-list-area .pagination .page-item {
  margin: 0 !important;
}
.content-list-area .pagination .page-link {
  min-width: 36px;
  height: 36px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--slate-600);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.content-list-area .pagination .page-item:not(.disabled):not(.active) .page-link:hover {
  background: var(--slate-50);
  border-color: var(--slate-400);
  color: var(--slate-800);
}
.content-list-area .pagination .page-item.active .page-link {
  background: var(--brand-500);
  border-color: var(--brand-500);
  color: #fff;
}
.content-list-area .pagination .page-item.disabled .page-link {
  opacity: 0.4;
  cursor: default;
}
/* 생략부호(…) — 버튼 아닌 텍스트로 */
.content-list-area .pagination .page-link.page-gap {
  border: none;
  background: none;
  color: var(--text-subtle);
  min-width: auto;
  padding: 0 4px;
}

/* (검색 영역 스타일은 위쪽 "검색 영역 — 옵션 B" 블록으로 통합) */

/* ===== 모달/알림 — 가이드 정렬 (갭 C) ===== */
/* Bootstrap 모달 컨테이너: 토큰 radius(lg)/그림자(3단계)/표면 */
.modal-content {
  background-color: var(--surface);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-3);
}
/* toastr 알림: 의미색을 팔레트 토큰으로 정렬 (아이콘/그림자는 유지) */
.toast-success { background-color: var(--success); }
.toast-error { background-color: var(--danger); }
.toast-info { background-color: var(--info); }
.toast-warning { background-color: var(--warning); }
/* SweetAlert confirm 버튼은 이미 브랜드(#3f6ad8) — 변경 없음 */

/* ===== 버튼 위계 — 디자인 가이드 정렬 =====
   primary(#3f6ad8)·danger(#d92550)는 base.css 가 이미 토큰과 일치.
   유일 불일치인 secondary(부트스트랩 회색 채움)를 가이드 .ds-btn-secondary
   (흰 표면 + 테두리 + slate 텍스트)로 정렬. outline-secondary 도 동일하게 통일. */
.btn-secondary,
.btn-outline-secondary {
  color: var(--slate-700);
  background-color: var(--surface);
  border-color: var(--border-strong);
}
.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active,
.btn-secondary.active,
.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.btn-outline-secondary:active,
.btn-outline-secondary.active {
  color: var(--slate-800);
  background-color: var(--slate-50);
  border-color: var(--slate-400);
  box-shadow: none;
}

.manual-left-wrap .manual-main,
.manual-left-wrap .manual-box {
  margin-left: 240px;
  transition: all 0.2s;
}

.manual-left-index {
  position: fixed;
  top: 150px;
  margin-left: -10px;
  padding: 20px;
  width: 240px;
  max-height: calc(100vh - 100px);
  background-color: #fff;
  border: 1px solid #d3d8e5;
  border-radius: 20px;
  box-shadow: 0 0px 10px rgba(0, 0, 0, 0.1);
  transition: all 0.2s;
  overflow-y: auto;
}

@media (max-width: 860px) {
  .manual-left-index {
    display: none;
  }

  .manual-left-wrap .manual-main,
  .manual-left-wrap .manual-box {
    margin-left: 0;
  }
}

.manual-left-index h4 {
  color: #555;
  font-weight: bold;
}

.manual-left-index ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.manual-left-index li {
  margin-bottom: 8px;
}

.manual-left-index p {
  display: block;
  text-decoration: none;
  color: #333;
  padding: 5px 10px;
  cursor: pointer;
  transition: all 0.2s;
  border-radius: 10px;
  letter-spacing: -0.2px;
}

.manual-left-index p:hover {
  background-color: #f4f6fa;
}

.manual-left-index .active {
  background-color: #c9def4;
}

.manual-left-index .active:hover {
  background-color: #c9def4;
}

.manual-wrap {
  position: relative;
}

.manual-wrap .manual-left-index {
  padding: 20px;
}

.manual-wrap .manual-left-index>p {
  margin: 0;
  margin-bottom: 20px;
  padding: 0;
  font-size: 20px;
  font-weight: bold;
}

.manual-wrap button {
  background-color: #fff;
  border: none;
  color: #000 !important;
  font-size: 16px;
  font-weight: bold;
}

.manual-wrap button:hover {
  text-decoration: underline;
}

.manual-wrap .manual-main {
  border-bottom: 1px solid #d3d8e5;
}

.manual-wrap .manual-main-title p {
  margin: 0;
  padding-top: 20px;
  padding-bottom: 30px;
  font-size: 28px;
  font-weight: bold;
}

@media (max-width: 860px) {
  .manual-wrap {
    top: 120px;
  }

  .manual-wrap .manual-main-title p {
    font-size: 20px;
    text-align: center;
  }
}

.manual-wrap .manual-main-index {
  padding: 20px;
}

.manual-wrap .manual-main-index>p {
  margin: 0;
  margin-bottom: 20px;
  padding: 0;
  font-size: 20px;
  font-weight: bold;
}

.manual-wrap li {
  margin-bottom: 20px;
}

.manual-wrap li p {
  margin: 5px;
  color: #555;
}

.manual-wrap .manual-box {
  padding: 30px;
  border-bottom: 1px solid #d3d8e5;
}

.manual-wrap .manual-box .manual-title {
  margin: 0;
  padding: 0;
  font-size: 20px;
  font-weight: bold;
}

.manual-wrap .manual-box .manual-sub-title {
  margin: 0;
  margin-top: 10px;
  margin-left: 10px;
  padding: 0;
  font-size: 18px;
  font-weight: bold;
  color: #333;
}

.manual-wrap .manual-box .manual-contents {
  padding: 20px;
  color: #555;
}

.manual-wrap .manual-box .manual-contents img {
  margin: 20px 0px;
  width: 100%;
  max-width: 1000px;
}

.manual-wrap .manual-box .manual-contents ul {
  margin-top: 20px;
  font-size: 16px;
}

.btn-create-wrap {
  display: flex;
  justify-content: space-between;
  gap: 5px;
  padding: 0;
}

.btn-create {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  width: 100px;
  height: 32px;
  background-color: var(--surface);
  border: 1px solid var(--border-strong);
  color: var(--slate-700);
  font-weight: 400;
  font-size: 14px;
}

.btn-create:hover {
  color: #fff;
  background-color: var(--slate-800);
}

.btn-excel {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 100px;
  height: 32px;
  border-radius: 4px;
  background-color: #3f6ad8;
  font-size: 14px;
  font-weight: 400;
  color: #fff;
  white-space: nowrap;
  transition: all 0.2s;
}

.btn-excel:hover {
  background-color: var(--brand-600);
  color: #fff;
}

.select-sort {
  width: 120px;
  height: 32px;
  color: var(--slate-700);
  border: none;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  border-color: var(--slate-700);
  cursor: pointer;
  transition: all 0.2s;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url('/image/arrow-down-icon.png') no-repeat right center;
  background-size: 10px 6px;
  background-position: calc(100% - 10px) center;
  padding-right: 20px;
}

.select-sort option {
  text-align: left;
}

.select-sort:focus {
  border-radius: 5px;
}

.basic-list-table {
  margin-top: 0px !important;
  width: 100%;
  border-collapse: collapse;
  border: none;
}

.basic-list-table thead {
  background-color: #f4f6fa;
  border-top: 1px solid #c2c7d3;
  border-bottom: 1px solid #c2c7d3;
  border-radius: 0;
}

.basic-list-table tbody tr {
  border-bottom: 1px solid #d3d8e5;
  height: 40px !important;
  max-height: 40px;
}

.basic-list-table th,
.basic-list-table td {
  padding: 0 10px !important;
  height: 40px !important;
  border-radius: 0 !important;
  border: none !important;
  font-size: 14px;
  color: #000;
}

.new-table-style {
  margin-left: 0px;
  width: 100%;
  max-width: 100%;
  font-size: 14px;
}

.new-table-style table {
  width: 100%;
  max-width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  box-sizing: border-box;
}

.new-table-style table td {
  padding: 0 10px;
  height: 48px;
  border: 1px solid var(--border-strong);
  /* white-space: nowrap; */
}

.new-table-style td:first-child,
.new-table-style td:nth-child(3) {
  /* padding-right: 20px; */
  min-width: 97px;
  font-weight: 600;
  background-color: var(--surface-alt);
  white-space: nowrap;
}

.new-table-style td:first-child {
  border-left: none;
}

.new-table-style td:last-child {
  border-right: none;
}

.new-table-style td span {
  color: var(--danger);
}

.new-table-style table input[type='text'],
.new-table-style table input[type='email'],
.new-table-style table input[type='password'],
.new-table-style table input[type='tel'],
.new-table-style table select {
  height: 32px !important;
  min-width: 150px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: 3px 8px;
}

.new-table-style table input[type='date'] {
  height: 32px !important;
  min-width: 150px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: 3px 8px;
}

.new-table-style table textarea {
  padding: 10px !important;
  width: 100%;
  min-height: 85px;
  max-height: 300px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: 3px 8px;
  resize: none;
}

/* 폼 입력 포커스 — 브랜드 링 */
.new-table-style table input:focus,
.new-table-style table select:focus,
.new-table-style table textarea:focus {
  outline: none;
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px var(--brand-100);
}

.button-save {
  background-color: #fff;
  color: #000;
}

.new-modal-wrap {
  position: relative;
  z-index: 1;
  pointer-events: auto;
}

.new-modal-wrap input[type='date'],
.new-modal-wrap input[type='text'],
.new-modal-wrap select {
  width: 50%;
  min-width: 150px;
  height: 32px !important;
  border: 1px solid #c2c7d3;
  border-radius: 4px;
  padding: 3px 8px;
}

.new-modal-wrap select {
  width: 100%;
}

.new-modal-wrap .new-modal-content {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 400px;
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  z-index: 1;
}

.new-modal-wrap .new-modal-input {
  margin-bottom: 20px;
}

.new-modal-wrap .new-modal-content .new-modal-input p {
  margin-bottom: 5px;
  font-size: 16px;
  font-weight: 500;
  color: #333;
}

.new-modal-wrap .new-modal-content .new-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
  border-bottom: 1px solid #b2b6c1;
}

.new-modal-wrap .new-modal-content .new-modal-header h5 {
  margin-bottom: 0;
  font-weight: 600;
}

.new-modal-input span {
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  height: 32px;
}

.new-modal-url {
  padding-top: 20px;
}

.new-modal-wrap .new-modal-content label {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}

.new-modal-wrap .new-modal-content .new-modal-url-content p {
  font-size: 13px;
  font-weight: 400;
  color: #3c3e42;
}

.new-modal-wrap .new-modal-content .new-modal-url-content h5 {
  margin-bottom: 0;
  font-size: 16px;
  color: #333;
}

.new-modal-url-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.new-modal-url-title .btn-invite-action {
  margin-left: 5px;
  padding: 2px 10px;
  height: 24px;
  background-color: #225b94;
  border-radius: 4px;
  font-size: 14px;
  color: #fff;
  border: none;
}

.new-modal-wrap .new-modal-content .new-modal-url-content div {
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 10px 0;
}

.new-modal-wrap .new-modal-content .new-modal-detail div input[type='text'] {
  width: 75%;
}

.btn-invite-action {
  padding: 0;
  width: 20%;
  min-width: 50px;
  height: 32px;
  background-color: #f4f6fa;
  border: 1px solid #c2c7d3;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 400;
  color: #000;
  white-space: nowrap;
}

.new-modal-section-divider {
  border-top: 2px dashed #eee;
  margin: 15px 0;
}

.new-modal-phone-title {
  margin: 15px 0;
  font-size: 16px;
  color: #333;
}

.new-modal-phone-row {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 5px;
}

.new-modal-phone-row input[type='text'] {
  flex: 1;
}

.new-modal-phone-row .btn-invite-action {
  width: auto;
  min-width: 50px;
  padding: 0 12px;
}

.new-modal-wrap .new-modal-content .new-modal-phone {
  gap: 5px;
}

.new-modal-input .radio-button-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.new-modal-input .radio-button-group input[type='radio'] {
  display: none;
}

.new-modal-input .radio-button-group .radio-button {
  padding: 8px 16px;
  width: 50%;
  border: 1px solid #c2c7d3;
  background-color: #fff;
  color: #333;
  cursor: pointer;
  border-radius: 4px;
  font-size: 14px;
  user-select: none;
  text-align: center;
  transition: all 0.2s;
}

.new-modal-input .radio-button-group .radio-button:hover {
  background-color: #f4f6fa;
  color: #333;
}

.new-modal-input .radio-button-group input[type='radio']:checked+.radio-button {
  background-color: #225b94;
  color: #fff;
  border-color: #225b94;
}

.detail-search-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  width: 100%;
}

@media (max-width: 860px) {
  .detail-search-wrap {
    flex-direction: column;
  }

  .detail-search-wrap .detail-search-box {
    width: 100% !important;
  }

  .detail-search-wrap .detail-search-box>div:first-child {
    width: 28% !important;
    white-space: nowrap;
  }

  .detail-search-wrap .detail-search-box>div:last-child {
    width: 72%;
    white-space: nowrap;
  }

  .detail-search-wrap .detail-search-box:last-child>div {
    border-right: 1px solid #d3d8e5;
  }
}

.detail-search-box {
  display: flex;
  align-items: center;
  width: 33.3%;
  min-height: 46px;
  overflow: hidden;
  border-top: 1px solid #d3d8e5;
  border-bottom: 1px solid #d3d8e5;
  white-space: nowrap;
}

.detail-search-box>div {
  padding: 0.5rem;
  width: 30%;
  border-right: 1px solid #d3d8e5;
}

.detail-search-box>div:first-child {
  max-width: 100px;
}

.detail-search-box>div:last-child {
  width: 100%;
  background-color: #fff;
}

.detail-search-box:last-child>div:last-child {
  border-right: none;
}

@media (max-width: 640px) {
  .detail-search-box:last-child>div:last-child {
    display: flex;
    flex-direction: column;
    height: fit-content;
    border-right: 1px solid #d3d8e5;
  }

  .detail-search-box:last-child>div:last-child>input {
    width: 100% !important;
    height: 30px !important;
  }

  .date-tilde {
    display: none;
  }
}

@media (max-width: 860px) {
  .detail-search-wrap {
    flex-direction: column;
  }

  .detail-search-box {
    width: 100% !important;
  }

  .detail-search-box>div:first-child {
    width: 30%;
  }

  /* .detail-search-box>div:last-child {
    width: 100% !important;
  } */
}

.form-search-input {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 0.5rem;
  height: 46px;
}

.form-search-input input,
.form-search-input select {
  padding: 0 10px;
  width: 140px;
  height: 100%;
  border-radius: 4px;
  border: 1px solid #c2c7d3;
}

.form-search-input select {
  min-width: 40%;
  min-height: 30px;
}

.form-search-input input[type='date'] {
  width: 45%;
}

/* 로그인 */

/* 디자인 토큰 적용 (기준: /guide/design-system.html). 기존 Figma S3 배경 URL은 만료되어 깨져 있었음 → 토큰 그라데이션으로 교체. */
.login-bg {
  position: fixed;
  top: 0;
  left: 0;
  background: linear-gradient(135deg, var(--brand-700) 0%, var(--slate-900) 100%);
  width: 100%;
  height: 100%;
  background-size: cover;
}

.login-bg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 28% 18%, rgba(63, 106, 216, 0.35), transparent 48%),
    radial-gradient(circle at 82% 88%, rgba(34, 58, 124, 0.4), transparent 42%);
}

.login-input-wrap {
  width: 400px !important;
  padding: 30px 24px;
  background-color: var(--surface);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-3);
}

.login-input-top {
  margin-bottom: -1px;
  padding: 0 !important;
}

.login-input-top input {
  padding: 20px;
  width: 100%;
  height: 50px !important;
  border-radius: var(--r-md) var(--r-md) 0 0 !important;
  border: 1px solid var(--border-strong) !important;
}

.login-input-bottom {
  padding: 0 !important;
}

.login-input-bottom input {
  padding: 20px;
  width: 100%;
  border-radius: 0 0 var(--r-md) var(--r-md) !important;
  height: 50px !important;
  border: 1px solid var(--border-strong) !important;
  background-color: var(--surface) !important;
}

/* 입력 포커스 — 브랜드 링 (접근성) */
.login-input-wrap input:focus {
  outline: none;
  border-color: var(--brand-500) !important;
  box-shadow: 0 0 0 3px var(--brand-100);
  position: relative;
  z-index: 1;
}

.black-box {
  position: fixed;
  top: calc(50% - 240px);
  left: calc(50% + 70px);
  width: 80px;
  height: 80px;
  background-color: #000;
}

.login-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 400px;
  border-radius: 0px;
  pointer-events: auto;
  background-color: rgba(0, 0, 0, 0);
  background-clip: padding-box;
  overflow: hidden;
  outline: 0;
}

.login-title {
  width: 400px;
}

.login-title span {
  color: #fff !important;
  font-weight: var(--fw-semibold);
}

.login-logo {
  position: relative;
  top: 0px;
  z-index: 1;
}

.login-desc p {
  color: var(--slate-300);
  font-size: var(--fs-14);
  text-align: center;
  margin-bottom: 10px;
  font-weight: var(--fw-regular);
}

@media (max-width: 640px) {
  .login-content {
    padding: 0 20px;
  }

  .login-content,
  .login-title,
  .login-input-wrap {
    width: 100% !important;
  }
}

.save-id label {
  margin: 10px 0px;
  font-size: var(--fs-13);
  color: var(--text);
}

.login-btn {
  width: 100%;
  height: 48px;
  background-color: var(--brand-500);
  font-weight: var(--fw-semibold) !important;
  font-size: var(--fs-16);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  transition: background-color 0.12s;
}

.login-btn:hover {
  background-color: var(--brand-600);
  color: #fff !important;
}

.login-footer {
  background-color: rgba(0, 0, 0, 0);
}

.login-footer .float-start {
  width: 100%;
}

.login-footer .float-start .mt-2 {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.login-footer a {
  font-size: 14px;
  color: #fff;
  font-weight: 400;
}

/* 진입 화면(로그인/가입/찾기) 전역 푸터 — 어두운 배경에 녹이기. base.css 미수정, .page-index 스코프라 대시보드 푸터는 무영향 */
.page-index .dashboard-footer {
  background-color: transparent;
  border-top: none;
  backdrop-filter: none;
}

.page-index .footer-container {
  color: var(--slate-300);
}

.page-index .company-name {
  color: var(--slate-100);
}

.page-index .footer-info a {
  color: var(--slate-300);
}

.page-index .footer-info a:hover {
  color: var(--brand-300);
}

.page-index .divider {
  background-color: rgba(255, 255, 255, 0.25);
}

.page-index .footer-copyright {
  color: var(--slate-400);
}

/* 회원가입 */

.join-desc {
  margin-bottom: 0px;
  font-weight: 300;
  font-size: var(--fs-14);
  text-align: center;
  color: var(--text-muted);
}

.join-content {
  margin-top: 10px;
}

.join-body {
  padding: 30px;
}

.join-form label {
  margin-top: 5px;
  padding-top: 10px;
  width: 100%;
  font-weight: 700;
  border-top: 1px solid var(--border);
}

.join-form input:focus {
  outline: none;
  border-color: var(--brand-500) !important;
  box-shadow: 0 0 0 3px var(--brand-100);
}

.join-form>div:first-child label {
  margin-top: 0px;
  padding-top: 0px;
  border-top: none;
}

.join-form input {
  height: 32px !important;
}

.join-id input {
  width: 73%;
}

.join-id button {
  width: 25%;
  background-color: var(--surface);
  border: 1px solid var(--border-strong);
  color: var(--slate-700) !important;
  white-space: nowrap;
}

.join-btn {
  padding: 30px;
  padding-top: 0px;
}

.join-btn button {
  width: 100%;
  height: 48px;
  border-radius: var(--r-sm);
  padding: 8px;
  background-color: var(--brand-500);
  color: #fff;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-16);
  transition: all 0.2s;
}

.join-btn button:hover {
  background-color: var(--brand-600);
  color: #fff !important;
}

/* 회원가입 완료 */

.join-complete-modal {
  padding: 40px 30px;
  width: 450px !important;
  border-radius: var(--r-lg);
  background-color: var(--surface);
  border: 1px solid var(--border);
}

@media (max-width: 640px) {
  .join-complete-modal {
    padding: 20px;
    width: 95% !important;
  }
}

.join-complete-modal>div {
  padding: 0px !important;
  padding-bottom: 40px !important;
}

.join-complete-btn {
  position: absolute;
  top: calc(50% + 280px);
  margin: 0 auto;
  width: 400px;
  height: 48px;
  z-index: 1;
  background-color: var(--brand-500);
  color: #fff;
  cursor: pointer !important;
}

@media (max-width: 640px) {
  .join-complete-btn {
    width: 80% !important;
  }
}

@media (max-width: 640px) {
  .join-complete-btn {
    top: calc(50% + 250px) !important;
  }
}

.join-complete-btn:hover {
  background-color: var(--brand-600);
  color: #fff !important;
}

.join-complete-wrap {
  text-align: center;
}

.join-complete-text div {
  margin-bottom: 10px;
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  color: var(--slate-900);
}

.join-complete-text p {
  margin-bottom: 0px !important;
  font-size: var(--fs-16);
  font-weight: var(--fw-regular);
  color: var(--text-muted);
}

.join-complete-image {
  margin: 35px 0px;
  margin-bottom: 40px;
}

.join-complete-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* 아이디 | 비밀번호 찾기 */

.bg-fa {
  background-color: var(--ground);
}

.find-id-wrap {
  display: none;
}

.find-user-wrap {
  width: 100%;
  max-width: 400px;
  border-radius: 10px;
}

.find-user-wrap input[type='text'],
.find-user-wrap input[type='tel'],
.find-user-wrap input[type='email'] {
  height: 32px !important;
  border-radius: 4px !important;
}

.find-container {
  padding: 30px 24px;
  height: 510px;
  box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0);
  border: 1px solid var(--border);
}

.find-header {
  position: relative;
  padding: 0px !important;
  height: 36px !important;
}

.find-header>.nav .nav-link.active {
  color: var(--brand-600) !important;
  font-weight: bold;
}

.find-header>.nav .nav-link::before {
  content: '';
  background: none !important;
  opacity: 0 !important;
}

.find-header>.nav {
  margin-left: 0px !important;
}

.find-nav-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50%;
  height: 2px;
  z-index: 1;
  background-color: var(--brand-500);
  border-radius: 10px;
  transition: all 0.2s;
}

.find-body {
  padding: 20px 10px;
}

#phone-auth,
#email-auth {
  transition: all 0.2s;
  overflow: hidden;
}

#phone-auth {
  margin-bottom: 10px;
}

#email-auth {
  height: 0px;
}

.find-email {
  border-top: 1px solid var(--border-strong);
  padding-top: 20px;
}

.find-input {
  margin: 10px 0px;
}

.find-input label {
  font-weight: 600;
}

.find-input input {
  padding: 10px;
  width: 100%;
  height: 32px;
  border-radius: 4px;
  outline: none;
  border: 1px solid var(--border-strong);
  font-size: 13px;
}

.find-input input:focus {
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px var(--brand-100);
}

.find-input input[type='tel'] {
  width: 70%;
}

.find-input input[type='email'] {
  width: 70%;
}

.find-input button {
  width: 28%;
  height: 32px;
  border-radius: 4px !important;
  border: 1px solid var(--border-strong);
  background-color: var(--surface);
  color: var(--slate-700);
}

.find-number-check-btn {
  width: 28%;
  height: 32px;
  border-radius: 4px;
  border: 1px solid var(--border-strong);
}

.find-tel {
  display: flex;
  justify-content: space-between;
  gap: 5px;
}

.find-tel button {
  border-radius: 4px !important;
  font-size: 13px;
  font-weight: 400;
}

.find-btn {
  margin-top: 30px;
  width: 100%;
  height: 48px;
  background-color: var(--brand-500);
  color: #fff;
  font-size: var(--fs-14);
  font-weight: var(--fw-semibold);
}

.find-btn:hover {
  background-color: var(--brand-600);
  color: #fff !important;
}

/* ===== 대시보드 (.dashboard-container 스코프, base.css 미수정 / 화면 단위 이관) ===== */
/* 상태 뱃지는 위 전역 소프트 뱃지 규칙(.badge-primary)이 담당 — 별도 솔리드 override 제거 */
/* 캠페인 카드/홈 액션 버튼: 차콜(#34383c)→브랜드, 비활성/disabled는 회색 */
.dashboard-container .dashboard-btn-group button {
  background-color: var(--brand-500);
}
.dashboard-container .dashboard-btn-group button:hover {
  background-color: var(--brand-600);
}
.dashboard-container .dashboard-btn-group button:disabled,
.dashboard-container .dashboard-btn-group button.btn-secondary {
  background-color: var(--slate-400);
}
/* 트래픽 통계 카드 보더 토큰화 */
.dashboard-container .dashboard-trafic-statistics .stat-item,
.dashboard-container .dashboard-trafic-statistics .stat-item:first-child,
.dashboard-container .dashboard-trafic-statistics .stat-item:last-child {
  border-color: var(--border);
}

/* 트래픽 통계: 큰 숫자(1000+/분할값)에도 안 깨지도록 세로 스택 + 숫자 nowrap·반응형 크기.
   base.css 는 제목(60%) 옆에 값(40%)을 가로로 두는데, 분할값(98,765/1,234,567)은
   반쪽 카드 폭을 넘쳐 깨짐. → 제목 위·숫자 아래로 세로 배치해 값에 카드 전체 폭을 부여. */
.dashboard-container .dashboard-trafic-statistics .stat-item {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  text-align: center;
}
.dashboard-container .dashboard-trafic-statistics .stat-item .header {
  width: 100%;
  flex: 0 0 auto;
  min-width: 0;
}
.dashboard-container .dashboard-trafic-statistics .stat-item .value {
  width: 100%;
  flex: 0 0 auto;
  min-width: 0;
  justify-content: center;
  white-space: nowrap;
}
.dashboard-container .dashboard-trafic-statistics .stat-item .value .number {
  font-size: clamp(1.1rem, 1.4vw + 0.6rem, 2rem);
  line-height: 1.2;
  white-space: nowrap;
}
.dashboard-container .dashboard-trafic-statistics .stat-item .value .unit,
.dashboard-container .dashboard-trafic-statistics .stat-item .value .stat-splitter {
  line-height: 1.2;
}

/* 캠페인 홈 footer 통계: 원래 3분할 레이아웃 유지. 카드가 좁아(≈144px) 큰 분할값이
   넘치므로, 값(.value)의 글자크기를 카드폭에 맞춰 JS(fitTrafficStats)가 자동 축소한다.
   자식은 .value 기준 em 으로 함께 스케일(원래 비율 유지). (base.css 미수정 — override만) */
.dashboard-footer-trafic-statistics .stat-item {
  min-width: 0; /* 콘텐츠로 인해 카드가 늘어나지 않도록 → 값이 카드폭에 맞춰 축소되게 */
}
.dashboard-footer-trafic-statistics .stat-item .value {
  font-size: 3rem; /* 기준 최대치 — JS가 카드폭 초과 시 인라인으로 줄임 */
  width: 100%;
  min-width: 0;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
}
.dashboard-footer-trafic-statistics .stat-item .value .number {
  font-size: 1em;
  line-height: 1.2;
  white-space: nowrap;
}
.dashboard-footer-trafic-statistics .stat-item .value .stat-splitter {
  font-size: 0.5em;
  line-height: 1.2;
  margin: 0 0.12em;
}
.dashboard-footer-trafic-statistics .stat-item .value .unit {
  font-size: 0.34em;
  line-height: 1.2;
}

/* 캠페인 상세 */
/* 테이블처럼 보이게 하는 래퍼 */
.reg-date-area label {
  margin-top: 0.5rem;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
}

.table-like {
  display: flex;
  flex-direction: column;
  width: 100%;
  border-bottom: 1px solid var(--border-strong);
}

/* 각 행 */
.table-row {
  display: flex;
  flex-wrap: wrap;
  /* 줄바꿈 허용(반응형) */
  border-top: 1px solid var(--border-strong);
}

/* 기본 셀 스타일 */
.table-cell {
  padding: 0.5rem;
  box-sizing: border-box;
}

/* 레이블 셀, 입력 셀 구분 */
.cell-label {
  /* 예: 레이블 셀 고정폭 (PC화면 기준) */
  display: flex;
  align-items: center;
  /* width: 15%; */
  min-width: 107px;
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
  vertical-align: middle;
  background-color: var(--surface-alt);
}

.cell-input {
  /* 나머지 공간 차지 */
  width: 35%;
  min-width: 200px;
  display: flex;
  align-items: center;
}

.cell-input input.custom-input {
  width: 16rem;
  height: 32px !important;
  border-radius: 4px !important;
  border-width: 1px;
  border-style: solid;
  padding-top: 3px;
  padding-right: 8px !important;
  padding-bottom: 3px;
  padding-left: 8px;
}

.cell-input input.custom-calendar {
  width: 8rem;
  height: 32px !important;
  border-radius: 4px !important;
  border-width: 1px;
  padding-top: 6px;
  padding-right: 8px !important;
  padding-bottom: 6px;
  padding-left: 8px;
  background-image: none !important;
}

.cell-input select.custom-select {
  width: 16rem;
  height: 32px !important;
  border-radius: 4px !important;
  border-width: 1px;
  padding-top: 6px;
  padding-right: 8px !important;
  padding-bottom: 6px;
  padding-left: 8px;
}

/* 기본정보 폼 입력 — 보더/포커스 토큰화 */
.cell-input input.custom-input,
.cell-input input.custom-calendar,
.cell-input select.custom-select {
  border-color: var(--border-strong);
}

.cell-input input.custom-input:focus,
.cell-input input.custom-calendar:focus,
.cell-input select.custom-select:focus {
  outline: none;
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px var(--brand-100);
}

/* custom-select 클래스 없는 맨 select(지역·템플릿 등)도 동일 높이/보더로 정렬
   — 브라우저 기본 40px 라 셀(32px)을 넘쳐 하단에 붙던 문제 해결 */
.cell-input select {
  height: 32px;
  padding: 3px 8px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-sm);
}
.cell-input select:focus {
  outline: none;
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px var(--brand-100);
}

/* 4칸 구조에서 "colspan"처럼 3칸을 합쳐 쓰고 싶을 때 */
.cell-input.colspan {
  width: 85%;
  /* (15% 레이블 + 85% 내용) */
  flex: 1;
  /* 남은 공간을 모두 차지 */
}

/* 반응형: 작은 화면에서는 레이블과 입력이 각각 가로폭 100% */
@media (max-width: 860px) {
  .table-row {
    border: 0;
  }

  .cell-label,
  .cell-input {
    width: 100% !important;
  }

  .material-row {
    height: auto !important;
  }
}

/* ===== 상세·편집 폼(개인정보·기본정보) — 가이드 테이블형 폼 적용 =====
   가이드 .ds-formtable: 둥근 카드 컨테이너 + 셀 그리드(연한 --border) + 라벨 slate-700
   + 입력 radius 6px. 두 화면이 마크업이 달라(div그리드 vs table) 각각 정렬. */
/* (1) 캠페인 기본정보 — div 그리드(.table-row/.cell-*) */
.new-table-style:has(.table-row) {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.new-table-style:has(.table-row) .table-row {
  border-top: 1px solid var(--border);
}
.new-table-style:has(.table-row) .table-row:first-child {
  border-top: none;
}
.new-table-style .cell-label {
  color: var(--slate-700);
  border-right: 1px solid var(--border);
}
.cell-input input.custom-input,
.cell-input input.custom-calendar,
.cell-input select.custom-select {
  border-radius: var(--r-sm) !important;
}

/* (2) 개인정보 — 실제 table(.new-table-style table) */
.new-table-style table {
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.new-table-style table td {
  border: none;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
}
.new-table-style table tr:last-child td {
  border-bottom: none;
}
.new-table-style table td:last-child {
  border-right: none;
}
.new-table-style table td:first-child,
.new-table-style table td:nth-child(3) {
  color: var(--slate-700);
}
.new-table-style table input[type='text'],
.new-table-style table input[type='email'],
.new-table-style table input[type='password'],
.new-table-style table input[type='tel'],
.new-table-style table input[type='date'],
.new-table-style table select,
.new-table-style table textarea {
  border-radius: var(--r-sm);
}

@media (max-width: 640px) {
  .material-cell {
    flex-wrap: wrap !important;
  }

  .material-cell #materialFileInfo {
    width: 100% !important;
  }

  .material-cell #materialFileInfo span {
    margin: 0 !important;
    width: 100% !important;
  }

  .material-cell .material-btn-wrap {
    width: 100%;
    margin-top: 5px;
    justify-content: center;
  }

  .material-cell .material-btn-wrap button {
    width: 50%;
  }
}

/* 버튼영역 배치 */
.btn-area {
  display: flex;
  gap: 0.5rem;
  /* 버튼 간격 */
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

/* 테마 카드 관련 (예시) */
.info-theme-item {
  border-radius: 8px;
  /* padding: 1rem; */
  color: #fff;
  background-size: cover;
  background-position: center;
  /* 필요한 추가 스타일 */
}

.info-modal {
  display: flex;
  justify-content: space-between;
  align-content: center;
  margin: 10px 0;
  padding: 10px 20px;
  background-color: var(--success-bg);
  border: 1px solid var(--success);
  border-radius: 10px;
}

.info-modal img {
  width: 40px;
  height: 40px;
  border-radius: 10px;
}

.info-modal ul {
  margin: 0;
  padding: 0;
  width: 90%;
  text-align: left;
}

.info-modal button {
  padding: 0;
  padding-top: 10px;
  width: 10px;
  height: 10px;
}

.info-modal-btn-wrap {
  padding: 20px 16px;
  text-align: right;
}

.info-modal-btn-wrap .form-save {
  width: 120px;
}

.info-theme-item {
  margin-right: 10px;
  width: 280px;
  height: 95px;
  border-radius: 4px;
}

.info-theme-con>div {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  max-width: 75%;
  height: 24px;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.6);
  font-size: 12px;
  font-weight: 400;
  color: #fff;
}

.info-theme-con h5 {
  margin-bottom: 0px !important;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 14px !important;
  font-weight: bold;
  font-size: 14px;
}

.info-theme-con li {
  font-size: 13px;
  font-weight: 400;
}

.search-icon-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  width: auto !important;
  height: 24px !important;
  border: none !important;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 50px;
}

.theme-info ul {
  margin-top: 10px;
}

.theme-info ul li {
  width: 100%;
  font-size: 14px;
  font-weight: 400;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  white-space: normal;
}

.contents-wrap .site-edit-save-btn {
  /* width: 24px; */
}

.contents-wrap .site-edit-save-btn img {
  width: 16px;
}

.contents-wrap .site-edit-refresh-btn {
  /* display: flex;
  justify-content: center;
  align-items: center; */
  /* font-size: 20px;
  font-weight: 100; */
}

.theme-select {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 10px;
  width: 100%;
  font-size: 14px;
  font-weight: 400;
  color: #000;
  border-bottom: 1px solid #d3d8e5 !important;
  border-radius: 0 !important;
}

.theme-select h5 {
  margin: 0;
}

.theme-select .theme-select-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.theme-btn-group {
  display: flex;
  gap: 5px;
}

.small-icon-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px 10px;
  width: auto;
  height: 32px !important;
  background-color: #fff;
  border: 1px solid #999;
  border-radius: 4px;
  cursor: pointer;
}

.new-theme-btn {
  width: 90px;
  height: 90px;
  /* background-color: #DFE4F2; */
  color: #1a1d1d;
  border-radius: 4px;
  cursor: pointer;
  border: 2px dashed #dfe4f2;
}

.new-theme-btn h5 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  margin: 0;
  width: 100%;
  height: 100%;
}

.new-theme-btn h5 p {
  margin: 0;
  font-size: 14px;
  font-weight: 400;
  color: #3c3e42;
}

.new-theme-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding-bottom: 20px !important;
}

.new-theme-wrap .new-theme-list {
  width: calc(100% - 75px);
  height: 90px;
}

.new-theme-item {
  padding: 0;
  width: 280px;
  height: 90px;
  border-radius: 4px;
}

.new-theme-item>div {
  padding: 10px;
  box-sizing: border-box;
}

.new-theme-item h5 {
  padding: 3px 4px;
  max-width: 85%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  background-color: rgba(0, 0, 0, 0.6);
  font-size: 14px;
  color: #fff;
  font-weight: bold;
  border-radius: 2px;
}

.new-theme-item li {
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 400;
  font-size: 13px;
}

.btn-fold {
  /* width: 12px;
  height: 2px;
  border: 1px solid #666;
  border-radius: 2px; */
}


/* 내 계정 */

.ck.ck-editor {
  max-width: 100%;
}

.ck-source-editing-area {
  min-height: 500px;
}

.ck-editor__editable_inline {
  height: 500px;
  max-height: 800px;
  overflow: auto;
}

.mypage-header {
  padding-top: 10px !important;
  padding-left: 0 !important;
  height: auto;
}

.mypage-title {
  margin-bottom: 0px !important;
  font-size: 24px;
  color: #000;
  font-weight: 700;
}

.mypage-body>p {
  margin-bottom: 10px !important;
  font-size: 16px;
  font-weight: 600;
  color: #000;
}

.mypage-body .new-table-style table td {
  height: 58px;
  padding: 10px 7px;
}

.mypage-profile {
  display: flex;
  align-items: center;
  gap: 10px;
  max-height: 80px;
}

.mypage-profile-btn-wrap {
  display: flex;
  gap: 10px;
}

.btn-mypage {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0px;
  width: 120px;
  height: 32px !important;
  font-size: 14px !important;
}

.mypage-pwd {
  display: flex;
  align-items: center;
}

.mypage-body .new-table-style table td.profile-cell {
  height: 116px;
}

.mypage-body .new-table-style table td.profile-cell-admin {
  height: 174px;
}

@media (max-width: 860px) {
  .mypage-body .new-table-style table td.profile-cell,
  .mypage-body .new-table-style table td.profile-cell-admin {
    height: auto;
  }

  .mypage-profile {
    max-height: none;
  }
}

@media (min-width: 861px) {
  .profile-desc-br {
    display: none;
  }
}

@media (max-width: 640px) {
  .mypage-profile {
    padding: 10px 0;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    max-height: none;
  }

  .mypage-body .new-table-style table td {
    height: auto;
  }

  .mypage-profile-btn-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .mypage-profile-btn-wrap button {
    width: 100px;
  }

  .mypage-pwd {
    flex-direction: column;
    gap: 5px;
  }
}

.mypage-profile img {
  width: 80px;
  height: 80px;
  border-radius: 10px;
}

.mypage-profile>div {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 5px;
  /* height: 122px; */
}

.mypage-profile p {
  margin-bottom: 0px;
  font-size: 13px;
  font-weight: 400;
  color: #5a5c60;
}

.mypage-btn-wrap {
  padding: 0 16px;
}

.mypage-btn-wrap button {
  padding: 0px;
  width: 120px;
  font-size: 14px;
  font-weight: 400;
}

@media (max-width: 640px) {
  .mypage-btn-wrap {
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
    align-items: center;
    gap: 10px;
  }

  .mypage-btn-wrap>div {
    width: 100%;
  }

  .mypage-btn-wrap button {
    width: 100%;
  }
}

.mypage-radio-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mypage-radio-wrap label {
  display: flex;
  align-items: center;
  gap: 5px;
}

@media (min-width: 861px) {
  .mypage-body #table-left td:first-child {
    border-left: 1px solid #c2c7d3;
  }

  .mypage-body #table-left td:last-child {
    border-right: 1px solid #c2c7d3;
  }

  .mypage-body #table-right td:last-child {
    border-right: 1px solid #c2c7d3;
  }
}

.new-theme-wrap .new-theme-list .slider-content {
  height: 70px;
}

.new-theme-wrap .new-theme-list .slider-content .selected {
  background-color: #a7c7e7 !important;
}

.new-theme-wrap .new-theme-list .slider-content .swiper {
  width: 100%;
  max-width: 100%;
  height: 90px;
  box-sizing: border-box;
}

.new-theme-wrap .new-theme-list .slider-content .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 5px;
  height: 100%;
  width: 280px !important;
  font-size: 20px;
  color: white;
}

.new-theme-wrap .new-theme-list .slider-content .swiper-slide .campain-image {
  text-align: center;
}

.new-theme-wrap .new-theme-list .slider-content .campain-infomation .list-unstyled li {
  font-size: 0.9rem;
  color: #34383c;
}

@media (max-width: 860px) {
  .new-theme-wrap .new-theme-list .slider-content .campain-slider {
    max-height: 700px;
  }

  .new-theme-wrap .new-theme-list .slider-content .swiper-slide .campain-image {
    height: 200px;
  }
}

.btn-fold:hover {
  cursor: pointer;
  /* background-color: #cba35c;
  color: white; */
}

.new-theme-wrap,
.button-container {
  transition: max-height 0s ease-out;
  /* overflow: hidden; */
}

.new-theme-wrap.collapsed,
.button-container.collapsed {
  max-height: 0;
}

.new-theme-wrap.expanded,
.button-container.expanded {
  max-height: 1000px;
}

.user-info {
  display: flex;
  padding: 0;
}

.user-pwd {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.user-pwd input {
  max-width: 200px;
  min-width: 200px !important;
  margin: 2px 0;
}

.user-pwd em {
  margin: 2px 5px;
  width: auto;
}

.user-pwd-btn {
  padding-bottom: 5px;
}

.user-pwd .pwd-left,
.user-pwd .pwd-right {
  display: flex;
  align-items: center;
}

.listCard {
  position: relative;
  display: flex;
  padding: 16px;
  width: 100%;
  max-width: 500px;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: var(--surface);
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--sh-1);
  cursor: pointer;
  transition: box-shadow 0.15s ease, border-color 0.15s ease, transform 0.1s ease;
}

.listCard:hover {
  box-shadow: var(--sh-2);
  border-color: var(--brand-300);
}

.listCard:active {
  transform: scale(0.995);
}

/* 캠페인 목록 모바일 카드 내용 */
.listCard .cl-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.listCard .cl-region {
  font-size: var(--fs-13);
  color: var(--text-muted);
}

.listCard .cl-title {
  font-size: var(--fs-16);
  font-weight: var(--fw-bold);
  color: var(--slate-900);
  line-height: 1.35;
  margin-bottom: 14px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  word-break: break-word;
}

.listCard .cl-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: var(--fs-13);
  color: var(--text-muted);
}

.listCard .cl-user {
  font-weight: var(--fw-medium);
  color: var(--slate-600);
}

/* EHDGrid 모바일 기본 CARD(라벨-값)를 가이드 톤으로 정렬:
   라벨 알약 제거 → muted 텍스트, 값 우측 slate, 행 사이 하이라인. (CARD2 cl-card 는 영향 없음) */
.listCard .card-body {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.listCard .row-cell {
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
}
.listCard .row-cell:last-child {
  border-bottom: none;
}
.listCard .row-cell > div:first-child {
  width: auto;
  flex: 0 0 auto;
  padding: 0;
  background: none;
  border-radius: 0;
  justify-content: flex-start;
  font-size: var(--fs-13);
  font-weight: var(--fw-semibold);
  color: var(--text-muted);
}
.listCard .row-cell > div:last-child {
  width: auto;
  flex: 1 1 auto;
  text-align: right !important;
  font-size: var(--fs-14);
  color: var(--slate-800);
}

@media (max-width: 860px) {
  .user-info {
    flex-direction: column;
  }

  .user-info .col-lg-6:nth-of-type(2) table tr:first-child td {
    border-top: none;
  }

  .user-pwd em {
    width: 85%;
  }
}

@media (max-width: 640px) {

  .user-pwd .pwd-left,
  .user-pwd .pwd-right {
    display: block;
  }

  .new-table-style td:first-child,
  .new-table-style td:nth-child(3) {
    white-space: wrap;
  }

}

.stat-header {}

.stat-header-area {}

.stat-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px;
  width: 100%;
  background-color: var(--surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  box-shadow: var(--sh-1);
}

.stat-card .stat-item {
  display: flex;
  justify-content: space-around;
  align-items: center;
  width: 45%;
  padding: 10px;
  margin: 5px;
  text-align: end;
}

.stat-card .stat-item:first-child {
  border-right: 1px solid var(--border);
}

.stat-card .stat-item:last-child {
  border-left: 1px solid var(--border);
}

.stat-card .stat-item .header {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 60%;
}

.stat-card .stat-item .icon {
  font-size: 18px;
}

.stat-card .stat-item .title {
  font-size: 1rem;
}

.stat-card .stat-item .label {
  font-weight: 400;
  font-size: 0.8rem;
  line-height: 20px;
  color: var(--text-muted);
}

.stat-card .stat-item .value {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 5px;
  text-align: end;
  width: 40%;
}

.stat-card .stat-item .value .number {
  font-weight: 600;
  font-size: 2rem;
  line-height: 48px;
  text-align: right;
  color: var(--slate-900);
}

.stat-card .stat-item .value .unit {
  font-weight: 400;
  font-size: 1rem;
  line-height: 40px;
  text-align: right;
  color: #5a5c60;
}

.stat-card .stat-item .value .stat-splitter {
  margin: 0 5px;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 40px;
  text-align: right;
  color: #5a5c60;
}

.stat-card .stat-item:first-child {
  border-right: 1px solid #dfe4f2;
}

.stat-card .stat-item {
  display: flex;
  align-items: center;
  width: 45%;
  height: 100px;
  padding: 10px;
  margin: 5px;
  text-align: end;
  border: 1px solid #dfe4f2;
  border-radius: 8px;
}

/* 통계 헤더 카드: 큰 숫자/분할값(당일/누적) 깨짐 방지 — 세로 스택(제목 위·숫자 아래),
   값에 카드 전체폭 부여 + 숫자 nowrap·반응형 크기. 4카드 가로배치라 폭이 좁아 더 필요. */
.stat-card .stat-item {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  text-align: center;
  height: auto;
  min-height: 100px;
}
.stat-card .stat-item .header {
  width: 100%;
  min-width: 0;
}
.stat-card .stat-item .value {
  width: 100%;
  min-width: 0;
  margin-top: 0;
  justify-content: center;
  white-space: nowrap;
}
.stat-card .stat-item .value .number {
  font-size: clamp(1rem, 1vw + 0.55rem, 2rem);
  line-height: 1.2;
  white-space: nowrap;
}
.stat-card .stat-item .value .unit,
.stat-card .stat-item .value .stat-splitter {
  line-height: 1.2;
}

@media (max-width: 860px) {
  .stat-card {
    flex-direction: column;
    align-items: center;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-shadow: 0 0 0 0px rgba(0, 0, 0, 0);
  }

  .stat-card .stat-item {
    margin: 5px 0 !important;
    padding: 1rem 0 !important;
    width: 100% !important;
  }
}

.statistics-page canvas {
  width: 100% !important;
  height: 250px !important;
}

.stat-graph {
  width: 100%;
  max-width: 800px;
  margin: 30px auto;
}

/* Dashboard Notice Table Mobile Styles */
.dashboard-table.notice-table {
  width: 100%;
  table-layout: fixed;
}

@media (max-width: 860px) {
  .dashboard-table.notice-table colgroup col:nth-child(1) {
    width: 15% !important;
  }

  .dashboard-table.notice-table colgroup col:nth-child(2) {
    width: 45% !important;
  }

  .dashboard-table.notice-table colgroup col:nth-child(3) {
    width: 20% !important;
  }

  .dashboard-table.notice-table colgroup col:nth-child(4) {
    width: 20% !important;
  }

  .dashboard-table.notice-table td:nth-child(2) {
    text-align: left !important;
  }
}

@media (max-width: 640px) {

  /* 더 작은 화면에서는 작성자 컬럼 숨기기 */
  .dashboard-table.notice-table colgroup col:nth-child(3) {
    width: 0 !important;
  }

  .dashboard-table.notice-table th:nth-child(3),
  .dashboard-table.notice-table td:nth-child(3) {
    display: none;
  }

  .dashboard-table.notice-table colgroup col:nth-child(1) {
    width: 70% !important;
  }

  .dashboard-table.notice-table colgroup col:nth-child(2) {
    width: 30% !important;
  }

  .dashboard-table.notice-table colgroup col:nth-child(4) {
    width: 0% !important;
  }
}