/* assets/css/50_modal_login.css
   
*/

/* =========================
   Modal base (login)
   ========================= */
.modal-content.modal-login{
  max-width: 760px;
  width: min(92vw, 760px);
  background: var(--modal-bg, #e9e6e6);
  border: 1px solid rgba(0,0,0,.35);
  padding: 22px 18px 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

/* Topo: título + fechar */
#modal-login .login-top{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  column-gap: 14px;
  margin-bottom: 12px;
}

#modal-login .login-titlebar{
  background: var(--modal-title-bg, #4c654f);
  color: var(--modal-title-color, #fff);
  font-size: 56px;
  font-weight: 300;
  line-height: 1.05;
  text-align: center;
  padding: 12px 14px;
  letter-spacing: 0px;
}

#modal-login .login-status{
  background: var(--bar-cream, #d9d1b5);
  border: 1px solid rgba(0,0,0,.18);
  color: #111;
  padding: 10px 12px;
  margin: 10px 0 12px;
  font-weight: 600;
  border-radius: 10px;
}

/* =========================
   Campos
   ========================= */
#modal-login .login-grid{
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 14px 16px;
  align-items: center;
  margin: 8px 0 12px;
}

#modal-login .login-label{
  font-size: 24px;
  font-weight: 300;
}

#modal-login .login-input{
  width: 100%;
  max-width: none;
  font-size: 18px;
  padding: 8px 10px;
  border: 2px solid rgba(0,0,0,.45);
  background: #fff;
  height: 44px;
  box-sizing: border-box;
}

/* Password + botão Mostrar */
#modal-login .login-pass-row{
  display: grid;
  grid-template-columns: 1fr 130px;
  gap: 12px;
  align-items: center;
}

#modal-login .login-btn-mostrar{
  height: 44px;
  font-size: 22px;
  padding: 8px 12px;
  border-radius: 16px;
}

/* =========================
   Botões inferiores — Layout v3
   3 botões numa linha:
   A minha ficha | Entrar | Esqueci Password
   ========================= */
#modal-login .login-actions--v3{
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 200px 1fr;
  gap: 14px;
  align-items: stretch;
}

#modal-login .login-actions--v3 .login-action-btn{
  height: 54px;
  font-size: 22px;
  font-weight: 300;
  border-radius: 16px;
  padding: 10px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  white-space: nowrap;
}

#modal-login .login-actions--v3 .login-btn-enter{
  width: 100%;
  height: 54px;     /* deixa de ser gigante */
  font-size: 26px;
  font-weight: 300;
  border-radius: 16px;
}

/* =========================
   Responsivo (login)
   ========================= */
@media (max-width: 820px){
  #modal-login .modal-content.modal-login{ max-width: 560px; width: calc(92vw - 10px); }
  #modal-login .login-titlebar{ font-size: 44px; }

  #modal-login .login-grid{ grid-template-columns: 1fr; }
  #modal-login .login-label{ font-size: 22px; font-weight: 400; }
  #modal-login .login-input{ height: 46px; font-size: 18px; }

  #modal-login .login-pass-row{ grid-template-columns: 1fr; }
  #modal-login .login-btn-mostrar{ height: 46px; font-size: 18px; }

  #modal-login .login-actions--v3{ grid-template-columns: 1fr; }
  #modal-login .login-actions--v3 .login-action-btn,
  #modal-login .login-actions--v3 .login-btn-enter{
    height: 54px;
    font-size: 22px;
  }
}

/* =====================================================
   Modal: Password esquecida (modal-forgot)
   ===================================================== */
.modal-content.modal-forgot{
  max-width: 500px;
  width: calc(90vw - 20px);
  background: var(--modal-bg, #e9e6e6);
  border: 1px solid rgba(0,0,0,.35);
  padding: 18px 16px 14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

.forgot-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.forgot-titlebar{
  flex:1;
  text-align:center;
  background:#4c654f;
  color:#fff;
  padding:12px 18px;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: .5px;
  border-radius: 10px;
}

.forgot-grid{
  display:grid;
  grid-template-columns: 90px 1fr;
  gap: 18px 18px;
  align-items:center;
  padding-top: 6px;
}

.fg-lab{
  font-size: 18px;
  font-weight: 300;
}

.fg-field{
  display:flex;
  gap: 12px;
  align-items:center;
}

.fg-input{
  width: 100%;
  height: 38px;
  font-size: 18px;
  padding: 8px 12px;
  border: 1px solid rgba(0,0,0,.35);
  background: #fff;
  box-sizing: border-box;
  border-radius: 10px;
}

.fg-question{
  width: 100%;
  min-height: 38px;
  font-size: 18px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.25);
  background: #eee;
  box-sizing: border-box;
  border-radius: 10px;
}

.fg-wide{ max-width: 100%; }

.forgot-actions{
  display:flex;
  justify-content:center;
  padding: 22px 0 6px;
}

.forgot-btn-main{
  font-size: 18px;
  padding: 14px 24px;
  border-radius: 28px;
}

/* Responsive forgot */
@media (max-width: 700px){
  .forgot-titlebar{ font-size: 34px; }
  .forgot-grid{ grid-template-columns: 60px 1fr; }
  .fg-lab{ font-size: 18px; }
  .fg-input, .fg-question{ font-size: 18px; height: 44px; }
  .forgot-btn-main{ font-size: 18px; }
}

/* =====================================================
   Mini-modal: Pedido de registo (modal-request-user)
   ===================================================== */
.modal-content.modal-request-user{
  max-width: 520px;
  width: min(92vw, 520px);
  background: var(--modal-bg, #e9e6e6);
  border: 1px solid rgba(0,0,0,.35);
  padding: 18px 16px 14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

#modal-request-user .login-top{
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 12px;
  align-items: start;
  margin-bottom: 12px;
}

#modal-request-user .login-titlebar{
  background: #4c654f;
  color:#fff;
  padding: 10px 12px;
  font-size: 34px;
  line-height: 1.05;
  font-weight: 300;
  text-align: center;
  border-radius: 10px;
}

#modal-request-user .login-grid{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 10px 12px;
  align-items:center;
  margin-top: 10px;
}

#modal-request-user .login-label{
  font-size: 18px;
  font-weight: 500;
}

#modal-request-user .login-input{
  height: 40px;
  font-size: 16px;
  padding: 8px 10px;
  border: 2px solid rgba(0,0,0,.25);
  border-radius: 12px;
  background:#fff;
  box-sizing: border-box;
}
