/* ============================================================
   Veloblock — Auth Pages Enhancement (login / register)
   ============================================================ */

:root {
  --vb-bg:      #04080f;
  --vb-surface: #080e1a;
  --vb-border:  rgba(255,255,255,0.07);
  --vb-primary: #3b82f6;
  --vb-text:    #f1f5f9;
  --vb-muted:   #64748b;
  --vb-dim:     #94a3b8;
  --vb-r:       12px;
}

/* Body & background */
body.nk-body {
  background: var(--vb-bg) !important;
  font-family: 'Inter', -apple-system, sans-serif !important;
}
body.nk-body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(59,130,246,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 80% 80%, rgba(99,102,241,0.06) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.nk-app-root { position: relative; z-index: 1; }

/* Wrapper */
.nk-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.nk-block-middle { width: 100%; max-width: 440px; }

/* Brand logo */
.brand-logo { margin-bottom: 28px !important; }
.brand-logo a img { height: 40px; filter: brightness(1.3); }

/* Card */
.card-bordered {
  background: var(--vb-surface) !important;
  border: 1px solid var(--vb-border) !important;
  border-radius: var(--vb-r) !important;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 60px rgba(59,130,246,0.06) !important;
  overflow: hidden;
}
.card-inner-lg { padding: 32px !important; }

/* Block head */
.nk-block-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--vb-text) !important;
  letter-spacing: -0.3px;
  margin-bottom: 4px !important;
}
.nk-block-des p {
  color: var(--vb-muted) !important;
  font-size: 13.5px !important;
}

/* Labels */
.form-label {
  color: var(--vb-dim) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  margin-bottom: 6px !important;
}
.text-soft { color: var(--vb-muted) !important; font-size: 12.5px !important; }

/* Inputs */
.form-control {
  background: rgba(13,21,38,0.7) !important;
  border: 1px solid var(--vb-border) !important;
  color: var(--vb-text) !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-size: 13.5px !important;
  transition: all 0.22s ease !important;
  height: auto !important;
}
.form-control:focus {
  border-color: rgba(59,130,246,0.5) !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.12) !important;
  background: rgba(13,21,38,1) !important;
  color: var(--vb-text) !important;
  outline: none !important;
}
.form-control::placeholder { color: var(--vb-muted) !important; }
.form-control.form-control-lg {
  padding: 11px 14px !important;
  font-size: 13.5px !important;
}

/* Password toggle */
.form-icon.form-icon-right {
  right: 10px !important;
  color: var(--vb-muted) !important;
}

/* Select */
.form-control.form-select { appearance: auto !important; }
select.form-control option { background: #0d1526; color: var(--vb-text); }

/* Primary button */
.btn-primary, .btn.btn-primary {
  background: linear-gradient(135deg, var(--vb-primary), #6366f1) !important;
  border: none !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  padding: 11px 24px !important;
  border-radius: 8px !important;
  transition: all 0.22s ease !important;
  box-shadow: 0 4px 14px rgba(59,130,246,0.28) !important;
  cursor: pointer;
}
.btn-primary:hover, .btn.btn-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(59,130,246,0.42) !important;
}
.btn-block { width: 100% !important; }

/* Form group spacing */
.form-group { margin-bottom: 18px !important; }

/* Checkbox */
.custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--vb-primary) !important;
  border-color: var(--vb-primary) !important;
}
.custom-control-label { color: var(--vb-dim) !important; font-size: 12.5px !important; cursor: pointer; }

/* Footer note */
.form-note-s2 { color: var(--vb-muted) !important; font-size: 13px !important; }
.form-note-s2 a, .link-primary { color: var(--vb-primary) !important; font-weight: 600; }
.form-note-s2 a:hover { color: #60a5fa !important; }

/* Forgot code link */
.link.link-primary { color: var(--vb-primary) !important; font-size: 12.5px !important; }

/* Error message */
.text-center[style*="color: red"] {
  color: #ef4444 !important;
  background: rgba(239,68,68,0.08) !important;
  border: 1px solid rgba(239,68,68,0.2) !important;
  border-radius: 8px !important;
  padding: 10px !important;
  font-size: 13px !important;
}

/* Top bar of card accent */
.card-bordered::before {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--vb-primary), #6366f1, transparent);
}

/* Remember me row */
.account__check, .form-control-group { margin: 12px 0 !important; }
.form-control-group.d-flex { align-items: center !important; }

/* Passcode switch icons */
.passcode-icon { color: var(--vb-muted) !important; }

/* NioIcon custom icons */
.ni { color: var(--vb-muted); }
