/* ===== Tela de login NIGE (layout split) ===== */
:root{
  --nige-azul:#2E6FBF;
  --nige-azul-escuro:#1F4E8C;
  --nige-navy:#1f2d5a;
  --nige-laranja:#DF7B19;
  --nige-laranja-claro:#ef9a3f;
  --nige-cinza:#8a94a6;
  --nige-borda:#e2e8f0;
  --nige-fundo:#eef2f7;
}

*{ box-sizing:border-box; }

body{
  margin:0; padding:0;
  background:var(--nige-fundo);
  min-height:100vh;
  display:block;
  font-family:Arial, Helvetica, sans-serif;
  overflow-x:hidden;
}

.login-page{
  display:flex;
  min-height:100vh;
  width:100%;
}

/* ---------- Painel esquerdo (branding) ---------- */
.login-hero{
  position:relative;
  flex:1 1 56%;
  max-width:56%;
  background:#16294a url('../img/somosparatodos/login-hero-bg.svg') center/cover no-repeat;
  color:#fff;
  padding:48px 56px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-logo{ position:absolute; top:44px; left:56px; z-index:2; }
.hero-logo img{ height:56px; width:auto; display:block; }

.hero-content{
  width:100%;
  max-width:480px;
  transform:translateY(-2vh);
}
/* carrossel */
.hero-slides{ position:relative; }
.hero-slide{ display:none; }
.hero-slide.active{ display:block; animation:heroFade .5s ease; }
@keyframes heroFade{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;} }
.hero-icon{
  width:58px; height:58px;
  border-radius:14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:24px;
}
.hero-badge{
  display:inline-block;
  font-size:11px; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase;
  color:#cdd9ec;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  padding:6px 14px; border-radius:20px;
  margin-bottom:18px;
}
.hero-content h1{
  font-size:40px; line-height:1.15; font-weight:800;
  margin:0 0 16px;
}
.hero-slide p{
  font-size:16px; line-height:1.6;
  color:rgba(255,255,255,.72);
  margin:0 0 30px;
}
.hero-features{ list-style:none; margin:0; padding:0; }
.hero-features li{
  display:flex; align-items:center; gap:12px;
  font-size:16px; color:#eaf0f8;
  margin-bottom:18px;
}
.hero-features .check{
  flex:0 0 22px; width:22px; height:22px;
  border-radius:50%;
  background:var(--nige-laranja);
  color:#fff; font-size:12px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.hero-dots{ display:flex; gap:8px; margin-top:8px; }
.hero-dots .dot{
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.25);
  cursor:pointer; transition:width .3s, background .3s;
}
.hero-dots .dot.active{ width:26px; border-radius:5px; background:var(--nige-laranja); }

/* ---------- Painel direito (formulário) ---------- */
.login-form-side{
  flex:1 1 44%;
  max-width:44%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:40px 24px;
}
.login-box{
  width:100%;
  max-width:420px;
  background:#fff;
  border-radius:16px;
  box-shadow:0 18px 50px rgba(20,40,75,.10);
  padding:40px;
}
.login-logo{ text-align:center; margin-bottom:24px; }
.login-logo img{ height:76px; width:auto; }
.form-badge{
  display:inline-block;
  font-size:11px; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--nige-laranja);
  background:#fdeacf;
  padding:6px 14px; border-radius:20px;
  margin-bottom:20px;
}
.login-box h2{
  font-size:26px; font-weight:800; color:var(--nige-navy);
  margin:0 0 6px;
}
.login-box .subtitle{
  font-size:14px; color:var(--nige-cinza);
  margin:0 0 26px;
  text-align:center;
}
.login-box .field{ margin-bottom:18px; }
.login-box .field-row{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:8px;
}
.login-box label{
  display:block;
  font-size:13px; font-weight:700; color:var(--nige-navy);
  margin-bottom:8px;
}
.login-box .field-row label{ margin-bottom:0; }
.forgot-link{
  font-size:13px; font-weight:600;
  color:var(--nige-laranja) !important; text-decoration:none;
}
.forgot-link:hover{ text-decoration:underline; }
.login-box input[type="text"],
.login-box input[type="password"],
.login-box input[type="email"]{
  width:100%;
  padding:13px 16px;
  border:1px solid var(--nige-borda);
  border-radius:10px;
  font-size:14px;
  color:#33415c;
  background:#fff;
  transition:border-color .2s, box-shadow .2s;
}
.login-box input::placeholder{ color:#9aa3b2; }
.login-box input:focus{
  outline:none;
  border-color:var(--nige-laranja);
  box-shadow:0 0 0 3px rgba(223,123,25,.12);
}
.btn-login{
  width:100%;
  margin-top:8px;
  padding:17px 18px;
  min-height:54px;
  border:none; border-radius:12px;
  background:linear-gradient(180deg,var(--nige-laranja-claro),var(--nige-laranja));
  color:#fff; font-size:15px; font-weight:800; letter-spacing:1.2px;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(223,123,25,.28);
  transition:filter .2s, transform .05s, box-shadow .2s;
}
.btn-login:hover{ filter:brightness(.96); box-shadow:0 12px 24px rgba(223,123,25,.34); }
.btn-login:active{ transform:translateY(1px); }
.form-help{
  margin:22px 0 0;
  font-size:12px; line-height:1.5;
  color:var(--nige-cinza); text-align:center;
}
.copyright{
  margin:22px 0 0;
  font-size:12px; color:#9aa3b2; text-align:center; line-height:1.7;
}
.privacy-link{
  color:var(--nige-laranja); font-weight:600; font-size:12px;
  text-decoration:none; cursor:pointer;
}
.privacy-link:hover{ text-decoration:underline; }

/* modal de Política de Privacidade */
.privacy-overlay{
  position:fixed; inset:0; z-index:9999;
  background:rgba(15,30,55,.55);
  display:none; align-items:center; justify-content:center;
  padding:20px;
}
.privacy-overlay.open{ display:flex; }
.privacy-box{
  position:relative;
  background:#fff; width:100%; max-width:560px; max-height:85vh;
  overflow:auto; border-radius:16px;
  padding:34px 36px;
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}
.privacy-box h3{
  margin:0 0 18px; font-size:22px; color:var(--nige-navy);
}
.privacy-close{
  position:absolute; top:14px; right:18px;
  border:none; background:none; font-size:28px; line-height:1;
  color:#9aa3b2; cursor:pointer;
}
.privacy-close:hover{ color:var(--nige-laranja); }
.privacy-content{ color:#4a5568; font-size:14px; line-height:1.65; }
.privacy-content p{ margin:0 0 12px; }
.privacy-content ul{ margin:0 0 12px; padding-left:20px; }
.privacy-content li{ margin-bottom:6px; }
.privacy-ok{
  margin-top:20px;
  background:var(--nige-laranja); color:#fff;
  border:none; border-radius:10px;
  padding:12px 24px; font-weight:700; font-size:14px; cursor:pointer;
}
.privacy-ok:hover{ filter:brightness(.96); }

/* o JS injeta <div class="input-group"> com o select de rede */
.login-box .input-group{ margin-bottom:18px; }
.login-box .input-group label{ margin-bottom:8px; }

/* mensagens de validação (jquery.validate) */
.login-box label.error{
  display:block; color:#d23b3b; font-size:12px; font-weight:600;
  margin:6px 0 0;
}

/* oculta o badge/erro do reCAPTCHA (chave registrada p/ domínio de produção) */
.grecaptcha-badge{ visibility:hidden !important; opacity:0 !important; }

/* link "Política de Privacidade" dentro da barra de cookies */
.cookiebar-privacy-link,
#cookie-bar .cookiebar-privacy-link{
  color:#DF7B19 !important;
  font-weight:700 !important;
  text-decoration:underline !important;
  cursor:pointer !important;
}

/* barra de cookies nas cores NIGE */
#cookie-bar{ background:#1F4E8C !important; }
#cookie-bar, #cookie-bar p, #cookie-bar-prompt-content{ color:#fff !important; }
#cookie-bar #cookie-bar-button,
#cookie-bar a#cookie-bar-button{
  background-color:#DF7B19 !important;
  color:#fff !important;
  border-bottom:1px solid #b5630f !important;
}
#cookie-bar #cookie-bar-button:hover{ filter:brightness(.95); }
#cookie-bar #cookie-bar-button-no,
#cookie-bar a#cookie-bar-button-no{
  background-color:transparent !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.55) !important;
}

/* ---------- Responsivo ---------- */
@media (max-width: 900px){
  .login-page{ flex-direction:column; }
  .login-hero{ display:none; }
  .login-form-side{ max-width:100%; flex:1; min-height:100vh; }
}
