/* =============================================
   EMAILING — Contacts, templates, campagnes
   ============================================= */

/* ── Contacts ── */
.contacts-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
  margin-bottom: var(--space-lg);
}

.contacts-toolbar__search {
  flex: 1;
  min-width: 180px;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  background: var(--bg-surface);
  color: var(--text-primary);
}
.contacts-toolbar__search:focus { outline: none; border-color: var(--color-primary); }

.contacts-toolbar__filter {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  background: var(--bg-surface);
  color: var(--text-primary);
}

.contacts-table {
  width: 100%;
  border-collapse: collapse;
}

.contacts-table th {
  text-align: left;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 2px solid var(--border-color);
}

.contacts-table td {
  padding: var(--space-sm);
  border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
  vertical-align: middle;
}

.contacts-table tr:hover td {
  background: rgba(108, 92, 231, 0.03);
}

.contacts-table__email { font-weight: var(--font-weight-medium); }
.contacts-table__source {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  background: var(--bg-base);
  padding: 2px 6px;
  border-radius: var(--border-radius-sm);
}

.contacts-table__actions {
  display: flex;
  gap: 2px;
  opacity: 0;
  transition: opacity var(--transition-fast);
}
.contacts-table tr:hover .contacts-table__actions { opacity: 1; }

/* ── Tag badges ── */
.tag-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  padding: 2px 8px;
  border-radius: 99px;
  white-space: nowrap;
}

.tag-badge__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.tags-inline { display: flex; flex-wrap: wrap; gap: 4px; }

/* ── Tag picker (modal multi-select) ── */
.tag-picker {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.tag-picker__item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  transition: background var(--transition-fast);
}
.tag-picker__item:hover { background: var(--bg-base); }

.tag-picker__item input[type="checkbox"] { accent-color: var(--color-primary); }

/* ── Email editor ── */
.em-editor {
  display: flex;
  flex-direction: column;
  min-height: calc(100dvh - var(--nav-height));
}

.em-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;
}

.em-toolbar__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;
}

.em-fields {
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
  padding: var(--space-md);
}

.em-fields .form__group { margin-bottom: var(--space-md); }

.em-segment-btn {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border: 1px dashed var(--border-color);
  border-radius: var(--border-radius-md);
  background: var(--bg-base);
  cursor: pointer;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  width: 100%;
  transition: border-color var(--transition-fast);
}
.em-segment-btn:hover { border-color: var(--color-primary); }
.em-segment-btn i { color: var(--color-primary); }

/* Email preview (simulated email client) */
.em-preview {
  background: var(--bg-base);
  padding: var(--space-md);
  border-radius: var(--border-radius-lg);
  margin-top: var(--space-md);
}

.em-preview__frame {
  max-width: 640px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: var(--border-radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  min-height: 200px;
}

.em-preview__frame iframe {
  width: 100%;
  border: none;
  min-height: 400px;
}

/* Email block editor (subset of page builder) */
.em-canvas {
  flex: 1;
  padding: var(--space-md);
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
}

.em-canvas--empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  color: var(--text-muted);
  text-align: center;
  gap: var(--space-md);
}
.em-canvas--empty i { font-size: 3rem; }

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

.campaign-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;
}
.campaign-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: inherit; }

.campaign-card__info { flex: 1; min-width: 0; }
.campaign-card__title { font-weight: var(--font-weight-semibold); margin-bottom: 2px; }
.campaign-card__meta {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

/* Campaign status badges */
.campaign-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  padding: 2px 8px;
  border-radius: 99px;
}
.campaign-status--draft { color: var(--text-muted); background: var(--bg-base); }
.campaign-status--scheduled { color: #0984e3; background: rgba(9, 132, 227, 0.1); }
.campaign-status--sending { color: #e17055; background: rgba(225, 112, 85, 0.1); }
.campaign-status--sent { color: #00b894; background: rgba(0, 184, 148, 0.1); }
.campaign-status--cancelled { color: #d63031; background: rgba(214, 48, 49, 0.1); }

/* Campaign mini stats */
.campaign-card__stats {
  display: flex;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}
.campaign-card__stat { display: flex; align-items: center; gap: 4px; }
.campaign-card__stat i { font-size: 0.9rem; }

/* ── Campaign stats detail ── */
.campaign-sends {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.campaign-send-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm);
  border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
}

.campaign-send-row__email { flex: 1; min-width: 0; font-weight: var(--font-weight-medium); }
.campaign-send-row__status { flex-shrink: 0; }
.campaign-send-row__time { flex-shrink: 0; color: var(--text-muted); font-size: var(--font-size-xs); }

/* ── Segment picker modal ── */
.segment-picker { display: flex; flex-direction: column; gap: var(--space-md); }

.segment-picker__section-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
}

.segment-picker__match {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
}

.segment-picker__match label {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-size-sm);
  cursor: pointer;
}

.segment-picker__count {
  text-align: center;
  padding: var(--space-sm);
  background: var(--bg-base);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
}

/* ── Import CSV modal ── */
.csv-preview-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-xs);
  margin-top: var(--space-sm);
}
.csv-preview-table th,
.csv-preview-table td {
  padding: var(--space-xs);
  border: 1px solid var(--border-color);
  text-align: left;
}
.csv-preview-table th {
  background: var(--bg-base);
  font-weight: var(--font-weight-semibold);
}

/* =============================================
   SÉQUENCES (EVO-11)
   ============================================= */

/* ── Sub-nav Campagnes / Séquences ── */
.seq-subnav {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
  border-bottom: 2px solid var(--border-color);
}

.seq-subnav__link {
  display: inline-block;
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.seq-subnav__link:hover { color: var(--text-primary); }
.seq-subnav__link--active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

/* ── Grid liste séquences ── */
.seq-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.seq-card {
  display: block;
  background: var(--bg-surface);
  border-radius: var(--border-radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: inherit;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.seq-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: inherit; }

.seq-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
}

.seq-card__title {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.seq-card__meta {
  display: flex;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}
.seq-card__meta i { margin-right: 2px; }

.seq-card__date {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}

/* ── Éditeur séquence (header) ── */
.seq-editor-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-bottom: var(--space-lg);
}

.seq-title-input {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--text-primary);
  padding: var(--space-xs) 0;
  width: 100%;
  max-width: 400px;
  transition: border-color var(--transition-fast);
}
.seq-title-input:focus { outline: none; border-bottom-color: var(--color-primary); }
.seq-title-input:disabled { opacity: 0.7; cursor: default; }

.seq-editor-badges {
  display: flex;
  gap: var(--space-xs);
  align-items: center;
  margin-top: var(--space-xs);
}

.seq-editor-actions {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

/* ── Config (segment / date) ── */
.seq-config {
  background: var(--bg-surface);
  border-radius: var(--border-radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* ── Timeline ── */
.seq-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: var(--space-lg);
}

.seq-timeline__arrow {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) 0 var(--space-sm) var(--space-xl);
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}
.seq-timeline__arrow i { color: var(--color-primary); }

/* ── Step card (dans timeline) ── */
.seq-step-card {
  background: var(--bg-surface);
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--border-color);
  padding: var(--space-md) var(--space-lg);
  transition: border-color var(--transition-fast);
}
.seq-step-card:hover { border-color: var(--color-primary); }

.seq-step-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.seq-step-card__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  flex-shrink: 0;
}

.seq-step-card__subject {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
}

.seq-step-card__meta {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  display: flex;
  gap: var(--space-md);
  margin-top: 2px;
}

.seq-step-card__actions {
  margin-left: auto;
  display: flex;
  gap: var(--space-xs);
}

/* ── Éditeur step (blocs) ── */
.seq-step-fields {
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
  padding: var(--space-md);
}
.seq-step-fields .form__group { margin-bottom: var(--space-md); }

.seq-canvas {
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
  padding: var(--space-md);
  min-height: 100px;
}

/* ── Bloc email (dans step editor) ── */
.seq-block {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--space-sm);
  overflow: hidden;
  transition: border-color var(--transition-fast);
}
.seq-block:hover { border-color: var(--color-primary); }

.seq-block__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-xs) var(--space-sm);
  background: var(--bg-base);
  border-bottom: 1px solid var(--border-color);
}

.seq-block__type {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 4px;
}

.seq-block__btns {
  display: flex;
  gap: 2px;
}

.seq-block__preview {
  padding: var(--space-sm);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  max-height: 80px;
  overflow: hidden;
}
.seq-block__preview img { max-width: 100%; max-height: 60px; object-fit: contain; }

.seq-block__text {
  font-size: var(--font-size-sm);
  line-height: 1.5;
  color: var(--text-secondary);
}

/* ── Block picker modal ── */
.seq-block-picker {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
}

.seq-block-picker__btn {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  background: var(--bg-surface);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.seq-block-picker__btn:hover { border-color: var(--color-primary); background: var(--bg-base); }
.seq-block-picker__btn i { font-size: 1.2rem; color: var(--color-primary); }

/* ── Responsive ── */
@media (min-width: 768px) {
  .campaigns-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-lg);
  }

  .seq-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-lg);
  }

  .em-canvas { max-width: 700px; }
  .seq-canvas { max-width: 700px; }
}

@media (max-width: 600px) {
  .contacts-table th:nth-child(3),
  .contacts-table td:nth-child(3),
  .contacts-table th:nth-child(4),
  .contacts-table td:nth-child(4) {
    display: none;
  }
}
