@import url("https://fonts.googleapis.com/css?family=Poppins:400,700&display=swap");

/* Reset and base styles */
* {
    box-sizing: border-box;
}

/* Main body and background */
html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

.login-pf body {
    background: url("../img/mediquest-bg.png") no-repeat center center fixed;
    background-size: cover;
    font-family: 'Poppins', sans-serif;
}

.login-pf-page {
    padding: 2rem;
}

/* Header with logo */
#kc-header {
    text-align: center;
    margin-bottom: 30px;
    padding: 0;
}

#kc-header img {
    max-width: 300px;
    width: 100%;
    height: auto;
}

/* Main card container */
.card-pf {
    background: #ffffff !important;
    margin: 0 auto !important;
    padding: 40px !important;
    max-width: 450px !important;
    width: 90% !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08) !important;
    border: 1px solid #e0e0e0 !important;
}

/* Page title */
#kc-page-title {
    color: #333333 !important;
    font-size: 24px !important;
    font-weight: 400 !important;
    text-align: center !important;
    margin: 0 0 30px 0 !important;
    font-family: 'Poppins', sans-serif !important;
}

/* Form groups */
.pf-c-form__group,
.form-group {
    margin-bottom: 20px !important;
    width: 100% !important;
}

/* Labels */
.pf-c-form__label,
.control-label,
.pf-v5-c-check__label,
label {
    display: flex !important;
    color: #333333 !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    margin-bottom: 8px !important;
    font-family: 'Poppins', sans-serif !important;
}

/* Input fields */
.pf-c-form__group input[type="text"],
.pf-c-form__group input[type="password"],
.pf-c-form__group input[type="email"] {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 1px solid #d0d0d0 !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    font-family: 'Poppins', sans-serif !important;
    background-color: #ffffff !important;
    transition: border-color 0.3s ease !important;
    box-sizing: border-box !important;
    height: auto !important;
    line-height: normal !important;
}

.pf-c-form-control:focus,
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus {
    outline: none !important;
    border-color: #6e52b5 !important;
}

/* Password input group with visibility toggle */
.pf-c-input-group {
    position: relative !important;
    display: flex !important;
    width: 100% !important;
}

.pf-c-input-group .pf-c-form-control {
    padding-right: 45px !important;
}

.pf-c-input-group .pf-c-button {
    position: absolute !important;
    right: 1px !important;
    top: 1px !important;
    bottom: 1px !important;
    background: #f8f8f8 !important;
    border: none !important;
    border-left: 1px solid #d0d0d0 !important;
    border-radius: 0 3px 3px 0 !important;
    padding: 0 15px !important;
    color: #666666 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.pf-c-input-group .pf-c-button:hover {
    background: #eeeeee !important;
}

/* Remember me checkbox */
.checkbox,
.pf-c-check {
    margin: 15px 0 !important;
}

.checkbox label,
.pf-c-check__label {
    display: inline-flex !important;
    align-items: center !important;
    color: #666666 !important;
    font-size: 14px !important;
    font-weight: normal !important;
    cursor: pointer !important;
}

.checkbox input[type="checkbox"],
.pf-c-check__input {
    margin-right: 8px !important;
    cursor: pointer !important;
}

/* Forgot password link and options */
#kc-form-options {
    margin-bottom: 10px !important;
}

/* Form settings wrapper that contains remember me and forgot password */
.login-pf-settings {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 20px !important;
}

/* Target the forgot password wrapper - it's the div after #kc-form-options */
#kc-form-options + div {
    text-align: right !important;
    display: block !important;
    margin-top: -30px !important;
    margin-bottom: 20px !important;
}

/* Also target by class if it exists */
.kcFormOptionsWrapperClass,
div[class*="kcFormOptionsWrapper"] {
    text-align: right !important;
    display: block !important;
    margin-top: -30px !important;
    margin-bottom: 20px !important;
}

/* Forgot password link styling - target any link in the div after form options */
#kc-form-options + div a,
#kc-form-options + div span a,
.kcFormOptionsWrapperClass a,
.login-pf-settings a {
    color: #0099d3 !important;
    font-size: 13px !important;
    text-decoration: none !important;
    display: inline-block !important;
    visibility: visible !important;
}

#kc-form-options + div a:hover,
.kcFormOptionsWrapperClass a:hover,
.login-pf-settings a:hover {
    text-decoration: underline !important;
}

/* Submit button */
#kc-form-buttons {
    margin-top: 30px !important;
}

.pf-c-button.pf-m-primary,
#kc-login,
input[type="submit"] {
    width: 100% !important;
    padding: 12px 20px !important;
    background: #64539e !important;
    border: none !important;
    border-radius: 4px !important;
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    font-family: 'Poppins', sans-serif !important;
    cursor: pointer !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.pf-c-button.pf-m-primary:hover,
#kc-login:hover,
input[type="submit"]:hover {
    background: #553e8c !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(100, 83, 158, 0.3) !important;
}

.pf-c-button.pf-m-primary:active,
#kc-login:active {
    background: #4a3579 !important;
    transform: translateY(0) !important;
}

/* Alert messages and info boxes */
.alert,
.pf-c-alert {
    padding: 12px 16px !important;
    border-radius: 6px !important;
    margin-bottom: 20px !important;
    font-size: 14px !important;
}

.alert-error,
.pf-c-alert.pf-m-danger {
    background-color: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    color: #dc2626 !important;
}

.alert-warning,
.pf-c-alert.pf-m-warning {
    background-color: #fffbeb !important;
    border: 1px solid #fbbf24 !important;
    color: #92400e !important;
}

.alert-success,
.pf-c-alert.pf-m-success {
    background-color: #dcfce7 !important;
    border: 1px solid #86efac !important;
    color: #166534 !important;
}

.alert-info,
.pf-c-alert.pf-m-info {
    background-color: #e0f2fe !important;
    border: 1px solid #7dd3fc !important;
    color: #075985 !important;
}

/* Social login section */
#kc-social-providers {
    margin-top: 30px !important;
    padding-top: 20px !important;
    border-top: 1px solid #e0e0e0 !important;
}

#kc-social-providers h2,
#kc-social-providers h4 {
    color: #666666 !important;
    font-size: 14px !important;
    font-weight: normal !important;
    text-align: center !important;
    margin-bottom: 15px !important;
}

#kc-social-providers ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

#kc-social-providers li {
    margin-bottom: 10px !important;
}

#kc-social-providers a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px !important;
    background: #f8f8f8 !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 4px !important;
    color: #333333 !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

#kc-social-providers a:hover {
    background: #eeeeee !important;
}

/* Registration link */
#kc-registration {
    text-align: center !important;
    margin-top: 20px !important;
    padding-top: 20px !important;
    border-top: 1px solid #e0e0e0 !important;
}

#kc-registration span {
    color: #666666 !important;
    font-size: 14px !important;
}

#kc-registration a {
    color: #0099d3 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

#kc-registration a:hover {
    text-decoration: underline !important;
}

/* Locale dropdown */
#kc-locale {
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 1000;
}

#kc-locale-dropdown {
    position: relative;
}

#kc-current-locale-link {
    color: #666666;
    text-decoration: none;
    padding: 8px 12px;
    display: inline-block;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 4px;
}

#kc-locale ul {
    display: none;
    position: absolute;
    right: 0;
    top: 100%;
    background: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    list-style: none;
    padding: 0;
    margin: 5px 0 0 0;
    min-width: 120px;
}

#kc-locale:hover ul {
    display: block;
}

#kc-locale ul li a {
    display: block;
    padding: 10px 15px;
    color: #333333;
    text-decoration: none;
}

#kc-locale ul li a:hover {
    background: #f8f8f8;
}

/* Hide unnecessary elements */
.pf-c-alert__icon {
    display: none !important;
}

/* Responsive design */
@media (max-width: 480px) {
    .card-pf {
        padding: 30px 20px !important;
        margin: 20px !important;
        width: calc(100% - 40px) !important;
    }

    #kc-header img {
        max-width: 200px;
    }

    #kc-page-title {
        font-size: 20px !important;
    }
}

/* Remove all PatternFly specific overrides that might interfere */
.pf-c-page__main,
.pf-c-page__main-section,
.pf-l-bullseye,
.pf-l-bullseye__item {
    background: transparent !important;
}

/* Ensure clean form layout */
#kc-form-wrapper {
    width: 100% !important;
}

#kc-form {
    width: 100% !important;
}

#kc-form-login {
    width: 100% !important;
}

/* Fix any layout issues with column classes */
.col-xs-12,
.col-sm-12,
.col-md-12,
.col-lg-12 {
    width: 100% !important;
    padding: 0 !important;
}

/* Ensure proper vertical spacing */
#kc-content-wrapper {
    display: block !important;
}

/* Additional fixes for input group layout */
.form-group:has(.pf-c-input-group) {
    margin-bottom: 20px !important;
}

/* Ensure the form container doesn't have extra padding */
#kc-form-wrapper > * {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
