:root{
  --verde-principal:#7bbf45;
  --verde-hover:#9acd32;
  --marrom:#6b4f2a;
  --marrom-escuro:#2d2416;
  --bege:#f3eee4;
  --bege-borda:#c8b08a;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:Arial,sans-serif;
}

body{
  background:linear-gradient(180deg,#f7f6f0,#ffffff);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  color:#222;
}

.cadastro-wrapper{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:40px 20px;
}

.cards{
  width:100%;
  max-width:500px;
  background:#fff;
  border:1px solid var(--bege-borda);
  border-radius:20px;
  padding:38px;
  box-shadow:0 10px 30px rgba(107,79,42,.12);
}

.cadastro-logo{
  text-align:center;
  margin-bottom:28px;
}

.logo-icon{
  font-size:55px;
  display:block;
  margin-bottom:10px;
}

.cadastro-logo h1{
  color:#222;
  font-size:28px;
}

.cadastro-logo h1 span{
  color:var(--verde-principal);
}

.cadastro-logo p{
  color:#666;
  margin-top:5px;
}

.tag-rural{
  display:inline-block;
  margin-top:12px;
  padding:5px 12px;
  border-radius:20px;
  background:var(--bege);
  color:var(--marrom);
  border:1px solid var(--bege-borda);
  font-size:11px;
}

.card{
  margin-bottom:16px;
}

.card p{
  margin-bottom:6px;
  color:#444;
  font-size:14px;
}

input{
  width:100%;
  padding:12px;
  background:#fff;
  border:1px solid var(--bege-borda);
  border-radius:10px;
  color:#222;
  outline:none;
  transition:.3s;
}

input:focus{
  border-color:var(--verde-principal);
  box-shadow:0 0 0 3px rgba(123,191,69,.15);
}

input::placeholder{
  color:#777;
}

.senha-box{
  position:relative;
}

.senha-box input{
  padding-right:45px;
}

.icone{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  color:var(--marrom);
  cursor:pointer;
  font-size:18px;
}

#cadastrar{
  width:100%;
  padding:13px;
  border:none;
  border-radius:10px;
  background:var(--marrom);
  color:white;
  font-weight:bold;
  cursor:pointer;
  transition:.3s;
  margin-top:8px;
}

#cadastrar:hover{
  background:var(--verde-principal);
}

.voltar-login{
  text-align:center;
  margin-top:15px;
}

.voltar-login a{
  color:#666;
  text-decoration:none;
  font-size:14px;
  transition:.3s;
}

.voltar-login a:hover{
  color:var(--verde-principal);
}

#mensagemCadastrar,
#mensagemNome,
#mensagemEmail,
#mensagemTelefone,
#mensagemEndereco,
#mensagemSenha,
#mensagemConfirmar{
  margin-top:5px;
  font-size:13px;
}

#temaBtn{
  position:fixed;
  bottom:20px;
  right:20px;
  width:55px;
  height:55px;
  border:none;
  border-radius:50%;
  background:var(--marrom);
  color:white;
  cursor:pointer;
  font-size:22px;
  transition:.3s;
  z-index:999;
}

#temaBtn:hover{
  background:var(--verde-principal);
}

footer{
  background:#f7f6f0;
  border-top:1px solid var(--bege-borda);
  text-align:center;
  padding:18px;
}

footer a{
  color:#666;
  text-decoration:none;
}

footer a:hover{
  color:var(--verde-principal);
}

/* MODO ESCURO */
body.escuro{
  background:#0f120c;
  color:#fff;
}

body.escuro .cards{
  background:#1a1f14;
  border:1px solid #2d3a20;
  box-shadow:0 0 25px rgba(123,191,69,.15);
}

body.escuro .cadastro-logo h1{
  color:#fff;
}

body.escuro .cadastro-logo p{
  color:#999;
}

body.escuro .tag-rural{
  background:var(--marrom-escuro);
  color:var(--verde-principal);
  border:1px solid var(--verde-principal);
}

body.escuro .card p{
  color:#ccc;
}

body.escuro input{
  background:#111;
  color:#fff;
  border:1px solid #333;
}

body.escuro input:focus{
  border-color:var(--verde-principal);
}

body.escuro input::placeholder{
  color:#777;
}

body.escuro .icone{
  color:var(--verde-principal);
}

body.escuro .voltar-login a{
  color:#888;
}

body.escuro .voltar-login a:hover{
  color:var(--verde-principal);
}

body.escuro footer{
  background:#0a0a0a;
  border-top:1px solid var(--marrom);
}

body.escuro footer a{
  color:#888;
}

body.escuro footer a:hover{
  color:var(--verde-principal);
}

@media(max-width:768px){
  .cards{
    max-width:95%;
    padding:28px;
  }

  .cadastro-logo h1{
    font-size:24px;
  }
}

@media(max-width:480px){
  .cadastro-wrapper{
    padding:25px 12px;
  }

  .cards{
    padding:22px;
  }

  .logo-icon{
    font-size:45px;
  }

  .cadastro-logo h1{
    font-size:22px;
  }

  #temaBtn{
    width:50px;
    height:50px;
    font-size:20px;
  }
}