/* ============================================================
   MUIY — Donor Pool: sync badge micro-interactions +
   A4 "Export donors" print document.
   ============================================================ */

/* ---------- 1. SYNC STATUS BADGE ---------- */
.dx-sync{
  display:inline-flex; align-items:center; gap:6px;
  height:34px; padding:0 11px 0 9px;
  border:none; border-radius:999px; cursor:pointer;
  font-family:inherit; font-size:12.5px; font-weight:800; letter-spacing:.01em;
  background:var(--surface-2); color:var(--ink-3);
  transition:background .28s ease, color .28s ease, max-width .32s ease, padding .28s ease;
  -webkit-tap-highlight-color:transparent;
}
.dx-sync-ico{ display:inline-flex; transform-origin:50% 50%; }
.dx-sync-lbl{
  overflow:hidden; white-space:nowrap;
  max-width:64px; opacity:.92;
  transition:max-width .32s ease, opacity .24s ease, margin .28s ease;
}

/* idle — quiet: icon only, label tucked away */
.dx-sync--idle{ background:transparent; color:var(--ink-3); padding:0 6px; }
.dx-sync--idle:hover{ background:var(--surface-2); }
.dx-sync--idle .dx-sync-lbl{ max-width:0; opacity:0; margin-left:-6px; }
.dx-sync--idle .dx-sync-ico{ opacity:.55; }

/* syncing — accent tint + spinning glyph */
.dx-sync--syncing{ background:color-mix(in srgb, var(--orange) 14%, transparent); color:var(--orange); }
.dx-sync--syncing .dx-sync-ico{ animation:dx-spin .8s linear infinite; }

/* synced — brief green confirmation with a soft pop */
.dx-sync--synced{ background:color-mix(in srgb, var(--eligible) 16%, transparent); color:var(--eligible); }
.dx-sync--synced .dx-sync-ico{ animation:dx-pop .42s cubic-bezier(.34,1.56,.64,1); }

/* error / offline — amber, static */
.dx-sync--error{ background:color-mix(in srgb, var(--soon) 16%, transparent); color:var(--soon); }
.dx-sync--error .dx-sync-ico{ animation:dx-nudge .5s ease; }

@keyframes dx-spin{ to{ transform:rotate(360deg); } }
@keyframes dx-pop{ 0%{ transform:scale(.4); opacity:0; } 60%{ transform:scale(1.18); } 100%{ transform:scale(1); opacity:1; } }
@keyframes dx-nudge{ 0%,100%{ transform:translateX(0); } 25%{ transform:translateX(-1.5px); } 75%{ transform:translateX(1.5px); } }

@media (prefers-reduced-motion: reduce){
  .dx-sync--syncing .dx-sync-ico,
  .dx-sync--synced .dx-sync-ico,
  .dx-sync--error .dx-sync-ico{ animation:none; }
}

/* ---------- 2. EXPORT SHEET CONTROLS ---------- */
.dx-fmt{ display:flex; gap:8px; margin-bottom:12px; }
.dx-fmt-btn{
  flex:1; display:inline-flex; align-items:center; justify-content:center; gap:7px;
  height:46px; border-radius:14px; cursor:pointer; font-family:inherit;
  font-size:13.5px; font-weight:800; color:var(--ink-2);
  background:var(--surface-2); border:1.5px solid transparent;
  transition:border-color .18s ease, background .18s ease, color .18s ease;
}
.dx-fmt-btn.on{ background:var(--surface); border-color:var(--orange); color:var(--ink); box-shadow:var(--sh-sm); }
.dx-fmt-btn:active{ transform:scale(.98); }

.dx-opts{ display:flex; flex-direction:column; gap:8px; margin-bottom:4px; }
.dx-opt{
  display:flex; align-items:center; gap:12px; text-align:left;
  padding:13px 14px; border-radius:15px; cursor:pointer; font-family:inherit;
  background:var(--surface-2); border:1.5px solid transparent;
  transition:border-color .18s ease, background .18s ease;
}
.dx-opt.on{ background:var(--surface); border-color:var(--orange); box-shadow:var(--sh-sm); }
.dx-opt-radio{
  width:20px; height:20px; flex:none; border-radius:50%;
  border:2px solid var(--ink-4, #c9cdce); position:relative; transition:border-color .18s ease;
}
.dx-opt.on .dx-opt-radio{ border-color:var(--orange); }
.dx-opt.on .dx-opt-radio::after{
  content:''; position:absolute; inset:3px; border-radius:50%; background:var(--orange);
}
.dx-opt-txt{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.dx-opt-t{ font-size:14.5px; font-weight:800; color:var(--ink); }
.dx-opt-d{ font-size:12px; font-weight:600; color:var(--ink-3); }

.dx-groups{ display:flex; flex-wrap:wrap; gap:7px; margin:10px 2px 2px; }
.dx-groups-empty{ font-size:13px; color:var(--ink-3); font-weight:600; padding:4px 2px; }

.dx-preview{
  margin-top:14px; padding:13px 15px; border-radius:15px;
  background:var(--surface-2); display:flex; flex-direction:column; gap:9px;
}
.dx-preview-row{ display:flex; justify-content:space-between; align-items:baseline; font-size:13.5px; font-weight:700; color:var(--ink-2); }
.dx-preview-row b{ font-size:16px; font-weight:800; color:var(--ink); }
.dx-preview-stats{ display:flex; gap:14px; font-size:12.5px; font-weight:600; color:var(--ink-3); }
.dx-preview-stats b{ font-weight:800; }
.dx-preview-file{
  display:flex; align-items:center; gap:7px;
  font-family:'SF Mono', ui-monospace, Menlo, monospace; font-size:12px; font-weight:600;
  color:var(--ink-3); padding-top:9px; border-top:1px solid var(--hairline);
}

/* ---------- 3. A4 PRINT DOCUMENT (#donor-print-root) ---------- */
#donor-print-root{ display:none; }
@media print{
  html, body{ background:#fff !important; height:auto !important; overflow:visible !important; }
  #root, body > .desk, .twk-panel, .toast, .sheet-backdrop, .dialog-backdrop, #tc-print-root{ display:none !important; }
  #donor-print-root{
    display:block !important; position:static !important;
    font-family:'Manrope', system-ui, sans-serif; color:#1d2b2c;
  }
  @page{ size:A4; margin:14mm 12mm 18mm; }
}
#donor-print-root{
  background:#fff; color:#1d2b2c;
  -webkit-print-color-adjust:exact; print-color-adjust:exact;
}
@media screen{
  /* on-screen preview (debug only) — keeps the badge/sheet as the real UI */
  #donor-print-root{ max-width:840px; margin:0 auto; padding:34px 40px; box-shadow:0 1px 24px rgba(0,0,0,.08); }
}

/* repeating footer — fixed elements repaint on every printed page */
.dx-foot{
  position:fixed; left:0; right:0; bottom:0;
  display:flex; justify-content:space-between; align-items:center;
  padding:5pt 12mm; font-size:7pt; font-weight:500; color:#9fb0b0;
  letter-spacing:.01em; border-top:.5pt solid #e3edec; background:#fff;
}
.dx-foot b{ color:#14716A; font-weight:800; }
@media screen{ .dx-foot{ display:none; } }

/* ---- masthead ---- */
.dx-mast{ display:flex; justify-content:space-between; align-items:center; }
.dx-mast-id{ display:flex; align-items:center; gap:8pt; }
.dx-mark{
  width:16pt; height:16pt; border-radius:4.5pt; flex:none; background:#14716A; position:relative;
}
.dx-mark::after{
  content:''; position:absolute; left:50%; top:50%; width:7pt; height:9pt;
  transform:translate(-50%,-52%);
  background:#fff; clip-path:polygon(50% 0, 100% 60%, 80% 100%, 20% 100%, 0 60%);
}
.dx-wordmark{ font-size:12pt; font-weight:800; color:#10302e; letter-spacing:-.02em; }
.dx-mast-sep{ width:.8pt; height:11pt; background:#cdddda; }
.dx-mast-kind{ font-size:8pt; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:#6f8a89; }
.dx-mast-ref{ font-family:'SF Mono', ui-monospace, Menlo, monospace; font-size:8pt; font-weight:600; color:#8aa0a0; letter-spacing:.02em; }

.dx-rule{ height:1.6pt; background:#14716A; margin:7pt 0 0; }

/* ---- title + meta ---- */
.dx-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24pt; margin:13pt 0 15pt; }
.dx-title{ font-size:21pt; font-weight:800; letter-spacing:-.025em; color:#10302e; margin:0 0 3pt; line-height:1; }
.dx-sub{ font-size:9pt; color:#6f8a89; font-weight:600; margin:0; }
.dx-meta{ margin:0; display:grid; grid-auto-flow:row; gap:3.5pt; text-align:right; flex:none; }
.dx-meta > div{ display:flex; justify-content:flex-end; align-items:baseline; gap:9pt; }
.dx-meta dt{ font-size:7pt; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#9fb0b0; }
.dx-meta dd{ margin:0; font-size:8.5pt; font-weight:700; color:#1d3a38; font-variant-numeric:tabular-nums; }

/* ---- KPI band ---- */
.dx-kpis{
  display:flex; align-items:stretch;
  border:.8pt solid #e0eaea; border-radius:8pt; overflow:hidden; margin-bottom:16pt; background:#fcfdfd;
}
.dx-kpi{ flex:1; padding:11pt 14pt; border-left:.8pt solid #e9f0ef; }
.dx-kpi:first-child{ border-left:none; }
.dx-kpi--lead{ background:#14716A; flex:1.15; }
.dx-kpi-n{
  display:flex; align-items:center; gap:5pt;
  font-size:20pt; font-weight:800; line-height:1; color:#10302e; font-variant-numeric:tabular-nums; letter-spacing:-.02em;
}
.dx-kpi--lead .dx-kpi-n{ color:#fff; }
.dx-kpi-l{ display:block; font-size:7.5pt; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:#7d9596; margin-top:5pt; }
.dx-kpi--lead .dx-kpi-l{ color:#a9d6d0; }
.dx-dot{ width:7pt; height:7pt; border-radius:50%; flex:none; display:inline-block; }
.dx-dot--ok{ background:#1A8F5E; }
.dx-dot--soon{ background:#C07A12; }
.dx-dot--off{ background:#90a4a4; }

/* ---- blocks / eyebrows ---- */
.dx-block{ margin-bottom:15pt; }
.dx-eyebrow{
  display:flex; align-items:baseline; justify-content:space-between; white-space:nowrap;
  font-size:8pt; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:#14716A;
  padding-bottom:5pt; margin-bottom:9pt; border-bottom:.8pt solid #e3edec;
}
.dx-eyebrow--table{ margin-bottom:0; }
.dx-eyebrow-meta{ font-size:7pt; font-weight:600; letter-spacing:.03em; text-transform:none; color:#9fb0b0; }

/* ---- distribution bar + legend ---- */
.dx-bar{ display:flex; height:9pt; border-radius:99pt; overflow:hidden; background:#eef4f3; }
.dx-bar-seg{ height:100%; }
.dx-bar-seg + .dx-bar-seg{ box-shadow:-.4pt 0 0 #fff; }
.dx-legend{ display:flex; flex-wrap:wrap; gap:5pt 14pt; margin-top:9pt; }
.dx-leg{ display:inline-flex; align-items:center; gap:5pt; font-size:8.5pt; color:#3a5453; }
.dx-leg-sw{ width:8pt; height:8pt; border-radius:2.5pt; flex:none; }
.dx-leg b{ font-weight:800; color:#10302e; letter-spacing:-.01em; }
.dx-leg-n{ font-weight:700; color:#8aa0a0; font-variant-numeric:tabular-nums; }

/* ---- directory table ---- */
.dx-table{ width:100%; border-collapse:collapse; font-size:8.5pt; }
.dx-table thead{ display:table-header-group; } /* repeats on every printed page */
.dx-table th{
  text-align:left; font-size:6.8pt; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  color:#6f8a89; padding:7pt 7pt 6pt; border-bottom:1pt solid #14716A; white-space:nowrap;
}
.dx-table td{ padding:6pt 7pt; border-bottom:.5pt solid #eef3f2; color:#1d3a38; vertical-align:baseline; }
.dx-row{ break-inside:avoid; }
.dx-name{ font-weight:800; color:#10302e; }
.dx-mono{ font-family:'SF Mono', ui-monospace, Menlo, monospace; font-size:7.8pt; letter-spacing:-.03em; color:#3a5453; }
.dx-mut{ color:#b3c0c0; }
.dx-ok{ color:#1A8F5E; font-weight:700; }
.dx-c-num{ width:16pt; text-align:right; padding-right:9pt; font-family:'SF Mono', ui-monospace, Menlo, monospace; font-size:7.5pt; }
.dx-c-grp{ white-space:nowrap; }
.dx-c-cnt{ text-align:center; white-space:nowrap; font-variant-numeric:tabular-nums; }
.dx-c-stat{ white-space:nowrap; }
.dx-grp{
  display:inline-block; min-width:22pt; text-align:center;
  font-size:8pt; font-weight:800; color:#B23A48; letter-spacing:-.01em;
  background:#FBEEF0; border:.5pt solid #F3D6DB; border-radius:3.5pt; padding:1.5pt 5pt;
}
.dx-stat-cell{ display:inline-flex; align-items:center; gap:5pt; font-weight:700; font-size:8pt; color:#3a5453; }
.dx-stat-cell .dx-dot{ width:5.5pt; height:5.5pt; }

/* notes sub-row */
.dx-noterow td{ background:transparent; padding-top:0; padding-bottom:6.5pt; border-bottom:.5pt solid #eef3f2; }
.dx-row:has(+ .dx-noterow) td{ border-bottom:none; padding-bottom:2pt; }
.dx-note{ font-size:7.6pt; color:#5b7574; line-height:1.45; }
.dx-note-k{
  display:inline-block; font-weight:800; color:#fff; background:#9fb6b4; letter-spacing:.04em; text-transform:uppercase;
  font-size:6.2pt; padding:.5pt 4pt; border-radius:3pt; margin-right:6pt; vertical-align:1pt;
}
.dx-empty{ text-align:center; color:#7d9596; padding:20pt; font-size:9pt; font-weight:600; }

.dx-disclaimer{
  margin-top:16pt; padding-top:9pt; border-top:.5pt solid #e3edec;
  font-size:7.4pt; color:#9fb0b0; line-height:1.55;
}
.dx-disclaimer b{ color:#5b7574; font-weight:800; }
