/* =============================================================
   DIAGNÓSTICO, estilos da página de conversão
   ============================================================= */

/* -----------------------------------------------------------
   1. HERO da página
   ----------------------------------------------------------- */

.diag-hero {
  position: relative;
  padding-block: clamp(var(--space-2xl), 6vw + 1rem, var(--space-4xl)) var(--section-py);
  background: var(--bg-primary);
  overflow: hidden;
}
.diag-hero__bg {
  position: absolute;
  inset: 0;
  background-image: url('../../assets/logos/obp-simbolo-branco.png');
  background-repeat: no-repeat;
  background-position: right -8% center;
  background-size: 60vmin;
  opacity: 0.04;
  pointer-events: none;
}

/* -----------------------------------------------------------
   2. Layout em 2 colunas (promessa + form)
   ----------------------------------------------------------- */

.diag-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--space-2xl);
  align-items: start;
}
@media (max-width: 1023px) {
  .diag-grid { grid-template-columns: 1fr; gap: var(--space-xl); }
}

/* -----------------------------------------------------------
   3. Coluna da promessa
   ----------------------------------------------------------- */

.diag-promise__title {
  font-size: clamp(2.25rem, 1.6rem + 3.5vw, 4rem);
  font-weight: var(--fw-light);
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--text-primary);
}
.diag-promise__title strong {
  font-weight: var(--fw-semibold);
  color: var(--text-brand);
}

.diag-promise__lead {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--text-secondary);
  margin-top: var(--space-lg);
  max-width: 50ch;
}

.diag-promise__list {
  list-style: none;
  padding: 0;
  margin: var(--space-xl) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.diag-promise__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  font-size: var(--fs-body);
  color: var(--text-primary);
  line-height: var(--lh-relaxed);
}

.diag-promise__num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--action-primary);
  color: var(--action-primary-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  margin-top: 2px;
}

.diag-promise__item strong {
  display: block;
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
  margin-bottom: 2px;
}
.diag-promise__item span {
  color: var(--text-secondary);
  font-size: var(--fs-caption);
  line-height: var(--lh-snug);
}

.diag-promise__badges {
  margin-top: var(--space-2xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.diag-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  padding: var(--space-xs) var(--space-md);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--text-secondary);
}
.diag-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--action-primary);
}

/* -----------------------------------------------------------
   4. Formulário
   ----------------------------------------------------------- */

.diag-form {
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  position: sticky;
  top: 96px;
}

@media (max-width: 1023px) {
  .diag-form { position: static; }
}

.diag-form__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-2xs);
}
.diag-form__sub {
  font-size: var(--fs-caption);
  color: var(--text-muted);
  margin-bottom: var(--space-lg);
}

.diag-field {
  margin-bottom: var(--space-md);
}

.diag-field--grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}
@media (max-width: 540px) {
  .diag-field--grid { grid-template-columns: 1fr; }
}

.diag-field__label {
  display: block;
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--text-secondary);
  margin-bottom: var(--space-2xs);
  letter-spacing: var(--ls-tight);
}
.diag-field__label .required {
  color: var(--text-brand);
  margin-left: 2px;
}

.diag-input,
.diag-select,
.diag-textarea {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: var(--fw-regular);
  transition: border-color var(--motion-fast) var(--ease-out), background-color var(--motion-fast) var(--ease-out);
}

.diag-input::placeholder,
.diag-textarea::placeholder {
  color: var(--color-cinza-500);
  opacity: 1;
}

.diag-input:hover,
.diag-select:hover,
.diag-textarea:hover {
  border-color: var(--color-cinza-500);
}

.diag-input:focus,
.diag-select:focus,
.diag-textarea:focus {
  outline: none;
  border-color: var(--action-primary);
  background-color: var(--bg-elevated);
}

.diag-input:invalid:not(:placeholder-shown),
.diag-select:invalid:not(:placeholder-shown) {
  border-color: rgba(255, 82, 0, 0.5);
}

.diag-textarea {
  min-height: 96px;
  resize: vertical;
  line-height: var(--lh-relaxed);
}

.diag-select {
  appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3e%3cpath d='M3 5l3 3 3-3' stroke='%23878787' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right var(--space-md) center;
  padding-right: var(--space-xl);
  cursor: pointer;
}

.diag-submit {
  width: 100%;
  margin-top: var(--space-md);
  padding: var(--space-md) var(--space-xl);
  background: var(--action-primary);
  color: var(--action-primary-text);
  border: 0;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: background-color var(--motion-fast) var(--ease-out), transform var(--motion-fast) var(--ease-out), box-shadow var(--motion-base) var(--ease-out);
}
.diag-submit:hover {
  background: var(--action-primary-hover);
  transform: translateY(-1px);
  box-shadow: var(--shadow-glow-orange);
}
.diag-submit:active { transform: translateY(0); }

.diag-form__legal {
  font-size: var(--fs-caption);
  color: var(--text-muted);
  margin-top: var(--space-md);
  line-height: var(--lh-snug);
}
.diag-form__legal a {
  color: var(--text-secondary);
  text-decoration: underline;
}
.diag-form__legal a:hover { color: var(--text-brand); }

/* -----------------------------------------------------------
   5. SEÇÃO "O que esperar"
   ----------------------------------------------------------- */

.diag-expect {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
}

.diag-expect__step {
  position: relative;
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}
.diag-expect__step-num {
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  color: var(--text-brand);
  letter-spacing: var(--ls-wide);
  font-weight: var(--fw-medium);
}
.diag-expect__step-title {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
  margin-top: var(--space-sm);
  line-height: var(--lh-snug);
}
.diag-expect__step-desc {
  font-size: var(--fs-body);
  color: var(--text-secondary);
  line-height: var(--lh-relaxed);
  margin-top: var(--space-sm);
}

/* -----------------------------------------------------------
   6. PÁGINA DE OBRIGADO
   ----------------------------------------------------------- */

.thanks {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: var(--section-py);
  position: relative;
  overflow: hidden;
}
.thanks__bg {
  position: absolute;
  inset: 0;
  background-image: url('../../assets/logos/obp-simbolo-branco.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 80vmin;
  opacity: 0.04;
  pointer-events: none;
}
.thanks__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin-inline: auto;
}
.thanks__check {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--action-primary);
  color: var(--action-primary-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-lg);
}
.thanks__title {
  font-size: clamp(2rem, 1.4rem + 3vw, 3.5rem);
  font-weight: var(--fw-light);
  line-height: var(--lh-tight);
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.thanks__title strong {
  font-weight: var(--fw-semibold);
  color: var(--text-brand);
}
.thanks__body {
  font-size: var(--fs-body-lg);
  color: var(--text-secondary);
  margin-top: var(--space-md);
  line-height: var(--lh-relaxed);
}
.thanks__cta {
  margin-top: var(--space-xl);
  display: inline-flex;
  gap: var(--space-md);
}
