/* Neumann Partners · Design System
 * Paleta: Deep Navy (#0B2A4A) → Medium Blue (#3365A0)
 * Filosofia: Enterprise medical consulting · Clean · Minimalista
 */

:root {
  --color-bg: #FFFFFF;
  --color-bg-subtle: #F5F7FA;
  --color-bg-muted: #EFEFEF;
  --color-surface: #FFFFFF;
  --color-border: #E5E7EB;
  --color-border-strong: #D1D5DB;

  /* Marca · gradiente de navy a azul-médio */
  --brand-deep:      #0B2A4A;       /* Navy profundo (início do gradiente) */
  --brand-mid:       #1E4876;       /* Navy médio (centro do gradiente) */
  --brand-light:     #3365A0;       /* Azul médio (final do gradiente) */
  --brand-gradient:  linear-gradient(135deg, #0B2A4A 0%, #1E4876 50%, #3365A0 100%);

  /* Tokens de UI derivados da marca */
  --color-primary:        #1E4A7C;   /* Azul corporativo · botões, ações */
  --color-primary-hover:  #153C64;
  --color-primary-subtle: #EEF4FC;
  --color-primary-text:   #0F2D4D;

  --color-text: #212121;
  --color-text-secondary: #4B5563;
  --color-text-muted: #6B7280;
  --color-text-inverse: #FFFFFF;

  --color-success: #047857;
  --color-success-bg: #ECFDF5;
  --color-warning: #B45309;
  --color-warning-bg: #FFFBEB;
  --color-danger: #B91C1C;
  --color-danger-bg: #FEF2F2;
  --color-info: #1D4ED8;
  --color-info-bg: #EFF6FF;

  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;

  --shadow-sm: 0 1px 2px rgba(17, 24, 39, 0.04);
  --shadow-md: 0 2px 8px rgba(17, 24, 39, 0.06);
  --shadow-lg: 0 8px 24px rgba(17, 24, 39, 0.08);

  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --sidebar-width: 240px;
  --topbar-height: 56px;
  --subnav-height: 48px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Links herdam a cor do texto · teal fica reservado para elementos de marca/ação.
 * Cor em letra (verde ou vermelha) carrega carga semântica de status (positivo/negativo)
 * e confunde com badges de confirmação/erro.
 */
a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; text-decoration-color: var(--color-border-strong); text-underline-offset: 3px; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; font-size: inherit; }

/* Icon default · qualquer SVG sem tamanho específico renderiza pequeno */
svg { width: 16px; height: 16px; flex-shrink: 0; vertical-align: middle; }

/* ========== APP SHELL ========== */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  grid-template-rows: var(--topbar-height) 1fr;
  height: 100vh;
}

/* ========== TOPBAR ========== */
.topbar {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  padding: 0;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  z-index: 10;
}

/* Brand area: toda a faixa esquerda do topbar É o logo.
 * Gradiente oficial da marca + Montserrat branco.
 */
.brand-wrap { position: relative; flex-shrink: 0; z-index: 15; }
.brand {
  width: var(--sidebar-width);
  height: var(--topbar-height);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  padding: 0 12px 0 20px;
  flex-shrink: 0;
  background: var(--brand-gradient);
  color: white;
  position: relative;
  box-shadow: inset -1px 0 0 rgba(0,0,0,0.06);
  cursor: pointer;
  text-align: left;
  border: none;
  font-family: inherit;
  transition: background 0.15s;
}
.brand::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top left, rgba(255,255,255,0.10) 0%, transparent 65%);
  pointer-events: none;
}
.brand:hover { background: var(--brand-gradient), rgba(255,255,255,0.05); }
.brand-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.brand-info .brand-name,
.brand-info .brand-tagline {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}
.brand-chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  border-radius: 4px;
  background: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.85);
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  transition: all 0.15s;
}
.brand-chev svg { width: 14px; height: 14px; }
.brand:hover .brand-chev { background: rgba(255,255,255,0.22); color: white; }

/* Badge "DEMO" usado em BUs fictícias (no topbar fica branca translúcida) */
.bu-badge {
  display: inline-flex;
  align-items: center;
  padding: 1px 5px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.22);
  color: white;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-left: 4px;
  vertical-align: middle;
  flex-shrink: 0;
}
/* Quando usada no dropdown ou página de gestão (fundo claro) · versão colorida */
.bu-dropdown .bu-badge,
.bu-grid .bu-badge {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  border: 1px solid #FDE68A;
}

/* Dropdown do switcher de BU · posicionado abaixo do topbar, sempre acima do conteúdo */
.bu-dropdown {
  position: fixed;
  left: 12px;
  right: auto;
  top: calc(var(--topbar-height) - 2px);
  min-width: 320px;
  max-width: 380px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 28px rgba(17, 24, 39, 0.18);
  padding: 6px 0;
  z-index: 2000;
}
.bu-item { display: flex; align-items: center; gap: 10px; padding: 10px 14px; cursor: pointer; }
.bu-item:hover { background: var(--color-bg-subtle); }
.bu-item-logo {
  width: 34px; height: 34px;
  border-radius: 6px;
  background: var(--color-bg-subtle);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
}
.bu-item-logo img { width: 100%; height: 100%; object-fit: contain; padding: 4px; background: white; }
.bu-item-current { background: var(--color-primary-subtle); }
.bu-item-current:hover { background: var(--color-primary-subtle); }
.text-success { color: var(--color-success); }

/* Grid de cards de BU na página de gestão */
.bu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}
.bu-card {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all 0.12s ease-out;
}
.bu-card-current {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 1px var(--color-primary);
}
.bu-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
}
.bu-card-logo {
  width: 44px; height: 44px;
  background: white;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
}
.bu-card-logo img { width: 100%; height: 100%; object-fit: contain; padding: 6px; }
.bu-card-body { padding: 14px 16px; }
.bu-card-footer {
  display: flex;
  gap: 6px;
  padding: 10px 12px;
  border-top: 1px solid var(--color-border);
  background: white;
  justify-content: flex-end;
}
.brand::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top left, rgba(255,255,255,0.10) 0%, transparent 65%);
  pointer-events: none;
}
.brand:hover { text-decoration: none; }

.brand-name {
  font-family: 'Montserrat', 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: white;
  letter-spacing: 0.1px;
  line-height: 1.1;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}
.brand-tagline {
  font-family: 'Montserrat', 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.78);
  letter-spacing: 0.2px;
  line-height: 1.1;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}

/* Resto do topbar tem seu próprio padding interno */
.topbar > .global-search { margin-left: 20px; flex: 1; }
.topbar > .topbar-actions { margin-right: 20px; margin-left: auto; }

.global-search {
  flex: 1;
  max-width: 520px;
  position: relative;
}

.global-search input {
  width: 100%;
  padding: 8px 12px 8px 34px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-subtle);
  outline: none;
  transition: all 0.15s;
}

.global-search input:focus {
  background: white;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(30, 74, 124, 0.18);
}

.global-search::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat center / contain;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

.icon-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  position: relative;
  transition: background 0.15s;
}

.icon-btn:hover { background: var(--color-bg-subtle); }
.icon-btn svg { width: 18px; height: 18px; }
.icon-btn-dialer { color: var(--color-success); }
.icon-btn-dialer:hover { background: var(--color-success-bg); color: var(--color-success); }

/* Logo Meet dentro de botões de texto */
.btn-meet-logo { display: inline-flex; align-items: center; margin-right: 2px; }
.btn-meet-logo .meet-logo-img { width: 14px; height: 14px; }
.cal-legend-meet { display: inline-flex; align-items: center; margin-left: 4px; }
.cal-legend-meet .meet-logo-img { width: 12px; height: 12px; }

/* Reordenar menu lateral */
.nav-reorder-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  margin-top: 8px;
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  background: transparent;
  border: 1px dashed var(--color-border);
  width: 100%;
  transition: all 0.12s;
}
.nav-reorder-toggle:hover { background: var(--color-bg-subtle); color: var(--color-text); border-color: var(--color-border-strong); }
.nav-reorder-toggle svg { width: 12px; height: 12px; }
.nav-reorder-active .nav-reorder-toggle {
  background: var(--color-primary-subtle);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-style: solid;
}
.nav-reorder-active .nav-item {
  cursor: grab;
  border: 1px dashed transparent;
}
.nav-reorder-active .nav-item:hover { border-color: var(--color-border-strong); background: var(--color-bg-subtle); }
.nav-grip {
  color: var(--color-text-muted);
  font-size: 14px;
  letter-spacing: -2px;
  margin-right: 2px;
  cursor: grab;
}
.nav-item.nav-dragging { opacity: 0.4; cursor: grabbing; }
.nav-reorder-active .nav-item { position: relative; }
/* Linha azul indicando onde o item será inserido */
.nav-item.nav-drop-before::before,
.nav-item.nav-drop-after::after {
  content: '';
  position: absolute;
  left: 4px; right: 4px;
  height: 3px;
  background: var(--color-primary);
  border-radius: 2px;
  box-shadow: 0 0 0 3px var(--color-primary-subtle);
  z-index: 10;
}
.nav-item.nav-drop-before::before { top: -2px; }
.nav-item.nav-drop-after::after { bottom: -2px; }

.badge-dot {
  position: absolute;
  top: 8px;
  right: 9px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-danger);
  border: 2px solid var(--color-surface);
}

.avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--brand-gradient);
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 12px;
}

/* ========== SIDEBAR ========== */
.sidebar {
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  overflow-y: auto;
  padding: 12px 0;
}

.nav-group { padding: 0 8px 12px; }

.nav-group-title {
  padding: 8px 12px 4px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: 13.5px;
  font-weight: 500;
  transition: all 0.12s;
}

.nav-item:hover { background: var(--color-bg-subtle); color: var(--color-text); }

.nav-item.active {
  background: var(--color-primary-subtle);
  color: var(--color-text);
  font-weight: 600;
}
.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0; top: 8px; bottom: 8px;
  width: 3px;
  background: var(--color-primary);
  border-radius: 0 2px 2px 0;
}
.nav-item { position: relative; }

.nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }

.nav-item .count {
  margin-left: auto;
  font-size: 11px;
  color: var(--color-text-muted);
  background: var(--color-bg-muted);
  padding: 1px 8px;
  border-radius: 10px;
  font-weight: 600;
}

/* ========== MAIN CONTENT ========== */
.main {
  overflow-y: auto;
  background: var(--color-bg);
}

.subnav {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  height: var(--subnav-height);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 4px;
  overflow-x: auto;
}

.subnav-tab {
  padding: 8px 14px;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  font-weight: 500;
  font-size: 13.5px;
  cursor: pointer;
  white-space: nowrap;
}

.subnav-tab:hover { background: var(--color-bg-subtle); }
.subnav-tab.active { color: var(--color-text); background: var(--color-primary-subtle); font-weight: 600; }

.page {
  padding: 28px 32px;
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
/* Cada filho direto da página já ganha espaçamento automático via gap · sem margin-bottom conflitantes */
.page > * { margin: 0; }

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.page-title {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.3px;
  color: var(--color-text);
}

.page-subtitle {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-top: 2px;
}

.breadcrumbs {
  font-size: 12px;
  color: var(--color-text-muted);
  margin-bottom: 6px;
}

.breadcrumbs a { color: var(--color-text-muted); }

/* ========== BUTTONS ========== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  border: 1px solid transparent;
  transition: all 0.15s;
  white-space: nowrap;
}

.btn-primary { background: var(--color-primary); color: white; }
.btn-primary:hover { background: var(--color-primary-hover); }

.btn-secondary { background: var(--color-surface); color: var(--color-text); border-color: var(--color-border-strong); }
.btn-secondary:hover { background: var(--color-bg-subtle); }

.btn-ghost { color: var(--color-text-secondary); }
.btn-ghost:hover { background: var(--color-bg-subtle); color: var(--color-text); }

.btn-sm { padding: 6px 10px; font-size: 12px; }
.btn svg { width: 14px; height: 14px; }

/* ========== CARDS ========== */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

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

.card-title { font-size: 13px; font-weight: 600; letter-spacing: -0.1px; color: var(--color-text); }
.card-body { padding: 18px; }

/* ========== KPI GRID ========== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.kpi-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 18px 20px;
  position: relative;
}
/* Semáforo · indicado apenas pela barra de progresso (sem faixa lateral) */
.kpi-card-success, .kpi-card-warning, .kpi-card-danger { border-left: 1px solid var(--color-border); }

.kpi-meta { margin-top: 10px; }
.kpi-bar {
  width: 100%;
  height: 6px;
  background: var(--color-bg-muted);
  border-radius: 3px;
  overflow: hidden;
}
.kpi-bar-fill { height: 100%; border-radius: 3px; transition: width 0.4s ease-out; }
.kpi-bar-success { background: var(--color-success); }
.kpi-bar-warning { background: var(--color-warning); }
.kpi-bar-danger  { background: var(--color-danger); }
.kpi-meta-label {
  font-size: 10.5px;
  color: var(--color-text-muted);
  margin-top: 5px;
  font-weight: 500;
}

/* Velocímetro · gauge semicircular */
.velocimetros-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}
.velocimetro {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 14px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.velocimetro-svg { width: 100%; max-width: 220px; height: auto; }
.velocimetro-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding-top: 8px;
  border-top: 1px solid var(--color-border);
  margin-top: 4px;
}
.velocimetro-label { font-size: 12.5px; font-weight: 600; color: var(--color-text); }
.velocimetro-pct { font-size: 16px; font-weight: 700; font-variant-numeric: tabular-nums; }

.kpi-label {
  font-size: 12px;
  color: var(--color-text-muted);
  font-weight: 500;
}

.kpi-value {
  font-size: 26px;
  font-weight: 600;
  color: var(--color-text);
  margin-top: 6px;
  letter-spacing: -0.6px;
}

/* ========== LAYOUT HELPERS ========== */
.row { display: flex; gap: 16px; }
.col { flex: 1; min-width: 0; }
.stack { display: flex; flex-direction: column; gap: 16px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid-sidebar { display: grid; grid-template-columns: 1fr 320px; gap: 16px; }

@media (max-width: 1100px) { .grid-sidebar { grid-template-columns: 1fr; } }

/* ========== TABLE ========== */
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.table th {
  text-align: left;
  padding: 10px 18px;
  background: transparent;
  color: var(--color-text-muted);
  font-weight: 500;
  font-size: 11.5px;
  letter-spacing: 0.2px;
  border-bottom: 1px solid var(--color-border);
}

.table td {
  padding: 12px 18px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
}

.table tr:last-child td { border-bottom: none; }
.table tr:hover td { background: var(--color-bg-subtle); }
.table a { color: var(--color-text); font-weight: 500; }
.table a:hover { text-decoration: underline; text-decoration-color: var(--color-border-strong); text-underline-offset: 3px; }

/* Cabeçalho ordenável · <th class="th-sort"> */
.th-sort { cursor: pointer; user-select: none; transition: background 0.1s; }
.th-sort:hover { background: var(--color-bg-subtle); }
.th-sort-inner { display: inline-flex; align-items: center; gap: 6px; }
.th-arrow {
  font-size: 10px;
  color: var(--color-text-muted);
  opacity: 0.5;
  transition: opacity 0.12s;
}
.th-sort:hover .th-arrow { opacity: 1; }
.th-sort-active { color: var(--color-primary); }
.th-sort-active .th-arrow { opacity: 1; color: var(--color-primary); }

/* Botões dentro de tabela · preservam suas cores próprias (sobrescreve .table a) */
.table a.btn { text-decoration: none; font-weight: 600; }
.table a.btn-primary,   .table a.btn-primary:hover   { color: white; }
.table a.btn-secondary, .table a.btn-secondary:hover { color: var(--color-text); text-decoration: none; }
.table a.btn-ghost,     .table a.btn-ghost:hover     { color: var(--color-text-secondary); text-decoration: none; }

/* ========== BADGE / STATUS (enterprise pill com dot) ========== */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: 4px;
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1.4;
  background: var(--color-surface);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  white-space: nowrap;
}
.badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.badge-success { color: var(--color-success); }
.badge-warning { color: var(--color-warning); }
.badge-danger  { color: var(--color-danger); }
.badge-info    { color: var(--color-info); }
.badge-neutral { color: var(--color-text-muted); }

.tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  white-space: nowrap;
}

/* ========== ALERT ========== */
.alert {
  padding: 10px 14px;
  border-radius: var(--radius-md);
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 12.5px;
  line-height: 1.45;
  border: 1px solid;
}

.alert svg { width: 14px; height: 14px; margin-top: 2px; }

.alert-danger { background: var(--color-danger-bg); color: var(--color-danger); border-color: #FECACA; }
.alert-warning { background: var(--color-warning-bg); color: var(--color-warning); border-color: #FDE68A; }
.alert-info { background: var(--color-info-bg); color: var(--color-info); border-color: #BFDBFE; }

.alert-title { font-weight: 600; margin-bottom: 1px; }

/* ========== AGENDA · visão semana (grid 7 colunas × slots 30min) ========== */
.calendar-wrap {
  display: grid;
  grid-template-columns: 68px repeat(7, 1fr);
  border-top: 1px solid var(--color-border);
  background: white;
}
.cal-corner { background: var(--color-bg-subtle); border-right: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.cal-h {
  padding: 10px 8px;
  background: var(--color-bg-subtle);
  border-bottom: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
  text-align: center;
  color: var(--color-text-secondary);
}
.cal-h:last-child { border-right: none; }
.cal-h-label { font-size: 10.5px; font-weight: 600; letter-spacing: 0.4px; text-transform: uppercase; }
.cal-h-day { font-size: 18px; font-weight: 600; color: var(--color-text); margin-top: 2px; }
.cal-h.today { background: var(--color-primary-subtle); }
.cal-h.today .cal-h-day {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--color-primary); color: white;
}

.cal-time {
  padding: 2px 8px 0; font-size: 10.5px; color: var(--color-text-muted);
  border-right: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border);
  text-align: right; line-height: 1;
}
.cal-cell {
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  min-height: 44px; position: relative;
  transition: background 0.12s ease-out;
}
.cal-cell:nth-child(8n) { border-right: none; }
.cal-cell-free { cursor: pointer; }
.cal-cell-free:hover {
  background: var(--color-primary-subtle);
  box-shadow: inset 0 0 0 1px var(--color-primary);
}
.cal-cell-free:hover::after {
  content: '+ Agendar';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.2px;
}

.cal-event {
  position: absolute;
  left: 3px;
  right: 3px;
  border-radius: 4px;
  padding: 5px 8px;
  font-size: 11px;
  line-height: 1.3;
  cursor: pointer;
  border-left: 3px solid;
  overflow: hidden;
  z-index: 1;
}

.ev-consulta     { background: #EEF4FC; border-color: #1E4A7C; color: var(--color-text); }
.ev-retorno      { background: #ECFDF5; border-color: #047857; color: var(--color-text); }
.ev-urgente      { background: #FEF2F2; border-color: #B91C1C; color: var(--color-text); font-weight: 600; }
.ev-teleconsulta { background: #EFF6FF; border-color: #1D4ED8; color: var(--color-text); }
.ev-bloqueio     { background: #FAF5FF; border-color: #6B21A8; color: var(--color-text); font-style: italic; }

.cal-event .ev-title { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-event .ev-meta { opacity: 0.7; font-size: 10px; margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.cal-legend {
  display: flex; gap: 18px; padding: 12px 18px;
  font-size: 11px; color: var(--color-text-secondary);
  border-top: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.cal-legend-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 2px;
  margin-right: 6px; vertical-align: middle;
}

/* ========== AGENDA · visão dia (timeline vertical) ========== */
.day-timeline {
  display: flex;
  flex-direction: column;
}
.day-row {
  display: grid;
  grid-template-columns: 70px 1fr;
  border-bottom: 1px solid var(--color-border);
  min-height: 56px;
}
.day-row:last-child { border-bottom: none; }
.day-time {
  padding: 12px 12px 0 18px;
  font-size: 11.5px;
  color: var(--color-text-muted);
  border-right: 1px solid var(--color-border);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.day-slot {
  padding: 8px 16px;
  cursor: pointer;
  border-left: 3px solid transparent;
  margin: 4px;
  border-radius: 6px;
}
.day-slot-free {
  color: var(--color-text-muted);
  font-size: 11.5px;
  font-style: italic;
  opacity: 0;
  transition: opacity 0.15s;
  padding: 12px 16px;
  margin: 0 4px;
  border-radius: 4px;
}
.day-row:hover .day-slot-free { opacity: 1; background: var(--color-bg-subtle); }
.day-slot.ev-consulta, .day-slot.ev-retorno, .day-slot.ev-urgente, .day-slot.ev-teleconsulta, .day-slot.ev-bloqueio {
  padding: 10px 14px;
}
.day-slot-content {
  display: flex;
  align-items: center;
  gap: 12px;
}
.day-slot-main { flex: 1; min-width: 0; }
.day-slot-title { font-weight: 600; font-size: 13px; color: var(--color-text); }
.day-slot-meta { font-size: 11.5px; color: var(--color-text-secondary); margin-top: 2px; }

/* ========== RECORD LAYOUT (Salesforce-style) ========== */
.record-header {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
}

.record-top { display: flex; align-items: flex-start; gap: 16px; }
.record-avatar {
  width: 56px; height: 56px; border-radius: 14px;
  background: var(--brand-gradient);
  color: white; display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 20px; flex-shrink: 0;
}
.record-name { font-size: 20px; font-weight: 700; letter-spacing: -0.3px; }
.record-sub { font-size: 13px; color: var(--color-text-muted); margin-top: 2px; }
.record-actions { margin-left: auto; display: flex; gap: 8px; }

.highlights {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 16px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--color-border);
}
.highlight-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--color-text-muted); font-weight: 600; }
.highlight-value { font-size: 14px; font-weight: 600; margin-top: 2px; }

/* ========== FIELD / FORM ========== */
.field-row { display: grid; grid-template-columns: 160px 1fr; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--color-border); }
.field-row:last-child { border-bottom: none; }
.field-label { font-size: 12px; color: var(--color-text-muted); font-weight: 500; }
.field-value { font-size: 13px; color: var(--color-text); }

.form-group { margin-bottom: 14px; }
.form-label { display: block; font-size: 12px; font-weight: 600; color: var(--color-text-secondary); margin-bottom: 4px; }
.form-input, .form-select, .form-textarea {
  width: 100%; padding: 8px 10px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  background: white; outline: none;
  transition: all 0.15s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(30, 74, 124, 0.18);
}
.form-textarea { min-height: 72px; resize: vertical; }

/* Select: chevron customizado em SVG (substitui a setinha nativa low-res) */
.form-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234B5563' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 14px 14px;
  padding-right: 36px;
  cursor: pointer;
}

/* Date/Time inputs · ícone SVG crisp à esquerda + chevron à direita.
 * Remove o picker indicator nativo (baixa qualidade) e cobre a área com uma
 * camada invisível clicável para manter a funcionalidade de abrir o picker.
 */
.form-input[type="date"],
.form-input[type="time"],
input[type="date"].form-input,
input[type="time"].form-input {
  position: relative;
  cursor: pointer;
  padding-left: 38px;
  padding-right: 34px;
  background-repeat: no-repeat, no-repeat;
  background-position: 12px center, right 12px center;
  background-size: 16px 16px, 12px 12px;
}

.form-input[type="date"],
input[type="date"].form-input {
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231E4A7C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}

.form-input[type="time"],
input[type="time"].form-input {
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231E4A7C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}

/* Esconde o ícone nativo do picker (baixa qualidade) mas preserva click */
.form-input[type="date"]::-webkit-calendar-picker-indicator,
.form-input[type="time"]::-webkit-calendar-picker-indicator,
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  opacity: 0;
  cursor: pointer;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
}

/* Remove spin buttons */
input[type="date"]::-webkit-inner-spin-button,
input[type="time"]::-webkit-inner-spin-button { display: none; }

/* Hover reforça affordance */
.form-input[type="date"]:hover,
.form-input[type="time"]:hover,
input[type="date"].form-input:hover,
input[type="time"].form-input:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-subtle);
}

/* Pill de tipo do agendamento · destaque especial para Encaixe */
.tipo-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 9px 2px 7px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.2px;
}
.tipo-pill svg { width: 12px; height: 12px; }
.tipo-pill-urgent {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border: 1px solid rgba(185, 28, 28, 0.25);
}

/* Linha da tabela destacada quando for agendamento de encaixe */
.table tr.row-urgent { background: rgba(254, 226, 226, 0.35); }
.table tr.row-urgent:hover { background: rgba(254, 226, 226, 0.6); }
.table tr.row-urgent td:first-child { box-shadow: inset 3px 0 0 var(--color-danger); }

/* Opção de canal no modal de reenvio de receita */
.canal-option {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 260px;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s ease-out;
  min-width: 0;
  background: white;
}
.canal-option:hover { border-color: var(--color-primary); }
.canal-option input[type="checkbox"] { margin: 0; cursor: pointer; flex-shrink: 0; }
.canal-option > span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
}
.canal-option > span svg { width: 14px; height: 14px; }
.canal-option small {
  font-size: 11px;
  color: var(--color-text-secondary);
  margin-left: auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.canal-option:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-subtle);
}

/* Seleção de método de pagamento · grid de opções no modal de transação */
.metodo-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.metodo-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s ease-out;
  background: white;
}
.metodo-option:hover { border-color: var(--color-primary); }
.metodo-option input[type="radio"] { margin: 0; flex-shrink: 0; }
.metodo-option .metodo-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
  flex-shrink: 0;
}
.metodo-option .metodo-icon svg { width: 15px; height: 15px; }
.metodo-option .metodo-label { font-size: 13px; font-weight: 500; color: var(--color-text); }
.metodo-option:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-subtle);
}
.metodo-option:has(input:checked) .metodo-icon {
  background: var(--color-primary);
  color: white;
}

/* Chip do Google Meet · usado em linhas de agenda com videoconsulta */
.meet-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px 2px 6px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: white;
  border: 1px solid var(--color-border);
  color: var(--color-text);
  margin-left: 6px;
  vertical-align: middle;
}
.meet-chip svg { width: 14px; height: 14px; flex-shrink: 0; }
.meet-logo-img {
  width: 18px; height: 18px;
  object-fit: contain;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}

/* Cronômetro de consulta · barra fixa acima do stepper */
.consulta-timer {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  margin-bottom: 16px;
  background: linear-gradient(135deg, #ECFDF5 0%, #F0FDF4 100%);
  border: 1px solid #A7F3D0;
  border-radius: var(--radius-md);
  box-shadow: 0 1px 3px rgba(4, 120, 87, 0.08);
}
.consulta-timer.timer-paused {
  background: linear-gradient(135deg, #FFFBEB 0%, #FEFCE8 100%);
  border-color: #FDE68A;
}
.timer-indicator {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--color-success);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.consulta-timer.timer-paused .timer-indicator { background: var(--color-warning); }
.timer-pulse {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: white;
  animation: timer-pulse 1.2s ease-in-out infinite;
}
.consulta-timer.timer-paused .timer-pulse { animation: none; }
@keyframes timer-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}
.timer-info { flex: 1; min-width: 0; }
.timer-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--color-success);
}
.consulta-timer.timer-paused .timer-label { color: var(--color-warning); }
.timer-time {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.timer-controls {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

/* Grid de valores padrão no Financeiro */
.valores-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
/* Grid de metas em Configurações · semelhante, mas menor */
.metas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.valor-padrao .form-label { margin-bottom: 6px; display: block; }
.input-prefixed {
  position: relative;
  display: flex;
  align-items: center;
}
.input-prefixed .input-prefix {
  position: absolute;
  left: 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  pointer-events: none;
}
.input-prefixed .form-input {
  padding-left: 38px;
  font-size: 15px;
  font-weight: 600;
}

/* Chip inline do Meet dentro de títulos de eventos */
.meet-chip-inline { display: inline-flex; align-items: center; margin-left: 4px; vertical-align: middle; }
.meet-chip-inline .meet-logo-img { width: 16px; height: 16px; }

/* Modelos de relatório · grid de cards clicáveis */
.relatorio-modelos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.relatorio-modelo {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: white;
  text-align: left;
  cursor: pointer;
  transition: all 0.12s ease-out;
}
.relatorio-modelo:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.relatorio-modelo-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--color-primary-subtle);
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.relatorio-modelo-icon svg { width: 18px; height: 18px; }
.relatorio-modelo-body { min-width: 0; }
.relatorio-modelo-nome { font-size: 13.5px; font-weight: 600; color: var(--color-text); }
.relatorio-modelo-desc { font-size: 12px; color: var(--color-text-secondary); margin-top: 4px; line-height: 1.4; }

/* Modal de encerrar consulta · salvar ou descartar */
.encerrar-consulta { }
.encerrar-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--color-primary-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 16px;
}
.encerrar-icon {
  width: 44px; height: 44px;
  background: var(--color-primary);
  color: white;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.encerrar-icon svg { width: 20px; height: 20px; }
.encerrar-duracao {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 24px;
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: 0.5px;
  margin: 2px 0;
}

.encerrar-opcoes { display: grid; gap: 10px; }
.encerrar-opcao {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: white;
  text-align: left;
  cursor: pointer;
  transition: all 0.12s ease-out;
}
.encerrar-opcao:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.encerrar-opcao-salvar:hover { border-color: var(--color-success); }
.encerrar-opcao-descartar:hover { border-color: var(--color-danger); }
.opcao-icon {
  width: 36px; height: 36px;
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.encerrar-opcao-salvar:hover .opcao-icon { background: var(--color-success-bg); color: var(--color-success); }
.opcao-icon-danger { background: var(--color-danger-bg); color: var(--color-danger); }

/* Botão danger · usado em ações destrutivas (descartar/excluir) */
.btn-danger { background: var(--color-danger); color: white; }
.btn-danger:hover { background: #7F1D1D; }
.btn-danger:disabled, .btn-danger[disabled] { opacity: 0.45; cursor: not-allowed; }

/* Botão de ícone destrutivo · usado em linhas de tabela para apagar */
.btn-icon-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 6px;
  color: var(--color-danger);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.12s ease-out;
}
.btn-icon-danger:hover { background: var(--color-danger-bg); color: #7F1D1D; }
.btn-icon-danger svg { width: 16px; height: 16px; }

/* Sub-formas do Pix · aparecem dentro do form de transação quando Pix é selecionado */
.forma-pix-wrap {
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  margin-top: 8px;
}
.forma-pix-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 4px;
}
.forma-pix-option {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s ease-out;
}
.forma-pix-option:hover { border-color: var(--color-primary); }
.forma-pix-option input { margin-top: 2px; flex-shrink: 0; }
.forma-pix-label { font-size: 12.5px; font-weight: 600; color: var(--color-text); }
.forma-pix-dica { font-size: 11px; color: var(--color-text-secondary); margin-top: 2px; line-height: 1.3; }
.forma-pix-option:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-subtle);
}

.metodo-chip-sub {
  color: var(--color-text-secondary);
  font-weight: 400;
  margin-left: 2px;
}

/* Top do formulário de usuário · foto + campos lado a lado */
.usr-form-top {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 16px;
  align-items: center;
  margin-bottom: 12px;
}
.usr-form-foto { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.usr-form-campos { min-width: 0; }
@media (max-width: 560px) { .usr-form-top { grid-template-columns: 1fr; justify-items: center; } }

/* Chip do método · usado na tabela do financeiro */
.metodo-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 500;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  white-space: nowrap;
}
.metodo-chip svg { width: 12px; height: 12px; opacity: 0.75; }

/* ========== STEPPER (fluxo multi-etapa) ========== */
.stepper {
  display: flex;
  margin-bottom: 20px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.stepper-step {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  background: white;
  cursor: pointer;
  font-size: 13px;
  color: var(--color-text-muted);
  transition: all 0.15s;
  position: relative;
  border: none;
  text-align: left;
}
.stepper-step:not(:last-child)::after {
  content: '';
  position: absolute;
  right: -8px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 16px;
  height: 16px;
  background: white;
  border-top: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
  z-index: 2;
}
.stepper-step:not(:last-child) { padding-right: 28px; }
.stepper-step:not(:first-child) { padding-left: 28px; }

.stepper-step.active {
  background: var(--color-primary-subtle);
  color: var(--color-text);
}
.stepper-step.active::after { background: var(--color-primary-subtle); }

.stepper-step.completed { color: var(--color-text-secondary); }

.stepper-num {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-muted);
  color: var(--color-text-muted);
  font-weight: 600;
  font-size: 12.5px;
  flex-shrink: 0;
}
.stepper-step.active .stepper-num {
  background: var(--color-primary);
  color: white;
}
.stepper-step.completed .stepper-num {
  background: var(--color-success);
  color: white;
}
.stepper-label { font-weight: 500; }
.stepper-step.active .stepper-label { font-weight: 600; }
.stepper-sub { font-size: 10.5px; color: var(--color-text-muted); margin-top: 1px; }

/* Navegação do fluxo (voltar / próximo) */
.step-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 20px;
  padding: 16px 20px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

/* Integração banner (Mevo) */
.integration-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--color-primary-subtle);
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-md);
  margin-bottom: 16px;
  font-size: 12.5px;
}
.integration-banner-logo {
  width: 72px; height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 4px;
  background: white;
  border-radius: 6px;
  border: 1px solid var(--color-border);
}
.mevo-logo-img { width: 100%; height: 100%; object-fit: contain; }

/* Card de revisão (step 3) */
.review-group {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
}
.review-group:last-child { border-bottom: none; }
.review-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.review-value { font-size: 13px; color: var(--color-text); line-height: 1.5; white-space: pre-wrap; }

/* ========== TIMELINE ========== */
.timeline-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--color-border); }
.timeline-item:last-child { border-bottom: none; }
.timeline-icon {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-primary-subtle); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.timeline-icon svg { width: 16px; height: 16px; }
.timeline-body { flex: 1; min-width: 0; }
.timeline-title { font-size: 13px; font-weight: 600; }
.timeline-meta { font-size: 11px; color: var(--color-text-muted); margin-top: 2px; }
.timeline-desc { font-size: 12.5px; color: var(--color-text-secondary); margin-top: 4px; }

/* ========== CHAT ========== */
.chat-shell { display: grid; grid-template-columns: 300px 1fr 300px; height: calc(100vh - var(--topbar-height) - var(--subnav-height) - 48px); background: white; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.chat-list { border-right: 1px solid var(--color-border); overflow-y: auto; }
.chat-thread { display: flex; flex-direction: column; }
.chat-context { border-left: 1px solid var(--color-border); padding: 16px; overflow-y: auto; background: var(--color-bg-subtle); }

.chat-conv-item { display: flex; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--color-border); cursor: pointer; }
.chat-conv-item:hover, .chat-conv-item.active { background: var(--color-bg-subtle); }
.chat-conv-item.active { background: var(--color-primary-subtle); }
.chat-conv-item .avatar-sm { width: 36px; height: 36px; border-radius: 50%; background: #25D366; color: white; display: flex; align-items: center; justify-content: center; font-weight: 600; flex-shrink: 0; }
.chat-conv-name { font-size: 13px; font-weight: 600; display: flex; justify-content: space-between; }
.chat-conv-preview { font-size: 12px; color: var(--color-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }

.chat-header { padding: 14px 20px; border-bottom: 1px solid var(--color-border); display: flex; align-items: center; gap: 12px; }
.chat-body { flex: 1; overflow-y: auto; padding: 20px; background: var(--color-bg-subtle); display: flex; flex-direction: column; gap: 8px; }
.chat-composer { border-top: 1px solid var(--color-border); padding: 12px 16px; display: flex; gap: 8px; background: white; }
.chat-composer input { flex: 1; padding: 9px 12px; border: 1px solid var(--color-border-strong); border-radius: 20px; outline: none; }

.msg { max-width: 68%; padding: 9px 13px; border-radius: 14px; font-size: 13px; line-height: 1.4; }
.msg-patient { background: white; border: 1px solid var(--color-border); align-self: flex-start; border-bottom-left-radius: 4px; }
.msg-bot { background: var(--color-primary-subtle); color: var(--color-text); align-self: flex-start; border-bottom-left-radius: 4px; }
.msg-agent { background: var(--color-primary); color: white; align-self: flex-end; border-bottom-right-radius: 4px; }
.msg-sys { background: #FFFBEB; color: var(--color-warning); align-self: center; font-size: 11px; font-style: italic; border-radius: 10px; padding: 4px 10px; }

/* ========== JOURNEY / MARKETING ========== */
.journey-canvas { background: white; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 24px; min-height: 400px; }
.journey-flow { display: flex; flex-direction: column; gap: 8px; align-items: center; }
.journey-node { background: white; border: 1.5px solid var(--color-border-strong); border-radius: var(--radius-md); padding: 12px 16px; display: flex; gap: 10px; align-items: center; min-width: 280px; }
.journey-node.trigger { border-color: var(--color-primary); background: var(--color-primary-subtle); }
.journey-node.action { border-color: var(--color-success); background: var(--color-success-bg); }
.journey-node.wait { border-color: #F59E0B; background: #FFFBEB; }
.journey-node.decision { border-color: #8B5CF6; background: #FAF5FF; }
.journey-node-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: white; }
.journey-arrow { color: var(--color-text-muted); font-size: 16px; }
.journey-node-title { font-size: 13px; font-weight: 600; }
.journey-node-desc { font-size: 11px; color: var(--color-text-muted); }

/* ========== PRESCRIÇÃO ITEM ========== */
.prescricao-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: white;
  margin-bottom: 6px;
}

.prescricao-item:last-child { margin-bottom: 0; }

/* Busca de medicamentos · input com dropdown de sugestões */
.medicamento-busca { position: relative; margin-bottom: 12px; }
.med-sugestoes {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  z-index: 10;
  max-height: 280px;
  overflow-y: auto;
}
.med-sugestoes.hidden { display: none; }
.med-sugestao {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-border);
  background: white;
  cursor: pointer;
  transition: background 0.1s;
}
.med-sugestao:last-child { border-bottom: none; }
.med-sugestao:hover { background: var(--color-primary-subtle); }
.med-sugestao-vazio {
  padding: 12px;
  font-size: 12.5px;
  color: var(--color-text-secondary);
  text-align: center;
}
.med-sugestao-vazio a { color: var(--color-primary); font-weight: 600; }

/* ========== TOGGLE SWITCH ========== */
.toggle-switch {
  position: relative;
  display: inline-block;
  width: 38px;
  height: 22px;
  cursor: pointer;
}
.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--color-border-strong);
  border-radius: 22px;
  transition: background 0.15s;
}
.toggle-slider::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 2px;
  width: 18px;
  height: 18px;
  background: white;
  border-radius: 50%;
  transition: transform 0.15s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.toggle-switch input:checked + .toggle-slider {
  background: var(--color-primary);
}
.toggle-switch input:checked + .toggle-slider::before {
  transform: translateX(16px);
}

/* ========== RADIO GROUP ========== */
.radio-group { display: flex; gap: 16px; padding: 4px 0; }
.radio-group label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
}
.radio-group input[type="radio"] {
  accent-color: var(--color-primary);
}

/* ========== UPLOAD BOX ========== */
.upload-box {
  border: 2px dashed var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: 40px 20px;
  text-align: center;
  background: var(--color-bg-subtle);
  transition: all 0.15s;
}
.upload-box:hover { border-color: var(--color-primary); background: var(--color-primary-subtle); }

/* ========== COPY FROM PANEL ========== */
.copy-from {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px;
  background: var(--color-bg-subtle);
  margin-bottom: 10px;
}
.copy-from-item {
  padding: 8px 10px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  margin-bottom: 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12.5px;
}
.copy-from-item:last-child { margin-bottom: 0; }

/* ========== MODAL ========== */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(17, 24, 39, 0.45);
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding-top: 10vh;
  z-index: 1000;
  animation: fadeIn 0.12s ease-out;
}
.modal-overlay.open { display: flex; }
.modal {
  background: white;
  border-radius: var(--radius-lg);
  width: 620px;
  max-width: 92vw;
  max-height: 80vh;
  overflow: auto;
  box-shadow: 0 16px 40px rgba(0,0,0,0.18);
  animation: slideUp 0.15s ease-out;
}
.modal.modal-large {
  width: 1200px;
  max-width: 96vw;
  max-height: 88vh;
}
.modal.modal-fullscreen {
  width: 100vw;
  max-width: 100vw;
  height: calc(100vh - 40px);
  max-height: calc(100vh - 40px);
  border-radius: 0;
  margin-top: -10vh;
}
.modal-header {
  padding: 18px 22px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--color-border);
}
.modal-title { font-size: 15px; font-weight: 600; }
.modal-body { padding: 20px 22px; }
.modal-footer {
  padding: 14px 22px;
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  background: var(--color-bg-subtle);
  flex-wrap: wrap;
}
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes slideUp { from { transform: translateY(8px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }

/* ========== DROPDOWN ========== */
.dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  min-width: 240px;
  z-index: 100;
  overflow: hidden;
  animation: slideUp 0.12s ease-out;
}
.dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--color-text);
  cursor: pointer;
  text-decoration: none;
}
.dropdown-item:hover { background: var(--color-bg-subtle); text-decoration: none; }
.dropdown-item svg { color: var(--color-text-muted); }
.dropdown-divider { height: 1px; background: var(--color-border); margin: 4px 0; }
.dropdown-header { padding: 10px 14px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--color-text-muted); font-weight: 600; }

.icon-btn { position: relative; }

/* ========== NOTIF ICON (caixa colorida + SVG · substitui o "dot Japan flag") ========== */
.notif-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.notif-icon svg { width: 16px; height: 16px; }
.notif-icon-danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.notif-icon-warning { background: var(--color-warning-bg); color: var(--color-warning); }
.notif-icon-info    { background: var(--color-info-bg);    color: var(--color-info); }
.notif-icon-success { background: var(--color-success-bg); color: var(--color-success); }
.notif-icon-neutral { background: var(--color-bg-subtle);  color: var(--color-text-secondary); }

/* ========== NOTIFICATION PANEL ========== */
.notif-panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 380px;
  max-height: 520px;
  overflow: auto;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(0,0,0,0.10);
  z-index: 100;
}
.notif-head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: white;
  position: sticky;
  top: 0;
  z-index: 1;
}
.notif-head .unread-count {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-primary);
  background: var(--color-primary-subtle);
  padding: 2px 8px;
  border-radius: 10px;
  margin-left: 6px;
}

/* Divisor de seção (não lidas / lidas) */
.notif-section-label {
  padding: 8px 16px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--color-text-muted);
  background: var(--color-bg-subtle);
  border-bottom: 1px solid var(--color-border);
}

.notif-item {
  padding: 12px 16px 12px 28px;
  border-bottom: 1px solid var(--color-border);
  cursor: pointer;
  position: relative;
  transition: background 0.12s;
}
.notif-item:hover { background: var(--color-bg-subtle); }
.notif-item:last-child { border-bottom: none; }

/* Item NÃO LIDO: fundo azulzinho, dot à esquerda, título em bold */
.notif-item.unread {
  background: var(--color-primary-subtle);
}
.notif-item.unread::before {
  content: '';
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-subtle);
}

/* Item LIDO: sem dot, cores suaves, título em weight normal */
.notif-item.read {
  opacity: 0.72;
}
.notif-item.read .notif-title { font-weight: 500; }
.notif-item.read .notif-icon { opacity: 0.55; }

.notif-title { font-size: 13px; font-weight: 600; margin-bottom: 2px; color: var(--color-text); }
.notif-desc { font-size: 12px; color: var(--color-text-secondary); line-height: 1.4; }
.notif-time { font-size: 11px; color: var(--color-text-muted); margin-top: 4px; }

/* ========== TOAST ========== */
.toast-wrap {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.toast {
  background: #1F2937;
  color: white;
  padding: 10px 16px;
  border-radius: var(--radius-md);
  font-size: 13px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 10px;
  animation: toastIn 0.2s ease-out;
  max-width: 360px;
}
.toast.toast-success { background: #065F46; }
.toast.toast-danger { background: #991B1B; }
@keyframes toastIn { from { transform: translateY(12px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }

/* ========== PATIENT PHOTO ========== */
.person-photo {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-bg-muted);
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--color-border);
}
.person-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.person-photo .photo-initials {
  display: inline-flex;
  width: 100%; height: 100%;
  align-items: center;
  justify-content: center;
  background: var(--brand-gradient);
  color: white;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.3px;
}

/* ========== ALERTAS DO PAINEL (acionáveis) ========== */
.alerta-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--color-border);
  transition: background 0.12s;
}
.alerta-item:last-child { border-bottom: none; }
.alerta-item:hover { background: var(--color-bg-subtle); }
.alerta-body { flex: 1; min-width: 0; cursor: pointer; }
.alerta-actions { display: flex; gap: 4px; opacity: 0.7; }
.alerta-item:hover .alerta-actions { opacity: 1; }
.btn-ghost-sm {
  width: 28px; height: 28px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.12s;
}
.btn-ghost-sm:hover { background: var(--color-bg-muted); color: var(--color-text); }
.btn-ghost-sm svg { width: 14px; height: 14px; }
.alerta-resolver:hover { background: var(--color-success-bg); color: var(--color-success); }

/* ========== INBOX (Gmail) ========== */
.inbox-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 16px;
}
.inbox-layout-split {
  grid-template-columns: 200px 380px 1fr;
  flex: 1;
  min-height: 0;
}
.inbox-layout-split.inbox-layout-com-ficha {
  grid-template-columns: 200px 360px 1fr 320px;
}
/* Modo "Janela grande" · mantém ficha lateral na página; email abre em modal */
.inbox-layout-large {
  grid-template-columns: 220px 1fr;
  flex: 1;
  min-height: 0;
}
.inbox-layout-large.inbox-layout-com-ficha {
  grid-template-columns: 220px 1fr 320px;
}
.inbox-layout-large .inbox-sidebar,
.inbox-layout-large .inbox-lista,
.inbox-layout-large .inbox-ficha {
  overflow-y: auto;
  min-height: 0;
}
.page-fullheight {
  height: calc(100vh - var(--topbar-height));
  padding-bottom: 20px;
  overflow: hidden;
}
@media (max-width: 1280px) {
  .inbox-layout-split.inbox-layout-com-ficha { grid-template-columns: 200px 340px 1fr 300px; }
}
@media (max-width: 1100px) {
  .inbox-layout-split, .inbox-layout-split.inbox-layout-com-ficha { grid-template-columns: 1fr; height: auto; }
  .inbox-layout-split .inbox-painel,
  .inbox-layout-split .inbox-ficha { display: none; }
}
.inbox-layout-split .inbox-sidebar,
.inbox-layout-split .inbox-lista,
.inbox-layout-split .inbox-painel,
.inbox-layout-split .inbox-ficha {
  overflow-y: auto;
  min-height: 0;
}

.inbox-painel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 500px;
}
.inbox-layout-split .inbox-painel { min-height: 0; }
.inbox-painel-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  flex-shrink: 0;
}
.inbox-painel-header-content { flex: 1; min-width: 0; }
.inbox-painel-header-actions { display: flex; gap: 4px; flex-shrink: 0; }

.inbox-painel-assunto {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.3;
  letter-spacing: -0.2px;
  margin: 0 0 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.inbox-star-prefix { color: #F59E0B; margin-right: 4px; }

.inbox-painel-meta { display: flex; flex-direction: column; gap: 4px; }
.inbox-painel-meta-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 12px;
  color: var(--color-text-secondary);
  flex-wrap: wrap;
}
.inbox-painel-meta-label {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--color-text-muted);
  min-width: 32px;
  flex-shrink: 0;
}
.inbox-painel-meta-val { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.inbox-painel-meta-data {
  font-size: 11px;
  color: var(--color-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Botões de ícone no header do email (Ficha, estrela) · compactos e discretos */
.btn-icon-header {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  transition: all 0.12s;
}
.btn-icon-header:hover { background: var(--color-bg-subtle); border-color: var(--color-border); color: var(--color-text); }
.btn-icon-header svg { width: 15px; height: 15px; }
.btn-icon-starred { color: #F59E0B; }
.btn-icon-starred:hover { color: #D97706; }
.inbox-painel-paciente {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: var(--color-primary-subtle);
  border-bottom: 1px solid var(--color-border);
}
.inbox-painel-corpo {
  flex: 1;
  padding: 18px;
  font-size: 14px;
  line-height: 1.6;
  overflow-y: auto;
}
.inbox-painel-corpo p { margin: 0 0 8px; }
.inbox-painel-footer {
  padding: 12px 16px;
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--color-bg-subtle);
  flex-shrink: 0;
}
/* Ações de leitura · botões compactos em uma linha só (sem quebra) */
.inbox-leitura-actions { flex-wrap: nowrap; overflow-x: auto; }
.inbox-leitura-actions .btn { flex-shrink: 0; white-space: nowrap; }
.inbox-painel-vazio {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}
.inbox-painel-vazio svg { width: 48px; height: 48px; opacity: 0.4; }
.inbox-item-selected { background: var(--color-primary-subtle) !important; box-shadow: inset 3px 0 0 var(--color-primary); }
.inbox-count-soft {
  background: var(--color-bg-muted);
  color: var(--color-text-muted);
  font-size: 11px;
  padding: 1px 8px;
  border-radius: 10px;
  font-weight: 600;
}

/* Sidebar · headers de pastas customizadas e tags */
.inbox-pastas-custom-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 14px 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.inbox-folder-dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.inbox-folder-tag { font-size: 12.5px; }

/* Toolbar da lista · seleção múltipla + ações */
.inbox-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--color-border);
  background: white;
  flex-wrap: wrap;
  min-height: 46px;
}
.inbox-toolbar-check {
  display: inline-flex;
  align-items: center;
  padding: 4px;
  cursor: pointer;
}
.inbox-toolbar-check input[type="checkbox"] { cursor: pointer; }
.inbox-toolbar-count {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--color-primary);
}
.inbox-toolbar-nome {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--color-text);
  margin-left: 4px;
}

/* Item com checkbox · layout ajustado */
.inbox-item-check {
  display: flex;
  align-items: center;
  padding: 0 4px 0 14px;
  cursor: pointer;
}
.inbox-item-main {
  display: flex;
  gap: 12px;
  flex: 1;
  padding: 14px 16px 14px 2px;
  cursor: pointer;
  min-width: 0;
}
.inbox-item { padding: 0; align-items: stretch; }
.inbox-item-checked { background: var(--color-primary-subtle); }

/* Tags inline no email */
.inbox-item-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.email-tag {
  font-size: 10.5px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  line-height: 1.4;
}

/* Badge "agendado" na data */
.inbox-agendado-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: var(--color-warning-bg);
  color: var(--color-warning);
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 600;
  font-size: 10.5px;
}
.inbox-agendado-badge svg { width: 10px; height: 10px; }

/* Menu contextual (botão direito em emails) */
.context-menu {
  position: fixed;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  padding: 6px 0;
  min-width: 220px;
  z-index: 3000;
  animation: slideUp 0.1s ease-out;
}
.context-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  font-size: 13px;
  color: var(--color-text);
  cursor: pointer;
  transition: background 0.1s;
}
.context-menu-item:hover { background: var(--color-bg-subtle); }
.context-menu-item svg { width: 14px; height: 14px; color: var(--color-text-muted); }
.context-menu-divider { height: 1px; background: var(--color-border); margin: 4px 0; }
.context-menu-submenu { position: relative; }
.context-menu-submenu-items {
  position: absolute;
  left: 100%;
  top: 0;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  padding: 6px 0;
  min-width: 200px;
  display: none;
}
.context-menu-submenu:hover .context-menu-submenu-items { display: block; }
.context-menu-danger { color: var(--color-danger); }
.context-menu-danger svg { color: var(--color-danger); }
.context-menu-danger:hover { background: var(--color-danger-bg); }

/* Modal de nova pasta · grid de cores */
.pasta-cor-grid { display: flex; gap: 8px; flex-wrap: wrap; }
.pasta-cor-opt { cursor: pointer; }
.pasta-cor-opt input { display: none; }
.pasta-cor-swatch {
  display: inline-block;
  width: 32px; height: 32px;
  border-radius: 8px;
  border: 2px solid transparent;
  transition: all 0.12s;
}
.pasta-cor-opt input:checked + .pasta-cor-swatch {
  border-color: var(--color-text);
  transform: scale(1.1);
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--color-text);
}

/* Preview de anexo · modal grande */
.anexo-preview-viewer {
  background: #F5F5F5;
  border-radius: 8px;
  padding: 24px;
  min-height: 520px;
  max-height: 68vh;
  overflow-y: auto;
}
.anexo-preview-pdf-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: #2B2B2B;
  color: white;
  border-radius: 6px;
  margin-bottom: 16px;
}
.anexo-preview-pdf-header svg { width: 18px; height: 18px; color: #EA4335; }
.anexo-preview-paginas { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.anexo-preview-pagina {
  width: 100%;
  max-width: 720px;
  background: white;
  padding: 40px 48px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
  border-radius: 2px;
}
.anexo-preview-pagina-header {
  display: flex;
  justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 2px solid #0B2A4A;
  margin-bottom: 24px;
}
.anexo-preview-linhas { display: flex; flex-direction: column; gap: 10px; }
.anexo-preview-linha { height: 10px; background: #E5E7EB; border-radius: 2px; }
.anexo-preview-img { min-height: 400px; background: repeating-linear-gradient(45deg, #F5F5F5, #F5F5F5 10px, #EFEFEF 10px, #EFEFEF 20px); }
.anexo-preview-img svg { width: 64px; height: 64px; color: var(--color-text-muted); }

/* Agendar envio · modal */
.agendar-envio-resumo {
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 12px 14px;
  margin-bottom: 16px;
}
.agendar-envio-quick {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.inbox-anexo-mini {
  display: inline-flex;
  vertical-align: middle;
  color: var(--color-text-muted);
}
.inbox-anexo-mini svg { width: 11px; height: 11px; transform: rotate(45deg); }

/* Painel de leitura · anexos */
.inbox-anexos {
  padding: 12px 18px;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
}
.inbox-anexos-titulo {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--color-text-secondary);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.inbox-anexos-titulo svg { width: 13px; height: 13px; transform: rotate(45deg); }
.inbox-anexos-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.inbox-anexo-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s;
  min-width: 200px;
}
.inbox-anexo-item:hover { border-color: var(--color-primary); box-shadow: 0 2px 6px rgba(0,0,0,0.06); }
.inbox-anexo-icon {
  width: 32px; height: 32px;
  background: var(--color-primary-subtle);
  color: var(--color-primary);
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.inbox-anexo-icon svg { width: 16px; height: 16px; }
.inbox-anexo-nome { font-size: 12.5px; font-weight: 600; color: var(--color-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.inbox-anexo-meta { font-size: 11px; color: var(--color-text-muted); }

/* Ficha do paciente · painel lateral exclusivo (4ª coluna) */
.inbox-ficha {
  display: flex;
  flex-direction: column;
  padding: 0;
}
.inbox-ficha-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-primary-subtle);
}
.inbox-ficha-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px;
  min-height: 0;
}
.inbox-ficha-campo {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 12px;
  border-bottom: 1px dashed var(--color-border);
}
.inbox-ficha-campo:last-of-type { border-bottom: none; margin-bottom: 10px; }
.inbox-ficha-campo span { color: var(--color-text-muted); }
.inbox-ficha-footer {
  display: flex;
  gap: 6px;
  padding: 10px 12px;
  border-top: 1px solid var(--color-border);
  background: white;
}

/* Compose inline · formulário completo */
.inbox-compose-form {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow-y: auto;
}
.inbox-compose-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--color-border);
}
.inbox-compose-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--color-text-muted);
  width: 60px;
  flex-shrink: 0;
}
.inbox-compose-row .form-input {
  border: none;
  padding: 4px 0;
  background: transparent;
  flex: 1;
}
.inbox-compose-row .form-input:focus { outline: none; box-shadow: none; }
.inbox-compose-corpo {
  flex: 1;
  min-height: 220px;
  border: none;
  border-radius: 0;
  padding: 14px;
  resize: none;
}
.inbox-compose-corpo:focus { outline: none; box-shadow: none; }
.inbox-compose-chk {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}

/* Compose inline · anexos + CC */
.inbox-compose-anexos {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 14px;
  border-top: 1px solid var(--color-border);
}
.inbox-compose-anexo {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px 4px 6px;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  border-radius: 4px;
}
.inbox-compose-anexo svg { width: 12px; height: 12px; color: var(--color-text-muted); }
.inbox-compose-footer-inline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 14px;
  border-top: 1px solid var(--color-border);
  flex-wrap: wrap;
  gap: 8px;
}

/* Resumo do paciente no inbox · dossier expansível */
.inbox-resumo, .email-resumo-wrap .inbox-resumo {
  background: linear-gradient(180deg, var(--color-primary-subtle) 0%, white 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px;
  margin: 0 18px 12px;
}
.email-resumo-wrap { margin: 0; }
.email-resumo-wrap .inbox-resumo { margin: 0 0 16px; }
.inbox-resumo-top {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 10px;
}
.inbox-resumo-alergia {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 11.5px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.inbox-resumo-alergia svg { width: 14px; height: 14px; flex-shrink: 0; }
.inbox-resumo-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 10px;
}
.inbox-resumo-stats > div {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 8px;
  text-align: center;
}
.inbox-resumo-num { font-size: 18px; font-weight: 700; color: var(--color-primary); line-height: 1.1; }
.inbox-resumo-lbl { font-size: 10.5px; color: var(--color-text-muted); margin-top: 2px; }
.inbox-resumo-cids { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
.inbox-resumo-accordion {
  margin-bottom: 6px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  background: white;
  overflow: hidden;
}
.inbox-resumo-accordion summary {
  padding: 8px 12px;
  cursor: pointer;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--color-text);
  user-select: none;
}
.inbox-resumo-accordion summary:hover { background: var(--color-bg-subtle); }
.inbox-resumo-accordion[open] summary { border-bottom: 1px solid var(--color-border); }
.inbox-resumo-item {
  padding: 8px 12px;
  border-bottom: 1px solid var(--color-border);
}
.inbox-resumo-item:last-child { border-bottom: none; }
.inbox-resumo-acoes {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.dropdown-item-active { background: var(--color-primary-subtle); font-weight: 600; }
.inbox-sidebar { display: flex; flex-direction: column; gap: 4px; }
.inbox-folder {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
}
.inbox-folder:hover { background: var(--color-bg-subtle); text-decoration: none; }
.inbox-folder.active { background: var(--color-primary-subtle); color: var(--color-text); font-weight: 600; }
.inbox-count {
  margin-left: auto;
  background: var(--color-primary);
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 1px 8px;
  border-radius: 10px;
}

.inbox-lista { display: flex; flex-direction: column; }
.inbox-item {
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  cursor: pointer;
  transition: background 0.12s;
}
.inbox-item:hover { background: var(--color-bg-subtle); }
.inbox-item-unread { background: rgba(239, 246, 255, 0.4); }
.inbox-item-unread .inbox-subject,
.inbox-item-unread .inbox-from { font-weight: 700; }
.inbox-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--brand-gradient);
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  flex-shrink: 0;
}
.inbox-avatar img { width: 100%; height: 100%; object-fit: cover; }
.inbox-content { flex: 1; min-width: 0; }
.inbox-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.inbox-from { font-size: 13px; color: var(--color-text); }
.inbox-subject { font-size: 13px; color: var(--color-text); margin: 2px 0; }
.inbox-preview { font-size: 12px; color: var(--color-text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.inbox-star { color: #F59E0B; }

.email-header {
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 14px;
}
.email-body { font-size: 14px; line-height: 1.6; }
.email-body p { margin: 0 0 8px; }

/* ========== TIMELINE DO PACIENTE ========== */
/* Dots ligados por linha contínua · linha atravessa o padding do item, não "sobra" */
.timeline { padding: 12px 20px 8px; }
.timeline-item {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 14px;
  padding-bottom: 14px;   /* espaço entre items · a linha percorre esse padding */
  align-items: stretch;
}
.timeline-item:last-child { padding-bottom: 0; }

/* Coluna esquerda · dot alinhado com o título do body + linha ocupando resto da coluna */
.timeline-icon-col {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.timeline-icon-col::after {
  content: '';
  flex: 1;
  width: 2px;
  background: var(--color-border);
  margin-top: 4px;    /* pequeno respiro entre dot e linha */
}
.timeline-item:last-child .timeline-icon-col::after { display: none; }

.timeline-dot {
  width: 32px; height: 32px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: white;
  /* Alinha centro do dot (16px) com centro do título do body (padding-top 10 + 12px de line) */
  margin-top: 2px;
}
.timeline-dot svg { width: 14px; height: 14px; }

.timeline-body {
  min-width: 0;
  padding: 10px 14px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.timeline-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; flex-wrap: wrap; }

/* ========== DISCADOR ========== */
.discador { padding: 6px 0; }
.discador-paciente {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--color-primary-subtle);
  border-radius: 8px;
  margin-bottom: 14px;
}
.discador-display {
  width: 100%;
  padding: 14px 16px;
  font-size: 22px;
  font-weight: 600;
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  text-align: center;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-bg-subtle);
  letter-spacing: 1px;
  margin-bottom: 16px;
}
.discador-teclado {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.discador-tecla {
  padding: 16px;
  font-size: 20px;
  font-weight: 600;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.1s;
}
.discador-tecla:hover { background: var(--color-primary-subtle); border-color: var(--color-primary); }
.discador-tecla:active { transform: scale(0.96); }

/* Chamada ativa · flutuante no canto inferior direito */
.chamada-ativa {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 2500;
  background: white;
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-success);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 320px;
}
.chamada-pulse {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--color-success);
  animation: chamada-pulse 1s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes chamada-pulse {
  0%, 100% { opacity: 1; transform: scale(1); box-shadow: 0 0 0 0 rgba(4, 120, 87, 0.4); }
  50% { opacity: 0.7; transform: scale(1.15); box-shadow: 0 0 0 8px rgba(4, 120, 87, 0); }
}
.chamada-info { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.chamada-icone {
  width: 36px; height: 36px;
  background: var(--color-success);
  color: white;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.chamada-fim {
  width: 36px; height: 36px;
  background: var(--color-danger);
  color: white;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.12s;
  border: none;
  flex-shrink: 0;
}
.chamada-fim:hover { background: #7F1D1D; }
.chamada-fim svg { width: 16px; height: 16px; transform: rotate(135deg); }

/* Perfil resumido · visão padrão em Configurações (só leitura) */
.perfil-resumo {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
}
.perfil-resumo .person-photo {
  border: 2px solid var(--color-border);
}

/* ========== INTEGRAÇÕES · um card por categoria ========== */
.integracoes-header {
  padding: 4px 2px 0;
}
.integracao-categoria { overflow: hidden; }
.integracao-categoria-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--color-border);
}
.integracao-categoria-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.integracao-categoria-icon svg { width: 20px; height: 20px; }
.integracao-categoria-titulo {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: -0.1px;
}
.integracao-categoria-desc {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 2px;
}
.integracao-categoria-stats {
  text-align: right;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.integracao-categoria-num {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}
.integracao-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
}
.integracao-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: white;
  padding: 14px 16px;
  transition: all 0.12s ease-out;
}
.integracao-card:hover { box-shadow: var(--shadow-md); }
.integracao-status-conectado { border-color: #D1FAE5; }
.integracao-status-precisa_acao { border-color: #FDE68A; background: #FFFBEB; }
.integracao-status-disponivel { border-style: dashed; }

.integracao-card-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.integracao-logo {
  width: 40px; height: 40px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.integracao-logo svg { width: 20px; height: 20px; }
.integracao-logo-img { width: 100%; height: 100%; object-fit: contain; border-radius: 6px; }
.integracao-nome { font-size: 13.5px; font-weight: 600; color: var(--color-text); }
.integracao-tipo {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 2px;
}
.integracao-tipo svg { width: 11px; height: 11px; }

.integracao-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
}
.integracao-dot-ok   { background: var(--color-success); box-shadow: 0 0 0 3px rgba(4, 120, 87, 0.18); }
.integracao-dot-warn { background: var(--color-warning); box-shadow: 0 0 0 3px rgba(180, 83, 9, 0.18); animation: pulse-warn 1.5s ease-in-out infinite; }
.integracao-dot-off  { background: var(--color-text-muted); box-shadow: 0 0 0 3px rgba(107, 114, 128, 0.15); }
@keyframes pulse-warn { 0%, 100% { box-shadow: 0 0 0 3px rgba(180, 83, 9, 0.18); } 50% { box-shadow: 0 0 0 6px rgba(180, 83, 9, 0.08); } }

.integracao-desc {
  font-size: 12px;
  color: var(--color-text-secondary);
  line-height: 1.4;
  margin-bottom: 10px;
}
.integracao-meta {
  font-size: 11.5px;
  color: var(--color-text-muted);
  margin-bottom: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.integracao-meta > div,
.integracao-meta > a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.integracao-meta svg { width: 12px; height: 12px; }
.integracao-meta a { color: var(--color-primary); text-decoration: none; }
.integracao-meta a:hover { text-decoration: underline; }

.integracao-alert {
  font-size: 11.5px;
  color: var(--color-warning);
  background: var(--color-warning-bg);
  border: 1px solid #FDE68A;
  padding: 6px 10px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
}
.integracao-alert svg { width: 12px; height: 12px; }

.integracao-actions {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
  gap: 8px;
  flex-wrap: wrap;
}

/* Modal de conectar SSO */
.sso-redirect {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 8px 0 4px;
}
.sso-escopo {
  width: 100%;
  padding: 12px 14px;
  background: var(--color-bg-subtle);
  border-radius: 6px;
  border: 1px solid var(--color-border);
}

/* Perfil editável em Configurações · foto grande + campos */
.perfil-edit {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 24px;
  align-items: flex-start;
}
@media (max-width: 720px) { .perfil-edit { grid-template-columns: 1fr; } }
.perfil-foto {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.perfil-foto-preview {
  width: 140px; height: 140px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid var(--color-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-gradient);
}
.perfil-foto-preview img { width: 100%; height: 100%; object-fit: cover; }
.photo-initials-lg {
  color: white;
  font-weight: 600;
  font-size: 44px;
  letter-spacing: 1px;
}
.perfil-campos { min-width: 0; }

.person-row { display: flex; align-items: center; gap: 10px; }
/* Selo de registro fictício · tag sutil, nunca inline no nome */
.fict-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.4px;
  background: var(--color-warning-bg);
  color: var(--color-warning);
  padding: 2px 7px;
  border-radius: 3px;
  border: 1px solid #FDE68A;
  text-transform: uppercase;
  white-space: nowrap;
}

/* Banner de registro fictício · faixa sutil acima do record-header */
.fict-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--color-warning-bg);
  color: var(--color-warning);
  border: 1px solid #FDE68A;
  border-radius: var(--radius-md);
  padding: 6px 12px;
  font-size: 11.5px;
  font-weight: 500;
  margin-bottom: 10px;
}
.fict-banner::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.fict-banner strong { font-weight: 600; letter-spacing: 0.3px; text-transform: uppercase; font-size: 10.5px; }

.record-photo {
  width: 64px; height: 64px; border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid var(--color-border);
}
.record-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ========== SUBTABS ========== */
.subtabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 20px;
}
.subtab {
  padding: 10px 16px;
  color: var(--color-text-muted);
  font-weight: 500;
  font-size: 13px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  text-decoration: none;
}
.subtab:hover { color: var(--color-text); text-decoration: none; }
.subtab.active { color: var(--color-text); border-bottom-color: var(--color-primary); font-weight: 600; }

/* ========== POST PREVIEWS ========== */
.post-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.post-ig, .post-fb, .post-blog {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: 12.5px;
}

.post-channel-head {
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.post-ig-head {
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--color-border);
}
.post-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(45deg, #F58529, #DD2A7B, #8134AF, #515BD4);
  padding: 2px; box-sizing: border-box;
}
.post-avatar-inner {
  width: 100%; height: 100%; border-radius: 50%;
  background: white; display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 11px; color: var(--color-text);
}
.post-img {
  aspect-ratio: 1; background: linear-gradient(135deg, #EEF2F6 0%, #D1D5DB 100%);
  display: flex; align-items: center; justify-content: center; color: var(--color-text-muted); font-size: 11px;
}
.post-caption { padding: 10px 12px; line-height: 1.45; color: var(--color-text); }
.post-actions { padding: 8px 12px; color: var(--color-text); display: flex; gap: 12px; }
.post-actions svg { width: 20px; height: 20px; }

.post-blog-title { padding: 14px 16px 4px; font-weight: 600; font-size: 14px; color: var(--color-text); }
.post-blog-body { padding: 0 16px 14px; color: var(--color-text-secondary); line-height: 1.5; }

/* ========== UTIL ========== */
.text-muted { color: var(--color-text-muted); }
.text-sm { font-size: 12px; }
.text-xs { font-size: 11px; }
.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
.mb-0 { margin-bottom: 0 !important; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mt-8 { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.gap-8 { gap: 8px; }
.flex { display: flex; }
.flex-center { display: flex; align-items: center; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.hidden { display: none !important; }

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #D1D5DB; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #9CA3AF; }
