/* =============================================================
   Connect N — Login Page (Lothan branded)
   ============================================================= */

.login-body {
    min-height: 100vh;
    background: var(--lh-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    position: relative;
    overflow: hidden;
}

/* Lothan brand curves in background */
.login-body::before,
.login-body::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.login-body::before {
    width: 700px;
    height: 700px;
    right: -280px;
    top: -300px;
    background: radial-gradient(circle, rgba(195,172,130,0.18) 0%, transparent 65%);
}
.login-body::after {
    width: 500px;
    height: 500px;
    left: -200px;
    bottom: -220px;
    background: radial-gradient(circle, rgba(71,128,205,0.22) 0%, transparent 65%);
}

.login-wrap {
    width: 100%;
    max-width: 440px;
    position: relative;
    z-index: 1;
}

/* Brand lockup above the card */
.login-lockup {
    text-align: center;
    margin-bottom: var(--space-6);
}
.login-lockup-logo {
    width: 96px;
    height: 96px;
    margin: 0 auto var(--space-4);
    filter: drop-shadow(0 4px 16px rgba(0,0,0,0.25));
}
.login-lockup-logo svg { width: 100%; height: 100%; }

.login-lockup-hospital {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    color: white;
    letter-spacing: 0.02em;
    margin-bottom: var(--space-1);
    text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.login-lockup-app {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--lh-gold-200);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
}

/* Login card */
.login-card {
    background: var(--surface-card);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
}

.login-card-header {
    padding: var(--space-6) var(--space-6) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
}
.login-card-title {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    color: var(--text-primary);
    margin-bottom: var(--space-1);
}
.login-card-subtitle {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.login-card-body {
    padding: var(--space-5) var(--space-6) var(--space-6);
}

.login-card-footer {
    padding: var(--space-3) var(--space-6);
    background: var(--surface-sunken);
    border-top: 1px solid var(--border-subtle);
    text-align: center;
    font-size: var(--text-xs);
    color: var(--text-muted);
}

/* Form bits */
.login-field { margin-bottom: var(--space-4); }

.login-field-label {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--text-primary);
}
.login-field-label i { color: var(--lh-gold-dark); font-size: 1rem; }

.login-input-group {
    display: flex;
    align-items: stretch;
    position: relative;
}
.login-input {
    flex: 1;
    min-height: var(--touch-target-comfy);
    padding: var(--space-3) var(--space-4);
    border: 1.5px solid var(--border-default);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    color: var(--text-primary);
    font-size: var(--text-md);
    font-family: var(--font-sans);
    transition: border-color var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-fast) var(--ease-out);
}
.login-input::placeholder { color: var(--text-muted); }
.login-input:hover { border-color: var(--border-strong); }
.login-input:focus {
    outline: none;
    border-color: var(--border-focus);
    box-shadow: var(--shadow-focus);
}

.login-input-group .login-input { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.login-input-toggle {
    padding: 0 var(--space-4);
    border: 1.5px solid var(--border-default);
    border-left: 0;
    background: var(--surface-sunken);
    color: var(--text-secondary);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    cursor: pointer;
    transition: color var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out);
}
.login-input-toggle:hover { color: var(--lh-gold-dark); background: var(--surface-card); }

/* Checkbox row */
.login-check {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
    cursor: pointer;
    font-size: var(--text-sm);
    color: var(--text-secondary);
    user-select: none;
}
.login-check input {
    width: 18px; height: 18px;
    accent-color: var(--lh-gold);
    cursor: pointer;
}

/* Submit button */
.login-submit {
    width: 100%;
    min-height: var(--touch-target-comfy);
    padding: var(--space-3);
    border: 0;
    border-radius: var(--radius-md);
    background: var(--color-action);
    color: var(--color-on-action);
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: var(--weight-semibold);
    letter-spacing: 0.02em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    box-shadow: var(--shadow-sm);
    transition: all var(--duration-fast) var(--ease-out);
}
.login-submit:hover {
    background: var(--color-action-hover);
    box-shadow: var(--shadow-gold);
    transform: translateY(-1px);
}
.login-submit:active { transform: translateY(0); }
.login-submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* Alert banner */
.login-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-urgent-subtle);
    border: 1px solid var(--color-urgent-border);
    border-left: 4px solid var(--color-urgent);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
    color: var(--text-primary);
}
.login-alert i {
    color: var(--color-urgent);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 2px;
}

/* Help link row */
.login-help {
    text-align: center;
    margin-top: var(--space-4);
    font-size: var(--text-sm);
    color: var(--text-muted);
}
.login-help a {
    color: var(--lh-gold-dark);
    font-weight: var(--weight-medium);
}

/* Responsive */
@media (max-width: 479.98px) {
    .login-lockup-logo { width: 72px; height: 72px; }
    .login-lockup-hospital { font-size: var(--text-lg); }
    .login-card-header, .login-card-body { padding-left: var(--space-4); padding-right: var(--space-4); }
}
