/* v107: Retention rebuilt as card-per-employee. No more horizontal-scroll table.
   Each employee is a self-contained card. Row 1 is always-editable basic fields.
   Row 2 is the "next milestone" strip with Mark Paid action. Click chevron →
   expand all milestones stacked vertically inside the card. */

/* Header (preserved from v106 — brand-aligned purple) */
#cp-retention .ret-hdr{background:linear-gradient(135deg,var(--p),var(--pd));color:white;padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
#cp-retention .ret-hdr-title{font-size:16px;font-weight:700;}
#cp-retention .ret-hdr-sub{font-size:10px;opacity:0.75;margin-top:2px;}
#cp-retention .ret-hdr-pills{display:flex;gap:8px;flex-wrap:wrap;}
#cp-retention .ret-pill{background:rgba(255,255,255,0.18);border-radius:8px;padding:6px 12px;text-align:center;min-width:120px;}
#cp-retention .ret-pill .rp-val{font-size:15px;font-weight:700;color:white;}
#cp-retention .ret-pill .rp-lbl{font-size:9px;opacity:0.75;margin-top:1px;text-transform:uppercase;letter-spacing:0.04em;}
#cp-retention .ret-pill.accent{background:rgba(255,255,255,0.32);}

/* Body sections */
#cp-retention .ret-body{padding:16px 22px;background:#FAFAFC;}
#cp-retention .ret-sec{background:white;border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:12px;}
#cp-retention .ret-sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--p);margin-bottom:10px;border-bottom:1px solid var(--border);padding-bottom:6px;}

/* ─── EMPLOYEE CARD (the v107 redesign) ─── */
#cp-retention .emp-card{background:white;border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden;transition:box-shadow 0.15s,border-color 0.15s;}
#cp-retention .emp-card:hover{box-shadow:0 2px 6px rgba(123,82,204,0.08);border-color:var(--pm);}
#cp-retention .emp-card.expanded{box-shadow:0 4px 12px rgba(123,82,204,0.12);border-color:var(--p);}

/* Row 1: always-editable basic fields */
#cp-retention .emp-row1{display:grid;grid-template-columns:32px 180px 130px 80px 100px 110px 60px 60px 1fr 32px;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);}
#cp-retention .emp-row1 .ec-status{display:flex;justify-content:center;}
#cp-retention .emp-row1 .ec-name input{font-size:13px;font-weight:600;color:#1C1B2E;}
#cp-retention .emp-row1 input,
#cp-retention .emp-row1 select{background:white;border:1px solid var(--border);border-radius:5px;padding:6px 8px;font-size:11px;color:#1C1B2E;width:100%;font-family:inherit;}
#cp-retention .emp-row1 input:focus,
#cp-retention .emp-row1 select:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 2px rgba(123,82,204,0.15);}
#cp-retention .emp-row1 .ec-summary{font-size:11px;color:#666;text-align:right;line-height:1.4;}
#cp-retention .emp-row1 .ec-summary .ec-salary{font-weight:700;color:var(--pd);font-size:12px;display:block;}
#cp-retention .emp-row1 .ec-summary .ec-tenure{font-size:10px;color:#888;}
#cp-retention .emp-row1 .ec-del{background:transparent;color:#C0392B;border:none;border-radius:4px;padding:4px 8px;font-size:16px;cursor:pointer;line-height:1;}
#cp-retention .emp-row1 .ec-del:hover{background:rgba(192,57,43,0.1);}

/* Row 1 column header (shows once, above the cards) */
#cp-retention .emp-row1-hdr{display:grid;grid-template-columns:32px 180px 130px 80px 100px 110px 60px 60px 1fr 32px;gap:10px;align-items:center;padding:8px 14px;background:var(--p);color:white;border-radius:8px;margin-bottom:8px;font-size:9px;text-transform:uppercase;letter-spacing:0.06em;font-weight:600;}
#cp-retention .emp-row1-hdr div{text-align:left;}
#cp-retention .emp-row1-hdr div.ec-summary-hdr{text-align:right;}

/* Row 2: NEXT milestone strip */
#cp-retention .emp-next{padding:10px 14px;background:#FAFAFC;display:flex;align-items:center;gap:12px;}
#cp-retention .emp-next .next-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:#888;flex-shrink:0;}
#cp-retention .emp-next .next-content{flex:1;font-size:11px;color:#1C1B2E;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
#cp-retention .emp-next .next-content .nc-yr{font-weight:700;color:var(--p);font-size:12px;}
#cp-retention .emp-next .next-content .nc-amt{font-weight:700;color:#1C1B2E;font-size:13px;}
#cp-retention .emp-next .next-content .nc-meta{color:#666;font-size:10px;}
#cp-retention .emp-next .next-content .nc-fund{background:var(--pl);color:var(--pd);padding:3px 8px;border-radius:4px;font-weight:600;font-size:10px;}
#cp-retention .emp-next .next-content .nc-due{padding:3px 8px;border-radius:4px;font-weight:600;font-size:10px;}
#cp-retention .emp-next .next-content .nc-due.future{background:#F4F3FA;color:var(--p);}
#cp-retention .emp-next .next-content .nc-due.soon{background:#FFF4E5;color:#e65100;}
#cp-retention .emp-next .next-content .nc-due.overdue{background:#FFEBEE;color:#C62828;animation:pulse-soft 2s ease-in-out infinite;}
@keyframes pulse-soft{0%,100%{opacity:1;}50%{opacity:0.7;}}
#cp-retention .emp-next .next-actions{display:flex;gap:6px;flex-shrink:0;}
#cp-retention .btn-mark-paid{background:var(--g);color:white;border:none;border-radius:5px;padding:6px 14px;font-size:10px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:0.04em;font-family:inherit;}
#cp-retention .btn-mark-paid:hover{background:var(--gd);}
#cp-retention .btn-expand{background:transparent;color:var(--p);border:1px solid var(--pm);border-radius:5px;padding:5px 10px;font-size:11px;cursor:pointer;line-height:1;font-family:inherit;font-weight:600;}
#cp-retention .btn-expand:hover{background:var(--pl);}
#cp-retention .emp-next .empty-state{font-size:11px;color:#888;font-style:italic;flex:1;}

/* Row 3 (when expanded): all milestones stacked */
#cp-retention .emp-all{padding:14px;background:#FAFAFC;border-top:1px solid var(--border);}
#cp-retention .emp-all-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:#888;margin-bottom:10px;}
#cp-retention .ms-row{background:white;border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-bottom:8px;display:grid;grid-template-columns:30px 80px 1fr auto;gap:14px;align-items:center;}
#cp-retention .ms-row:last-child{margin-bottom:0;}
#cp-retention .ms-row.ms-paid{background:#F0F7F0;border-color:#C8E6C9;opacity:0.85;}
#cp-retention .ms-row.ms-active{border-color:var(--p);background:#FAFAFC;}
#cp-retention .ms-row.ms-future{opacity:0.6;}
#cp-retention .ms-row.ms-overdue{border-color:#C62828;background:#FFEBEE;}
#cp-retention .ms-row .ms-icon{font-size:18px;text-align:center;line-height:1;}
#cp-retention .ms-row.ms-paid .ms-icon{color:var(--g);}
#cp-retention .ms-row.ms-active .ms-icon{color:var(--p);}
#cp-retention .ms-row.ms-future .ms-icon{color:#aaa;}
#cp-retention .ms-row.ms-overdue .ms-icon{color:#C62828;}
#cp-retention .ms-row .ms-yr{font-size:14px;font-weight:700;color:var(--p);}
#cp-retention .ms-row.ms-paid .ms-yr{color:var(--gd);}
#cp-retention .ms-row .ms-yr-sub{font-size:9px;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:0.04em;}
#cp-retention .ms-row .ms-detail{font-size:11px;color:#1C1B2E;display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
#cp-retention .ms-row .ms-detail .md-amt{font-weight:700;font-size:13px;}
#cp-retention .ms-row .ms-detail .md-meta{color:#666;font-size:10px;}
#cp-retention .ms-row .ms-detail .md-fund{background:var(--pl);color:var(--pd);padding:3px 8px;border-radius:4px;font-weight:600;font-size:10px;}
#cp-retention .ms-row.ms-paid .ms-detail .md-fund{display:none;}
#cp-retention .emp-all-footer{font-size:11px;color:#666;text-align:right;padding:8px 4px 0;border-top:1px dashed var(--border);margin-top:6px;}
#cp-retention .emp-all-footer strong{color:var(--p);}

/* Buttons (consistent w/ rest of app) */
#cp-retention .ret-btn-add{background:var(--pl);color:var(--p);border:1px dashed var(--p);border-radius:6px;padding:7px 18px;font-size:11px;font-weight:600;cursor:pointer;margin-top:10px;font-family:inherit;}
#cp-retention .ret-btn-add:hover{background:var(--pm);}
#cp-retention .btn-unpaid{background:transparent;color:#888;border:1px solid var(--border);border-radius:5px;padding:4px 10px;font-size:9px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:0.04em;font-family:inherit;}
#cp-retention .btn-unpaid:hover{background:#F4F3FA;color:var(--p);}

/* Status dot per employee */
#cp-retention .status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle;}
#cp-retention .status-dot.ok{background:var(--g);}
#cp-retention .status-dot.due{background:#F57C00;box-shadow:0 0 0 3px rgba(245,124,0,0.18);}
#cp-retention .status-dot.overdue{background:#C62828;box-shadow:0 0 0 3px rgba(198,40,40,0.18);animation:pulse-soft 2s ease-in-out infinite;}
#cp-retention .status-dot.past{background:#9CA3AF;}

/* KPI / total cards */
#cp-retention .ret-totals{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px;}
#cp-retention .ret-tot-card{background:white;border:1px solid var(--border);border-radius:8px;padding:10px 12px;text-align:center;}
#cp-retention .ret-tot-card .rtv{font-size:16px;font-weight:700;color:var(--p);}
#cp-retention .ret-tot-card .rtl{font-size:9px;color:#888;margin-top:2px;text-transform:uppercase;letter-spacing:0.04em;}

/* Milestone config rows + how-it-works */
#cp-retention .ret-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
#cp-retention .ret-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
#cp-retention .ret-field{display:flex;justify-content:space-between;align-items:center;font-size:11px;padding:4px 0;color:#1C1B2E;}
#cp-retention .ret-field .rf-lbl{color:#666;}
#cp-retention .ret-field .rf-val{font-weight:600;background:var(--pl);color:var(--pd);padding:2px 8px;border-radius:4px;font-size:11px;}
#cp-retention .ret-funding-settings{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;background:#FAFAFC;border:1px solid var(--border);border-radius:8px;padding:10px;}
#cp-retention .ret-funding-settings .ret-field-stack{display:flex;flex-direction:column;gap:4px;}
#cp-retention .ret-funding-settings .ret-field-stack:nth-child(3){grid-column:1/-1;}
#cp-retention .ret-funding-settings label{font-size:9px;color:#666;text-transform:uppercase;letter-spacing:0.05em;font-weight:700;display:flex;align-items:center;gap:5px;}
#cp-retention .ret-funding-settings .ret-info{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--pl);border:1px solid var(--pm);color:var(--p);font-size:9px;font-weight:800;line-height:1;text-transform:none;letter-spacing:0;cursor:help;}
#cp-retention .ret-funding-settings .ret-info:focus{outline:none;box-shadow:0 0 0 2px rgba(123,82,204,0.18);}
#cp-retention .ret-funding-settings input{background:white;border:1px solid var(--border);border-radius:5px;padding:7px 8px;font-size:11px;color:#1C1B2E;width:100%;font-family:inherit;}
#cp-retention .ret-funding-settings input:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 2px rgba(123,82,204,0.15);}
#cp-retention .ret-funding-note{grid-column:1/-1;font-size:10px;line-height:1.5;color:#666;}
#cp-retention .how-it-works{font-size:11px;line-height:1.7;color:#444;}
#cp-retention .how-it-works strong{color:var(--p);}
#cp-retention .how-it-works em{color:#888;}
#cp-retention .ret-disclaimer{font-size:10px;color:#888;padding:8px 22px 14px;text-align:center;background:#FAFAFC;border-top:1px solid var(--border);}

/* Timeline cards */
#cp-retention .timeline-item{padding:6px 10px;background:#FAFAFC;border-left:3px solid var(--p);border-radius:4px;margin-bottom:4px;font-size:11px;color:#1C1B2E;}
#cp-retention .timeline-item.past{border-left-color:#9CA3AF;color:#888;}
#cp-retention .timeline-item.due{border-left-color:#F57C00;background:#FFF4E5;}

/* Mobile responsive — collapse row1 grid into wrapping flex below 720px */
@media (max-width: 720px) {
  #cp-retention .emp-row1{grid-template-columns:32px 1fr 32px;gap:8px;}
  #cp-retention .emp-row1 > div:nth-child(n+3):nth-child(-n+8){grid-column:2;display:flex;align-items:center;gap:6px;font-size:10px;}
  #cp-retention .emp-row1-hdr{display:none;}
  #cp-retention .emp-next{flex-wrap:wrap;}
  #cp-retention .ms-row{grid-template-columns:30px 1fr;gap:10px;}
  #cp-retention .ms-row > .ms-detail{grid-column:1/-1;}
}
