/* ============================================================
   CFA CARDS
   Phase: Components > Cards
   Requires: cfa-tokens.css loaded first

   COMPONENTS IN THIS FILE:
   1. .cfa-card          — base glass card (cobalt tint)
   2. .cfa-card--amber   — amber glass variant
   3. .cfa-card--dark    — dark glass variant (navy surfaces)
   4. .cfa-card--flat    — white flat card (most PHP contexts)
   5. .cfa-card--static  — no hover lift
   6. Card sub-elements  — body, header, title, desc, img, topbar, metrics
   7. .cfa-pitch-card    — pitch listing card (EC-14)
   8. .cfa-progress      — funding progress bar (P-10)
   9. .cfa-metric        — stat metric display
   10. .cfa-stat-card    — summary stat card
   11. .cfa-feature-card — large feature/highlight card

   PHP ALIASES (CSS-only coexistence — no template changes required):
   - .admin-panel-box-container → .cfa-card--flat
   - .admin-panel-box-top       → suppressed (sprite decoration)
   - .admin-panel-box-bot       → suppressed (sprite decoration)
   - .admin-panel-box-content   → card body styles
   - .myaccount-box-top-title   → card header styles
   - .myaccount-box-top         → suppressed (sprite decoration)
   - .myaccount-box-bot         → suppressed (sprite decoration)
   - .myaccount-box-content     → card body styles
   - .pitch-list                → .cfa-pitch-card base styles
   ============================================================ */


/* ================================================================
   1. BASE CARD  (.cfa-card)
   Glass morphism — cobalt tint. Used on light backgrounds.
   ================================================================ */

.cfa-card {
  background: var(--cfa-glass-cobalt-bg);
  backdrop-filter: var(--cfa-glass-blur);
  -webkit-backdrop-filter: var(--cfa-glass-blur);
  border: 1.5px solid var(--cfa-glass-cobalt-border);
  border-radius: var(--cfa-radius-xl);
  overflow: hidden;
  box-shadow: var(--cfa-glass-cobalt-shadow), var(--cfa-glass-inset);
  transition: box-shadow var(--cfa-transition-slow),
              transform var(--cfa-transition-slow),
              border-color var(--cfa-transition-slow);
}

.cfa-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cfa-glass-cobalt-shadow-hover), var(--cfa-glass-inset);
  border-color: var(--cfa-glass-cobalt-border-hover);
}


/* ── Amber glass variant ── */
.cfa-card--amber {
  background: var(--cfa-glass-amber-bg);
  border-color: var(--cfa-glass-amber-border);
  box-shadow: var(--cfa-glass-amber-shadow), var(--cfa-glass-inset);
}

.cfa-card--amber:hover {
  box-shadow: var(--cfa-glass-amber-shadow-hover), var(--cfa-glass-inset);
  border-color: var(--cfa-glass-amber-border-hover);
}


/* ── Dark glass variant (navy surface) ── */
.cfa-card--dark {
  background: var(--cfa-glass-dark-bg);
  border: 1.5px solid var(--cfa-glass-dark-border);
  box-shadow: var(--cfa-glass-dark-shadow), var(--cfa-glass-dark-inset);
}

.cfa-card--dark:hover {
  box-shadow: var(--cfa-glass-dark-shadow), var(--cfa-glass-dark-inset);
  border-color: rgba(255, 255, 255, 0.40);
}


/* ── Flat card (white, no glass) ── */
.cfa-card--flat,
.admin-panel-box-container {
  background: var(--cfa-bg) !important;
  border: 1px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-lg) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
  overflow: hidden;
  transition: box-shadow var(--cfa-transition-normal),
              border-color var(--cfa-transition-normal);
  /* Reset legacy fixed width */
  width: auto !important;
  margin: 0 !important;
}

.cfa-card--flat:hover,
.admin-panel-box-container:hover {
  box-shadow: var(--cfa-shadow-sm) !important;
  border-color: var(--cfa-border-strong) !important;
}


/* ── No-hover-lift variant ── */
.cfa-card--static,
.cfa-card--static:hover {
  transform: none !important;
  transition: box-shadow var(--cfa-transition-fast);
}


/* ── Selected state ── */
.cfa-card.is-selected,
.cfa-card.selected,
.cfa-pitch-card.is-selected,
.cfa-pitch-card.selected {
  border-color: var(--cfa-cobalt) !important;
  background: var(--cfa-cobalt-pale) !important;
}

/* ── Disabled / closed card state ── */
.cfa-card.disabled,
.cfa-card.closed,
.cfa-card[aria-disabled="true"] {
  opacity: 0.65;
  cursor: default;
  pointer-events: none;
}

.cfa-card.disabled:hover,
.cfa-card.closed:hover {
  transform: none !important;
  box-shadow: var(--cfa-glass-cobalt-shadow), var(--cfa-glass-inset) !important;
  border-color: var(--cfa-glass-cobalt-border) !important;
}


/* ================================================================
   2. CARD SUB-ELEMENTS
   ================================================================ */

/* ── Top accent bar ── */
.cfa-card-topbar {
  height: 4px;
  background: var(--cfa-cobalt);
  flex-shrink: 0;
}

.cfa-card--amber .cfa-card-topbar { background: var(--cfa-amber); }
.cfa-card--dark  .cfa-card-topbar { background: var(--cfa-on-dark-mid); }


/* ── Card image ── */
.cfa-card-img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}


/* ── Card body ── */
.cfa-card-body,
.admin-panel-box-content,
.myaccount-box-content {
  padding: 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
  /* Reset sprite backgrounds */
  background-image: none !important;
  background: var(--cfa-bg) !important;
  width: auto !important;
}


/* ── Card header ── */
.cfa-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--cfa-space-3);
  margin-bottom: var(--cfa-space-4);
}


/* ── Card title ── */
.cfa-card-title {
  font-family: var(--cfa-font-body);
  font-weight: var(--cfa-weight-extrabold);
  font-size: var(--cfa-text-2xl);
  color: var(--cfa-text);
  margin: 0 0 var(--cfa-space-2);
  line-height: var(--cfa-leading-heading);
}

.cfa-card--dark .cfa-card-title { color: var(--cfa-on-dark); }


/* ── Card description ── */
.cfa-card-desc {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-base);
  color: var(--cfa-text-muted);
  line-height: var(--cfa-leading-normal);
  margin: 0 0 var(--cfa-space-5);
  flex: 1;
}

.cfa-card--dark .cfa-card-desc { color: var(--cfa-on-dark-muted); }


/* ── Card footer ── */
.cfa-card-footer {
  padding: var(--cfa-space-5) 28px 28px;
  border-top: 1px solid var(--cfa-border);
  display: flex;
  align-items: center;
  gap: var(--cfa-space-3);
}

.cfa-card--dark .cfa-card-footer {
  border-top-color: var(--cfa-on-dark-border);
}


/* ── Metrics grid ── */
.cfa-card-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--cfa-space-3);
  padding-top: var(--cfa-space-5);
  border-top: 1px solid var(--cfa-border);
  margin-top: auto;
}

.cfa-card--dark .cfa-card-metrics { border-top-color: var(--cfa-on-dark-border); }


/* ── Suppress old sprite decorations ── */
.admin-panel-box-top,
.admin-panel-box-bot,
.myaccount-box-top,
.myaccount-box-bot,
.myaccount-box-top-title {
  display: none !important;
}


/* ================================================================
   3. METRIC  (.cfa-metric)
   Stat display used inside cards and standalone.
   ================================================================ */

.cfa-metric {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.cfa-metric-lbl {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);
  font-weight: var(--cfa-weight-semibold);
  color: var(--cfa-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--cfa-tracking-wider);
}

.cfa-metric-val {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-lg);
  font-weight: var(--cfa-weight-bold);
  color: var(--cfa-text);
  line-height: 1.2;
}

.cfa-card--dark .cfa-metric-lbl { color: var(--cfa-on-dark-muted); }
.cfa-card--dark .cfa-metric-val  { color: var(--cfa-on-dark); }


/* ================================================================
   4. STAT CARD  (.cfa-stat-card)
   Dashboard summary stats — single value + label.
   ================================================================ */

.cfa-stat-card {
  background: var(--cfa-bg);
  border: 1px solid var(--cfa-border);
  border-radius: var(--cfa-radius-lg);
  padding: var(--cfa-space-6) var(--cfa-space-6) var(--cfa-space-5);
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-2);
  box-shadow: var(--cfa-shadow-sm);
  transition: box-shadow var(--cfa-transition-normal),
              border-color var(--cfa-transition-normal);
}

.cfa-stat-card:hover {
  box-shadow: var(--cfa-shadow-md);
  border-color: var(--cfa-cobalt-border);
}

.cfa-stat-card-label {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xs);
  font-weight: var(--cfa-weight-semibold);
  color: var(--cfa-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--cfa-tracking-wider);
}

.cfa-stat-card-value {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-4xl);
  font-weight: var(--cfa-weight-black);
  color: var(--cfa-text);
  line-height: 1;
  letter-spacing: var(--cfa-tracking-tight);
}

.cfa-stat-card-sub {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-sm);
  color: var(--cfa-text-muted);
}

/* Accent bar on top */
.cfa-stat-card--cobalt { border-top: 3px solid var(--cfa-cobalt); }
.cfa-stat-card--amber  { border-top: 3px solid var(--cfa-amber); }
.cfa-stat-card--green  { border-top: 3px solid var(--cfa-green); }
.cfa-stat-card--red    { border-top: 3px solid var(--cfa-red); }


/* ================================================================
   5. PITCH CARD  (.cfa-pitch-card)
   EC-14. Pitch listing card — flat surface, structured layout.
   PHP alias: .pitch-list (CSS-only base styles)
   ================================================================ */

.cfa-pitch-card,
.pitch-list {
  display: flex;
  flex-direction: column;
  background: var(--cfa-bg);
  border: 1px solid var(--cfa-border);
  border-radius: var(--cfa-radius-xl);
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  transition: box-shadow var(--cfa-transition-slow),
              transform var(--cfa-transition-slow);
  /* Reset legacy fixed dimensions */
  width: auto !important;
  height: auto !important;
  float: none !important;
  margin: 0 !important;
}

.cfa-pitch-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--cfa-shadow-md);
}

/* Funded / closed — muted, no lift */
.cfa-pitch-card.funded,
.cfa-pitch-card.closed {
  opacity: 0.75;
}

.cfa-pitch-card.funded:hover,
.cfa-pitch-card.closed:hover {
  transform: none;
  box-shadow: none;
}


/* ── Pitch card header ── */
.cfa-pitch-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 20px 20px 0;
  gap: var(--cfa-space-3);
}

/* ── Company logo ── */
.cfa-pitch-card-logo {
  width: 56px;
  height: 56px;
  object-fit: contain;
  border-radius: var(--cfa-radius-sm);
  border: 1px solid var(--cfa-border);
  background: var(--cfa-bg);
  flex-shrink: 0;
}

/* ── Pitch card badges ── */
.cfa-pitch-card-badges {
  display: flex;
  align-items: center;
  gap: var(--cfa-space-2);
  flex-wrap: wrap;
  justify-content: flex-end;
}


/* ── Pitch card body ── */
.cfa-pitch-card-body {
  padding: 16px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-4);
}

.cfa-pitch-card-title {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xl);
  font-weight: var(--cfa-weight-black);
  color: var(--cfa-text);
  margin: 0;
  line-height: var(--cfa-leading-heading);
}

.cfa-pitch-card-desc {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-sm);
  color: var(--cfa-text-muted);
  line-height: var(--cfa-leading-normal);
  flex: 1;
  margin: 0;
}


/* ── Progress section ── */
.cfa-pitch-card-progress {
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-3);
}

.cfa-pitch-card-meta {
  display: flex;
  gap: var(--cfa-space-5);
  flex-wrap: wrap;
}

.cfa-pitch-card-meta .cfa-metric-val {
  font-size: var(--cfa-text-base);
}

.cfa-pitch-card-meta .cfa-metric-lbl {
  font-size: 11px;
}


/* ── Pitch card footer ── */
.cfa-pitch-card-footer {
  padding: 16px 20px 20px;
}

.cfa-pitch-card-footer .cfa-btn-primary,
.cfa-pitch-card-footer .blue_btn {
  width: 100%;
  justify-content: center;
  text-align: center;
}


/* ================================================================
   6. PROGRESS BAR  (.cfa-progress)
   P-10. Used inside pitch cards and inline contexts.
   ================================================================ */

.cfa-progress {
  width: 100%;
  height: 8px;
  background: var(--cfa-border);
  border-radius: var(--cfa-radius-full);
  overflow: hidden;
}

.cfa-progress--mini {
  height: 5px;
}

.cfa-progress--lg {
  height: 12px;
}

.cfa-progress-bar {
  height: 100%;
  background: var(--cfa-cobalt);
  border-radius: var(--cfa-radius-full);
  transition: width 0.4s ease;
  min-width: 2px;
}

.cfa-progress--active   .cfa-progress-bar { background: var(--cfa-cobalt); }
.cfa-progress--overfunded .cfa-progress-bar { background: var(--cfa-green); }
.cfa-progress--amber    .cfa-progress-bar { background: var(--cfa-amber); }


/* ================================================================
   7. FEATURE CARD  (.cfa-feature-card)
   Large two-tone highlight card — marketing/pitch context.
   ================================================================ */

.cfa-feature-card {
  border-radius: var(--cfa-radius-3xl);
  overflow: hidden;
  position: relative;
  transition: box-shadow var(--cfa-transition-normal);
}

.cfa-feature-card:hover {
  box-shadow: var(--cfa-shadow-lg);
}

.cfa-feature-card--cobalt {
  background: var(--cfa-glass-cobalt-bg);
  border: 1.5px solid var(--cfa-glass-cobalt-border);
}

.cfa-feature-card--amber {
  background: var(--cfa-glass-amber-bg);
  border: 1.5px solid var(--cfa-glass-amber-border);
}

.cfa-feature-card-img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
}

.cfa-feature-card-content {
  padding: 44px 40px;
  position: relative;
}

/* Large decorative step number */
.cfa-feature-step {
  font-family: var(--cfa-font-body);
  font-size: 90px;
  font-weight: var(--cfa-weight-black);
  line-height: 1;
  opacity: 0.08;
  position: absolute;
  top: 20px;
  right: 28px;
  pointer-events: none;
  user-select: none;
}


/* ================================================================
   RESPONSIVE ADJUSTMENTS
   ================================================================ */

@media (max-width: 920px) {
  .cfa-card-body,
  .admin-panel-box-content,
  .myaccount-box-content {
    padding: 20px;
  }

  .cfa-feature-card-content {
    padding: 28px 24px;
  }
}

@media (max-width: 600px) {
  .cfa-card-body,
  .admin-panel-box-content,
  .myaccount-box-content {
    padding: 16px;
  }

  .cfa-pitch-card-header  { padding: 16px 16px 0; }
  .cfa-pitch-card-body    { padding: 12px 16px; }
  .cfa-pitch-card-footer  { padding: 12px 16px 16px; }

  .cfa-stat-card-value {
    font-size: var(--cfa-text-3xl);
  }

  .cfa-card-metrics {
    grid-template-columns: repeat(2, 1fr);
  }
}
