/* ══════════════════════════════════════════════════════
   IA CRIAR OBRA — Wizard CSS
   3 etapas: Upload → Processando → Revisão → Criando
   ══════════════════════════════════════════════════════ */

/* Igual #view-nova-obra: flex:1, overflow hidden, sem height fixo */
#view-ia-contrato-obra {
  flex: 1;
  display: none;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg);
}
#view-ia-contrato-obra.active {
  display: flex;
}

/* ─── Topbar ─── */
.iac-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px 12px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
  background: var(--bg);
}
.iac-topbar-title {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.iac-topbar-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 20px;
  background: rgba(74, 127, 212, .14);
  color: #7eb3f7;
  border: 1px solid rgba(74, 127, 212, .25);
  letter-spacing: .3px;
}

/* ─── Scrollable body ─── */
.iac-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* ══════════════════════════════════════════
   STEP 1 — UPLOAD
   ══════════════════════════════════════════ */
.iac-upload-wrap {
  max-width: 520px;
  margin: 32px auto;
  padding: 0 20px;
}
.iac-upload-hero {
  text-align: center;
  margin-bottom: 28px;
}
.iac-upload-icon {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(74,127,212,.18), rgba(139,92,246,.18));
  border: 1px solid rgba(74,127,212,.28);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
}
.iac-upload-icon svg {
  width: 30px;
  height: 30px;
  stroke: #7eb3f7;
}
.iac-upload-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}
.iac-upload-sub {
  font-size: 13px;
  color: var(--text-dim);
  line-height: 1.5;
}

.iac-dropzone {
  border: 2px dashed rgba(74,127,212,.35);
  border-radius: 16px;
  padding: 40px 24px;
  text-align: center;
  cursor: pointer;
  background: rgba(74,127,212,.04);
  transition: border-color .2s, background .2s;
  position: relative;
}
.iac-dropzone:hover,
.iac-dropzone.drag-over {
  border-color: #4a7fd4;
  background: rgba(74,127,212,.09);
}
.iac-dropzone input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.iac-dropzone-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 12px;
  color: var(--text-dim);
}
.iac-dropzone-txt {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-sub);
  margin-bottom: 6px;
}
.iac-dropzone-hint {
  font-size: 12px;
  color: var(--text-dim);
}

/* File preview pill */
.iac-file-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 12px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  margin-top: 14px;
}
.iac-file-pill-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(74,127,212,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.iac-file-pill-icon svg { width: 18px; height: 18px; stroke: #7eb3f7; }
.iac-file-pill-info { flex: 1; min-width: 0; }
.iac-file-pill-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.iac-file-pill-size {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 2px;
}
.iac-file-pill-remove {
  background: none;
  border: none;
  color: var(--text-dim);
  cursor: pointer;
  padding: 4px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  transition: color .15s, background .15s;
}
.iac-file-pill-remove:hover { color: var(--red); background: rgba(239,68,68,.1); }

.iac-btn-upload {
  width: 100%;
  padding: 14px;
  border-radius: 12px;
  background: #4a7fd4;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  margin-top: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background .2s, opacity .2s;
}
.iac-btn-upload:hover { background: #3a6fc4; }
.iac-btn-upload:disabled { opacity: .4; cursor: not-allowed; }
.iac-btn-upload .spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: none;
}
.iac-btn-upload.loading .spinner { display: block; }
.iac-btn-upload.loading .btn-txt { display: none; }

/* ══════════════════════════════════════════
   STEP 2 — PROCESSANDO
   ══════════════════════════════════════════ */
.iac-processing-wrap {
  max-width: 480px;
  margin: 40px auto;
  padding: 0 20px;
}
.iac-proc-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  padding: 28px 24px;
}
.iac-proc-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.iac-proc-sub {
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 22px;
}
.iac-proc-steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.iac-proc-step {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255,255,255,.03);
  border: 1px solid transparent;
  transition: border-color .3s, background .3s;
}
.iac-proc-step.active {
  border-color: rgba(74,127,212,.3);
  background: rgba(74,127,212,.07);
}
.iac-proc-step.done {
  border-color: rgba(34,197,94,.2);
  background: rgba(34,197,94,.05);
}
.iac-proc-step.error {
  border-color: rgba(239,68,68,.3);
  background: rgba(239,68,68,.07);
}
.iac-proc-step-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
  background: rgba(255,255,255,.05);
}
.iac-proc-step.active .iac-proc-step-icon { background: rgba(74,127,212,.2); }
.iac-proc-step.done  .iac-proc-step-icon { background: rgba(34,197,94,.2); }
.iac-proc-step.error .iac-proc-step-icon { background: rgba(239,68,68,.18); }
.iac-proc-step-label {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-sub);
}
.iac-proc-step.active .iac-proc-step-label,
.iac-proc-step.done  .iac-proc-step-label { color: var(--text); }
.iac-proc-step-status {
  font-size: 11px;
  color: var(--text-dim);
}
.iac-proc-step.active .iac-proc-step-status { color: #7eb3f7; }
.iac-proc-step.done  .iac-proc-step-status { color: #4ade80; }
.iac-proc-step.error .iac-proc-step-status { color: #f87171; }

/* Spinning indicator for active step */
.iac-step-spin {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(74,127,212,.3);
  border-top-color: #7eb3f7;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: inline-block;
  flex-shrink: 0;
}

/* Error state */
.iac-proc-error-box {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(239,68,68,.08);
  border: 1px solid rgba(239,68,68,.25);
  font-size: 12px;
  color: #f87171;
  line-height: 1.5;
}
.iac-proc-retry {
  margin-top: 10px;
  background: none;
  border: 1px solid rgba(239,68,68,.35);
  color: #f87171;
  border-radius: 8px;
  padding: 7px 14px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}
.iac-proc-retry:hover { background: rgba(239,68,68,.1); }

/* ══════════════════════════════════════════
   STEP 3 — REVISÃO  (arquitetura wizard, single-column centrado)
   Espelha o padrão nova-obra / novo-cliente.
   ══════════════════════════════════════════ */
.iac-review-wrap {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  width: 100%;
}

/* Tabs mobile — collapsible panel sections on mobile */
.iac-review-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
}
.iac-review-title {
  flex: 1;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.iac-review-hints {
  display: flex;
  gap: 10px;
  font-size: 11px;
}
.iac-hint { display: flex; align-items: center; gap: 4px; color: var(--text-dim); }
.iac-hint-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.iac-hint-dot.green  { background: #4ade80; }
.iac-hint-dot.yellow { background: #fbbf24; }
.iac-hint-dot.red    { background: #f87171; }

/* Body — single column scroller, centra o form na tela inteira */
.iac-review-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
.iac-review-left { display: none !important; }
.iac-raw-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text-dim);
  margin-bottom: 10px;
}
.iac-raw-text {
  font-size: 11px;
  line-height: 1.7;
  color: var(--text-sub);
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, 'Cascadia Code', monospace;
}

/* Form column — centrado, max-width tipo wizard nova-obra mas mais largo
   pois tem múltiplas seções complexas (cliente + obra + serviços) */
.iac-review-right {
  width: 100%;
  max-width: 760px;
  padding: 24px clamp(16px, 4vw, 32px) 32px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Cabeçalho — barra full-width, conteúdo centrado em 760px */
.iac-review-header {
  width: 100%;
  flex-shrink: 0;
}

/* Score bar e wrap ficam full-width naturalmente (filhos diretos do wrap) */

/* Footer — barra sticky full-width, botões agrupados centrados */
.iac-review-footer {
  flex-shrink: 0;
  width: 100%;
  background: rgba(6,9,19,.96);
  backdrop-filter: blur(8px);
  border-top: 1px solid var(--glass-border);
  padding: 12px clamp(16px, 4vw, 32px);
  display: flex;
  justify-content: center;
  gap: 12px;
}
.iac-review-footer .iac-btn-back,
.iac-review-footer .iac-btn-criar { flex: 1; max-width: 320px; }

/* Texto extraído colapsável (substitui split panel) */
.iac-raw-details {
  margin-top: 32px;
  border-top: 1px dashed var(--glass-border);
  padding-top: 16px;
}
.iac-raw-details > summary {
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: .6px;
  padding: 8px 0;
  list-style: none;
}
.iac-raw-details > summary::-webkit-details-marker { display: none; }
.iac-raw-details > summary::before {
  content: '▸ ';
  display: inline-block;
  transition: transform .2s;
  margin-right: 4px;
}
.iac-raw-details[open] > summary::before { transform: rotate(90deg); }
.iac-raw-details[open] > summary { color: var(--text); }

/* Fullscreen mode: garante que IA Criar Obra ocupe 100% sem sidebar */
.iac-fullscreen #view-ia-contrato-obra { width: 100%; flex: 1; min-width: 0; }
.iac-fullscreen .app-content { width: 100%; max-width: 100%; flex: 1; }

/* Section headers */
.iac-section {
  margin-bottom: 20px;
}
.iac-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 12px;
  cursor: pointer;
  user-select: none;
}
.iac-section-title {
  flex: 1;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text-sub);
}
.iac-section-toggle {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-dim);
  transition: transform .2s;
}
.iac-section.collapsed .iac-section-toggle { transform: rotate(-90deg); }
.iac-section.collapsed .iac-section-fields { display: none; }

/* Fields */
.iac-field {
  margin-bottom: 10px;
  position: relative;
}
.iac-field-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.iac-field-label .req { color: var(--red); }
.iac-field-conf {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.iac-field-conf.green  { background: #4ade80; }
.iac-field-conf.yellow { background: #fbbf24; }
.iac-field-conf.red    { background: #f87171; box-shadow: 0 0 0 3px rgba(248,113,113,.2); }
.iac-field-conf.gray   { background: var(--text-dim); }

.iac-input,
.iac-select,
.iac-textarea {
  width: 100%;
  box-sizing: border-box;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 9px 12px;
  font-size: 13px;
  color: var(--text);
  font-family: var(--font);
  transition: border-color .15s;
  -webkit-appearance: none;
  appearance: none;
}
.iac-input:focus,
.iac-select:focus,
.iac-textarea:focus {
  outline: none;
  border-color: #4a7fd4;
  background: rgba(74,127,212,.07);
}
.iac-input.missing,
.iac-select.missing {
  border-color: rgba(248,113,113,.5);
  background: rgba(248,113,113,.06);
}
.iac-input.missing:focus { border-color: #f87171; }
.iac-textarea { resize: vertical; min-height: 64px; line-height: 1.5; }
.iac-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; padding-right: 28px; }

/* Row layout for 2-col fields */
.iac-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.iac-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
@media (max-width: 480px) {
  .iac-row, .iac-row-3 { grid-template-columns: 1fr; }
}

/* Serviços list */
.iac-servico-card {
  background: rgba(255,255,255,.025);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 14px;
}
.iac-servico-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  cursor: pointer;
}
.iac-servico-num {
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  background: rgba(74,127,212,.16);
  color: #7eb3f7;
  flex-shrink: 0;
}
.iac-servico-title {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.iac-servico-toggle {
  color: var(--text-dim);
  transition: transform .2s;
}
.iac-servico-card.collapsed .iac-servico-toggle { transform: rotate(-90deg); }
.iac-servico-card.collapsed .iac-servico-body { display: none; }

/* Sub-items: especificações / materiais / equipamentos */
.iac-sub-list {
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.iac-sub-list-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-dim);
  margin-bottom: 8px;
}
.iac-sub-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.iac-sub-item:last-child { border-bottom: none; }
.iac-sub-item-idx {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-dim);
  padding-top: 2px;
  min-width: 16px;
  flex-shrink: 0;
}
.iac-sub-item-input {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 2px 4px 4px;
  font-size: 12px;
  color: var(--text);
  font-family: var(--font);
  min-width: 0;
  transition: border-color .15s;
}
.iac-sub-item-input:focus {
  outline: none;
  border-bottom-color: #4a7fd4;
}
.iac-sub-item-remove {
  background: none;
  border: none;
  color: var(--text-dim);
  cursor: pointer;
  padding: 2px;
  border-radius: 4px;
  line-height: 1;
  font-size: 16px;
  transition: color .15s;
  flex-shrink: 0;
}
.iac-sub-item-remove:hover { color: #f87171; }
.iac-add-btn {
  background: none;
  border: 1px dashed rgba(74,127,212,.3);
  color: #7eb3f7;
  border-radius: 7px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 8px;
  width: 100%;
  transition: background .15s, border-color .15s;
}
.iac-add-btn:hover { background: rgba(74,127,212,.08); border-color: rgba(74,127,212,.5); }

/* Client found badge */
.iac-client-found {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(34,197,94,.08);
  border: 1px solid rgba(34,197,94,.2);
  color: #4ade80;
  margin-bottom: 10px;
}
.iac-client-new {
  background: rgba(251,191,36,.07);
  border-color: rgba(251,191,36,.22);
  color: #fbbf24;
}

/* ─── Review footer ─── */
.iac-review-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 14px 20px;
  background: var(--bg);
  border-top: 1px solid var(--glass-border);
  display: flex;
  gap: 10px;
  z-index: 200;
}
@media (min-width: 600px) {
  .iac-review-footer {
    position: sticky;
    bottom: 0;
  }
}
.iac-btn-back {
  padding: 12px 18px;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: transparent;
  color: var(--text-sub);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}
.iac-btn-back:hover { background: var(--glass); }
.iac-btn-criar {
  flex: 1;
  padding: 13px;
  border-radius: 12px;
  background: #4a7fd4;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background .2s, opacity .2s;
}
.iac-btn-criar:hover { background: #3a6fc4; }
.iac-btn-criar:disabled { opacity: .4; cursor: not-allowed; }
.iac-btn-criar .spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: none;
}
.iac-btn-criar.loading .spinner { display: block; }
.iac-btn-criar.loading .btn-txt { display: none; }

/* ══════════════════════════════════════════
   STEP 4 — CRIANDO (progress)
   ══════════════════════════════════════════ */
.iac-creating-wrap {
  max-width: 440px;
  margin: 48px auto;
  padding: 0 20px;
}
.iac-creating-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
}
.iac-creating-icon {
  width: 56px; height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(74,127,212,.2), rgba(139,92,246,.2));
  border: 1px solid rgba(74,127,212,.28);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
}
.iac-creating-icon svg { width: 26px; height: 26px; stroke: #7eb3f7; }
.iac-creating-title {
  font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 4px;
}
.iac-creating-sub {
  font-size: 12px; color: var(--text-dim); margin-bottom: 22px;
}
.iac-create-steps { display: flex; flex-direction: column; gap: 8px; }
.iac-create-step {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-sub); padding: 6px 0;
}
.iac-create-step-icon {
  width: 22px; height: 22px; flex-shrink: 0;
  font-size: 13px; text-align: center;
}
.iac-create-step.done { color: #4ade80; }
.iac-create-step.active { color: var(--text); font-weight: 600; }

/* ─── Success banner ─── */
.iac-success-card {
  background: var(--glass);
  border: 1px solid rgba(34,197,94,.25);
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
}
.iac-success-icon {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(34,197,94,.12);
  border: 1px solid rgba(34,197,94,.3);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
}
.iac-success-icon svg { width: 26px; height: 26px; stroke: #4ade80; }
.iac-success-title { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.iac-success-sub   { font-size: 13px; color: var(--text-dim); margin-bottom: 20px; }
.iac-btn-go-obra {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px; border-radius: 12px;
  background: #4a7fd4; color: #fff; font-size: 14px; font-weight: 700;
  border: none; cursor: pointer; transition: background .2s;
  text-decoration: none;
}
.iac-btn-go-obra:hover { background: #3a6fc4; }
.iac-btn-nova {
  margin-top: 12px; display: block; width: 100%; padding: 11px;
  border-radius: 12px; border: 1px solid var(--glass-border);
  background: transparent; color: var(--text-sub); font-size: 13px;
  font-weight: 600; cursor: pointer; transition: background .15s;
}
.iac-btn-nova:hover { background: var(--glass); }

/* ─── Shared animation ─── */
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ══════════════════════════════════════════
   SCORE BAR DE COMPLETUDE
   ══════════════════════════════════════════ */
.iac-score-bar-wrap {
  margin: 0;
  padding: 10px 20px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
  background: rgba(255,255,255,.02);
}
.iac-score-bar-wrap.green  { background: rgba(34,197,94,.04);  }
.iac-score-bar-wrap.yellow { background: rgba(251,191,36,.04); }
.iac-score-bar-wrap.red    { background: rgba(239,68,68,.04);  }

.iac-score-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.iac-score-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  white-space: nowrap;
}
.iac-score-blocks {
  display: flex;
  gap: 3px;
  flex: 1;
}
.iac-score-block {
  height: 6px;
  flex: 1;
  border-radius: 3px;
  background: rgba(255,255,255,.08);
  transition: background .3s;
}
.iac-score-bar-wrap.green  .iac-score-block.filled { background: #4ade80; }
.iac-score-bar-wrap.yellow .iac-score-block.filled { background: #fbbf24; }
.iac-score-bar-wrap.red    .iac-score-block.filled { background: #f87171; }

.iac-score-pct {
  font-size: 12px;
  font-weight: 700;
  min-width: 34px;
  text-align: right;
}
.iac-score-bar-wrap.green  .iac-score-pct { color: #4ade80; }
.iac-score-bar-wrap.yellow .iac-score-pct { color: #fbbf24; }
.iac-score-bar-wrap.red    .iac-score-pct { color: #f87171; }

.iac-score-faltando {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  margin-top: 7px;
}
.iac-score-faltando-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-dim);
}
.iac-score-tag {
  font-size: 10px;
  font-weight: 500;
  padding: 2px 7px;
  border-radius: 20px;
  background: rgba(251,191,36,.12);
  border: 1px solid rgba(251,191,36,.25);
  color: #fbbf24;
}

/* ══════════════════════════════════════════
   ETAPAS TÉCNICAS — editor
   ══════════════════════════════════════════ */
.iac-etapas-list {
  margin-top: 8px;
}
.iac-sub-list-label svg {
  vertical-align: middle;
  margin-right: 2px;
  opacity: .7;
}
.iac-etapa-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.iac-etapa-item:last-of-type { border-bottom: none; }
.iac-etapa-num {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  border-radius: 6px;
  background: rgba(74,127,212,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: #7eb3f7;
  margin-top: 2px;
}
.iac-etapa-fields {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.iac-etapa-titulo {
  font-size: 12px;
  font-weight: 600;
}
.iac-etapa-desc {
  font-size: 11px;
  line-height: 1.5;
  resize: vertical;
  min-height: 40px;
  max-height: 120px;
}

/* ══════════════════════════════════════════
   MISC EXTRAS
   ══════════════════════════════════════════ */

/* Textarea menor para mapa */
.iac-textarea-sm {
  min-height: 48px;
  max-height: 100px;
}

/* Tag "opcional" ao lado do título de seção */
.iac-optional-tag {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 20px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text-dim);
  letter-spacing: .3px;
  text-transform: lowercase;
  margin-left: 4px;
  vertical-align: middle;
}

/* ══════════════════════════════════════════
   V4 — MATCH CARDS (vincular/criar/aditivar)
   ══════════════════════════════════════════ */

.iac-match-wrap {
  margin: 0 0 18px 0;
  padding: 14px;
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(74,127,212,.07), rgba(74,127,212,.02));
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Versão compacta: nada para vincular/aditivar */
.iac-match-compact {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px 0;
  padding: 10px 14px;
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  background: rgba(74,127,212,.06);
  font-size: 12px;
  color: var(--text-sub);
  line-height: 1.5;
}
.iac-match-compact-icon {
  font-size: 14px;
  flex-shrink: 0;
}
.iac-match-compact-text strong {
  color: var(--text);
  font-weight: 700;
}

.iac-match-header {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.iac-match-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .2px;
}
.iac-match-sub {
  font-size: 11px;
  color: var(--text-dim);
  line-height: 1.4;
}

.iac-match-card {
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  background: var(--bg);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.iac-match-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 6px;
  border-bottom: 1px dashed var(--glass-border);
}
.iac-match-card-icon {
  font-size: 14px;
}
.iac-match-card-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .4px;
}

.iac-match-options {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.iac-match-option {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  cursor: pointer;
  background: rgba(255,255,255,.02);
  transition: border-color .15s, background .15s, box-shadow .15s;
}
.iac-match-option:hover {
  border-color: rgba(74,127,212,.45);
  background: rgba(74,127,212,.05);
}
.iac-match-option.is-selected {
  border-color: #4a7fd4;
  background: rgba(74,127,212,.12);
  box-shadow: inset 0 0 0 1px rgba(74,127,212,.35);
}
.iac-match-option input[type="radio"] {
  margin: 2px 0 0 0;
  accent-color: #4a7fd4;
  flex-shrink: 0;
}
.iac-match-option-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.iac-match-option-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.35;
  word-break: break-word;
}
.iac-match-option-sub {
  font-size: 11px;
  color: var(--text-dim);
  line-height: 1.4;
}

.iac-match-conf {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
  letter-spacing: .3px;
  flex-shrink: 0;
  align-self: flex-start;
}
.iac-match-conf.high {
  background: rgba(46, 160, 67, .18);
  color: #4acf6f;
  border: 1px solid rgba(46, 160, 67, .35);
}
.iac-match-conf.mid {
  background: rgba(227, 167, 41, .18);
  color: #ecc36b;
  border: 1px solid rgba(227, 167, 41, .35);
}
.iac-match-conf.low {
  background: rgba(207, 74, 74, .15);
  color: #e88686;
  border: 1px solid rgba(207, 74, 74, .3);
}

.iac-match-servico-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 0;
  border-top: 1px dashed var(--glass-border);
}
.iac-match-servico-row:first-of-type {
  border-top: none;
  padding-top: 0;
}
.iac-match-servico-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .2px;
}

/* Autocomplete dropdown (overrides mínimas sobre inline styles de autocomplete.js) */
.iac-autocomplete-dropdown {
  color: var(--text, #1a1a1a);
  font-family: inherit;
}
.iac-autocomplete-item:last-child {
  border-bottom: none !important;
}
