.mf-view {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: calc(100vh - 184px);
  padding: 0;
  /* Sem padding-top — toolbar fica colada ao menu do topo, igual às
     outras ferramentas (.nl2-view e .lp-grade-nomes). */
  /* Fundo herdado do body — sem gradientes decorativos próprios para
     manter consistência visual entre todas as ferramentas. */
}

.mf-sidebar,
.mf-preview-card {
  border: 1px solid var(--border-mid);
  background: var(--surface-2);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}

/* Toolbar unificada (template aplicado também em .nl2-toolbar e .lp-gn-toolbar). */
.mf-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 14px 18px;
  border: 1px solid var(--border-mid);
  background: var(--surface-2);
  border-radius: var(--radius-lg);
}

/* Bloco de título do módulo (mesmo padrão de .rf-toolbar-title e
   .vt-toolbar-title). Fica no canto esquerdo da toolbar. */
.mf-toolbar-title {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-right: auto;
}

.mf-toolbar-title-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  background: rgba(var(--accent-rgb), .14);
  border: 1px solid rgba(var(--accent-rgb), .26);
  display: grid;
  place-items: center;
  color: var(--accent-hi);
  flex: 0 0 auto;
}

.mf-toolbar-title h2 {
  margin: 0;
  color: var(--text);
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0;
}

.mf-toolbar-title p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.mf-toolbar-main {
  display: flex;
  flex: 1;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}

.mf-toolbar-copy h2,
.mf-sidebar-head h3 {
  margin: 0;
  color: var(--text);
  font-size: var(--text-xl);
  line-height: 1.1;
}

.mf-toolbar-copy p,
.mf-sidebar-head p,
.mf-hint,
.mf-status-card p,
.mf-preview-note,
.mf-preview-placeholder span,
.mf-upload-zone small,
.mf-alert,
.mf-step,
.mf-link-btn,
.mf-inline-error {
  color: var(--muted);
}

.mf-toolbar-copy p,
.mf-sidebar-head p,
.mf-hint,
.mf-status-card p,
.mf-preview-note,
.mf-preview-placeholder span,
.mf-upload-zone small {
  margin: 0;
  font-size: var(--text-md);
  line-height: 1.45;
}

.mf-kicker,
.mf-sidebar-kicker,
.mf-label,
.mf-preview-badge,
.mf-upload-zone span,
.mf-range-head span {
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-size: var(--text-xs);
  font-weight: 700;
}

/* Kickers (tags de seção) usam teal — decorativos.
   Labels de campo usam muted — consistente com nl2 e lp-gn. */
.mf-kicker,
.mf-sidebar-kicker,
.mf-preview-badge,
.mf-range-head span {
  color: var(--accent-hi);
}

.mf-label {
  color: var(--muted);
}

.mf-stepper {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.mf-step {
  border-radius: var(--radius-pill);
  padding: 10px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  font-size: var(--text-sm);
  font-weight: 700;
}

.mf-step--active {
  color: var(--text);
  border-color: rgba(var(--accent-rgb), 0.45);
  background: rgba(var(--accent-rgb), 0.16);
}

.mf-step--done {
  color: var(--accent-hi);
  border-color: rgba(var(--accent-rgb), 0.28);
  background: rgba(var(--accent-rgb), 0.1);
}

.mf-toolbar-side,
.mf-stack,
.mf-control-block,
.mf-sidebar,
.mf-shell,
.mf-main,
.mf-button-grid {
  display: flex;
}

.mf-toolbar-side {
  gap: 10px;
  align-items: flex-start;
}

.mf-shell {
  gap: 18px;
  min-height: 0;
  flex: 1;
}

.mf-sidebar {
  width: 340px;
  min-width: 340px;
  flex-direction: column;
  gap: 18px;
  padding: 20px;
  border-radius: var(--radius-2xl);
  overflow: auto;
}

.mf-sidebar-head {
  display: grid;
  gap: 8px;
}

.mf-main {
  flex: 1;
  min-width: 0;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.mf-control-block,
.mf-stack {
  flex-direction: column;
  gap: 12px;
}

.mf-field {
  display: grid;
  gap: 8px;
}

#mfStepOneControls,
#mfStepTwoControls,
#mfStepOneContent,
#mfStepTwoContent {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
}

#mfStepTwoControls {
  gap: 14px;
}

.mf-select,
.mf-number,
.mf-range,
.mf-mode-btn,
.mf-btn,
.mf-upload-zone,
.mf-link-btn {
  font: inherit;
}

.mf-select,
.mf-number,
.mf-range,
.mf-mode-btn,
.mf-btn {
  border-radius: var(--radius-lg);
}

.mf-select,
.mf-number,
.mf-range {
  width: 100%;
}

.mf-select,
.mf-number {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
    rgba(255, 255, 255, 0.04);
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
  padding: 13px 14px;
}

.mf-select {
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none'%3E%3Cpath d='M3 5.25 7 9l4-3.75' stroke='%23cfe4f5' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center / 14px 14px,
    linear-gradient(135deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
    rgba(255, 255, 255, 0.04);
  padding: 13px 44px 13px 14px;
}

.mf-select:focus,
.mf-number:focus,
.mf-range:focus,
.mf-btn:focus,
.mf-link-btn:focus,
.mf-upload-zone:focus,
.mf-mode-btn:focus {
  outline: 2px solid rgba(var(--accent-rgb), 0.48);
  outline-offset: 2px;
}

.mf-range {
  accent-color: var(--accent);
}

.mf-select option,
.mf-select optgroup {
  background: var(--surface-1);
  color: var(--text);
}

.mf-number::-webkit-outer-spin-button,
.mf-number::-webkit-inner-spin-button {
  margin: 0;
}

.mf-manual-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02));
}

.mf-manual-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mf-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  font-size: var(--text-md);
  font-weight: 600;
}

.mf-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.mf-mode-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 6px;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.mf-mode-btn,
.mf-btn,
.mf-link-btn {
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.mf-mode-btn {
  padding: 12px 10px;
  background: transparent;
  color: var(--muted);
  font-weight: 700;
}

.mf-mode-btn:hover,
.mf-btn:hover,
.mf-link-btn:hover {
  background: rgba(var(--accent-rgb), 0.08);
  border-color: rgba(var(--accent-rgb), 0.32);
}

/* Botão Fechar — hover em vermelho discreto, mesma cor de .lp-mini-btn-ghost
   em Nomes em Lote, sinalizando que vai sair do módulo. */
#mfCloseBtn:hover {
  background: rgba(212, 85, 85, .10);
  border-color: rgba(212, 85, 85, .32);
  color: #e07070;
}

.mf-mode-btn--active {
  color: var(--text);
  background: linear-gradient(135deg, rgba(var(--accent-rgb), 0.3), rgba(var(--gold-rgb), 0.2));
  border-color: rgba(var(--accent-rgb), 0.22);
}

.mf-upload-zone {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 30px 22px;
  border-radius: var(--radius-2xl);
  border: 1.5px dashed rgba(var(--accent-rgb), 0.3);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.025));
  text-align: center;
  cursor: pointer;
}

.mf-upload-zone--drag {
  border-color: rgba(var(--accent-rgb), 0.8);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.14), rgba(var(--gold-rgb), 0.08));
}

.mf-upload-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  color: var(--accent-hi);
  background: rgba(var(--accent-rgb), 0.12);
  border: 1px solid rgba(var(--accent-rgb), 0.22);
}

.mf-upload-zone strong,
.mf-preview-placeholder strong,
.mf-status-line strong {
  color: var(--text);
}

.mf-upload-zone strong {
  font-size: var(--text-lg);
}

.mf-upload-zone span {
  color: var(--accent-hi);
}

.mf-inline-error {
  font-size: var(--text-md);
  color: #ed8a8a;
}

.mf-btn {
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  font-weight: 700;
}

.mf-btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  transform: none;
}

/* Primário — mesmo padrão de .rf-btn--primary / .vt-btn--primary:
   accent sólido, sem gradiente nem sombra colorida, hover sobe pra accent-hi. */
.mf-btn--primary {
  background-color: var(--accent);
  color: #0a141a;
  border-color: rgba(var(--accent-rgb), 0.6);
  font-weight: 700;
}

.mf-btn--primary:hover {
  background-color: var(--accent-hi);
  border-color: var(--accent-hi);
}

.mf-btn--secondary {
  border-color: rgba(255, 255, 255, 0.08);
}

.mf-btn--ghost,
.mf-link-btn {
  color: var(--muted);
  border-color: var(--border-mid);
  background: transparent;
}

.mf-btn--block {
  width: 100%;
}

.mf-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--radius-lg);
}

.mf-range-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.mf-range-head strong {
  color: var(--text);
  font-size: var(--text-md);
}

.mf-button-grid {
  gap: 10px;
}

.mf-button-grid .mf-btn {
  flex: 1;
}

#mfStepTwoControls .mf-field,
#mfStepTwoControls .mf-control-block,
#mfStepTwoControls .mf-button-grid {
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02));
}

#mfStepTwoControls .mf-field {
  align-content: start;
}

#mfStepTwoControls .mf-button-grid {
  gap: 12px;
}

.mf-status-card,
.mf-alert {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

.mf-status-card--ready {
  border-color: rgba(var(--accent-rgb), 0.22);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.11), rgba(255, 255, 255, 0.04));
}

.mf-alert--error {
  color: #ed8a8a;
  border-color: rgba(212, 85, 85, 0.25);
  background: rgba(212, 85, 85, 0.08);
}

.mf-status-line {
  display: flex;
  gap: 10px;
  align-items: center;
}

.mf-status-dot,
.mf-spinner {
  flex: 0 0 auto;
}

.mf-status-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-pill);
  background: var(--accent);
  box-shadow: 0 0 0 6px rgba(var(--accent-rgb), 0.12);
}

.mf-spinner {
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pill);
  border: 2px solid rgba(255, 255, 255, 0.16);
  border-top-color: var(--accent-hi);
  animation: mf-spin 0.8s linear infinite;
}

.mf-spinner--lg {
  width: 32px;
  height: 32px;
  border-width: 3px;
}

.mf-progress-track {
  width: 100%;
  height: 7px;
  border-radius: var(--radius-pill);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.08);
}

.mf-progress-bar {
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-hi));
  transition: width 0.35s ease;
}

.mf-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  min-height: 0;
  height: 100%;
  align-items: stretch;
}

.mf-preview-grid--matrix {
  align-items: stretch;
}

.mf-preview-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
  min-height: 0;
  padding: 16px;
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.mf-preview-badge {
  align-self: flex-start;
  padding: 8px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(var(--accent-rgb), 0.15);
  background: rgba(var(--accent-rgb), 0.08);
}

.mf-preview-stage {
  position: relative;
  flex: 1;
  min-height: 0;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

#mfStepOneContent .mf-preview-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#mfStepOneContent .mf-preview-card {
  min-height: 0;
}

#mfStepOneContent .mf-preview-stage {
  height: clamp(240px, 41vh, 420px);
}

.mf-shape-guide {
  position: absolute;
  inset: 0;
  margin: auto;
  z-index: 2;
  border: 1.5px dashed rgba(var(--accent-rgb), 0.72);
  box-shadow: inset 0 0 0 1px rgba(16, 23, 34, 0.18);
  pointer-events: none;
}

#mfStepTwoContent .mf-preview-stage {
  height: clamp(300px, 54vh, 620px);
}

.mf-preview-stage--solid {
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.06), transparent 42%),
    var(--surface-1);
}

.mf-preview-stage--checker {
  background-color: #f3f6fb;
  background-image:
    linear-gradient(45deg, rgba(20, 29, 43, 0.08) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(20, 29, 43, 0.08) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(20, 29, 43, 0.08) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(20, 29, 43, 0.08) 75%);
  background-size: 24px 24px;
  background-position: 0 0, 0 12px, 12px -12px, -12px 0;
}

.mf-preview-stage img,
.mf-preview-stage canvas {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.mf-preview-stage--canvas {
  padding: 14px;
}

.mf-preview-stage--canvas canvas {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(6, 10, 16, 0.7);
}

.mf-preview-stage--silhouette {
  padding: 14px;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.06), transparent 42%),
    var(--surface-1);
}

.mf-silhouette-frame {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 88%;
  height: 88%;
  max-width: 100%;
  max-height: 100%;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(6, 10, 16, 0.7);
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.mf-silhouette-frame::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 1.5px dashed rgba(var(--accent-rgb), 0.45);
  border-radius: inherit;
  pointer-events: none;
}

.mf-silhouette-frame--round {
  border-radius: var(--radius-pill);
}

.mf-silhouette-frame--rect {
  border-radius: 0;
}

.mf-preview-stage--silhouette img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: contrast(1.06);
}

.mf-preview-placeholder {
  display: grid;
  justify-items: center;
  gap: 8px;
  text-align: center;
  padding: 18px;
}

.mf-preview-note {
  font-size: var(--text-md);
}

.mf-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  text-align: center;
  background: rgba(4, 8, 14, 0.74);
  backdrop-filter: blur(6px);
  color: var(--text);
}

.mf-overlay strong {
  font-size: var(--text-lg);
}

@keyframes mf-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (max-width: 1260px) {
  .mf-shell {
    flex-direction: column;
  }

  .mf-sidebar {
    width: auto;
    min-width: 0;
  }

  .mf-main {
    overflow: visible;
    min-height: auto;
  }

  #mfStepOneContent,
  #mfStepTwoContent,
  .mf-preview-grid {
    flex: none;
    height: auto;
  }

  #mfStepTwoControls {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  #mfStepTwoControls .mf-sidebar-head,
  #mfStepTwoControls .mf-link-btn,
  #mfStepTwoControls .mf-button-grid,
  #mfStepTwoControls #mfGenerateMatrixBtn,
  #mfStepTwoControls #mfGenerateStatus,
  #mfStepTwoControls #mfDownloadGroup,
  #mfStepTwoControls #mfStageTwoErrorCard {
    grid-column: 1 / -1;
  }
}

@media (max-width: 980px) {
  .mf-toolbar,
  .mf-toolbar-main {
    flex-direction: column;
  }

  .mf-stepper,
  .mf-toolbar-side {
    justify-content: flex-start;
  }

  .mf-preview-grid {
    grid-template-columns: 1fr;
  }

  #mfStepOneContent .mf-preview-stage {
    height: clamp(220px, 34vh, 360px);
  }

  #mfStepTwoContent .mf-preview-stage {
    height: clamp(260px, 44vh, 500px);
  }

  #mfStepTwoControls {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .mf-view {
    padding: 14px;
  }

  .mf-toolbar,
  .mf-sidebar,
  .mf-preview-card {
    border-radius: var(--radius-xl);
  }

  .mf-toolbar,
  .mf-sidebar,
  .mf-preview-card {
    padding: 14px;
  }

  .mf-button-grid,
  .mf-toolbar-side {
    flex-direction: column;
  }

  #mfStepTwoControls .mf-field,
  #mfStepTwoControls .mf-control-block,
  #mfStepTwoControls .mf-button-grid {
    padding: 12px 14px;
  }

  .mf-manual-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-height: 860px) {
  #mfStepOneContent .mf-preview-stage {
    height: clamp(210px, 36vh, 340px);
  }

  #mfStepTwoContent .mf-preview-stage {
    height: clamp(250px, 48vh, 460px);
  }
}

/* ═══════════════════════════════════════════════════════════════
   UNIFORMIZAÇÃO v1.0 — Abordagem A
   Vence por ordem de cascade (último bloco do arquivo).
   Força todos os botões/inputs locais às mesmas dimensões.
   ═══════════════════════════════════════════════════════════════ */

.mf-btn,
.mf-mode-btn,
.mf-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  min-height: 40px;
  padding: 0 16px;
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
  border-radius: var(--radius-md);
  white-space: nowrap;
}

.mf-btn--block {
  width: 100%;
}

.mf-select,
.mf-number {
  height: 40px;
  min-height: 40px;
  padding: 0 12px;
  font-size: var(--text-md);
  line-height: 1;
  border-radius: var(--radius-md);
}

.mf-select {
  padding-right: 44px;
}

.mf-step {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 12px;
  font-size: var(--text-2xs);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
  border-radius: var(--radius-pill);
}
