.elementor-1563 .elementor-element.elementor-element-7398c29a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:2%;--padding-bottom:2%;--padding-left:0%;--padding-right:0%;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-1563 .elementor-element.elementor-element-640f52a{border-radius:10px 10px 10px 10px;}.elementor-1563 .elementor-element.elementor-element-715335f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:30px 0px;--row-gap:30px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0vw;--padding-bottom:5vw;--padding-left:0vw;--padding-right:0vw;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-1563 .elementor-element.elementor-element-fb9d32a{text-align:center;}.elementor-widget-form .elementor-field-group > label, .elementor-widget-form .elementor-field-subgroup label{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group > label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-type-html{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-group .elementor-field{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group .elementor-field, .elementor-widget-form .elementor-field-subgroup label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-button{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form .e-form__buttons__wrapper__button-next{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-button[type="submit"]{background-color:var( --e-global-color-accent );}.elementor-widget-form .e-form__buttons__wrapper__button-previous{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-message{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .e-form__indicators__indicator, .elementor-widget-form .e-form__indicators__indicator__label{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form{--e-form-steps-indicator-inactive-primary-color:var( --e-global-color-text );--e-form-steps-indicator-active-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-completed-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-background-color:var( --e-global-color-text );--e-form-steps-indicator-progress-meter-color:var( --e-global-color-text );}.elementor-widget-form .e-form__indicators__indicator__progress__meter{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-type-html{padding-bottom:0px;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .e-form__buttons__wrapper__button-next{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-button[type="submit"]{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .e-form__buttons__wrapper__button-next:hover{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-button[type="submit"]:hover{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-1563 .elementor-element.elementor-element-7f8fb70 .elementor-message{font-family:"Inter", Sans-serif;font-weight:400;}.elementor-1563 .elementor-element.elementor-element-7f8fb70{--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-icon-size:15px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}.elementor-1563 .elementor-element.elementor-element-411603cc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(max-width:767px){.elementor-1563 .elementor-element.elementor-element-7398c29a{--padding-top:0%;--padding-bottom:0%;--padding-left:0%;--padding-right:0%;}.elementor-1563 .elementor-element.elementor-element-715335f{--padding-top:7vw;--padding-bottom:12vw;--padding-left:4vw;--padding-right:4vw;}}@media(min-width:768px){.elementor-1563 .elementor-element.elementor-element-7398c29a{--content-width:35%;}.elementor-1563 .elementor-element.elementor-element-715335f{--content-width:35%;}}@media(max-width:1024px) and (min-width:768px){.elementor-1563 .elementor-element.elementor-element-7398c29a{--content-width:80%;}.elementor-1563 .elementor-element.elementor-element-715335f{--content-width:80%;}}/* Start custom CSS for html, class: .elementor-element-4c08f598 *//* =====================================================
   RESET / TIPOGRAFIA BASE
   ===================================================== */
html {
    font-size: 62.5% !important;
}

body {
    font-family: 'Roboto', sans-serif !important;
    background-color: #fcfcfc;
    color: #121212;
}

/* =====================================================
   CARTÃO BRANCO (ALVO: .elementor-element-7f8fb70)
   - Este bloco cria o fundo branco, sombra, padding
   - Mantém tudo dentro do cartão e é responsivo
   ===================================================== */
.elementor-element-7f8fb70 .elementor-form {
  background: #ffffff;
  border-radius: 16px;
  padding: 3.2rem;                 /* 32px */
  box-shadow: 0 10px 30px rgba(18,18,18,0.06);
  border: 1px solid #f0f0f0;
  max-width: 920px;
  box-sizing: border-box;
  transition: transform .15s ease, box-shadow .15s ease;
}

/* Evita "blocos brancos" internos (mantém o visual limpo do cartão) */
.elementor-element-7f8fb70 .elementor-form .elementor-form-fields-wrapper,
.elementor-element-7f8fb70 .elementor-form .e-form__indicators {
  background: transparent !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

/* Ajustes de espaçamento das colunas dentro do cartão */
.elementor-element-7f8fb70 .elementor-column {
  padding-left: 0;
  padding-right: 0;
}

/* Subtítulos / descrições (opcional) */
.elementor-element-7f8fb70 .subtitulo {
  display: block;
  margin: 0 0 1.2rem 0;
  font-size: 1.6rem;
  color: #444;
}

/* Botões e wrapper de botões dentro do cartão */
.elementor-element-7f8fb70 .e-form__buttons {
  display: flex;
  gap: 1.2rem;
  justify-content: flex-end;
  align-items: center;
  margin-top: 1.6rem;
}

.elementor-element-7f8fb70 .elementor-button {
  min-width: 12rem;
}

/* Interação hover sutil do cartão */
.elementor-element-7f8fb70 .elementor-form:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(18,18,18,0.07);
}

/* Foco acessível para inputs dentro do cartão */
.elementor-element-7f8fb70 .elementor-field-textual:focus,
.elementor-element-7f8fb70 textarea:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(255,193,7,0.12);
  border-color: #ffc107;
}

/* RESPONSIVO (melhorias para mobile / toca mais as extremidades do telefone) */
/* RESPONSIVO (melhorias para mobile / toca mais as extremidades do telefone) */
/* RESPONSIVO (melhorias para mobile / toca mais as extremidades do telefone) */
/* RESPONSIVO (melhorias para mobile / toca mais as extremidades do telefone) */
/* RESPONSIVO (melhorias para mobile / toca mais as extremidades do telefone) */


@media (max-width: 768px) {

  /* Caixa principal: menos margin, padding reduzido para "encostar" mais nas bordas */
  .elementor-element-7f8fb70 .elementor-form {
    padding: 1.8rem;             /* 14px padding interno */
    margin: 0rem;              /* margem pequena nas laterais para 'encostar' mais */
    border-radius: 12px;
    box-shadow: 0 6px 20px rgba(18,18,18,0.05);
  }

  /* Indicadores (steps): reduzir padding e borda para caber melhor no celular */
  .elementor-form .e-form__indicators {
    margin-bottom: 1rem !important;
    padding: 0.9rem 0.9rem !important;
    border-radius: 10px !important;
    background: transparent !important; /* dentro do cartão já temos fundo branco */
    box-shadow: none !important;
    border: none !important;
  }

  .elementor-form .e-form__indicators__indicator__label {
    font-size: 1.4rem !important;
  }

  .elementor-form .e-form__indicators__indicator__number {
    width: 34px !important;
    height: 34px !important;
    font-size: 1.4rem !important;
  }

  /* Campos de formulário: ajustar padding para o mobile */
  .elementor-field-textual {
    padding: 12px 14px !important;
    font-size: 1.6rem !important;
  }

  /* Reduz espaçamento entre linhas de opções (radio/checkbox) para caber melhor */
  .elementor-field-option {
    margin-bottom: 0.9rem !important;
  }

  .elementor-field-option label {
    font-size: 1.5rem !important;
    padding-left: 10px !important;
  }

  /* Botões: empilhar, largura total e padding reduzido */
  .elementor-element-7f8fb70 .e-form__buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 0.8rem;
    margin-top: 1rem;
  }

  .elementor-element-7f8fb70 .elementor-button,
  .elementor-element-7f8fb70 .e-form__buttons .e-form__buttons__wrapper__button--next,
  .elementor-element-7f8fb70 .e-form__buttons .e-form__buttons__wrapper__button--previous {
    width: 100% !important;
    padding: 12px 14px !important;
    font-size: 1.6rem !important;
    min-width: 0;
  }

  /* Upload field - reduzir gaps e ajustar botão do file .elementor-1563 .elementor-element.elementor-element-4c08f598 */
  .elementor-field-type-upload input[type="file"] {
    padding: 9px 10px !important;
    font-size: 1.4rem !important;
  }

  .elementor-field-type-upload input[type="file"]::file-.elementor-1563 .elementor-element.elementor-element-4c08f598-button {
    padding: 8px 12px !important;
    margin-right: 10px !important;
  }

  /* Ícones / tamanhos menores em mobile */
  .e-font-icon-svg {
    width: 18px !important;
    height: 18px !important;
  }

  /* Ajuste extra: reduzir gap geral entre campos para usar melhor o espaço vertical */
  .elementor-form .elementor-field-group {
    margin-bottom: 1rem !important;
  }

  .titulo {
    color: #121212;
    font-family: "Inter", sans-serif;
    font-size: 1.6rem;
    font-weight: 500;
}

  .subtitulo {
    color: #121212;
    font-family: "Inter", sans-serif;
    font-size: 1.5rem;
    text-align: justify !important;
}
}

/* =====================================================
   INDICADORES DE STEPS (Lógica Invertida: Preto Atual / Amarelo Concluído)
   ===================================================== */

.e-form__indicators__indicator__label {
    color: #121212;
    font-family: "Inter", sans-serif;
    font-size: 1.6rem;
}

.elementor-form .e-form__indicators {
    margin-bottom: 40px !important;
    background: #ffffff !important;
    padding: 25px 40px !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.04) !important;
    border: 1px solid #f0f0f0 !important;
}

/* Bolinha Inativa (Futura) */
.elementor-form .e-form__indicators__indicator__number {
    width: 38px !important;
    height: 38px !important;
    border: 2px solid #d1d5db !important;
    background-color: #ffffff !important;
    color: #9ca3af !important;
    font-weight: 700 !important;
    font-size: 1.5rem !important;
    border-radius: 50% !important;
}

/* --- ESTADO: ATIVO (Fase atual fica PRETA) --- */
.elementor-form .e-form__indicators__indicator--active .e-form__indicators__indicator__number {
    background-color: #121212 !important; 
    border-color: #121212 !important;
    color: #ffffff !important; /* Número branco para contraste */
    box-shadow: 0 0 0 4px rgba(18, 18, 18, 0.1);
}

.elementor-form .e-form__indicators__indicator--active .e-form__indicators__indicator__label {
    color: #121212 !important;
    font-weight: 700 !important;
}

/* --- ESTADO: CONCLUÍDO (Fase respondida fica AMARELA) --- */
.elementor-form .e-form__indicators__indicator--completed .e-form__indicators__indicator__number {
    background-color: #ffc107 !important; 
    border-color: #ffc107 !important;
    color: #121212 !important;
}

.elementor-form .e-form__indicators__indicator--completed .e-form__indicators__indicator__label {
    color: #ffc107 !important;
}

/* Linhas conectoras */
.elementor-form .e-form__indicators__lines {
    background-color: #f0f0f0 !important;
}

.elementor-form .e-form__indicators__lines__indicator--completed {
    background-color: #ffc107 !important; /* Linha amarela indicando caminho concluído */
}

.e-form__indicators__indicator--state-active .e-font-icon-svg {
    fill: #121212;
}

.e-form__indicators__indicator--state-completed 
.e-font-icon-svg {
    fill: #121212;
    /*opacity: 0.6;*/
}

.e-form__indicators__indicator--state-active 
.e-form__indicators__indicator__label {
    color: #121212;
}

.e-form__indicators__indicator--state-completed 
.e-form__indicators__indicator__label {
    color: #121212;
    /*opacity: 0.6;*/
}

/* =====================================================
   RADIO (Correção da Quebra de Linha)
   ===================================================== */
.elementor-field-option {
    display: flex !important;
    align-items: center !important; /* Alinha verticalmente bolinha e texto */
    flex-wrap: nowrap !important; /* Impede a quebra de linha */
    margin-bottom: 1.2rem !important;
}

.elementor-field-option label {
    font-family: "Inter", sans-serif;
    display: inline-block !important;
    font-size: 1.6rem !important;
    color: #333333 !important;
    padding-left: 12px !important;
    margin: 0 !important; /* Remove margens que podem causar quebra */
    cursor: pointer !important;
    line-height: 1 !important; /* Garante alinhamento com a bolinha */
}

.elementor-form input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important; /* Impede que a bolinha amasse se o texto for longo */
    border: 2px solid #d1d5db !important;
    border-radius: 50% !important;
    background: #ffffff !important;
    display: grid !important;
    place-content: center !important;
    margin: 0 !important;
    cursor: pointer !important;
}

.elementor-form input[type="radio"]::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 50%;
    transform: scale(0);
    transition: 0.2s transform ease;
    background-color: #ffc107 !important;
}

.elementor-form input[type="radio"]:checked {
    border-color: #121212 !important;
}

.elementor-form input[type="radio"]:checked::before {
    transform: scale(1);
}

/* =====================================================
   CHECK
   ===================================================== */

.elementor-form input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important; /* Impede que a bolinha amasse se o texto for longo */
    border: 2px solid #d1d5db !important;
    border-radius: 20% !important;
    background: #ffffff !important;
    display: grid !important;
    place-content: center !important;
    margin: 0 !important;
    cursor: pointer !important;
}

.elementor-form input[type="checkbox"]::before {
    content: "✔";
    font-size: 1.8rem;
    text-align: center;
    width: 24px;
    height: 24px;
    border-radius: 20%;
    transform: scale(0);
    transition: 0.2s transform ease;
    background-color: #121212 !important;
}

.elementor-form input[type="checkbox"]:checked {
    border-color: #121212 !important;
}

.elementor-form input[type="checkbox"]:checked::before {
    transform: scale(1);
}

/* =====================================================
   MANTENDO DEMAIS ESTILOS (Inputs e Botões)
   ===================================================== */
.elementor-field-textual {
    background-color: #ffffff !important;
    border: 2px solid #f0f3f3 !important;
    border-radius: 12px !important;
    padding: 14px 18px !important;
    font-size: 1.6rem !important;
    color: #a3a3a3 !important;
}

.elementor-field-textual:focus {
    border-color: #ffc107 !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(255, 193, 7, 0.1) !important;
}

.elementor-form .elementor-field-label {
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    color: #121212 !important;
    margin-bottom: 0.8rem !important;
}

.elementor-form .elementor-button,
.elementor-form .e-form__buttons__wrapper__button--next {
    background-color: #121212 !important;
    color: #ffffff !important;
    border-radius: 12px !important;
    font-size: 1.7rem !important;
    font-weight: 600 !important;
    padding: 16px 32px !important;
    border: none !important;
    transition: 0.3s !important;
}

.elementor-form .elementor-button:hover,
.elementor-form .e-form__buttons__wrapper__button--next:hover {
    background-color: #202020 !important;
    color: #ffffff !important;
    transform: translateY(-2px);
}

.elementor-form .e-form__buttons__wrapper__button--previous {
    background-color: transparent !important;
    color: #121212 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 12px !important;
    font-size: 1.7rem !important;
    padding: 16px 32px !important;
}

/* =====================================================
   UPLOAD FIELD (Estilização do Campo de Arquivo)
   ===================================================== */

/* O campo principal (a caixa externa) */
.elementor-field-type-upload input[type="file"] {
    background-color: #ffffff !important;
    border: 1px solid #d1d5db !important;
    border-radius: 12px !important;
    padding: 10px 12px !important;
    font-size: 1.4rem !important;
    color: #4b5563 !important; /* Cor do texto "Nenhum arquivo selecionado" */
    cursor: pointer !important;
    width: 100% !important;
    display: block !important;
}

/* Estilo do Botão "Escolher arquivo" (Chrome, Edge, Safari moderno) */
.elementor-field-type-upload input[type="file"]::file-.elementor-1563 .elementor-element.elementor-element-4c08f598-button {
    background-color: #121212 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    margin-right: 15px !important;
    font-family: 'Roboto', sans-serif !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

/* Estilo para navegadores Webkit antigos (Safari/Chrome antigos) */
.elementor-field-type-upload input[type="file"]::-webkit-file-upload-button {
    background-color: #121212 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    margin-right: 15px !important;
    font-family: 'Roboto', sans-serif !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}

/* Hover no botão do upload */
.elementor-field-type-upload input[type="file"]::file-.elementor-1563 .elementor-element.elementor-element-4c08f598-button:hover,
.elementor-field-type-upload input[type="file"]::-webkit-file-upload-button:hover {
    background-color: #ffc107 !important;
    color: #121212 !important;
}

/* Estado de Foco (quando clica ou usa o tab) */
.elementor-field-type-upload input[type="file"]:focus {
    border-color: #ffc107 !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(255, 193, 7, 0.1) !important;
}

/* =====================================================
   UTILITÁRIOS / ICONS / TITULO
   ===================================================== */
.titulo {
    color: #121212;
    font-family: "Inter", sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
}

.subtitulo {
    color: #121212;
    font-family: "Inter", sans-serif;
    font-size: 1.8rem;
    text-align: center !important;
}

.e-font-icon-svg {
    width: 22px !important;
    height: 22px !important;
}/* End custom CSS */