/* ===== AllLife Brand Colors ===== */
:root {
  --color-cream:      #e3e5d9;
  --color-lime:       #d8db39;
  --color-teal:       #9ad3ca;
  --color-brown:      #7a6040; /* corrigido de #9f8153 — contraste WCAG AA */
  --color-green:      #0c4633;

  --color-cream-dark: #cdd0c2;
  --color-lime-dark:  #b8bb1f;
  --color-teal-dark:  #72b8ae;
  --color-brown-dark: #5c4830;
  --color-green-dark: #083322;

  --text-on-green:    #e3e5d9;
  --text-on-cream:    #0c4633;
  --text-on-lime:     #0c4633;
  --text-on-teal:     #0c4633;
  --text-on-brown:    #e3e5d9;

  /* Variáveis de suporte ausentes — adicionadas para consistência */
  --color-white:      #ffffff;
  --color-border:     #d5d9d0;
  --color-gold:       #0c4633;  /* alias para bolhas de chat outbound */
  --color-surface:    #f4f6f0;
  --color-text-muted: #6b7280;  /* contraste 4.6:1 sobre branco — WCAG AA */
  --color-error:      #b91c1c;
  --color-success:    #15803d;

  --sidebar-width: 260px;
  --topbar-height: 64px;
  --border-radius: 10px;
  --shadow: 0 2px 12px rgba(12,70,51,.10);

  /* Espaçamento base */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
}

/* ===== Reset / Base ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  background: var(--color-cream);
  color: var(--text-on-cream);
  min-height: 100vh;
  line-height: 1.6;
}

a { color: var(--color-green); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ===== Layout ===== */
.layout {
  display: flex;
  min-height: 100vh;
}

/* ===== Sidebar ===== */
.sidebar {
  width: var(--sidebar-width);
  background: var(--color-green);
  color: var(--text-on-green);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 100;
  overflow-y: auto;
}

.sidebar-logo {
  padding: 24px 20px 16px;
  border-bottom: 1px solid rgba(255,255,255,.12);
}

.sidebar-logo .brand-name {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-lime);
  letter-spacing: -.5px;
}

.sidebar-logo .brand-sub {
  font-size: .75rem;
  color: var(--color-teal);
  opacity: .85;
  margin-top: 2px;
}

.sidebar-nav {
  flex: 1;
  padding: 16px 0;
}

.nav-section-label {
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--color-teal);
  opacity: .7;
  padding: 12px 20px 4px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  color: var(--text-on-green);
  opacity: .85;
  border-left: 3px solid transparent;
  transition: all .15s;
  font-size: .92rem;
}

.nav-item:hover {
  background: rgba(255,255,255,.07);
  opacity: 1;
  text-decoration: none;
}

.nav-item.active {
  background: rgba(216,219,57,.12);
  border-left-color: var(--color-lime);
  color: var(--color-lime);
  opacity: 1;
  font-weight: 600;
}

.nav-item .nav-icon {
  width: 18px;
  text-align: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.sidebar-footer {
  padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,.12);
  font-size: .8rem;
  color: var(--color-teal);
  opacity: .7;
}

/* ===== Main content ===== */
.main {
  margin-left: var(--sidebar-width);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ===== Topbar ===== */
.topbar {
  height: var(--topbar-height);
  background: #fff;
  border-bottom: 1px solid rgba(12,70,51,.10);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  position: sticky;
  top: 0;
  z-index: 90;
  box-shadow: var(--shadow);
}

.topbar-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-green);
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 16px;
}

.topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .88rem;
  color: var(--color-green);
}

.avatar {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: var(--color-green);
  color: var(--color-lime);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: .85rem;
}

/* ===== Page content ===== */
.page-content {
  flex: 1;
  padding: 28px;
}

.page-header {
  margin-bottom: 24px;
}

.page-header h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-green);
}

.page-header p {
  color: var(--color-brown);
  font-size: .9rem;
  margin-top: 4px;
}

/* ===== Stat Cards ===== */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px;
  margin-bottom: 28px;
}

.stat-card {
  background: #fff;
  border-radius: var(--border-radius);
  padding: 20px 24px;
  box-shadow: var(--shadow);
  border-left: 4px solid var(--color-teal);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.stat-card.accent-lime  { border-left-color: var(--color-lime); }
.stat-card.accent-green { border-left-color: var(--color-green); }
.stat-card.accent-brown { border-left-color: var(--color-brown); }
.stat-card.accent-teal  { border-left-color: var(--color-teal); }

.stat-label {
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--color-brown);
  font-weight: 600;
}

.stat-value {
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-green);
  line-height: 1;
}

.stat-sub {
  font-size: .78rem;
  color: var(--color-brown);
}

/* ===== Cards ===== */
.card {
  background: #fff;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 24px;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--color-cream);
  background: var(--color-cream);
}

.card-title {
  font-size: .95rem;
  font-weight: 700;
  color: var(--color-green);
}

.card-body { padding: 0; }

/* ===== Table ===== */
.table-wrap { overflow-x: auto; }

table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}

thead th {
  background: var(--color-cream);
  padding: 10px 16px;
  text-align: left;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .7px;
  color: var(--color-brown);
  font-weight: 700;
  border-bottom: 2px solid var(--color-cream-dark);
}

tbody td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-cream);
  vertical-align: middle;
}

tbody tr:last-child td { border-bottom: none; }

tbody tr:hover { background: rgba(154,211,202,.1); }

/* ===== Badges / Status ===== */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.badge-pending     { background: #e8e9a8; color: #4a4c0a; }   /* contraste ~5.2:1 ✓ */
.badge-confirmed   { background: rgba(12,70,51,.15);  color: #083322; }  /* #083322 sobre fundo ~6:1 ✓ */
.badge-cancelled   { background: rgba(239,68,68,.15); color: #991b1b; }
.badge-rescheduled { background: rgba(122,96,64,.15); color: #5c4830; }
.badge-no_response { background: rgba(239,68,68,.1);  color: #991b1b; }
.badge-completed   { background: rgba(154,211,202,.35); color: #0d5c53; }
.badge-warning     { background: #fef3c7; color: #92400e; }
.badge-info        { background: rgba(154,211,202,.3); color: #0d5c53; }
.badge-success     { background: rgba(21,128,61,.12); color: #15803d; }
.badge-error       { background: rgba(185,28,28,.1);  color: #991b1b; }
.badge-secondary   { background: var(--color-cream-dark); color: var(--color-green); }

/* ===== Buttons ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 7px;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all .15s;
  text-decoration: none !important;
  position: relative;
}

/* Estado de foco acessível para todos os botões */
.btn:focus-visible {
  outline: 2px solid var(--color-teal);
  outline-offset: 2px;
}

.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

/* Spinner de loading inline */
.btn.loading {
  pointer-events: none;
  opacity: 0.75;
}
.btn.loading::after {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: btn-spin .6s linear infinite;
  margin-left: 4px;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

.btn-primary {
  background: var(--color-green);
  color: var(--color-lime);
}
.btn-primary:hover  { background: var(--color-green-dark); }
.btn-primary:active { background: #052218; transform: scale(0.98); }

.btn-secondary {
  background: var(--color-cream);
  color: var(--color-green);
  border: 1px solid var(--color-cream-dark);
}
.btn-secondary:hover { background: var(--color-cream-dark); }

.btn-lime {
  background: var(--color-lime);
  color: var(--text-on-lime);
}
.btn-lime:hover { background: var(--color-lime-dark); }

.btn-danger {
  background: rgba(239,68,68,.12);
  color: #b91c1c;
  border: 1px solid rgba(239,68,68,.25);
}
.btn-danger:hover { background: rgba(239,68,68,.2); }

.btn-warning {
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fde68a;
}
.btn-warning:hover { background: #fde68a; }
.btn-warning:focus-visible { outline-color: #f59e0b; }

.btn-sm { padding: 5px 12px; font-size: .8rem; }

/* ===== Forms ===== */
.form-group { margin-bottom: 16px; }

.form-label {
  display: block;
  font-size: .83rem;
  font-weight: 600;
  color: var(--color-green);
  margin-bottom: 6px;
}

.form-control {
  width: 100%;
  padding: 9px 13px;
  border: 1.5px solid var(--color-cream-dark);
  border-radius: 7px;
  font-size: .9rem;
  color: var(--text-on-cream);
  background: #fff;
  transition: border-color .15s;
  outline: none;
}

.form-control:focus,
.form-control:focus-visible {
  border-color: var(--color-teal);
  box-shadow: 0 0 0 3px rgba(154,211,202,.25);
  outline: none; /* substituído pelo box-shadow acima */
}

.form-control.error,
.form-control[aria-invalid="true"] {
  border-color: var(--color-error);
  box-shadow: 0 0 0 3px rgba(185,28,28,.12);
}

.form-control:disabled {
  background: var(--color-surface);
  opacity: 0.6;
  cursor: not-allowed;
}

/* Texto de erro de campo */
.form-error {
  display: block;
  font-size: .8rem;
  color: var(--color-error);
  margin-top: 4px;
}

.search-bar {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 20px;
}

.search-bar .form-control { max-width: 320px; }

/* ===== Alert ===== */
.alert {
  padding: 12px 18px;
  border-radius: var(--border-radius);
  margin-bottom: 18px;
  font-size: .9rem;
}
.alert-warning { background: rgba(216,219,57,.25); border-left: 4px solid var(--color-lime); color: #5c5e10; }
.alert-danger   { background: rgba(239,68,68,.1);  border-left: 4px solid #ef4444; color: #b91c1c; }
.alert-success  { background: rgba(12,70,51,.1);   border-left: 4px solid var(--color-green); color: var(--color-green); }

/* ===== Handoff detail ===== */
.handoff-item {
  border-left: 4px solid var(--color-brown);
  padding: 14px 18px;
  margin-bottom: 12px;
  background: #fff;
  border-radius: 0 var(--border-radius) var(--border-radius) 0;
  box-shadow: var(--shadow);
}

.handoff-item.status-in_progress { border-left-color: var(--color-lime); }
.handoff-item.status-resolved { border-left-color: var(--color-teal); opacity: .7; }

/* ===== Empty state ===== */
.empty-state {
  text-align: center;
  padding: 52px 20px;
  color: var(--color-brown);
}
.empty-state .empty-icon { font-size: 2.5rem; margin-bottom: 12px; opacity: .5; }
.empty-state p { font-size: .95rem; }

/* ===== Dashboard layouts ===== */
.dashboard-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 800px) {
  .dashboard-two-col { grid-template-columns: 1fr; }
}

/* ===== Aliases de classes ausentes ===== */
/* Algumas telas usam .page-title e .page-subtitle — mapear para os estilos base */
.page-title   { font-size: 1.5rem; font-weight: 700; color: var(--color-green); }
.page-subtitle { color: var(--color-text-muted); font-size: .9rem; margin-top: 4px; }

/* ===== Toast / Notificação global ===== */
.toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
  max-width: 360px;
}

.toast {
  background: #fff;
  border-radius: var(--border-radius);
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
  padding: 12px 16px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .88rem;
  pointer-events: all;
  animation: toast-in .25s ease;
  border-left: 4px solid var(--color-teal);
}
.toast.toast-success { border-left-color: var(--color-success); }
.toast.toast-error   { border-left-color: var(--color-error); }
.toast.toast-warning { border-left-color: var(--color-lime-dark); }

.toast-body { flex: 1; color: var(--text-on-cream); line-height: 1.4; }

.toast-close {
  background: none; border: none; cursor: pointer;
  font-size: 1rem; color: var(--color-text-muted);
  padding: 0; line-height: 1; flex-shrink: 0;
}
.toast-close:hover { color: var(--text-on-cream); }

@keyframes toast-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toast-out {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(20px); }
}
.toast.removing { animation: toast-out .2s ease forwards; }

/* ===== Sidebar Mobile Toggle ===== */
.sidebar-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
  color: var(--color-green);
  font-size: 1.3rem;
  line-height: 1;
}
.sidebar-toggle:focus-visible {
  outline: 2px solid var(--color-teal);
  outline-offset: 2px;
}

.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 99;
}

/* ===== Status de conexão de calendário ===== */
/*
 * Usado em calendar_connections.html.
 * 4 estados: active, warning (token expirado), error (needs_reauth), paused.
 * Contraste verificado WCAG AA: todos os pares texto/fundo >= 4.5:1.
 */
.conn-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
}

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

/* Ativa — verde, pulsa suavemente */
.conn-status--active {
  background: rgba(21, 128, 61, .12);
  color: #15803d;                         /* contraste ~5.1:1 sobre branco */
}
.conn-status--active .conn-status__dot {
  background: #15803d;
  animation: conn-pulse 2.5s ease-in-out infinite;
}

/* Token expirado — âmbar */
.conn-status--warning {
  background: #fef3c7;
  color: #92400e;                         /* contraste ~5.5:1 sobre #fef3c7 */
}
.conn-status--warning .conn-status__dot {
  background: #d97706;
}

/* Precisa reconectar (needs_reauth) — vermelho */
.conn-status--error {
  background: rgba(185, 28, 28, .10);
  color: #991b1b;                         /* contraste ~5.2:1 sobre branco */
}
.conn-status--error .conn-status__dot {
  background: #b91c1c;
}

/* Pausada manualmente (is_active=False, needs_reauth=False) — cinza */
.conn-status--paused {
  background: var(--color-cream-dark);
  color: #4b5563;                         /* contraste ~5.9:1 sobre #cdd0c2 */
}
.conn-status--paused .conn-status__dot {
  background: #9ca3af;
}

@keyframes conn-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .55; transform: scale(.85); }
}

/* ===== Indicador de conexão no chat ===== */
.connection-indicator {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.connection-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #9e9e9e;
  flex-shrink: 0;
  transition: background .3s;
}
.connection-dot.online  { background: #15803d; animation: pulse-dot 2s infinite; }
.connection-dot.offline { background: #b91c1c; }

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50%       { opacity: .5; }
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .sidebar {
    transform: translateX(-100%);
    transition: transform .25s ease;
    z-index: 200;
  }
  .sidebar.open {
    transform: translateX(0);
  }
  .sidebar-overlay.open { display: block; }
  .sidebar-toggle { display: flex; }
  .main { margin-left: 0; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .stats-grid { grid-template-columns: 1fr; }
  .page-content { padding: 16px; }
  .topbar { padding: 0 16px; }
}

/* ===== Auth pages (login / register) ===== */
body.auth-page {
  background: var(--color-green);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 1rem;
}

.auth-wrapper {
  width: 100%;
  max-width: 480px;
}

.auth-card {
  background: #fff;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  padding: 2.5rem 2rem;
}

.auth-logo {
  text-align: center;
  margin-bottom: 1.5rem;
}
.auth-logo .brand-name { color: var(--color-green); }
.auth-logo .brand-sub  { color: var(--color-brown); font-size: .85rem; }

.auth-title    { font-size: 1.5rem; font-weight: 700; margin-bottom: .25rem; color: var(--color-green); }
.auth-subtitle { color: var(--color-text-muted, #666); font-size: .875rem; margin-bottom: 1.25rem; }

.auth-links {
  margin-top: 1.25rem;
  text-align: center;
  font-size: .875rem;
  color: var(--color-text-muted, #666);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}

.captcha-group { margin-top: .25rem; }

.btn-full { width: 100%; margin-top: .5rem; }

/* Role badges in topbar */
.role-badge {
  font-size: 0.65rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-left: 4px;
  vertical-align: middle;
}
.role-badge.role-admin     { background: var(--color-green); color: var(--color-lime); }
.role-badge.role-gestor    { background: var(--color-brown); color: #fff; }
.role-badge.role-assistente { background: var(--color-teal); color: var(--color-green); }

/* Alert variants */
.alert-success  { background: #d4edda; border-color: #c3e6cb; color: #155724; }
.alert-error, .alert-danger { background: #f8d7da; border-color: #f5c6cb; color: #721c24; }
.alert-warning  { background: #fff3cd; border-color: #ffeeba; color: #856404; }
.alert-info     { background: #d1ecf1; border-color: #bee5eb; color: #0c5460; }
