html, body {
    max-width: 100%;
    overflow-x: hidden;
}

body {
    min-height: 100vh;
}

.card-soft {
    border: 0;
    border-radius: 1rem;
    box-shadow: 0 0.5rem 1.25rem rgba(0, 0, 0, 0.06);
}

.login-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #eef4ff, #f8fbff);
}

.login-card {
    width: 100%;
    max-width: 420px;
}

.table-actions {
    white-space: nowrap;
}

.status-pill {
    min-width: 90px;
}

.appointment-list {
    width: 100%;
}

.appointment-card + .appointment-card {
    border-top: 1px solid #e9ecef;
}

.appointment-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    min-width: 0;
}

.appointment-card-main {
    min-width: 0;
    flex: 1 1 auto;
}

.appointment-card-title {
    font-weight: 600;
    word-break: break-word;
}

.appointment-card-meta,
.appointment-card-description {
    color: #6c757d;
    font-size: 0.925rem;
    word-break: break-word;
}

.appointment-card-description {
    margin-top: 0.35rem;
}

.appointment-card-menu {
    flex: 0 0 auto;
}

.dropdown-toggle-no-caret::after {
    display: none;
}

.hamburger-icon {
    display: inline-block;
    font-size: 1rem;
    line-height: 1;
}

.dropdown-menu form {
    margin: 0;
}

.dropdown-menu .dropdown-item {
    width: 100%;
    text-align: left;
    background: transparent;
    border: 0;
}

.user-navbar-info {
    flex-wrap: wrap;
}

@media (max-width: 575.98px) {
    .appointment-card {
        gap: 0.75rem;
    }

    .appointment-card-title {
        font-size: 0.98rem;
    }
}


body {
    display: flex;
    flex-direction: column;
}

.password-toggle-btn {
    min-width: 48px;
}

.password-toggle-btn svg {
    display: block;
    margin: 0 auto;
}

.dropdown-menu {
    max-width: calc(100vw - 2rem);
}

.app-footer {
    margin-top: auto;
    padding: 0.9rem 1rem 1.25rem;
    color: #6c757d;
    font-size: 0.95rem;
}
