/* ===== Reset & Base ===== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

:root {
  --primary: #1a56db;
  --primary-hover: #1347b8;
  --primary-light: #e8effc;
  --purple: #7c3aed;
  --purple-light: #ede9fe;
  --success: #059669;
  --success-bg: #ecfdf5;
  --warning: #d97706;
  --warning-bg: #fffbeb;
  --danger: #dc2626;
  --danger-bg: #fef2f2;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;
  --radius: 8px;
  --shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.06);
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background: var(--gray-100);
  color: var(--gray-800);
  line-height: 1.6;
  min-height: 100vh;
}

/* ===== Layout ===== */
.container {
  max-width: 780px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

/* ===== App Layout (Sidebar + Content) ===== */
.app-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
}

.app-content {
  max-width: 100%;
  min-width: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.page-content {
  max-width: 860px;
  margin: 0 auto;
  padding: 1.5rem 2rem 2rem;
  flex: 1;
  width: 100%;
  animation: pageIn 0.2s ease-out;
}

@keyframes pageIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ===== App Header ===== */
.app-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  border-bottom: 1px solid var(--gray-200);
  background: #fff;
  position: sticky;
  top: 0;
  z-index: 20;
}

.app-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.app-breadcrumb {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.app-header-title {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--gray-900);
  margin-top: -2px;
  letter-spacing: -0.02em;
}

.sidebar-mobile-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.25rem;
  color: var(--gray-600);
  cursor: pointer;
  padding: 0.25rem;
}

/* ===== Sidebar ===== */
.sidebar {
  background: #0f172a;
  color: #fff;
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow-y: auto;
  transition: width 0.2s;
}

.sidebar-header {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 1.25rem 1.25rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.sidebar-logo {
  height: 28px;
  filter: brightness(0) invert(1);
}

.sidebar-brand {
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  flex: 1;
}

.sidebar-toggle {
  background: none;
  border: none;
  color: rgba(255,255,255,0.65);
  font-size: 1rem;
  cursor: pointer;
  padding: 0.25rem;
  transition: color 0.15s;
}

.sidebar-toggle:hover {
  color: #fff;
}

/* Sidebar Nav */
.sidebar-nav {
  flex: 1;
  padding: 0.75rem 0;
  overflow-y: auto;
}

.sidebar-section {
  padding: 0.25rem 0;
}

.sidebar-section-label {
  display: block;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.55);
  padding: 0.75rem 1.25rem 0.375rem;
}

.sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 1.25rem;
  color: rgba(255,255,255,0.75);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.15s;
  border-left: 3px solid transparent;
}

.sidebar-link:hover {
  color: #fff;
  background: rgba(255,255,255,0.06);
}

.sidebar-link.active {
  color: #fff;
  background: rgba(26,86,219,0.2);
  border-left-color: #60a5fa;
}

.sidebar-icon {
  font-size: 1.125rem;
  min-width: 22px;
  text-align: center;
}

.sidebar-text {
  white-space: nowrap;
  flex: 1;
}

.sidebar-badge {
  font-size: 0.625rem;
  font-weight: 700;
  background: rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.7);
  padding: 0.125rem 0.4375rem;
  border-radius: 10px;
  min-width: 20px;
  text-align: center;
}

/* Sidebar Footer */
.sidebar-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  flex: 1;
  min-width: 0;
}

.sidebar-user-avatar {
  width: 32px;
  height: 32px;
  min-width: 32px;
  border-radius: 50%;
  background: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #fff;
}

.sidebar-user-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.sidebar-user-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-user-role {
  font-size: 0.6875rem;
  color: rgba(255,255,255,0.65);
}

.sidebar-footer .btn-ghost {
  color: rgba(255,255,255,0.65);
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
}

.sidebar-footer .btn-ghost:hover {
  color: #fff;
  background: rgba(255,255,255,0.1);
}

/* Sidebar collapsed */
.app-layout.sidebar-collapsed {
  grid-template-columns: 64px 1fr;
}

.app-layout.sidebar-collapsed .sidebar-text,
.app-layout.sidebar-collapsed .sidebar-section-label,
.app-layout.sidebar-collapsed .sidebar-brand,
.app-layout.sidebar-collapsed .sidebar-user-info {
  display: none;
}

.app-layout.sidebar-collapsed .sidebar-link {
  justify-content: center;
  padding: 0.625rem;
  border-left: none;
  position: relative;
}

.app-layout.sidebar-collapsed .sidebar-link:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  margin-left: 8px;
  background: var(--gray-900);
  color: #fff;
  padding: 0.375rem 0.625rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
  z-index: 60;
  pointer-events: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.app-layout.sidebar-collapsed .sidebar-header {
  justify-content: center;
  padding: 1.25rem 0.5rem 1rem;
}

.app-layout.sidebar-collapsed .sidebar-footer {
  flex-direction: column;
  padding: 0.75rem 0.5rem;
  gap: 0.5rem;
}

/* Sidebar mobile */
@media (max-width: 768px) {
  .app-layout {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: fixed;
    left: -280px;
    top: 0;
    width: 260px;
    z-index: 50;
    transition: left 0.25s;
  }

  .sidebar.sidebar-open {
    left: 0;
  }

  .sidebar-mobile-toggle {
    display: block;
  }

  .sidebar-toggle {
    display: none;
  }

  .app-layout.sidebar-collapsed {
    grid-template-columns: 1fr;
  }

  .page-content {
    padding: 1rem;
  }

  .app-header {
    padding: 0.75rem 1rem;
  }
}

/* Sidebar overlay (mobile) */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 40;
}

.sidebar-overlay.visible {
  display: block;
}

/* ===== B2B Form Styles ===== */
.b2b-form {
  max-width: 640px;
}

.form-section-title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--gray-800);
  margin: 1.5rem 0 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-100);
}

.form-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-100);
}

/* ===== B2B Toolbar ===== */
.b2b-toolbar {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.b2b-search {
  flex: 1;
  min-width: 200px;
}

.b2b-search input {
  width: 100%;
  padding: 0.5625rem 0.875rem 0.5625rem 2.25rem;
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-size: 0.875rem;
  color: var(--gray-800);
  background: var(--gray-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85zm-5.242.656a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") no-repeat 0.75rem center;
  transition: all 0.15s;
}

.b2b-search input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(26,86,219,0.1);
  background-color: #fff;
}

.b2b-filters {
  display: flex;
  gap: 0.5rem;
}

.b2b-filters select {
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-size: 0.8125rem;
  color: var(--gray-700);
  background: var(--gray-50);
  cursor: pointer;
  transition: border-color 0.15s;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.625rem center;
}

.b2b-filters select:focus {
  border-color: var(--primary);
  outline: none;
  background-color: #fff;
}

/* ===== B2B Table ===== */
.b2b-table-wrapper {
  overflow-x: auto;
}

.b2b-table .actions-cell {
  white-space: nowrap;
}

.b2b-table .btn-action {
  background: none;
  border: none;
  color: var(--gray-400);
  cursor: pointer;
  padding: 0.25rem 0.375rem;
  font-size: 0.875rem;
  border-radius: 4px;
  transition: all 0.15s;
}

.b2b-table .btn-action:hover {
  color: var(--primary);
  background: var(--primary-light);
}

.b2b-table .btn-action.btn-action-danger:hover {
  color: var(--danger);
  background: var(--danger-bg);
}

/* ===== B2B Pagination ===== */
.b2b-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  margin-top: 1rem;
  font-size: 0.8125rem;
}

.b2b-pagination button {
  padding: 0.375rem 0.625rem;
  border: 1px solid var(--gray-200);
  border-radius: 4px;
  background: #fff;
  color: var(--gray-600);
  cursor: pointer;
  font-size: 0.8125rem;
  transition: all 0.15s;
}

.b2b-pagination button:hover {
  background: var(--gray-50);
  border-color: var(--gray-300);
}

.b2b-pagination button.active {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}

.b2b-pagination button:disabled {
  opacity: 0.4;
  cursor: default;
}

.pag-info {
  color: var(--text-muted);
  font-size: 0.8rem;
  margin-right: 0.5rem;
}

.pag-dots {
  color: var(--gray-400);
  padding: 0 0.25rem;
}

/* ===== Modal Large ===== */
.modal-lg {
  max-width: 560px;
}

/* ===== Toggle/Switch ===== */
.b2b-toggles {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.toggle-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.15s;
}

.toggle-item:hover {
  background: var(--gray-50);
}

.toggle-item input {
  display: none;
}

.toggle-switch {
  width: 40px;
  height: 22px;
  min-width: 40px;
  background: var(--gray-300);
  border-radius: 11px;
  position: relative;
  transition: background 0.2s;
}

.toggle-switch::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
}

.toggle-item input:checked + .toggle-switch {
  background: var(--primary);
}

.toggle-item input:checked + .toggle-switch::after {
  transform: translateX(18px);
}

.toggle-text {
  flex: 1;
}

.toggle-text strong {
  display: block;
  font-size: 0.875rem;
  color: var(--gray-800);
  margin-bottom: 0.125rem;
}

.toggle-text span {
  font-size: 0.8125rem;
  color: var(--gray-500);
}

/* ===== Danger Zone ===== */
.b2b-danger-zone {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.danger-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.875rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
}

.danger-action strong {
  display: block;
  font-size: 0.875rem;
  color: var(--gray-800);
  margin-bottom: 0.125rem;
}

.danger-action p {
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin: 0;
}

.btn-danger-text {
  color: var(--danger) !important;
}

.btn-danger-text:hover {
  background: var(--danger-bg) !important;
}

.btn-danger {
  background: var(--danger);
  color: #fff;
  border-color: var(--danger);
}

.btn-danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
}

/* ===== Planos Grid ===== */
.plano-atual {
  margin-bottom: 1rem;
}

.plano-card {
  padding: 1.25rem;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius);
}

.plano-card.plano-ativo {
  border-color: var(--primary);
  background: var(--primary-light);
}

.plano-info h3 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.25rem;
}

.plano-info p {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin: 0;
}

.plano-uso {
  margin: 1rem 0 0.5rem;
}

.plano-uso-bar {
  height: 8px;
  background: rgba(0,0,0,0.08);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 0.375rem;
}

.plano-uso-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 4px;
  transition: width 0.3s;
}

.plano-uso-fill.usage-warn { background: var(--warning); }
.plano-uso-fill.usage-danger { background: var(--danger); }

.plano-selecionado {
  border: 2px solid var(--primary) !important;
  background: #f0f4ff !important;
}

.plano-uso-text {
  font-size: 0.8125rem;
  color: var(--gray-600);
  font-weight: 500;
}

.plano-periodo {
  font-size: 0.75rem;
  color: var(--gray-400);
}

.planos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.plano-option {
  padding: 1.5rem 1.25rem;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius);
  text-align: center;
  position: relative;
}

.plano-option.plano-destaque {
  border-color: var(--primary);
}

.plano-popular {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.1875rem 0.75rem;
  border-radius: 20px;
}

.plano-option h4 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.5rem;
}

.plano-preco {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--gray-900);
  margin-bottom: 1rem;
}

.plano-preco small {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-400);
}

.plano-features {
  list-style: none;
  text-align: left;
  font-size: 0.8125rem;
  color: var(--gray-600);
  margin-bottom: 1rem;
}

.plano-features li {
  padding: 0.25rem 0;
  padding-left: 1.25rem;
  position: relative;
}

.plano-features li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  color: var(--success);
  font-weight: 700;
}

/* ===== Sessions ===== */
.b2b-sessions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.session-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
}

.session-item.session-current {
  border-color: var(--primary);
  background: #f0f4ff;
}

.session-icon {
  font-size: 1.25rem;
  opacity: 0.6;
  flex-shrink: 0;
}

.session-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  flex: 1;
}

.session-info small {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.session-device {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-800);
}

.session-meta {
  font-size: 0.75rem;
  color: var(--gray-400);
}

.session-current {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--success);
  background: var(--success-bg);
  padding: 0.125rem 0.5rem;
  border-radius: 20px;
}

@media (max-width: 768px) {
  .planos-grid {
    grid-template-columns: 1fr;
  }
  .b2b-toolbar {
    flex-direction: column;
  }
  .b2b-filters {
    flex-wrap: wrap;
  }
}

/* ===== Header (legacy, inside page content) ===== */
.logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.logo-img {
  height: 36px;
  width: auto;
}

.logo-icon {
  font-size: 2.5rem;
  color: var(--primary);
}

.logo h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--gray-900);
  line-height: 1.2;
}

.subtitle {
  font-size: 0.875rem;
  color: var(--gray-500);
}

/* ===== Cards ===== */
.card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  border: 1px solid var(--gray-100);
  transition: box-shadow 0.2s;
}

.card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04);
}

.card-upload {
  border: 2px solid var(--primary-light);
}

.card h2 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--gray-900);
  margin-bottom: 0.25rem;
}

.card-header-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.25rem;
}

.card-description {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin-bottom: 1.25rem;
}

/* ===== Drop Zone ===== */
.drop-zone {
  border: 2px dashed var(--gray-300);
  border-radius: 12px;
  padding: 3rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--gray-50);
}

.drop-zone:hover,
.drop-zone.drag-over {
  border-color: var(--primary);
  background: var(--primary-light);
  border-style: solid;
  transform: scale(1.01);
}

.drop-icon {
  font-size: 3rem;
  display: block;
  margin-bottom: 0.5rem;
}

.drop-zone-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0.5rem 0;
}

.btn-camera { display: none; }
@media (pointer: coarse), (max-width: 768px) {
  .btn-camera { display: inline-flex; }
}

.drop-text {
  font-size: 1rem;
  font-weight: 600;
  color: var(--gray-700);
}

.drop-hint {
  font-size: 0.875rem;
  color: var(--gray-400);
  margin-top: 0.25rem;
}

.drop-formats {
  font-size: 0.75rem;
  color: var(--gray-400);
  margin-top: 0.5rem;
}

/* ===== Preview ===== */
.preview-container {
  margin-top: 1rem;
}

.preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.preview-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--success);
}

.preview-image-wrapper {
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 1rem;
  max-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-50);
}

.preview-image-wrapper img {
  max-width: 100%;
  max-height: 400px;
  object-fit: contain;
}

/* ===== Loading / Spinner ===== */
.analysis-loading {
  text-align: center;
  padding: 2rem 1rem;
}

.spinner {
  width: 40px;
  height: 40px;
  border: 4px solid var(--gray-200);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 1rem;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.loading-text {
  font-size: 1rem;
  font-weight: 600;
  color: var(--gray-700);
}

.loading-hint {
  font-size: 0.8125rem;
  color: var(--gray-400);
  margin-top: 0.25rem;
}

/* ===== AI Result ===== */
.ai-result {
  margin-top: 1.25rem;
  padding: 1rem;
  background: var(--purple-light);
  border-radius: var(--radius);
  border: 1px solid #c4b5fd;
}

.ai-result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.ai-badge {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--purple);
}

.ai-confidence {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.625rem;
  border-radius: 20px;
}

.conf-alta {
  background: var(--success-bg);
  color: var(--success);
}

.conf-media {
  background: var(--warning-bg);
  color: var(--warning);
}

.conf-baixa {
  background: var(--danger-bg);
  color: var(--danger);
}

.ai-summary p {
  font-size: 0.875rem;
  color: var(--gray-700);
  line-height: 1.5;
}

.ai-alerts {
  margin-top: 0.75rem;
  padding: 0.75rem;
  background: rgba(255,255,255,0.6);
  border-radius: 6px;
}

.ai-alerts strong {
  font-size: 0.8125rem;
  color: var(--danger);
}

.ai-alerts ul {
  margin-top: 0.375rem;
  padding-left: 1.25rem;
}

.ai-alerts li {
  font-size: 0.8125rem;
  color: var(--gray-700);
  margin-bottom: 0.25rem;
}

/* ===== Badge ===== */
.badge {
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.1875rem 0.625rem;
  border-radius: 20px;
  letter-spacing: 0.02em;
}

.badge-ai {
  background: var(--purple-light);
  color: var(--purple);
}

/* ===== AI Parecer ===== */
.ai-parecer {
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 1rem;
  font-size: 0.875rem;
}

.ai-parecer .ai-badge {
  display: block;
  margin-bottom: 0.375rem;
}

.ai-parecer p {
  color: var(--gray-700);
}

.parecer-valido {
  background: var(--success-bg);
  border: 1px solid #a7f3d0;
}

.parecer-pendente {
  background: var(--warning-bg);
  border: 1px solid #fde68a;
}

.parecer-invalido {
  background: var(--danger-bg);
  border: 1px solid #fca5a5;
}

/* ===== Forms ===== */
.form-row {
  margin-bottom: 1rem;
}

.form-row.two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.form-group label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 0.375rem;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 0.5625rem 0.875rem;
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-size: 0.875rem;
  color: var(--gray-800);
  background: var(--gray-50);
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(26,86,219,0.1);
  background: #fff;
}

.form-group input.invalid,
.form-group select.invalid {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px var(--danger-bg);
}

.form-group textarea {
  resize: vertical;
}

/* ===== Checklist ===== */
.checklist {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.check-item {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
  font-size: 0.875rem;
  color: var(--gray-700);
}

.check-item:hover {
  background: var(--gray-50);
}

.check-item input[type="checkbox"] {
  display: none;
}

.checkmark {
  width: 20px;
  height: 20px;
  min-width: 20px;
  margin-top: 1px;
  border: 2px solid var(--gray-300);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}

.check-item input:checked + .checkmark {
  background: var(--success);
  border-color: var(--success);
}

.check-item input:checked + .checkmark::after {
  content: '\2713';
  color: white;
  font-size: 0.75rem;
  font-weight: bold;
}

.check-item.ai-fail .checkmark {
  background: var(--danger);
  border-color: var(--danger);
}

.check-item.ai-fail .checkmark::after {
  content: '\2717';
  color: white;
  font-size: 0.75rem;
  font-weight: bold;
}

.check-text {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.check-ai-note {
  font-size: 0.75rem;
  font-style: italic;
  display: none;
}

.check-ai-note.note-ok {
  display: block;
  color: var(--success);
}

.check-ai-note.note-warn {
  display: block;
  color: var(--danger);
}

.checklist-status {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  display: none;
}

.checklist-status.show {
  display: block;
}

.checklist-status.complete {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid #a7f3d0;
}

.checklist-status.incomplete {
  background: var(--warning-bg);
  color: var(--warning);
  border: 1px solid #fde68a;
}

/* ===== CFM Section ===== */
.cfm-loading {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  color: var(--gray-500);
  font-size: 0.875rem;
}

.spinner.spinner-sm {
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: 3px solid var(--gray-200);
  border-top-color: var(--primary);
  margin: 0;
}

.cfm-no-crm {
  padding: 1rem;
  text-align: center;
  color: var(--gray-400);
  font-size: 0.875rem;
}

.cfm-resultado {
  border-radius: var(--radius);
  overflow: hidden;
}

.cfm-status-bar {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.75rem 1rem;
  font-weight: 600;
  font-size: 0.9375rem;
}

.cfm-status-bar.status-ativo {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid #a7f3d0;
}

.cfm-status-bar.status-inativo {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #fca5a5;
}

.cfm-status-bar.status-nao-encontrado {
  background: var(--warning-bg);
  color: var(--warning);
  border: 1px solid #fde68a;
}

.cfm-status-icon {
  font-size: 1.25rem;
}

.cfm-details {
  margin-top: 0.75rem;
}

.cfm-details table {
  width: 100%;
  border-collapse: collapse;
}

.cfm-details td {
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--gray-100);
}

.cfm-details td:first-child {
  font-weight: 600;
  color: var(--gray-500);
  width: 140px;
}

.cfm-details td:last-child {
  color: var(--gray-800);
}

.cfm-nome-match {
  margin-top: 0.75rem;
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
}

.cfm-nome-match.match-ok {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid #a7f3d0;
}

.cfm-nome-match.match-fail {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #fca5a5;
}

.cfm-nao-encontrado-details {
  padding: 0.75rem 1rem;
  margin-top: 0.75rem;
  font-size: 0.8125rem;
  color: var(--gray-600);
  background: var(--gray-50);
  border-radius: 6px;
}

.cfm-nao-encontrado-details ul {
  margin: 0.375rem 0 0.5rem 1.25rem;
}

.cfm-nao-encontrado-details li {
  margin-bottom: 0.25rem;
}

.cfm-buscas {
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: var(--gray-400);
}

.cfm-aviso {
  padding: 0.625rem 0.75rem;
  margin-top: 0.5rem;
  background: var(--warning-bg);
  border: 1px solid #fde68a;
  border-radius: 6px;
  font-size: 0.8125rem;
  color: var(--warning);
}

.cfm-hint-correcao {
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin-top: 0.75rem;
  padding: 0 0.25rem;
}

.btn-reconsultar {
  margin-top: 0.75rem;
  color: var(--primary) !important;
  font-weight: 600 !important;
}

.btn-reconsultar:hover {
  background: var(--primary-light) !important;
}

.highlight {
  background: #fef3c7;
  padding: 0.125rem 0.375rem;
  border-radius: 3px;
  font-weight: 600;
}

.hidden {
  display: none !important;
}

/* ===== Buttons ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: -0.01em;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 1px 2px rgba(26,86,219,0.2);
}

.btn-primary:hover:not(:disabled) {
  background: var(--primary-hover);
  box-shadow: 0 4px 12px rgba(26,86,219,0.3);
  transform: translateY(-1px);
}

.btn-primary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(26,86,219,0.2);
}

.btn-lg {
  padding: 0.75rem 2rem;
  font-size: 1rem;
  width: 100%;
  justify-content: center;
}

.btn-sm {
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}

.btn-secondary {
  background: var(--gray-800);
  color: #fff;
  width: 100%;
  justify-content: center;
  margin-top: 0.5rem;
}

.btn-secondary:hover {
  background: var(--gray-900);
  box-shadow: var(--shadow-md);
}

.btn-ghost {
  background: transparent;
  color: var(--gray-500);
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}

.btn-ghost:hover {
  background: var(--gray-100);
  color: var(--gray-700);
}

.btn-icon {
  font-size: 1.125rem;
}

/* ===== Modal ===== */
.modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 1;
}

.modal-content {
  position: relative;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15), 0 4px 16px rgba(0,0,0,0.08);
  padding: 1.75rem;
  width: 90%;
  max-width: 420px;
  animation: modalIn 0.2s ease-out;
  z-index: 2;
}

@keyframes modalIn {
  from { opacity: 0; transform: scale(0.95) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.modal-content h3 {
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.modal-content p {
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin-bottom: 1rem;
}

.modal-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  margin-top: 1rem;
}

/* ===== Parecer ===== */
.parecer-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

.radio-card input {
  display: none;
}

.radio-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
  padding: 1.125rem 0.5rem;
  border: 2px solid var(--gray-200);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
  text-align: center;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--gray-600);
}

.radio-content:hover {
  border-color: var(--gray-300);
  background: var(--gray-50);
}

.radio-icon {
  font-size: 1.5rem;
}

.radio-card input:checked + .radio-content.valid {
  border-color: var(--success);
  background: var(--success-bg);
  color: var(--success);
}

.radio-card input:checked + .radio-content.pending {
  border-color: var(--warning);
  background: var(--warning-bg);
  color: var(--warning);
}

.radio-card input:checked + .radio-content.invalid {
  border-color: var(--danger);
  background: var(--danger-bg);
  color: var(--danger);
}

/* ===== Export Dropdown ===== */
.dash-actions { display: flex; gap: 0.375rem; align-items: center; }
.dash-export-menu { position: relative; }
.export-dropdown { position: absolute; right: 0; top: 100%; background: #fff; border: 1px solid var(--gray-200); border-radius: 6px; box-shadow: var(--shadow-md); z-index: 10; min-width: 180px; margin-top: 0.25rem; }
.export-item { display: block; padding: 0.5rem 0.75rem; font-size: 0.8125rem; color: var(--gray-700); text-decoration: none; transition: background 0.15s; }
.export-item:hover { background: var(--gray-50); }

/* ===== Inline Dashboard ===== */
.card-dashboard {
  border: 2px solid var(--purple-light);
}

.dash-summary {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.dash-stat {
  text-align: center;
  padding: 0.875rem 0.5rem;
  background: #fff;
  border-radius: 10px;
  border: 1px solid var(--gray-100);
  transition: transform 0.15s, box-shadow 0.15s;
}

.dash-stat:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}

.dash-stat-value {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--gray-900);
  letter-spacing: -0.02em;
}

.dash-stat-label {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 0.125rem;
}

.dash-valido .dash-stat-value { color: var(--success); }
.dash-pendente .dash-stat-value { color: var(--warning); }
.dash-invalido .dash-stat-value { color: var(--danger); }

/* Anomalias inline */
.dash-anomalias {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.dash-anomalia {
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}

.dash-anomalia-critical {
  background: var(--danger-bg);
  border: 1px solid #fca5a5;
}

.dash-anomalia-warning {
  background: var(--warning-bg);
  border: 1px solid #fde68a;
}

.dash-anomalia-info {
  background: var(--primary-light);
  border: 1px solid #bfdbfe;
}

.dash-anomalia strong { color: var(--gray-900); }

.dash-no-anomalias {
  padding: 1rem;
  text-align: center;
  color: var(--success);
  font-weight: 500;
  background: var(--success-bg);
  border-radius: 6px;
  font-size: 0.8125rem;
  margin-bottom: 1.25rem;
}

/* Tabs */
.dash-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--gray-200);
  margin-bottom: 1rem;
}

.dash-tab {
  padding: 0.5rem 1.125rem;
  border: none;
  background: none;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-400);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all 0.15s;
  position: relative;
}

.dash-tab:hover {
  color: var(--gray-700);
}

.dash-tab.active {
  color: var(--primary);
  border-bottom-color: var(--primary);
  background: rgba(26,86,219,0.04);
  border-radius: 6px 6px 0 0;
}

.dash-tab-content {
  min-height: 100px;
}

/* Inline tables */
.dash-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}

.dash-table th {
  text-align: left;
  padding: 0.5rem 0.625rem;
  font-weight: 600;
  color: var(--gray-500);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 2px solid var(--gray-200);
  white-space: nowrap;
}

.dash-table td {
  padding: 0.5rem 0.625rem;
  border-bottom: 1px solid var(--gray-100);
  color: var(--gray-700);
}

.dash-table tbody tr { transition: background 0.1s; }
.dash-table tbody tr:hover td { background: #f0f4ff; }
.dash-table .num { text-align: center; font-weight: 600; }
.dash-table .num-warn { color: var(--warning); font-weight: 700; }
.dash-table .num-danger { color: var(--danger); font-weight: 700; }

.dash-tag {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 20px;
  font-size: 0.6875rem;
  font-weight: 600;
}

.dash-tag-ativo { background: var(--success-bg); color: var(--success); }
.dash-tag-inativo { background: var(--danger-bg); color: var(--danger); }
.dash-tag-ferias { background: var(--primary-light); color: var(--primary); }
.dash-tag-afastado { background: var(--warning-bg); color: var(--warning); }

/* Detail row */
.dash-detail-row { display: none; }
.dash-detail-row.open { display: table-row; }
.dash-detail-row td { background: var(--gray-50); padding: 0.75rem; }

.dash-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

.dash-detail-section h4 {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--gray-500);
  text-transform: uppercase;
  margin-bottom: 0.375rem;
}

.dash-detail-section ul { list-style: none; font-size: 0.8125rem; }
.dash-detail-section li { padding: 0.1875rem 0; color: var(--gray-600); }

.dash-dia-bar {
  display: inline-block;
  height: 10px;
  background: var(--primary);
  border-radius: 2px;
  min-width: 3px;
}

/* Timeline inline */
.dash-timeline-row {
  display: grid;
  grid-template-columns: 70px 1fr 50px;
  align-items: center;
  gap: 0.625rem;
  padding: 0.375rem 0;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--gray-100);
}

.dash-timeline-bar {
  height: 16px;
  background: var(--gray-100);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
}

.dash-bar-v { background: var(--success); }
.dash-bar-p { background: var(--warning); }
.dash-bar-i { background: var(--danger); }

.dash-timeline-label { color: var(--gray-500); font-weight: 500; }
.dash-timeline-count { text-align: right; font-weight: 600; color: var(--gray-700); }

.dash-legend {
  display: flex;
  gap: 0.75rem;
  margin-top: 0.5rem;
  font-size: 0.6875rem;
  color: var(--gray-400);
}

.dash-legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  vertical-align: middle;
  margin-right: 3px;
}

.dash-empty {
  text-align: center;
  padding: 1.5rem;
  color: var(--gray-400);
  font-size: 0.8125rem;
}

.dash-click-hint {
  font-size: 0.6875rem;
  color: var(--gray-400);
  margin-bottom: 0.5rem;
}

/* ===== Footer ===== */
footer {
  text-align: center;
  padding: 1.5rem 0 0;
  font-size: 0.8125rem;
  color: var(--gray-400);
}

footer a {
  color: var(--primary);
  text-decoration: none;
}

footer a:hover {
  text-decoration: underline;
}

.footer-note {
  margin-top: 0.25rem;
}

/* ===== Responsive ===== */
@media (max-width: 600px) {
  .container {
    padding: 1rem 0.75rem;
  }

  .app-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }

  .form-row.two-cols {
    grid-template-columns: 1fr;
  }

  .parecer-options {
    grid-template-columns: 1fr;
  }

  .drop-zone {
    padding: 2rem 1rem;
  }

  .dash-summary {
    grid-template-columns: repeat(3, 1fr);
  }

  .dash-detail-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== Auth Screen (Split Layout) ===== */
.auth-screen {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* --- Hero Side --- */
.auth-hero {
  background: linear-gradient(145deg, #0f2a5e 0%, #1a56db 60%, #2563eb 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 2.5rem;
  position: relative;
  overflow: hidden;
}

.auth-hero::before {
  content: '';
  position: absolute;
  top: -120px;
  right: -120px;
  width: 400px;
  height: 400px;
  background: rgba(255,255,255,0.04);
  border-radius: 50%;
}

.auth-hero::after {
  content: '';
  position: absolute;
  bottom: -80px;
  left: -80px;
  width: 300px;
  height: 300px;
  background: rgba(255,255,255,0.03);
  border-radius: 50%;
}

.auth-hero-content {
  position: relative;
  z-index: 1;
  max-width: 480px;
}

.auth-hero-brand {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  margin-bottom: 2.5rem;
}

.auth-hero-logo {
  height: 32px;
  filter: brightness(0) invert(1);
}

.auth-hero-brand-name {
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.auth-hero-title {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}

.auth-hero-subtitle {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.8);
  margin-bottom: 2.25rem;
}

/* Metrics */
.auth-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 2.25rem;
}

.auth-metric {
  text-align: center;
  padding: 1rem 0.5rem;
  background: rgba(255,255,255,0.1);
  border-radius: 8px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}

.auth-metric-value {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 0.25rem;
}

.auth-metric-label {
  font-size: 0.6875rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.3;
}

/* Features */
.auth-features {
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
  margin-bottom: 2.25rem;
}

.auth-feature {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
}

.auth-feature-icon {
  font-size: 1.5rem;
  min-width: 28px;
  text-align: center;
  margin-top: 2px;
}

.auth-feature strong {
  display: block;
  font-size: 0.9375rem;
  font-weight: 700;
  margin-bottom: 0.125rem;
}

.auth-feature p {
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.4;
  margin: 0;
}

/* Social proof */
.auth-proof {
  padding: 1.25rem;
  background: rgba(255,255,255,0.08);
  border-radius: 8px;
  border-left: 3px solid rgba(255,255,255,0.3);
  margin-bottom: 2rem;
}

.auth-proof-quote {
  font-size: 0.9375rem;
  font-style: italic;
  line-height: 1.5;
  margin-bottom: 0.5rem;
  color: rgba(255,255,255,0.9);
}

.auth-proof-author {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.65);
  margin: 0;
}

/* Urgência — case-driven alert */
.auth-alert {
  position: relative;
  padding: 1.125rem 1.25rem 1.25rem;
  margin-bottom: 1.75rem;
  background: linear-gradient(135deg, rgba(217,119,6,0.18), rgba(220,38,38,0.14));
  border: 1px solid rgba(255,255,255,0.18);
  border-left: 3px solid var(--warning);
  border-radius: 10px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}

.auth-alert-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.625rem;
  margin-bottom: 0.75rem;
  background: rgba(220,38,38,0.2);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #fff;
}

.auth-alert-pulse {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ff6b6b;
}

.auth-alert-pulse::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #ff6b6b;
  opacity: 0.7;
  transform: scale(1);
  transform-origin: center;
  will-change: transform, opacity;
  animation: authAlertPulse 1.8s infinite;
}

@keyframes authAlertPulse {
  0%   { transform: scale(1);   opacity: 0.7; }
  70%  { transform: scale(3.5); opacity: 0;   }
  100% { transform: scale(3.5); opacity: 0;   }
}

.auth-alert-title {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
  margin: 0 0 0.5rem;
  color: #fff;
}

.auth-alert-title strong {
  color: #ffd591;
}

.auth-alert-body {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
  margin: 0 0 0.625rem;
}

.auth-alert-body strong {
  color: #fff;
  font-weight: 700;
}

.auth-alert-cta {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #fff;
  margin: 0;
}

@media (prefers-reduced-motion: reduce) {
  .auth-alert-pulse { animation: none; }
}

@media (max-width: 768px) {
  .auth-alert {
    padding: 1rem;
    margin-bottom: 1.25rem;
  }
  .auth-alert-title { font-size: 0.9375rem; }
  .auth-alert-body, .auth-alert-cta { font-size: 0.75rem; }
}

.auth-hero-footer {
  display: flex;
  gap: 0.625rem;
  font-size: 0.75rem;
}

.auth-hero-footer a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  transition: color 0.15s;
}

.auth-hero-footer a:hover {
  color: #fff;
}

.auth-hero-footer span {
  color: rgba(255,255,255,0.25);
}

/* --- Form Side --- */
.auth-form-side {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background: var(--gray-50);
}

.auth-card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: 2.5rem 2rem;
  width: 100%;
  max-width: 400px;
}

.auth-logo {
  text-align: center;
  margin-bottom: 2rem;
}

.auth-logo .logo-img {
  height: 36px;
  margin-bottom: 0.75rem;
}

.auth-logo h2 {
  font-size: 1.25rem;
  color: var(--gray-900);
  font-weight: 700;
}

.auth-form .form-group {
  margin-bottom: 1rem;
}

.auth-error {
  background: var(--danger-bg);
  color: var(--danger);
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-bottom: 1rem;
  border: 1px solid #fca5a5;
}

.auth-toggle {
  text-align: center;
  margin-top: 1rem;
  font-size: 0.875rem;
  color: var(--gray-500);
}

.auth-toggle a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
}

.auth-toggle a:hover {
  text-decoration: underline;
}

.auth-legal {
  text-align: center;
  font-size: 0.6875rem;
  color: var(--gray-400);
  margin-top: 1.5rem;
  line-height: 1.4;
}

.auth-legal a {
  color: var(--gray-500);
  text-decoration: underline;
}

/* Invite flow */
.auth-invite-info {
  font-size: 0.875rem;
  color: var(--gray-500);
  text-align: center;
  margin-bottom: 1.25rem;
  line-height: 1.5;
}

.input-invite-code {
  text-align: center;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 1.125rem !important;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.auth-invite-validated {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--success-bg);
  border: 1px solid #a7f3d0;
  border-radius: 6px;
  margin-bottom: 1.25rem;
}

.auth-invite-check {
  font-size: 1.25rem;
  color: var(--success);
  min-width: 24px;
}

.auth-invite-validated strong {
  display: block;
  font-size: 0.9375rem;
  color: var(--gray-800);
}

.auth-invite-code-badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  color: var(--success);
  font-weight: 600;
  margin-top: 0.125rem;
}

.auth-toggle-secondary {
  margin-top: 0.5rem;
}

.auth-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

@media (max-width: 480px) {
  .auth-form-row {
    grid-template-columns: 1fr;
  }
}

/* Forgot password */
.auth-forgot {
  text-align: center;
  margin-top: 0.75rem;
  margin-bottom: -0.25rem;
  font-size: 0.8125rem;
}

.auth-forgot a {
  color: var(--gray-400);
  text-decoration: none;
}

.auth-forgot a:hover {
  color: var(--primary);
  text-decoration: underline;
}

.auth-reset-info {
  font-size: 0.875rem;
  color: var(--gray-500);
  text-align: center;
  margin-bottom: 1.25rem;
  line-height: 1.5;
}

.auth-reset-sent {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--primary-light);
  border: 1px solid #bfdbfe;
  border-radius: 6px;
  margin-bottom: 1.25rem;
  font-size: 0.875rem;
  color: var(--gray-700);
}

.auth-reset-sent-icon {
  font-size: 1.5rem;
}

.input-reset-code {
  text-align: center;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 1.5rem !important;
  font-weight: 700;
  letter-spacing: 0.3em;
}

.auth-success {
  background: var(--success-bg);
  color: var(--success);
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-bottom: 1rem;
  border: 1px solid #a7f3d0;
  text-align: center;
}

/* --- Auth Responsive --- */
@media (max-width: 900px) {
  .auth-screen {
    grid-template-columns: 1fr;
  }

  .auth-hero {
    padding: 2rem 1.5rem;
  }

  .auth-hero-title {
    font-size: 1.5rem;
  }

  .auth-hero-subtitle {
    font-size: 0.9375rem;
    margin-bottom: 1.5rem;
  }

  .auth-metrics {
    margin-bottom: 1.5rem;
  }

  .auth-features {
    display: none;
  }

  .auth-proof {
    display: none;
  }
}

@media (max-width: 480px) {
  .auth-hero {
    padding: 1.5rem 1rem;
  }

  .auth-hero-title {
    font-size: 1.25rem;
  }

  .auth-metrics {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }

  .auth-metric {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-align: left;
    padding: 0.75rem;
  }

  .auth-metric-value {
    font-size: 1.25rem;
    margin-bottom: 0;
    min-width: 50px;
  }

  .auth-form-side {
    padding: 1.5rem 1rem;
  }

  .auth-card {
    padding: 1.5rem 1.25rem;
  }
}

/* ===== User Info (header) ===== */
.user-info {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.user-nome {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-600);
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Usage counter */
.usage-counter {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.usage-bar {
  width: 60px;
  height: 6px;
  background: var(--gray-200);
  border-radius: 3px;
  overflow: hidden;
}

.usage-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s, background 0.3s;
  background: var(--success);
}

.usage-bar-fill.usage-warn { background: var(--warning); }
.usage-bar-fill.usage-danger { background: var(--danger); }

.usage-text {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--gray-400);
  white-space: nowrap;
}

@media (max-width: 600px) {
  .usage-counter { display: none; }
}

/* ===== Save Indicator ===== */
.save-indicator {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  border-radius: 8px;
  font-size: 0.8125rem;
  font-weight: 500;
  margin: 1rem 0;
  transition: all 0.3s;
  animation: slideIn 0.25s ease-out;
}

@keyframes slideIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.save-indicator.save-ok {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid #a7f3d0;
}

.save-indicator.save-error {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #fca5a5;
}

.save-icon {
  font-size: 1rem;
}

/* ===== PDF Info ===== */
.pdf-page-info {
  font-size: 0.75rem;
  color: var(--purple);
  background: var(--purple-light);
  padding: 0.375rem 0.75rem;
  border-radius: 4px;
  margin-bottom: 0.75rem;
  text-align: center;
  font-weight: 500;
}

/* ===== Upload em Lote ===== */
.lote-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.lote-status {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-600);
}

.lote-progress {
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.lote-progress-bar {
  flex: 1;
  height: 8px;
  background: var(--gray-200);
  border-radius: 4px;
  overflow: hidden;
}

.lote-progress-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 4px;
  transition: width 0.3s;
  width: 0%;
}

.lote-progress-text {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gray-500);
  white-space: nowrap;
}

.lote-table td {
  font-size: 0.8125rem;
}

.lote-table td:first-child {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lote-badge {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 20px;
  font-size: 0.6875rem;
  font-weight: 600;
}

.lote-pendente {
  background: var(--gray-100);
  color: var(--gray-500);
}

.lote-processando {
  background: var(--primary-light);
  color: var(--primary);
  animation: lote-pulse 1.5s ease-in-out infinite;
}

@keyframes lote-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.lote-ok {
  background: var(--success-bg);
  color: var(--success);
}

.lote-erro {
  background: var(--danger-bg);
  color: var(--danger);
}

.lote-actions {
  margin-top: 0.75rem;
  display: flex;
  gap: 0.5rem;
}

.lote-row-rejected td {
  opacity: 0.4;
  text-decoration: line-through;
}

@media (max-width: 600px) {
  /* Scroll instead of hiding columns — all data stays accessible */
  .lote-table-wrapper,
  .b2b-table-wrapper {
    overflow-x: auto;
  }
  .lote-table,
  .dash-table {
    min-width: 600px;
  }
}

/* ===== Free Tier Limite ===== */
.limite-card {
  text-align: center;
  padding: 2rem 1.5rem;
}

.limite-icon {
  font-size: 3rem;
  margin-bottom: 0.75rem;
}

.limite-card h3 {
  font-size: 1.25rem;
  color: var(--gray-900);
  margin-bottom: 0.5rem;
}

.limite-card p {
  font-size: 0.9375rem;
  color: var(--gray-600);
  line-height: 1.5;
  margin-bottom: 0.25rem;
}

.limite-hint {
  font-size: 0.75rem !important;
  color: var(--gray-400) !important;
  margin-top: 1rem !important;
}

/* ===== CTA Banner ===== */
.cta-banner {
  background: linear-gradient(135deg, #0f2a5e 0%, #1a56db 100%);
  border-radius: var(--radius);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  color: #fff;
}

.cta-content {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.cta-text {
  flex: 1;
}

.cta-text strong {
  font-size: 1rem;
  display: block;
  margin-bottom: 0.375rem;
}

.cta-text p {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.8);
  line-height: 1.5;
  margin: 0;
}

.btn-cta {
  background: #fff;
  color: var(--primary);
  font-weight: 700;
  padding: 0.75rem 1.5rem;
  border-radius: 6px;
  text-decoration: none;
  white-space: nowrap;
  font-size: 0.9375rem;
  transition: all 0.15s;
}

.btn-cta:hover {
  background: var(--gray-100);
  box-shadow: var(--shadow-md);
}

@media (max-width: 600px) {
  .cta-content {
    flex-direction: column;
    text-align: center;
  }
}

/* ===== Historico Colaborador ===== */
.card-historico {
  border: 2px solid var(--warning-bg);
  background: #fffdf7;
}

.hist-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

.hist-section h4 {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.375rem;
}

.hist-section ul {
  list-style: none;
  font-size: 0.8125rem;
}

.hist-section li {
  padding: 0.1875rem 0;
  color: var(--gray-600);
}

@media (max-width: 600px) {
  .hist-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== Form Feedback ===== */
.form-feedback {
  display: none;
  padding: 0.625rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-top: 1rem;
}

.form-feedback-ok {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid #a7f3d0;
}

.form-feedback-error {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #fca5a5;
}

/* ===== Catálogo de Médicos ===== */
.medicos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1rem;
}

.medico-card {
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  padding: 1.25rem;
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
}

.medico-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.medico-card-header {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.medico-avatar {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  font-weight: 700;
  color: #fff;
  background: var(--primary);
}

.medico-avatar.risco-alto { background: var(--danger); }
.medico-avatar.risco-medio { background: var(--warning); }

.medico-card-info { flex: 1; min-width: 0; }

.medico-card-name {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--gray-900);
  line-height: 1.3;
  display: block;
}

.medico-card-crm {
  font-size: 0.75rem;
  color: var(--gray-500);
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
}

.medico-card-espec {
  font-size: 0.75rem;
  color: var(--primary);
  font-weight: 500;
  margin-top: 0.125rem;
}

.medico-card-situacao {
  position: absolute;
  top: 1rem;
  right: 1rem;
}

.medico-card-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--gray-100);
}

.medico-stat {
  text-align: center;
}

.medico-stat-value {
  display: block;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
}

.medico-stat-label {
  font-size: 0.5625rem;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.medico-stat-value.stat-danger { color: var(--danger); }
.medico-stat-value.stat-warning { color: var(--warning); }

.medico-card-alerts {
  margin-top: 0.625rem;
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
}

.medico-alert-tag {
  font-size: 0.625rem;
  font-weight: 600;
  padding: 0.125rem 0.4375rem;
  border-radius: 3px;
}

.medico-alert-tag.alert-critical {
  background: var(--danger-bg);
  color: var(--danger);
}

.medico-alert-tag.alert-warning {
  background: var(--warning-bg);
  color: var(--warning);
}

.medico-card-footer {
  margin-top: 0.625rem;
  font-size: 0.6875rem;
  color: var(--gray-400);
  display: flex;
  justify-content: space-between;
}

/* Ficha Modal */
.modal-xl {
  max-width: 720px;
  max-height: 85vh;
  overflow-y: auto;
}

.ficha-header {
  padding: 1.5rem 1.5rem 1rem;
  border-bottom: 1px solid var(--gray-200);
  position: relative;
}

.modal-close-btn {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--gray-400);
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: background 0.15s, color 0.15s;
}

.modal-close-btn:hover {
  background: var(--gray-100);
  color: var(--gray-700);
}

.ficha-top {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.ficha-avatar {
  width: 56px;
  height: 56px;
  min-width: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  background: var(--primary);
}

.ficha-avatar.risco-alto { background: var(--danger); }

.ficha-title {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--gray-900);
}

.ficha-subtitle {
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin-top: 0.125rem;
}

.ficha-tags {
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

.ficha-tag {
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 0.1875rem 0.5rem;
  border-radius: 20px;
}

.ficha-tag-espec { background: var(--purple-light); color: var(--purple); }
.ficha-tag-grad { background: var(--gray-100); color: var(--gray-600); }

.ficha-stats-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
}

.ficha-stat {
  text-align: center;
  padding: 0.5rem;
  background: var(--gray-50);
  border-radius: 6px;
}

.ficha-stat-value {
  display: block;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gray-900);
}

.ficha-stat-label {
  font-size: 0.5625rem;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
}

.ficha-body {
  padding: 1.25rem 1.5rem;
}

.ficha-section {
  margin-bottom: 1.5rem;
}

.ficha-section h4 {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--gray-800);
  margin-bottom: 0.625rem;
  padding-bottom: 0.375rem;
  border-bottom: 1px solid var(--gray-100);
}

.ficha-alertas {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin-bottom: 1rem;
}

.ficha-alerta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
}

.ficha-alerta-critical {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #fca5a5;
}

.ficha-alerta-warning {
  background: var(--warning-bg);
  color: var(--warning);
  border: 1px solid #fde68a;
}

.ficha-dias-grid {
  display: flex;
  gap: 0.375rem;
  align-items: flex-end;
  height: 60px;
  padding: 0.5rem 0;
}

.ficha-dia-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

.ficha-dia-bar {
  width: 100%;
  max-width: 40px;
  background: var(--primary);
  border-radius: 3px 3px 0 0;
  min-height: 2px;
  transition: height 0.3s;
}

.ficha-dia-bar.dia-alerta { background: var(--warning); }

.ficha-dia-label {
  font-size: 0.5625rem;
  font-weight: 600;
  color: var(--gray-400);
}

.ficha-cid-list {
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
}

.ficha-cid-tag {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.625rem;
  border-radius: 20px;
  background: var(--gray-100);
  color: var(--gray-700);
}

.ficha-cid-count {
  font-size: 0.625rem;
  color: var(--gray-400);
  margin-left: 0.25rem;
}

/* Fontes externas grid */
.ficha-fontes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.75rem;
}

.ficha-fonte-card {
  padding: 0.875rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  font-size: 0.8125rem;
}

.ficha-fonte-card strong {
  display: block;
  font-size: 0.8125rem;
  color: var(--gray-800);
  margin-bottom: 0.25rem;
}

.ficha-fonte-card p {
  color: var(--gray-600);
  margin: 0 0 0.25rem;
  font-size: 0.8125rem;
}

.ficha-fonte-icon {
  float: right;
  font-size: 1.25rem;
}

.ficha-fonte-meta {
  display: block;
  font-size: 0.6875rem;
  color: var(--gray-400);
}

.ficha-fonte-link {
  display: inline-block;
  margin-top: 0.375rem;
  font-size: 0.75rem;
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
}

.ficha-fonte-link:hover {
  text-decoration: underline;
}

/* Perfil do Médico com IA */
.perfil-ia-card {
  background: linear-gradient(135deg, var(--bg-surface, #f8f9fa) 0%, var(--bg-surface-hover, #eef1f5) 100%);
  border: 1px solid var(--border, #e0e4ea);
  border-radius: 12px;
  padding: 1.25rem;
}

.perfil-ia-header {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.perfil-ia-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--bg-surface, #fff);
  border: 3px solid currentColor;
  flex-shrink: 0;
}

.perfil-ia-score.score-alto { color: #16a34a; }
.perfil-ia-score.score-medio { color: #d97706; }
.perfil-ia-score.score-baixo { color: #dc2626; }

.perfil-ia-score-value {
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1;
}

.perfil-ia-score-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.8;
  margin-top: 2px;
}

.perfil-ia-resumo {
  flex: 1;
}

.perfil-ia-resumo p {
  margin: 0 0 0.4rem;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--text-primary, #1a1a2e);
}

.perfil-ia-bloco {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--border, #e0e4ea);
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--text-secondary, #4a5568);
}

.perfil-ia-bloco strong {
  color: var(--text-primary, #1a1a2e);
  display: block;
  margin-bottom: 0.3rem;
}

.perfil-ia-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.4rem;
}

.perfil-ia-tag {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  background: var(--bg-surface, #fff);
  border: 1px solid var(--border, #e0e4ea);
  border-radius: 6px;
  font-size: 0.8rem;
  color: var(--text-secondary, #4a5568);
}

.perfil-ia-padroes {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-top: 0.4rem;
}

.perfil-ia-padrao {
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  border-left: 3px solid;
  background: var(--bg-surface, #fff);
}

.padrao-critico { border-left-color: #dc2626; }
.padrao-atencao { border-left-color: #d97706; }
.padrao-positivo { border-left-color: #16a34a; }
.padrao-neutro { border-left-color: #6b7280; }

.perfil-ia-padrao-tipo {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  font-size: 0.7rem;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.03em;
  margin-right: 0.3rem;
}

.padrao-critico .perfil-ia-padrao-tipo { background: #fef2f2; color: #dc2626; }
.padrao-atencao .perfil-ia-padrao-tipo { background: #fffbeb; color: #d97706; }
.padrao-positivo .perfil-ia-padrao-tipo { background: #f0fdf4; color: #16a34a; }
.padrao-neutro .perfil-ia-padrao-tipo { background: #f3f4f6; color: #6b7280; }

.perfil-ia-recomendacoes {
  margin: 0.4rem 0 0 1.2rem;
  padding: 0;
}

.perfil-ia-recomendacoes li {
  margin-bottom: 0.3rem;
  font-size: 0.88rem;
  color: var(--text-secondary, #4a5568);
}

.ficha-alerta-info {
  background: #eff6ff;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
}

.btn-accent {
  background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s;
}

.btn-accent:hover {
  opacity: 0.9;
}

.btn-accent:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.spinner-sm {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  vertical-align: middle;
  margin-right: 4px;
}

/* Dark mode: Perfil IA */
[data-theme="dark"] .perfil-ia-card {
  background: linear-gradient(135deg, #1e1e2e 0%, #252538 100%);
  border-color: #3a3a52;
}

[data-theme="dark"] .perfil-ia-score { background: #2a2a3e; }
[data-theme="dark"] .perfil-ia-padrao { background: #2a2a3e; }
[data-theme="dark"] .perfil-ia-tag { background: #2a2a3e; border-color: #3a3a52; }
[data-theme="dark"] .ficha-alerta-info { background: #1e2a4a; color: #60a5fa; border-color: #2d4a7a; }
[data-theme="dark"] .padrao-critico .perfil-ia-padrao-tipo { background: #3a1a1a; }
[data-theme="dark"] .padrao-atencao .perfil-ia-padrao-tipo { background: #3a2f1a; }
[data-theme="dark"] .padrao-positivo .perfil-ia-padrao-tipo { background: #1a3a1a; }
[data-theme="dark"] .padrao-neutro .perfil-ia-padrao-tipo { background: #2a2a3e; }

@media (max-width: 768px) {
  .perfil-ia-header { flex-direction: column; align-items: center; text-align: center; }
  .perfil-ia-score { min-width: 70px; height: 70px; }
}

@media (max-width: 768px) {
  .medicos-grid { grid-template-columns: 1fr; }
  .medico-card-stats { grid-template-columns: repeat(2, 1fr); }
  .ficha-stats-row { grid-template-columns: repeat(3, 1fr); }
  .ficha-fontes-grid { grid-template-columns: 1fr; }
  .modal-xl { max-width: 95%; }
}

/* ===== Quick Nav (Ctrl+K) ===== */
.quicknav {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 20vh;
}

.quicknav-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

.quicknav-panel {
  position: relative;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.2);
  width: 90%;
  max-width: 440px;
  overflow: hidden;
}

.quicknav-input {
  width: 100%;
  padding: 1rem 1.25rem;
  border: none;
  border-bottom: 1px solid var(--gray-200);
  font-size: 1rem;
  color: var(--gray-900);
  outline: none;
}

.quicknav-input::placeholder {
  color: var(--gray-400);
}

.quicknav-results {
  max-height: 240px;
  overflow-y: auto;
}

.quicknav-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.625rem 1.25rem;
  cursor: pointer;
  transition: background 0.1s;
  font-size: 0.875rem;
  color: var(--gray-700);
}

.quicknav-item:hover,
.quicknav-item.selected {
  background: var(--primary-light);
  color: var(--primary);
}

.quicknav-item-icon {
  font-size: 1.125rem;
  min-width: 22px;
  text-align: center;
}

.quicknav-item-section {
  font-size: 0.6875rem;
  color: var(--gray-400);
  margin-left: auto;
}

.quicknav-hint {
  padding: 0.5rem 1.25rem;
  font-size: 0.6875rem;
  color: var(--gray-400);
  border-top: 1px solid var(--gray-100);
  text-align: center;
}

/* ===== Print / PDF ===== */
@media print {
  body {
    background: #fff;
  }

  .sidebar,
  .sidebar-overlay,
  .sidebar-mobile-toggle,
  .app-header {
    display: none !important;
  }

  .app-layout {
    grid-template-columns: 1fr !important;
  }

  .container,
  .page-content {
    max-width: 100%;
    padding: 0;
  }

  .card {
    box-shadow: none;
    border: 1px solid var(--gray-200);
    break-inside: avoid;
  }

  .btn,
  .cfm-hint,
  .drop-zone,
  .api-config,
  footer,
  .modal-backdrop,
  .modal,
  .quicknav,
  #authScreen {
    display: none !important;
  }
}

/* ===== Wizard ===== */
.wizard-steps {
  display: flex;
  align-items: center;
  padding: 1rem 1.5rem;
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg, #fff);
  border-bottom: 1px solid var(--gray-100);
  margin: 0 -1.5rem 1rem;
}
.wizard-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  flex: 0 0 auto;
}
.wizard-step-number {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--gray-200);
  color: var(--text-muted);
  font-size: 0.8125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
}
.wizard-step-label {
  font-size: 0.75rem;
  color: var(--text-muted);
  font-weight: 500;
  white-space: nowrap;
  transition: color 0.2s;
}
.wizard-step.active .wizard-step-number {
  background: var(--primary);
  color: #fff;
}
.wizard-step.active .wizard-step-label {
  color: var(--primary);
  font-weight: 600;
}
.wizard-step.completed .wizard-step-number {
  background: #16a34a;
  color: #fff;
}
.wizard-step.completed .wizard-step-label {
  color: #16a34a;
}
.wizard-step-line {
  flex: 1;
  height: 2px;
  background: var(--gray-200);
  margin: 0 0.5rem;
  margin-bottom: 1.35rem;
  transition: background 0.2s;
}
.wizard-step-line.completed {
  background: #16a34a;
}
.wizard-panels-area {
  display: grid;
}
.wizard-panels-area > .wizard-panel {
  grid-area: 1 / 1;
}
.wizard-panel {
  display: none;
}
.wizard-panel.active {
  display: block;
}
.wizard-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0 0.5rem;
  gap: 1rem;
}
@media (max-width: 480px) {
  .wizard-step-label { display: none; }
  .wizard-steps { padding-bottom: 1.25rem; }
}

/* Wizard transition animations */
@keyframes wizardSlideIn {
  from { opacity: 0; transform: translateX(calc(30px * var(--wizard-dir, 1))); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes wizardSlideOut {
  from { opacity: 1; transform: translateX(0); }
  to { opacity: 0; transform: translateX(calc(-30px * var(--wizard-dir, 1))); }
}
.wizard-panel.wizard-enter {
  animation: wizardSlideIn 0.3s ease forwards;
  z-index: 2;
}
.wizard-panel.wizard-exit {
  display: block;
  animation: wizardSlideOut 0.3s ease forwards;
  z-index: 1;
  pointer-events: none;
}
#pageAnalise {
  overflow: visible;
}
.wizard-step {
  transition: transform 0.15s ease;
}
.wizard-step:hover {
  transform: scale(1.08);
}

/* Wizard keyboard focus */
.wizard-step:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 4px;
  border-radius: 8px;
}

/* ===== Dark Mode =====
   Projeto usa DOIS seletores historicamente: `html.dark` (style.css legacy) e
   `[data-theme="dark"]` (dashboard-new.css). Ambos devem ativar TODAS as regras dark.
   Por isso, tudo é escrito com ambos os seletores lado a lado. */
html.dark,
[data-theme="dark"] {
  --gray-50: #1a1a2e;
  --gray-100: #16213e;
  --gray-200: #2a2a4a;
  --gray-300: #3d3d5c;
  --gray-400: #8888a8;
  --gray-500: #a0a0b8;
  --gray-600: #c0c0d0;
  --gray-700: #d8d8e8;
  --gray-800: #e8e8f0;
  --gray-900: #f5f5ff;
  --shadow: 0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.25), 0 2px 4px rgba(0,0,0,0.2);
}

html.dark body,
[data-theme="dark"] body {
  background: #0f0f23;
  color: #e8e8f0;
}

html.dark .card,
html.dark .auth-card,
html.dark .modal-content,
[data-theme="dark"] .card,
[data-theme="dark"] .auth-card,
[data-theme="dark"] .modal-content {
  background: #1a1a2e;
  border-color: #2a2a4a;
}

html.dark .app-header,
[data-theme="dark"] .app-header {
  background: #1a1a2e;
  border-color: #2a2a4a;
}

html.dark input,
html.dark select,
html.dark textarea,
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: #16213e;
  border-color: #3d3d5c;
  color: #e8e8f0;
}

html.dark input:focus,
html.dark select:focus,
html.dark textarea:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus {
  border-color: var(--primary);
}

html.dark select option,
html.dark select optgroup,
[data-theme="dark"] select option,
[data-theme="dark"] select optgroup {
  background: #16213e;
  color: #e8e8f0;
}

html.dark select option:disabled {
  color: #7a7a95;
}

html.dark select option:checked,
html.dark select option:hover {
  background: #2a3a66;
  color: #ffffff;
}

html.dark .dash-table thead th {
  background: #16213e;
  color: #c0c0d0;
}

html.dark .dash-table tbody tr:nth-child(even) {
  background: rgba(255,255,255,0.02);
}

html.dark .dash-table td {
  border-color: #2a2a4a;
}

html.dark .b2b-toolbar {
  background: #16213e;
}

html.dark .dash-stat,
[data-theme="dark"] .dash-stat {
  background: #16213e;
}

/* .btn-secondary usa var(--gray-800) + #fff — em dark os tokens invertem,
   então o bg fica quase branco com texto branco. Override explícito: */
html.dark .btn-secondary,
[data-theme="dark"] .btn-secondary {
  background: #2a3a66;
  color: #ffffff;
  border: 1px solid #3d4d7a;
}
html.dark .btn-secondary:hover,
[data-theme="dark"] .btn-secondary:hover {
  background: #3d4d7a;
}
html.dark .btn:disabled,
[data-theme="dark"] .btn:disabled {
  opacity: 0.55;
}

html.dark .checklist label {
  border-color: #2a2a4a;
}

html.dark .ai-result {
  background: #16213e;
  border-color: #2a2a4a;
}

html.dark .ai-parecer {
  background: #16213e;
  border: 1px solid #2a2a4a;
}
html.dark .ai-parecer .ai-badge { color: #c4b5fd; }
html.dark .ai-parecer p { color: #e2e8f0; }
html.dark .ai-summary p { color: #e2e8f0; }

html.dark .drop-zone {
  background: #16213e;
  border-color: #3d3d5c;
}

html.dark .cfm-resultado {
  background: #16213e;
}

html.dark .auth-screen {
  background: #0f0f23;
}

/* ===== Insights IA ===== */
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.15); opacity: 0.7; }
}

/* ===== Educação ===== */
.edu-eyebrow {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-light);
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  margin-bottom: 0.75rem;
}
.edu-hero h2 { margin: 0.25rem 0 0.5rem; }
.edu-toc { display: flex; flex-direction: column; gap: 0.6rem; margin-top: 1rem; }
.edu-toc-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.75rem;
  align-items: center;
  padding: 0.85rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, transform 0.15s, background 0.15s, box-shadow 0.15s;
}
.edu-toc-item:hover {
  border-color: var(--primary);
  background: var(--primary-light);
  transform: translateY(-1px);
}
.edu-toc-item:focus-visible {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}
.edu-toc-tag {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--primary);
  color: #fff;
  padding: 0.2rem 0.55rem;
  border-radius: 6px;
}
.edu-toc-title { font-weight: 600; color: var(--gray-900); }
.edu-toc-meta { font-size: 0.78rem; color: var(--gray-500); }

.edu-article { max-width: 820px; }
.edu-article-header { margin-bottom: 1.25rem; }
.edu-article-header h2 { margin: 0.5rem 0 0.4rem; line-height: 1.25; color: var(--gray-900); }
.edu-article-meta { font-size: 0.85rem; color: var(--gray-500); margin: 0; }
.edu-lead {
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--gray-900);
  border-left: 3px solid var(--primary);
  padding-left: 0.9rem;
  margin: 1rem 0 1.25rem;
}
.edu-article p { line-height: 1.65; margin: 0.6rem 0 0.9rem; color: var(--gray-700); }
.edu-article h3 {
  margin: 1.5rem 0 0.5rem;
  font-size: 1.1rem;
  color: var(--gray-900);
}
.edu-list { padding-left: 1.25rem; line-height: 1.7; margin: 0.4rem 0 1rem; color: var(--gray-700); }
.edu-list li { margin-bottom: 0.35rem; }
.edu-list-ordered { padding-left: 1.4rem; }
.edu-callout {
  background: var(--warning-bg);
  border-left: 3px solid var(--warning);
  padding: 0.7rem 0.9rem;
  border-radius: 6px;
  margin: 0.5rem 0 1.2rem;
  font-size: 0.95rem;
  color: var(--gray-900);
}
.edu-tip {
  margin-top: 1.5rem;
  padding: 1rem 1.1rem;
  background: var(--primary-light);
  border: 1px solid var(--primary);
  border-radius: 10px;
}
.edu-tip strong { display: block; margin-bottom: 0.35rem; color: var(--primary); }
.edu-tip p { margin: 0; font-size: 0.92rem; line-height: 1.55; color: var(--gray-800); }
.edu-article-footer {
  margin-top: 1.75rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-200);
  font-size: 0.8rem;
  color: var(--gray-500);
}
.edu-article-footer a, .edu-article-meta a { color: var(--primary); }

/* ===== Dark theme — contraste em callouts amarelos/alertas ===== */
[data-theme="dark"] .dash-anomalia,
[data-theme="dark"] .dash-anomalia strong,
[data-theme="dark"] .edu-callout,
[data-theme="dark"] .edu-callout strong {
  color: #fef3c7;
}
[data-theme="dark"] .edu-callout {
  background: rgba(217, 119, 6, 0.18);
  border-left-color: rgba(245, 158, 11, 0.85);
}
[data-theme="dark"] .dash-anomalia-warning { background: rgba(217, 119, 6, 0.18); border-color: rgba(217, 119, 6, 0.55); }
[data-theme="dark"] .dash-anomalia-critical { background: rgba(220, 38, 38, 0.2); border-color: rgba(220, 38, 38, 0.55); color: #fecaca; }
[data-theme="dark"] .dash-anomalia-critical strong { color: #fecaca; }
[data-theme="dark"] .dash-anomalia-info { background: rgba(37, 99, 235, 0.18); border-color: rgba(37, 99, 235, 0.55); color: #dbeafe; }
[data-theme="dark"] .dash-anomalia-info strong { color: #dbeafe; }

/* Bloco Assinatura digital ICP-Brasil + Referências de fraude (P0 — abr/2026) */
.ai-icp { margin-top: 12px; padding: 10px 12px; border-radius: 6px; border: 1px solid; font-size: 0.95rem; }
.ai-icp ul { margin: 6px 0 0 18px; padding: 0; }
.ai-icp li { margin: 2px 0; }
.ai-icp.icp-ok   { background: #ecfdf5; border-color: #10b981; color: #064e3b; }
.ai-icp.icp-warn { background: #fffbeb; border-color: #f59e0b; color: #78350f; }
.ai-icp.icp-miss { background: #fef2f2; border-color: #ef4444; color: #7f1d1d; }
.ai-refs { margin-top: 12px; padding: 10px 12px; border-radius: 6px; border: 1px solid #f59e0b; background: #fffbeb; color: #78350f; font-size: 0.95rem; }
.ai-refs ul { margin: 6px 0 0 18px; padding: 0; }
.ai-refs a { color: #92400e; text-decoration: underline; }
.ai-refs-critico { border: 2px solid #dc2626; background: #fef2f2; color: #7f1d1d; outline: 2px solid rgba(220,38,38,0.25); outline-offset: 1px; }
.ai-refs-critico a { color: #991b1b; font-weight: 600; }
[data-theme="dark"] .ai-icp.icp-ok   { background: rgba(16,185,129,0.15); color: #bbf7d0; border-color: rgba(16,185,129,0.5); }
[data-theme="dark"] .ai-icp.icp-warn { background: rgba(245,158,11,0.15); color: #fde68a; border-color: rgba(245,158,11,0.5); }
[data-theme="dark"] .ai-icp.icp-miss { background: rgba(239,68,68,0.15); color: #fecaca; border-color: rgba(239,68,68,0.5); }
[data-theme="dark"] .ai-refs { background: rgba(239,68,68,0.15); color: #fecaca; border-color: rgba(239,68,68,0.5); }
[data-theme="dark"] .ai-refs a { color: #fca5a5; }
.ai-fonte-municipal { margin-top: 12px; padding: 10px 12px; border-radius: 6px; border: 1px solid #3b82f6; background: #eff6ff; color: #1e3a8a; font-size: 0.95rem; }
.ai-fonte-municipal a { color: #1d4ed8; text-decoration: underline; word-break: break-all; }
.ai-fonte-municipal.vm-ok   { background: #ecfdf5; border-color: #10b981; color: #064e3b; }
.ai-fonte-municipal.vm-ok a { color: #065f46; }
.ai-fonte-municipal.vm-bad  { background: #fef2f2; border-color: #ef4444; color: #7f1d1d; }
.ai-fonte-municipal.vm-bad a { color: #991b1b; }
.ai-fonte-municipal.vm-warn { background: #fffbeb; border-color: #f59e0b; color: #78350f; }
.ai-fonte-municipal.vm-warn a { color: #92400e; }
[data-theme="dark"] .ai-fonte-municipal { background: rgba(59,130,246,0.15); color: #bfdbfe; border-color: rgba(59,130,246,0.5); }
[data-theme="dark"] .ai-fonte-municipal a { color: #93c5fd; }
[data-theme="dark"] .ai-fonte-municipal.vm-ok   { background: rgba(16,185,129,0.15); color: #bbf7d0; border-color: rgba(16,185,129,0.5); }
[data-theme="dark"] .ai-fonte-municipal.vm-ok a { color: #86efac; }
[data-theme="dark"] .ai-fonte-municipal.vm-bad  { background: rgba(239,68,68,0.15); color: #fecaca; border-color: rgba(239,68,68,0.5); }
[data-theme="dark"] .ai-fonte-municipal.vm-bad a { color: #fca5a5; }
[data-theme="dark"] .ai-fonte-municipal.vm-warn { background: rgba(245,158,11,0.15); color: #fde68a; border-color: rgba(245,158,11,0.5); }
[data-theme="dark"] .ai-fonte-municipal.vm-warn a { color: #fcd34d; }

/* CRMs com restrição */
.restricao-resumo { padding: 0.5rem 0; }
.restricao-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 0.75rem; }
.restricao-card { padding: 1rem; border: 1px solid var(--gray-200, #e5e7eb); border-radius: 8px; background: var(--gray-50, #f9fafb); text-align: center; }
.restricao-card-critico { border-color: #dc2626; background: #fef2f2; color: #7f1d1d; }
.restricao-card-alerta  { border-color: #f59e0b; background: #fffbeb; color: #78350f; }
.restricao-card-aviso   { border-color: #3b82f6; background: #eff6ff; color: #1e3a8a; }
.restricao-num { font-size: 1.75rem; font-weight: 700; line-height: 1; }
.restricao-label { margin-top: 0.25rem; font-size: 0.85rem; opacity: 0.85; }
.restricao-filters { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.restricao-filters select, .restricao-filters input { padding: 0.4rem 0.6rem; border: 1px solid var(--gray-300, #d1d5db); border-radius: 6px; font-size: 0.92rem; background: var(--bg, #fff); color: inherit; }
.restricao-filters input[type="search"] { flex: 1; min-width: 200px; }
.restricao-row-critico td { background: rgba(220,38,38,0.06); }
.restricao-row-alerta  td { background: rgba(245,158,11,0.06); }
[data-theme="dark"] .restricao-card { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.1); }
[data-theme="dark"] .restricao-card-critico { background: rgba(220,38,38,0.12); color: #fecaca; border-color: rgba(220,38,38,0.5); }
[data-theme="dark"] .restricao-card-alerta  { background: rgba(245,158,11,0.12); color: #fde68a; border-color: rgba(245,158,11,0.5); }
[data-theme="dark"] .restricao-card-aviso   { background: rgba(59,130,246,0.12); color: #bfdbfe; border-color: rgba(59,130,246,0.5); }
[data-theme="dark"] .restricao-row-critico td { background: rgba(220,38,38,0.12); }
[data-theme="dark"] .restricao-row-alerta  td { background: rgba(245,158,11,0.10); }
