/* Sign-in Rebrand Page Styles
   Page-specific styles on top of rebrand-base.css */

/* ===== Card (sign-in specific: 400px width, 450px for password expired) ===== */
.sign-in-page .rebrand-card {
    width: 400px;
}

.sign-in-page .rebrand-card:has(#okta-sign-in .password-expired),
.sign-in-page .rebrand-card.password-expired-card {
    width: 450px;
}

.sign-in-page .rebrand-card h1 {
    margin: 0 0 24px 0;
}

/* ===== Banner Message ===== */
.rebrand-banner {
    width: 100%;
    margin-bottom: 16px;
    padding: 8px 12px;
    background: var(--color-warning-bg);
    border-radius: var(--radius-btn);
    font-family: var(--font-family);
    font-size: 14px;
    font-weight: 500;
    line-height: 22px;
    color: var(--color-warning-text);
}

/* ===== Sign-in Widget Container ===== */
#sign-in-widget {
    margin-bottom: 16px;
    width: 100%;
}

/* ===== Card Buttons (SSO button group) ===== */
.rebrand-card-buttons {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    width: 100%;
}

.rebrand-card-buttons .link-btn,
.rebrand-card-links .link-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 12px 16px;
    height: var(--btn-height);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-btn);
    background: var(--color-white);
    font-family: var(--font-family);
    font-size: 16px;
    font-weight: 600;
    line-height: 26px;
    color: var(--color-text-secondary);
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.rebrand-card-buttons .link-btn:hover,
.rebrand-card-links .link-btn:hover {
    background: var(--color-border-hover);
    border-color: var(--color-border-hover);
    color: var(--color-black);
}

.rebrand-card-buttons .link-btn:focus,
.rebrand-card-links .link-btn:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 2px var(--color-primary);
}

.rebrand-card-buttons .link-btn:active,
.rebrand-card-links .link-btn:active {
    background: var(--color-primary-active);
    border-color: var(--color-primary-active);
    color: var(--color-white);
}

/* ===== Card Links (Forgot password, Trouble signing in) ===== */
.rebrand-card-links {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    width: 100%;
    margin-top: 24px;
}

.rebrand-card-links .link-text:first-of-type {
    margin-top: 0;
}

.rebrand-card-links .link-text {
    display: block;
    font-family: var(--font-family);
    font-size: 16px;
    font-weight: 600;
    line-height: 26px;
    color: var(--color-text-secondary);
    text-decoration: none;
    white-space: nowrap;
}

.rebrand-card-links .link-text:visited {
    color: var(--color-text-secondary);
}

.rebrand-card-links .link-text:hover {
    color: var(--color-primary);
}

/* ===== Okta Widget Overrides ===== */
#okta-sign-in {
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    min-width: unset !important;
    max-width: 100% !important;
}

#okta-sign-in .okta-sign-in-header {
    display: none !important;
}

#okta-sign-in .okta-form-title {
    display: none !important;
}

#okta-sign-in .o-form-error-container:empty {
    display: none !important;
}

#okta-sign-in .o-form-error-container {
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

#okta-sign-in .o-form-error-container .okta-form-infobox-error {
    background: #F1E1E8 !important;
    border: none !important;
    padding: 8px 16px 8px 32px !important;
    margin: 0 !important;
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 22px !important;
    color: #A8011E !important;
    box-shadow: none !important;
    border-radius: 8px !important;
    position: relative !important;
    display: block !important;
}

#okta-sign-in .o-form-error-container .okta-form-infobox-error .icon {
    display: none !important;
}

#okta-sign-in .o-form-error-container .okta-form-infobox-error::before {
    content: '⚠' !important;
    background: none !important;
    background-image: none !important;
    color: #A8011E !important;
    font-size: 24px !important;
    position: absolute !important;
    left: 10px !important;
    top: 8px !important;
    width: 24px !important;
    height: 22px !important;
    text-indent: 0 !important;
    display: block !important;
    float: none !important;
}

#okta-sign-in .margin-btm-30 {
    margin-bottom: 0 !important;
}

#okta-sign-in .margin-btm-0 {
    margin-bottom: 0 !important;
}

#okta-sign-in .auth-content {
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .auth-content-inner,
#okta-sign-in .idp-discovery,
#okta-sign-in .primary-auth {
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .primary-auth-form {
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .primary-auth .o-form-fieldset-container {
    gap: 0 !important;
}

#okta-sign-in .o-form-content {
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .o-form-content.clearfix::before,
#okta-sign-in .o-form-content.clearfix::after {
    display: none !important;
}

#okta-sign-in .o-form-fieldset-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.sso-disabled #okta-sign-in .o-form-fieldset-container {
    gap: 0 !important;
}

#okta-sign-in .idp-discovery-form,
#okta-sign-in .primary-auth-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .o-form-fieldset {
    margin: 0 !important;
    padding: 0 !important;
}

#okta-sign-in .auth-container {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

#okta-sign-in .o-form-head {
    display: none !important;
}

#okta-sign-in .o-form-label,
#okta-sign-in .o-form-label label {
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 22px !important;
    color: #000 !important;
}

#okta-sign-in .o-form-explain,
#okta-sign-in .input-tooltip,
#okta-sign-in .o-form-input-name-username .input-tooltip {
    display: none !important;
}

#okta-sign-in .custom-checkbox input[type="checkbox"],
#okta-sign-in input[type="checkbox"] {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    width: 22px !important;
    height: 22px !important;
    min-width: 22px !important;
    min-height: 22px !important;
    border: 2px solid #C2C5E6 !important;
    border-radius: 50% !important;
    background: #fff !important;
    cursor: pointer;
    vertical-align: middle;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
}

#okta-sign-in .custom-checkbox input[type="checkbox"]:checked,
#okta-sign-in input[type="checkbox"]:checked {
    background: #2B0BF9 !important;
    border-color: #2B0BF9 !important;
}

#okta-sign-in .custom-checkbox label,
#okta-sign-in label[data-se-for-name="remember"] {
    color: #000 !important;
    font-size: 0.9375rem !important;
    font-weight: 400 !important;
    margin-left: 0.5rem !important;
    vertical-align: middle !important;
}

#okta-sign-in .custom-checkbox,
#okta-sign-in .o-form-input-name-remember {
    display: flex !important;
    align-items: center !important;
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
}

#okta-sign-in .o-form-button-bar {
    padding-top: 0 !important;
    margin-top: 0 !important;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

#okta-sign-in .o-form {
    width: 100% !important;
}

#okta-sign-in .o-form-input {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .input-fix {
    width: 100% !important;
}

#okta-sign-in input[type="text"],
#okta-sign-in input[type="password"],
#okta-sign-in .o-form input.o-form-control {
    border: 2px solid #C2C5E6 !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 22px !important;
    height: 36px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: #fff !important;
    transition: border-color 0.2s ease !important;
}

#okta-sign-in .o-form-input .input-fix,
#okta-sign-in .o-form-input-name-username,
#okta-sign-in .o-form-input-name-password,
#okta-sign-in .o-form-input-name-oldPassword,
#okta-sign-in .o-form-input-name-newPassword,
#okta-sign-in .o-form-input-name-confirmPassword,
#okta-sign-in .input-fix {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative !important;
}

#okta-sign-in .password-toggle {
    position: absolute !important;
    right: 10px !important;
    top: 0 !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    cursor: pointer !important;
}

#okta-sign-in input[type="text"]:hover,
#okta-sign-in input[type="password"]:hover,
#okta-sign-in .o-form input.o-form-control:hover {
    border-color: #EBECFD !important;
}

#okta-sign-in input:focus,
#okta-sign-in .o-form input.o-form-control:focus {
    border-color: #2B0BF9 !important;
    outline: none !important;
    box-shadow: none !important;
}

#okta-sign-in .o-form-has-errors input,
#okta-sign-in input.o-form-control-error {
    border-color: #A8011E !important;
}

#okta-sign-in #okta-signin-submit,
#okta-sign-in .button-primary,
#okta-sign-in .btn-primary {
    background-color: #2B0BF9 !important;
    background: #2B0BF9 !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 26px !important;
    width: 100% !important;
    height: 48px !important;
    color: #ffffff !important;
    text-transform: none !important;
    box-shadow: none !important;
    display: block !important;
    transition: background-color 0.2s ease !important;
}

#okta-sign-in #okta-signin-submit:hover,
#okta-sign-in .button-primary:hover,
#okta-sign-in .btn-primary:hover {
    background-color: #4639F4 !important;
    background: #4639F4 !important;
    box-shadow: 0 2px 8px rgba(43, 11, 249, 0.3) !important;
}

#okta-sign-in #okta-signin-submit:focus,
#okta-sign-in .button-primary:focus,
#okta-sign-in .btn-primary:focus {
    background-color: #2B0BF9 !important;
    outline: 2px solid #fff !important;
    outline-offset: 2px !important;
    box-shadow: 0 0 0 4px #2B0BF9 !important;
}

#okta-sign-in #okta-signin-submit:active,
#okta-sign-in .button-primary:active,
#okta-sign-in .btn-primary:active {
    background-color: #6A68F4 !important;
    background: #6A68F4 !important;
}

#okta-sign-in .auth-footer {
    display: none !important;
}

/* ===== Okta Password Expired/Reset Form Overrides ===== */
#okta-sign-in .password-expired {
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .password-expired .o-form-head {
    display: block !important;
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 36px !important;
    font-weight: 700 !important;
    line-height: 46px !important;
    color: #000 !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
}

/* Injected password requirements section */
.rebrand-requirements-injected {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
    margin: 0 !important;
}

.rebrand-requirements-injected h2 {
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 22px !important;
    color: #010063 !important;
    margin: 0 !important;
}

.rebrand-requirements-injected ul {
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 22px !important;
    color: #010063 !important;
    margin: 0 !important;
    padding-left: 16px !important;
    list-style: none !important;
}

.rebrand-requirements-injected ul li {
    margin-bottom: 2px !important;
    padding: 0 !important;
    padding-left: 8px !important;
    position: relative !important;
    display: block !important;
}

.rebrand-requirements-injected ul li::before {
    content: '\2022' !important;
    position: absolute !important;
    left: -8px !important;
    font-size: 14px !important;
    line-height: 22px !important;
    color: #010063 !important;
}

#okta-sign-in .password-expired .o-form-fieldset-container {
    gap: 16px !important;
}

#okta-sign-in .password-expired .o-form-content {
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
}

#okta-sign-in .password-expired .o-form-fieldset {
    margin: 0 !important;
    padding: 0 !important;
}

#okta-sign-in .password-expired .o-form-fieldset:last-child {
    margin-bottom: 0 !important;
}

#okta-sign-in .password-expired .o-form-button-bar {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* Hide tooltips in password expired form */
#okta-sign-in .password-expired .input-tooltip,
#okta-sign-in .password-expired .o-form-explain {
    display: none !important;
}

/* Tighten label-to-input spacing */
#okta-sign-in .password-expired .o-form-label {
    margin-bottom: 4px !important;
    padding: 0 !important;
}

#okta-sign-in .password-expired .o-form-input {
    margin: 0 !important;
    padding: 0 !important;
}

/* Tighten the form layout */
#okta-sign-in .password-expired .o-form-content .o-form-fieldset-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

/* Remove any extra margins from Okta utility classes */
#okta-sign-in .password-expired .margin-btm-30,
#okta-sign-in .password-expired .margin-btm-0,
#okta-sign-in .password-expired .margin-btm-5 {
    margin-bottom: 0 !important;
}

/* Divider between old and new password */
#okta-sign-in .password-expired .okta-form-divider,
#okta-sign-in .password-expired .form-divider {
    border: none !important;
    border-top: 2px solid #C2C5E6 !important;
    margin: -8px 0 !important;
    padding: 0 !important;
    height: 0 !important;
}

/* Password expired form wrapper */
#okta-sign-in .password-expired .o-form,
#okta-sign-in .password-expired form {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Hide Okta's own Sign Out link (we inject our own) */
#okta-sign-in .password-expired .auth-footer {
    display: none !important;
}

/* Hide the subtitle/explain paragraph that Okta renders */
#okta-sign-in .password-expired .okta-form-subtitle {
    display: none !important;
}

/* Hide error container when empty */
#okta-sign-in .password-expired .o-form-error-container:empty {
    display: none !important;
}

/* Password expired form — force input styling */
#okta-sign-in .password-expired .o-form-input .input-fix {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#okta-sign-in .password-expired input[type="password"] {
    border: 2px solid #C2C5E6 !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    height: 36px !important;
    font-family: 'Manrope', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 22px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: #fff !important;
}

/* Password expired — divider between old and new password sections */
#okta-sign-in .password-expired .password-divider,
#okta-sign-in .password-expired hr {
    border: none !important;
    border-top: 2px solid #C2C5E6 !important;
    margin: 0 !important;
}

/* Hide the card heading when Okta shows password expired form */
.rebrand-card:has(#okta-sign-in .password-expired) > h1 {
    display: none;
}

/* Sign Out link shown below Okta password expired form */
.sign-out-link-okta {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 12px 16px;
    height: var(--btn-height);
    background: var(--color-white);
    border-radius: var(--radius-btn);
    font-family: var(--font-family);
    font-size: 16px;
    font-weight: 600;
    line-height: 26px;
    color: var(--color-text-secondary);
    text-decoration: none;
    box-sizing: border-box;
}

.sign-out-link-okta:hover {
    background: var(--color-border-hover);
}

.sign-out-link-okta:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* When password-expired card is showing and viewport is short, allow scrolling */
@media (min-width: 1024px) and (max-height: 900px) {
    body.rebrand-page:has(.password-expired-card) {
        min-height: 1100px;
    }
}

/* ===== Responsive: Mobile ===== */
@media (max-width: 767px) {
    .rebrand-card-links .link-text {
        white-space: normal;
    }

    #okta-sign-in.auth-container .auth-content {
        max-width: 100% !important;
        width: 100% !important;
    }
}
