/**
 * DataLens 시맨틱·오버라이드 스타일 (순수 CSS, 항상 손으로 유지)
 * 토큰·유틸 본문은 app.css(스냅샷)에 있으며, 이 파일은 dl- 프리픽스와 예외 위주로 확장합니다.
 *
 * @date 2026-04-22
 * @link https://cv.innored.co.kr/solution/data-lens/public/assets/dl.css
 */

/* --- 앱 셸 (사이드바+메인) --- */
.dl-app {
  min-height: 100vh;
  background-color: var(--color-surface);
}

.dl-main {
  margin-left: var(--spacing-sidebar);
  min-height: 100vh;
}

.dl-main--plain {
  min-height: 100vh;
}

/* --- 좌측 LNB --- */
.dl-sidebar {
  position: fixed;
  z-index: 50;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--spacing-sidebar);
  display: flex;
  flex-direction: column;
  background-color: var(--color-secondary-fixed);
}

/* --- 로그인(풀스크린 2단) 루트 --- */
.dl-login-root {
  min-height: 100vh;
  display: flex;
  background-color: var(--color-surface);
}

/* ==========================================================================
   대시보드 셸 — App-shell(contained scroll) 유틸 보강
   --------------------------------------------------------------------------
   data-lens 는 Tailwind 빌드를 쓰지 않고 app.css 가 사전 생성된 스냅샷이라,
   대시보드의 lg 이상 contained-scroll 레이아웃에서 새로 필요한 유틸리티 클래스를
   여기에 손으로 추가한다. (selector 표기는 app.css 의 escape 컨벤션과 동일)
   ========================================================================== */
@media (width >= 64rem) {
  .lg\:flex-col { flex-direction: column; }
  .lg\:flex-1 { flex: 1; }
  .lg\:overflow-hidden { overflow: hidden; }
  .lg\:overflow-y-auto { overflow-y: auto; }
  .lg\:items-center { align-items: center; }
  .lg\:justify-center { justify-content: center; }
  .lg\:h-screen { height: 100vh; }
  .lg\:pr-1 { padding-right: calc(var(--spacing) * 1); }
  .lg\:-mr-1 { margin-right: calc(var(--spacing) * -1); }
  .lg\:pb-4 { padding-bottom: calc(var(--spacing) * 4); }
  .lg\:border-b { border-bottom-style: var(--tw-border-style); border-bottom-width: 1px; }
  .lg\:border-outline-variant\/10 {
    border-color: color-mix(in oklab, var(--color-outline-variant) 10%, transparent);
  }
}

/* lg 미만(<64rem) 에서만 적용되는 폴백 — 좌측 리스트가 모바일에서 화면을 다 잡지 않도록 */
@media (width < 64rem) {
  .max-lg\:h-\[60vh\] { height: 60vh; }
}

/* app.css 스냅샷에 누락된 일반 패딩 — 셸 본문 모바일 스페이싱 */
.pb-6 { padding-bottom: calc(var(--spacing) * 6); }

/* 앱 메인 영역 공통 페이지 타이틀 띠 */
.dl-page-header {
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #cbcedb) 14%, transparent);
}

/* 좌측 마스터 리스트(추적 키워드) — 헤더·세그먼트·메타 */
.dl-master-list {
  display: flex;
  flex-direction: column;
}
.dl-master-list__head {
  padding: 1rem 1rem 1.125rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #cbcedb) 10%, transparent);
}
.dl-master-list__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.625rem;
}
.dl-master-list__counts {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1.2;
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 88%, transparent);
}
.dl-master-list__counts strong {
  font-weight: 700;
  color: var(--color-on-surface, #1b1b21);
}
.dl-master-list__counts-sep {
  opacity: 0.45;
  font-weight: 500;
}
.dl-master-list__meta {
  margin-top: 0.625rem;
  font-size: 0.6875rem;
  line-height: 1.4;
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 75%, transparent);
  font-variant-numeric: tabular-nums;
}
.dl-master-list__meta-label {
  font-weight: 600;
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 88%, transparent);
  margin-right: 0.25rem;
}

.dl-segmented {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding: 3px;
  border-radius: 0.5rem;
  background: color-mix(in oklab, var(--color-on-surface, #1b1b21) 3.5%, transparent);
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #cbcedb) 16%, transparent);
}
.dl-segmented__btn {
  appearance: none;
  border: none;
  margin: 0;
  padding: 0.3rem 0.55rem;
  border-radius: 0.375rem;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--color-on-surface-variant, #434656);
  background: transparent;
  cursor: pointer;
  transition: background-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
}
.dl-segmented__btn:hover {
  background: color-mix(in oklab, var(--color-surface-container-high, #e8e8ef) 85%, transparent);
  color: var(--color-on-surface, #1b1b21);
}
.dl-segmented__btn:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--color-primary, #003ec7) 38%, transparent);
  outline-offset: 1px;
}
.dl-segmented__btn[data-active="true"] {
  background: color-mix(in oklab, var(--color-primary-fixed, #e8edff) 100%, transparent);
  color: var(--color-primary, #003ec7);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--color-primary, #003ec7) 20%, transparent);
}

.dl-master-list__search-input {
  width: 100%;
  background: color-mix(in oklab, var(--color-surface-container-high, #e8e8ef) 38%, transparent);
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #cbcedb) 18%, transparent);
  border-radius: 0.5rem;
  padding: 0.45rem 0.75rem 0.45rem 2.125rem;
  font-size: 0.8125rem;
  line-height: 1.35;
  color: var(--color-on-surface, #1b1b21);
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.dl-master-list__search-input::placeholder {
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 45%, transparent);
}
.dl-master-list__search-input:focus {
  border-color: color-mix(in oklab, var(--color-primary, #003ec7) 45%, transparent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary, #003ec7) 14%, transparent);
}

/* app.css 스냅샷에 없는 sm 유틸 — 키워드 헤더(기준일 열) 반응형 */
@media (width >= 40rem) {
  .sm\:border-t-0 {
    border-top-width: 0;
  }
  .sm\:pt-0 {
    padding-top: 0;
  }
  .sm\:pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }
  .sm\:justify-end {
    justify-content: flex-end;
  }
  .sm\:justify-center {
    justify-content: center;
  }
  .sm\:flex-1 {
    flex: 1 1 0%;
  }
  .sm\:min-w-0 {
    min-width: 0;
  }
  .sm\:border-l {
    border-left-style: var(--tw-border-style, solid);
    border-left-width: 1px;
  }
}

/* ==========================================================================
   엔티티 탭 (메인 + 경쟁군) — dashboard_keyword_detail.php 의 .comp-tabs
   --------------------------------------------------------------------------
   · 한 화면에 한 탭 스트립만 등장(인지 부하 최소화).
   · 키보드 포커스 가시성 + reduce-motion 대응.
   · 경쟁군 5 종 색조는 keyword_chart_controller PALETTE 와 1:1 매핑.
   ========================================================================== */
:root {
  /* 메인 인디고 + 경쟁 5종 (보라/하늘/주황/적/녹) */
  --dl-comp-color-main: #003ec7;
  --dl-comp-color-1: #7c3aed;
  --dl-comp-color-2: #0ea5e9;
  --dl-comp-color-3: #f59e0b;
  --dl-comp-color-4: #ef4444;
  --dl-comp-color-5: #10b981;
}

.comp-tabs {
  scrollbar-width: thin;
}

.comp-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.55rem 0.875rem 0.625rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-on-surface-variant, #434656);
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color 160ms ease, border-color 160ms ease, background-color 160ms ease;
  white-space: nowrap;
}

.comp-tab:hover {
  color: var(--color-on-surface, #1b1f3b);
  background-color: color-mix(in oklab, var(--color-primary, #003ec7) 5%, transparent);
}

.comp-tab:focus-visible {
  outline: 2px solid var(--color-primary, #003ec7);
  outline-offset: -2px;
  border-radius: 4px;
}

.comp-tab.is-active {
  color: var(--color-primary, #003ec7);
  border-bottom-color: var(--color-primary, #003ec7);
}

.comp-tab__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.05rem 0.35rem;
  border-radius: 4px;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  background-color: color-mix(in oklab, var(--color-primary, #003ec7) 12%, transparent);
  color: var(--color-primary, #003ec7);
}

.comp-tab__warn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 9999px;
  font-size: 0.625rem;
  font-weight: 800;
  background-color: color-mix(in oklab, var(--color-warning, #f59e0b) 18%, transparent);
  color: var(--color-warning, #f59e0b);
}

.comp-tab__label {
  max-width: 14rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (prefers-reduced-motion: reduce) {
  .comp-tab {
    transition: none;
  }
}

/* ==========================================================================
   KPI 비교 테이블 — .kpi-compare
   --------------------------------------------------------------------------
   · 메트릭 라벨 컬럼 sticky (가로 스크롤시에도 라벨 고정).
   · 메인 행은 primary 약한 배경으로 강조(SSR 인라인 bg-primary/5 와 별개로 row-level 강조 보강).
   ========================================================================== */
.kpi-compare {
  border-collapse: separate;
  border-spacing: 0;
}

.kpi-compare thead th:first-child,
.kpi-compare tbody td:first-child {
  position: sticky;
  left: 0;
  background-color: var(--color-surface-container-lowest, #ffffff);
  z-index: 1;
  box-shadow: 1px 0 0 0 color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 18%, transparent);
}

.kpi-compare thead th {
  position: sticky;
  top: 0;
  background-color: var(--color-surface-container-lowest, #ffffff);
  z-index: 2;
}

/* 모바일 폴백 — 좁은 화면에서는 가로 스크롤이 자연스럽도록 컬럼 최소폭 확보 */
@media (width < 48rem) {
  .kpi-compare th,
  .kpi-compare td {
    min-width: 7rem;
  }
}

/* ==========================================================================
   Phase A — 타이포 스케일 9단 (어워드 폴리시)
   --------------------------------------------------------------------------
   · 본문 14px, 메타 12px, KPI hero 36px tabular-nums.
   · ratio 10→36 = 3.6× (현 2.4× → 4× 근접).
   · 한국어 가독: 본문 14px (Toss/Kakao Enterprise/Naver Cloud 라인).
   · 모든 클래스는 dl- 프리픽스로 충돌 없음.
   ========================================================================== */
.dl-text-overline {
  font-size: 0.625rem; /* 10px */
  line-height: 1.4;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dl-text-caption {
  font-size: 0.75rem; /* 12px */
  line-height: 1.5;
}

.dl-text-body-sm {
  font-size: 0.8125rem; /* 13px */
  line-height: 1.6;
}

.dl-text-body {
  font-size: 0.875rem; /* 14px */
  line-height: 1.6;
}

.dl-text-title-sm {
  font-size: 1rem; /* 16px */
  line-height: 1.4;
  font-weight: 600;
}

.dl-text-title {
  font-size: 1.125rem; /* 18px */
  line-height: 1.35;
  font-weight: 700;
}

.dl-text-title-lg {
  font-size: 1.375rem; /* 22px */
  line-height: 1.3;
  font-weight: 700;
}

.dl-text-display-md {
  font-size: 2.25rem; /* 36px */
  line-height: 1.1;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.dl-text-display-lg {
  font-size: 2rem; /* 32px */
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: -0.015em;
}

/* tabular-nums 헬퍼 (광범 사용) */
.dl-tnum {
  font-variant-numeric: tabular-nums;
}

/* ==========================================================================
   Phase A — 카드 3-tier (hero / standard / quiet)
   --------------------------------------------------------------------------
   · hero  : KPI 비교, Insight Summary Band 등 시선 앵커.
   · 기본  : 차트 카드 대부분 (현 톤 유지).
   · quiet : 보조 그리드/sub 카드.
   · hover elevation 토큰 통일 (Phase G hover 신호와 같은 곡선).
   ========================================================================== */
.dl-card,
.dl-card-hero,
.dl-card-quiet {
  border-radius: 0.5rem;
  background-color: var(--color-surface-container-lowest, #ffffff);
  transition: box-shadow 180ms cubic-bezier(0.2, 0.8, 0.2, 1),
              border-color 180ms cubic-bezier(0.2, 0.8, 0.2, 1),
              transform 180ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dl-card {
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 12%, transparent);
  padding: 1.25rem;
  box-shadow: 0 1px 0 0 color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 6%, transparent);
}

.dl-card-hero {
  border: 1px solid color-mix(in oklab, var(--color-primary, #003ec7) 14%, transparent);
  padding: 1.5rem;
  box-shadow: 0 6px 18px -10px color-mix(in oklab, var(--color-primary, #003ec7) 28%, transparent),
              0 1px 0 0 color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 8%, transparent);
}

.dl-card-quiet {
  border: 1px solid transparent;
  padding: 1rem;
  background-color: color-mix(in oklab, var(--color-surface-container-high, #e6e7f2) 22%, transparent);
}

.dl-card-quiet:hover,
.dl-card-quiet:focus-within {
  border-color: color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 24%, transparent);
  background-color: color-mix(in oklab, var(--color-surface-container-high, #e6e7f2) 36%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .dl-card,
  .dl-card-hero,
  .dl-card-quiet { transition: none; }
}

/* ==========================================================================
   Phase A — 섹션 간격
   --------------------------------------------------------------------------
   · 본문 12→14px 승격으로 페이지 ≈12% 길어지므로 96 → 64~80px 로 축소,
     호흡은 카드 padding(.dl-card-hero 1.5rem) 으로 보완.
   ========================================================================== */
.dl-section-gap { margin-top: 2.5rem; /* 40px */ }
@media (width >= 64rem) { .dl-section-gap { margin-top: 3.5rem; /* 56px */ } }
@media (width >= 80rem) { .dl-section-gap { margin-top: 4.5rem; /* 72px */ } }

/* ==========================================================================
   Phase A — 섹션 캡션 슬롯 (Phase C 에서 자동 인사이트 카피가 들어감)
   ========================================================================== */
.dl-section-caption {
  margin-top: 0.25rem;
  font-size: 0.75rem; /* 12px */
  line-height: 1.5;
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 88%, transparent);
}

/* ==========================================================================
   Phase A — 보강 유틸 (app.css 스냅샷에 없는 임의값 한정)
   --------------------------------------------------------------------------
   · KPI 카드 hero 폰트 등에서 쓰는 text-[2rem] (32px).
   · KPI hero 카드의 미세 shadow lift (호버 시 강조).
   · bg-success/12, bg-error/12 → KPI 변화 chip 미세 색조 (10/15 사이).
   ========================================================================== */
.text-\[2rem\] {
  font-size: 2rem;
  line-height: 1.15;
}

.dl-kpi-card {
  box-shadow: 0 1px 0 0 color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 18%, transparent);
  transition: box-shadow 180ms cubic-bezier(0.2, 0.8, 0.2, 1),
              transform 180ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
.dl-kpi-card:hover {
  box-shadow: 0 8px 22px -12px color-mix(in oklab, var(--color-primary, #003ec7) 32%, transparent),
              0 1px 0 0 color-mix(in oklab, var(--color-outline-variant, #c3c5d9) 24%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .dl-kpi-card { transition: none; }
}

/* 변화 chip 색조 (success/error) — 12% 농도 */
.bg-success\/12 { background-color: color-mix(in oklab, var(--color-success, #16a34a) 12%, transparent); }
.bg-error\/12   { background-color: color-mix(in oklab, var(--color-error, #dc2626) 12%, transparent); }

/* ==========================================================================
   Phase B — 차트 카드 micro-meta strip
   --------------------------------------------------------------------------
   · [기간 · 단위 · y축] 등 차트 컨텍스트 메타정보 표시.
   · 카드 헤더 아래 1줄, 12px, 토큰 색상, 칩 사이 미들닷 분리자.
   · 핸드드로운 인사이트 캡션(.dl-section-caption)과 시각적 위계 분리.
   ========================================================================== */
.dl-chart-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem 0.625rem;
  margin-top: 0.375rem;
  font-size: 0.75rem; /* 12px */
  line-height: 1.4;
  color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 86%, transparent);
}

.dl-chart-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.0625rem 0.4375rem;
  border-radius: 999px;
  font-weight: 600;
  background-color: color-mix(in oklab, var(--color-surface-container-high, #e6e7f2) 30%, transparent);
  color: color-mix(in oklab, var(--color-on-surface, #1b1f3b) 88%, transparent);
}

.dl-chart-meta-pill > .dl-chart-meta-pill__label {
  opacity: 0.65;
  font-weight: 500;
}

.dl-chart-meta-sep {
  width: 2px;
  height: 2px;
  border-radius: 999px;
  background-color: color-mix(in oklab, var(--color-on-surface-variant, #434656) 35%, transparent);
}

/* ==========================================================================
   Phase B — KPI mini sparkline (no library)
   --------------------------------------------------------------------------
   · 80x20 SVG polyline. stroke=currentColor 로 KPI 카드 tone 색을 상속.
   · 가로 100% 까지 자연스럽게 늘어나도록 width 100%, height 고정.
   · 모션 감소 사용자에 대해서는 stroke 두께만 유지하고 애니메이션 없음.
   ========================================================================== */
.dl-spark {
  display: block;
  width: 100%;
  max-width: 8rem;
  height: 1.25rem; /* 20px */
  overflow: visible;
}
.dl-spark > polyline {
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 1px 0 color-mix(in oklab, currentColor 22%, transparent));
}

/* --- 소셜 요약 옵션B (탭 + 풍부 패널) --- */
/* 소셜 채널 탭 (Phase G-1 refresh) — 박스 외곽 없이 카드처럼 떨어진 4개 단위.
   모바일 < 480px: 2×2 그리드, 그 외: 4 등분. 활성 탭은 상단 primary 띠로 표시. */
.dl-social-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.875rem; /* 14px — 카드 간 숨통 확보 */
  margin-top: 1rem; /* 상단 헤더(소셜 요약 / 최근 7일 …)와 분리 */
  margin-bottom: 1.25rem; /* 활성 패널과 분리 */
}
@media (max-width: 480px) {
  .dl-social-tabs { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.75rem; }
}

.dl-social-tab {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 0.875rem 1rem;
  border: 1px solid var(--color-outline-variant, #c4c6d0);
  border-radius: 0.625rem;
  background-color: var(--color-surface-container-lowest, #ffffff);
  color: var(--color-on-surface-variant, #46464f);
  cursor: pointer;
  text-align: left;
  min-width: 0;
  overflow: hidden; /* 상단 띠가 카드 모서리(radius) 밖으로 삐져나오지 않도록 */
  transition:
    border-color .14s ease-out,
    background-color .14s ease-out,
    box-shadow .14s ease-out,
    transform .14s ease-out;
}
.dl-social-tab::before {
  /* 활성 시 상단 primary 띠 — 카드 안쪽 상단에 붙음. overflow:hidden 으로 모서리 안에 클립됨. */
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background-color: transparent;
  transition: background-color .14s ease-out;
}
.dl-social-tab:hover {
  border-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 18%, transparent);
  background-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 2%, var(--color-surface-container-lowest, #ffffff));
}
.dl-social-tab:focus-visible {
  outline: 2px solid var(--color-primary, #003ec7);
  outline-offset: 2px;
}
.dl-social-tab.is-active {
  border-color: color-mix(in oklab, var(--color-primary, #003ec7) 45%, transparent);
  background-color: color-mix(in oklab, var(--color-primary, #003ec7) 4%, var(--color-surface-container-lowest, #ffffff));
  box-shadow: 0 4px 12px -8px color-mix(in oklab, var(--color-primary, #003ec7) 35%, transparent);
  color: var(--color-on-surface, #1b1b21);
}
.dl-social-tab.is-active::before {
  background-color: var(--color-primary, #003ec7);
}

/* 1행: 아이콘 + 라벨 가로 정렬 */
.dl-social-tab__head {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}
.dl-social-tab__icon {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
}
.dl-social-tab__label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--color-on-surface-variant, #46464f);
  text-transform: none;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dl-social-tab.is-active .dl-social-tab__label {
  color: var(--color-on-surface, #1b1b21);
}

/* 2행: 큰 수치 + "건" 접미 */
.dl-social-tab__body {
  display: flex;
  align-items: baseline;
  gap: 0.125rem;
  min-width: 0;
  line-height: 1;
}
.dl-social-tab__recent {
  font-size: 22px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1;
}
.dl-social-tab__recent-suffix {
  font-size: 11px;
  font-weight: 500;
  color: var(--color-on-surface-variant, #46464f);
  margin-left: 2px;
}
.dl-social-tab__sub {
  display: none;
}

.dl-social-panel {
  margin-top: 1.25rem;
  display: grid;
  gap: 2rem; /* 주요 발행처 / 최근 게시 두 열(또는 행) 사이 숨통 */
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .dl-social-panel {
    gap: 2.5rem; /* 데스크톱: 좌·우 컬럼 사이 더 여유 */
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  }
}

.dl-social-hero {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.dl-social-hero__cell {
  background-color: color-mix(in oklab, var(--color-surface-container, #f3f3fa) 50%, transparent);
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 50%, transparent);
  border-radius: 0.5rem;
  padding: 0.5rem 0.625rem;
}
.dl-social-hero__label {
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-on-surface-variant, #46464f);
  font-weight: 600;
}
.dl-social-hero__value {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-on-surface, #1b1b21);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  margin-top: 0.125rem;
}
.dl-social-hero__hint {
  font-size: 10px;
  color: var(--color-on-surface-variant, #46464f);
  margin-top: 0.125rem;
}

.dl-pub-list {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.dl-pub-row {
  display: grid;
  grid-template-columns: 1.25rem minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0;
  border-bottom: 1px dashed color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 40%, transparent);
}
.dl-pub-row:last-child { border-bottom: 0; }
.dl-pub-row__rank {
  font-size: 10px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-on-surface-variant, #46464f);
  text-align: right;
}
.dl-pub-row__main {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.dl-pub-row__name {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-on-surface, #1b1b21);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dl-pub-row__bar {
  height: 4px;
  border-radius: 999px;
  background-color: color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 35%, transparent);
  overflow: hidden;
  margin-top: 0.25rem;
}
.dl-pub-row__bar-fill {
  display: block;
  height: 100%;
  border-radius: 999px;
  background-color: var(--color-primary, #003ec7);
}
.dl-pub-row__count {
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--color-on-surface, #1b1b21);
}

.dl-sample-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.dl-sample-row {
  padding: 0.375rem 0;
  border-bottom: 1px dashed color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 40%, transparent);
}
.dl-sample-row:last-child { border-bottom: 0; }
.dl-sample-row__title {
  display: block;
  font-size: 12px;
  color: var(--color-on-surface, #1b1b21);
  font-weight: 600;
  line-height: 1.35;
  text-decoration: none;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
}
.dl-sample-row__title--link:hover { text-decoration: underline; color: var(--color-primary, #003ec7); }
.dl-sample-row__meta {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.25rem;
  font-size: 10px;
  color: var(--color-on-surface-variant, #46464f);
}
.dl-sample-row__meta > span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.dl-social-subhead {
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--color-on-surface-variant, #46464f);
  margin-bottom: 0.375rem;
}

/* --- 광고 인사이트 보드 카드 (Phase G-2) --- */
.dl-insight-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 0.875rem 0.875rem 0.75rem 1rem;
  background-color: var(--color-surface-container-lowest, #ffffff);
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 60%, transparent);
  border-radius: 0.625rem;
  overflow: hidden;
  transition: box-shadow .15s ease-out, transform .15s ease-out, border-color .15s ease-out;
}
.dl-insight-card:hover {
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
  transform: translateY(-1px);
}
.dl-insight-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 3px;
  background-color: var(--color-primary, #003ec7);
  border-top-left-radius: 0.625rem;
  border-bottom-left-radius: 0.625rem;
}

.dl-insight-card--primary    { border-color: color-mix(in oklab, var(--color-primary, #003ec7) 25%, transparent); }
.dl-insight-card--primary::before { background-color: var(--color-primary, #003ec7); }

.dl-insight-card--success    { border-color: color-mix(in oklab, var(--color-success, #1e7d40) 25%, transparent); }
.dl-insight-card--success::before { background-color: var(--color-success, #1e7d40); }

.dl-insight-card--secondary  { border-color: color-mix(in oklab, var(--color-secondary, #5a5d72) 25%, transparent); }
.dl-insight-card--secondary::before { background-color: var(--color-secondary, #5a5d72); }

.dl-insight-card--warning    { border-color: color-mix(in oklab, var(--color-warning, #b3260b) 25%, transparent); }
.dl-insight-card--warning::before { background-color: var(--color-warning, #b3260b); }

.dl-insight-card__head {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  min-width: 0;
}
.dl-insight-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  border-radius: 0.25rem;
  color: var(--color-primary, #003ec7);
}
.dl-insight-card--success .dl-insight-card__icon   { color: var(--color-success, #1e7d40); }
.dl-insight-card--secondary .dl-insight-card__icon { color: var(--color-secondary, #5a5d72); }
.dl-insight-card--warning .dl-insight-card__icon   { color: var(--color-warning, #b3260b); }

.dl-insight-card__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-on-surface-variant, #46464f);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.dl-insight-card__value {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1.25;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.dl-insight-card__value--numeric {
  font-size: 22px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.dl-insight-card__sub {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.25rem;
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
  background-color: color-mix(in oklab, var(--color-surface-container, #f3f3fa) 80%, transparent);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  color: var(--color-on-surface-variant, #46464f);
}
.dl-insight-card--primary   .dl-insight-card__sub { color: var(--color-primary, #003ec7);  background-color: color-mix(in oklab, var(--color-primary, #003ec7) 10%, transparent); }
.dl-insight-card--success   .dl-insight-card__sub { color: var(--color-success, #1e7d40); background-color: color-mix(in oklab, var(--color-success, #1e7d40) 10%, transparent); }
.dl-insight-card--secondary .dl-insight-card__sub { color: var(--color-secondary, #5a5d72); background-color: color-mix(in oklab, var(--color-secondary, #5a5d72) 10%, transparent); }
.dl-insight-card--warning   .dl-insight-card__sub { color: var(--color-warning, #b3260b); background-color: color-mix(in oklab, var(--color-warning, #b3260b) 10%, transparent); }

/* --- 연관 키워드 heat-table (Phase G-3) --- */
.dl-rk-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.dl-rk-table thead th {
  position: sticky;
  top: 0;
  z-index: 5;
  background-color: var(--color-surface-container-lowest, #ffffff);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-on-surface-variant, #46464f);
  padding: 0.5rem 0.625rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 50%, transparent);
  box-shadow: 0 1px 0 color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 30%, transparent);
}
.dl-rk-table thead th button {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: transparent;
  border: 0;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  color: inherit;
  cursor: pointer;
  padding: 0;
}
.dl-rk-table thead th button:hover { color: var(--color-on-surface, #1b1b21); }
.dl-rk-table tbody tr {
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 18%, transparent);
  transition: background-color .12s ease-out;
}
.dl-rk-table tbody tr:hover {
  background-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 3%, transparent);
}
.dl-rk-table td {
  padding: 0.5rem 0.625rem;
  vertical-align: middle;
}
.dl-rk-table td.dl-rk-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.dl-rk-table td.dl-rk-center { text-align: center; }
.dl-rk-table td.dl-rk-keyword {
  font-weight: 600;
  color: var(--color-on-surface, #1b1b21);
}

.dl-heat-cell {
  --heat: 0;
  --heat-color: var(--color-primary, #003ec7);
  background-color: color-mix(in oklab, var(--heat-color) calc(var(--heat) * 16%), transparent);
}
.dl-heat-cell--primary   { --heat-color: var(--color-primary, #003ec7); }
.dl-heat-cell--secondary { --heat-color: var(--color-secondary, #5a5d72); }
.dl-heat-cell--success   { --heat-color: var(--color-success, #1e7d40); }
.dl-heat-cell--warning   { --heat-color: var(--color-warning, #b3260b); }

.dl-rk-comp-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
}
.dl-rk-comp-chip--high {
  background-color: color-mix(in oklab, var(--color-error, #b3260b) 12%, transparent);
  color: var(--color-error, #b3260b);
  border-color: color-mix(in oklab, var(--color-error, #b3260b) 25%, transparent);
}
.dl-rk-comp-chip--mid {
  background-color: color-mix(in oklab, var(--color-warning, #b06c00) 14%, transparent);
  color: var(--color-warning, #b06c00);
  border-color: color-mix(in oklab, var(--color-warning, #b06c00) 28%, transparent);
}
.dl-rk-comp-chip--low {
  background-color: color-mix(in oklab, var(--color-success, #1e7d40) 12%, transparent);
  color: var(--color-success, #1e7d40);
  border-color: color-mix(in oklab, var(--color-success, #1e7d40) 25%, transparent);
}
.dl-rk-comp-chip--none {
  background-color: color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 30%, transparent);
  color: var(--color-on-surface-variant, #46464f);
}

/* --- 통일 EmptyState / Skeleton (Phase E-1) --- */
.dl-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1.75rem 1rem;
  border: 1px dashed color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 55%, transparent);
  border-radius: 0.625rem;
  background-color: color-mix(in oklab, var(--color-surface-container, #f3f3fa) 30%, transparent);
  text-align: center;
  min-height: 8rem;
}
.dl-empty--compact {
  padding: 1rem 0.875rem;
  min-height: 0;
  gap: 0.25rem;
}
.dl-empty__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 5%, transparent);
  color: var(--color-on-surface-variant, #46464f);
  margin-bottom: 0.125rem;
}
.dl-empty--compact .dl-empty__icon {
  width: 1.75rem;
  height: 1.75rem;
}
.dl-empty__title {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1.3;
}
.dl-empty__sub {
  font-size: 11px;
  color: var(--color-on-surface-variant, #46464f);
  line-height: 1.45;
  max-width: 22rem;
}
.dl-empty__action {
  margin-top: 0.5rem;
}

.dl-empty-inline {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.625rem 0.5rem;
  font-size: 12px;
  color: var(--color-on-surface-variant, #46464f);
  text-align: center;
}

/* --- Skeleton --- */
@keyframes dl-skeleton-shimmer {
  0%   { background-position: -240px 0; }
  100% { background-position: 240px 0; }
}
.dl-skeleton {
  display: block;
  border-radius: 0.375rem;
  background-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 8%, transparent);
  background-image: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklab, var(--color-on-surface, #1b1b21) 4%, transparent) 50%,
    transparent 100%
  );
  background-size: 240px 100%;
  background-repeat: no-repeat;
  animation: dl-skeleton-shimmer 1.4s ease-in-out infinite;
}
.dl-skeleton--text   { height: 0.75rem; }
.dl-skeleton--title  { height: 1.125rem; }
.dl-skeleton--block  { height: 6rem; }
.dl-skeleton--circle { border-radius: 999px; }

@media (prefers-reduced-motion: reduce) {
  .dl-skeleton { animation: none; }
}

/* --- Explorer 검색 로딩 --- */
@keyframes dl-loading-orb-spin {
  to { transform: rotate(360deg); }
}
@keyframes dl-loading-progress {
  0% { transform: translateX(-100%); }
  55% { transform: translateX(25%); }
  100% { transform: translateX(140%); }
}
@keyframes dl-loading-pulse {
  0%, 100% { opacity: .55; transform: scale(.96); }
  50% { opacity: 1; transform: scale(1); }
}
.dl-explorer-loading {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  overflow: hidden;
  padding: 1.125rem 1.25rem;
  border: 1px solid color-mix(in oklab, var(--color-primary, #003ec7) 18%, transparent);
  border-radius: 1rem;
  background:
    radial-gradient(circle at 12% 20%, color-mix(in oklab, var(--color-primary, #003ec7) 12%, transparent), transparent 32%),
    linear-gradient(135deg, var(--color-surface-container-lowest, #fff), color-mix(in oklab, var(--color-primary, #003ec7) 4%, var(--color-surface-container-lowest, #fff)));
  box-shadow:
    0 14px 36px color-mix(in oklab, var(--color-primary, #003ec7) 8%, transparent),
    0 1px 0 color-mix(in oklab, var(--color-on-surface, #1b1b21) 4%, transparent);
}
.dl-explorer-loading__orb {
  position: relative;
  width: 3rem;
  height: 3rem;
  flex: 0 0 auto;
  border-radius: 999px;
  background: conic-gradient(from 0deg, var(--color-primary, #003ec7), color-mix(in oklab, var(--color-primary, #003ec7) 18%, transparent), var(--color-primary, #003ec7));
  animation: dl-loading-orb-spin 1.05s linear infinite;
}
.dl-explorer-loading__orb::before {
  content: "";
  position: absolute;
  inset: .25rem;
  border-radius: inherit;
  background: var(--color-surface-container-lowest, #fff);
}
.dl-explorer-loading__orb span {
  position: absolute;
  inset: .95rem;
  z-index: 1;
  border-radius: inherit;
  background: var(--color-primary, #003ec7);
  animation: dl-loading-pulse 1.15s ease-in-out infinite;
}
.dl-explorer-loading__badge {
  display: inline-flex;
  align-items: center;
  height: 1.125rem;
  padding: 0 .45rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-primary, #003ec7) 10%, transparent);
  color: var(--color-primary, #003ec7);
  font-size: .625rem;
  font-weight: 800;
  letter-spacing: .08em;
}
.dl-explorer-loading__track {
  position: relative;
  height: .375rem;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-primary, #003ec7) 10%, transparent);
}
.dl-explorer-loading__track span {
  position: absolute;
  inset: 0 auto 0 0;
  width: 48%;
  border-radius: inherit;
  background: linear-gradient(90deg, color-mix(in oklab, var(--color-primary, #003ec7) 42%, transparent), var(--color-primary, #003ec7));
  animation: dl-loading-progress 1.7s cubic-bezier(.4, 0, .2, 1) infinite;
}
.dl-explorer-loading__step {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .25rem .55rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 24%, transparent);
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-surface-container-lowest, #fff) 82%, transparent);
}
.dl-explorer-loading__step::before {
  content: "";
  width: .35rem;
  height: .35rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 32%, transparent);
}
.dl-explorer-loading__step.is-active::before {
  background: var(--color-primary, #003ec7);
  box-shadow: 0 0 0 .2rem color-mix(in oklab, var(--color-primary, #003ec7) 12%, transparent);
}
.dl-inline-loading {
  display: flex;
  align-items: center;
  gap: .625rem;
  padding: .625rem .75rem;
  margin-bottom: 1rem;
  border: 1px solid color-mix(in oklab, var(--color-primary, #003ec7) 12%, transparent);
  border-radius: .75rem;
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--color-primary, #003ec7) 6%, transparent),
    color-mix(in oklab, var(--color-surface-container-lowest, #fff) 86%, transparent)
  );
}
.dl-inline-loading__spinner {
  position: relative;
  width: 1.5rem;
  height: 1.5rem;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 2px solid color-mix(in oklab, var(--color-primary, #003ec7) 16%, transparent);
  border-top-color: var(--color-primary, #003ec7);
  animation: dl-loading-orb-spin .85s linear infinite;
}
.dl-inline-loading__title {
  margin: 0;
  color: var(--color-on-surface, #1b1b21);
  font-size: .75rem;
  font-weight: 700;
  line-height: 1.25;
}
.dl-inline-loading__desc {
  margin: .125rem 0 0;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 72%, transparent);
  font-size: .6875rem;
  line-height: 1.3;
}
.dl-inline-loading__bar {
  position: relative;
  width: 5.5rem;
  height: .25rem;
  flex: 0 0 auto;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-primary, #003ec7) 10%, transparent);
}
.dl-inline-loading__bar::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 48%;
  border-radius: inherit;
  background: var(--color-primary, #003ec7);
  animation: dl-loading-progress 1.45s cubic-bezier(.4, 0, .2, 1) infinite;
}

@media (prefers-reduced-motion: reduce) {
  .dl-explorer-loading__orb,
  .dl-explorer-loading__orb span,
  .dl-explorer-loading__track span,
  .dl-inline-loading__spinner,
  .dl-inline-loading__bar::after {
    animation: none;
  }
}

/* --- Motion: 섹션 reveal & KPI count-up (Phase E-2) --- */
@keyframes dl-fade-up {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dl-reveal {
  opacity: 0;
  transform: translateY(6px);
  will-change: opacity, transform;
}
.dl-reveal.is-visible {
  animation: dl-fade-up 360ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
}
@media (prefers-reduced-motion: reduce) {
  .dl-reveal,
  .dl-reveal.is-visible {
    opacity: 1;
    transform: none;
    animation: none;
  }
}

/* count-up — 폭 흔들림 방지 (tabular-nums) */
.dl-count-up {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

/* --- Toast (Phase E-3) --- */
.dl-toast-host {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 10000;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
  width: min(22rem, calc(100vw - 2rem));
}
.dl-toast {
  pointer-events: auto;
  display: grid;
  grid-template-columns: 1.25rem 1fr auto;
  align-items: start;
  gap: 0.625rem;
  padding: 0.75rem 0.875rem;
  border-radius: 0.625rem;
  background: var(--color-surface-container-highest, #e8e8ee);
  color: var(--color-on-surface, #1b1b21);
  box-shadow:
    0 8px 24px -8px rgba(0, 0, 0, 0.18),
    0 1px 0 rgba(0, 0, 0, 0.04);
  border: 1px solid color-mix(in oklab, var(--color-on-surface, #1b1b21) 8%, transparent);
  font-size: 13px;
  line-height: 1.4;
  animation: dl-toast-in 220ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
}
.dl-toast--leaving {
  animation: dl-toast-out 180ms ease-in both;
}
.dl-toast__icon {
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 0.125rem;
  flex-shrink: 0;
}
.dl-toast__body { min-width: 0; }
.dl-toast__title {
  font-weight: 600;
  font-size: 13px;
  margin: 0 0 0.125rem;
}
.dl-toast__msg {
  margin: 0;
  font-size: 12px;
  color: var(--color-on-surface-variant, #46464f);
  word-break: break-word;
}
.dl-toast__close {
  background: none;
  border: 0;
  cursor: pointer;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.375rem;
  color: var(--color-on-surface-variant, #46464f);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
  padding: 0;
}
.dl-toast__close:hover { background: color-mix(in oklab, var(--color-on-surface, #1b1b21) 6%, transparent); }
.dl-toast__close:focus-visible { outline: 2px solid var(--color-primary, #003ec7); outline-offset: 2px; }

.dl-toast--success { border-left: 3px solid #10b981; }
.dl-toast--success .dl-toast__icon { color: #10b981; }
.dl-toast--error   { border-left: 3px solid #ef4444; }
.dl-toast--error   .dl-toast__icon { color: #ef4444; }
.dl-toast--warning { border-left: 3px solid #f59e0b; }
.dl-toast--warning .dl-toast__icon { color: #f59e0b; }
.dl-toast--info    { border-left: 3px solid var(--color-primary, #003ec7); }
.dl-toast--info    .dl-toast__icon { color: var(--color-primary, #003ec7); }

@keyframes dl-toast-in {
  from { opacity: 0; transform: translateY(-6px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes dl-toast-out {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(-4px); }
}
@media (prefers-reduced-motion: reduce) {
  .dl-toast,
  .dl-toast--leaving { animation: none; }
}

/* --- A11y 보강 (Phase F-1) --- */

/* 전역 focus-visible — 인터랙티브 요소 키보드 접근 시 일관된 ring 표시 */
button:focus-visible,
[role="button"]:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible {
  outline: 2px solid var(--color-primary, #003ec7);
  outline-offset: 2px;
  border-radius: 4px;
}

/* 차트 컨테이너 등 키보드로 진입 못하는 컨테이너에 의도치 않은 ring 가는 것 방지 */
[data-keyword-chart-target="chart"]:focus,
[data-word-cloud-chart-target="chart"]:focus {
  outline: none;
}

/* sr-only — 시각적으로 숨기지만 스크린리더 노출 */
.dl-sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* skip-link — 페이지 최상단에 두면 키보드로 본문으로 즉시 점프 */
.dl-skip-link {
  position: absolute;
  left: -10000px;
  top: 0;
  z-index: 10001;
  background: var(--color-primary, #003ec7);
  color: #fff;
  padding: 0.5rem 0.875rem;
  border-radius: 0 0 0.5rem 0;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
}
.dl-skip-link:focus,
.dl-skip-link:focus-visible {
  left: 0;
  outline: 2px solid #fff;
  outline-offset: -4px;
}

/* ==========================================================================
   기업 정보 카드 (DART) — 헤더(아바타+이름+메타) + 프로필 그리드 + 요약/차트
   - 대시보드 다른 카드와 시각적 위계 통일: 헤더 14~16px / 라벨 11px overline / 값 14px
   - 프로필 셀은 "라벨-값" 페어를 카드 안에 한 번 더 묶어 하나의 정보 유닛으로 인식되도록 함
   ========================================================================== */
.dl-company-card {
  background-color: var(--color-surface-container-lowest, #ffffff);
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 35%, transparent);
  border-radius: 0.75rem;
  box-shadow: 0 1px 2px -1px color-mix(in oklab, var(--color-on-surface, #1b1b21) 8%, transparent);
  overflow: hidden;
}

.dl-company-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: linear-gradient(
    180deg,
    color-mix(in oklab, var(--color-primary, #003ec7) 3%, var(--color-surface-container-lowest, #ffffff)) 0%,
    var(--color-surface-container-lowest, #ffffff) 100%
  );
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 25%, transparent);
  flex-wrap: wrap;
}

.dl-company-card__title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.dl-company-card__avatar {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: color-mix(in oklab, var(--color-primary, #003ec7) 12%, transparent);
  color: var(--color-primary, #003ec7);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.01em;
  font-family: var(--font-display, inherit);
}

.dl-company-card__eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 85%, transparent);
  margin-bottom: 0.125rem;
}

.dl-company-card__name {
  font-family: var(--font-display, inherit);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-on-surface, #1b1b21);
  letter-spacing: -0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 36ch;
}

.dl-company-card__meta {
  font-size: 11px;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 80%, transparent);
  text-align: right;
  line-height: 1.4;
  flex-shrink: 0;
  max-width: 16rem;
  font-variant-numeric: tabular-nums;
}

.dl-company-card__body {
  padding: 1.125rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 1024px) {
  .dl-company-card__body--with-chart {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: stretch;
    gap: 1.25rem;
  }
}
.dl-company-card__col {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}

/* 프로필 그리드 */
.dl-company-card__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}
@media (min-width: 640px) {
  .dl-company-card__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.dl-company-fact {
  min-width: 0;
  padding: 0.625rem 0.75rem;
  border-radius: 0.5rem;
  background-color: color-mix(in oklab, var(--color-on-surface, #1b1b21) 2.5%, var(--color-surface-container-lowest, #ffffff));
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 22%, transparent);
}
.dl-company-fact--wide {
  grid-column: 1 / -1;
}
@media (min-width: 640px) {
  .dl-company-fact--wide {
    grid-column: span 2 / span 2;
  }
}

.dl-company-fact__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 80%, transparent);
  margin-bottom: 0.25rem;
}

.dl-company-fact__value {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1.4;
  word-break: break-all;
}

/* 홈페이지 링크 */
.dl-company-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--color-primary, #003ec7);
  font-weight: 600;
  font-size: 13px;
  text-decoration: none;
  word-break: break-all;
}
.dl-company-card__link:hover { text-decoration: underline; }
.dl-company-card__link-icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
  opacity: 0.75;
}

/* 재무 요약 */
.dl-company-summary {
  border-radius: 0.5rem;
  padding: 0.75rem 0.875rem;
  background: color-mix(in oklab, var(--color-on-surface, #1b1b21) 3.5%, var(--color-surface-container-lowest, #ffffff));
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 22%, transparent);
}
.dl-company-summary--stick-bottom { margin-top: auto; }

.dl-company-summary__title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 80%, transparent);
  margin-bottom: 0.5rem;
}

.dl-company-summary__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem 0.75rem;
}

.dl-company-summary__cell { min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.dl-company-summary__label { font-size: 11px; color: var(--color-on-surface-variant, #46464f); }
.dl-company-summary__value {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1.2;
}
.dl-company-summary__yoy {
  font-size: 10px;
  font-weight: 600;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 85%, transparent);
}

/* 재무 차트 */
.dl-company-chart {
  border-radius: 0.5rem;
  padding: 0.75rem 0.875rem;
  background: color-mix(in oklab, var(--color-on-surface, #1b1b21) 2%, var(--color-surface-container-lowest, #ffffff));
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 22%, transparent);
  display: flex;
  flex-direction: column;
  min-width: 0;
}
@media (min-width: 1024px) {
  .dl-company-chart { align-self: stretch; }
}
.dl-company-chart__title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 80%, transparent);
  margin-bottom: 0.375rem;
  flex-shrink: 0;
}
.dl-company-chart__canvas {
  width: 100%;
  flex: 1 1 auto;
  min-height: 220px;
  height: 240px;
}

/* ==========================================================================
   공통 검색 바 (Explorer / Multi Explorer)
   --------------------------------------------------------------------------
   높이 토큰: 2.5rem (40px) — 데스크톱 compact로 충분한 터치 영역.
   ========================================================================== */
.dl-search-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.625rem 0.75rem;
  padding: 0.875rem 1rem;
  border-radius: 0.75rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 18%, transparent);
  background: var(--color-surface-container-lowest, #fff);
  box-shadow:
    0 1px 3px color-mix(in oklab, var(--color-on-surface, #1b1b21) 4%, transparent),
    0 0 0 1px color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 5%, transparent);
}
.dl-search-bar__field {
  flex: 1 1 auto;
  min-width: 0;
}
.dl-search-bar__label {
  display: block;
  margin-bottom: 0.3125rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--color-on-surface-variant, #46464f);
}
.dl-search-bar__label .dl-required {
  color: var(--color-error, #ba1a1a);
}
.dl-search-bar__input {
  display: block;
  width: 100%;
  height: 2.5rem;
  box-sizing: border-box;
  border-radius: 0.5rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 30%, transparent);
  background: var(--color-surface-container-lowest, #fff);
  padding: 0 0.625rem 0 2.125rem;
  font-size: 0.8125rem;
  line-height: 2.5rem;
  color: var(--color-on-surface, #1b1b21);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.dl-search-bar__input::placeholder {
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 50%, transparent);
}
.dl-search-bar__input:focus {
  border-color: var(--color-primary, #4758b8);
  box-shadow: 0 0 0 2.5px color-mix(in oklab, var(--color-primary, #4758b8) 12%, transparent);
}
/* DART 법인 선택 후 우측 초기화 버튼 영역 */
.dl-search-bar__input[data-corp-locked="true"] {
  padding-right: 2rem;
}
.dl-search-bar__input-wrap {
  position: relative;
}
.dl-search-bar__clear-corp {
  position: absolute;
  right: 0.375rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 9999px;
  background: transparent;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 70%, transparent);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}
.dl-search-bar__clear-corp:hover {
  background: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 14%, transparent);
  color: var(--color-on-surface, #1b1b21);
}
.dl-search-bar__clear-corp svg {
  width: 0.75rem;
  height: 0.75rem;
  flex-shrink: 0;
}
.dl-search-bar__input-icon {
  position: absolute;
  left: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  pointer-events: none;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 55%, transparent);
}
.dl-search-bar__period {
  display: inline-flex;
  height: 2.5rem;
  align-items: stretch;
  gap: 0.125rem;
  box-sizing: border-box;
  border-radius: 0.5rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 28%, transparent);
  background: color-mix(in oklab, var(--color-surface-container-high, #eceef7) 35%, transparent);
  padding: 0.1875rem;
}
.dl-search-bar__period-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  border-radius: 0.3125rem;
  padding: 0 0.625rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 92%, transparent);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  white-space: nowrap;
}
.dl-search-bar__period-btn:hover {
  background: color-mix(in oklab, var(--color-surface-container-high, #eceef7) 70%, transparent);
}
.dl-search-bar__period-btn.is-active {
  background: var(--color-primary, #4758b8);
  color: var(--color-on-primary, #fff);
  font-weight: 600;
  box-shadow: 0 1px 2px color-mix(in oklab, var(--color-primary, #4758b8) 18%, transparent);
}
.dl-search-bar__date {
  height: 2.5rem;
  box-sizing: border-box;
  border-radius: 0.5rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 28%, transparent);
  background: color-mix(in oklab, var(--color-surface-container-high, #eceef7) 28%, transparent);
  padding: 0 0.5rem;
  font-size: 0.8125rem;
  color: var(--color-on-surface, #1b1b21);
  outline: none;
  width: 8.25rem;
  min-width: 8.25rem;
  max-width: 8.25rem;
  transition: border-color 0.15s;
}
.dl-search-bar__date:focus {
  border-color: var(--color-primary, #4758b8);
}
.dl-search-bar__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  padding: 0 0.775rem;
  font-size: 0.8125rem;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  border: none;
  transition: background 0.15s, box-shadow 0.15s;
}
.dl-search-bar__btn--primary {
  background: var(--color-primary, #4758b8);
  color: var(--color-on-primary, #fff);
  box-shadow: 0 1px 4px color-mix(in oklab, var(--color-primary, #4758b8) 25%, transparent);
}
.dl-search-bar__btn--primary:hover {
  background: color-mix(in oklab, var(--color-primary, #4758b8) 88%, black);
  box-shadow: 0 2px 8px color-mix(in oklab, var(--color-primary, #4758b8) 30%, transparent);
}
.dl-search-bar__btn--ghost {
  background: transparent;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 35%, transparent);
  color: var(--color-on-surface-variant, #46464f);
  gap: 0.375rem;
  font-weight: 500;
}
.dl-search-bar__btn--ghost:hover {
  border-color: color-mix(in oklab, var(--color-primary, #4758b8) 40%, transparent);
  color: var(--color-primary, #4758b8);
  background: color-mix(in oklab, var(--color-primary-fixed, #e8e4ff) 28%, transparent);
}
.dl-search-bar__divider {
  width: 1px;
  align-self: stretch;
  background: color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 35%, transparent);
  margin: 0.25rem 0;
  flex-shrink: 0;
}
@media (max-width: 1280px) {
  .dl-search-bar--explorer {
    align-items: flex-end;
  }
  .dl-search-bar--explorer .dl-search-bar__period-break {
    display: none !important;
  }
  .dl-search-bar--explorer .dl-search-bar__period-field {
    flex: 1 0 100% !important;
    width: 100%;
    padding-top: 0.625rem;
    border-top: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 22%, transparent);
  }
  .dl-search-bar--explorer .dl-search-bar__period-field > .flex {
    flex-wrap: wrap;
  }
}
.dl-search-bar__tagbox {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.3125rem;
  height: 2.5rem;
  box-sizing: border-box;
  border-radius: 0.5rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 30%, transparent);
  background: var(--color-surface-container-lowest, #fff);
  padding: 0 3rem 0 2.125rem;
  overflow-x: auto;
  overflow-y: hidden;
  cursor: text;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  scrollbar-width: thin;
}
.dl-search-bar__tagbox:focus-within {
  border-color: var(--color-primary, #4758b8);
  box-shadow: 0 0 0 2.5px color-mix(in oklab, var(--color-primary, #4758b8) 12%, transparent);
}
.dl-search-bar__tagbox-input {
  flex: 1 1 auto;
  min-width: 5rem;
  height: 100%;
  border: 0;
  background: transparent;
  padding: 0;
  font-size: 0.8125rem;
  color: var(--color-on-surface, #1b1b21);
  outline: none;
}
.dl-search-bar__tagbox-input::placeholder {
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 50%, transparent);
}
.dl-search-bar__hint {
  width: 100%;
  margin: 0;
  padding: 0.375rem 0.125rem 0;
  border-top: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 12%, transparent);
  font-size: 0.6875rem;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 75%, transparent);
  line-height: 1.45;
}

/* ==========================================================================
   Multi Explorer — 비교 구성 확장 (dl-search-bar 위에 쌓는 패널)
   ========================================================================== */
.dl-me-compare {
  border-radius: 0.625rem;
  border: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 18%, transparent);
  background: var(--color-surface-container-lowest, #fff);
  box-shadow:
    0 1px 2px color-mix(in oklab, var(--color-on-surface, #1b1b21) 3%, transparent),
    0 0 0 1px color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 4%, transparent);
  overflow: hidden;
}
.dl-me-compare__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.625rem 0.75rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 12%, transparent);
  background: color-mix(
    in oklab,
    var(--color-primary-fixed, #e8e4ff) 15%,
    var(--color-surface-container-lowest, #fff)
  );
}
.dl-me-compare__title {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-on-surface, #1b1b21);
  line-height: 1.25;
}
.dl-me-compare__meta {
  margin: 0.125rem 0 0;
  font-size: 0.6875rem;
  line-height: 1.45;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 82%, transparent);
  max-width: 42rem;
}
.dl-me-compare__body {
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.dl-me-compare__label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--color-on-surface-variant, #46464f);
  margin-bottom: 0.3125rem;
}
.dl-me-compare__label-note {
  font-weight: 500;
  font-size: 0.6875rem;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 68%, transparent);
}
.dl-me-compare__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.375rem;
}
.dl-me-compare__queue {
  border-radius: 0.375rem;
  border: 1px dashed color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 42%, transparent);
  background: color-mix(in oklab, var(--color-surface-container-high, #eceef7) 22%, transparent);
  overflow: hidden;
}
.dl-me-compare__queue-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.375rem 0.625rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 12%, transparent);
  background: color-mix(in oklab, var(--color-surface-container-lowest, #fff) 55%, transparent);
}
.dl-me-compare__queue-title {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-on-surface-variant, #46464f) 78%, transparent);
}
.dl-me-tagbox::-webkit-scrollbar {
  height: 4px;
}
.dl-me-tagbox::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-outline-variant, #c4c6d0) 55%, transparent);
}

/* ==========================================================================
   Collection Toast — 키워드 수집 완료 전역 알림
   ========================================================================== */
.km-collection-toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 120;
  width: min(360px, calc(100vw - 32px));
  padding: 16px;
  border: 1px solid #bfdbfe;
  border-left: 4px solid #2563eb;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 18px 46px -18px rgba(15, 23, 42, 0.38), 0 4px 12px -8px rgba(15, 23, 42, 0.25);
  animation: km-toast-in .2s ease-out both;
}

.km-collection-toast.is-leaving {
  animation: km-toast-out .16s ease-in both;
}

.km-collection-toast__title {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 800;
  color: #1e293b;
}

.km-collection-toast__desc {
  margin: 0;
  font-size: 12.5px;
  line-height: 1.5;
  color: #64748b;
}

.km-collection-toast__actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 14px;
}

.km-collection-toast__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .14s ease;
}

.km-collection-toast__btn:hover {
  background: #f8fafc;
  color: #334155;
}

.km-collection-toast__btn--primary {
  border-color: #2563eb;
  background: #2563eb;
  color: #fff;
}

.km-collection-toast__btn--primary:hover {
  background: #1d4ed8;
  color: #fff;
}

@keyframes km-toast-in {
  from { opacity: 0; transform: translateY(10px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes km-toast-out {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(8px); }
}
