/* ============================
   RESET BÁSICO
============================ */
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

/* ============================
   ÁREA DE LAYOUT DO FORM
============================ */
#forms {
  background: 0 0 !important;
}

#forms_layout,
#forms_layout-two {
  margin: 0 auto;
  width: 100%;
  max-width: 430px;
  /* largura real */
  min-width: auto;
  overflow: hidden;
  border-radius: 0;
  font-family: Arial, Helvetica, sans-serif;
}

.inputs_no_display_forms {
  display: none;
}

/* ============================
   INPUTS BASE
============================ */
.form-control {
  display: block;
  width: 100%;
  height: auto !important;
  min-height: 48px;
  padding: 16px 12px !important;
  font-size: 1rem;
  line-height: 1.4;
  color: #ffffff !important;
  background-color: transparent !important;
  border: 1px solid #ffffff !important;
  border-radius: 4px !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* Inputs: email, tel, text */
#forms #forms_layout input[type="text"],
#forms #forms_layout input[type="email"],
#forms #forms_layout input[type="tel"] {
  padding: 16px 12px !important;
  color: #ffffff !important;
  background-color: transparent !important;
  border-left: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-top-left-radius: 0 !important;
}

#forms #forms_layout input[type="text"]:focus,
.form-control:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
select:focus,
textarea:focus {
  border-color: #ccc;
  box-shadow: 0 0 0;
  outline: 0;
  color: #fff;
}

/* ============================
  PLACEHOLDERS
============================ */

#forms #forms_layout ::-webkit-input-placeholder {
  color: #fff;
  font-size: 13px;
  background-color: transparent;
}

#forms #forms_layout ::-moz-placeholder {
  color: #fff;
  font-size: 13px;
  background-color: transparent;
}

#forms #forms_layout :-ms-input-placeholder {
  color: #a9abbd;
  font-size: 13px;
  background-color: transparent;
}

#forms #forms_layout ::placeholder {
  color: #a9abbd;
  font-size: 13px;
  background-color: transparent;
}


/* ============================
   SELECT
============================ */
#forms #forms_layout .selectpicker {
  background-color: transparent !important;
  color: #ffffff !important;
  padding: 0 12px !important;
  height: 48px !important;
  border-left: 0 !important;
  font-size: 14px;
  border-bottom-left-radius: 0 !important;
  border-top-left-radius: 0 !important;
}

#forms #forms_layout .selectpicker:focus {
  border-color: #ccc;
  box-shadow: none;
  outline: 0;
}

#forms #forms_layout .selectpicker option {
  color: #747474;
}

/* ============================
   AUTOFILL (Chrome/Firefox/Safari)
============================ */
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
  -webkit-text-fill-color: #fff !important;
  -webkit-box-shadow: 0 0 0px 1000px transparent inset !important;
  background-color: transparent !important;
}

/* ============================
   ÍCONES E INPUT GROUP
============================ */
#forms #forms_layout span.input-group-text {
  background-color: transparent !important;
  border-right: 0 !important;
  border-left: 1px solid #fff !important;
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
  color: #ffffff !important;
  padding: 10px 16px;
  border: 0.1px solid #ffffff;
}

.input-group {
  display: flex;
  /* mantém ícone e input na mesma linha */
  flex-wrap: wrap;
  /* permite que elementos "quebrem" linha */
  align-items: stretch;
  /* mantém altura consistente */
}

img.form-icons-svg {
  border-bottom-left-radius: 4px;
  border-top-left-radius: 4px;
  padding: 4px;
  border: 0.1px solid #000;
  border-right: 0;
  filter: invert(1);
}

svg.svg-inline--fa.fa-chevron-right {
  padding: 14px 16px;
  border-radius: 50%;
}

/* ============================
   CHECKBOX CUSTOMIZADO
============================ */
#forms #forms_layout input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}

#forms #forms_layout input[type="checkbox"]+label {
  display: block;
  position: relative;
  cursor: pointer;
  padding: 5px 0 0 40px;
  line-height: 1.5em;
  color: #fff !important;
  font-size: 14px;
}

#forms #forms_layout input[type="checkbox"]+label::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  left: 0;
  top: 5px;
  border: 2px solid #fff;
  border-radius: 3px;
}

#forms #forms_layout input[type="checkbox"]:checked+label::after {
  content: "";
  position: absolute;
  left: 8px;
  top: 8px;
  width: 5px;
  height: 10px;
  border-right: 3px solid #fff;
  border-bottom: 3px solid #fff;
  transform: rotate(45deg);
}

/* ============================
   BOTÃO / CTA
============================ */
#forms #forms_layout .btn-custom,
.formulario_estrategia .btn-modal {
  border: none;
  width: 100%;
  height: 68px;
  background-color: #f4bc00;
  padding: 0 0 0 25px;
  display: flex;
  align-items: center;
  position: relative;
  transition: 0.3s ease;
}

#forms #forms_layout .btn-custom:hover,
.formulario_estrategia .btn-modal:hover {
  opacity: 0.8;
}

#forms #forms_layout .btn-blue {
  background: #40a7ff;
}

#forms #forms_layout .btn-blue:hover {
  background: #006ecc;
}

#forms #forms_layout .btn-red {
  background: #fff;
}

#forms #forms_layout .btn-red:hover {
  background: #ffd8de;
}

/* Label do botão */
#forms #forms_layout #lblBotao,
.formulario_estrategia .btn-modal #lblBotao {
  font-weight: bold;
  font-size: 100%;
  text-align: left;
  display: block;
}

/* ============================
   SEND ICON (lado direito do botão)
============================ */
.send__icon {
  background-color: white;
  position: absolute;
  width: 80px;
  height: 68px;
  right: 0;
  top: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

i.fa.fa-chevron-right {
  display: flex !important;
  padding: 16px 18px !important;
  font-size: 1rem !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ============================
   MODAL
============================ */
.wrapper-modal {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh !important;
  z-index: 999;
  background-color: rgba(0, 0, 0, 0.8);
}

#content-modal {
  max-width: 50%;
  margin: 130px auto 0 auto;
  padding: 30px 20px;
  border-radius: 10px;
  background-color: rgba(0, 0, 0, 0.9);
}

.close {
  position: relative;
  top: 0;
  right: 0;
  color: #fff !important;
  cursor: pointer;
  font-size: 150%;
}

/* ============================
   SAFARI FIXES — iPhone e macOS
============================ */
@supports (-webkit-touch-callout: none) {

  /* Normaliza inputs no Safari */
  #forms #forms_layout input[type="text"],
  #forms #forms_layout input[type="email"],
  #forms #forms_layout input[type="tel"],
  select.selectpicker {
    height: auto !important;
    min-height: 48px !important;
    padding: 16px 12px !important;
  }

  /* Autofill Safari */
  input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px transparent inset !important;
    background-color: transparent !important;
    -webkit-text-fill-color: #fff !important;
  }

  /* Checkbox alinhado */
  #forms #forms_layout input[type="checkbox"]+label {
    padding-left: 32px !important;
  }

  #forms #forms_layout input[type="checkbox"]+label::before {
    top: 2px !important;
  }

  /* send__icon fix */
  #forms #forms_layout .send__icon {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
  }
}

/* ============================
   RESPONSIVO
============================ */
@media (max-width: 767px) {
  #forms #forms_layout #lblBotao {
    font-size: 100%;
  }

  #forms #forms_layout input[type="checkbox"]+label {
    font-size: 13px !important;
  }

  #content-modal {
    max-width: 95%;
    margin-top: 125px;
  }

  .close {
    right: -10px;
    top: -30px;
  }
}

@media (max-width: 600px) {
  #forms_layout {
    width: 100% !important;
    max-width: 100%;
    display: contents;
  }

  #forms #forms_layout #lblBotao {
    width: 65% !important;
  }
}

/* Animação */
.animate {
  animation: animatezoom 1s;
}

@keyframes animatezoom {
  from {
    transform: scale(0);
  }

  to {
    transform: scale(1);
  }
}

@media only screen and (max-width: 360px) {
  #forms_layout {
    max-width: 280px;
    min-width: 280px;
  }
}