/* assets/css/theme.css */

/* 공통 본문 배경/글자색 */
body.dark-mode {
  background: #1e1e1e;
  color: #ddd;
}

/* ===== Header ===== */
body.dark-mode .header {
  background: #2c2c2c;
  color: #ddd;
  border-bottom: 1px solid #666; 
}

/* 헤더 액션 버튼들 (공통) */
.btn-logout,
.btn-theme {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 2px 5px;
  border-radius: 6px;
  border: 1px solid #ccc;
  background: #fff;
  color: #333;
  cursor: pointer;
  text-decoration: none;
  font-size: 12px;
  line-height: 1;
}
.btn-theme { margin: 0 4px; }

body.dark-mode .btn-logout,
body.dark-mode .btn-theme {
  border-color: #555;
  background: #3a3a3a;
  color: #eee;
}
.btn-logout:hover,
.btn-theme:hover {
  filter: brightness(0.95);
}

/* ===== Sidebar ===== */
body.dark-mode .left-panel {
  background: #2a2a2a;
  border-right: 1px solid #444;
}
body.dark-mode .nav-category-title {
  background: #3a3a3a;
  border-bottom: 1px solid #555;
  color: #ddd;
}
body.dark-mode .nav-item {
  color: #ccc;
  border-bottom: 1px solid #444;
}
body.dark-mode .nav-item:hover {
  background: #3a3a3a;
}
body.dark-mode .nav-item.active {
  background: #006453;
  color: #fff;
}

body.dark-mode .logo-section {
  border-bottom: 1px solid #666;
}

/* ===== Login ===== */
body.dark-mode .login-wrap {
  background: #2c2c2c;
}
body.dark-mode .login-card {
  background: #333;
  border: 1px solid #444;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}
body.dark-mode .login-title { color: #eee; }
body.dark-mode .login-label { color: #ccc; }
body.dark-mode .login-input {
  background: #2b2b2b;
  color: #e6e6e6;
  border: 1px solid #555;
}
body.dark-mode .login-input:focus { border-color: #7fb3ff; }
body.dark-mode .login-error {
  background: #3a2a2a;
  color: #ffb3b3;
  border: 1px solid #553f3f;
}
body.dark-mode .login-button {
  background: #006453;
  border-color: #006453;
  color: #fff;
}
body.dark-mode .login-button:hover { filter: brightness(1.05); }

/* 콘텐츠 레이아웃 */
body.dark-mode .content-area {
  background: #262626;
  color: #e0e0e0;
}
body.dark-mode .content-title,
body.dark-mode .section-title { color: #f0f0f0; }

/* ===== 입력/폼 공통 ===== */
body.dark-mode .search-input,
body.dark-mode .search-select,
body.dark-mode .date-input,
body.dark-mode textarea,
body.dark-mode input,
body.dark-mode select,
body.dark-mode button {
  background: #2b2b2b;
  color: #e6e6e6;
  border-color: #555;
}
body.dark-mode .date-input::-webkit-calendar-picker-indicator { filter: invert(1); }

/* ===== 공통 버튼 계열 ===== */
body.dark-mode .btn {
  background: #3a3a3a;
  border-color: #555;
  color: #e6e6e6;
}
body.dark-mode .btn:hover { background: #444; }
body.dark-mode .btn-search {
  background: #006453;
  border-color: #006453;
  color: #fff;
}
body.dark-mode .btn-search:hover { filter: brightness(1.1); }
body.dark-mode .btn-reset,
body.dark-mode .btn-red {
  background: transparent;
  border: 1px solid #ccc;
  color: #ccc;
}
body.dark-mode .btn-reset:hover,
body.dark-mode .btn-red:hover { background: #f5f5f5; }

/* 날짜 빠른필터 */
body.dark-mode .btn-date-filter {
  background-color: #343a40;
  border-color: #495057;
  color: #e9ecef;
}
body.dark-mode .btn-date-filter.active {
  background-color: #006453;
  border-color: #006453;
  color: #fff;
}

/* ===== 검색 섹션 ===== */
body.dark-mode .search-section {
  background: #2a2a2a;
  border-color: #444;
}
body.dark-mode .search-table th,
body.dark-mode .search-table td {
  border-color: #444;
}
body.dark-mode .search-table th {
  background: #333;
  color: #e6e6e6;
}
body.dark-mode .search-table td { background: #2a2a2a; }

/* ===== 표(테이블) 공통 ===== */
body.dark-mode .info-table,
body.dark-mode .data-table,
body.dark-mode .product-table,
body.dark-mode .cs-table,
body.dark-mode .memo-table,
body.dark-mode .modal-table {
  background: #2a2a2a;
}
body.dark-mode .info-table th, body.dark-mode .info-table td,
body.dark-mode .data-table th, body.dark-mode .data-table td,
body.dark-mode .product-table th, body.dark-mode .product-table td,
body.dark-mode .cs-table th, body.dark-mode .cs-table td,
body.dark-mode .memo-table th, body.dark-mode .memo-table td,
body.dark-mode .modal-table th, body.dark-mode .modal-table td {
  border-color: #444;
  color: #e6e6e6;
}
body.dark-mode .info-table th,
body.dark-mode .data-table th,
body.dark-mode .product-table th,
body.dark-mode .cs-table th,
body.dark-mode .memo-table th,
body.dark-mode .modal-table th {
  background: #333;
  color: #f0f0f0;
}
body.dark-mode .data-table tr:nth-child(even) { background: #2f2f2f; }
body.dark-mode .product-table .product-img {
  border-color: #444;
  background: #2f2f2f;
}

/* === Sort Arrows (dark) === */
body.dark-mode .data-table th a {
  color: #bbb;
  border-color: transparent;
  background: transparent;
}
body.dark-mode .data-table th a:hover {
  background: #444;
  color: #fff;
}
body.dark-mode .data-table th a.active {
  background: #006453;
  border-color: #006453;
  color: #fff;
}

/* ===== 테이블 컨트롤/섹션 ===== */
body.dark-mode .table-section {
  background: #2a2a2a;
  border-color: #444;
}
body.dark-mode .table-header .table-title { color: #f0f0f0; }

/* ===== 페이지네이션 ===== */
body.dark-mode .pagination-section {
  background: #2a2a2a;
  border-color: #444;
}
body.dark-mode .pagination a,
body.dark-mode .pagination strong {
  border-color: #555;
  background: #3a3a3a;
  color: #e6e6e6;
}
body.dark-mode .pagination strong {
  background: #006453;
  border-color: #006453;
  color: #fff;
}

/* ===== 모달 ===== */
body.dark-mode .modal-overlay { background-color: rgba(0,0,0,0.6); }
body.dark-mode .modal-content {
  background: #2d2d2d;
  color: #e6e6e6;
  box-shadow: 0 2px 12px rgba(0,0,0,0.6);
}
body.dark-mode .modal-header { color: #f0f0f0; }
body.dark-mode .modal-table th { background: #333; }
body.dark-mode .modal-footer .btn { background: #3a3a3a; }

/* ===== 보조 ===== */
body.dark-mode .search-actions,
body.dark-mode .footer-buttons { color: #e6e6e6; }

/* === Error Page (Dark) === */
body.dark-mode.error-page { background: #1e1e1e; color: #ddd; }
body.dark-mode .error-card {
  background: #2a2a2a;
  border-color: #444;
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
body.dark-mode .error-title { color: #ff7676; }
body.dark-mode .error-desc { color: #ddd; }
body.dark-mode .error-detail h3 { color: #e6e6e6; }
body.dark-mode .error-detail pre {
  background: #242424;
  border-color: #3a3a3a;
  color: #e6e6e6;
}

/* 버튼 가독성 */
body.dark-mode .error-actions .btn {
  background: #3a3a3a;
  border-color: #555;
  color: #e6e6e6;
}
body.dark-mode .error-actions .btn:hover { background: #444; }

/* 다크모드 사이드바 active */
body.dark-mode .nav-item.active {
  background: #006453;
  color: #fff;
}

/* ===== Dark mode: 링크 색 (모달/본문 공통) ===== */
body.dark-mode a,
body.dark-mode .modal-content a {
  color: #cfe1ff;          /* 밝은 파란색 */
  text-decoration: none;
}
body.dark-mode a:hover,
body.dark-mode .modal-content a:hover {
  color: #ffffff;
  text-decoration: underline;
}
body.dark-mode a:visited,
body.dark-mode .modal-content a:visited {
  color: #b8d2ff;          /* visited도 밝게 */
}

/* ===== Dark mode: 파일 업로드 입력 ===== */
/* input[type=file] 전체 박스 */
body.dark-mode input[type="file"] {
  background: #2b2b2b;
  color: #e6e6e6;
  border: 1px solid #555;
  border-radius: 4px;
  padding: 6px;
}

/* 크롬/엣지/사파리: 파일 선택 버튼 */
body.dark-mode input[type="file"]::file-selector-button {
  background: #3a3a3a;
  color: #e6e6e6;
  border: 1px solid #555;
  border-radius: 4px;
  padding: 6px 10px;
  margin-right: 8px;
  cursor: pointer;
}
body.dark-mode input[type="file"]::file-selector-button:hover {
  background: #444;
}

/* 파이어폭스: 파일 선택 버튼 */
@-moz-document url-prefix() {
  body.dark-mode input[type="file"] {
    padding: 0; /* FF는 버튼/라벨 스타일이 다르므로 최소화 */
  }
  body.dark-mode input[type="file"]::-moz-file-upload-button {
    background: #3a3a3a;
    color: #e6e6e6;
    border: 1px solid #555;
    border-radius: 4px;
    padding: 6px 10px;
    margin-inline-end: 8px;
    cursor: pointer;
  }
  body.dark-mode input[type="file"]::-moz-file-upload-button:hover {
    background: #444;
  }
}

/* 업로드 바(설명 라인 등)를 어둡게 하고 텍스트 밝게 */
body.dark-mode .ri-filebar,
body.dark-mode .filebar {
  background: #2a2a2a;
  border: 1px solid #444;
  color: #e6e6e6;
}

/* 업로드 버튼(이미 공통 .btn 규칙 있지만 강조하고 싶다면) */
body.dark-mode .btn-upload {
  background: #3a3a3a;
  border-color: #555;
  color: #e6e6e6;
}
body.dark-mode .btn-upload:hover { background: #444; }

/* ===== Form controls accent (checkbox/radio) ===== */
/* 기본(라이트/다크 공통) */
input[type="checkbox"],
input[type="radio"] {
  accent-color: #006453; /* 선택 색상을 브랜드 컬러로 고정 */
}

/* 다크모드에서도 동일하게 유지 (명시적 중복 지정) */
body.dark-mode input[type="checkbox"],
body.dark-mode input[type="radio"] {
  accent-color: #006453;
}

/* 포커스 시 윤곽선도 너무 보라/파랑 튀지 않게 */
input[type="checkbox"]:focus-visible,
input[type="radio"]:focus-visible {
  outline: 2px solid #006453;
  outline-offset: 2px;
}

/* 라벨 정렬 보정(체크박스+텍스트 정렬) */
label > input[type="checkbox"],
label > input[type="radio"] {
  vertical-align: middle;
  margin-right: 4px;
}

/* === Product Dashboard (Dark Mode Overrides) === */
body.dark-mode {
  --pld-bg: #1f2427;        /* 카드 배경 유지 */
  --pld-border: #384047;    /* 활성 테두리 기준색(체브론 외곽) */
  --pld-border-soft: #384047;/* 일반 테두리도 동일 회색으로 유지 */
  --pld-text: #dfe7ef;
  --pld-subtext: #9aabb8;
  --pld-green: #006453;     /* 선택 강조 */
}

/* 다크(부모 body에 .dark-mode) */ body.dark-mode .img-card{ background:#111418 !important; border-color:#2b2f36 !important; box-shadow:0 1px 0 rgba(0,0,0,.45) inset; }
body.dark-mode .img-box{ background:#0f1216 !important; border-color:#454b56 !important; }
body.dark-mode .img-box .placeholder{ color:#b7c0cc !important; }
body.dark-mode #image-size-guide{ color:#9aa4b2 !important; }

/* Dashboard chips (pld-*) — Dark overrides */
body.dark-mode {
  --pld-bg: #1f2427;
  --pld-border: #384047;
  --pld-border-soft: #384047;
  --pld-text: #dfe7ef;
  --pld-subtext: #9aabb8;
  --pld-green: #006453;
}