/* ============================================================
   CFA BADGES, STATUS INDICATORS & ALERTS
   Phase: Components > Badges & Alerts
   Requires: cfa-tokens.css loaded first

   COMPONENTS IN THIS FILE:
   1. .cfa-status       — platform status badge (P-06)
   2. .cfa-badge        — reference UI pill badge
   3. .cfa-chip         — bordered type label
   4. .cfa-tag          — solid uppercase tag
   5. .cfa-status-dot   — 8px inline dot indicator
   6. .cfa-alert        — alert banner (P-07 EC-02)
   7. .cfa-toast        — toast notification (EC-03)

   PHP ALIASES:
   - Raw KYC status text → .cfa-status.kyc-* (markup update required)
   - gray_btn "Funded"   → .cfa-status.funded (markup update required)
   - .error_msg block    → .cfa-alert.cfa-alert--error (markup update)
   - Laminas flash msgs  → .cfa-alert variants (layout.phtml update required)

   NOTE: Badges and alerts are NEW components with no current PHP
   equivalent, so no CSS aliases are needed — only new markup.
   PHP template updates are tracked as follow-up tasks.
   ============================================================ */


/* ================================================================
   1. STATUS BADGE  (.cfa-status)
   Platform-specific badge for entity status values.
   Defined in EC-01 (EXTENDED_COMPONENT_LIBRARY.md).
   ================================================================ */

.cfa-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);         /* 13px */
  font-weight: var(--cfa-weight-bold);
  letter-spacing: var(--cfa-tracking-wide); /* 0.02em — mixed case, not uppercase */
  padding: 4px 10px;
  border-radius: var(--cfa-radius-full);
  white-space: nowrap;
  line-height: 1.4;
}

/* Status dot — auto-generated before each badge */
.cfa-status::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: var(--cfa-radius-circle);
  flex-shrink: 0;
}

/* ── Status variants ── */

/* Active — green */
.cfa-status.active {
  background: var(--cfa-green-pale);
  color: var(--cfa-green);
}
.cfa-status.active::before { background: var(--cfa-green); }

/* Funded — cobalt */
.cfa-status.funded {
  background: var(--cfa-cobalt-pale);
  color: var(--cfa-cobalt);
}
.cfa-status.funded::before { background: var(--cfa-cobalt); }

/* Pending — amber */
.cfa-status.pending,
.cfa-status.kyc-pending,
.cfa-status.restricted {
  background: var(--cfa-amber-pale);
  color: var(--cfa-amber);
}
.cfa-status.pending::before,
.cfa-status.kyc-pending::before,
.cfa-status.restricted::before { background: var(--cfa-amber); }

/* Closed / Draft — grey neutral */
.cfa-status.closed,
.cfa-status.draft {
  background: var(--cfa-bg-soft);
  color: var(--cfa-text-muted);
}
.cfa-status.closed::before,
.cfa-status.draft::before { background: var(--cfa-border-strong); }

/* Suspended / KYC Failed — red */
.cfa-status.suspended,
.cfa-status.kyc-failed {
  background: var(--cfa-red-pale);
  color: var(--cfa-red);
}
.cfa-status.suspended::before,
.cfa-status.kyc-failed::before { background: var(--cfa-red); }

/* KYC Verified — green */
.cfa-status.kyc-verified {
  background: var(--cfa-green-pale);
  color: var(--cfa-green);
}
.cfa-status.kyc-verified::before { background: var(--cfa-green); }

/* ── No dot variant ── */
.cfa-status.no-dot::before { display: none; }

/* ── Outlined variant ── */
.cfa-status--outline {
  background: transparent;
  border: 1.5px solid currentColor;
  opacity: 0.85;
}


/* ================================================================
   2. BADGE  (.cfa-badge)
   Pill-shaped label from reference UI — marketing/pitch context.
   ================================================================ */

.cfa-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--cfa-space-2);
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);         /* 13px */
  font-weight: var(--cfa-weight-bold);
  letter-spacing: var(--cfa-tracking-wide);
  padding: 5px 12px;
  border-radius: var(--cfa-radius-full);
  white-space: nowrap;
  line-height: 1;
}

.cfa-badge--cobalt {
  background: var(--cfa-cobalt-pale);
  color: var(--cfa-cobalt);
}
.cfa-badge--amber {
  background: var(--cfa-amber-pale);
  color: var(--cfa-amber);
}
.cfa-badge--green {
  background: var(--cfa-green-pale);
  color: var(--cfa-green);
}
.cfa-badge--red {
  background: var(--cfa-red-pale);
  color: var(--cfa-red);
}
.cfa-badge--dark {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--cfa-on-dark-border);
  color: var(--cfa-on-dark-mid);
}

/* Badge dot */
.cfa-badge-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cfa-badge--cobalt .cfa-badge-dot { background: var(--cfa-cobalt); }
.cfa-badge--amber  .cfa-badge-dot { background: var(--cfa-amber); }
.cfa-badge--green  .cfa-badge-dot { background: var(--cfa-green); }


/* ================================================================
   3. CHIP  (.cfa-chip)
   Bordered type label — used in pitch cards.
   ================================================================ */

.cfa-chip {
  display: inline-flex;
  align-items: center;
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);         /* 13px */
  font-weight: var(--cfa-weight-bold);
  letter-spacing: var(--cfa-tracking-wider);
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: var(--cfa-radius-full);
  white-space: nowrap;
  line-height: 1;
}
.cfa-chip--cobalt {
  background: var(--cfa-cobalt-pale);
  color: var(--cfa-cobalt);
  border: 1.5px solid rgba(36, 81, 209, 0.30);
}
.cfa-chip--amber {
  background: var(--cfa-amber-pale);
  color: var(--cfa-amber);
  border: 1.5px solid var(--cfa-amber-border);
}


/* ================================================================
   4. TAG  (.cfa-tag)
   Solid uppercase pill — used for investment type labels.
   ================================================================ */

.cfa-tag {
  display: inline-block;
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);
  font-weight: var(--cfa-weight-bold);
  letter-spacing: var(--cfa-tracking-wider);
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: var(--cfa-radius-full);
  white-space: nowrap;
  line-height: 1;
}
.cfa-tag--cobalt { background: var(--cfa-cobalt); color: white; }
.cfa-tag--amber  { background: var(--cfa-amber);  color: white; }
.cfa-tag--green  { background: var(--cfa-green);  color: white; }
.cfa-tag--red    { background: var(--cfa-red);    color: white; }
.cfa-tag--grey   {
  background: var(--cfa-bg-soft);
  color: var(--cfa-text-muted);
  border: 1px solid var(--cfa-border);
}


/* ================================================================
   5. STATUS DOT  (.cfa-status-dot)
   Inline 8px dot for table cells and nav items.
   ================================================================ */

.cfa-status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cfa-border-strong);
  flex-shrink: 0;
}
.cfa-status-dot--active  { background: var(--cfa-green); }
.cfa-status-dot--pending { background: var(--cfa-amber); }
.cfa-status-dot--error   { background: var(--cfa-red); }
.cfa-status-dot--info    { background: var(--cfa-cobalt); }


/* ================================================================
   6. ALERT BANNER  (.cfa-alert)
   Defined in EC-02. Replaces ad-hoc .error_msg blocks and
   future Laminas flash message rendering.
   ================================================================ */

.cfa-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--cfa-space-3);
  padding: var(--cfa-space-4) var(--cfa-space-5);
  border-radius: var(--cfa-radius-md);
  border: 1.5px solid transparent;
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-base);
  line-height: var(--cfa-leading-normal);
  margin-bottom: var(--cfa-space-5);
}

/* ── Alert variants ── */

.cfa-alert--success {
  background: var(--cfa-green-pale);
  border-color: rgba(5, 150, 105, 0.30);
  color: #065F46;
}
.cfa-alert--error {
  background: var(--cfa-red-pale);
  border-color: rgba(220, 38, 38, 0.30);
  color: #991B1B;
}
.cfa-alert--warning {
  background: var(--cfa-amber-pale);
  border-color: var(--cfa-amber-border);
  color: #92400E;
}
.cfa-alert--info {
  background: var(--cfa-cobalt-pale);
  border-color: var(--cfa-cobalt-border);
  color: var(--cfa-navy);
}

/* ── Alert sub-elements ── */

.cfa-alert-icon {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-base);
  font-weight: var(--cfa-weight-bold);
  flex-shrink: 0;
  margin-top: 2px;
  line-height: 1.4;
}

.cfa-alert-body {
  flex: 1;
  min-width: 0;
}

.cfa-alert-body strong {
  font-weight: var(--cfa-weight-semibold);
}

.cfa-alert-body p {
  margin: 0;
  font-family: var(--cfa-font-body);
}

.cfa-alert-body p + p {
  margin-top: var(--cfa-space-2);
}

.cfa-alert-body ul {
  margin: var(--cfa-space-2) 0 0;
  padding-left: var(--cfa-space-5);
  list-style: disc;
}

.cfa-alert-close {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 18px;
  color: inherit;
  opacity: 0.6;
  flex-shrink: 0;
  line-height: 1;
  padding: 0;
  margin-left: var(--cfa-space-2);
  transition: opacity var(--cfa-transition-fast);
}

.cfa-alert-close:hover { opacity: 1; }

/* ── Dismissing animation ── */
.cfa-alert.is-dismissing {
  animation: cfa-alert-out 0.2s ease forwards;
}

@keyframes cfa-alert-out {
  to { opacity: 0; transform: translateY(-4px); }
}

/* ── Compact (no left padding spacing) variant ── */
.cfa-alert--compact {
  padding: var(--cfa-space-3) var(--cfa-space-4);
  font-size: var(--cfa-text-sm);
  border-radius: var(--cfa-radius-sm);
}

/* ── Full-width banner variant (top-of-page) ── */
.cfa-alert--banner {
  border-radius: 0;
  border-left: none;
  border-right: none;
  margin-bottom: 0;
}


/* ================================================================
   7. TOAST NOTIFICATION  (.cfa-toast)
   Defined in EC-03. Fixed-position, JS-driven.
   Initialized by cfa-ui.js (CFA.toast(message, type)).
   ================================================================ */

.cfa-toast-container {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: var(--cfa-z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-3);
  max-width: 360px;
  pointer-events: none;
}

.cfa-toast {
  display: flex;
  align-items: center;
  gap: var(--cfa-space-3);
  padding: var(--cfa-space-4) var(--cfa-space-5);
  border-radius: var(--cfa-radius-md);
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1.5px solid var(--cfa-border);
  box-shadow: var(--cfa-shadow-overlay);
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-sm);
  pointer-events: auto;
  animation: cfa-toast-in 0.2s ease;
}

@keyframes cfa-toast-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: none; }
}

.cfa-toast.is-dismissing {
  animation: cfa-toast-out 0.2s ease forwards;
}

@keyframes cfa-toast-out {
  to { opacity: 0; transform: translateX(20px); }
}

/* Colour-coded left border per type */
.cfa-toast--success { border-left: 3px solid var(--cfa-green); }
.cfa-toast--error   { border-left: 3px solid var(--cfa-red); }
.cfa-toast--warning { border-left: 3px solid var(--cfa-amber); }
.cfa-toast--info    { border-left: 3px solid var(--cfa-cobalt); }

.cfa-toast-icon {
  font-size: var(--cfa-text-base);
  font-weight: var(--cfa-weight-bold);
  flex-shrink: 0;
  line-height: 1;
}

.cfa-toast-msg {
  flex: 1;
  color: var(--cfa-text-mid);
  line-height: 1.5;
}

.cfa-toast-close {
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--cfa-text-muted);
  font-size: 16px;
  padding: 0;
  line-height: 1;
  opacity: 0.7;
  transition: opacity var(--cfa-transition-fast);
}
.cfa-toast-close:hover { opacity: 1; }


/* ================================================================
   RESPONSIVE ADJUSTMENTS
   ================================================================ */

@media (max-width: 600px) {
  .cfa-toast-container {
    top: auto;
    bottom: 16px;
    right: 16px;
    left: 16px;
    max-width: none;
  }
}
