/* ============================================================
   ERP Restaurante — Módulo Checklists
   Fase B (v757) — Extração de styles inline + tokens + estados visuais
   Convenções:
     ck-*  → Acompanhamento e estruturas gerais do módulo
     wz-*  → Wizard de execução (já era convenção do código)
   ============================================================ */

/* ── Tokens semânticos (paleta de feedback do módulo) ─────── */
:root {
  /* Sucesso (resposta válida, IA aprovou, checklist concluído) */
  --ck-success:        #22c55e;
  --ck-success-bg:     #dcfce7;
  --ck-success-text:   #166534;
  --ck-success-border: #86efac;

  /* Aviso/em-andamento (salvando, aguardando IA, sem horário) */
  --ck-warning:        #facc15;
  --ck-warning-bg:     #fef3c7;
  --ck-warning-text:   #92400e;
  --ck-warning-border: #fde68a;

  /* Perigo (erro, IA reprovou, atrasado, crítica) */
  --ck-danger:         #ef4444;
  --ck-danger-bg:      #fee2e2;
  --ck-danger-text:    #991b1b;
  --ck-danger-border:  #fca5a5;
  --ck-danger-strong:  #dc2626;

  /* Info (em andamento azul, padrão ouro) */
  --ck-info:           #3b82f6;
  --ck-info-bg:        #dbeafe;
  --ck-info-text:      #1e40af;
  --ck-info-border:    #93c5fd;

  /* Notificar (criticidade média) — roxo */
  --ck-notif-bg:       #ede9fe;
  --ck-notif-text:     #6d28d9;

  /* Padrão Ouro (referência visual) */
  --ck-gold:           #fbbf24;
  --ck-gold-bg:        #fef3c7;
  --ck-gold-text:      #92400e;
  --ck-gold-border:    #fbbf24;
}

/* ════════════════════════════════════════════════════════════
   ACOMPANHAMENTO — Cards de checklist do dia
   ════════════════════════════════════════════════════════════ */

.ck-acomp-grid {
  display: grid;
  /* v767: minmax 280-380 evita cards esticados em iPad landscape (era 320/1fr → ~410px em 1280) */
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
/* Em telas largas (desktop admin), limita cards a ~360px e centraliza o restante */
@media (min-width: 1100px) {
  .ck-acomp-grid {
    grid-template-columns: repeat(auto-fill, minmax(300px, 360px));
    justify-content: start;
  }
}

.ck-acomp-section {
  margin-bottom: 24px;
}

.ck-acomp-section-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text-3);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 12px;
}

.ck-acomp-card {
  padding: 0;
  overflow: hidden;
}
.ck-acomp-card--atrasado {
  box-shadow: 0 0 0 2px var(--ck-danger-border);
}

.ck-acomp-card__bar {
  height: 5px;
  background: var(--cat-color, var(--color-primary));
}

.ck-acomp-card__body {
  padding: 16px;
}

.ck-acomp-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.ck-acomp-card__title-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ck-acomp-card__icon {
  font-size: 24px;
}

.ck-acomp-card__title {
  font-weight: 700;
  font-size: 14px;
}

.ck-acomp-card__subtitle {
  font-size: 12px;
  color: var(--color-text-3);
}

.ck-acomp-card__meta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--color-text-2);
  margin-bottom: 12px;
}

.ck-acomp-card__action {
  width: 100%;
  padding: 12px;
}

/* Badges de status do card de acompanhamento */
.ck-badge-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  border: 1px solid transparent;
}
.ck-badge-status--em-andamento {
  background: var(--ck-info-bg);
  color: var(--ck-info-text);
  border-color: var(--ck-info-border);
}
.ck-badge-status--atrasado {
  background: var(--ck-danger-bg);
  color: var(--ck-danger-text);
  border-color: var(--ck-danger-border);
}
.ck-badge-status--no-horario {
  background: var(--ck-warning-bg);
  color: var(--ck-warning-text);
  border-color: var(--ck-warning-border);
}
.ck-badge-status--concluido {
  background: var(--ck-success-bg);
  color: var(--ck-success-text);
  border-color: var(--ck-success-border);
}
.ck-badge-status--parcial {
  background: var(--ck-warning-bg);
  color: var(--ck-warning-text);
  border-color: var(--ck-warning-border);
}

/* ── Contador inline na barra de título da seção ─────────── */
.ck-acomp-section-count {
  color: var(--color-text-3);
  font-weight: 700;
  margin-left: 4px;
}

/* ── Modifiers de seção (cor da barra de título por urgência) ── */
.ck-acomp-section--atrasados .ck-acomp-section-title {
  color: var(--ck-danger);
}
.ck-acomp-section--execucao .ck-acomp-section-title {
  color: var(--ck-info);
}
.ck-acomp-section--pendentes .ck-acomp-section-title {
  color: var(--ck-warning-text);
}
.ck-acomp-section--futuros .ck-acomp-section-title {
  color: var(--color-text-3);
}

/* ── Accordion de Concluídos ─────────────────────────────── */
.ck-acomp-concluidos {
  margin-top: 24px;
  border-top: 1px dashed var(--color-border);
  padding-top: 16px;
}
.ck-acomp-concluidos__summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: var(--ck-success-text);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 12px;
  padding: 8px 12px;
  border-radius: 8px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  list-style: none;             /* esconde marcador padrão */
  user-select: none;
}
.ck-acomp-concluidos__summary::-webkit-details-marker {
  display: none;                /* WebKit/Safari */
}
.ck-acomp-concluidos__summary::before {
  content: '▶';
  display: inline-block;
  margin-right: 6px;
  font-size: 10px;
  transition: transform 0.15s ease;
}
.ck-acomp-concluidos[open] .ck-acomp-concluidos__summary::before {
  transform: rotate(90deg);
}
.ck-acomp-concluidos__summary:hover {
  background: var(--color-surface-3);
  border-color: var(--color-border-2);
}

/* Grid mais denso para cards compactos (concluídos) */
.ck-acomp-grid--compact {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
}

/* ── Card compacto (Concluídos) ──────────────────────────── */
.ck-acomp-card--compact .ck-acomp-card__body {
  padding: 10px 12px;
}
.ck-acomp-card--compact .ck-acomp-card__bar {
  height: 3px;                  /* barra superior mais fina */
}
.ck-acomp-card--compact .ck-acomp-card__icon {
  font-size: 18px;
}
.ck-acomp-card--compact .ck-acomp-card__title {
  font-size: 13px;
}
.ck-acomp-card--compact .ck-acomp-card__subtitle {
  font-size: 11px;
}
.ck-acomp-card--compact .ck-acomp-card__head {
  margin-bottom: 0;
  gap: 8px;
}

@media (prefers-reduced-motion: reduce) {
  .ck-acomp-concluidos__summary::before {
    transition: none;
  }
}

/* ════════════════════════════════════════════════════════════
   v766 — UX touch targets + contraste + skeleton
   ════════════════════════════════════════════════════════════ */

/* Estrelas do modal de avaliação — touch target 48px */
.ck-star-row {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.ck-star-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 42px;
  line-height: 1;
  color: var(--color-text-3);
  width: 48px;       /* touch target — antes era ~16px (font-size 42 mas padding só 4) */
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: transform 0.12s ease, background 0.12s ease, color 0.12s ease;
  -webkit-tap-highlight-color: transparent;
}
.ck-star-btn:hover,
.ck-star-btn:focus-visible {
  background: var(--color-surface-2);
  transform: scale(1.1);
  outline: none;
}
.ck-star-btn--filled {
  color: var(--color-primary);
}

/* Botão "Retirar Foto" — antes era btn-secondary (cinza sobre cinza, ruim em luz fluor).
   Agora um botão warning suave com contraste melhor. */
.wz-foto-retake-btn {
  margin-top: 8px;
  background: var(--ck-warning-bg);
  color: var(--ck-warning-text);
  border: 1px solid var(--ck-warning-border);
  font-weight: 700;
}
.wz-foto-retake-btn:hover:not(:disabled) {
  background: var(--ck-warning);
  color: #fff;
  border-color: var(--ck-warning);
}

/* Toggle do Padrão Ouro — aumenta touch target (era ~32px alt., crítico em tablet) */
.wz-padrao-ouro__toggle {
  min-height: 44px;
}

/* Skeleton inicial do wizard (entre _abrirWizard e Realtime channel ativar) */
.wz-skeleton {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.wz-skeleton__line {
  background: linear-gradient(90deg, var(--color-surface-2) 0%, var(--color-surface-3) 50%, var(--color-surface-2) 100%);
  background-size: 200% 100%;
  border-radius: 8px;
  height: 16px;
  animation: wz-shimmer 1.2s ease-in-out infinite;
}
.wz-skeleton__line--big { height: 72px; }
.wz-skeleton__line--lg  { height: 24px; width: 60%; }
.wz-skeleton__line--md  { height: 16px; width: 80%; }

@keyframes wz-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .wz-skeleton__line { animation: none; }
}

/* ════════════════════════════════════════════════════════════
   v768 — Medalhas (score gamificado nos cards compactos)
   ════════════════════════════════════════════════════════════ */

.ck-acomp-card__head-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

.ck-medal {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
  border: 1px solid transparent;
  font-variant-numeric: tabular-nums;
}
.ck-medal--ouro {
  background: linear-gradient(135deg, rgba(250,204,21,.18), rgba(217,119,6,.10));
  color: #facc15;
  border-color: rgba(250,204,21,.45);
}
.ck-medal--prata {
  background: linear-gradient(135deg, rgba(203,213,225,.18), rgba(148,163,184,.10));
  color: #cbd5e1;
  border-color: rgba(203,213,225,.45);
}
.ck-medal--bronze {
  background: linear-gradient(135deg, rgba(180,83,9,.20), rgba(120,53,15,.12));
  color: #fbbf24;
  border-color: rgba(180,83,9,.45);
}
.ck-medal--falha {
  background: var(--ck-danger-bg);
  color: var(--ck-danger-strong);
  border-color: var(--ck-danger-border);
}

/* Header do acompanhamento (data + botão atualizar) */
.ck-acomp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 12px;
  flex-wrap: wrap;
}
.ck-acomp-header__date {
  font-size: 14px;
  color: var(--color-text-2);
}

/* Empty state quando "Tudo em dia" */
.ck-acomp-empty {
  text-align: center;
  padding: 40px;
}
.ck-acomp-empty__icon {
  font-size: 48px;
  margin-bottom: 12px;
}
.ck-acomp-empty__title {
  color: var(--color-text-2);
}
.ck-acomp-empty__hint {
  font-size: 13px;
  color: var(--color-text-3);
}

/* ════════════════════════════════════════════════════════════
   WIZARD — Tela de execução do checklist
   ════════════════════════════════════════════════════════════ */

/* Header do modal do wizard com cor da categoria */
.wz-modal-header {
  background: var(--cat-color, var(--color-primary));
  color: #fff;
}
.wz-modal-header .btn-close {
  color: #fff;
}

/* Status bar logo abaixo do header (operador + contador) */
.wz-status-bar {
  padding: 12px 20px;
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
}

/* Banner offline (entre status-bar e modal-body) */
.wz-offline-banner {
  display: none;          /* JS muda para flex quando offline */
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--ck-warning-bg);
  color: var(--ck-warning-text);
  border-bottom: 1px solid var(--ck-warning-border);
  font-size: 13px;
  font-weight: 600;
}

/* Modal body do wizard (scroll vertical) */
.wz-body {
  max-height: 65vh;
  overflow-y: auto;
  padding: 16px;
  /* Fase C: container query ativa o split-view quando o modal estiver largo o suficiente */
  container-type: inline-size;
  container-name: wz-body;
}
.wz-body__stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* v980/v991: modo foco — quando há foto_ia pendente, esconde TODAS as tarefas
   exceto a ativa, em mobile E tablet. Foco total na foto_ia atual pra
   evitar distração (UX kit: animate 1-2 key elements per view maximum).
   Removido automaticamente pelo JS quando todas as foto_ia foram resolvidas. */
.wz-body__stack.wz-foco-mode .wz-tarefa { display: none; }
.wz-body__stack.wz-foco-mode .wz-tarefa.wz-tarefa--active { display: block; }
/* Em tablet, .wz-master e' a lista lateral. Escondemos quando ha foto_ia
   pendente — usuario nao deve "fugir" pra outras tarefas pulando a IA. */
.wz-grid.wz-foco-mode .wz-master { display: none !important; }
/* Em tablet, .wz-detail no foco mode fica em largura cheia (sem o sidebar). */
.wz-grid.wz-foco-mode { grid-template-columns: 1fr !important; }

/* ════════════════════════════════════════════════════════════
   FASE C — Master-Detail (Split-View) para tablets
   Mobile (default): .wz-master oculto, .wz-detail mostra stack inteiro.
   Tablet (>=720px de largura do MODAL): master visível à esquerda,
   detail só renderiza a tarefa ativa.
   ════════════════════════════════════════════════════════════ */

.wz-grid {
  display: block;
}

.wz-master {
  display: none;          /* default mobile: oculto */
}

.wz-master-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  text-align: left;
  color: var(--color-text);
  font: inherit;
  font-size: 13px;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
  min-height: 48px;       /* touch target */
}
.wz-master-item:hover,
.wz-master-item:focus-visible {
  background: var(--color-surface-3);
  border-color: var(--color-border-2);
  outline: none;
}
.wz-master-item--active {
  background: var(--color-primary-bg);
  border-color: var(--color-primary);
  color: var(--color-text-1);
}

.wz-master-item__num {
  flex-shrink: 0;
  min-width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-surface-3);
  color: var(--color-text-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
}
.wz-master-item--active .wz-master-item__num {
  background: var(--color-primary);
  color: #000;
}

.wz-master-item__title {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wz-master-item__icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  line-height: 1;
}

/* Ícone do master-item por status — usa ::before com emoji-text */
.wz-master-item[data-status="pending"]    .wz-master-item__icon::before { content: '○'; color: var(--color-text-3); font-size: 16px; }
.wz-master-item[data-status="saving"]     .wz-master-item__icon::before { content: '⏳'; }
.wz-master-item[data-status="done"]       .wz-master-item__icon::before { content: '✓'; color: var(--ck-success); font-weight: 800; }
.wz-master-item[data-status="pending-ia"] .wz-master-item__icon::before { content: '🤖'; }
.wz-master-item[data-status="error"]      .wz-master-item__icon::before { content: '✕'; color: var(--ck-danger); font-weight: 800; }

/* ── Container query: ativa split-view quando o modal está largo ──
   Threshold de 640px considera que .modal-wide tem max-width 720px
   menos 32px de padding interno = ~688px efetivos. 640 garante que
   iPad portrait (modal preenche ~720) dispare o split. */
@container wz-body (min-width: 640px) {
  .wz-grid {
    display: grid;
    grid-template-columns: minmax(240px, 30%) 1fr;
    gap: 16px;
    align-items: start;
  }
  .wz-master {
    display: flex;
    flex-direction: column;
    gap: 6px;
    position: sticky;
    top: 0;
    max-height: calc(65vh - 32px);
    overflow-y: auto;
    padding-right: 4px;
  }
  .wz-detail {
    min-width: 0; /* permite ellipsis em filhos */
  }
  /* No detail, apenas a tarefa ativa é renderizada — as outras ficam ocultas */
  .wz-detail .wz-tarefa:not(.wz-tarefa--active) {
    display: none;
  }
  /* Card ativo ganha respiro extra em tablet */
  .wz-detail .wz-tarefa--active {
    padding: 20px;
  }
}

/* Fallback para navegadores sem suporte a container queries (Safari < 16 / Chrome < 105).
   Usa media query baseada em viewport — split aparece se o usuário está em telas largas. */
@supports not (container-type: inline-size) {
  @media (min-width: 900px) {
    .wz-grid {
      display: grid;
      grid-template-columns: minmax(240px, 30%) 1fr;
      gap: 16px;
      align-items: start;
    }
    .wz-master {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .wz-detail .wz-tarefa:not(.wz-tarefa--active) {
      display: none;
    }
  }
}

/* Footer do wizard (progresso + botões) */
.wz-footer-progress {
  font-size: 12px;
  color: var(--color-text-3);
}
.wz-footer-actions {
  display: flex;
  gap: 8px;
}

/* ── Card de tarefa dentro do wizard ─────────────────────── */
.wz-tarefa {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 16px;
  border-left: 4px solid transparent; /* base — estados pintam por cima */
  transition: border-left-color 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

/* v788: estado "respondido" mais nítido — borda esquerda grossa verde + fundo levemente esverdeado
   + check no número. Vale pra qualquer tipo (boolean Feito/Não Feito, texto, número, foto).
   Persiste durante toda a execução do checklist. */
.wz-tarefa--done {
  border-left: 5px solid var(--ck-success);
  background: linear-gradient(to right, rgba(16,185,129,0.08) 0%, transparent 80%);
}
.wz-tarefa--done .wz-tarefa__num {
  background: var(--ck-success);
  position: relative;
}
.wz-tarefa--done .wz-tarefa__num::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ck-success);
  color: #fff;
  border-radius: 50%;
  font-weight: 900;
  font-size: 16px;
}
.wz-tarefa--done .wz-tarefa__title {
  color: var(--color-text-2);
  text-decoration: line-through;
  text-decoration-color: rgba(16,185,129,0.4);
  text-decoration-thickness: 1px;
}

/* v788: destaque pulsante quando user tenta finalizar com pendente */
@keyframes wzHighlight {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245,158,11,0); }
  50% { box-shadow: 0 0 0 6px rgba(245,158,11,0.4); }
}
.wz-tarefa--highlight {
  animation: wzHighlight 0.7s ease-in-out 3;
  border-left: 5px solid #f59e0b !important;
  background: linear-gradient(to right, rgba(245,158,11,0.12) 0%, transparent 80%) !important;
}

/* Cabeçalho do card de tarefa (num + título + badge) */
.wz-tarefa__head {
  margin-bottom: 12px;
}
.wz-tarefa__head-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

/* Numero circular colorido por categoria */
.wz-tarefa__num {
  background: var(--cat-color, var(--color-primary));
  color: #fff;
  min-width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 800;
  flex-shrink: 0;
}

.wz-tarefa__title {
  font-weight: 700;
  font-size: 17px;
  line-height: 1.3;
  color: var(--color-text);
}

.wz-tarefa__desc {
  font-size: 13px;
  color: var(--color-text-2);
  margin: 0 0 0 36px;
  line-height: 1.4;
}

/* Badge de criticidade no header da tarefa */
.wz-bdg {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 6px;
  white-space: nowrap;
}
.wz-bdg--critica {
  background: var(--ck-danger-bg);
  color: var(--ck-danger-strong);
}
.wz-bdg--notificar {
  background: var(--ck-notif-bg);
  color: var(--ck-notif-text);
}

/* Área de resposta abaixo do header */
.wz-resposta {
  margin-top: 10px;
}

/* ── Respostas: Boolean (Feito / Não Feito) ──────────────── */
.wz-resp-row {
  display: flex;
  gap: 10px;
}
.wz-resp-row .btn {
  flex: 1;
  padding: 14px;
  font-size: 16px;
}
.wz-resp-row__btn--no-feito-active {
  background: var(--ck-danger);
  border-color: var(--ck-danger);
  color: #fff;
}

/* ── Respostas: Texto e Número ───────────────────────────── */
.wz-resp-inline {
  display: flex;
  gap: 8px;
  align-items: stretch;
}
.wz-resp-inline .form-control {
  flex: 1;
}
.wz-resp-inline__num {
  font-size: 18px;
  font-weight: 600;
  text-align: center;
}
.wz-resp-inline__unidade {
  display: flex;
  align-items: center;
  padding: 0 12px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-2);
}

/* ── Respostas: Foto (com e sem IA) ──────────────────────── */
.wz-foto-cam-btn {
  width: 100%;
  padding: 14px 16px;
  font-size: 15px;
  /* v995: permite até 2 linhas pra títulos longos de tarefa */
  white-space: normal;
  line-height: 1.25;
  min-height: 56px;
  height: auto;
  word-break: break-word;
  text-align: center;
}
.wz-foto-cam-btn svg { flex-shrink: 0; }
.wz-foto-preview-wrap {
  position: relative;
  margin-bottom: 8px;
}
.wz-foto-preview-img {
  width: 100%;
  max-height: 200px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--color-border);
}
.wz-foto-ia-tag {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(0,0,0,0.7);
  color: #fff;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 10px;
}
.wz-foto-retake-btn {
  margin-top: 8px;
}
.wz-foto-upload-status {
  display: none;            /* JS troca para block durante upload */
  text-align: center;
  padding: 10px;
}
.wz-foto-upload-status__hint {
  font-size: 12px;
  color: var(--color-text-3);
  margin-top: 6px;
}

/* Badge de status da IA (aprovado / reprovado / pendente) */
.wz-ia-badge {
  margin-top: 8px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 12px;
  border: 1px solid transparent;
}
.wz-ia-badge--aprovado {
  background: var(--ck-success-bg);
  color: var(--ck-success-text);
  border-color: var(--ck-success-border);
}
.wz-ia-badge--reprovado {
  background: var(--ck-danger-bg);
  color: var(--ck-danger-text);
  border-color: var(--ck-danger-border);
}
.wz-ia-badge--pendente {
  background: var(--ck-warning-bg);
  color: var(--ck-warning-text);
  border-color: var(--ck-warning-border);
}

/* Bloco do Padrão Ouro (referência visual) */
/* v991: Foto Exemplo de-emphasizada — antes tinha gradiente dourado chamativo.
   Agora é um botão sutil; só ganha destaque quando aberta (a imagem em si). */
.wz-padrao-ouro {
  margin-bottom: 10px;
}
.wz-padrao-ouro__toggle {
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-3);
  background: transparent;
  border: 1px dashed var(--color-border-2);
  border-radius: 6px;
  padding: 6px 10px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  width: auto;
}
.wz-padrao-ouro__toggle:hover {
  color: var(--color-text-2);
  border-color: var(--color-border);
}
.wz-padrao-ouro__toggle svg { width: 14px; height: 14px; }
.wz-padrao-ouro__img {
  display: none;
  width: 100%;
  max-height: 280px;
  object-fit: contain;
  background: var(--color-surface-2);
  border-radius: 8px;
  margin-top: 8px;
  border: 2px solid var(--ck-gold-border);
}
/* Em celular: ajusta pra caber o card + botão sem cortar */
@media (max-width: 600px) {
  .wz-padrao-ouro__img {
    max-height: 220px;
  }
}

/* ════════════════════════════════════════════════════════════
   v1001: POP-UP central de análise da IA (sobe na tela,
   auto-fecha em 3s, com botão Continuar)
   ════════════════════════════════════════════════════════════ */
.wz-ia-popup {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity .2s ease;
}
.wz-ia-popup.wz-ia-popup--open {
  opacity: 1;
  pointer-events: auto;
}
.wz-ia-popup__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.98);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}
.wz-ia-popup__card {
  position: relative;
  margin-top: 18vh;
  background: var(--color-surface);
  border: 1px solid var(--color-border-2);
  border-radius: 16px;
  padding: 24px 22px;
  width: min(440px, calc(100vw - 32px));
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.55);
  text-align: center;
  animation: wz-ia-pop-up .25s ease;
}
@keyframes wz-ia-pop-up {
  from { transform: translateY(-18px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.wz-ia-popup__row {
  display: flex; align-items: center; gap: 14px;
  justify-content: center;
  margin-bottom: 6px;
}
.wz-ia-popup__spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: wz-spin .9s linear infinite;
}
@keyframes wz-spin { to { transform: rotate(360deg); } }
.wz-ia-popup__icon {
  font-size: 52px;
  line-height: 1;
  margin-bottom: 6px;
}
.wz-ia-popup__title {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 4px;
}
.wz-ia-popup__sub {
  font-size: 14px;
  color: var(--color-text-2);
  line-height: 1.45;
  margin-top: 6px;
}
.wz-ia-popup__btn {
  margin-top: 18px;
  width: 100%;
  min-height: 50px;
  font-size: 15px;
  font-weight: 600;
}
.wz-ia-popup__card--ok {
  border-color: rgba(34, 197, 94, 0.5);
  box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.18), 0 20px 60px rgba(0, 0, 0, 0.55);
}
.wz-ia-popup__card--err {
  border-color: rgba(239, 68, 68, 0.5);
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.18), 0 20px 60px rgba(0, 0, 0, 0.55);
}
.wz-ia-popup__card--warn {
  border-color: rgba(245, 158, 11, 0.5);
}

/* v1000: footer wizard FIXED no fundo da viewport (brute force).
   Tentamos flex column 4 vezes e algo no ambiente do iOS sempre
   quebrava a cadeia. position:fixed mata o problema na raiz.
   Em mobile ocupa width inteiro; em desktop, mantém largura do modal. */
#modal-box.wz-modal-flex .modal-footer {
  position: fixed !important;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding-bottom: max(14px, env(safe-area-inset-bottom, 14px));
}
/* Espaço extra no fim do scroll pra não ficar oculto atrás do footer fixo */
#modal-box.wz-modal-flex .wz-body {
  padding-bottom: 80px;
}
/* Em desktop o modal não é full-width — ajusta o footer pra ficar
   com a mesma largura que o modal-box (centralizado). */
@media (min-width: 721px) {
  #modal-box.wz-modal-flex .modal-footer {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: min(720px, 95vw);
    max-width: 720px;
    border-radius: 0 0 16px 16px;
  }
}

/* ════════════════════════════════════════════════════════════
   ESTADOS VISUAIS DE SALVAMENTO (B3)
   Substituem o opacity:0.6 + borderLeft hardcoded.
   Feedback claro de "estou salvando / salvei / deu erro".
   ════════════════════════════════════════════════════════════ */

.wz-saving {
  border-left-color: var(--ck-warning) !important;
  pointer-events: none;
  animation: wz-pulse 1.2s ease-in-out infinite;
}

.wz-saved {
  border-left-color: var(--ck-success) !important;
  animation: wz-pop 240ms ease-out;
}

.wz-error {
  border-left-color: var(--ck-danger) !important;
  animation: wz-shake 320ms ease-in-out;
}

.wz-ia-processing {
  /* Borda azul enquanto a IA processa, sem confundir com "erro" ou "ok" */
  border-left-color: var(--ck-info) !important;
}

@keyframes wz-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.78; }
}

@keyframes wz-pop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.015); }
  100% { transform: scale(1); }
}

@keyframes wz-shake {
  0%, 100% { transform: translateX(0); }
  20%      { transform: translateX(-5px); }
  40%      { transform: translateX(4px); }
  60%      { transform: translateX(-3px); }
  80%      { transform: translateX(2px); }
}

/* Respeita preferência do sistema por menos movimento (acessibilidade) */
@media (prefers-reduced-motion: reduce) {
  .wz-saving,
  .wz-saved,
  .wz-error {
    animation: none;
  }
  .wz-tarefa {
    transition: none;
  }
}
