/* ============================================================
   Editorial CRM — Stylesheet
   Estética: papel & tinta · Fraunces + Hanken Grotesk
   ============================================================ */
:root {
  --paper:#f3ede1; --paper-2:#ece4d4; --ink:#1c1a17; --ink-soft:#4a463e;
  --ink-faint:#8a8275; --line:#d8cfbd; --accent:#d6452b; --accent-2:#c98a2e;
  --card:#fbf7ee; --white:#fff; --ok:#5b9279; --warn:#c98a2e; --off:#b0a895;
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --radius:14px; --shadow:0 18px 50px -24px rgba(28,26,23,.44);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);
  background-image:radial-gradient(circle at 10% 10%,rgba(214,69,43,.05),transparent 38%),
                   radial-gradient(circle at 90% 88%,rgba(201,138,46,.06),transparent 40%);
  min-height:100vh}
a{color:inherit}
.brand-mark{color:var(--accent)}
.muted{color:var(--ink-faint)}
.spacer{flex:1}

/* ── AUTH ─────────────────────────────────────────────────── */
.auth-body{display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:38px 34px;width:min(420px,100%);box-shadow:var(--shadow)}
.auth-brand{font-family:var(--serif);font-size:1.8rem;font-weight:600;display:flex;align-items:center;gap:10px}
.auth-sub{color:var(--ink-faint);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin:6px 0 24px}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-foot{margin-top:18px;font-size:.82rem;color:var(--ink-faint);text-align:center}

/* ── TOPBAR ───────────────────────────────────────────────── */
.topbar{display:flex;align-items:center;gap:24px;background:var(--ink);color:var(--paper);
  padding:0 24px;height:62px;position:sticky;top:0;z-index:50;flex-shrink:0}
.topbar-brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:1.2rem;font-weight:600;white-space:nowrap}
.topnav{display:flex;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}
.topnav::-webkit-scrollbar{display:none}
.topnav a{padding:8px 13px;border-radius:8px;font-size:.88rem;color:rgba(243,237,225,.75);text-decoration:none;transition:all .15s;white-space:nowrap}
.topnav a:hover{background:rgba(255,255,255,.08);color:var(--paper)}
.topnav a.on{background:var(--paper);color:var(--ink);font-weight:600}
.topbar-user{display:flex;align-items:center;gap:12px;flex-shrink:0}
.user-info{display:flex;flex-direction:column;text-align:right;line-height:1.2}
.user-nome{font-size:.88rem;font-weight:600}
.user-papel{font-size:.7rem;color:rgba(243,237,225,.5);text-transform:uppercase;letter-spacing:.08em}
.logout-link{width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.15);border-radius:8px;text-decoration:none;transition:all .15s;font-size:.9rem}
.logout-link:hover{background:var(--accent);border-color:var(--accent)}

/* ── PAGE ─────────────────────────────────────────────────── */
.page{max-width:1200px;margin:0 auto;padding:30px 24px 60px}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.eyebrow{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:4px}
.page-title{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.8rem);font-weight:600;letter-spacing:-.02em;line-height:1}
.head-actions{display:flex;gap:10px;align-items:center}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{font-family:var(--sans);font-size:.88rem;font-weight:600;padding:9px 17px;border-radius:10px;
  cursor:pointer;border:1px solid transparent;transition:all .15s;text-decoration:none;display:inline-flex;
  align-items:center;justify-content:center;gap:6px;white-space:nowrap;line-height:1}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#b83a22;transform:translateY(-1px)}
.btn-ghost{background:var(--card);border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-ghost.danger{color:#b83a22}
.btn-ghost.danger:hover{border-color:#b83a22;background:#fff1ee}
.btn-block{width:100%}
.icon-btn{background:var(--paper);border:1px solid var(--line);width:32px;height:32px;border-radius:8px;
  cursor:pointer;font-size:.92rem;display:inline-flex;align-items:center;justify-content:center;transition:all .18s;text-decoration:none}
.icon-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.icon-btn.danger:hover{background:var(--accent);border-color:var(--accent)}
.sel-inline{font-family:var(--sans);font-size:.9rem;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:8px 12px;color:var(--ink)}

/* ── ALERTS ───────────────────────────────────────────────── */
.alert{padding:11px 15px;border-radius:10px;font-size:.9rem;margin-bottom:16px;line-height:1.5}
.alert-ok{background:rgba(91,146,121,.14);border:1px solid rgba(91,146,121,.35);color:#3c6650}
.alert-erro{background:rgba(214,69,43,.1);border:1px solid rgba(214,69,43,.3);color:#a8331e}
.alert-info{background:rgba(201,138,46,.12);border:1px solid rgba(201,138,46,.3);color:#8a5e1c}
.alert code{background:rgba(0,0,0,.07);padding:2px 6px;border-radius:5px;font-size:.85em}

/* ── CARDS / TABLES ───────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line);gap:12px}
.card-head h3{font-family:var(--serif);font-size:1.1rem;font-weight:600}
.table-card{overflow:hidden}
.data-table{width:100%;border-collapse:collapse;font-size:.9rem}
.data-table thead th{text-align:left;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:600;padding:13px 18px;border-bottom:1px solid var(--line)}
.data-table tbody td{padding:13px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:rgba(255,255,255,.5);cursor:pointer}
.row-actions{display:flex;gap:10px;font-size:1.05rem}
.row-actions a{text-decoration:none;opacity:.65;transition:opacity .15s}
.row-actions a:hover{opacity:1}
.pill{font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:20px}
.pill-ok{background:rgba(91,146,121,.16);color:#3c6650}
.pill-warn{background:rgba(201,138,46,.16);color:#8a5e1c}
.pill-off{background:rgba(176,168,149,.2);color:var(--ink-soft)}
.badge-count{background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}
.accent-ok{color:var(--ok) !important}

/* ── FORMS ────────────────────────────────────────────────── */
.form-card{padding:24px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.field{display:flex;flex-direction:column;gap:5px}
.field-wide{grid-column:1/-1}
.field>span{font-size:.73rem;letter-spacing:.04em;font-weight:600;color:var(--ink-soft);text-transform:uppercase}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:.91rem;color:var(--ink);
  background:var(--white);border:1px solid var(--line);border-radius:9px;padding:9px 12px;resize:vertical;transition:border-color .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(214,69,43,.12)}
.color-input{height:42px;padding:4px;cursor:pointer}
.check-field{flex-direction:row;align-items:center;gap:8px}
.check-field input{width:17px;height:17px;accent-color:var(--accent)}
.check-field span{font-size:.9rem;color:var(--ink);text-transform:none;letter-spacing:0;font-weight:400}
.form-actions{display:flex;align-items:center;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}
.form-note{font-size:.83rem;color:var(--ink-faint);margin-top:12px;font-style:italic;line-height:1.5}

/* ── FILTER BAR ───────────────────────────────────────────── */
.filter-bar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.filter-bar input,.filter-bar select{font-family:var(--sans);font-size:.88rem;background:var(--white);
  border:1px solid var(--line);border-radius:9px;padding:8px 12px;color:var(--ink)}
.filter-bar input{flex:1;min-width:180px}

/* ── DASHBOARD ────────────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:var(--serif);font-size:2.2rem;font-weight:600;color:var(--accent);line-height:1}
.stat-lbl{font-size:.78rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em}
.dash-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.chart-card{display:flex;flex-direction:column}
.chart-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px}
.chart-head h3{font-family:var(--serif);font-size:1.05rem;font-weight:600}
.chart-head .chart-badge{font-size:.72rem;color:var(--ok);font-weight:600;padding:3px 9px;
  background:rgba(91,146,121,.12);border-radius:20px}
.chart-card canvas{padding:0 14px 14px;max-height:260px}
.activities-card{display:flex;flex-direction:column}
.activities-list{display:flex;flex-direction:column;gap:0;overflow-y:auto;max-height:280px}
.activity-item{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);transition:all .15s}
.activity-item:last-child{border-bottom:none}
.activity-item:hover{background:rgba(214,69,43,.05);padding-left:22px}
.act-icon{font-size:1.1rem;flex-shrink:0}
.act-main{flex:1;min-width:0}
.act-title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act-meta{font-size:.77rem;color:var(--ink-faint)}
.act-time{font-family:var(--serif);font-size:.85rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.empty-state{background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);
  padding:28px;text-align:center;color:var(--ink-faint);font-size:.92rem}
.empty-state.big{padding:60px 30px;font-size:1.05rem}
.empty-state a{color:var(--accent)}

/* ── FUNIS GRID ───────────────────────────────────────────── */
.funis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.funil-card{padding:20px 22px;display:flex;flex-direction:column;gap:12px}
.funil-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.funil-card-head h3{font-family:var(--serif);font-size:1.15rem;font-weight:600}
.funil-desc{font-size:.88rem;color:var(--ink-soft);line-height:1.5}
.funil-stages{display:flex;flex-wrap:wrap;gap:6px;min-height:28px}
.stage-chip{font-size:.76rem;padding:3px 10px;border-radius:20px;border:1.5px solid;font-weight:600}
.funil-footer{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--line)}
.funil-actions{display:flex;gap:6px}

/* ── STAGES LIST (funis.php editor) ──────────────────────── */
.dual-panel{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.stages-card,.stages-list{display:flex;flex-direction:column}
.stages-list{padding:0}
.stage-row{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--line)}
.stage-row:last-child{border-bottom:none}
.stage-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.stage-name{flex:1;font-weight:600;font-size:.92rem}
.stage-ord{font-size:.78rem}
.stage-actions{display:flex;gap:6px}

/* ── PASSOS (fluxos.php) ──────────────────────────────────── */
.passos-list{display:flex;flex-direction:column}
.passo-row{display:flex;align-items:center;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line)}
.passo-row:last-child{border-bottom:none}
.passo-num{font-family:var(--serif);font-weight:600;color:var(--accent);min-width:40px;font-size:.9rem}
.passo-icon{font-size:1.1rem;flex-shrink:0}
.passo-info{flex:1;min-width:0}
.passo-nome{font-weight:600;font-size:.92rem}

/* ── LEAD DETAIL ──────────────────────────────────────────── */
.lead-layout{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}
.lead-main{display:flex;flex-direction:column;gap:16px}
.lead-header{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}
.lh-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}
.lh-nome{font-size:clamp(1.4rem,3vw,2rem)}
.lh-empresa{color:var(--ink-soft);font-size:.95rem;margin-top:2px}
.lh-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.lh-info{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.info-chip{display:inline-flex;align-items:center;gap:5px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:20px;padding:5px 12px;font-size:.83rem;color:var(--ink-soft);text-decoration:none}
.info-chip:hover{border-color:var(--accent);color:var(--accent)}
.lh-stages{display:flex;flex-wrap:wrap;gap:8px;padding-top:14px;border-top:1px solid var(--line)}
.stage-pill{padding:6px 14px;border-radius:20px;border:1.5px solid;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s;background:transparent}
.stage-pill:hover{opacity:.85;transform:translateY(-1px)}
.stage-pill.active{box-shadow:0 3px 10px rgba(0,0,0,.15)}
.section-card{overflow:hidden}

/* ── ATIVIDADES ───────────────────────────────────────────── */
.ativs-list{display:flex;flex-direction:column;gap:0}
.ativ-item{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--line);transition:background .15s}
.ativ-item:last-child{border-bottom:none}
.ativ-item.done{opacity:.55}
.ativ-item.vencida{background:rgba(214,69,43,.04)}
.ativ-check{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:0;width:28px;text-align:center;flex-shrink:0;color:var(--ink-faint)}
.ativ-check.checked{color:var(--ok)}
.ativ-icon{font-size:1rem;flex-shrink:0}
.ativ-body{flex:1;min-width:0}
.ativ-titulo{font-weight:600;font-size:.9rem}
.ativ-desc{font-size:.78rem;color:var(--ink-faint)}
.ativ-meta{display:flex;align-items:center;gap:8px}
.ativ-data{font-size:.78rem;color:var(--ink-faint);font-variant-numeric:tabular-nums}
.text-vencida{color:var(--accent);font-weight:600}

/* ── CAMPOS DISPLAY ───────────────────────────────────────── */
.campos-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:4px 0}
.campo-item{display:flex;flex-direction:column;gap:3px;padding:12px 20px;border-bottom:1px solid var(--line)}
.campo-item:nth-child(odd){border-right:1px solid var(--line)}
.campo-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:600}
.campo-val{font-size:.92rem;color:var(--ink)}

/* ── TIMELINE ─────────────────────────────────────────────── */
.lead-side{display:flex;flex-direction:column;gap:0;position:sticky;top:78px}
.timeline-head{display:flex;justify-content:space-between;align-items:center;padding:0 0 14px;margin-bottom:2px}
.timeline-head h3{font-family:var(--serif);font-size:1.1rem;font-weight:600}
.timeline{display:flex;flex-direction:column;gap:0;position:relative;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;max-height:calc(100vh - 180px);overflow-y:auto}
.tl-item{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);position:relative;transition:background .15s}
.tl-item:last-child{border-bottom:none}
.tl-item:hover{background:rgba(255,255,255,.5)}
.tl-dot{width:28px;height:28px;border-radius:50%;background:var(--paper-2);border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:1px}
.tl-content{flex:1;min-width:0}
.tl-titulo{font-weight:600;font-size:.88rem;line-height:1.3}
.tl-desc{font-size:.8rem;color:var(--ink-soft);margin-top:2px;line-height:1.4}
.tl-meta{font-size:.73rem;color:var(--ink-faint);margin-top:4px}

/* ── FLUXOS LISTA ─────────────────────────────────────────── */
.fluxos-lista{display:flex;flex-direction:column;gap:8px}
.fluxo-item{padding:14px 16px;background:var(--paper);border:1.5px solid var(--line);border-radius:10px;cursor:pointer;transition:all .15s}
.fluxo-item:hover{border-color:var(--accent);background:rgba(214,69,43,.04)}
.fi-nome{font-weight:600;font-size:.95rem}
.fi-meta{font-size:.8rem;color:var(--ink-faint);margin-top:3px}

/* ── COL MAPPER (import) ──────────────────────────────────── */
.col-map{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.cm-row{display:grid;grid-template-columns:1.2fr 28px 1.5fr 1fr;gap:10px;align-items:center}
.cm-col-name{font-weight:600;font-size:.88rem;background:var(--paper-2);border:1px solid var(--line);
  border-radius:8px;padding:8px 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-arrow{text-align:center;color:var(--ink-faint)}
.cm-select{font-family:var(--sans);font-size:.86rem;background:var(--white);border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--ink)}
.cm-preview{font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── MODAIS ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(28,26,23,.52);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:20px;z-index:200;
  opacity:0;visibility:hidden;transition:all .22s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--paper);width:min(660px,100%);max-height:90vh;border-radius:18px;
  display:flex;flex-direction:column;box-shadow:0 40px 90px -30px rgba(0,0,0,.55);
  transform:translateY(14px);transition:transform .22s;overflow:hidden}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--line);background:var(--card)}
.modal-title{font-family:var(--serif);font-size:1.3rem;font-weight:600}
.modal-body{padding:20px 24px 26px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}

/* ── TOAST ────────────────────────────────────────────────── */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(16px);
  background:var(--ink);color:var(--paper);padding:11px 22px;border-radius:30px;font-size:.86rem;
  font-weight:500;box-shadow:var(--shadow);z-index:300;opacity:0;visibility:hidden;transition:all .28s}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ── AVATAR ───────────────────────────────────────────────── */
.avatar{width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--paper);
  font-size:.68rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;
  letter-spacing:-.02em;flex-shrink:0}

/* ── SCROLLBARS ───────────────────────────────────────────── */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px;border:2px solid var(--card)}

/* ── RESPONSIVO ───────────────────────────────────────────── */
@media(max-width:980px){
  .topnav a{padding:7px 10px;font-size:.82rem}
  .stat-row{grid-template-columns:1fr 1fr}
  .dash-grid{grid-template-columns:1fr}
  .dual-panel{grid-template-columns:1fr}
  .lead-layout{grid-template-columns:1fr}
  .lead-side{position:static}
  .form-grid{grid-template-columns:1fr}
  .cm-row{grid-template-columns:1fr 28px 1fr}
  .cm-preview{display:none}
}
@media(max-width:640px){
  .page{padding:20px 14px 40px}
  .stat-row{grid-template-columns:1fr}
  .user-info{display:none}
}
