/* =====================================================================
   Infomail Design System — shared components for the Claude Design restyle
   (handoff bundle). Adds ONLY the design tokens the project was missing
   (derived from the tenant brand via color-mix, so they follow branding)
   plus NEW component classes used by the redesigned pages. Existing global
   classes (.card/.badge base/.table/.toolbar/.tabs/.search) are NOT
   redefined here to avoid affecting non-redesigned pages.
   ===================================================================== */

:root {
  /* brand-derived (follow the tenant --im-brand / --im-accent) */
  --im-brand-tint: color-mix(in srgb, var(--im-brand) 7%, #fff);
  --im-accent-strong: color-mix(in srgb, var(--im-accent) 80%, #000);
  /* neutral status palette (fixed) */
  --im-ink-faint: #8a9591;
  --im-success-soft: #dcf5e3;
  --im-danger-soft: #fde3e3;
  --im-warn: #b45309;
  --im-warn-soft: #fcefcf;
  --im-info: #1d4ed8;
  --im-info-soft: #dde7fe;
  --im-purple: #7c3aed;
  --im-purple-soft: #ede4fd;
  /* shape / elevation / focus */
  --radius: 14px;
  --radius-pill: 999px;
  --shadow-sm: none;
  --shadow-md: 0 1px 2px rgba(16, 40, 34, .06);
  --shadow-lg: 0 8px 28px rgba(16, 40, 34, .10);
  --ring: 0 0 0 3px color-mix(in srgb, var(--im-brand) 20%, transparent);
}

/* ---------- helpers ---------- */
.dash-em { color: var(--im-ink-faint); }
.ds-grid { display: grid; gap: 22px; }
.g2 { display: grid; gap: 22px; grid-template-columns: repeat(2, 1fr); }
.g3 { display: grid; gap: 22px; grid-template-columns: repeat(3, 1fr); }
.g4 { display: grid; gap: 22px; grid-template-columns: repeat(4, 1fr); }
.split-72 { display: grid; grid-template-columns: minmax(0, 2.05fr) minmax(300px, 1fr); gap: 22px; }
.split-64 { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr); gap: 22px; }
.col-stack { display: flex; flex-direction: column; gap: 22px; }
.mb-22 { margin-bottom: 22px; }

/* ---------- KPI tiles ---------- */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.kpi { background: var(--im-panel); border: 1px solid var(--im-panel-strong); border-radius: var(--radius); padding: 18px 18px 16px; box-shadow: var(--shadow-sm); position: relative; overflow: hidden; transition: border-color .16s; }
.kpi:hover { border-color: #d2dad7; }
.kpi-top { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.kpi-ico { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; font-size: 16px; background: var(--im-brand-tint); color: var(--im-brand); }
.kpi-ico.amber { background: var(--im-accent-soft); color: var(--im-accent-strong); }
.kpi-ico.green { background: var(--im-success-soft); color: var(--im-success); }
.kpi-ico.red { background: var(--im-danger-soft); color: var(--im-danger); }
.kpi-ico.blue { background: var(--im-info-soft); color: var(--im-info); }
.kpi-ico.purple { background: var(--im-purple-soft); color: var(--im-purple); }
.kpi-label { font-size: 12.5px; font-weight: 600; color: var(--im-ink-soft); }
.kpi-value { font-size: 30px; font-weight: 700; letter-spacing: -.02em; line-height: 1.05; font-variant-numeric: tabular-nums; }
.kpi-value .u { font-size: 18px; color: var(--im-ink-soft); }
.kpi-foot { display: flex; align-items: center; gap: 7px; margin-top: 8px; font-size: 12.5px; color: var(--im-ink-faint); }
.delta { display: inline-flex; align-items: center; gap: 2px; font-weight: 600; padding: 2px 7px; border-radius: var(--radius-pill); font-size: 12px; white-space: nowrap; }
.delta i { font-size: 14px; margin: 0 -2px; }
.delta.up, .delta.good-down { background: var(--im-success-soft); color: var(--im-success); }
.delta.down { background: var(--im-danger-soft); color: var(--im-danger); }

/* ---------- quick actions ---------- */
.qa { display: flex; align-items: center; gap: 13px; padding: 11px 12px; border-radius: 11px; color: var(--im-ink); font-weight: 600; font-size: 13.5px; transition: background .14s; cursor: pointer; border: 1px solid transparent; text-decoration: none; }
.qa:hover { background: var(--im-panel-muted); text-decoration: none; border-color: var(--im-panel-strong); }
.qa-ico { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; font-size: 16px; flex: 0 0 36px; }
.qa-ico.brand { background: var(--im-brand); color: #fff; }
.qa-ico.tint { background: var(--im-brand-tint); color: var(--im-brand); }
.qa-ico.amber { background: var(--im-accent-soft); color: var(--im-accent-strong); }
.qa-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.qa-text small { font-weight: 400; color: var(--im-ink-faint); font-size: 11.5px; }
.qa .bi-arrow-right { margin-left: auto; color: var(--im-ink-faint); font-size: 14px; }

/* ---------- range pill ---------- */
.range-pill { display: inline-flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: var(--radius-sm); border: 1px solid var(--im-panel-strong); background: var(--im-panel); font-size: 13px; font-weight: 600; color: var(--im-ink); cursor: pointer; }
.range-pill:hover { border-color: var(--im-brand); }
.range-pill i:first-child { color: var(--im-brand); }
.range-pill i:last-child { font-size: 11px; color: var(--im-ink-faint); }

/* ---------- design table ---------- */
.ds-tbl-wrap { overflow-x: auto; }
table.ds-tbl { width: 100%; border-collapse: collapse; font-size: 13.5px; }
table.ds-tbl th { text-align: left; font-weight: 600; color: var(--im-ink-faint); font-size: 11.5px; text-transform: uppercase; letter-spacing: .05em; padding: 11px 18px; border-bottom: 1px solid var(--im-panel-strong); background: var(--im-panel-muted); white-space: nowrap; }
table.ds-tbl th.num, table.ds-tbl td.num { text-align: right; font-variant-numeric: tabular-nums; }
table.ds-tbl td { padding: 14px 18px; border-bottom: 1px solid var(--im-panel-strong); vertical-align: middle; }
table.ds-tbl tbody tr:last-child td { border-bottom: none; }
table.ds-tbl tbody tr { transition: background .12s; }
table.ds-tbl tbody tr:hover { background: var(--im-panel-muted); }
.row-name { display: flex; align-items: center; gap: 12px; }
.row-name a { text-decoration: none; color: inherit; }
.row-name a:hover .nm { color: var(--im-brand); }
.row-ico { width: 34px; height: 34px; border-radius: 10px; flex: 0 0 34px; display: grid; place-items: center; background: var(--im-brand-tint); color: var(--im-brand); font-size: 15px; }
.row-ico.amber { background: var(--im-accent-soft); color: var(--im-accent-strong); }
.row-ico.green { background: var(--im-success-soft); color: var(--im-success); }
.row-ico.muted { background: var(--im-panel-muted); color: var(--im-ink-faint); }
.row-name .nm { font-weight: 600; color: var(--im-ink); }
.row-name .meta { font-size: 12px; color: var(--im-ink-faint); }
.bar-cell { display: flex; align-items: center; gap: 9px; justify-content: flex-end; }
.minibar { width: 46px; height: 5px; border-radius: 3px; background: var(--im-panel-strong); overflow: hidden; }
.minibar > i { display: block; height: 100%; border-radius: 3px; background: var(--im-brand); }
.minibar.amber > i { background: var(--im-accent); }
.rowmenu { width: 32px; height: 32px; border-radius: 8px; border: 1px solid transparent; background: none; color: var(--im-ink-faint); cursor: pointer; display: grid; place-items: center; font-size: 15px; }
.rowmenu:hover { background: var(--im-panel); border-color: var(--im-panel-strong); color: var(--im-ink); }
.col-subj { max-width: 230px; color: var(--im-ink-soft); }
.col-subj span { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.col-sender { white-space: nowrap; }
.col-sender .sname { display: block; color: var(--im-ink); font-weight: 500; }
.col-sender .smail { display: block; font-size: 12px; color: var(--im-ink-faint); }
.tagcell { display: flex; gap: 5px; flex-wrap: wrap; }
.tagcell .chip { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 500; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--im-panel-muted); border: 1px solid var(--im-panel-strong); color: var(--im-ink-soft); }
.tagcell .chip i { font-size: 11px; }

/* avatar */
.av { width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 12px; flex: 0 0 32px; background: linear-gradient(150deg, color-mix(in srgb, var(--im-brand) 70%, #fff), var(--im-brand-strong)); }

/* ---------- status badges (compose with the existing .badge base) ---------- */
.badge.b-sent { background: var(--im-success-soft); color: var(--im-success); }
.badge.b-sending { background: var(--im-info-soft); color: var(--im-info); }
.badge.b-queued { background: var(--im-accent-soft); color: var(--im-accent-strong); }
.badge.b-scheduled { background: var(--im-brand-soft); color: var(--im-brand-strong); }
.badge.b-paused { background: var(--im-warn-soft); color: var(--im-warn); }
.badge.b-sending .dot { animation: ds-pulse 1.3s ease-in-out infinite; }
@keyframes ds-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .35; transform: scale(.8); } }

/* ---------- gauge / deflist / stat ---------- */
.gauge { position: relative; width: 84px; height: 84px; flex: 0 0 84px; }
.gauge svg { transform: rotate(-90deg); }
.gauge-num { position: absolute; inset: 0; display: grid; place-items: center; font-size: 23px; font-weight: 700; letter-spacing: -.02em; color: var(--im-ink); }
.deflist { display: flex; flex-direction: column; }
.def { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-top: 1px solid var(--im-panel-strong); font-size: 13.5px; }
.def:first-child { border-top: 0; }
.def .k { color: var(--im-ink-soft); min-width: 160px; }
.def .v { font-weight: 600; margin-left: auto; text-align: right; }
.ds-stat .v { font-size: 22px; font-weight: 700; letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.ds-stat .l { font-size: 12px; color: var(--im-ink-soft); font-weight: 500; }

/* ---------- pager / filter dropdown ---------- */
.ds-pager { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-top: 1px solid var(--im-panel-strong); font-size: 13px; color: var(--im-ink-soft); }
.empty-fold { padding: 44px 20px; text-align: center; color: var(--im-ink-faint); font-size: 13.5px; }
.empty-fold i { font-size: 26px; display: block; margin-bottom: 8px; color: var(--im-panel-strong); }

.ds-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.ds-toolbar .ds-search { display: flex; align-items: center; gap: 8px; background: var(--im-panel); border: 1px solid var(--im-panel-strong); border-radius: var(--radius-sm); padding: 0 12px; min-width: 240px; flex: 1; max-width: 360px; }
.ds-toolbar .ds-search i { color: var(--im-ink-faint); font-size: 15px; }
.ds-toolbar .ds-search input { border: 0; outline: 0; background: none; padding: 10px 0; font-family: inherit; font-size: 13.5px; color: var(--im-ink); width: 100%; }
.ds-toolbar .spacer { flex: 1; }

.filter-dd { position: relative; display: inline-flex; }
.filter-pill { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 14px; border: 1px solid var(--im-panel-strong); background: var(--im-panel); border-radius: var(--radius-sm); font-family: inherit; font-size: 13.5px; font-weight: 600; color: var(--im-ink); cursor: pointer; }
.filter-pill:hover { border-color: #cdd6d3; }
.filter-dd.open .filter-pill { border-color: var(--im-brand); box-shadow: var(--ring); }
.filter-pill .flt-badge { display: inline-grid; place-items: center; min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px; background: var(--im-brand); color: #fff; font-size: 11px; font-weight: 700; }
.filter-pill .flt-badge[hidden] { display: none; }
.filter-dd-menu { position: absolute; top: calc(100% + 6px); right: 0; z-index: 55; width: 320px; background: var(--im-panel); border: 1px solid var(--im-panel-strong); border-radius: var(--radius); box-shadow: var(--shadow-lg); display: none; }
.filter-dd.open .filter-dd-menu { display: block; }
.fdd-sec { padding: 16px 16px 6px; }
.fdd-title { font-size: 11.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--im-ink-faint); margin-bottom: 11px; }
.fdd-range { display: flex; align-items: flex-end; gap: 9px; }
.fdd-field { flex: 1; display: flex; flex-direction: column; gap: 5px; }
.fdd-field span { font-size: 12px; font-weight: 600; color: var(--im-ink-soft); }
.fdd-field input { width: 100%; font-family: inherit; font-size: 13px; color: var(--im-ink); border: 1px solid var(--im-panel-strong); border-radius: var(--radius-sm); padding: 9px 10px; outline: none; }
.fdd-field input:focus { border-color: var(--im-brand); box-shadow: var(--ring); }
.fdd-sep { padding-bottom: 9px; color: var(--im-ink-faint); font-size: 13px; }
.fdd-foot { display: flex; justify-content: space-between; gap: 10px; padding: 12px 16px; border-top: 1px solid var(--im-panel-strong); margin-top: 10px; }

/* segmented control (design) */
.ds-seg { display: inline-flex; background: var(--im-panel-muted); border: 1px solid var(--im-panel-strong); border-radius: var(--radius-sm); padding: 3px; gap: 3px; }
.ds-seg button { border: 0; background: none; font-family: inherit; font-size: 12.5px; font-weight: 600; color: var(--im-ink-soft); padding: 6px 13px; border-radius: 7px; cursor: pointer; }
.ds-seg button.active { background: var(--im-panel); color: var(--im-ink); box-shadow: inset 0 0 0 1px var(--im-panel-strong); }

@media (max-width: 1180px) {
  .kpi-grid, .g4 { grid-template-columns: repeat(2, 1fr); }
  .g3 { grid-template-columns: 1fr 1fr; }
  .split-72, .split-64 { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .kpi-grid, .g2, .g3, .g4 { grid-template-columns: 1fr; }
  table.ds-tbl .hide-md { display: none; }
}
