* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  max-width: 100%;
  height: 100%;
  overflow-x: hidden;
  padding: 0 !important;
}

body.modal-open {
  padding: 0 !important;
}

@media (min-width: 768px) {
  .modal-login-concursos-culturais .modal-sm-login {
    width: 360px !important;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: 0 auto;
    transform: translate(-50%, -50%) !important;
  }
}

.modal-login-concursos-culturais .modal-sm-login .modal-content {
  border-radius: 0;
}

.modal-login-concursos-culturais .modal-sm-login #btnLogar {
  width: 100%;
  border-radius: 5px;
  font-weight: 500;
  border: 2px solid #0a0505;
  color: #525252;
  background-color: transparent;
  transition: .2s;
}

.modal-login-concursos-culturais .modal-sm-login #btnLogar:hover {
  border: 2px solid #f07d00;
  color: #ffffff;
  background-color: #f07d00;
  transition: .2s;
}

.modal-login-concursos-culturais .modal-sm-login input {
  height: 45px;
  border: 1.5px solid #939393 !important;
  font-weight: 500;
  background-color: #eeeeee;
  box-shadow: 3px 3px 10px rgb(0 0 0 / 10%) !important;
}

.modal-login-concursos-culturais .modal-sm-login .panel-heading {
  text-align: center;
  padding: 10px 0 10px;
  color: #f07d00;
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  background-color: #f5f5f5;
  margin: 20px 20px 0;
}

.modal-login-concursos-culturais .modal-sm-login .esqueci-senha {
  text-align: center;
}

.modal-login-concursos-culturais .modal-sm-login .esqueci-senha a {
  color: #f07d00;
  font-weight: 400;
  font-size: 16px;
  border-bottom: 1px solid #f07d00;
}

.modal-login-concursos-culturais .modal-sm-login .panel {
  margin-bottom: 0;
}

.modal-login-concursos-culturais .modal-sm-login .panel-footer {
  background-color: #eeeeee;
  text-align: center;
}

.modal-login-concursos-culturais .modal-sm-login .panel-footer a {
  font-weight: bold;
  color: #337ab7;
  font-size: 20px;
  text-transform: uppercase;
  background-color: #ffffff;
}

.logo-promo-toscana-brasileira img {
  width: 100%;
  max-width: 600px;
}

@media (max-width: 768px) {
  .btn-promo-comprar {
    position: relative;
    height: 20vh;
  }

  .btn-promo-comprar a {
    color: #ffffff;
    font-size: 28px;
    border: 2px solid #ffffff;
    border-radius: 5px;
    background-color: #ff9601;
    position: absolute;
    top: 50%;
    left: 10%;
    transform: translate(5%, -50%);
    padding: 15px 20px;
    font-weight: 600;
    box-shadow: 2px 5px 15px rgb(0 0 0 / 90%);
  }

  /* Substitua as duas declarações de .conteudo-promo por esta: */
  .conteudo-promo {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 25px;
    margin-right: -15px;
    margin-left: -15px;
    margin-bottom: 25px;
    background-color: #FF9800;
    padding: 25px 15px;
  }
}

@media (min-width: 769px) {
  .btn-promo-comprar {
    position: relative;
  }

  .btn-promo-comprar a {
    color: #ffffff;
    font-size: 22px;
    border: 2px solid #ffffff;
    border-radius: 5px;
    background-color: #ff9601;
    position: absolute;
    top: 115%;
    left: 50%;
    transform: translate(-50%, 50%);
    padding: 15px 20px;
    font-weight: 600;
    box-shadow: 2px 5px 15px rgb(0 0 0 / 90%);
  }

  .btn-promo-comprar a:hover {
    color: #ff9601;
    font-size: 28px;
    border: 2px solid #ff9601;
    border-radius: 5px;
    background-color: #ffffff;
  }

  /* Substitua as duas declarações de .conteudo-promo por esta: */
  .conteudo-promo {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 75vh;
    position: relative;
    bottom: 100px;
  }
}

/* Centralize o bloco .texto-promo que contém o p.t2 */
.texto-promo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;

}

h1.titulo-promo {
  font-size: 44px;
  color: #337ab7 !important;
  margin-bottom: 15px;
}

.texto-promo p.t1 {
  line-height: 1.5;
}

.texto-promo p.t1 span {
  font-weight: 600;
  border-radius: 5px;
  padding: 1px 6px;
  height: 40px;
  display: inline-block;
}

.texto-promo p.t2 span {
  font-weight: 600;
  border-radius: 5px;
  padding: 0 6px;
  height: 45px;
  display: inline-block;
  line-height: 0.8;
}

.texto-promo p.t1 span.tx-red {
  background-color: #af2628;
}

.texto-promo p.t1 span.tx-orange {
  background-color: #fa7701;
}

.texto-promo p.t2 span.tx-blue {
  background-color: #4890b4;
}

@media (max-width: 768px) {
  .texto-promo p.t1 span.tx-orange {
    background-color: #fa7701;
    margin-top: 10px;
  }

  .texto-promo p.t2 span {
    font-weight: 600;
    border-radius: 5px;
    padding: 0 6px;
    height: 45px;
    display: inline-block;
    line-height: normal;
  }

  .texto-promo {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin: 25px 0 0;
  }

  .texto-promo p.t1,
  .texto-promo p.t2,
  .texto-promo p.t3 {
    line-height: 1.2;
    color: #ffffff;
    text-align: center;
    font-weight: 800;
    font-style: italic;
    letter-spacing: 1.3px;
    text-shadow: 1px 0px 2px #000000;
  }

  .texto-promo p.t4,
  .texto-promo p.t5,
  .texto-promo p.t6 {
    font-size: 20px;
    line-height: 0.8;
    color: #ffffff;
    text-transform: uppercase;
    text-align: center;
    font-weight: 800;
    font-style: italic;
    letter-spacing: 1.3px;
    text-shadow: 1px 0px 2px #000000;
  }

  .texto-promo p.t6 span {
    font-size: 25px;
  }

  .texto-promo p.t1 {
    font-size: 30px;
  }

  .texto-promo p.t2 {
    font-size: 32px;
  }

  .texto-promo p.t3 {
    font-size: 40px;
  }
}

@media (min-width: 769px) {
  .texto-promo {
    height: 22vh;
  }

  .texto-promo p.t1,
  .texto-promo p.t2,
  .texto-promo p.t3 {
    line-height: 1.1;
    color: #ffffff;
    text-align: center;
    font-weight: 500;
    letter-spacing: 1.3px;
    text-shadow: 1px 0px 2px #000000;
  }

  .texto-promo p.t4,
  .texto-promo p.t5,
  .texto-promo p.t6 {
    font-size: 35px;
    line-height: 0.8;
    color: #ffffff;
    text-transform: uppercase;
    text-align: center;
    font-weight: 800;
    font-style: italic;
    letter-spacing: 1.3px;
    text-shadow: 1px 0px 2px #000000;
  }

  .texto-promo p.t6 span {
    font-size: 30px;
  }

  .texto-promo p.t1 {
    font-size: 32px;
  }

  .texto-promo p.t2 {
    font-size: 38px;
    margin-bottom: 15px;
  }

  .texto-promo p.t3 {
    font-size: 60px;
  }

  .texto-promo a img {
    margin: 15px 0 0 !important;

  }

  .texto-promo a {
    z-index: 999;
  }

  .conteudo-footer-promo {
    display: flex;
    position: absolute;
    bottom: 15%;
    align-items: center;
    justify-content: center;
    left: 50%;
    right: 50%;
  }
}

.foto-transformers {
  max-width: 480px;
  text-align: center;
  ;
}

.foto-transformers h5.visible-xs {
  min-width: 100%;
  font-size: 16px;
  color: #ffffff;
  margin-bottom: 40px;
  ;
}

.foto-transformers h5 a:hover {
  color: #01718d;
}

.items-promo {
  max-width: 400px;
}

.legal-line {
  max-width: 380px;
  margin: 0 0 25px;
}

.legal-line-vertical {
  position: absolute;
  right: -15px;
  text-align: center;
}

.legal-line-vertical h5 {
  color: #ffffff;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  font-weight: 400;
  margin: 0 10px;
}

.legal-line-vertical h5 a:hover {
  color: #3776ff;
}

.legal-line-horizontal {
  position: initial;
  margin: 15px 0;
}

#regulamento {
  padding-bottom: 80px !important;
}

#regulamento span {
  background-color: transparent !important;
}

#participacoes {
  padding-bottom: 0 !important;
  background-size: cover;
}

#participacoes span {
  background-color: transparent !important;
}

#home {
  padding: 0 !important;
}

@media (max-width: 480px) {
  #home {
    height: auto;
    padding-bottom: 50px !important;
  }
}

@media (min-width: 769px) {
  .table-regulamento {
    padding-left: 25px;
  }
}

.bloco-regulamento {
  background-color: rgba(0, 0, 0, 0.8);
  max-width: 1200px;
  color: #ffffff;
  border-radius: 4px;
  text-align: justify;
  margin-top: 15px;
  margin-bottom: 50px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px 15px;
  font-size: 16px;
  overflow-y: overlay;
  max-height: 500px;
  height: 100%;
}

.bloco-regulamento::-webkit-scrollbar {
  width: 12px;
  /* width of the entire scrollbar */
}

.bloco-regulamento::-webkit-scrollbar-track {
  background: #01718d;
  /* color of the tracking area */
}

.bloco-regulamento::-webkit-scrollbar-thumb {
  background-color: rgb(255, 255, 255);
  /* color of the scroll thumb */
  border-radius: 20px;
  /* roundness of the scroll thumb */
  border: 2px solid #0091b7;
  /* creates padding around scroll thumb */
}

.bloco-regulamento ol {
  margin-left: 60px;
}

.error-message {
  color: red;
  font-size: 1.5rem;
  margin-top: 5px;
}

#charCount {
  padding-top: 15px;
}

.btn-resposta input {
  margin: 0;
  background-color: #f07d00;
  text-transform: uppercase;
  font-size: 20px;
}

.btn-resposta {
  display: flex;
  justify-content: right;
}

.bloco-participe textarea {
  font-size: 18px;
}

.bloco-participe {
  background-color: rgba(0, 0, 0, 0.8);
  max-width: 1200px;
  color: #ffffff;
  border-radius: 4px;
  text-align: justify;
  margin-top: 15px;
  margin-bottom: 50px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px 15px;
  font-size: 16px;
}

.bloco-participe table tr th {
  font-size: 22px;
  border: 0;
}

.bloco-participe .table>thead>tr>th,
.bloco-participe .table>tbody>tr>td {
  border: 0 !important;
}

@media (max-width: 768px) {
  .bloco-participe {
    text-align: left;
  }
}

.bloco-participe h1 {
  padding: 20px 0 0;
  color: #ffffff !important;
}

.bloco-participe h2 {
  font-size: 30px;
}

.bloco-participe h3 {
  color: #ffffff !important;
}

.bloco-participe p {
  padding-left: 0;
  font-size: 18px;
}

.bloco-participacoes {
  background-color: rgba(0, 0, 0, 0.8);
  max-width: 1200px;
  color: #ffffff;
  border-radius: 4px;
  text-align: justify;
  margin-top: 15px;
  margin-bottom: 50px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px 15px;
  font-size: 16px;
}

.bloco-participacoes ol {
  margin-left: 60px;
}

.bloco-participacoes table tr th {
  font-size: 20px;
}

.voltar-home {
  max-width: 1200px;
  color: #ffffff;
  margin-top: 15px;
  margin-bottom: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: right;
}

.voltar-home.form {
  display: flex;
  justify-content: right;
}

.voltar-home.form a {
  margin-left: 10px;
}

.voltar-home a {
  background-color: #ffffff;
  color: #01718d;
  font-size: 22px;
  font-weight: 600;
  box-shadow: 2px 3px 5px #000000;
  margin-left: 10px;
}

.link-nav {
  max-width: 1200px;
  color: hsl(0, 0%, 100%);
  margin-top: 0;
  margin-left: 5px;
  margin-right: 5px;
  text-align: right;
}

.link-nav a {
  text-transform: uppercase;
  min-width: 310px;
  max-width: 100%;
  font-weight: 600;
  font-size: 30px;
  padding: 5px;
  box-shadow: 2px 2px 0px #000;
  border: 0;
  margin-top: 0;
  margin-bottom: 0;
}

.link-nav a.ingresso {
  font-size: 30px;
  padding: 5px;
  box-shadow: 2px 2px 0px #000;
  border: 0;
  margin-top: 10px;
  margin-bottom: 0;
  z-index: 1000;
  position: relative;
}

.link-nav a.participe {
  font-size: 30px;
  padding: 5px;
  box-shadow: 2px 2px 0px #000;
  border: 0;
  margin-top: 0;
  margin-bottom: 0;
}

.link-nav a.ingresso:hover,
.link-nav a.participe:hover {
  border: 0;
}

.link-nav a.login {
  background-color: #f07d00;
}

.link-nav a.participacoes {
  background-color: #0091b7;
}

.link-nav a.regulamento {
  background-color: #0091b7;
}

.link-nav a:hover,
.link-nav a:focus {
  color: #ffffff;
  background-color: #007491;
}

.link-nav-aviso {
  width: 95%;
  background-color: #ffffff;
  text-align: center;
  box-shadow: 1px 0px 2px #000000;
}

.link-nav-aviso h3 {
  margin: 20px 0;
  font-size: 2em;
  font-weight: 600;
}

@media (max-width: 768px) {
  .bloco-regulamento {
    text-align: left;
  }
}

.bloco-regulamento h1 {
  padding: 20px 0 0;
  color: #ffffff !important;
}

.bloco-regulamento h2 {
  font-size: 30px;
}

.bloco-regulamento h3 {
  color: #ffffff !important;
}

.bloco-regulamento p {
  padding-left: 25px;
}

.full.agradecimento {
  height: 80vh;
}

.bloco-participacoes.agradecimento {
  background-color: rgb(255 255 255 / 80%);
  margin-top: 5%;
}

.bloco-participacoes.agradecimento {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 50vh;
}

.bloco-participacoes.agradecimento h1 {
  padding: 20px 0 0;
  color: #00a613 !important;
}

.bloco-participacoes.agradecimento a {
  font-size: 20px;
  background-color: #f07d00;
  color: #ffffff;
}

@media (max-width: 768px) {
  .bloco-participacoes {
    text-align: left;
  }
}

.bloco-participacoes h1 {
  padding: 20px 0 0;
  color: #ffffff !important;
}

.bloco-participacoes h2 {
  font-size: 30px;
}

.bloco-participacoes h3 {
  color: #ffffff !important;
}

.bloco-participacoes p {
  padding-left: 0;
  font-size: 18px;
}

@media screen and (min-width: 769px) {

  .sub-paragrafo,
  .sub-paragrafo-2,
  .sub-paragrafo-3,
  .sub-paragrafo-4,
  .sub-paragrafo-5 {
    margin-left: 50px;
  }
}

.table-bordered {
  border: 2px solid #ffffff;
}

@media screen and (max-width: 767px) {

  .table-responsive>.table>tbody>tr>td,
  .table-responsive>.table>tbody>tr>th,
  .table-responsive>.table>tfoot>tr>td,
  .table-responsive>.table>tfoot>tr>th,
  .table-responsive>.table>thead>tr>td,
  .table-responsive>.table>thead>tr>th {
    white-space: normal;
  }
}

.table-bordered>tbody>tr>td,
.table-bordered>tbody>tr>th,
.table-bordered>tfoot>tr>td,
.table-bordered>tfoot>tr>th,
.table-bordered>thead>tr>td,
.table-bordered>thead>tr>th {
  border: 2px solid #ffffff;
  max-width: 500px;
  vertical-align: middle;
}

#rodape {
  background: rgb(243, 126, 63, 1);
  background: linear-gradient(180deg,
      rgba(237, 201, 77, 1) 0%,
      rgba(243, 126, 63, 1) 100%);
  height: 50px;
  box-shadow: 0px -10px 30px rgba(0, 0, 0, 0.5);
  clear: both;
}

#rodape footer p {
  background: rgb(243, 126, 63, 1);
  background: linear-gradient(180deg,
      rgba(237, 201, 77, 1) 0%,
      rgba(243, 126, 63, 1) 100%);
  text-align: center;
  color: #ffffff;
  margin: 0;
  padding: 5px 0;
}

@media (min-width: 768px) {
  #rodape footer p {
    margin: 0;
    padding: 15px 0;
  }
}

@media (min-width: 769px) {
  .logado {
    position: absolute;
    color: #ffffff;
    top: 50%;
    transform: translate(5%, 0%);
    -moz-transform: translate(5%, 40%);
    -webkit-transition: translate(5%, 40%);
    -o-transform: translate(5%, 40%);
  }
}

@media (max-width: 768px) {
  .logado {
    color: #ffffff;
  }
}

.numero-inscricao,
.data-hora {
  min-width: 220px;
}

label.checkbox-titulo {
  font-size: 13.5px;
  text-transform: initial;
  font-weight: 600;
}

.certificados {
  text-align: center;
  color: #ffffff;
  padding: 0 15px 0 15px;
  background-color: rgba(48, 48, 48, 0.7);
}

.certificados h4 {
  margin-bottom: 0;
  font-weight: 800;
  font-size: 16px;
}

.certificados p {
  font-size: 12px;
}

@media (min-width: 769px) {
  .certificados .left {
    text-align: left;
  }

  .certificados .right {
    text-align: right;
  }
}

.yellow {
  color: yellow;
}

.facebook,
#googleBtnCustom {
  border-radius: 15px;
  text-align: center;
  padding: 8px 15px;
  margin: 8px 0 0 0;
  cursor: pointer;
}

#googleBtnCustom {
  border-radius: 15px;
  text-align: center;
  padding: 8px 15px;
  margin: 8px 0 0 0;
  font-size: 12px;
  color: #fff;
  background-color: #f34346;
}

#googleBtnCustomCadastro {
  border-radius: 5px;
  text-align: center;
  padding: 8px 5px;
  margin: 0px 0 0 0;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background-color: #f34346;
  min-width: 210px;
  ;
}

#googleBtnCustom .buttonText:hover {
  border-bottom: 1px solid #ffffff;
}

.facebook a,
.google a {
  font-size: 14px;
  color: #fff;
}

.facebook {
  border-radius: 0 25px;
  text-align: center;
  padding: 12px 15px;
  margin: 0px 0 0 0;
  font-size: 14px;
  color: #fff;
  background-color: #47619e;
}

.google {
  background-color: #f34346;
}

span.btn,
.customGPlusSignIn {
  cursor: pointer;
}

.signin-button {
  width: 210px;
  height: 40px;
}

.login-redes-sociais {
  display: inline-block;
}