/* ═══════════════════════════════════════════════════════════
   FOD IBZ — Login Page Branding
   ═══════════════════════════════════════════════════════════ */

body.login {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  background: #0f0f13 !important;
  position: relative;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
}

body.login::before {
  content: '';
  position: fixed;
  top: -50%;
  left: -20%;
  width: 800px;
  height: 800px;
  background: radial-gradient(circle, rgba(253,218,36,.06), transparent 60%);
  animation: login-glow 8s ease-in-out infinite;
  pointer-events: none;
}

body.login::after {
  content: '';
  position: fixed;
  bottom: -30%;
  right: -10%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(239,51,64,.04), transparent 60%);
  animation: login-glow 8s ease-in-out infinite 4s;
  pointer-events: none;
}

@keyframes login-glow {
  0%, 100% { transform: scale(1); opacity: .5; }
  50%      { transform: scale(1.1); opacity: 1; }
}

/* Belgian flag bar at top */
body.login #login::before {
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  border-radius: 2px;
  margin: 0 auto 30px;
  background: linear-gradient(90deg, #000 33.3%, #FDDA24 33.3% 66.6%, #EF3340 66.6%);
  animation: flag-grow .6s ease-out;
}

@keyframes flag-grow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* Logo */
#login h1 a {
  background-image: url('/wp-content/uploads/2026/01/logo.svg') !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  width: 80px !important;
  height: 80px !important;
  margin-bottom: 8px !important;
  animation: login-logo-in .5s cubic-bezier(.34, 1.56, .64, 1);
}

@keyframes login-logo-in {
  from { transform: scale(.8); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* Title below logo */
#login h1::after {
  content: 'FOD Binnenlandse Zaken';
  display: block;
  color: rgba(255,255,255,.7);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-align: center;
  margin-top: 6px;
}

/* Login form card */
.login form {
  background: #1a1a24 !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  border-radius: 14px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.2) !important;
  padding: 28px 24px 24px !important;
  animation: login-card-in .4s ease-out .1s both;
}

@keyframes login-card-in {
  from { transform: translateY(12px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

/* Labels */
.login form label {
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: .3px;
}

/* Inputs */
.login form input[type="text"],
.login form input[type="password"] {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 8px !important;
  color: #fff !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  font-family: 'Inter', sans-serif !important;
  transition: all .2s cubic-bezier(.4, 0, .2, 1) !important;
}

.login form input[type="text"]:focus,
.login form input[type="password"]:focus {
  border-color: #FDDA24 !important;
  box-shadow: 0 0 0 3px rgba(253,218,36,.12) !important;
  background: rgba(255,255,255,.08) !important;
  outline: none !important;
}

.login form input[type="text"]::placeholder,
.login form input[type="password"]::placeholder {
  color: rgba(255,255,255,.2);
}

/* Show password button */
.login .wp-pwd .button.wp-hide-pw {
  color: rgba(255,255,255,.4) !important;
  background: transparent !important;
  border: none !important;
}

.login .wp-pwd .button.wp-hide-pw:hover {
  color: #FDDA24 !important;
}

/* Remember me */
.login form .forgetmenot label {
  color: rgba(255,255,255,.8) !important;
}

/* Submit button */
.login form .submit input[type="submit"],
.login #wp-submit {
  background: linear-gradient(135deg, #d4a800, #FDDA24) !important;
  border: none !important;
  border-radius: 8px !important;
  color: #0f0f13 !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  padding: 10px 20px !important;
  width: 100% !important;
  cursor: pointer;
  letter-spacing: .3px;
  box-shadow: 0 4px 16px rgba(253,218,36,.2) !important;
  transition: all .2s cubic-bezier(.4, 0, .2, 1) !important;
  text-shadow: none !important;
}

.login form .submit input[type="submit"]:hover,
.login #wp-submit:hover {
  background: linear-gradient(135deg, #FDDA24, #ffe44d) !important;
  box-shadow: 0 6px 24px rgba(253,218,36,.35) !important;
  transform: translateY(-1px);
}

.login form .submit input[type="submit"]:active {
  transform: translateY(0) !important;
}

/* Links below */
#login #nav,
#login #backtoblog {
  padding: 0 24px;
}

#login #nav a,
#login #backtoblog a {
  color: rgba(255,255,255,.7) !important;
  transition: color .2s;
  font-size: 12.5px;
}

#login #nav a:hover,
#login #backtoblog a:hover {
  color: #FDDA24 !important;
}

/* Messages */
.login .message,
.login .success {
  background: rgba(253,218,36,.06) !important;
  border-left: 4px solid #FDDA24 !important;
  border-radius: 8px !important;
  color: rgba(255,255,255,.7) !important;
  padding: 12px 14px !important;
}

.login #login_error {
  background: rgba(239,51,64,.08) !important;
  border-left: 4px solid #EF3340 !important;
  border-radius: 8px !important;
  color: rgba(255,255,255,.7) !important;
}

.login #login_error a {
  color: #ff6b6b !important;
}

/* Privacy policy link */
.login .privacy-policy-page-link {
  margin-top: 16px;
}

.login .privacy-policy-page-link a {
  color: rgba(255,255,255,.5) !important;
  font-size: 11.5px;
}

/* Language switcher */
.language-switcher {
  background: #1a1a24 !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 10px !important;
}

.language-switcher select {
  background: #1a1a24 !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 6px !important;
  padding: 6px 10px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
}

.language-switcher select option {
  background: #1a1a24 !important;
  color: #fff !important;
}

.language-switcher .button {
  background: rgba(255,255,255,.1) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 6px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  transition: all .2s !important;
}

.language-switcher .button:hover {
  background: rgba(255,255,255,.15) !important;
  color: #fff !important;
}
