/* ════════════════════════════════════════════════════════
   CETREL — Componentes reutilizáveis
   ════════════════════════════════════════════════════════ */

/* ── Botões ──────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  line-height: 1;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background-color var(--transition-fast),
              color var(--transition-fast),
              border-color var(--transition-fast),
              box-shadow var(--transition-fast),
              opacity var(--transition-fast);
  white-space: nowrap;
  user-select: none;
  text-decoration: none;
}

.btn:focus-visible {
  outline: 3px solid var(--border-focus);
  outline-offset: 2px;
}

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

.btn--primary {
  background-color: var(--brand-blue-800);
  color: var(--text-on-brand);
}
.btn--primary:hover { background-color: var(--brand-blue-900); }

.btn--secondary {
  background-color: transparent;
  color: var(--brand-blue-800);
  border-color: var(--brand-blue-800);
}
.btn--secondary:hover {
  background-color: var(--brand-blue-50);
}

.btn--danger {
  background-color: var(--color-danger);
  color: #FFFFFF;
}
.btn--danger:hover { filter: brightness(0.9); }

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

.btn--full { width: 100%; }
.btn--lg   { padding: var(--space-4) var(--space-6); font-size: var(--text-base); }
.btn--sm   { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); }

/* ── Formulários ─────────────────────────────────────── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-label {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-primary);
}

.form-label--required::after {
  content: ' *';
  color: var(--color-danger);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--border-default);
  border-radius: var(--radius-md);
  background-color: var(--surface-card);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(58, 141, 196, 0.20);
}

.form-input::placeholder { color: var(--text-disabled); }

.form-input--error { border-color: var(--color-danger); }
.form-input--error:focus {
  box-shadow: 0 0 0 3px rgba(212, 43, 43, 0.20);
}

.form-hint {
  font-size: var(--text-xs);
  color: var(--text-secondary);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--color-danger-text);
  background: var(--color-danger-bg);
  border: 1px solid var(--color-danger-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
}

/* Wrapper para input com ícone/toggle */
.input-wrapper {
  position: relative;
}
.input-wrapper .form-input {
  padding-right: var(--space-10);
}
.input-toggle {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-secondary);
  padding: var(--space-1);
  line-height: 1;
}
.input-toggle:hover { color: var(--text-primary); }

/* ── Cards ───────────────────────────────────────────── */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.card--elevated { box-shadow: var(--shadow-md); }

.card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.card__title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}

/* ── Badges / Chips ──────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  white-space: nowrap;
}

.badge--success {
  background: var(--color-success-bg);
  color: var(--color-success-text);
  border: 1px solid var(--color-success-border);
}
.badge--warning {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
  border: 1px solid var(--color-warning-border);
}
.badge--danger {
  background: var(--color-danger-bg);
  color: var(--color-danger-text);
  border: 1px solid var(--color-danger-border);
}
.badge--info {
  background: var(--color-info-bg);
  color: var(--color-info-text);
  border: 1px solid var(--color-info-border);
}
.badge--neutral {
  background: var(--neutral-100);
  color: var(--neutral-700);
  border: 1px solid var(--neutral-200);
}

/* ── Alert / Callout ─────────────────────────────────── */
.alert {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border-left: 4px solid;
  font-size: var(--text-sm);
}

.alert--success {
  background: var(--color-success-bg);
  border-color: var(--color-success);
  color: var(--color-success-text);
}
.alert--warning {
  background: var(--color-warning-bg);
  border-color: var(--color-warning);
  color: var(--color-warning-text);
}
.alert--danger {
  background: var(--color-danger-bg);
  border-color: var(--color-danger);
  color: var(--color-danger-text);
}
.alert--info {
  background: var(--color-info-bg);
  border-color: var(--color-info);
  color: var(--color-info-text);
}

/* ── Tabela ───────────────────────────────────────────── */
.table-wrapper {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.table th,
.table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--border-default);
}

.table th {
  background: var(--surface-subtle);
  font-weight: var(--font-semibold);
  color: var(--text-secondary);
  white-space: nowrap;
}

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

.table tbody tr:hover td {
  background: var(--surface-subtle);
}

/* ── Skeleton loader ─────────────────────────────────── */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--neutral-150) 25%,
    var(--neutral-100) 50%,
    var(--neutral-150) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.4s infinite;
  border-radius: var(--radius-sm);
}

@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Spinner ──────────────────────────────────────────── */
.spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-default);
  border-top-color: var(--brand-blue-800);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  display: inline-block;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ── Progress bar ────────────────────────────────────── */
.progress {
  height: 8px;
  background: var(--neutral-150);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress__bar {
  height: 100%;
  background: var(--brand-blue-800);
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
}

/* ── Dashboard stat cards ────────────────────────────── */
.stat-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

.stat-card__label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}

.stat-card__value {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
  line-height: 1;
}

.stat-card__sub {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: var(--space-1);
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-4);
}

/* ── Toast notifications ─────────────────────────────── */
#toast-container {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  z-index: 9999;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  pointer-events: all;
  animation: toast-in var(--transition-normal) forwards;
  max-width: 360px;
}

.toast--success { background: var(--color-success); color: #FFF; }
.toast--error   { background: var(--color-danger);  color: #FFF; }
.toast--warning { background: var(--color-warning);  color: #FFF; }
.toast--info    { background: var(--brand-blue-800); color: #FFF; }

@keyframes toast-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Modal ───────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--surface-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: var(--space-4);
  animation: fade-in var(--transition-fast) forwards;
}

.modal {
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--space-8);
  animation: slide-up var(--transition-normal) forwards;
}

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

.modal__title {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
}

.modal__close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-secondary);
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  line-height: 1;
  font-size: 1.25rem;
}
.modal__close:hover { color: var(--text-primary); }

@keyframes fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes slide-up { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

/* ════════════════════════════════════════════════════════
   COLABORADOR — Fluxo de validação (Fase 3)
   ════════════════════════════════════════════════════════ */

/* ── Layout centralizado ─────────────────────────────── */
.colab-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background-color: var(--surface-subtle);
  padding: var(--space-8) var(--space-4);
}

.colab-card {
  width: 100%;
  max-width: 560px;
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  padding: var(--space-8);
}

.colab-card__header {
  margin-bottom: var(--space-6);
}

.colab-card__title {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.colab-card__subtitle {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

/* ── Indicador de etapas ─────────────────────────────── */
.step-indicator {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}

.step-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--neutral-200);
  transition: background var(--transition-fast), transform var(--transition-fast);
}

.step-dot--active {
  background: var(--brand-blue-800);
  transform: scale(1.4);
}

.step-dot--done {
  background: var(--color-success);
}

/* ── Dados cadastrais (dl/dt/dd) ─────────────────────── */
.dados-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--surface-subtle);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-2) var(--space-4);
  margin-bottom: var(--space-6);
}

.dado-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--space-3) var(--space-2);
  border-bottom: 1px solid var(--border-default);
}

.dado-item:nth-last-child(-n+2) {
  border-bottom: none;
}

.dado-label {
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dado-valor {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-primary);
}

/* ── Radio cards ─────────────────────────────────────── */
.radio-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.radio-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1.5px solid var(--border-default);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.radio-card:hover {
  border-color: var(--brand-blue-400);
  background-color: var(--brand-blue-50);
}

.radio-card--selected {
  border-color: var(--brand-blue-800);
  background-color: var(--brand-blue-50);
}

.radio-card input[type="radio"] {
  display: none;
}

.radio-card__content {
  flex: 1;
}

.radio-card__label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}

.radio-card__desc {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: 2px;
}

.radio-card__check {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  border: 2px solid var(--border-default);
  flex-shrink: 0;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
  position: relative;
}

.radio-card--selected .radio-card__check {
  border-color: var(--brand-blue-800);
  background-color: var(--brand-blue-800);
}

.radio-card--selected .radio-card__check::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: #fff;
}

/* ── Ícone de sucesso ────────────────────────────────── */
.sucesso-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-5);
}

.sucesso-icon svg {
  width: 100%;
  height: 100%;
}

/* ── Ações e logout ──────────────────────────────────── */
.colab-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.colab-logout {
  text-align: center;
  margin-top: var(--space-5);
  font-size: var(--text-sm);
}

.colab-logout a {
  color: var(--text-secondary);
  text-decoration: none;
}

.colab-logout a:hover {
  color: var(--text-primary);
  text-decoration: underline;
}

/* ── Utilitário ──────────────────────────────────────── */
.hidden { display: none !important; }

@media (max-width: 480px) {
  .dados-grid { grid-template-columns: 1fr; }
  .dado-item:last-child { border-bottom: none; }
  .colab-card { padding: var(--space-5); }
}
