/* =================================================================== */
/*      PROFESSIONAL LOGIN PAGE - AMI SAUDI ARABIA                     */
/*      Version: 1.1 - Fixed Layout & Scrolling                        */
/* =================================================================== */

:root {
  --login-primary: #009055;
  --login-primary-dark: #006b3f;
  --login-primary-light: #00b36b;
  --login-secondary: #1a1f36;
  --login-accent: #00d4aa;
  --login-gold: #d4af37;
  --login-white: #ffffff;
  --login-light: #f8faf9;
  --login-gray: #6c757d;
  --login-dark: #0f1219;
  --login-gradient: linear-gradient(135deg, var(--login-primary) 0%, var(--login-primary-dark) 100%);
  --login-gradient-dark: linear-gradient(135deg, var(--login-secondary) 0%, var(--login-dark) 100%);
  --login-shadow: 0 25px 80px rgba(0, 0, 0, 0.35);
  --login-shadow-sm: 0 10px 40px rgba(0, 144, 85, 0.15);
  --login-radius: 24px;
  --login-radius-sm: 12px;
  --login-transition: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* =================================================================== */
/*      CRITICAL: Fix Body & HTML for proper scrolling                  */
/* =================================================================== */

html {
  height: auto !important;
  min-height: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

body.login-page {
  min-height: 100vh !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  font-family: 'Inter', 'Segoe UI', sans-serif !important;
  background: var(--login-gradient-dark) !important;
  position: relative !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* =================================================================== */
/*      ANIMATED BACKGROUND - Fixed POSITION                            */
/* =================================================================== */

.login-bg-animation {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* Gradient Orbs */
.login-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  animation: float-orb 20s ease-in-out infinite;
}

.login-orb-1 {
  width: 500px;
  height: 500px;
  background: var(--login-primary);
  top: -150px;
  left: -150px;
  animation-delay: 0s;
}

.login-orb-2 {
  width: 400px;
  height: 400px;
  background: var(--login-accent);
  bottom: -100px;
  right: -100px;
  animation-delay: -7s;
}

.login-orb-3 {
  width: 300px;
  height: 300px;
  background: var(--login-gold);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation-delay: -14s;
  opacity: 0.3;
}

@keyframes float-orb {
  0%, 100% {
    transform: translate(0, 0) scale(1);
  }

  25% {
    transform: translate(30px, -30px) scale(1.05);
  }

  50% {
    transform: translate(0, -50px) scale(0.98);
  }

  75% {
    transform: translate(-30px, -20px) scale(1.02);
  }
}

/* Grid Pattern */
.login-grid-pattern {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: linear-gradient(rgba(0, 144, 85, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(0, 144, 85, 0.03) 1px, transparent 1px);
  background-size: 50px 50px;
  animation: grid-move 20s linear infinite;
}

@keyframes grid-move {
  0% {
    transform: translate(0, 0);
  }

  100% {
    transform: translate(50px, 50px);
  }
}

/* Floating Particles */
.login-particles {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.login-particle {
  position: absolute;
  width: 4px;
  height: 4px;
  background: var(--login-primary);
  border-radius: 50%;
  opacity: 0.6;
  animation: particle-float 15s infinite ease-in-out;
}

@keyframes particle-float {
  0%, 100% {
    transform: translateY(100vh) rotate(0deg);
    opacity: 0;
  }

  10% {
    opacity: 0.6;
  }

  90% {
    opacity: 0.6;
  }

  100% {
    transform: translateY(-100vh) rotate(720deg);
    opacity: 0;
  }
}

/* =================================================================== */
/*      HEADER                                                          */
/* =================================================================== */

.login-header {
  position: relative !important;
  z-index: 10 !important;
  padding: 15px 0 !important;
  flex-shrink: 0 !important;
}

.login-header-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.login-logo img {
  height: 50px;
  filter: brightness(0) invert(1);
  transition: var(--login-transition);
}

.login-logo:hover img {
  transform: scale(1.05);
  filter: brightness(0) invert(1) drop-shadow(0 0 20px rgba(0, 144, 85, 0.5));
}

.login-header-info {
  display: flex;
  align-items: center;
  gap: 20px;
}

.login-header-link {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  transition: var(--login-transition);
  padding: 8px 16px;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

  .login-header-link:hover {
    color: var(--login-white);
    background: rgba(0, 144, 85, 0.2);
    border-color: var(--login-primary);
    transform: translateY(-2px);
  }

  .login-header-link i {
    font-size: 14px;
    color: var(--login-primary);
  }

/* =================================================================== */
/*      MAIN CONTENT                                                    */
/* =================================================================== */

.login-main {
  flex: 1 1 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  position: relative !important;
  z-index: 10 !important;
}

.login-container {
  width: 100%;
  max-width: 450px;
}

/* =================================================================== */
/*      LOGIN CARD                                                      */
/* =================================================================== */

.login-card {
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(40px);
  border-radius: var(--login-radius);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: var(--login-shadow);
  overflow: visible;
  animation: card-appear 0.8s ease-out;
}

@keyframes card-appear {
  from {
    opacity: 0;
    transform: translateY(30px) scale(0.95);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Card Header */
.login-card-header {
  text-align: center;
  padding: 25px 25px 15px;
  position: relative;
}

.login-brand-logo {
  margin-bottom: 15px;
}

  .login-brand-logo img {
    height: 55px;
    filter: brightness(0) invert(1);
    transition: var(--login-transition);
  }

.login-card:hover .login-brand-logo img {
  transform: scale(1.05);
}

.login-welcome-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  background: rgba(0, 144, 85, 0.15);
  border-radius: 50px;
  color: var(--login-accent);
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 15px;
  border: 1px solid rgba(0, 144, 85, 0.3);
}

  .login-welcome-badge i {
    animation: wave 2s infinite;
  }

@keyframes wave {
  0%, 100% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(20deg);
  }

  75% {
    transform: rotate(-20deg);
  }
}

.login-title {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--login-white);
  margin: 0 0 6px 0;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.login-subtitle {
  color: rgba(255, 255, 255, 0.6);
  font-size: 13px;
  margin: 0;
}

/* Card Body */
.login-card-body {
  padding: 10px 25px 25px;
}

/* Serenity Login Panel Override */
#LoginPanel {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

  #LoginPanel .s-Panel {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  #LoginPanel .s-PanelTitle {
    display: none !important;
  }

  #LoginPanel .s-Form {
    padding: 0 !important;
  }

  #LoginPanel .field {
    margin-bottom: 16px !important;
  }

    #LoginPanel .field label,
    #LoginPanel .caption {
      color: rgba(255, 255, 255, 0.8) !important;
      font-weight: 600 !important;
      font-size: 13px !important;
      margin-bottom: 8px !important;
      display: block !important;
    }

  #LoginPanel input[type="text"],
  #LoginPanel input[type="password"],
  #LoginPanel .s-StringEditor,
  #LoginPanel .s-PasswordEditor {
    width: 100% !important;
    padding: 14px 18px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 2px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: var(--login-radius-sm) !important;
    color: var(--login-white) !important;
    font-size: 14px !important;
    transition: var(--login-transition) !important;
    outline: none !important;
    text-align: left !important;
  }

[dir="rtl"] #LoginPanel input[type="text"],
[dir="rtl"] #LoginPanel input[type="password"],
html[lang^="ar"] #LoginPanel input[type="text"],
html[lang^="ar"] #LoginPanel input[type="password"] {
  text-align: right !important;
}

#LoginPanel input[type="text"]:focus,
#LoginPanel input[type="password"]:focus,
#LoginPanel .s-StringEditor:focus,
#LoginPanel .s-PasswordEditor:focus {
  border-color: var(--login-primary) !important;
  background: rgba(0, 144, 85, 0.1) !important;
  box-shadow: 0 0 0 4px rgba(0, 144, 85, 0.15) !important;
}

#LoginPanel input::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
  text-align: left !important;
}

[dir="rtl"] #LoginPanel input::placeholder,
html[lang^="ar"] #LoginPanel input::placeholder {
  text-align: right !important;
}

/* Light mode inputs */
[data-bs-theme="light"] #LoginPanel input[type="text"],
[data-bs-theme="light"] #LoginPanel input[type="password"] {
  background: var(--login-white) !important;
  border-color: rgba(0, 144, 85, 0.2) !important;
  color: var(--login-secondary) !important;
}

[data-bs-theme="light"] #LoginPanel input::placeholder {
  color: rgba(0, 0, 0, 0.4) !important;
}

/* =================================================================== */
/*      FORM FIELD CONTAINER                                            */
/* =================================================================== */

#LoginPanel .field,
#LoginPanel .s-PropertyItem {
  margin-bottom: 18px !important;
  text-align: left !important;
}

[dir="rtl"] #LoginPanel .field,
[dir="rtl"] #LoginPanel .s-PropertyItem,
html[lang^="ar"] #LoginPanel .field,
html[lang^="ar"] #LoginPanel .s-PropertyItem {
  text-align: right !important;
}

/* =================================================================== */
/*      CHECKBOX (Remember Me)                                          */
/* =================================================================== */

#LoginPanel .check-box,
#LoginPanel input[type="checkbox"] {
  accent-color: var(--login-primary) !important;
}

#LoginPanel .field:has(input[type="checkbox"]) {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

  #LoginPanel .field:has(input[type="checkbox"]) label {
    margin-bottom: 0 !important;
    display: inline !important;
    width: auto !important;
  }

/* =================================================================== */
/*      HEADER                                                          */
/* =================================================================== */

.login-header {
  position: relative !important;
  z-index: 10 !important;
  padding: 15px 0 !important;
  flex-shrink: 0 !important;
}

.login-header-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.login-logo img {
  height: 50px;
  filter: brightness(0) invert(1);
  transition: var(--login-transition);
}

.login-logo:hover img {
  transform: scale(1.05);
  filter: brightness(0) invert(1) drop-shadow(0 0 20px rgba(0, 144, 85, 0.5));
}

.login-header-info {
  display: flex;
  align-items: center;
  gap: 20px;
}

.login-header-link {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  transition: var(--login-transition);
  padding: 8px 16px;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

  .login-header-link:hover {
    color: var(--login-white);
    background: rgba(0, 144, 85, 0.2);
    border-color: var(--login-primary);
    transform: translateY(-2px);
  }

  .login-header-link i {
    font-size: 14px;
    color: var(--login-primary);
  }

/* =================================================================== */
/*      MAIN CONTENT                                                    */
/* =================================================================== */

.login-main {
  flex: 1 1 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  position: relative !important;
  z-index: 10 !important;
}

.login-container {
  width: 100%;
  max-width: 450px;
}

/* =================================================================== */
/*      LOGIN CARD                                                      */
/* =================================================================== */

.login-card {
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(40px);
  border-radius: var(--login-radius);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: var(--login-shadow);
  overflow: visible;
  animation: card-appear 0.8s ease-out;
}

@keyframes card-appear {
  from {
    opacity: 0;
    transform: translateY(30px) scale(0.95);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Card Header */
.login-card-header {
  text-align: center;
  padding: 25px 25px 15px;
  position: relative;
}

.login-brand-logo {
  margin-bottom: 15px;
}

  .login-brand-logo img {
    height: 55px;
    filter: brightness(0) invert(1);
    transition: var(--login-transition);
  }

.login-card:hover .login-brand-logo img {
  transform: scale(1.05);
}

.login-welcome-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  background: rgba(0, 144, 85, 0.15);
  border-radius: 50px;
  color: var(--login-accent);
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 15px;
  border: 1px solid rgba(0, 144, 85, 0.3);
}

  .login-welcome-badge i {
    animation: wave 2s infinite;
  }

@keyframes wave {
  0%, 100% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(20deg);
  }

  75% {
    transform: rotate(-20deg);
  }
}

.login-title {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--login-white);
  margin: 0 0 6px 0;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.login-subtitle {
  color: rgba(255, 255, 255, 0.6);
  font-size: 13px;
  margin: 0;
}

/* Card Body */
.login-card-body {
  padding: 10px 25px 25px;
}

/* Serenity Login Panel Override */
#LoginPanel {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

  #LoginPanel .s-Panel {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  #LoginPanel .s-PanelTitle {
    display: none !important;
  }

  #LoginPanel .s-Form {
    padding: 0 !important;
  }

  #LoginPanel .field {
    margin-bottom: 16px !important;
  }

    #LoginPanel .field label,
    #LoginPanel .caption {
      color: rgba(255, 255, 255, 0.8) !important;
      font-weight: 600 !important;
      font-size: 13px !important;
      margin-bottom: 8px !important;
      display: block !important;
    }

/* =================================================================== */
/*      SECURITY BADGE - CENTERED                                       */
/* =================================================================== */

.login-security {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin-top: 20px !important;
  padding: 12px !important;
  background: rgba(0, 144, 85, 0.1) !important;
  border-radius: var(--login-radius-sm) !important;
  border: 1px solid rgba(0, 144, 85, 0.2) !important;
  text-align: center !important;
}

  .login-security i {
    color: var(--login-primary) !important;
    font-size: 18px !important;
    flex-shrink: 0 !important;
  }

  .login-security span {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 12px !important;
  }

[data-bs-theme="light"] .login-security span {
  color: var(--login-gray) !important;
}

/* =================================================================== */
/*      HIDE DUPLICATE PANEL TITLE FROM SERENITY (Inside Panel Only)   */
/* =================================================================== */

/* Hide title ONLY inside the LoginPanel (not the page title) */
#LoginPanel .s-PanelTitle,
#LoginPanel .s-Panel > .panel-titlebar,
#LoginPanel .panel-titlebar,
#LoginPanel .s-Panel h5:first-of-type,
#LoginPanel > .s-Panel > .s-PanelBody > h5:first-child,
#LoginPanel .s-PanelBody > h5:first-child,
#LoginPanel .card-header,
#LoginPanel .panel-title {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* =================================================================== */
/*      FORM LABELS - ALIGN LEFT                                        */
/* =================================================================== */

#LoginPanel .field label,
#LoginPanel .caption,
#LoginPanel .s-PropertyItem > label,
#LoginPanel .s-PropertyGrid label {
  color: rgba(255, 255, 255, 0.85) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  margin-bottom: 8px !important;
  display: block !important;
  text-align: left !important;
  width: 100% !important;
}

/* RTL Support */
[dir="rtl"] #LoginPanel .field label,
[dir="rtl"] #LoginPanel .caption,
html[lang^="ar"] #LoginPanel .field label,
html[lang^="ar"] #LoginPanel .caption {
  text-align: right !important;
}

/* Light mode labels */
[data-bs-theme="light"] #LoginPanel .field label,
[data-bs-theme="light"] #LoginPanel .caption {
  color: var(--login-secondary) !important;
}

/* =================================================================== */
/*      FORM INPUTS                                                     */
/* =================================================================== */

#LoginPanel input[type="text"],
#LoginPanel input[type="password"],
#LoginPanel .s-StringEditor,
#LoginPanel .s-PasswordEditor {
  width: 100% !important;
  padding: 14px 18px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 2px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: var(--login-radius-sm) !important;
  color: var(--login-white) !important;
  font-size: 14px !important;
  transition: var(--login-transition) !important;
  outline: none !important;
  text-align: left !important;
}

[dir="rtl"] #LoginPanel input[type="text"],
[dir="rtl"] #LoginPanel input[type="password"],
html[lang^="ar"] #LoginPanel input[type="text"],
html[lang^="ar"] #LoginPanel input[type="password"] {
  text-align: right !important;
}

#LoginPanel input[type="text"]:focus,
#LoginPanel input[type="password"]:focus,
#LoginPanel .s-StringEditor:focus,
#LoginPanel .s-PasswordEditor:focus {
  border-color: var(--login-primary) !important;
  background: rgba(0, 144, 85, 0.1) !important;
  box-shadow: 0 0 0 4px rgba(0, 144, 85, 0.15) !important;
}

#LoginPanel input::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
  text-align: left !important;
}

[dir="rtl"] #LoginPanel input::placeholder,
html[lang^="ar"] #LoginPanel input::placeholder {
  text-align: right !important;
}

/* Light mode inputs */
[data-bs-theme="light"] #LoginPanel input[type="text"],
[data-bs-theme="light"] #LoginPanel input[type="password"] {
  background: var(--login-white) !important;
  border-color: rgba(0, 144, 85, 0.2) !important;
  color: var(--login-secondary) !important;
}

[data-bs-theme="light"] #LoginPanel input::placeholder {
  color: rgba(0, 0, 0, 0.4) !important;
}

/* =================================================================== */
/*      FORM FIELD CONTAINER                                            */
/* =================================================================== */

#LoginPanel .field,
#LoginPanel .s-PropertyItem {
  margin-bottom: 18px !important;
  text-align: left !important;
}

[dir="rtl"] #LoginPanel .field,
[dir="rtl"] #LoginPanel .s-PropertyItem,
html[lang^="ar"] #LoginPanel .field,
html[lang^="ar"] #LoginPanel .s-PropertyItem {
  text-align: right !important;
}

/* =================================================================== */
/*      CHECKBOX (Remember Me)                                          */
/* =================================================================== */

#LoginPanel .check-box,
#LoginPanel input[type="checkbox"] {
  accent-color: var(--login-primary) !important;
}

#LoginPanel .field:has(input[type="checkbox"]) {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

  #LoginPanel .field:has(input[type="checkbox"]) label {
    margin-bottom: 0 !important;
    display: inline !important;
    width: auto !important;
  }

/* =================================================================== */
/*      FOOTER                                                          */
/* =================================================================== */

.login-footer {
  position: relative !important;
  z-index: 10 !important;
  padding: 15px 0 !important;
  text-align: center !important;
  border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
  flex-shrink: 0 !important;
}

  .login-footer p {
    color: rgba(255, 255, 255, 0.5);
    font-size: 12px;
    margin: 0 0 8px 0;
  }

  .login-footer a {
    color: var(--login-accent);
    text-decoration: none;
    transition: var(--login-transition);
  }

    .login-footer a:hover {
      color: var(--login-primary-light);
    }

.login-footer-links {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.login-footer-link {
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  font-size: 12px;
  transition: var(--login-transition);
  display: flex;
  align-items: center;
  gap: 5px;
}

  .login-footer-link:hover {
    color: var(--login-primary);
  }

/* =================================================================== */
/*      ALERT STYLES                                                    */
/* =================================================================== */

.login-alert {
  padding: 14px 18px;
  border-radius: var(--login-radius-sm);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  animation: alert-slide 0.5s ease-out;
}

@keyframes alert-slide {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.login-alert-info {
  background: rgba(0, 144, 85, 0.15);
  border: 1px solid rgba(0, 144, 85, 0.3);
  color: var(--login-accent);
}

.login-alert-error {
  background: rgba(220, 53, 69, 0.15);
  border: 1px solid rgba(220, 53, 69, 0.3);
  color: #ff6b6b;
}

.login-alert i {
  font-size: 18px;
}

.login-alert-close {
  margin-left: auto;
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  opacity: 0.7;
  transition: var(--login-transition);
}

  .login-alert-close:hover {
    opacity: 1;
  }

/* =================================================================== */
/*      RESPONSIVE                                                      */
/* =================================================================== */

@media (max-width: 768px) {
  .login-header-info {
    display: none;
  }

  .login-card-header {
    padding: 20px 20px 15px;
  }

  .login-card-body {
    padding: 10px 20px 20px;
  }

  .login-title {
    font-size: 1.3rem;
  }

  .login-brand-logo img {
    height: 50px;
  }

  #LoginPanel input[type="text"],
  #LoginPanel input[type="password"] {
    padding: 12px 14px !important;
  }

  #LoginPanel .btn,
  #LoginPanel button[type="submit"] {
    padding: 12px 20px !important;
  }
}

@media (max-width: 480px) {
  .login-container {
    padding: 0 10px;
  }

  .login-card {
    border-radius: 18px;
  }

  .login-title {
    font-size: 1.2rem;
  }

  .login-footer-links {
    flex-direction: column;
    gap: 8px;
  }
}

/* =================================================================== */
/*      LIGHT MODE                                                      */
/* =================================================================== */

[data-bs-theme="light"] body.login-page {
  background: linear-gradient(135deg, #f0f4f3 0%, #e0e8e5 100%) !important;
}

[data-bs-theme="light"] .login-orb {
  opacity: 0.25;
}

[data-bs-theme="light"] .login-card {
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(0, 144, 85, 0.1);
}

[data-bs-theme="light"] .login-title {
  color: var(--login-secondary);
}

[data-bs-theme="light"] .login-subtitle {
  color: var(--login-gray);
}

[data-bs-theme="light"] #LoginPanel .field label,
[data-bs-theme="light"] #LoginPanel .caption {
  color: var(--login-secondary) !important;
}

[data-bs-theme="light"] #LoginPanel input[type="text"],
[data-bs-theme="light"] #LoginPanel input[type="password"] {
  background: var(--login-white) !important;
  border-color: rgba(0, 144, 85, 0.2) !important;
  color: var(--login-secondary) !important;
}

[data-bs-theme="light"] .login-header-link {
  color: var(--login-secondary);
  background: rgba(0, 144, 85, 0.05);
}

[data-bs-theme="light"] .login-logo img {
  filter: none;
}

[data-bs-theme="light"] .login-brand-logo img {
  filter: none;
}

[data-bs-theme="light"] .login-footer p {
  color: var(--login-gray);
}

[data-bs-theme="light"] .login-security span {
  color: var(--login-gray);
}

/* =================================================================== */
/*      ANIMATIONS                                                      */
/* =================================================================== */

.login-fade-in {
  animation: fadeIn 0.6s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.login-slide-up {
  animation: slideUp 0.6s ease-out;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =================================================================== */
/*      THEME TOGGLE BUTTON                                             */
/* =================================================================== */

.login-theme-toggle {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--login-white);
  font-size: 18px;
  cursor: pointer;
  transition: var(--login-transition);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

  .login-theme-toggle:hover {
    background: var(--login-primary);
    border-color: var(--login-primary);
    transform: rotate(180deg) scale(1.1);
  }

  .login-theme-toggle i {
    transition: var(--login-transition);
  }

#theme-icon-light {
  display: none;
  color: #ffc107;
}

#theme-icon-dark {
  display: block;
  color: #a0c4ff;
}

[data-bs-theme="light"] .login-theme-toggle {
  background: rgba(0, 144, 85, 0.1);
  border-color: rgba(0, 144, 85, 0.2);
  color: var(--login-secondary);
}

[data-bs-theme="light"] #theme-icon-light {
  display: none;
}

[data-bs-theme="light"] #theme-icon-dark {
  display: block;
}

/* =================================================================== */
/*      HIDE DUPLICATE PANEL TITLE FROM SERENITY                        */
/* =================================================================== */

/* Hide ALL possible title elements from Serenity LoginPanel */
#LoginPanel .s-PanelTitle,
#LoginPanel .s-Panel > .panel-titlebar,
#LoginPanel .panel-titlebar,
#LoginPanel .s-PanelBody > h5:first-child,
#LoginPanel .card-header,
#LoginPanel > .s-Panel > .s-PanelBody > h5,
#LoginPanel .s-Form > h5,
#LoginPanel .s-PropertyGrid > h5,
#LoginPanel .s-Panel h5,
#LoginPanel h5,
#LoginPanel h4,
#LoginPanel h3,
#LoginPanel .panel-title,
#LoginPanel .card-title,
#LoginPanel .s-PanelBody > *:first-child:not(.s-Form):not(.s-PropertyGrid):not(.field),
#LoginPanel .s-Panel > .s-PanelBody > *:first-child:not(.s-Form):not(.s-PropertyGrid):not(.field) {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

/* Ensure form elements remain visible */
#LoginPanel .s-Form,
#LoginPanel .s-PropertyGrid,
#LoginPanel .field,
#LoginPanel .s-PropertyItem,
#LoginPanel input,
#LoginPanel button,
#LoginPanel .btn,
#LoginPanel label,
#LoginPanel .caption,
#LoginPanel a {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

#LoginPanel .s-Form {
  display: flex !important;
  flex-direction: column !important;
}

#LoginPanel .field {
  display: block !important;
}

/* Remove any top padding/margin that might be left by hidden title */
#LoginPanel .s-PanelBody,
#LoginPanel .s-Panel {
  padding-top: 0 !important;
}

  #LoginPanel .s-PanelBody > .s-Form:first-child,
  #LoginPanel .s-PanelBody > .s-PropertyGrid:first-child {
    margin-top: 0 !important;
  }
