html {
    font-size: 12px;
    position: relative;
    min-height: 100%;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* Password Strength Meter Styles */
.password-strength-container {
    margin-top: 0.5rem;
}

#passwordStrengthMeter {
    width: 100%;
    height: 5px;
    margin-bottom: 0.5rem;
    --strength-color: #dc3545; /* Default to red */
    -webkit-appearance: none;
    appearance: none;
    background-color: #e9ecef;
    border-radius: 2px;
}

#passwordStrengthMeter::-webkit-progress-bar {
    background-color: #e9ecef;
    border-radius: 2px;
}

#passwordStrengthMeter::-webkit-progress-value {
    background-color: var(--strength-color);
    border-radius: 2px;
    transition: all 0.3s ease;
}

/* Firefox */
#passwordStrengthMeter::-moz-progress-bar {
    background-color: var(--strength-color);
    border-radius: 2px;
    transition: all 0.3s ease;
}

#passwordStrengthMeter::-webkit-progress-value[value="0"],
#passwordStrengthMeter::-webkit-progress-value[value="1"] {
    background-color: #dc3545;
}

#passwordStrengthMeter::-webkit-progress-value[value="2"] {
    background-color: #ffc107;
}

#passwordStrengthMeter::-webkit-progress-value[value="3"] {
    background-color: #0dcaf0;
}

#passwordStrengthMeter::-webkit-progress-value[value="4"] {
    background-color: #198754;
}

.password-strength-label {
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
}

#passwordStrengthFeedback {
    font-size: 0.75rem;
    color: #6c757d;
    margin: 0;
    padding-left: 1rem;
}

#passwordStrengthFeedback li {
    margin-bottom: 0.25rem;
}

/* Modal Dialog Transitions - FIXED VERSION */
.modal-dialog {
    max-width: 500px !important;
    width: 500px;
    transition: all 0.3s ease-in-out;
    margin: 1.75rem auto;
}

.modal-dialog.expanded {
    max-width: 900px !important;
    width: 900px;
}

/* Ensure the modal content adapts */
.modal-content {
    width: 100%;
}

/* Password Generator Panel */
#passwordGeneratorPanel {
    display: none;
    min-width: 280px;
    flex-shrink: 0;
}

/* Generator Button Animation */
#generatePassword i {
    transition: transform 0.3s ease-in-out;
}

#generatePassword.active i {
    transform: rotate(180deg);
}

/* Responsive considerations for modal */
@media (max-width: 992px) {
    .modal-dialog.expanded {
        max-width: 95% !important;
        width: 95%;
    }
}

@media (max-width: 768px) {
    .modal-dialog,
    .modal-dialog.expanded {
        max-width: 95% !important;
        width: 95%;
        margin: 1rem auto;
    }
    
    #passwordGeneratorPanel {
        min-width: 250px;
    }
    
    /* Stack the modal content vertically on small screens */
    .modal-body.d-flex {
        flex-direction: column;
    }
    
    #passwordGeneratorPanel {
        border-start: none !important;
        border-top: 1px solid #dee2e6;
        padding-start: 0 !important;
        padding-top: 1rem;
        margin-top: 1rem;
    }
}

.activity-modal-dialog {
    max-width: 90% !important;
    width: 90% !important;
}

main {
    flex: 1 0 auto;
}

/* OTP Panel Slide-Out (Left) */
#modalBodyPanels {
    width: 600px;
    transition: width 0.3s;
    display: flex;
    flex-direction: row;
    position: relative;
}
#otpPanel {
    display: none;
    width: 300px;
    min-width: 300px;
    background: #e3f2fd;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    z-index: 2;
    transition: transform 0.3s, opacity 0.3s;
    transform: translateX(-100%);
    opacity: 0;
}
#modalBodyPanels.show-otp-panel {
    width: 900px;
}
#modalBodyPanels.show-otp-panel #otpPanel {
    display: flex;
    position: relative;
    transform: translateX(0);
    opacity: 1;
}
#mainCredentialForm {
    flex-grow: 1;
    transition: margin-left 0.3s;
}
#modalBodyPanels.show-otp-panel #mainCredentialForm {
    margin-left: 300px;
}

.no-select {
    -webkit-user-select: none !important;
    user-select: none !important;
}