/* ================================================================
   MÓDULO GESTÃO DE TRÁFEGO — Orion Business Suite
   Agência Comunikativa | styles/trafego.css
   ================================================================ */

/* ── CONTAINER ───────────────────────────────────────────────── */
#trafego-container {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  overflow: hidden;
  font-family: inherit;
}

/* ── HEADER / ABAS ───────────────────────────────────────────── */
.tr-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  flex-shrink: 0;
  gap: 10px;
  flex-wrap: wrap;
}
.tr-tabs {
  display: flex;
  gap: 2px;
  background: var(--bg);
  border-radius: 8px;
  padding: 3px;
}
.tr-tab {
  padding: 6px 13px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--text2);
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.tr-tab:hover { color: var(--text); background: rgba(255,255,255,.04); }
.tr-tab.active { background: var(--accent); color: #000; font-weight: 600; }
.tr-header-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ── BODY / PANELS ───────────────────────────────────────────── */
.tr-body { flex: 1; overflow: hidden; position: relative; }
.tr-panel { display: none; height: 100%; overflow-y: auto; padding: 20px; }
.tr-panel.active { display: block; }
.tr-panel::-webkit-scrollbar { width: 4px; }
.tr-panel::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ── SELETOR DE CLIENTE / PERFIL ADS ────────────────────────── */
.tr-cliente-selector {
  position: relative;
}
.tr-cliente-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  font-size: 12px;
  color: var(--text);
  transition: border-color .15s;
  white-space: nowrap;
}
.tr-cliente-btn:hover { border-color: var(--accent); }
.tr-cliente-avatar {
  width: 24px; height: 24px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  color: #fff; flex-shrink: 0;
}
.tr-cliente-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 260px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  z-index: 9000;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  overflow: hidden;
}
.tr-cliente-opt {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; cursor: pointer;
  font-size: 12px; color: var(--text);
  transition: background .12s;
}
.tr-cliente-opt:hover { background: var(--surface2); }
.tr-cliente-opt.sel { background: rgba(0,212,255,.08); color: var(--accent); }

/* ── PLATAFORMA BADGES ───────────────────────────────────────── */
.tr-plat-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 5px;
  font-size: 10px; font-weight: 700;
  color: #fff; white-space: nowrap;
}
.tr-plat-badge.meta { background: #1877f2; }
.tr-plat-badge.google { background: #ea4335; }
.tr-plat-badge.meta-sm { background: #1877f2; }
.tr-plat-badge.google-sm { background: #ea4335; }
.tr-plat-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 4px;
  font-size: 10px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.tr-plat-icon.meta { background: #1877f2; }
.tr-plat-icon.google { background: #ea4335; }

/* ── KPI GRID ────────────────────────────────────────────────── */
.tr-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.tr-kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  position: relative;
  overflow: hidden;
  transition: border-color .2s;
}
.tr-kpi:hover { border-color: rgba(0,212,255,.3); }
.tr-kpi::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.tr-kpi.green::before { background: linear-gradient(90deg, var(--accent3), transparent); }
.tr-kpi.purple::before { background: linear-gradient(90deg, var(--accent2), transparent); }
.tr-kpi.warn::before { background: linear-gradient(90deg, var(--warn), transparent); }
.tr-kpi.red::before { background: linear-gradient(90deg, var(--danger), transparent); }
.tr-kpi-label {
  font-size: 9px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text2); margin-bottom: 6px;
}
.tr-kpi-value {
  font-family: 'Syne', sans-serif;
  font-size: 24px; font-weight: 800; line-height: 1; margin-bottom: 3px;
}
.tr-kpi-sub { font-size: 10px; color: var(--text2); }
.tr-kpi-icon {
  position: absolute; right: 14px; top: 50%;
  transform: translateY(-50%);
  font-size: 22px; opacity: .12;
}

/* ── CHARTS ROW ──────────────────────────────────────────────── */
.tr-charts-row {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 14px;
  margin-bottom: 20px;
}
.tr-chart-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px;
}
.tr-chart-title {
  font-family: 'Syne', sans-serif;
  font-size: 13px; font-weight: 600; margin-bottom: 2px;
}
.tr-chart-sub { font-size: 10px; color: var(--text2); margin-bottom: 14px; }

/* ── TABELA DE CAMPANHAS ─────────────────────────────────────── */
.tr-table-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 20px;
}
.tr-table-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap; gap: 10px;
}
.tr-table-title {
  font-family: 'Syne', sans-serif;
  font-size: 13px; font-weight: 600;
}
.tr-filters { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; }
.tr-filter-select {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text3);
  font-family: 'DM Mono', monospace;
  font-size: 11px; padding: 5px 9px;
  border-radius: 6px; cursor: pointer; outline: none;
}
.tr-filter-select:focus { border-color: var(--accent); }
.tr-search {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'DM Mono', monospace;
  font-size: 11px; padding: 5px 11px;
  border-radius: 6px; outline: none; width: 180px;
}
.tr-search:focus { border-color: var(--accent); }
.tr-search::placeholder { color: var(--text2); }

.tr-table { width: 100%; border-collapse: collapse; }
.tr-table th {
  font-size: 9px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text2);
  padding: 9px 14px; text-align: left;
  background: var(--surface2);
  border-bottom: 1px solid var(--border);
}
.tr-table td {
  padding: 11px 14px;
  border-bottom: 1px solid rgba(30,42,54,.5);
  font-size: 12px; vertical-align: middle;
}
.tr-table tr:hover td { background: rgba(255,255,255,.02); }
.tr-table tr:last-child td { border-bottom: none; }

/* ── STATUS BADGES ───────────────────────────────────────────── */
.tr-status {
  display: inline-block;
  padding: 3px 8px; border-radius: 4px;
  font-size: 10px; letter-spacing: .3px;
}
.tr-status.rascunho { background: rgba(100,116,139,.12); color: var(--text2); }
.tr-status.em_revisao { background: rgba(245,158,11,.12); color: var(--warn); }
.tr-status.ativa { background: rgba(16,185,129,.12); color: var(--accent3); }
.tr-status.pausada { background: rgba(239,68,68,.12); color: var(--danger); }
.tr-status.concluida { background: rgba(0,212,255,.1); color: var(--accent); }
.tr-status.arquivada { background: rgba(100,116,139,.08); color: var(--text2); }

/* ── CAMPANHA CARD (lista visual) ────────────────────────────── */
.tr-camp-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 10px;
  transition: border-color .2s;
  cursor: pointer;
}
.tr-camp-card:hover { border-color: rgba(0,212,255,.3); }
.tr-camp-card.ativa { border-left: 3px solid var(--accent3); }
.tr-camp-card.pausada { border-left: 3px solid var(--danger); }
.tr-camp-card.rascunho { border-left: 3px solid var(--border); }
.tr-camp-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.tr-camp-name {
  font-family: 'Syne', sans-serif;
  font-size: 14px; font-weight: 700;
  margin-bottom: 2px;
}
.tr-camp-meta { font-size: 11px; color: var(--text2); display: flex; gap: 12px; flex-wrap: wrap; }
.tr-camp-kpis {
  display: flex; gap: 18px; align-items: center;
  font-size: 12px;
}
.tr-camp-kpi { text-align: center; }
.tr-camp-kpi-val { font-weight: 700; color: var(--text); font-size: 14px; }
.tr-camp-kpi-lbl { font-size: 9px; color: var(--text2); text-transform: uppercase; letter-spacing: .5px; }

/* ── BARRA DE ORÇAMENTO ──────────────────────────────────────── */
.tr-orcamento-bar-wrap {
  flex: 1; background: var(--surface2);
  border-radius: 4px; height: 6px;
  overflow: hidden; min-width: 100px;
}
.tr-orcamento-bar {
  height: 100%; border-radius: 4px;
  transition: width .5s ease;
}
.tr-orcamento-bar.normal { background: var(--accent3); }
.tr-orcamento-bar.warn { background: var(--warn); }
.tr-orcamento-bar.over { background: var(--danger); }

/* ── MÉTRICAS DETALHADAS ─────────────────────────────────────── */
.tr-metricas-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
.tr-metrica-box {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
}
.tr-metrica-val {
  font-family: 'Syne', sans-serif;
  font-size: 20px; font-weight: 800;
  color: var(--accent); margin-bottom: 2px;
}
.tr-metrica-lbl { font-size: 10px; color: var(--text2); text-transform: uppercase; letter-spacing: .8px; }

/* ── ALERTAS ─────────────────────────────────────────────────── */
.tr-alert-list { display: flex; flex-direction: column; gap: 8px; }
.tr-alert-item {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px; padding: 12px 14px;
  transition: border-color .15s;
}
.tr-alert-item.nao-lido { border-left: 3px solid var(--warn); }
.tr-alert-item.lido { opacity: .6; }
.tr-alert-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.tr-alert-msg { font-size: 12px; color: var(--text); line-height: 1.5; }
.tr-alert-time { font-size: 10px; color: var(--text2); margin-top: 3px; }
.tr-alert-actions { margin-left: auto; display: flex; gap: 6px; flex-shrink: 0; }

/* ── FORM / MODAL ────────────────────────────────────────────── */
.tr-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tr-form-group { display: flex; flex-direction: column; gap: 5px; }
.tr-form-label {
  font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase; color: var(--text2);
}
.tr-form-input, .tr-form-select, .tr-form-textarea {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'DM Mono', monospace;
  font-size: 12px; padding: 8px 11px;
  border-radius: 7px; outline: none;
  transition: border-color .15s;
  width: 100%;
}
.tr-form-input:focus, .tr-form-select:focus, .tr-form-textarea:focus {
  border-color: var(--accent);
}
.tr-form-input::placeholder, .tr-form-textarea::placeholder { color: var(--text2); }
.tr-form-textarea { min-height: 80px; resize: vertical; }
.tr-form-section {
  font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text2);
  padding: 12px 0 4px;
  border-top: 1px solid var(--border);
  margin-top: 6px;
}

/* ── FONTE / ORIGEM CONTENT SELECTOR ────────────────────────── */
.tr-fonte-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 8px; margin-bottom: 14px;
}
.tr-fonte-opt {
  background: var(--surface2);
  border: 2px solid var(--border);
  border-radius: 8px; padding: 12px;
  cursor: pointer; text-align: center;
  transition: all .15s;
}
.tr-fonte-opt:hover { border-color: rgba(0,212,255,.4); }
.tr-fonte-opt.sel { border-color: var(--accent); background: rgba(0,212,255,.05); }
.tr-fonte-opt-icon { font-size: 24px; margin-bottom: 4px; }
.tr-fonte-opt-label { font-size: 11px; font-weight: 600; color: var(--text); }
.tr-fonte-opt-sub { font-size: 10px; color: var(--text2); margin-top: 2px; }

/* ── ANUNCIO PREVIEW ─────────────────────────────────────────── */
.tr-ad-preview-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-bottom: 16px;
}
.tr-ad-preview-box {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
}
.tr-ad-preview-label {
  font-size: 10px; color: var(--text2);
  padding: 8px 12px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 6px;
}

/* Preview Meta Ads */
.tr-preview-meta {
  padding: 12px;
  background: #fff; color: #000;
  font-family: 'Helvetica Neue', sans-serif;
  min-height: 200px;
}
.tr-preview-meta .pm-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.tr-preview-meta .pm-avatar {
  width: 36px; height: 36px; background: #1877f2;
  border-radius: 50%; display: flex; align-items: center;
  justify-content: center; color: #fff; font-weight: 700; font-size: 14px;
}
.tr-preview-meta .pm-name { font-size: 13px; font-weight: 700; color: #050505; }
.tr-preview-meta .pm-sponsored { font-size: 11px; color: #65676b; }
.tr-preview-meta .pm-img {
  width: 100%; height: 120px;
  background: linear-gradient(135deg, #1a1a2e, #16213e);
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; margin-bottom: 8px;
}
.tr-preview-meta .pm-title { font-size: 13px; font-weight: 700; color: #050505; margin-bottom: 4px; }
.tr-preview-meta .pm-desc { font-size: 12px; color: #65676b; }
.tr-preview-meta .pm-cta {
  background: #1877f2; color: #fff;
  border: none; border-radius: 6px;
  font-size: 12px; font-weight: 700;
  padding: 8px 16px; margin-top: 8px; cursor: pointer;
  width: 100%;
}

/* Preview Google Ads */
.tr-preview-google {
  padding: 12px;
  background: #fff; color: #000;
  font-family: Arial, sans-serif;
  min-height: 120px;
}
.tr-preview-google .pg-url { font-size: 12px; color: #202124; margin-bottom: 2px; }
.tr-preview-google .pg-ad-badge {
  display: inline-block; border: 1px solid #006621;
  color: #006621; font-size: 10px; padding: 0 4px;
  border-radius: 3px; margin-right: 4px;
}
.tr-preview-google .pg-title {
  font-size: 18px; color: #1a0dab;
  margin-bottom: 4px; cursor: pointer;
}
.tr-preview-google .pg-title:hover { text-decoration: underline; }
.tr-preview-google .pg-desc { font-size: 13px; color: #4d5156; line-height: 1.5; }

/* ── CONTENT LIST (social + authority) ───────────────────────── */
.tr-content-list { display: flex; flex-direction: column; gap: 8px; max-height: 280px; overflow-y: auto; }
.tr-content-item {
  display: flex; align-items: center; gap: 10px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 12px;
  cursor: pointer; transition: border-color .15s;
}
.tr-content-item:hover { border-color: var(--accent); }
.tr-content-item.sel { border-color: var(--accent); background: rgba(0,212,255,.05); }
.tr-content-item-img {
  width: 48px; height: 48px; border-radius: 6px;
  background: var(--surface); display: flex;
  align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.tr-content-item-body { flex: 1; overflow: hidden; }
.tr-content-item-title { font-size: 12px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tr-content-item-meta { font-size: 10px; color: var(--text2); margin-top: 2px; }

/* ── PERFIS ADS ──────────────────────────────────────────────── */
.tr-perfis-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.tr-perfil-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px; padding: 18px;
  transition: border-color .2s;
}
.tr-perfil-card:hover { border-color: rgba(0,212,255,.3); }
.tr-perfil-header {
  display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 12px;
}
.tr-perfil-name {
  font-family: 'Syne', sans-serif;
  font-size: 14px; font-weight: 700;
}
.tr-perfil-stats { display: flex; flex-direction: column; gap: 6px; }
.tr-perfil-stat {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--text2);
  padding: 5px 0; border-top: 1px solid var(--border);
}
.tr-perfil-stat span:last-child { color: var(--text); font-weight: 600; }

/* ── RELATÓRIOS ──────────────────────────────────────────────── */
.tr-relatorio-filtros {
  display: flex; gap: 10px; align-items: center;
  margin-bottom: 18px; flex-wrap: wrap;
}
.tr-relatorio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}
.tr-relatorio-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px; padding: 16px;
}
.tr-relatorio-card-title {
  font-size: 11px; color: var(--text2);
  text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: 8px;
}
.tr-relatorio-card-val {
  font-family: 'Syne', sans-serif;
  font-size: 26px; font-weight: 800;
}

/* ── EMPTY STATE ─────────────────────────────────────────────── */
.tr-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--text2); font-size: 12px;
}
.tr-empty-icon { font-size: 40px; margin-bottom: 12px; opacity: .3; }
.tr-empty-title {
  font-family: 'Syne', sans-serif;
  font-size: 16px; font-weight: 700;
  color: var(--text); margin-bottom: 6px;
}

/* ── LOADING ─────────────────────────────────────────────────── */
.tr-loading {
  display: flex; align-items: center;
  justify-content: center;
  padding: 50px; gap: 10px;
  color: var(--text2); font-size: 12px;
}
.tr-spinner {
  width: 16px; height: 16px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}

/* ── BOTÕES AÇÃO ─────────────────────────────────────────────── */
.tr-btn-actions { display: flex; gap: 6px; }
.tr-btn-sm {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text2);
  padding: 4px 10px; border-radius: 5px;
  font-family: 'DM Mono', monospace;
  font-size: 10px; cursor: pointer;
  transition: all .15s;
}
.tr-btn-sm:hover { border-color: var(--accent); color: var(--accent); }
.tr-btn-sm.danger:hover { border-color: var(--danger); color: var(--danger); }
.tr-btn-sm.primary {
  background: var(--accent); color: #000;
  border-color: var(--accent); font-weight: 600;
}
.tr-btn-sm.primary:hover { background: #00b8d9; }

/* ── MODAL OVERLAY ───────────────────────────────────────────── */
.tr-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(4px);
  z-index: 500;
  display: none; align-items: flex-start;
  justify-content: center;
  padding: 24px 16px; overflow-y: auto;
}
.tr-modal-overlay.open { display: flex; }
.tr-modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 100%; max-width: 700px;
  padding: 28px; position: relative; margin: auto; flex-shrink: 0;
}
.tr-modal-title {
  font-family: 'Syne', sans-serif;
  font-size: 17px; font-weight: 700;
  margin-bottom: 20px;
  display: flex; justify-content: space-between; align-items: center;
}
.tr-modal-close { cursor: pointer; color: var(--text2); font-size: 20px; }
.tr-modal-close:hover { color: var(--text); }
.tr-modal-footer {
  display: flex; gap: 8px; margin-top: 20px;
  justify-content: flex-end;
}

/* ── TOGGLE ──────────────────────────────────────────────────── */
.tr-toggle {
  width: 40px; height: 22px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 11px; cursor: pointer;
  position: relative; transition: all .2s; flex-shrink: 0;
}
.tr-toggle.on { background: rgba(16,185,129,.3); border-color: var(--accent3); }
.tr-toggle::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  background: var(--text2); border-radius: 50%;
  top: 2px; left: 2px; transition: all .2s;
}
.tr-toggle.on::after { left: 20px; background: var(--accent3); }

/* ── PROGRESS STEPS ──────────────────────────────────────────── */
.tr-steps {
  display: flex; gap: 6px; margin-bottom: 22px;
}
.tr-step-dot {
  flex: 1; height: 4px;
  background: var(--border); border-radius: 2px;
  transition: background .3s;
}
.tr-step-dot.done { background: var(--accent3); }
.tr-step-dot.active { background: var(--accent); }
.tr-step { display: none; }
.tr-step.active { display: block; }

/* ── RESPONSIVO ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .tr-kpi-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .tr-charts-row { grid-template-columns: 1fr !important; }
  .tr-metricas-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .tr-form-grid { grid-template-columns: 1fr !important; }
  .tr-ad-preview-wrap { grid-template-columns: 1fr !important; }
  .tr-relatorio-grid { grid-template-columns: 1fr !important; }
  .tr-perfis-grid { grid-template-columns: 1fr !important; }
  .tr-fonte-grid { grid-template-columns: 1fr !important; }
  .tr-camp-kpis { display: none; }
}
