/* ============================================================
   Nexuscred — simulador.css
   Calculadora de financiamento imobiliário
   ============================================================ */

/* ── Wrapper ── */
.nc-simulador {
  background: var(--nc-surface);
  border: 1px solid var(--nc-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  /* Destaque sutil no topo */
  border-top: 3px solid var(--nc-blue);
}

/* ── Header ── */
.nc-simulador__header {
  background: linear-gradient(135deg, var(--nc-blue) 0%, #0050C8 100%);
  padding: var(--space-lg) var(--space-xl);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.nc-simulador__header-icon {
  width: 42px;
  height: 42px;
  background: rgba(255,255,255,.18);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.nc-simulador__header-title {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: #fff;
  line-height: 1.2;
}
.nc-simulador__header-sub {
  font-size: 0.8rem;
  color: rgba(255,255,255,.7);
  margin-top: 2px;
}

/* ── Body ── */
.nc-simulador__body { padding: var(--space-xl); }

/* ── Tabs Price / SAC ── */
.nc-sim-tabs {
  display: flex;
  background: var(--nc-paper);
  border: 1px solid var(--nc-border);
  border-radius: var(--radius-md);
  padding: 3px;
  gap: 3px;
  margin-bottom: var(--space-lg);
}
.nc-sim-tab {
  flex: 1;
  padding: 0.5625rem;
  border-radius: calc(var(--radius-md) - 2px);
  font-size: 0.875rem;
  font-weight: var(--fw-semibold);
  color: var(--nc-ink-light);
  transition: background var(--transition), color var(--transition), box-shadow var(--transition);
  cursor: pointer;
  text-align: center;
  min-height: 38px;
}
.nc-sim-tab.is-active {
  background: var(--nc-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(0,48,135,.25);
}
.nc-sim-tab:not(.is-active):hover {
  background: var(--nc-blue-light);
  color: var(--nc-blue);
}

/* ── Campos ── */
.nc-simulador__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.nc-sim-field { display: flex; flex-direction: column; gap: 6px; }
.nc-sim-field--full { grid-column: 1 / -1; }
.nc-sim-label {
  font-size: 0.8125rem;
  font-weight: var(--fw-semibold);
  color: var(--nc-ink);
}
.nc-sim-label span {
  font-weight: var(--fw-normal);
  color: var(--nc-ink-light);
  font-size: 0.78rem;
}

.nc-sim-input {
  padding: 0.75rem var(--space-md);
  border: 2px solid var(--nc-border);
  border-radius: var(--radius-md);
  font-size: 1rem;
  font-weight: var(--fw-semibold);
  color: var(--nc-ink);
  background: var(--nc-surface);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  width: 100%;
}
.nc-sim-input:hover { border-color: #c5cde8; }
.nc-sim-input:focus,
.nc-sim-input:focus-visible {
  border-color: var(--nc-blue);
  box-shadow: 0 0 0 3px rgba(0,80,200,.12);
  outline: none;
}
.nc-sim-input.has-error { border-color: #DC2626; }
.nc-sim-input.has-error:focus { box-shadow: 0 0 0 3px rgba(220,38,38,.12); }

/* ── Range slider ── */
.nc-sim-range {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: var(--nc-border);
  outline: none;
  cursor: pointer;
  margin-block: var(--space-xs);
}
.nc-sim-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--nc-blue);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(0,48,135,.35);
  cursor: pointer;
  transition: transform .15s;
}
.nc-sim-range::-webkit-slider-thumb:hover { transform: scale(1.15); }
.nc-sim-range::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--nc-blue);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(0,48,135,.35);
  cursor: pointer;
}
.nc-sim-range:focus-visible {
  outline: 3px solid var(--nc-blue-mid);
  outline-offset: 4px;
}

/* Prazo labels */
.nc-sim-prazo-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--nc-ink-light);
  margin-top: 4px;
}
.nc-sim-prazo-labels .nc-sim-prazo-current {
  font-weight: var(--fw-semibold);
  color: var(--nc-blue);
}

/* ── Botão calcular ── */
.nc-simulador__form .nc-btn--primary {
  margin-top: var(--space-sm);
  font-size: 1rem;
  letter-spacing: .01em;
}

/* ── Resultado ── */
.nc-simulador__resultado {
  margin-top: var(--space-lg);
  background: linear-gradient(135deg, #f0f5ff 0%, var(--nc-paper) 100%);
  border: 1px solid #d4e0ff;
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-xl);
  display: none;
}
.nc-simulador__resultado.is-visible { display: block; }

.nc-sim-resultado-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}
.nc-sim-resultado-item {
  text-align: center;
  padding: var(--space-md) var(--space-sm);
  background: #fff;
  border-radius: var(--radius-sm);
  border: 1px solid var(--nc-border);
  /* Impede que valores longos estourem o grid */
  min-width: 0;
  overflow: hidden;
}
.nc-sim-resultado-label {
  font-size: 0.625rem;
  font-weight: var(--fw-semibold);
  color: var(--nc-ink-light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 6px;
  /* Permite quebra se necessário */
  word-break: break-word;
}
.nc-sim-resultado-value {
  /* clamp garante que o valor caiba mesmo sendo longo (ex: R$ 1.197.000,00) */
  font-size: clamp(0.875rem, 2.5vw, 1.25rem);
  font-weight: var(--fw-extrabold);
  color: var(--nc-blue);
  line-height: 1.1;
  word-break: break-all;
}
.nc-sim-resultado-value.is-highlight {
  font-size: clamp(1rem, 3vw, 1.5rem);
  color: var(--nc-green);
}
.nc-sim-resultado-sub {
  font-size: 0.6875rem;
  color: var(--nc-ink-light);
  margin-top: 5px;
  line-height: 1.35;
  word-break: break-word;
}

/* ── Alertas ── */
.nc-sim-alerta {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-md);
  border-radius: var(--radius-sm);
  font-size: 0.8125rem;
  margin-top: var(--space-md);
  line-height: 1.5;
}
.nc-sim-alerta--aviso {
  background: #FEF3C7;
  color: #92400E;
  border: 1px solid #FDE68A;
}
.nc-sim-alerta--ok {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #A7F3D0;
}

/* ── CTAs do resultado ── */
.nc-simulador__cta {
  margin-top: var(--space-lg);
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.nc-simulador__cta .nc-btn { flex: 1; justify-content: center; min-width: 140px; }

/* ── Disclaimer ── */
.nc-simulador__disclaimer {
  font-size: 0.72rem;
  color: var(--nc-ink-light);
  margin-top: var(--space-md);
  line-height: 1.55;
  opacity: .8;
}

/* ── Tabela comparativa de bancos ── */
.nc-sim-comparativo {
  margin-top: var(--space-xl);
  border: 1px solid var(--nc-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.nc-sim-comparativo-title {
  background: var(--nc-paper);
  padding: var(--space-md) var(--space-lg);
  font-size: 0.875rem;
  font-weight: var(--fw-bold);
  color: var(--nc-ink);
  border-bottom: 1px solid var(--nc-border);
}
.nc-sim-comparativo-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.nc-sim-comparativo-table th {
  background: var(--nc-paper);
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  font-size: 0.75rem;
  font-weight: var(--fw-semibold);
  color: var(--nc-ink-light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.nc-sim-comparativo-table td {
  padding: var(--space-sm) var(--space-md);
  border-top: 1px solid var(--nc-border);
  color: var(--nc-ink);
}
.nc-sim-comparativo-table tr:hover td { background: var(--nc-paper); }
.nc-sim-banco-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}

/* ── Responsivo ── */
@media (max-width: 640px) {
  .nc-simulador__fields      { grid-template-columns: 1fr; }
  .nc-sim-resultado-grid     { grid-template-columns: 1fr; }
  .nc-simulador__cta         { flex-direction: column; }
  .nc-simulador__body        { padding: var(--space-lg); }
}
