:root {
  --brand: #fcb653;
  --brand-600: #e7a949;
  --brand-700: #d99c3f;

  --bg: #f6f7f9;
  --surface: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --border: #e5e7eb;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);
  --shadow-md: 0 10px 25px rgba(17, 24, 39, .08);

  --radius: 16px;
  --radius-sm: 12px;
}

html,
body {
  height: 100%;
}

body {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}

.logo {
  height: 40px;
  width: auto;
}

/* Touch-first */
.touch {
  min-height: 56px;
  padding: 12px 18px;
  font-weight: 700;
  border-radius: 14px;
}

/* Cards */
.card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

.card.soft {
  background: rgba(255, 255, 255, .75);
  backdrop-filter: blur(8px);
}

/* Inputs */
.form-control,
.form-select {
  border-radius: 14px;
  border-color: var(--border);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--brand-600);
  box-shadow: 0 0 0 .25rem rgba(252, 182, 83, .25);
}

/* Botão primário com brand */
.btn-primary {
  --bs-btn-bg: var(--brand);
  --bs-btn-border-color: var(--brand);
  --bs-btn-hover-bg: var(--brand-600);
  --bs-btn-hover-border-color: var(--brand-600);
  --bs-btn-active-bg: var(--brand-700);
  --bs-btn-active-border-color: var(--brand-700);
  color: #1a1a1a;
}

.btn-outline-primary {
  --bs-btn-color: #1f2937;
  --bs-btn-border-color: var(--border);
  --bs-btn-hover-bg: rgba(252, 182, 83, .20);
  --bs-btn-hover-border-color: rgba(252, 182, 83, .45);
  --bs-btn-hover-color: #111827;
  border-radius: 14px;
}

/* Cabeçalho mais “app” */
.app-header {
  background: rgba(255, 255, 255, .75);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.user-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(17, 24, 39, .04);
  border: 1px solid var(--border);
  font-weight: 600;
  color: #374151;
}

/* Badges de status */
.badge-status {
  font-size: .90rem;
  padding: .55rem .8rem;
  border-radius: 999px;
  border: 1px solid var(--border);
}

.st-ANALISE {
  background: #f3f4f6;
  color: #374151;
}

.st-AGUARDANDO_APROVACAO {
  background: #fff7ed;
  color: #9a3412;
  border-color: #fed7aa;
}

.st-APROVADO {
  background: #eff6ff;
  color: #1d4ed8;
  border-color: #bfdbfe;
}

.st-EM_REPARO {
  background: #fff7ed;
  color: #c2410c;
  border-color: #fed7aa;
}

.st-PRONTO {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}

.st-ENTREGUE {
  background: #111827;
  color: #fff;
  border-color: #111827;
}

/* Checklist */
.check-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
}

.check-item .label {
  font-weight: 700;
  color: #111827;
}

.check-item .state {
  min-width: 120px;
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  font-weight: 800;
}

.state-na {
  background: #f9fafb;
  color: #6b7280;
}

.state-ok {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}

.state-nok {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fecaca;
}

.small-muted {
  font-size: .92rem;
  color: var(--muted);
}

/* Fotos */
.photo-thumb {
  width: 104px;
  height: 104px;
  border-radius: 16px;
  object-fit: cover;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  background: #fff;
}

/* Pattern */
.pattern-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #eef2f7;
  border: 2px solid #d1d5db;
}

.pattern-dot.active {
  background: var(--brand);
  border-color: var(--brand-700);
}

/* Barra fixa de ações (mobile) */
.action-bar {
  position: sticky;
  bottom: 0;
  z-index: 30;
  background: rgba(255, 255, 255, .85);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-md);
  padding: 10px;
}