/* ============================================================================
   Portal Marques & Abreu — Folha de estilos partilhada
   ============================================================================ */
:root{
  color-scheme: light;
  --primary:#9c1c2e;
  --primary-dark:#74121f;
  --primary-light:#fdecef;
  --bg:#f6f4f5;
  --card:#ffffff;
  --border:#e8dfe1;
  --text:#241a1c;
  --muted:#8a7479;
  --green:#15803d;
  --red:#b91c1c;
  --yellow:#b45309;
  --accent:#c0263b;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family: Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--text);
}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--primary);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 20px;
  flex-wrap:wrap;
  gap:10px;
}
.topbar .brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:17px;
  font-weight:bold;
  letter-spacing:.02em;
  text-decoration:none;
  color:#fff;
}
.topbar .brand .logo-dot{
  width:14px;height:14px;border-radius:50%;
  background:#fff;
  display:inline-block;
}
.topbar nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.topbar nav a, .topbar nav button{
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:bold;
  background:rgba(255,255,255,.12);
  border:none;
  padding:8px 14px;
  border-radius:6px;
  cursor:pointer;
}
.topbar nav a:hover, .topbar nav button:hover{background:rgba(255,255,255,.22);}
.topbar .user-info{font-size:12px;opacity:.9;text-align:right;}
.topbar .user-info b{display:block;font-size:13px;}

.page-wrap{padding:20px;max-width:1300px;margin:0 auto;}

h1{font-size:22px;color:var(--primary);margin:0 0 4px 0;}
.subtitle{color:var(--muted);font-size:13px;margin:0 0 16px 0;}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:2px solid var(--border);flex-wrap:wrap;}
.tab-btn{
  background:none;border:none;padding:10px 18px;font-size:14px;font-weight:bold;
  color:var(--muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;
}
.tab-btn.active{color:var(--primary);border-bottom:3px solid var(--primary);}
.tab-content{display:none;}
.tab-content.active{display:block;}

/* ---------- Cards ---------- */
.card{
  background:var(--card);border:1px solid var(--border);border-radius:10px;
  padding:16px;margin-bottom:16px;
}
.card h2{margin:0 0 12px 0;font-size:15px;color:var(--primary);}
.card h3{margin:0 0 8px 0;font-size:13px;color:var(--muted);font-weight:bold;text-transform:uppercase;letter-spacing:.04em;}

/* ---------- KPI ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;}
.kpi-card{background:var(--primary-light);border-radius:8px;padding:14px;text-align:left;}
.kpi-label{font-size:12px;color:var(--muted);margin-bottom:6px;}
.kpi-value{font-size:24px;font-weight:bold;color:var(--primary);}

/* ---------- Charts ---------- */
.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:16px;}
.chart-box{position:relative;height:260px;}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:13px;}
th,td{border:1px solid var(--border);padding:7px 9px;text-align:left;}
th{background:var(--primary);color:#fff;font-weight:bold;font-size:12px;}
tbody tr:nth-child(even){background:#fbf7f8;}
td.num{text-align:right;font-variant-numeric:tabular-nums;}
tfoot td{font-weight:bold;background:var(--primary-light);}
.tables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;}
.scroll-x{overflow-x:auto;}

/* ---------- Badges ---------- */
.badge{padding:3px 9px;border-radius:12px;font-size:11px;font-weight:bold;display:inline-block;}
.badge-Vendido{background:#dcfce7;color:var(--green);}
.badge-Angariado{background:#fdecef;color:var(--primary);}
.badge-Em.Visitas, .badge-EmVisitas{background:#fef3c7;color:var(--yellow);}
.badge-Perdido{background:#fee2e2;color:var(--red);}
.badge-role-admin{background:#fdecef;color:var(--primary);}
.badge-role-editor{background:#fef3c7;color:var(--yellow);}
.badge-role-viewer{background:#f1f5f9;color:var(--muted);}
.badge-role-diretor_comercial{background:#e0e7ff;color:#3730a3;}
.badge-role-pendente{background:#fef3c7;color:var(--yellow);}

/* ---------- Forms ---------- */
form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;}
.field{display:flex;flex-direction:column;}
.field label{font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:bold;line-height:1.3;min-height:28px;display:flex;align-items:flex-end;}
.field input,.field select{padding:7px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit;}
.field-full{grid-column:1/-1;}
.actions-row{grid-column:1/-1;display:flex;gap:8px;margin-top:4px;flex-wrap:wrap;}

/* Form split into multiple sub-card sections (e.g. Adicionar Negocio) */
#deal-form{display:block;}
.form-section{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;
  background:var(--bg);border:1px solid var(--border);border-radius:8px;
  padding:12px;margin-bottom:12px;
}
.form-section h3{grid-column:1/-1;}
.form-section:last-of-type{margin-bottom:16px;}

button{
  background:var(--accent);color:#fff;border:none;padding:9px 16px;border-radius:6px;
  cursor:pointer;font-size:13px;font-weight:bold;
}
button:hover{opacity:.9;}
button.secondary{background:#8a7479;}
button.danger{background:var(--red);}
button.small{padding:4px 10px;font-size:11px;font-weight:normal;margin-right:4px;}
button:disabled{opacity:.5;cursor:not-allowed;}

.empty{color:var(--muted);font-size:13px;font-style:italic;padding:8px 0;}
.note{font-size:12px;color:var(--muted);margin-top:6px;}

.aniversarios-card{margin-top:32px;}

/* ---------- Insights automaticos ---------- */
.insight-item{padding:10px 12px;border-radius:6px;margin-bottom:8px;font-size:13px;line-height:1.4;border-left:4px solid var(--border);background:var(--bg);}
.insight-item:last-child{margin-bottom:0;}
.insight-alerta{background:#fee2e2;border-left-color:var(--red);}
.insight-positivo{background:#dcfce7;border-left-color:var(--green);}
.insight-sugestao{background:#fef3c7;border-left-color:var(--yellow);}

/* ---------- Misc widgets ---------- */
.visit-row{display:flex;align-items:center;gap:3px;white-space:nowrap;font-size:12px;margin-bottom:3px;}
.visit-row:last-child{margin-bottom:0;}
.btn-tiny{background:#f1e7e9;color:var(--text);border:none;width:20px;height:20px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:bold;padding:0;line-height:1;}
.btn-tiny:hover{background:#e8d7da;}
.status-select{padding:4px 6px;border-radius:6px;border:1px solid var(--border);font-size:12px;font-weight:bold;font-family:inherit;cursor:pointer;}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;}
.modal-overlay.hidden{display:none;}
.modal-box{background:#fff;border-radius:10px;padding:20px;max-width:380px;width:90%;box-shadow:0 10px 30px rgba(0,0,0,.25);}
.modal-box.modal-wide{max-width:760px;}
.modal-box h3{margin:0 0 10px 0;color:var(--primary);font-size:16px;}
.modal-box p{margin:0 0 12px 0;font-size:13px;line-height:1.4;}
.modal-box .field{margin-bottom:4px;}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px;}

.list-manager{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.chip{background:var(--primary-light);border-radius:14px;padding:4px 10px 4px 12px;font-size:12px;display:flex;align-items:center;gap:6px;}
.chip button{background:none;color:var(--red);padding:0;font-size:14px;font-weight:bold;line-height:1;}
.add-row{display:flex;gap:8px;}
.add-row input{flex:1;padding:7px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;}

/* ---------- Login page ---------- */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  padding:20px;
}
.login-box{
  background:#fff;border-radius:14px;padding:34px 30px;max-width:380px;width:100%;
  box-shadow:0 20px 50px rgba(0,0,0,.25);
}
.login-box h1{text-align:center;margin-bottom:4px;}
.login-box .subtitle{text-align:center;margin-bottom:22px;}
.login-box form{grid-template-columns:1fr;gap:12px;}
.login-box button[type="submit"]{margin-top:6px;width:100%;padding:11px;font-size:14px;}
.login-switch{text-align:center;font-size:12px;color:var(--muted);margin-top:16px;}
.login-switch a{color:var(--accent);font-weight:bold;text-decoration:none;cursor:pointer;}
.login-error{background:#fee2e2;color:var(--red);border-radius:6px;padding:9px 12px;font-size:12px;margin-bottom:12px;display:none;}
.login-success{background:#dcfce7;color:var(--green);border-radius:6px;padding:9px 12px;font-size:12px;margin-bottom:12px;display:none;}

/* ---------- Home / module cards ---------- */
.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:18px;}
.module-card{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:24px;text-decoration:none;color:var(--text);
  transition:box-shadow .15s, transform .15s;
  display:block;
}
.module-card:hover{box-shadow:0 8px 24px rgba(156,28,46,.15);transform:translateY(-2px);}
.module-card .module-icon{font-size:30px;margin-bottom:10px;display:block;}
.module-card h2{color:var(--primary);font-size:17px;margin:0 0 6px 0;}
.module-card p{color:var(--muted);font-size:13px;margin:0;line-height:1.4;}
.module-card.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;}
.module-card .tag{
  display:inline-block;background:var(--primary-light);color:var(--primary);
  font-size:10px;font-weight:bold;text-transform:uppercase;letter-spacing:.05em;
  padding:2px 8px;border-radius:10px;margin-bottom:8px;
}

/* ---------- Loading ---------- */
.loading-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:14px;
}
