/**
 * erp-ui-polish.css
 * ─────────────────────────────────────────────────────────────────────────────
 * 비파괴적 개선 레이어 — 기존 CSS 구조를 일절 깨지 않고 위에 얹음.
 * 로드 순서: erp-index-layout-extras.css 다음에 마지막으로 링크.
 *
 * 개선 범위:
 *  1. 패널 글래스 & 엣지 하이라이트
 *  2. 탭바 animated active indicator
 *  3. 섹션 타이틀 kicker 정제
 *  4. 테이블 hover accent slide
 *  5. KPI/metric 카드 accent bar + glow
 *  6. AI 패널 frosted glass 업그레이드
 *  7. 버튼 micro-interaction
 *  8. 패널 stagger fade-in
 *  9. 헤더 eyebrow gradient text
 * 10. 스크롤 가능 영역 커스텀 스크롤바
 * 11. 툴팁·토스트 정제
 * 12. 다크/웜 테마 보완
 * ─────────────────────────────────────────────────────────────────────────────
 */

/* ═══════════════════════════════════════════════════════════
   0. 공통 애니메이션 키프레임
   ═══════════════════════════════════════════════════════════ */

@keyframes polish-fadein {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes polish-slidein {
  from { opacity: 0; transform: translateX(-6px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes polish-scaleup {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes polish-bar-grow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

@keyframes polish-pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 var(--polish-glow, rgba(37, 99, 235, 0.0)); }
  50%       { box-shadow: 0 0 0 6px var(--polish-glow, rgba(37, 99, 235, 0.12)); }
}


/* ═══════════════════════════════════════════════════════════
   1. 패널 글래스모피즘 & 엣지 하이라이트
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .panel {
  position: relative;
  /* 상단 내부 반사선: 유리 느낌 */
  box-shadow:
    var(--impact-panel-shadow, 0 16px 42px rgba(15, 23, 42, 0.10)),
    inset 0 1px 0 rgba(255, 255, 255, 0.55),
    inset 0 -1px 0 rgba(15, 23, 42, 0.04) !important;
  transition:
    box-shadow 0.22s ease,
    transform 0.18s ease,
    border-color 0.18s ease !important;
  /* 패널 fade-in */
  animation: polish-fadein 0.32s ease both;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .panel:hover {
  box-shadow:
    var(--impact-panel-shadow-hover, 0 24px 54px rgba(15, 23, 42, 0.14)),
    inset 0 1px 0 rgba(255, 255, 255, 0.65),
    inset 0 -1px 0 rgba(15, 23, 42, 0.03) !important;
  transform: translateY(-1px) !important;
}

/* 다크 테마 패널 */
body.erp-atlas[data-theme="dark"]:not(.cover-mode):not(.main-summary-mode) .panel {
  box-shadow:
    0 18px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    inset 0 -1px 0 rgba(0, 0, 0, 0.2) !important;
}
body.erp-atlas[data-theme="dark"]:not(.cover-mode):not(.main-summary-mode) .panel:hover {
  box-shadow:
    0 26px 60px rgba(0, 0, 0, 0.52),
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 -1px 0 rgba(0, 0, 0, 0.18) !important;
}

/* 웜 테마 패널 */
body.erp-atlas[data-theme="warm"]:not(.cover-mode):not(.main-summary-mode) .panel {
  box-shadow:
    0 14px 38px rgba(20, 18, 26, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    inset 0 -1px 0 rgba(20, 18, 26, 0.03) !important;
}

/* 패널 좌측 primary 액센트 라인 (선택적: panel-main 에만) */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .panel-main {
  border-left: 3px solid color-mix(in srgb, var(--primary) 55%, transparent) !important;
}
body.erp-atlas[data-theme="dark"]:not(.cover-mode):not(.main-summary-mode) .panel-main {
  border-left: 3px solid color-mix(in srgb, var(--primary) 45%, transparent) !important;
}


/* ═══════════════════════════════════════════════════════════
   2. 패널 헤더 구분선 & 타이포
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .panel-head {
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 14%, var(--line)) !important;
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--primary) 4%, var(--panel)) 0%,
    var(--panel) 100%
  ) !important;
  border-radius: var(--impact-panel-radius, 20px) var(--impact-panel-radius, 20px) 0 0 !important;
}

/* panel-head 타이포는 erp-index-section-overrides.css 단일 소스 사용 */


/* ═══════════════════════════════════════════════════════════
   3. 탭바 animated active indicator
   ═══════════════════════════════════════════════════════════ */

/* active 탭 아래 animated underline indicator (fusion/기본) */
body.erp-atlas:not([data-toolbar-variant]):not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab.active::after,
body.erp-atlas[data-toolbar-variant="fusion"]:not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 8px;
  right: 8px;
  height: 2.5px;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--primary), var(--accent, #0ea5e9));
  animation: polish-bar-grow 0.26s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  transform-origin: left center;
}

body.erp-atlas:not([data-toolbar-variant]):not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab,
body.erp-atlas[data-toolbar-variant="fusion"]:not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab {
  position: relative;
  transition:
    color 0.16s ease,
    background 0.18s ease,
    opacity 0.16s ease !important;
}

body.erp-atlas:not([data-toolbar-variant]):not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab:not(.active):hover,
body.erp-atlas[data-toolbar-variant="fusion"]:not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab:not(.active):hover {
  background: color-mix(in srgb, var(--primary) 8%, transparent) !important;
  border-radius: 10px !important;
}

/* 탭 glyph 아이콘 부드럽게 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab .atlas-dock-glyph {
  transition: transform 0.18s ease !important;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode)
  .unified-toolbar .atlas-dock--top .atlas-dock-item.tab.active .atlas-dock-glyph {
  transform: scale(1.1) !important;
}


/* ═══════════════════════════════════════════════════════════
   4. 섹션 타이틀 kicker 정제
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 10.5px !important;
  font-weight: 900 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--primary) !important;
  margin-bottom: 6px !important;
}

/* kicker 앞 accent bar */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-kicker::before {
  content: "" !important;
  display: inline-block !important;
  width: 16px !important;
  height: 2px !important;
  border-radius: 99px !important;
  background: linear-gradient(90deg, var(--primary), var(--accent, #0ea5e9)) !important;
  animation: polish-bar-grow 0.35s ease both !important;
  transform-origin: left center !important;
  flex-shrink: 0 !important;
}

/* section-title 타이포는 erp-index-section-overrides.css 단일 소스 사용 */


/* ═══════════════════════════════════════════════════════════
   5. 테이블 hover accent slide
   ═══════════════════════════════════════════════════════════ */

/* 호버 바: tr::before 는 Blink/WebKit 에서 익명 표 셀을 만들어 열이 한 칸씩 밀림.
   첫 셀에만 ::before → 모든 .ranking-table 에서 레이아웃 안전 + 동일 비주얼 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table tbody tr {
  transition: background 0.14s ease !important;
  cursor: default;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table tbody tr td:first-child {
  position: relative;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table tbody tr td:first-child::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: color-mix(in srgb, var(--primary) 18%, transparent);
  border-radius: 0 4px 4px 0;
  transition: width 0.18s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
  pointer-events: none;
  z-index: 1;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table tbody tr:hover td:first-child::before {
  width: 3px;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table th {
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table td {
  font-size: 12.5px !important;
  vertical-align: middle !important;
}

/* 숫자 컬럼 tabular numerals */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table td.num,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .ranking-table th.num {
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
}


/* ═══════════════════════════════════════════════════════════
   6. KPI / metric 카드 accent bar + glow
   ═══════════════════════════════════════════════════════════ */

/* kpi 카드 stagger animation */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > * {
  animation: polish-fadein 0.28s ease both;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(1) { animation-delay: 0.04s; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(2) { animation-delay: 0.08s; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(3) { animation-delay: 0.12s; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(4) { animation-delay: 0.16s; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(5) { animation-delay: 0.20s; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .metric-strip > *:nth-child(6) { animation-delay: 0.24s; }

/* kpi 카드 호버 리프트 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .product-kpi-strip > * {
  transition: transform 0.18s ease, box-shadow 0.18s ease !important;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .product-kpi-strip > *:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 8px 24px color-mix(in srgb, var(--primary) 18%, transparent),
    inset 0 1px 0 rgba(255,255,255,0.6) !important;
}


/* ═══════════════════════════════════════════════════════════
   7. AI 패널 frosted glass 업그레이드
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .erp-ai-panel {
  backdrop-filter: blur(16px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.3) !important;
  border: 1.5px solid var(--ai-panel-border) !important;
  box-shadow:
    0 8px 32px rgba(109, 40, 217, 0.12),
    0 2px 8px rgba(109, 40, 217, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
  animation: polish-scaleup 0.28s cubic-bezier(0.34, 1.4, 0.64, 1) both !important;
}

body.erp-atlas .erp-ai-panel__header {
  background: linear-gradient(
    to right,
    rgba(109, 40, 217, 0.12),
    rgba(139, 92, 246, 0.07)
  ) !important;
}

body.erp-atlas .erp-ai-panel__title {
  background: linear-gradient(90deg, #6d28d9, #8b5cf6);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

body.erp-atlas[data-theme="dark"] .erp-ai-panel__title {
  background: linear-gradient(90deg, #a78bfa, #c4b5fd);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

body.erp-atlas .erp-ai-btn {
  transition: filter 0.16s ease, transform 0.14s ease, box-shadow 0.16s ease !important;
}
body.erp-atlas .erp-ai-btn:hover:not(:disabled) {
  filter: brightness(1.08) !important;
  transform: translateY(-1px) !important;
  box-shadow:
    0 4px 16px rgba(109, 40, 217, 0.32),
    0 1px 0 rgba(255,255,255,0.18) inset !important;
}
body.erp-atlas .erp-ai-btn:active:not(:disabled) {
  transform: translateY(0) !important;
  filter: brightness(0.96) !important;
}


/* ═══════════════════════════════════════════════════════════
   8. 버튼 micro-interaction
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode) .btn,
body.erp-atlas:not(.cover-mode) .btn-mini,
body.erp-atlas:not(.cover-mode) .org-compare-period-btn,
body.erp-atlas:not(.cover-mode) .main-summary-org-toggle-btn {
  transition:
    background 0.14s ease,
    color 0.14s ease,
    border-color 0.14s ease,
    transform 0.12s ease,
    box-shadow 0.14s ease !important;
}

body.erp-atlas:not(.cover-mode) .btn:not([disabled]):not(:disabled):hover,
body.erp-atlas:not(.cover-mode) .btn-mini:not([disabled]):not(:disabled):hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 10px color-mix(in srgb, var(--primary) 22%, transparent) !important;
}

body.erp-atlas:not(.cover-mode) .btn:active,
body.erp-atlas:not(.cover-mode) .btn-mini:active {
  transform: translateY(0) scale(0.98) !important;
}

/* 헤더 nav 버튼 */
body.erp-atlas:not(.cover-mode) .header-left-nav-btn,
body.erp-atlas:not(.cover-mode) .main-summary-left-nav-btn {
  transition:
    background 0.14s ease,
    border-color 0.14s ease,
    transform 0.12s ease !important;
}
body.erp-atlas:not(.cover-mode) .header-left-nav-btn:active,
body.erp-atlas:not(.cover-mode) .main-summary-left-nav-btn:active {
  transform: translateY(0) scale(0.97) !important;
}


/* ═══════════════════════════════════════════════════════════
   9. 뷰 섹션 stagger fade-in
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .view.active > .section {
  animation: polish-fadein 0.35s ease both;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .view.active > .section:nth-child(2) {
  animation-delay: 0.08s;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .view.active > .section:nth-child(3) {
  animation-delay: 0.14s;
}

/* 섹션 타이틀 slide-in */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .view.active .section-title {
  animation: polish-slidein 0.32s ease both;
}


/* ═══════════════════════════════════════════════════════════
   10. 스크롤 가능 영역 — 얇은 커스텀 스크롤바
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .erp-ai-panel__body,
body.erp-atlas .qa-questions,
body.erp-atlas .qa-questions-card .qa-question-list,
body.erp-atlas .oc-members-scroll,
body.erp-atlas .report-scroll-body,
body.erp-atlas .builder-catalog-wrap,
body.erp-atlas .builder-help-body {
  scrollbar-width: thin !important;
  scrollbar-color: color-mix(in srgb, var(--primary) 35%, transparent) transparent !important;
}

body.erp-atlas .erp-ai-panel__body::-webkit-scrollbar,
body.erp-atlas .qa-questions::-webkit-scrollbar,
body.erp-atlas .qa-questions-card .qa-question-list::-webkit-scrollbar,
body.erp-atlas .oc-members-scroll::-webkit-scrollbar,
body.erp-atlas .report-scroll-body::-webkit-scrollbar {
  display: block !important;
  width: 4px !important;
}

body.erp-atlas .erp-ai-panel__body::-webkit-scrollbar-track,
body.erp-atlas .qa-questions::-webkit-scrollbar-track,
body.erp-atlas .qa-questions-card .qa-question-list::-webkit-scrollbar-track,
body.erp-atlas .oc-members-scroll::-webkit-scrollbar-track,
body.erp-atlas .report-scroll-body::-webkit-scrollbar-track {
  background: transparent !important;
}

body.erp-atlas .erp-ai-panel__body::-webkit-scrollbar-thumb,
body.erp-atlas .qa-questions::-webkit-scrollbar-thumb,
body.erp-atlas .qa-questions-card .qa-question-list::-webkit-scrollbar-thumb,
body.erp-atlas .oc-members-scroll::-webkit-scrollbar-thumb,
body.erp-atlas .report-scroll-body::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--primary) 38%, transparent) !important;
  border-radius: 99px !important;
}


/* ═══════════════════════════════════════════════════════════
   11. 헤더 eyebrow gradient text (쿨톤/다크)
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not([data-theme]):not(.cover-mode) .page-header-eyebrow,
body.erp-atlas[data-theme="white"]:not(.cover-mode) .page-header-eyebrow,
body.erp-atlas:not([data-theme]):not(.cover-mode) .main-summary-title-sub,
body.erp-atlas[data-theme="white"]:not(.cover-mode) .main-summary-title-sub {
  background: linear-gradient(90deg, rgba(255,255,255,0.88), rgba(147, 210, 255, 0.9));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

body.erp-atlas[data-theme="dark"]:not(.cover-mode) .page-header-eyebrow,
body.erp-atlas[data-theme="dark"]:not(.cover-mode) .main-summary-title-sub {
  background: linear-gradient(90deg, rgba(232, 160, 144, 0.9), rgba(196, 181, 253, 0.85));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ═══════════════════════════════════════════════════════════
   12. 모달 개선
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .modal-card {
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.28),
    0 8px 24px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.45) !important;
  animation: polish-scaleup 0.3s cubic-bezier(0.34, 1.4, 0.64, 1) both !important;
}

body.erp-atlas[data-theme="dark"] .modal-card {
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.6),
    0 8px 24px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

body.erp-atlas .modal-head {
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 14%, var(--line)) !important;
}

body.erp-atlas .modal-backdrop {
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  background: rgba(0, 0, 0, 0.42) !important;
}

/* 개발 중(WIP) 모달 — 맞춤·Q&A·조직도 동일 카드(Atlas에서만 폭 오버라이드) */
body.erp-atlas #wipFeatureModal.modal .modal-card.wip-feature-modal-card {
  width: min(848px, calc(100vw - 28px)) !important;
  max-width: min(848px, calc(100vw - 28px)) !important;
}

body.erp-atlas #wipFeatureModal .wip-feature-modal-desc {
  display: block !important;
  width: auto !important;
  min-height: 0 !important;
  justify-content: unset !important;
  align-items: unset !important;
}

body.erp-atlas #wipFeatureModal .modal-backdrop.wip-feature-modal-backdrop::after {
  color: rgba(255, 255, 255, 0.09) !important;
}


/* ═══════════════════════════════════════════════════════════
   13. 로딩 카드 & 스피너
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .loading-card {
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.55) !important;
  border-radius: 20px !important;
}

/* 무지개 링 스피너: 테두리 스피너 아님 — 테마에서 가해지던 border 제거 */
body.erp-atlas .loading-spinner {
  border: none !important;
}


/* ═══════════════════════════════════════════════════════════
   14. 토스트 알림 정제
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .dashboard-toast {
  top: 50% !important;
  bottom: auto !important;
  left: 50% !important;
  right: auto !important;
  min-width: 280px !important;
  max-width: min(88vw, 520px) !important;
  padding: 14px 20px !important;
  transform: translate(-50%, calc(-50% + 18px)) scale(0.96) !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
  color: var(--title) !important;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--panel) 94%, white 6%),
    color-mix(in srgb, var(--panel-strong) 92%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--panel-border) 88%, var(--accent) 12%) !important;
  backdrop-filter: blur(10px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.2) !important;
  box-shadow:
    0 8px 28px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
  border-radius: 14px !important;
}

body.erp-atlas .dashboard-toast.is-visible {
  transform: translate(-50%, -50%) scale(1) !important;
}

body.erp-atlas .dashboard-toast.success {
  color: #0f3d2e !important;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, white 86%, var(--ok) 14%),
    color-mix(in srgb, var(--ok) 16%, var(--panel) 84%)
  ) !important;
  border-color: color-mix(in srgb, var(--ok) 36%, var(--panel-border)) !important;
}

body.erp-atlas .dashboard-toast.error {
  color: #7f1d1d !important;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, white 88%, var(--bad) 12%),
    color-mix(in srgb, var(--bad) 15%, var(--panel) 85%)
  ) !important;
  border-color: color-mix(in srgb, var(--bad) 34%, var(--panel-border)) !important;
}

/* 의견 알림: 화면 중앙 토스트 규칙 무시 → 우측 상단·조금 더 큼 */
body.erp-atlas .dashboard-toast.dashboard-toast--feedback {
  top: 88px !important;
  bottom: auto !important;
  left: auto !important;
  right: 20px !important;
  transform: translate(12px, -8px) scale(0.98) !important;
  text-align: left !important;
  min-width: 320px !important;
  max-width: min(92vw, 460px) !important;
  padding: 16px 18px !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  pointer-events: auto !important;
}
body.erp-atlas .dashboard-toast.dashboard-toast--feedback.is-visible {
  transform: translate(0, 0) scale(1) !important;
}


/* ═══════════════════════════════════════════════════════════
   15. 이슈 센터 개선
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode) .issue-drilldown-placeholder-icon {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--muted)) !important;
  color: color-mix(in srgb, var(--primary) 40%, var(--muted)) !important;
  animation: polish-pulse-glow 2.8s ease-in-out infinite;
  --polish-glow: color-mix(in srgb, var(--primary) 14%, transparent);
}


/* ═══════════════════════════════════════════════════════════
   16. glass-panel (메인요약) 개선
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .glass-panel {
  box-shadow:
    0 20px 56px rgba(0, 0, 0, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    inset 0 -1px 0 rgba(15, 23, 42, 0.03) !important;
  animation: polish-fadein 0.36s ease both !important;
}

body.erp-atlas[data-theme="dark"] .glass-panel {
  box-shadow:
    0 22px 56px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
}


/* ═══════════════════════════════════════════════════════════
   17. Record Builder (맞춤 보고서) UI 정제
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .rb-btn {
  transition:
    background 0.14s ease,
    color 0.14s ease,
    border-color 0.14s ease,
    transform 0.12s ease,
    box-shadow 0.14s ease !important;
}

body.erp-atlas .rb-btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 10px color-mix(in srgb, var(--primary) 20%, transparent) !important;
}

body.erp-atlas .rb-topbar {
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 12%, var(--line)) !important;
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--primary) 3%, var(--panel)),
    var(--panel)
  ) !important;
}


/* ═══════════════════════════════════════════════════════════
   18. Panel eyebrow (panel-eyebrow in main-summary)
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .panel-eyebrow {
  font-size: 9.5px !important;
  font-weight: 900 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: color-mix(in srgb, var(--primary) 80%, var(--muted)) !important;
  opacity: 0.85 !important;
}


/* ═══════════════════════════════════════════════════════════
   19. 툴팁 UI 정제
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas .ui-tooltip {
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  box-shadow: 0 6px 22px rgba(0,0,0,0.18), 0 1px 4px rgba(0,0,0,0.1) !important;
  border-radius: 10px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1.55 !important;
}


/* ═══════════════════════════════════════════════════════════
   20. 접근성 & prefers-reduced-motion 준수
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  body.erp-atlas .panel,
  body.erp-atlas .glass-panel,
  body.erp-atlas .erp-ai-panel,
  body.erp-atlas .modal-card,
  body.erp-atlas .view.active > .section,
  body.erp-atlas .view.active .section-title,
  body.erp-atlas .metric-strip > *,
  body.erp-atlas .product-kpi-strip > * {
    animation: none !important;
    transition: none !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   21. 필터 선택 강조 효과 — 전면 재설계
   ─────────────────────────────────────────────────────────
   구조: label(래퍼) > .filter-group-label(왼쪽 텍스트) + select(오른쪽)
   기존 문제: inset left-bar + 연파랑 배경 → 약하고 어중간한 강조
   새 방향:
     · label 전체가 하나의 unified pill처럼 보이도록
     · 활성 시 → gradient fill + 흰 글자 + glow ring
     · hover → 부드러운 primary tint + 위로 살짝 lift
     · 비활성 → 기존보다 더 깔끔한 glass pill
     · 트랜지션 전면 강화 (0.2s → cubic-bezier spring)
   ═══════════════════════════════════════════════════════════ */

/* ── 쿨톤(white/기본) ── */

/* 비활성 기본: 더 투명하고 깔끔한 glass pill */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label .filter-group-label,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label .filter-group-label,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label .filter-group-label,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label .filter-group-label {
  background: rgba(248, 250, 252, 0.92) !important;
  border: 1px solid rgba(203, 213, 225, 0.9) !important;
  border-right: none !important;
  color: #475569 !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease !important;
}

html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label select,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label select,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label select,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label select {
  background: #ffffff !important;
  border: 1px solid rgba(203, 213, 225, 0.9) !important;
  color: #1e293b !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease !important;
}

/* hover — label 전체 primary tint + lift */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 12px rgba(37, 99, 235, 0.12) !important;
}

html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label {
  background: rgba(219, 234, 254, 0.85) !important;
  border-color: rgba(147, 197, 253, 0.8) !important;
  color: #1d4ed8 !important;
}

html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover select,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover select,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:hover select,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:hover select {
  border-color: rgba(147, 197, 253, 0.8) !important;
}

/* ★ 활성(is-filtered) — 디자인 랩 시안 C: 135° primary/primary-2 + 인셋 링 + 본문색 */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label select.is-filtered,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label select.is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary, #2563eb) 38%, transparent),
    color-mix(in srgb, var(--primary-2, #3b82f6) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow:
    0 2px 12px color-mix(in srgb, var(--primary, #2563eb) 22%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
  text-shadow: none !important;
}

/* ★ 활성(is-active / :has) — label 래퍼: gradient fill 통합 pill */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label.is-active,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label.is-active,
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered),
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered),
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label.is-active,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label.is-active,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered),
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) {
  /* 선택 표시는 select 배경만 사용 */
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  color: inherit !important;
}

/* 활성 시 라벨 탭도 gradient에 어울리게 */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label,
body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary, #2563eb) 38%, transparent),
    color-mix(in srgb, var(--primary-2, #3b82f6) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
  border-right: none !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
  text-shadow: none !important;
}


/* ── 다크 테마 ── */

body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label .filter-group-label {
  background: rgba(30, 27, 46, 0.92) !important;
  border: 1px solid rgba(100, 90, 130, 0.28) !important;
  border-right: none !important;
  color: #8b82a0 !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease !important;
}

body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label select {
  background: rgba(22, 20, 34, 0.96) !important;
  border: 1px solid rgba(100, 90, 130, 0.28) !important;
  color: #e2dff0 !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease !important;
}

/* 다크 hover */
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 14px color-mix(in srgb, var(--primary) 24%, transparent) !important;
}
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label {
  background: rgba(50, 40, 68, 0.95) !important;
  border-color: color-mix(in srgb, var(--primary) 44%, rgba(100, 90, 130, 0.42)) !important;
  color: color-mix(in srgb, var(--primary) 72%, #f5f8ff) !important;
}
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:hover select {
  border-color: color-mix(in srgb, var(--primary) 44%, rgba(100, 90, 130, 0.42)) !important;
}

/* 다크 활성 select — 시안 C 동일 그라데이션 */
body.erp-atlas[data-theme="dark"]:not(.cover-mode):not(.main-summary-mode) #filterBox .filter-group label select.is-filtered,
body.erp-atlas[data-theme="dark"]:not(.cover-mode):not(.main-summary-mode) #filterStrip .filter-group select.is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow:
    0 2px 12px rgba(0, 0, 0, 0.4),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent) !important;
}

/* 다크 활성 label 래퍼 */
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label.is-active,
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label {
  background: rgba(30, 27, 46, 0.92) !important;
  border: 1px solid rgba(100, 90, 130, 0.28) !important;
  border-right: none !important;
  color: #8b82a0 !important;
  font-weight: 600 !important;
}


/* ── 웜 테마 ── */

body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label .filter-group-label {
  background: rgba(255, 250, 242, 0.92) !important;
  border: 1px solid rgba(180, 140, 90, 0.24) !important;
  border-right: none !important;
  color: #7c6a50 !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease !important;
}

body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label select {
  background: #fffcf8 !important;
  border: 1px solid rgba(180, 140, 90, 0.24) !important;
  color: #292019 !important;
  transition:
    background 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease !important;
}

/* 웜 hover */
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 12px rgba(196, 92, 62, 0.12) !important;
}
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label:hover .filter-group-label {
  background: rgba(253, 234, 220, 0.9) !important;
  border-color: rgba(196, 92, 62, 0.36) !important;
  color: #c45c3e !important;
}
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label:hover select {
  border-color: rgba(196, 92, 62, 0.36) !important;
}

/* 웜 활성 select — 시안 C(테마 primary) */
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow:
    0 2px 10px color-mix(in srgb, var(--primary) 22%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent) !important;
}

/* 웜 활성 label 래퍼 */
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label.is-active,
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) {
  /* 선택 표시는 select 배경만 사용 */
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
body[data-theme="warm"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label {
  background: rgba(255, 250, 242, 0.92) !important;
  border-color: rgba(180, 140, 90, 0.24) !important;
  border-right: none !important;
  color: #7c6a50 !important;
  font-weight: 600 !important;
}


/* ── label 래퍼에 transform transition 추가 (공통) ── */
body:not(.cover-mode) #filterBox .filter-group label {
  transition:
    transform 0.18s cubic-bezier(0.34, 1.4, 0.64, 1),
    box-shadow 0.2s ease,
    background 0.18s ease,
    border-color 0.18s ease !important;
}

/* #filterStrip 인라인 필터 (topPeriodFilters 등) — 시안 C */
body.erp-atlas:not(.cover-mode) .compact-top-filters select.is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow:
    0 2px 12px color-mix(in srgb, var(--primary) 24%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent) !important;
}

/* ── 테마별 선택 상태 통일: 디자인 랩 시안 C(135° primary/primary-2 + 인셋 링) ── */
body[data-theme="white"]:not(.cover-mode),
body:not([data-theme]):not(.cover-mode),
body[data-theme="default"]:not(.cover-mode) {
  --erp-active-bg: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary, #2563eb) 38%, transparent),
    color-mix(in srgb, var(--primary-2, #3b82f6) 28%, transparent)
  );
  --erp-active-border: color-mix(in srgb, var(--primary, #2563eb) 35%, transparent);
  --erp-active-text: var(--text);
  --erp-active-shadow: 0 2px 12px color-mix(in srgb, var(--primary, #2563eb) 22%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary, #2563eb) 35%, transparent);
}
body[data-theme="dark"]:not(.cover-mode) {
  --erp-active-bg: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  );
  --erp-active-border: color-mix(in srgb, var(--primary) 35%, transparent);
  --erp-active-text: var(--text);
  --erp-active-shadow: 0 2px 12px rgba(0, 0, 0, 0.4),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent);
}
body[data-theme="warm"]:not(.cover-mode) {
  --erp-active-bg: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  );
  --erp-active-border: color-mix(in srgb, var(--primary) 35%, transparent);
  --erp-active-text: var(--text);
  --erp-active-shadow: 0 2px 10px color-mix(in srgb, var(--primary) 22%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent);
}

/* 조직단위/기간/막대-선/데이터레이블 등 선택 버튼 공통 스타일 */
body:not(.cover-mode) .btn-mini.is-active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) .main-summary-org-toggle-btn.is-active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) .org-compare-period-btn.is-active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) .customer-share-rank-tab-btn.is-active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) .gran-btn.active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) .btn-mini.active:not(.tab):not(.atlas-dock-item),
body:not(.cover-mode) button.active:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle),
body:not(.cover-mode) button[aria-pressed="true"]:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle),
body:not(.cover-mode) button[aria-selected="true"]:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle) {
  background: var(--erp-active-bg) !important;
  border: 1px solid var(--erp-active-border) !important;
  color: var(--erp-active-text) !important;
  font-weight: 800 !important;
  box-shadow: var(--erp-active-shadow) !important;
}

/* 조직/기간 드롭다운 선택 상태도 같은 테마 규칙으로 통일 */
body:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
body:not(.cover-mode) #filterStrip .filter-group select.is-filtered,
body:not(.cover-mode) .inline-filter-box select.is-filtered,
body:not(.cover-mode) .compact-top-filters select.is-filtered,
body:not(.cover-mode) .org-level-picker select.is-filtered,
body:not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered,
body:not(.cover-mode) .org-compare-period-detail.is-filtered,
body:not(.cover-mode) .report-period-detail.is-filtered,
body:not(.cover-mode) select[data-org-page-depth].is-filtered,
body:not(.cover-mode) select[data-summary-page-goal-detail].is-filtered {
  background: var(--erp-active-bg) !important;
  border: 1px solid var(--erp-active-border) !important;
  color: var(--erp-active-text) !important;
  font-weight: 800 !important;
  box-shadow: var(--erp-active-shadow) !important;
}

/* ── 최종 강제 통일(우선순위 상향) ───────────────────────────── */
/* 다크: 라벨/좌측 보더 강조 제거 -> 드롭다운만 색상 변경 */
html body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label.is-active,
html body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}
html body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label.is-active .filter-group-label,
html body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label:has(select.is-filtered) .filter-group-label {
  background: rgba(30, 27, 46, 0.92) !important;
  border: 1px solid rgba(100, 90, 130, 0.28) !important;
  border-right: none !important;
  color: #8b82a0 !important;
  box-shadow: none !important;
}
html body[data-theme="dark"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) #filterStrip .filter-group select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .inline-filter-box select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .compact-top-filters select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .org-level-picker select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .org-compare-period-detail.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) .report-period-detail.is-filtered,
html body[data-theme="dark"]:not(.cover-mode) select[data-org-page-depth].is-filtered,
html body[data-theme="dark"]:not(.cover-mode) select[data-summary-page-goal-detail].is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4), inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent) !important;
}

/* 쿨톤(white/default): 필터 선택 — 시안 C 그라데이션 (메인 탭 내비는 별도 규칙 유지) */
html body[data-theme="white"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body:not([data-theme]):not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body[data-theme="white"]:not(.cover-mode) #filterStrip .filter-group select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) #filterStrip .filter-group select.is-filtered,
html body:not([data-theme]):not(.cover-mode) #filterStrip .filter-group select.is-filtered,
html body[data-theme="white"]:not(.cover-mode) .inline-filter-box select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) .inline-filter-box select.is-filtered,
html body:not([data-theme]):not(.cover-mode) .inline-filter-box select.is-filtered,
html body[data-theme="white"]:not(.cover-mode) .compact-top-filters select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) .compact-top-filters select.is-filtered,
html body:not([data-theme]):not(.cover-mode) .compact-top-filters select.is-filtered,
html body[data-theme="white"]:not(.cover-mode) .org-level-picker select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) .org-level-picker select.is-filtered,
html body:not([data-theme]):not(.cover-mode) .org-level-picker select.is-filtered,
html body[data-theme="white"]:not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered,
html body[data-theme="default"]:not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered,
html body:not([data-theme]):not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary, #2563eb) 38%, transparent),
    color-mix(in srgb, var(--primary-2, #3b82f6) 28%, transparent)
  ) !important;
  border: 1px solid color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
  box-shadow: 0 2px 12px color-mix(in srgb, var(--primary, #2563eb) 22%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary, #2563eb) 35%, transparent) !important;
}

/* org-compare-period-detail / report-period-detail 은 아래 --erp-unified-active-* 와 단일 규칙으로 통일(테마 primary) */

/* ── 통일 선택 토큰: 필터·토글 — 시안 C 그라데이션 (상단 .tab.active 는 제외, base·툴바 스킨 유지) ── */
html body:not(.cover-mode) {
  --erp-unified-active-bg: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary, #2563eb) 38%, transparent),
    color-mix(in srgb, var(--primary-2, #3b82f6) 28%, transparent)
  );
  --erp-unified-active-border: color-mix(in srgb, var(--primary, #2563eb) 35%, transparent);
  --erp-unified-active-text: var(--text);
  --erp-unified-active-shadow: 0 2px 14px rgba(37, 99, 235, 0.22),
    inset 0 0 0 1px color-mix(in srgb, var(--primary, #2563eb) 35%, transparent);
}

/* Atlas: 테마 --primary / --primary-2 */
html body.erp-atlas:not(.cover-mode) {
  --erp-unified-active-bg: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary) 38%, transparent),
    color-mix(in srgb, var(--primary-2) 28%, transparent)
  );
  --erp-unified-active-border: color-mix(in srgb, var(--primary) 35%, transparent);
  --erp-unified-active-text: var(--text);
  --erp-unified-active-shadow: 0 2px 14px color-mix(in srgb, var(--primary) 28%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 35%, transparent);
}

html body.erp-atlas[data-theme="dark"]:not(.cover-mode) {
  --erp-unified-active-border: color-mix(in srgb, var(--primary) 40%, transparent);
  --erp-unified-active-text: var(--text);
  --erp-unified-active-shadow: 0 2px 14px rgba(0, 0, 0, 0.45),
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 40%, transparent);
}

html body:not(.cover-mode) .btn-mini.is-active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) .main-summary-org-toggle-btn.is-active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) .org-compare-period-btn.is-active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) .customer-share-rank-tab-btn.is-active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) .gran-btn.active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) .btn-mini.active:not(.tab):not(.atlas-dock-item),
html body:not(.cover-mode) button.active:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle),
html body:not(.cover-mode) button[aria-pressed="true"]:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle),
html body:not(.cover-mode) button[aria-selected="true"]:not(.tab):not(.atlas-dock-item):not(.header-fullscreen-toggle) {
  background: var(--erp-unified-active-bg) !important;
  border: 1px solid var(--erp-unified-active-border) !important;
  color: var(--erp-unified-active-text) !important;
  font-weight: 800 !important;
  box-shadow: var(--erp-unified-active-shadow) !important;
}

html body:not(.cover-mode) #filterBox .filter-group label select.is-filtered,
html body:not(.cover-mode) #filterStrip .filter-group select.is-filtered,
html body:not(.cover-mode) .inline-filter-box select.is-filtered,
html body:not(.cover-mode) .compact-top-filters select.is-filtered,
html body:not(.cover-mode) .org-level-picker select.is-filtered,
html body:not(.cover-mode) .summary-goal-brief-detail-host select.is-filtered,
html body:not(.cover-mode) .section-year-filter-label select.is-filtered,
html body:not(.cover-mode) .org-compare-period-detail.is-filtered,
html body:not(.cover-mode) .report-period-detail.is-filtered,
html body:not(.cover-mode) select[data-org-page-depth].is-filtered,
html body:not(.cover-mode) select[data-summary-page-goal-detail].is-filtered {
  background: var(--erp-unified-active-bg) !important;
  border: 1px solid var(--erp-unified-active-border) !important;
  color: var(--erp-unified-active-text) !important;
  font-weight: 800 !important;
  box-shadow: var(--erp-unified-active-shadow) !important;
}

/* 접근성: prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  body:not(.cover-mode) #filterBox .filter-group label,
  body:not(.cover-mode) #filterBox .filter-group label .filter-group-label,
  body:not(.cover-mode) #filterBox .filter-group label select {
    transition: none !important;
    transform: none !important;
  }
}

/* =========================================================
   24. Non-cover Component Normalization
   ========================================================= */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title {
  gap: var(--ui-section-title-gap) !important;
  padding-block: var(--ui-section-title-padding-y) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title .section-kicker {
  font-size: var(--ui-section-kicker-size) !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: color-mix(in srgb, var(--primary) 74%, var(--muted)) !important;
  /* 한 줄 타이틀(키커+h2)에서 수직 가운데 정렬 시 아래 여백이 어긋남 방지 */
  margin-bottom: 0 !important;
}

/* section-title/description 타이포는 erp-index-section-overrides.css 단일 소스 사용 */

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  grid-template-areas:
    "title search filters"
    "desc desc desc" !important;
  align-items: start !important;
  column-gap: 18px !important;
  row-gap: 10px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line > :first-child {
  grid-area: title !important;
  min-width: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line > p {
  grid-area: desc !important;
  max-width: 70ch !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line .search-inline {
  grid-area: search !important;
  align-self: start !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line .section-title-filters {
  grid-area: filters !important;
  justify-self: end !important;
  align-self: start !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-head {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  column-gap: unset !important;
  row-gap: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-top {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-top .section-title-filters {
  flex: 0 0 auto !important;
  margin-left: 0 !important;
  align-self: center !important;
  justify-content: flex-end !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-main {
  display: flex !important;
  flex-direction: row !important;
  align-items: baseline !important;
  flex-wrap: nowrap !important;
  gap: 10px 14px !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
  box-sizing: border-box !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-text {
  flex: 0 0 auto !important;
  min-width: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-desc {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
}


body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .panel-head,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-trend-panel-head,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .product-trend-panel-head {
  padding: 9px var(--ui-panel-head-padding-x) 7px !important;
  margin-bottom: 6px !important;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 92%, transparent) !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, white 8%), color-mix(in srgb, var(--panel-strong) 86%, transparent)) !important;
  gap: 10px !important;
}

/* panel-head/meta 타이포는 erp-index-section-overrides.css 단일 소스 사용 */

body.erp-atlas:not(.cover-mode) #view-summary .summary-goal-panel.panel.panel-main::before {
  display: none !important;
  content: none !important;
}

body.erp-atlas:not(.cover-mode) #view-summary .summary-goal-panel.panel.panel-main::after {
  display: block !important;
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  border-radius: 22px 22px 0 0 !important;
  background: linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--accent) 78%, white 22%)) !important;
  box-shadow: none !important;
  opacity: 1 !important;
  pointer-events: none !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.record-table, .ranking-table, .tbl-v1, #view-qa table, #view-issue-center table) {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.record-table, .ranking-table, .tbl-v1, #view-qa table, #view-issue-center table) thead th {
  padding: 11px var(--ui-table-cell-padding-x) !important;
  font-size: var(--ui-table-head-size) !important;
  font-weight: 800 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--table-head-text) !important;
  background: color-mix(in srgb, var(--table-head-bg) 82%, white 18%) !important;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 96%, transparent) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.record-table, .ranking-table, .tbl-v1, #view-qa table, #view-issue-center table) tbody td {
  padding: var(--ui-table-cell-padding-y) var(--ui-table-cell-padding-x) !important;
  font-size: var(--ui-table-cell-size) !important;
  line-height: 1.5 !important;
  color: var(--text) !important;
  border-bottom: 1px solid color-mix(in srgb, var(--line-2) 96%, transparent) !important;
  vertical-align: middle !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.record-table, .ranking-table, .tbl-v1, #view-qa table, #view-issue-center table) tbody tr:hover td {
  background: color-mix(in srgb, var(--primary) 6%, transparent) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.record-table, .ranking-table, .tbl-v1, #view-qa table, #view-issue-center table) :is(td.num, th.num) {
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.btn, .btn-mini, .main-summary-org-toggle-btn, .org-compare-period-btn, .customer-share-rank-tab-btn, .gran-btn, .qa-nlp-input, .compact-field, .report-period-detail, .search-inline input, select, input[type="text"], input[type="search"]) {
  min-height: var(--ui-control-height) !important;
  border-radius: var(--ui-control-radius) !important;
  font-size: var(--ui-control-font-size) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(select, input[type="text"], input[type="search"], .compact-field, .qa-nlp-input, .report-period-detail, .search-inline input) {
  border: 1px solid color-mix(in srgb, var(--line) 92%, transparent) !important;
  background: color-mix(in srgb, var(--panel) 94%, white 6%) !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(select, input[type="text"], input[type="search"], .compact-field, .qa-nlp-input, .report-period-detail, .search-inline input):focus {
  outline: none !important;
  border-color: color-mix(in srgb, var(--primary) 58%, white) !important;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .search-inline,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .report-period-toggle,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .issue-center-filters,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .qa-title-one-line,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .qa-title-actions {
  gap: 10px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .qa-title-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  align-items: center !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :is(.mini-note, .oc-rank-pill) {
  border-radius: var(--ui-chip-radius) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) :not(td).mini-note {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 58px !important;
  padding: var(--ui-empty-padding) !important;
  text-align: center !important;
  color: var(--muted) !important;
  background: color-mix(in srgb, var(--panel) 88%, transparent) !important;
  border: 1px dashed color-mix(in srgb, var(--line) 92%, transparent) !important;
}

/* 거래처/모델 상세 모달: 빈 상태 칩 스타일이 KPI·트렌드 안내 문구에 먹지 않도록 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #detailModal :not(td):not(th).mini-note {
  display: block !important;
  align-items: unset !important;
  justify-content: unset !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  font-weight: 500 !important;
  font-size: 14px !important;
}

/* Q&A 질문 카드: 빈 상태용 .mini-note 스타일이 헤더·질문 설명에 먹지 않도록 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-questions-head .mini-note {
  display: block !important;
  align-items: unset !important;
  justify-content: unset !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  font-weight: 500 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-question-btn .mini-note {
  display: block !important;
  align-items: unset !important;
  justify-content: unset !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  text-align: center !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  font-weight: 500 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-question-btn.active .mini-note {
  color: rgba(255, 255, 255, 0.92) !important;
}

/* Q&A 옵션 줄: 빈상태 .mini-note 규칙이 필터 힌트 칩에 먹지 않도록 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-options .qa-options-filter-hint {
  display: inline-block !important;
  width: auto !important;
  min-height: 0 !important;
  padding: 5px 10px !important;
  justify-content: unset !important;
  align-items: unset !important;
  text-align: center !important;
  border-style: solid !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) td.mini-note,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .table-empty-row {
  padding: 18px 14px !important;
  text-align: center !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  background: color-mix(in srgb, var(--panel) 82%, transparent) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-row {
  display: grid !important;
  grid-template-columns: minmax(104px, 120px) minmax(0, 1fr) minmax(78px, 88px) !important;
  gap: 12px !important;
  align-items: center !important;
  margin-bottom: 12px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-track,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .bar-track,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-track {
  overflow: hidden !important;
  background: color-mix(in srgb, var(--line-2) 92%, transparent) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-track {
  height: 14px !important;
  border-radius: 999px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-fill {
  width: var(--cohort-fill-width) !important;
  height: 100% !important;
  border-radius: 999px !important;
  background: var(--cohort-fill-color, var(--primary)) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .cohort-compare-value {
  justify-self: end !important;
  min-height: auto !important;
  width: auto !important;
  padding: var(--ui-chip-padding-y) var(--ui-chip-padding-x) !important;
  border-style: solid !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row {
  display: grid !important;
  grid-template-columns: minmax(90px, 108px) minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .lbl,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .val {
  font-size: 13px !important;
  font-weight: 700 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .lbl {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .bar-track {
  height: 10px !important;
  border-radius: 999px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .customer-mini-bar-row .bar-fill {
  width: var(--bar-fill-width, 0%) !important;
  height: 100% !important;
  border-radius: 999px !important;
  background: var(--bar-fill-color, var(--primary)) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .yoy-waterfall-title {
  margin-bottom: 10px !important;
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  color: var(--title) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-row {
  display: grid !important;
  grid-template-columns: minmax(96px, 110px) minmax(0, 1fr) 54px !important;
  gap: 8px !important;
  align-items: center !important;
  margin-bottom: 6px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-track {
  height: 9px !important;
  border-radius: 999px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-fill {
  width: var(--org-achievement-width, 0%) !important;
  height: 100% !important;
  border-radius: 999px !important;
  background: var(--org-achievement-color, var(--primary)) !important;
  transition: width 0.6s ease !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .org-achievement-value {
  color: var(--org-achievement-color, var(--primary)) !important;
  text-align: right !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .oc-notes-list {
  margin: 8px 0 0 !important;
  padding-left: 16px !important;
  line-height: 1.8 !important;
  font-size: 13px !important;
  color: var(--text) !important;
}

@media (max-width: 1100px) {
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas:
      "title"
      "search"
      "filters"
      "desc" !important;
  }

  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line .search-inline,
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.customer-title-one-line .section-title-filters {
    justify-self: start !important;
  }

  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .section-title.report-title-compact .report-title-top {
    flex-wrap: wrap !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
  }

  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .report-title-compact .report-title-main {
    flex-wrap: wrap !important;
    align-items: baseline !important;
  }

  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .report-title-compact .report-title-top .section-title-filters {
    margin-left: 0 !important;
    align-self: flex-end !important;
    width: 100% !important;
    justify-content: flex-end !important;
  }
}

.main-summary-focus-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--line-soft, rgba(133, 161, 194, 0.32));
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-1, #ffffff) 84%, var(--primary, #2f6bff) 5%);
  box-shadow: 0 14px 32px rgba(33, 67, 118, 0.08);
}

.main-summary-focus-label {
  color: var(--text-2, #5f728d);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.main-summary-focus-chip strong {
  color: var(--text-strong, #18304f);
  font-size: 18px;
  line-height: 1;
}

.main-summary-bottom .main-summary-panel-head {
  margin-bottom: 16px;
}

@media (max-width: 1100px) {
  .main-summary-focus-chip {
    width: 100%;
    justify-content: space-between;
  }
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-unified-meta .mini-note:empty,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-unified-meta .compact-top-filters:empty {
  display: none !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-unified-meta {
  flex: 0 1 auto !important;
  gap: 6px 8px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-unified-bar {
  align-items: center !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-dock.tabbar.atlas-dock--top {
  justify-content: flex-start !important;
  width: 100% !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-dock .atlas-dock-item.tab {
  flex: 0 0 auto !important;
  min-width: max-content !important;
}

@media (min-width: 1380px) {
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-dock .atlas-dock-item.tab {
    flex: 0 1 auto !important;
    min-width: max-content !important;
  }
}

@media (min-width: 1180px) {
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-dock.tabbar.atlas-dock--top {
    overflow-x: auto !important;
  }

  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) .atlas-unified-meta {
    max-width: none !important;
  }
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  gap: 18px !important;
  min-width: 0 !important;
  margin-bottom: 14px !important;
  padding: 4px 0 10px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title > :first-child {
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 12px !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .section-kicker {
  margin: 0 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.11em !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .section-kicker::before {
  margin-right: 2px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title h2 {
  margin: 0 !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title > p {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title :is(.org-level-picker-wrap, .search-inline) {
  flex: 0 0 auto !important;
  align-self: center !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .org-level-picker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .org-level-picker > span {
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
  color: var(--muted) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .search-inline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .search-inline input {
  width: clamp(210px, 18vw, 260px) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title .search-inline .btn {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report > .section > .section-title.report-title-compact .report-title-head {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

/* Q&A: 제목·설명 1행 / NLP·버튼 2행 — 과밀·ellipsis 방지 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa > .section > .section-title.qa-title-one-line {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 6px !important;
  row-gap: 4px !important;
  column-gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  /* 타이틀-추천질의 간격 과다 방지 */
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .report-title-text {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-title-block {
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 12px !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .report-title-desc {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-title-desc {
  flex: 1 1 240px !important;
  min-width: 0 !important;
  margin: 0 !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .section-title-filters {
  flex: 0 0 auto !important;
  min-width: 0 !important;
  align-self: center !important;
  margin-left: 0 !important;
  justify-content: flex-end !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-title-actions {
  flex: 0 0 auto !important;
  min-width: 0 !important;
  align-self: stretch !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px 10px !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-nlp-input-wrap {
  /* 요청: 현재 대비 3배 확장 */
  flex: 0 0 600px !important;
  width: 600px !important;
  min-width: 0 !important;
  max-width: 600px !important;
}

/* Q&A: 연도 필터가 JS로 마지막에 붙어도 튜토리얼은 좌측 유지 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-title-actions {
  order: 1 !important;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .section-title-filters {
  order: 99 !important;
  margin-left: auto !important;
  justify-self: end !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
  overflow: visible !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .section-title-filters [data-global-year-filter] {
  width: 82px !important;
  min-width: 82px !important;
  max-width: 82px !important;
}

/* 요청: 튜토리얼 버튼을 실행 우측으로 이동 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-nlp-input-wrap { order: 1 !important; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-nlp-submit-btn { order: 2 !important; }
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-tutorial-btn { order: 3 !important; }

/* 요청: 튜토리얼/실행 버튼 배경색 분리 */
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-nlp-submit-btn {
  background: var(--primary) !important;
  color: var(--on-primary) !important;
}
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa #qaHeaderRow .qa-tutorial-btn {
  background: color-mix(in srgb, var(--ok) 88%, white 12%) !important;
  color: #fff !important;
  border-color: color-mix(in srgb, var(--ok) 72%, #000 28%) !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-studio-title {
  font-size: clamp(22px, 1.45vw, 26px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  line-height: 1.05 !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-pill > span {
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}

body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-pill > strong,
body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-meta {
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-topbar {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--panel) 82%, var(--primary) 8%),
    color-mix(in srgb, var(--panel-strong) 78%, var(--primary) 12%)
  ) !important;
  border-bottom-color: color-mix(in srgb, var(--primary) 16%, var(--line)) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-topbar::before {
  background:
    radial-gradient(circle at 18% 28%, color-mix(in srgb, var(--primary) 14%, transparent) 0%, transparent 52%),
    radial-gradient(circle at 82% 42%, rgba(255, 255, 255, 0.66) 0%, transparent 48%) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-pill {
  background: color-mix(in srgb, var(--panel) 88%, white 12%) !important;
  border-color: color-mix(in srgb, var(--primary) 14%, var(--line)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78), 0 8px 18px rgba(44, 83, 138, 0.08) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-pill > span {
  color: color-mix(in srgb, var(--primary) 54%, var(--muted)) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-pill > strong,
body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-studio-title {
  color: var(--title) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-divider {
  background: color-mix(in srgb, var(--primary) 16%, var(--line)) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-btn:not(.rb-btn-primary):not(.rb-btn-green) {
  color: var(--text) !important;
  background: color-mix(in srgb, var(--panel) 92%, white 8%) !important;
  border-color: color-mix(in srgb, var(--primary) 14%, var(--line)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74) !important;
}

body.erp-atlas[data-theme="white"]:not(.cover-mode):not(.main-summary-mode) #view-custom-report .rb-btn:not(.rb-btn-primary):not(.rb-btn-green):hover {
  background: color-mix(in srgb, var(--primary) 8%, var(--panel)) !important;
  border-color: color-mix(in srgb, var(--primary) 24%, var(--line)) !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-title-center {
  gap: 4px !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-title-heading {
  font-family: var(--atlas-font-display) !important;
  font-size: clamp(17px, 1.65vw, 22px) !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-title-sub {
  margin: 4px 0 0 !important;
  font-family: var(--atlas-font-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.2em !important;
  line-height: 1.25 !important;
  text-transform: uppercase !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-header-tools {
  gap: 8px !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact {
  min-width: auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  font-size: 11px !important;
  gap: 4px !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact select {
  min-width: 72px !important;
  height: 28px !important;
  min-height: 28px !important;
  padding: 0 22px 0 8px !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

body.erp-atlas.main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn {
  height: 28px !important;
  min-height: 28px !important;
  padding: 0 10px !important;
  border-radius: 10px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-title-heading {
  color: #ffffff !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-title-sub {
  color: rgba(255, 255, 255, 0.78) !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact {
  color: rgba(238, 244, 250, 0.84) !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact select,
body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn {
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.16) !important;
  color: #f5f8fb !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn.is-on {
  border-color: rgba(147, 197, 253, 0.42) !important;
  background: rgba(96, 165, 250, 0.16) !important;
  color: #dbeafe !important;
}

body.erp-atlas[data-theme="white"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn.is-off {
  color: rgba(245, 248, 251, 0.74) !important;
  background: rgba(255, 255, 255, 0.1) !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-title-heading {
  color: #faf6f0 !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-title-sub {
  color: var(--atlas-terra) !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact {
  color: rgba(238, 244, 250, 0.84) !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-header-tools .theme-picker.compact select,
body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn {
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.16) !important;
  color: #f5f8fb !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn.is-on {
  border-color: rgba(147, 197, 253, 0.42) !important;
  background: rgba(96, 165, 250, 0.16) !important;
  color: #dbeafe !important;
}

body.erp-atlas[data-theme="dark"].main-summary-mode #view-main-summary .main-summary-header-tools .tooltip-toggle-btn.is-off {
  color: rgba(245, 248, 251, 0.74) !important;
  background: rgba(255, 255, 255, 0.1) !important;
}

@media (max-width: 1280px) {
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-qa .qa-title-desc,
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) #view-report .report-title-desc,
  body.erp-atlas:not(.cover-mode):not(.main-summary-mode) main > .view:not(#view-cover):not(#view-main-summary) > .section > .section-title > p {
    max-width: 34vw !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   세부 모달: 표는 org-compare 계열 레이아웃 + 가독성(13/14/15px)·주요 열 강조
   모달 컨트롤은 Atlas 폴리시 토큰 유지
   ═══════════════════════════════════════════════════════════ */

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal) :is(.btn, .btn-mini, select, input[type="text"], input[type="search"]) {
  min-height: var(--ui-control-height) !important;
  border-radius: var(--ui-control-radius) !important;
  font-size: var(--ui-control-font-size) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal) :is(select, input[type="text"], input[type="search"]) {
  border: 1px solid color-mix(in srgb, var(--line) 92%, transparent) !important;
  background: color-mix(in srgb, var(--panel) 94%, white 6%) !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal) :is(select, input[type="text"], input[type="search"]):focus {
  outline: none !important;
  border-color: color-mix(in srgb, var(--primary) 58%, white) !important;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal) .table-sortable-th {
  transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease !important;
}

/* ─── 세부 모달 표 = 조직 .org-panel-compare / .org-compare-table 과 동일 시각 언어 ─── */

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .record-table.ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .record-table.admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .record-table.admin2-net-cohort-table-scroll) {
  --org-compare-wrap-bg: linear-gradient(180deg, color-mix(in srgb, var(--panel-surface) 94%, transparent), color-mix(in srgb, var(--panel) 88%, transparent));
  --org-compare-wrap-border: color-mix(in srgb, var(--panel-border) 76%, var(--line-soft));
  --org-compare-head-fill: linear-gradient(180deg, color-mix(in srgb, var(--table-head-bg) 88%, white), color-mix(in srgb, var(--table-head-bg) 100%, var(--panel-surface)));
  --org-compare-row-fill: color-mix(in srgb, var(--panel-surface) 92%, var(--panel));
  --org-compare-row-alt: color-mix(in srgb, var(--accent-soft) 10%, var(--panel-surface));
  --org-compare-row-hover: color-mix(in srgb, var(--accent-soft) 24%, var(--panel-surface));
  box-sizing: border-box;
  width: 100%;
  padding: 8px !important;
  padding-bottom: 14px !important;
  border-radius: 18px !important;
  background: var(--org-compare-wrap-bg) !important;
  border: 1px solid var(--org-compare-wrap-border) !important;
  overflow-x: auto;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}

body.erp-atlas[data-theme="dark"]:not(.cover-mode) :is(#mainSummaryGrowthModal .record-table.ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .record-table.admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .record-table.admin2-net-cohort-table-scroll) {
  --org-compare-wrap-bg: linear-gradient(180deg, color-mix(in srgb, var(--panel-surface) 96%, transparent), color-mix(in srgb, var(--panel) 92%, transparent));
  --org-compare-wrap-border: color-mix(in srgb, var(--panel-border) 84%, var(--line-soft));
  --org-compare-head-fill: linear-gradient(180deg, color-mix(in srgb, var(--table-head-bg) 94%, transparent), color-mix(in srgb, var(--panel) 78%, transparent));
  --org-compare-row-fill: color-mix(in srgb, var(--panel-surface) 96%, var(--panel));
  --org-compare-row-alt: color-mix(in srgb, var(--accent-soft) 12%, var(--panel-surface));
  --org-compare-row-hover: color-mix(in srgb, var(--accent-soft) 22%, var(--panel-surface));
}

body.erp-atlas[data-theme="warm"]:not(.cover-mode) :is(#mainSummaryGrowthModal .record-table.ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .record-table.admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .record-table.admin2-net-cohort-table-scroll) {
  --org-compare-row-alt: color-mix(in srgb, var(--accent-soft) 15%, var(--panel-surface));
  --org-compare-row-hover: color-mix(in srgb, var(--accent-soft-2) 18%, var(--panel-surface));
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) {
  display: block !important;
  width: 100% !important;
  min-width: 100%;
  table-layout: fixed !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  font-size: 14px !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead {
  display: table !important;
  width: 100% !important;
  table-layout: fixed !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  overscroll-behavior-y: contain !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-gutter: stable !important;
  padding: 0 !important;
  scroll-snap-type: none !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody tr {
  display: table !important;
  width: 100% !important;
  table-layout: fixed !important;
  flex-shrink: 0 !important;
  scroll-snap-align: unset !important;
}

/* 모달 카드 높이 활용: 본문·래퍼·table 세로 flex → tbody가 남은 영역을 채우고 스크롤 */
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-modal-body {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalFilterMount {
  flex-shrink: 0 !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody > .ms-growth-yoy-shell {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody > p.mini-note:first-child {
  flex-shrink: 0 !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody .ms-growth-table-toolbar {
  flex-shrink: 0 !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody .record-table.ms-growth-modal-table-wrap {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody .ms-growth-modal-table-wrap > table.ranking-table {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalBody .ms-growth-modal-table-wrap > table.ranking-table thead {
  flex-shrink: 0 !important;
}

body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll {
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table thead {
  flex-shrink: 0 !important;
}

body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > .admin2-kpi-detail-kpis,
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > .admin2-kpi-detail-summary-note,
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > p.mini-note {
  flex-shrink: 0 !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > .admin2-kpi-detail-section:last-of-type {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  margin-bottom: 0 !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > .admin2-kpi-detail-section:last-of-type > h4 {
  flex-shrink: 0 !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body:not(.admin2-kpi-detail-body--net-split) > .admin2-kpi-detail-section:last-of-type .admin2-kpi-modal-table-scroll {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-modal-table-scroll > table.ranking-table {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-modal-table-scroll > table.ranking-table thead {
  flex-shrink: 0 !important;
}

body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-net-cohort-table-scroll {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-net-cohort-table-scroll > table.ranking-table {
  flex: 1 1 0% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-net-cohort-table-scroll > table.ranking-table thead {
  flex-shrink: 0 !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead th {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  padding: 10px 8px !important;
  background: var(--org-compare-head-fill) !important;
  color: var(--table-head-text) !important;
  border-top: 1px solid var(--org-compare-wrap-border) !important;
  border-bottom: 1px solid var(--org-compare-wrap-border) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  text-align: center !important;
  text-transform: none !important;
  vertical-align: middle !important;
  box-shadow: 0 1px 0 color-mix(in srgb, var(--line-2) 85%, transparent) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead th:first-child {
  border-left: 1px solid var(--org-compare-wrap-border) !important;
  border-radius: 12px 0 0 12px !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead th:last-child {
  border-right: 1px solid var(--org-compare-wrap-border) !important;
  border-radius: 0 12px 12px 0 !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody td {
  padding: 8px 9px !important;
  vertical-align: middle !important;
  text-align: center !important;
  border-top: 1px solid var(--org-compare-wrap-border) !important;
  border-bottom: 1px solid var(--org-compare-wrap-border) !important;
  background: var(--org-compare-row-fill) !important;
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody tr:nth-child(even) td {
  background: var(--org-compare-row-alt) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody tr:hover td {
  background: var(--org-compare-row-hover) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody td:first-child {
  border-left: 1px solid var(--org-compare-wrap-border) !important;
  border-radius: 12px 0 0 12px !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody td:last-child {
  border-right: 1px solid var(--org-compare-wrap-border) !important;
  border-radius: 0 12px 12px 0 !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) :is(td.num, th.num) {
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
  text-align: center !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  color: color-mix(in srgb, var(--text) 72%, var(--primary) 28%) !important;
}

/* 주요 열: 첫 열(일자·라벨) — 좌측 액센트 + 강조 */
body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead th:first-child {
  box-shadow: inset 4px 0 0 color-mix(in srgb, var(--primary) 55%, transparent), 0 1px 0 color-mix(in srgb, var(--line-2) 85%, transparent) !important;
  padding-left: 12px !important;
  font-weight: 900 !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody td:first-child {
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  box-shadow: inset 4px 0 0 color-mix(in srgb, var(--primary) 50%, transparent) !important;
  padding-left: 12px !important;
}

/* 금액·수치 열: 은은한 틴트 + 우측 강조 라인 느낌 */
body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) thead th.num {
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 14%, transparent), color-mix(in srgb, var(--table-head-bg) 88%, white)) !important;
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--primary) 35%, transparent), 0 1px 0 color-mix(in srgb, var(--line-2) 85%, transparent) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody td.num {
  background: color-mix(in srgb, var(--primary) 11%, var(--org-compare-row-fill)) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 22%, transparent) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody tr:nth-child(even) td.num {
  background: color-mix(in srgb, var(--primary) 13%, var(--org-compare-row-alt)) !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-table-wrap, #orgCompareSalesModal .org-compare-sales-table-scroll, #admin2KpiDetailModal .admin2-kpi-modal-table-scroll, #admin2KpiDetailModal .admin2-net-cohort-table-scroll) > :is(table.ranking-table, table.org-compare-sales-modal-table) tbody tr:hover td.num {
  background: color-mix(in srgb, var(--primary) 18%, var(--org-compare-row-hover)) !important;
}

/* 모달 본문·부제·소제목 가독성 */
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-modal-body,
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-body,
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-modal-body {
  font-size: 15px !important;
  line-height: 1.55 !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal #mainSummaryGrowthModalSubtitle,
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal #admin2KpiDetailModalSubtitle,
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal #orgCompareSalesModalSubtitle {
  font-size: 14px !important;
  line-height: 1.5 !important;
}

/* color는 data-theme별 블록에서만 지정. 여기서 var(--title) !important 를 주면 쿨톤 --title(#10243a)이
   body[data-theme="white"] .modal-card * (#000)보다 특이도가 높아 이겨 ‘회색’ 타이틀로 보임 */
body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3 {
  font-size: clamp(1.15rem, 1.1rem + 0.45vw, 1.38rem) !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  text-shadow: none !important;
}

/* 라이트: 본문 대비 타이틀 명도 확보 */
body.erp-atlas[data-theme="white"]:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3,
body.erp-atlas:not([data-theme]):not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3,
body.erp-atlas[data-theme="default"]:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3 {
  color: #000000 !important;
}

body.erp-atlas[data-theme="dark"]:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3 {
  color: #f8fafc !important;
}

body.erp-atlas[data-theme="warm"]:not(.cover-mode) :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal, #detailModal, #receiptRawModal) .modal-head h3 {
  color: #451a03 !important;
}

/* 타이틀 h3: 다크에서 modal-card의 ink-soft 상속으로 회색으로 보이는 것 방지(이중 id) */
body.erp-atlas[data-theme="white"]:not(.cover-mode) :is(#mainSummaryGrowthModal #mainSummaryGrowthModalTitle, #orgCompareSalesModal #orgCompareSalesModalTitle, #admin2KpiDetailModal #admin2KpiDetailModalTitle, #detailModal #modalTitle, #receiptRawModal #receiptRawModalTitle),
body.erp-atlas:not([data-theme]):not(.cover-mode) :is(#mainSummaryGrowthModal #mainSummaryGrowthModalTitle, #orgCompareSalesModal #orgCompareSalesModalTitle, #admin2KpiDetailModal #admin2KpiDetailModalTitle, #detailModal #modalTitle, #receiptRawModal #receiptRawModalTitle),
body.erp-atlas[data-theme="default"]:not(.cover-mode) :is(#mainSummaryGrowthModal #mainSummaryGrowthModalTitle, #orgCompareSalesModal #orgCompareSalesModalTitle, #admin2KpiDetailModal #admin2KpiDetailModalTitle, #detailModal #modalTitle, #receiptRawModal #receiptRawModalTitle) {
  color: #000000 !important;
}

/* 성장·매출비교·KPI 상세: 우측 본문 헤더 면 통일(좌측 atlas 스트립과 인접) */
body.erp-atlas[data-theme="white"]:not(.cover-mode)
  :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal)
  .atlas-modal-main
  .modal-head,
body.erp-atlas:not([data-theme]):not(.cover-mode)
  :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal)
  .atlas-modal-main
  .modal-head,
body.erp-atlas[data-theme="default"]:not(.cover-mode)
  :is(#mainSummaryGrowthModal, #orgCompareSalesModal, #admin2KpiDetailModal)
  .atlas-modal-main
  .modal-head {
  background: rgba(255, 255, 255, 0.98) !important;
  border-left: none !important;
  padding-left: 20px !important;
}

body.erp-atlas[data-theme="dark"]:not(.cover-mode) :is(#mainSummaryGrowthModal #mainSummaryGrowthModalTitle, #orgCompareSalesModal #orgCompareSalesModalTitle, #admin2KpiDetailModal #admin2KpiDetailModalTitle, #detailModal #modalTitle, #receiptRawModal #receiptRawModalTitle) {
  color: #f8fafc !important;
}

body.erp-atlas[data-theme="warm"]:not(.cover-mode) :is(#mainSummaryGrowthModal #mainSummaryGrowthModalTitle, #orgCompareSalesModal #orgCompareSalesModalTitle, #admin2KpiDetailModal #admin2KpiDetailModalTitle, #detailModal #modalTitle, #receiptRawModal #receiptRawModalTitle) {
  color: #451a03 !important;
}

body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-pane__title,
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-section h4 {
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-table-toolbar label {
  font-size: 15px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  font-size: 21px !important;
}

/* 메인 하단 카드 1·2(YoY): 모달 헤더 h3 외 본문 대형 제목 — var(--text)만 두면 쿨톤 청회색·다크는 본문과 구분 어려움 */
body.erp-atlas[data-theme="white"]:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title,
body.erp-atlas:not([data-theme]):not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title,
body.erp-atlas[data-theme="default"]:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #000000 !important;
}

body.erp-atlas[data-theme="dark"]:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #f8fafc !important;
}

body.erp-atlas[data-theme="warm"]:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #451a03 !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-sub {
  font-size: 15px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-kpi .kpi-label {
  font-size: 13px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-kpi .kpi-value {
  font-size: 26px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-scale {
  font-size: 13px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-label {
  font-size: 16px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-label-sub {
  font-size: 13px !important;
}

body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .ms-growth-yoy-track-label {
  font-size: 16px !important;
}

body.erp-atlas:not(.cover-mode) :is(#mainSummaryGrowthModal .ms-growth-modal-body, #admin2KpiDetailModal .admin2-kpi-detail-body, #orgCompareSalesModal .org-compare-sales-modal-body) .mini-note {
  font-size: 14px !important;
  line-height: 1.5 !important;
}

/* 메인 하단 4카드 성장 모달: cover-mode 잔류 시에도 타이틀·YoY 대제목이 다른 모달과 동일 명도로 보이도록(특이도↑, -webkit-text-fill 대비) */
html body.erp-atlas[data-theme="white"] #mainSummaryGrowthModal #mainSummaryGrowthModalTitle,
html body.erp-atlas:not([data-theme]) #mainSummaryGrowthModal #mainSummaryGrowthModalTitle,
html body.erp-atlas[data-theme="default"] #mainSummaryGrowthModal #mainSummaryGrowthModalTitle {
  color: #000000 !important;
  -webkit-text-fill-color: #000000 !important;
}

html body.erp-atlas[data-theme="white"] #mainSummaryGrowthModal .modal-head h3,
html body.erp-atlas:not([data-theme]) #mainSummaryGrowthModal .modal-head h3,
html body.erp-atlas[data-theme="default"] #mainSummaryGrowthModal .modal-head h3 {
  color: #000000 !important;
  -webkit-text-fill-color: #000000 !important;
}

html body.erp-atlas[data-theme="white"] #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title,
html body.erp-atlas:not([data-theme]) #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title,
html body.erp-atlas[data-theme="default"] #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #000000 !important;
  -webkit-text-fill-color: #000000 !important;
}

html body.erp-atlas[data-theme="dark"] #mainSummaryGrowthModal #mainSummaryGrowthModalTitle,
html body.erp-atlas[data-theme="dark"] #mainSummaryGrowthModal .modal-head h3,
html body.erp-atlas[data-theme="dark"] #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #f8fafc !important;
  -webkit-text-fill-color: #f8fafc !important;
}

html body.erp-atlas[data-theme="warm"] #mainSummaryGrowthModal #mainSummaryGrowthModalTitle,
html body.erp-atlas[data-theme="warm"] #mainSummaryGrowthModal .modal-head h3,
html body.erp-atlas[data-theme="warm"] #mainSummaryGrowthModal .ms-growth-yoy-headline .headline-title {
  color: #451a03 !important;
  -webkit-text-fill-color: #451a03 !important;
}

/* 세부 모달 표 전용 열 필터(상단 툴바) */
body.erp-atlas:not(.cover-mode) .atlas-modal-table-filter-mount {
  flex-shrink: 0;
  padding: 0 16px 10px;
  box-sizing: border-box;
}
body.erp-atlas:not(.cover-mode) #mainSummaryGrowthModal .atlas-modal-table-filter-mount {
  padding-left: 20px;
  padding-right: 20px;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-modal-body > .atlas-modal-table-filter-mount {
  padding-left: 16px;
  padding-right: 16px;
  padding-bottom: 8px;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-main-stack > .atlas-modal-table-filter-mount {
  padding: 10px 16px 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: color-mix(in srgb, var(--panel-surface) 98%, var(--panel));
}
body.erp-atlas:not(.cover-mode) .atlas-modal-column-filter-bar__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-column-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1 1 200px;
  max-width: min(100%, 420px);
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-column-label__text {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted, var(--text));
  white-space: nowrap;
  flex-shrink: 0;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-column-select {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  font-size: 13px;
  line-height: 1.35;
  padding: 7px 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: var(--panel, #fff);
  color: var(--text);
  box-sizing: border-box;
  cursor: pointer;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-column-select:focus {
  outline: 2px solid color-mix(in srgb, var(--primary, #2563eb) 45%, transparent);
  outline-offset: 1px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-column-filter-bar__head .btn {
  font-size: 13px;
  padding: 6px 12px;
  line-height: 1.35;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-active-hint {
  font-size: 12px;
  font-weight: 700;
  color: var(--primary, #2563eb);
  margin-left: 4px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-value-slot {
  margin-top: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
  background: color-mix(in srgb, var(--panel-surface) 96%, var(--panel));
  max-height: min(44vh, 380px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col--single {
  max-width: 100%;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col__hint {
  margin: 0;
  font-size: 11px;
  line-height: 1.45;
  color: var(--muted, var(--text));
  opacity: 0.92;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col__label {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted, var(--text));
  letter-spacing: -0.01em;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-multiselect,
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-substring {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-size: 13px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: var(--panel, #fff);
  color: var(--text);
  padding: 6px 8px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-multiselect {
  padding: 4px 6px;
}
body.erp-atlas:not(.cover-mode) #admin2KpiDetailModal .admin2-kpi-detail-main-stack .admin2-kpi-detail-body {
  flex: 1 1 0%;
  min-height: 0;
}

/* 세부 모달 열 필터 — 열별 패널(체크박스·검색) 그리드 */
body.erp-atlas:not(.cover-mode) .atlas-modal-column-filter-bar--grid .atlas-modal-column-filter-bar__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px 12px;
  margin-bottom: 8px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-head-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1 1 200px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-head-sub {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted, var(--text));
  opacity: 0.88;
  line-height: 1.35;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px 14px;
  max-height: min(40vh, 320px);
  overflow: auto;
  padding: 2px 0 4px;
  -webkit-overflow-scrolling: touch;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
  background: color-mix(in srgb, var(--panel-surface) 96%, var(--panel));
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 8px;
  min-width: 0;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel__title {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted, var(--text));
  flex: 1 1 auto;
  min-width: 0;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel__badge {
  font-size: 10px;
  font-weight: 800;
  padding: 2px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary, #2563eb) 18%, transparent);
  color: var(--primary, #2563eb);
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel__badge[hidden] {
  display: none !important;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col-dd {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-size: 13px;
  line-height: 1.35;
  padding: 7px 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: var(--panel, #fff);
  color: var(--text);
  cursor: pointer;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-col-dd:focus {
  outline: 2px solid color-mix(in srgb, var(--primary, #2563eb) 45%, transparent);
  outline-offset: 1px;
}
body.erp-atlas:not(.cover-mode) .atlas-modal-filter-panel .atlas-modal-filter-substring {
  margin-top: 2px;
}

/* 조직 전년비교·인당매출 → 매출 상세 모달: 가로는 base 카드 폭. 데이터 행 1px 축소, 일자 열(헤더·본문)은 볼드 해제·한 단계 작게 */
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table thead th:first-child {
  font-weight: 600 !important;
  font-size: 12px !important;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table tbody td {
  font-size: 13px !important;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table tbody td:first-child {
  font-weight: 500 !important;
  font-size: 12px !important;
  letter-spacing: 0 !important;
}
body.erp-atlas:not(.cover-mode) #orgCompareSalesModal .org-compare-sales-table-scroll > table.org-compare-sales-modal-table :is(td.num, th.num) {
  font-size: 14px !important;
}
