
/* macOS-like cards UI */
.ciae-macos.wrap{max-width:1100px;margin:24px auto;padding:0 8px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,Roboto,Arial,sans-serif}
.ciae-macos .banner{display:flex;gap:12px;align-items:center;border-radius:14px;padding:16px 18px;box-shadow:0 8px 24px rgba(16,24,40,.04);margin-bottom:14px}
.ciae-macos .banner.info{background:#eff6ff;border:1px solid #bfdbfe}
.ciae-macos .banner .icon{font-size:18px;line-height:1}
.banner-body{flex:1}
.banner-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.banner-top h3{margin:0;font-size:22px;letter-spacing:-.2px}
.ciae-topmeta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.ciae-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.85);border:1px solid rgba(191,219,254,.9);font-size:12px;white-space:nowrap}
.ciae-macos .banner p{margin:6px 0 0;color:#334155}
.ciae-macos .card.avance{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px 18px;box-shadow:0 10px 30px rgba(16,24,40,.06);margin-bottom:16px}
.avance-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.avance-pct{font-weight:800}
.ciae-progress{width:100%;height:10px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;overflow:hidden}
.ciae-progress-bar{height:100%;background:#3b82f6;width:0}
.ciae-mes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.mes-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:18px;box-shadow:0 10px 30px rgba(16,24,40,.06)}
.mes-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.mes-tit{font-weight:700;font-size:18px}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px}
.badge.ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.badge.due{background:#fffbeb;color:#92400e;border:1px solid #fde68a}
.badge.late{background:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}
.badge.pending{background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe}
.badge.future{background:#f0f9ff;color:#075985;border:1px solid #bae6fd}
.mes-amount{font-size:20px;font-weight:700;margin:10px 0;color:#111827}
.mes-sub{font-size:13px;color:#475569;margin-top:2px}
.mes-sub.ok{color:#065f46}
.mes-actions{margin-top:12px}
.ciae-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:12px;background:#111827;color:#fff;text-decoration:none;font-weight:700;font-size:13px;box-shadow:0 10px 20px rgba(16,24,40,.10)}
.ciae-btn:hover{filter:brightness(1.05)}

.mes-det{margin-top:12px;border-top:1px dashed #e5e7eb;padding-top:10px}
.mes-det summary{cursor:pointer;list-style:none;font-weight:700;color:#111827}
.mes-det summary::-webkit-details-marker{display:none}
.mes-det summary:after{content:'▾';float:right;opacity:.7}
.mes-det[open] summary:after{content:'▴'}
.mes-det-body{margin-top:10px;display:flex;flex-direction:column;gap:10px}
.det-row{border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;background:#f8fafc}
.det-main{font-weight:700;color:#0f172a}
.det-side{margin-top:6px;font-weight:800;color:#111827}
.det-link a{display:inline-block;margin-top:6px;font-size:12px;color:#2563eb;text-decoration:none}
.det-link a:hover{text-decoration:underline}
.muted{font-weight:600;color:#64748b}
.ciae-macos .callout{border-radius:14px;padding:14px 16px;margin:8px 0}
.ciae-macos .callout.warn{background:#fff7ed;border:1px solid #fed7aa}
.ciae-macos .callout.error{background:#fef2f2;border:1px solid #fecaca}

@media (max-width: 520px){
  .banner-top{flex-direction:column;align-items:flex-start}
  .ciae-topmeta{justify-content:flex-start}
}
