:root {
  --preto: #0A0A0A;
  --dourado: #C9A84C;
  --dourado-soft: #e3cd8a;
  --cinza: #888;
  --cinza-bg: #f4f5f7;
  --branco: #fff;
  --borda: #e3e5ea;
  --novo: #6b7280;
  --qualificado: #2563eb;
  --reuniao: #7c3aed;
  --proposta: #d97706;
  --fechado: #16a34a;
  --perdido: #dc2626;
  --sombra: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', system-ui, sans-serif; background: var(--cinza-bg); color: #1a1a1a; font-size: 16px; }

/* ---------- LOGIN ---------- */
.login-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--preto); }
.login-card { background: var(--branco); border-radius: 16px; padding: 48px 40px; width: 380px; max-width: 92vw; box-shadow: 0 20px 60px rgba(0,0,0,.5); border-top: 4px solid var(--dourado); }
.login-logo { font-family: 'Playfair Display', serif; font-size: 44px; font-weight: 700; letter-spacing: 6px; text-align: center; color: var(--preto); }
.login-sub { text-align: center; color: var(--cinza); font-size: 15px; margin: 6px 0 28px; letter-spacing: .5px; }
.login-card label { display: block; font-size: 15px; font-weight: 500; margin: 16px 0 6px; }
.login-card input { width: 100%; padding: 13px 14px; font-size: 16px; border: 1.5px solid var(--borda); border-radius: 9px; font-family: inherit; }
.login-card input:focus { outline: none; border-color: var(--dourado); }
.login-card button { width: 100%; margin-top: 26px; padding: 14px; background: var(--preto); color: var(--branco); border: none; border-radius: 9px; font-size: 16px; font-weight: 600; cursor: pointer; transition: .15s; }
.login-card button:hover { background: #222; }
.login-card button:disabled { opacity: .6; cursor: wait; }
.login-erro { color: var(--perdido); font-size: 14px; text-align: center; margin-top: 14px; min-height: 18px; }

/* ---------- TOPBAR ---------- */
.topbar { display: flex; align-items: center; gap: 28px; background: var(--preto); color: var(--branco); padding: 0 24px; height: 62px; position: sticky; top: 0; z-index: 50; }
.brand { font-family: 'Playfair Display', serif; font-size: 24px; display: flex; align-items: center; gap: 8px; }
.brand-logo { font-weight: 700; letter-spacing: 3px; color: var(--dourado); }
.brand-sep { color: #555; }
.brand-app { font-size: 17px; font-weight: 600; font-family: 'Inter', sans-serif; letter-spacing: 1px; }
.topnav { display: flex; gap: 6px; flex: 1; }
.nav-item { color: #bbb; text-decoration: none; font-size: 15px; padding: 8px 14px; border-radius: 8px; cursor: pointer; }
.nav-item.active, .nav-item:hover { color: var(--branco); background: rgba(255,255,255,.08); }
.nav-extra { display: none; } /* só aparece no menu mobile */
.topbar-right { display: flex; align-items: center; gap: 14px; }
.user-chip { font-size: 15px; color: var(--dourado-soft); cursor: pointer; }
.user-chip:hover { color: var(--dourado); }
.hamburger { display: none; background: transparent; border: none; color: #fff; font-size: 24px; cursor: pointer; padding: 0 4px; line-height: 1; }
.fu-head-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.modal-sm { max-width: 420px; }
.btn-primary { background: var(--dourado); color: var(--preto); border: none; padding: 10px 16px; border-radius: 8px; font-weight: 600; font-size: 15px; cursor: pointer; transition: .15s; }
.btn-primary:hover { background: var(--dourado-soft); }
.btn-ghost { background: transparent; color: #ccc; border: 1px solid #444; padding: 9px 14px; border-radius: 8px; font-size: 14px; cursor: pointer; }
.btn-ghost:hover { color: #fff; border-color: #777; }

/* ---------- BOARD ---------- */
.board-wrap { padding: 20px; overflow-x: auto; }
.board { display: flex; gap: 16px; min-height: calc(100vh - 102px); }
.col { background: #eceef1; border-radius: 12px; width: 290px; flex: 0 0 290px; display: flex; flex-direction: column; }
.col-head { display: flex; align-items: center; gap: 8px; padding: 14px 16px 10px; font-weight: 600; font-size: 15px; border-top: 3px solid var(--novo); border-radius: 12px 12px 0 0; }
.col-novo .col-head { border-color: var(--novo); }
.col-qualificado .col-head { border-color: var(--qualificado); }
.col-reuniao .col-head { border-color: var(--reuniao); }
.col-proposta .col-head { border-color: var(--proposta); }
.col-fechado .col-head { border-color: var(--fechado); }
.col-perdido .col-head { border-color: var(--perdido); }
.col-count { background: #d4d7dd; color: #444; border-radius: 20px; padding: 1px 9px; font-size: 13px; }
.col-total { margin-left: auto; font-size: 13px; color: var(--fechado); font-weight: 600; }
.col-body { flex: 1; padding: 6px 10px 16px; display: flex; flex-direction: column; gap: 10px; min-height: 60px; }

.card { background: var(--branco); border-radius: 10px; padding: 13px 14px; box-shadow: var(--sombra); cursor: pointer; border: 1px solid transparent; transition: .12s; }
.card:hover { border-color: var(--dourado); transform: translateY(-1px); }
.card-ghost { opacity: .4; }
.card-alerta { border-left: 3px solid var(--perdido); }
.card-nome { font-weight: 600; font-size: 16px; margin-bottom: 7px; }
.card-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: 12.5px; background: #f0ead6; color: #7a6418; padding: 2px 8px; border-radius: 6px; font-weight: 500; }
.tag-valor { background: #dcfce7; color: #15803d; }
.card-origem { font-size: 13px; color: var(--cinza); margin-top: 7px; }
.card-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; padding-top: 9px; border-top: 1px solid #f0f1f3; }
.card-owner { font-size: 13px; color: #555; }
.card-dias { font-size: 12.5px; color: #999; }
.card-dias.alerta { color: var(--perdido); font-weight: 600; }

/* ---------- MODAL ---------- */
.modal-overlay { position: fixed; inset: 0; background: rgba(10,10,10,.6); display: flex; align-items: center; justify-content: center; z-index: 100; padding: 20px; }
.modal-overlay[hidden] { display: none; }
.modal { background: var(--branco); border-radius: 14px; width: 880px; max-width: 96vw; max-height: 92vh; overflow-y: auto; padding: 28px 30px; position: relative; border-top: 4px solid var(--dourado); }
.modal-close { position: absolute; top: 16px; right: 20px; background: none; border: none; font-size: 30px; line-height: 1; color: #aaa; cursor: pointer; }
.modal-close:hover { color: #000; }
.modal-title { font-family: 'Playfair Display', serif; font-size: 26px; margin-bottom: 20px; padding-right: 30px; }
.modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.modal-grid:has(.modal-timeline[hidden]) { grid-template-columns: 1fr; }
.modal-form label { display: block; font-size: 14px; font-weight: 500; color: #444; margin: 13px 0 5px; }
.modal-form input, .modal-form select, .modal-form textarea { width: 100%; padding: 10px 12px; font-size: 16px; border: 1.5px solid var(--borda); border-radius: 8px; font-family: inherit; }
.modal-form input:focus, .modal-form select:focus, .modal-form textarea:focus { outline: none; border-color: var(--dourado); }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.modal-actions { display: flex; justify-content: space-between; gap: 12px; margin-top: 24px; }
.btn-danger { background: #fff; color: var(--perdido); border: 1.5px solid var(--perdido); padding: 11px 18px; border-radius: 8px; font-weight: 600; font-size: 15px; cursor: pointer; }
.btn-danger:hover { background: var(--perdido); color: #fff; }
.modal-actions .btn-primary { margin-left: auto; padding: 11px 26px; }

/* ---------- TIMELINE ---------- */
.modal-timeline h3 { font-size: 17px; margin-bottom: 14px; }
.add-activity { display: flex; gap: 7px; margin-bottom: 16px; }
.add-activity select { width: 110px; padding: 9px; font-size: 15px; border: 1.5px solid var(--borda); border-radius: 8px; }
.add-activity input { flex: 1; padding: 9px 11px; font-size: 15px; border: 1.5px solid var(--borda); border-radius: 8px; }
.btn-sm { background: var(--dourado); border: none; border-radius: 8px; width: 40px; font-size: 22px; font-weight: 700; color: var(--preto); cursor: pointer; }
.timeline { list-style: none; display: flex; flex-direction: column; gap: 14px; max-height: 420px; overflow-y: auto; }
.tl-item { display: flex; gap: 10px; }
.tl-ico { font-size: 16px; flex-shrink: 0; }
.tl-desc { font-size: 15px; }
.tl-meta { font-size: 12.5px; color: var(--cinza); margin-top: 2px; }
.tl-vazio { color: var(--cinza); font-size: 15px; }

/* ---------- TOAST ---------- */
.toast { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%); background: var(--preto); color: #fff; padding: 13px 24px; border-radius: 10px; font-size: 15px; z-index: 200; box-shadow: 0 8px 30px rgba(0,0,0,.4); }
.toast-erro { background: var(--perdido); }

/* ---------- VIEWS / AGENDA (Fase B) ---------- */
.view-pad { padding: 28px 32px; max-width: 1100px; }
.view-title { font-family: 'Playfair Display', serif; font-size: 30px; margin-bottom: 4px; }
.view-sub { color: var(--cinza); font-size: 16px; margin-bottom: 22px; }
.agenda-list { display: flex; flex-direction: column; gap: 12px; }
.ag-card { display: flex; align-items: center; gap: 16px; background: var(--branco); border-radius: 12px; padding: 16px 20px; box-shadow: var(--sombra); border-left: 4px solid var(--cinza); }
.ag-card.ag-realizado { border-left-color: var(--fechado); }
.ag-card.ag-no_show { border-left-color: var(--perdido); }
.ag-card.ag-confirmado { border-left-color: var(--qualificado); }
.ag-card.ag-cancelado { border-left-color: #bbb; opacity: .65; }
.ag-info { flex: 1; }
.ag-nome { font-weight: 600; font-size: 17px; }
.ag-meta { font-size: 14px; color: var(--cinza); margin-top: 3px; }
.ag-status { font-size: 13px; font-weight: 600; padding: 4px 12px; border-radius: 20px; }
.ag-badge-agendado { background: #eee; color: #555; }
.ag-badge-confirmado { background: #dbeafe; color: #1d4ed8; }
.ag-badge-realizado { background: #dcfce7; color: #15803d; }
.ag-badge-no_show { background: #fee2e2; color: #b91c1c; }
.ag-badge-cancelado { background: #f3f4f6; color: #888; }
.ag-acoes { display: flex; gap: 7px; }
.btn-sm2 { background: #fff; border: 1.5px solid var(--borda); border-radius: 7px; padding: 7px 11px; font-size: 13.5px; cursor: pointer; font-family: inherit; }
.btn-sm2:hover { border-color: var(--dourado); }
.btn-sm2.ok:hover { border-color: var(--fechado); color: var(--fechado); }
.btn-sm2.danger:hover { border-color: var(--perdido); color: var(--perdido); }
.btn-ghost.dark { color: #333; border-color: var(--borda); background: var(--branco); }
.btn-ghost.dark:hover { border-color: var(--dourado); color: #000; }

/* ---------- FOLLOW-UP ---------- */
.fu-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.fu-list { display: flex; flex-direction: column; gap: 14px; margin-top: 6px; }
.fu-card { background: var(--branco); border-radius: 12px; padding: 16px 18px; box-shadow: var(--sombra); border-left: 4px solid var(--dourado); }
.fu-card.fu-enviado { border-left-color: var(--fechado); opacity: .8; }
.fu-card.fu-cancelado { display: none; }
.fu-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.fu-nome { font-weight: 600; font-size: 16px; }
.fu-fone { color: var(--cinza); font-size: 14px; margin-left: 8px; }
.fu-badge { font-size: 12.5px; font-weight: 600; padding: 3px 10px; border-radius: 20px; }
.fu-badge-parado { background: #fef3c7; color: #92400e; }
.fu-badge-noshow { background: #fee2e2; color: #b91c1c; }
.fu-badge-parcela { background: #dbeafe; color: #1d4ed8; }
.fu-msg { width: 100%; padding: 11px 13px; font-size: 15px; line-height: 1.5; border: 1.5px solid var(--borda); border-radius: 9px; font-family: inherit; resize: vertical; color: #1a1a1a; }
.fu-msg:focus { outline: none; border-color: var(--dourado); }
.fu-msg-ro { font-size: 15px; line-height: 1.5; color: #555; background: #f8f9fb; border-radius: 9px; padding: 11px 13px; }
.fu-acoes { display: flex; gap: 8px; margin-top: 10px; }
.fu-sent { color: var(--fechado); font-size: 14px; font-weight: 600; margin-bottom: 8px; }

/* ---------- DASHBOARD ---------- */
.dash-pad { max-width: 1200px; }
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin: 8px 0 24px; }
.kpi { background: var(--branco); border-radius: 12px; padding: 18px 20px; box-shadow: var(--sombra); border-top: 3px solid var(--dourado); }
.kpi-val { font-family: 'Playfair Display', serif; font-size: 30px; font-weight: 700; line-height: 1.1; }
.kpi-lbl { color: #444; font-size: 14px; font-weight: 600; margin-top: 4px; }
.kpi-sub { color: var(--cinza); font-size: 13px; margin-top: 2px; }
.dash-charts { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.dash-card { background: var(--branco); border-radius: 12px; padding: 18px 20px; box-shadow: var(--sombra); }
.dash-card-wide { grid-column: 1 / -1; }
.dash-card-title { font-size: 16px; font-weight: 600; margin-bottom: 14px; color: #222; }

/* ---------- MOBILE ---------- */
@media (max-width: 760px) {
  .dash-charts { grid-template-columns: 1fr; }
  .topbar { gap: 12px; padding: 0 14px; }
  .brand-app { display: none; }
  .hamburger { display: block; }
  .user-chip { display: none; }
  #btnSync { display: none; }
  /* topnav vira dropdown sob a topbar */
  .topnav { display: none; position: absolute; top: 62px; left: 0; right: 0; flex-direction: column; gap: 0; background: var(--preto); padding: 8px; border-top: 1px solid #222; z-index: 60; }
  .topnav.open { display: flex; }
  .topnav .nav-item { padding: 14px 16px; font-size: 16px; border-radius: 8px; }
  .nav-extra { display: block; border-top: 1px solid #222; margin-top: 6px; color: var(--dourado-soft); }
  .modal-grid { grid-template-columns: minmax(0, 1fr); }
  .modal-form, .modal-timeline { min-width: 0; }
  .row2 { grid-template-columns: minmax(0, 1fr); }
  .modal-overlay { padding: 10px; }
  .modal { width: 100%; max-width: 100%; padding: 22px 18px; overflow-x: hidden; }
  .col { width: 80vw; flex-basis: 80vw; }
  .view-pad { padding: 18px 16px; }
  .ag-card { flex-wrap: wrap; }
  .ag-acoes { width: 100%; }
  .fu-head { flex-direction: column; }
}
