/* Nuonic Login Theme */

:root {
    --nuonic-primary: #272b5c;
    --nuonic-primary-hover: #1e2249;
    --nuonic-primary-light: #3a3f73;
    --nuonic-bg: #f0f2f5;
    --nuonic-card-bg: #ffffff;
    --nuonic-radius: 16px;
    --nuonic-input-radius: 8px;

    /* PatternFly overrides */
    --pf-v5-global--primary-color--100: #272b5c;
    --pf-v5-global--primary-color--200: #1e2249;
    --pf-v5-global--link--Color: #272b5c;
    --pf-v5-global--link--Color--hover: #3a3f73;
    --pf-v5-global--active-color--100: #272b5c;
}

/* Page background — gradient with subtle pattern */
html, body {
    margin: 0;
    min-height: 100vh;
}

body {
    background:
        radial-gradient(ellipse at 20% 50%, rgba(39, 43, 92, 0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(39, 43, 92, 0.1) 0%, transparent 40%),
        radial-gradient(ellipse at 60% 80%, rgba(39, 43, 92, 0.08) 0%, transparent 45%),
        linear-gradient(135deg, #e8eaf0 0%, #dde1eb 25%, #e4e7f0 50%, #dce0ec 75%, #e8ecf4 100%) !important;
    background-attachment: fixed !important;
}

/* Hide default header chrome */
#kc-header {
    display: none;
}

/* Center the login container */
.pf-v5-c-login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    width: 100%;
    padding: 1rem;
    max-width: 100%;
    background: transparent !important;
}

/* Card wrapper */
.pf-v5-c-login__main {
    width: 100%;
    border-radius: var(--nuonic-radius) !important;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(39, 43, 92, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Card sections */
.pf-v5-c-login__main-header {
    background: var(--nuonic-card-bg) !important;
    padding: 2rem 2.5rem 0 !important;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Logo above the title */
.pf-v5-c-login__main-header::before {
    content: "";
    display: block;
    width: 56px;
    height: 56px;
    margin: 0 auto 1rem;
    background: url("../img/logo.svg") center / contain no-repeat;
}

.pf-v5-c-login__main-body,
.pf-v5-c-card {
    background: var(--nuonic-card-bg) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 1.5rem 2.5rem !important;
    border: none !important;
}

.pf-v5-c-login__main-footer {
    background: var(--nuonic-card-bg) !important;
    padding: 0 2.5rem 2.5rem !important;
}

/* Title */
#kc-page-title {
    color: var(--nuonic-primary);
    font-weight: 700;
    font-size: 1.5rem;
    text-align: center;
    margin-bottom: 0.5rem;
}

/* Form control wrappers (PatternFly wraps inputs in divs) */
.pf-v5-c-form-control {
    --pf-v5-c-form-control--BorderRadius: var(--nuonic-input-radius) !important;
    border-radius: var(--nuonic-input-radius) !important;
    border: 1.5px solid #d1d5db !important;
    background-color: #fff !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    overflow: hidden;
}

.pf-v5-c-form-control::before,
.pf-v5-c-form-control::after {
    display: none !important;
}

.pf-v5-c-form-control:focus-within {
    border-color: var(--nuonic-primary) !important;
    box-shadow: 0 0 0 3px rgba(39, 43, 92, 0.15) !important;
}

.pf-v5-c-form-control input,
.pf-v5-c-form-control select,
.pf-v5-c-form-control textarea {
    padding: 0.625rem 0.875rem !important;
    font-size: 0.9375rem !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
}

/* Input group (password field with toggle) */
.pf-v5-c-input-group {
    border-radius: var(--nuonic-input-radius) !important;
    overflow: hidden;
}

.pf-v5-c-input-group .pf-v5-c-form-control {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-right: none !important;
}

.pf-v5-c-input-group .pf-v5-c-button {
    border-radius: 0 var(--nuonic-input-radius) var(--nuonic-input-radius) 0 !important;
    border: 1.5px solid #d1d5db !important;
    border-left: none !important;
    background: #fff !important;
    color: #6b7280 !important;
}

.pf-v5-c-input-group:focus-within .pf-v5-c-form-control {
    border-color: var(--nuonic-primary) !important;
    box-shadow: 0 0 0 3px rgba(39, 43, 92, 0.15) !important;
}

.pf-v5-c-input-group:focus-within .pf-v5-c-button {
    border-color: var(--nuonic-primary) !important;
    box-shadow: 0 3px 0 -1px rgba(39, 43, 92, 0.15), 3px 0 0 -1px rgba(39, 43, 92, 0.15), 0 -3px 0 -1px rgba(39, 43, 92, 0.15) !important;
}

/* Primary button */
.pf-v5-c-button.pf-m-primary {
    background-color: var(--nuonic-primary) !important;
    border-color: var(--nuonic-primary) !important;
    border-radius: var(--nuonic-input-radius) !important;
    padding: 0.75rem 1.25rem !important;
    font-weight: 600 !important;
    font-size: 0.9375rem !important;
    width: 100%;
    transition: background-color 0.2s ease !important;
}

.pf-v5-c-button.pf-m-primary:hover {
    background-color: var(--nuonic-primary-hover) !important;
    border-color: var(--nuonic-primary-hover) !important;
}

.pf-v5-c-button.pf-m-primary:focus {
    box-shadow: 0 0 0 3px rgba(39, 43, 92, 0.3) !important;
}

/* Links */
a, .pf-v5-c-button.pf-m-link {
    color: var(--nuonic-primary);
}

a:hover, .pf-v5-c-button.pf-m-link:hover {
    color: var(--nuonic-primary-light);
}

/* Alert / error messages */
.pf-v5-c-alert.pf-m-inline.pf-m-danger {
    border-radius: var(--nuonic-input-radius);
}

/* Checkbox */
.pf-v5-c-check__input:checked {
    background-color: var(--nuonic-primary);
    border-color: var(--nuonic-primary);
}
