/* ═══════════════════════════════════════════════════════
   MCAST Data Tables — Display CSS v5.0
   Scoped to .mcd-scope
═══════════════════════════════════════════════════════ */

.mcd-scope {
  --dv-navy:   #000043;
  --dv-white:  #ffffff;
  --dv-off:    #f5f5fa;
  --dv-border: #e2e2ee;
  --dv-text:   #1a1a3e;
  --dv-mute:   #6b6b99;
  --dv-ok:     #005c3a;
  font-family: 'Montserrat', sans-serif;
  color: var(--dv-text);
  -webkit-font-smoothing: antialiased;
}
.mcd-scope *, .mcd-scope *::before, .mcd-scope *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── TOOLBAR ─────────────────────────────────────────── */
.mcdv-toolbar {
  background: var(--dv-white);
  border: 1.5px solid var(--dv-border);
  border-radius: 12px;
  box-shadow: 0 2px 14px rgba(0,0,67,.06);
  margin-bottom: 20px;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mcdv-toolbar-row1 { display: flex; align-items: center; gap: 10px; }

.mcdv-search-wrap { position: relative; flex: 1; max-width: 340px; }
.mcdv-search-wrap i { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--dv-mute); font-size: 12px; pointer-events: none; }
.mcdv-search {
  width: 100%; padding: 9px 12px 9px 32px;
  border: 1.5px solid var(--dv-border); border-radius: 8px;
  font-family: 'Montserrat', sans-serif; font-size: 13px;
  color: var(--dv-text); background: var(--dv-off); outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.mcdv-search:focus { border-color: var(--dv-navy); box-shadow: 0 0 0 3px rgba(0,0,67,.09); background: var(--dv-white); }

.mcdv-meta { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.mcdv-count-wrap { font-size: 12px; color: var(--dv-mute); white-space: nowrap; }
.mcdv-count { color: var(--dv-navy); font-weight: 700; }
.mcdv-badge { font-size: 11px; color: var(--dv-ok); font-weight: 500; white-space: nowrap; }

/* ── FILTER CHIPS ────────────────────────────────────── */
.mcdv-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-top: 10px;
  border-top: 1px solid var(--dv-border);
}
.mcdv-chips:empty { display: none; }

.mcdv-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 12px; border-radius: 8px;
  border: 1.5px solid var(--dv-border);
  background: var(--dv-white);
  font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 600;
  color: var(--dv-mute); cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}
.mcdv-chip:hover { border-color: var(--dv-navy); color: var(--dv-navy); }
.mcdv-chip.is-active { background: var(--dv-navy); border-color: var(--dv-navy); color: #fff; }
.mcdv-chip-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.mcdv-chip--more { background: var(--dv-off); font-style: italic; }
.mcdv-chip--more:hover { background: rgba(0,0,67,.06); border-color: var(--dv-navy); }

/* ── CARD GRID ───────────────────────────────────────── */
.mcdv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.mcdv-card {
  background: var(--dv-white);
  border: 1.5px solid var(--dv-border);
  border-radius: 12px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  animation: mcdvFadeUp .3s ease both;
}
.mcdv-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,67,.10);
  border-color: var(--card-accent, rgba(0,0,67,.22));
}
@keyframes mcdvFadeUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

/* Coloured top stripe */
.mcdv-card-accent { height: 4px; }

/* ── CARD HEAD ───────────────────────────────────────── */
.mcdv-card-head {
  padding: 14px 18px 12px;
  border-bottom: 1.5px solid var(--dv-border);
  display: flex; align-items: flex-start; gap: 10px;
}

/* Main heading — the "Thematic areas" value */
.mcdv-card-heading {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--dv-navy);
  line-height: 1.35;
  word-break: break-word;
}

/* ── STATUS BADGES ───────────────────────────────────── */
.mcdv-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 20px;
  font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  flex-shrink: 0; white-space: nowrap; line-height: 1;
}
.mcdv-status--active   { background:#e6f4ee; color:#005c3a; border:1.5px solid #b3ddc9; }
.mcdv-status--active i { color:#00a060; }
.mcdv-status--complete   { background:#f0f0f6; color:#5a5a8a; border:1.5px solid #d0d0e8; }
.mcdv-status--complete i { color:#8888b8; }

/* ── CARD BODY ───────────────────────────────────────── */
.mcdv-card-body { padding: 12px 18px 16px; flex: 1; display: flex; flex-direction: column; gap: 8px; }

/* Taxonomy tag — colour applied inline */
.mcdv-cat-tag {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 4px;
  font-size: 11px; font-weight: 600; letter-spacing: .03em;
  border: 1.5px solid; max-width: 100%;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Body fields */
.mcdv-fields     { display: flex; flex-direction: column; gap: 6px; }
.mcdv-field      { display: flex; flex-direction: column; gap: 2px; }
.mcdv-field-key  { font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--dv-mute); }
.mcdv-field-val  { font-size: 13px; color: var(--dv-text); line-height: 1.45; word-break: break-word; }
.mcdv-field-sep  { height: 1px; background: var(--dv-off); margin: 2px 0; }
.mcdv-link       { color: var(--dv-navy); text-underline-offset: 2px; }

/* ── NO RESULTS ──────────────────────────────────────── */
.mcdv-nores { text-align: center; padding: 50px 20px; color: var(--dv-mute); }
.mcdv-nores i { font-size: 38px; display: block; margin-bottom: 10px; opacity: .2; }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media (max-width: 600px) {
  .mcdv-grid  { grid-template-columns: 1fr; }
  .mcdv-chips { gap: 5px; }
  .mcdv-chip  { font-size: 10px; padding: 6px 9px; }
}
