/* =============================================
   FUNNELS — Liste, éditeur, analytics, public
   ============================================= */

/* ── Liste ── */
.funnels-grid { display: flex; flex-direction: column; gap: var(--space-md); }

.funnel-card {
  display: flex; align-items: center; gap: var(--space-md);
  background: var(--bg-surface); border-radius: var(--border-radius-lg);
  padding: var(--space-lg); box-shadow: var(--shadow-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  text-decoration: none; color: inherit;
}
.funnel-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: inherit; }
.funnel-card__info { flex: 1; min-width: 0; }
.funnel-card__title { font-weight: var(--font-weight-semibold); margin-bottom: 2px; }
.funnel-card__meta { font-size: var(--font-size-xs); color: var(--text-muted); display: flex; align-items: center; gap: var(--space-xs); flex-wrap: wrap; }

/* ── Éditeur layout ── */
.funnel-editor { display: flex; flex-direction: column; min-height: calc(100dvh - var(--nav-height)); }

.funnel-editor__toolbar {
  position: sticky; top: var(--nav-height); z-index: 50;
  background: var(--bg-surface); border-bottom: 1px solid var(--border-color);
  padding: var(--space-sm) var(--space-md);
  display: flex; align-items: center; gap: var(--space-sm); overflow-x: auto;
}
.funnel-editor__title {
  flex: 1; font-weight: var(--font-weight-semibold); font-size: var(--font-size-sm);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0;
}
.funnel-editor__canvas { flex: 1; padding: var(--space-xl) var(--space-md); overflow-y: auto; }

/* ── Flow vertical ── */
.funnel-flow {
  display: flex; flex-direction: column; align-items: center;
  max-width: 480px; margin: 0 auto;
}

/* Step card */
.funnel-step-card {
  width: 100%; background: var(--bg-surface);
  border: 2px solid var(--border-color); border-radius: var(--border-radius-lg);
  overflow: hidden; transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.funnel-step-card:hover { border-color: var(--color-primary-light, var(--color-primary)); box-shadow: var(--shadow-md); }

.funnel-step-card__header {
  display: flex; align-items: center; gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-base); border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
}
.funnel-step-card__header > i { font-size: 1.2rem; color: var(--color-primary); }
.funnel-step-card__type { font-weight: var(--font-weight-semibold); flex: 1; }

.funnel-step-card__actions {
  display: flex; gap: 2px; opacity: 0; transition: opacity var(--transition-fast);
}
.funnel-step-card:hover .funnel-step-card__actions { opacity: 1; }

.funnel-step-card__body { padding: var(--space-md); }
.funnel-step-card__page {
  font-size: var(--font-size-sm); display: flex; align-items: center; gap: var(--space-xs);
}
.funnel-step-card__page i { color: var(--color-primary); }
.funnel-step-card__price { font-size: var(--font-size-xs); color: var(--text-muted); margin-top: var(--space-xs); }

/* ── Flèches CSS ── */
.funnel-arrow {
  width: 2px; height: 32px; background: var(--border-color);
  position: relative; margin: 0 auto;
}
.funnel-arrow::after {
  content: ''; position: absolute; bottom: -4px; left: 50%; transform: translateX(-50%);
  border-left: 6px solid transparent; border-right: 6px solid transparent;
  border-top: 6px solid var(--border-color);
}

.funnel-arrow--accept { background: var(--color-success); }
.funnel-arrow--accept::after { border-top-color: var(--color-success); }
.funnel-arrow--decline { background: var(--color-error); }
.funnel-arrow--decline::after { border-top-color: var(--color-error); }

/* ── Branchement upsell ── */
.funnel-branch {
  display: flex; justify-content: center; gap: var(--space-xl);
  padding: var(--space-xs) 0; width: 100%;
}
.funnel-branch__accept, .funnel-branch__decline {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.funnel-branch__label {
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  padding: 2px var(--space-xs); border-radius: var(--border-radius-sm);
}
.funnel-branch__label--accept { color: var(--color-success); background: rgba(0, 184, 148, 0.1); }
.funnel-branch__label--decline { color: var(--color-error); background: rgba(225, 112, 85, 0.1); }

/* ── Analytics chart ── */
.funnel-chart { margin-bottom: var(--space-xl); }
.funnel-chart__step { margin-bottom: var(--space-md); }
.funnel-chart__label {
  display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--space-xs);
}
.funnel-chart__step-name { font-weight: var(--font-weight-semibold); font-size: var(--font-size-sm); }
.funnel-chart__step-stats { font-size: var(--font-size-xs); color: var(--text-muted); }
.funnel-chart__bar-bg {
  height: 32px; background: var(--bg-base); border-radius: var(--border-radius-sm); overflow: hidden;
}
.funnel-chart__bar {
  height: 100%; background: var(--color-primary); border-radius: var(--border-radius-sm);
  transition: width 0.6s ease; min-width: 4%;
}

/* ── Public funnel actions ── */
.lp-funnel-actions { padding: var(--space-xl) 0; }
.lp-checkout-box {
  background: var(--bg-surface, #fff); border-radius: var(--border-radius-lg);
  padding: var(--space-xl); box-shadow: var(--shadow-md); text-align: center;
}

/* ── Step type palette ── */
.funnel-type-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-sm);
}
.funnel-type-card {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-xs);
  padding: var(--space-md); border-radius: var(--border-radius-md);
  background: var(--bg-base); border: 2px solid transparent; cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
  text-align: center; font-size: var(--font-size-sm);
}
.funnel-type-card:hover { border-color: var(--color-primary); background: var(--bg-surface); }
.funnel-type-card i { font-size: 1.5rem; color: var(--color-primary); }

/* ── Responsive ── */
@media (min-width: 768px) {
  .funnels-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-lg); }
  .funnel-flow { max-width: 520px; }
  .funnel-type-grid { grid-template-columns: repeat(3, 1fr); }
}
