/* ===== LOGIN ===== */

:root{
  --login-bg: rgba(15, 15, 15, 0.95);
  --login-border: rgba(255, 210, 125, 0.15);
  --accent-gold: #ffd27d;
  --accent-red: #8a0000;
}

.login-section{
  min-height: 85vh;
  padding: 20px 0;
  display:flex;
  align-items:center;
}

.login-wrapper{
  max-width: 450px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}

/* Brilho de fundo */
.login-wrapper::before{
  content:'';
  position:absolute;
  top:50%; left:50%;
  transform: translate(-50%, -50%);
  width:120%;
  height:120%;
  background: radial-gradient(circle, rgba(138,0,0,0.25) 0%, transparent 70%);
  filter: blur(40px);
  z-index:0;
  pointer-events:none;
}

.login-card{
  position:relative;
  z-index:1;
  background: var(--login-bg);
  border: 1px solid var(--login-border);
  border-top: 3px solid var(--accent-gold);
  border-radius: 16px;
  padding: 40px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.7);
  backdrop-filter: blur(10px);
}

.login-header{
  text-align:center;
  margin-bottom: 22px;
}

.login-icon-circle{
  width:80px;
  height:80px;
  margin:0 auto 15px;
  background:#000;
  border:2px solid var(--accent-gold);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow: 0 0 25px rgba(255, 210, 125, 0.15);
  padding:5px;
}

.login-icon-circle img{
  width:100%;
  height:100%;
  object-fit: contain;
  border-radius:50%;
}

.login-header h1{
  font-family: var(--font-title);
  font-size: 24px;
  color:#fff;
  text-transform: uppercase;
  margin:0;
  letter-spacing:1px;
}

.login-header p{
  color:#999;
  font-size:14px;
  margin-top:5px;
  font-weight:400;
}

/* Alerts */
.login-alert{
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 13px;
  margin-bottom: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.85);
}
.login-alert.success{
  border-color: rgba(34,197,94,0.25);
  background: rgba(34,197,94,0.08);
}
.login-alert.error{
  border-color: rgba(239,68,68,0.25);
  background: rgba(239,68,68,0.08);
}

/* Inputs */
.form-group{ margin-bottom: 18px; }
.form-label{
  display:block;
  font-size: 11px;
  font-weight:700;
  text-transform: uppercase;
  color:#aaa;
  margin-bottom: 8px;
  letter-spacing: .5px;
}

.input-box{
  display:flex;
  align-items:center;
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  transition: all .3s ease;
  overflow:hidden;
}
.input-box:focus-within{
  border-color: var(--accent-gold);
  box-shadow: 0 0 15px rgba(255, 210, 125, 0.15);
  background: rgba(0,0,0,0.6);
}
.input-box.is-invalid{
  border-color: rgba(239,68,68,0.55);
  box-shadow: 0 0 0 2px rgba(239,68,68,0.10);
}

.input-icon{
  width:45px;
  text-align:center;
  color:#555;
  font-size:18px;
  border-right: 1px solid rgba(255,255,255,0.05);
  transition:.3s;
}
.input-box:focus-within .input-icon{ color: var(--accent-gold); }

.form-control-custom{
  width:100%;
  background: transparent;
  border:none;
  color:#fff;
  padding: 12px 15px;
  outline: none;
  font-size: 14px;
}

.btn-toggle-pass{
  background: transparent;
  border:none;
  color:#666;
  padding: 0 15px;
  cursor:pointer;
  transition:.3s;
}
.btn-toggle-pass:hover{ color:#fff; }

.field-error{
  margin-top:8px;
  font-size: 12px;
  color: rgba(239,68,68,0.9);
}

/* Links */
.auth-links{
  display:flex;
  justify-content: space-between;
  font-size:13px;
  margin-bottom: 22px;
  padding: 0 2px;
}
.auth-links a{
  color: rgba(255,255,255,0.8);
  text-decoration:none;
  transition:.2s;
}
.auth-links a:hover{
  color:#fff;
  text-decoration: underline;
}

/* Botão */
.btn-login{
  width:100%;
  padding: 14px;
  background: linear-gradient(90deg, #600000, #8a0000);
  border: 1px solid #ff3333;
  color:#fff;
  font-weight: 800;
  text-transform: uppercase;
  border-radius: 8px;
  letter-spacing: 1px;
  transition:.3s;
  box-shadow: 0 5px 15px rgba(138,0,0,0.3);
}
.btn-login:hover{
  background: linear-gradient(90deg, #8a0000, #a00000);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(138,0,0,0.5);
  color:#fff;
}

.btn-register-link{
  text-align:center;
  display:block;
  margin-top: 18px;
  font-size: 13px;
  color:#777;
  text-decoration:none;
}
.btn-register-link strong{ color:#fff; }
.btn-register-link:hover strong{ color: var(--accent-gold); }

.login-foot{
  text-align:center;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.login-download-link{
  text-decoration:none;
  color: rgba(255,255,255,0.55);
  font-size: 12px;
}
.login-download-link:hover{
  color: rgba(255,255,255,0.9);
}

@media (max-width: 576px){
  .login-card{ padding: 30px 20px; }
  .login-header h1{ font-size: 22px; }
  .form-control-custom{ padding: 14px 10px; font-size: 15px; }
  .btn-login{ padding: 16px; font-size: 14px; }
  .auth-links{ flex-direction: column; gap: 8px; align-items:flex-start; }
}
