* {
    user-select: none;
}

/* ========== Header Login Wrapper ========== */

.header-login-wrapper {
    position: relative;
    display: grid;
}

/* Both sections occupy the same grid cell so only the visible one shows */
.header-login-wrapper > * {
    grid-area: 1 / 1;
}

/* ========== Auth Sections (shared) ========== */

.logout-section,
.login-section {
    visibility: hidden;
    font-family: sans-serif;
    font-size: 0.9em;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 6px 12px;
    transition: all 0.3s;
    z-index: 100;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
    white-space: nowrap;
    position: relative;
    align-self: center;
}

/* ========== Header Rows ========== */

.logout-header,
.login-header {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.9em;
}

.auth-trigger-icon {
    color: var(--color-primary);
    font-size: 1.1em;
}

.auth-label {
    color: var(--color-text);
    font-weight: 600;
    font-size: 0.92em;
}

.arrow-down-logout,
.arrow-down-login {
    color: var(--color-text-muted);
    font-size: 0.75em;
    transition: transform 0.3s;
    user-select: none;
}

.logout-section.expanded .arrow-down-logout,
.login-section.expanded .arrow-down-login {
    transform: rotate(180deg);
}

/* ========== Dropdown Content ========== */

.logout-content,
.login-content {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 14px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    z-index: 200;
    min-width: 250px;
    white-space: normal;
}

/* ========== Login Form ========== */

.input-div {
    display: flex;
    flex-direction: column;
}

.input-div form {
    position: relative;
}

.login-content input[type="text"],
.login-content input[type="password"] {
    width: 100%;
    padding: 7px 10px;
    margin: 4px 0;
    box-sizing: border-box;
    border: 1px solid var(--color-border-medium);
    border-radius: 6px;
    font-size: 0.92em;
    font-style: normal;
    outline: none;
    transition: border-color 0.2s;
}

.login-content input:focus {
    border-color: var(--color-primary);
}

.toggle-password {
    color: var(--color-text-muted);
    position: absolute;
    right: 8px;
    bottom: 8px;
    cursor: pointer;
    z-index: 1;
    user-select: none;
}

.login-btn-div {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
}

.submit-login-btn {
    padding: 7px 18px;
    border: none;
    border-radius: 6px;
    background-color: var(--color-primary);
    color: #fff;
    cursor: pointer;
    font-size: 0.9em;
    transition: background 0.2s;
}

.submit-login-btn:hover {
    background-color: var(--color-primary-hover);
}

.login-message,
.logout-message {
    font-size: 0.85em;
    color: var(--color-success);
    display: inline;
}

/* ========== Logout Button (door icon) ========== */

.submit-logout-btn {
    background: none;
    border: none;
    color: var(--color-error);
    cursor: pointer;
    font-size: 1.05em;
    padding: 4px 6px;
    border-radius: 6px;
    transition: background 0.2s;
    display: flex;
    align-items: center;
}

.submit-logout-btn:hover {
    background: var(--color-error-bg);
}

/* ========== Logged As Info ========== */

.logged-as-div {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 6px 10px;
    font-size: 0.85em;
    color: var(--color-text-secondary);
    word-break: break-all;
}

#logged-as-span {
    display: block;
}

.logged-as-role {
    display: block;
    margin-top: 3px;
    font-size: 0.78em;
    font-style: italic;
    color: var(--color-text-muted);
    opacity: 0.85;
}

.logged-as-role:empty {
    display: none;
}

.logout-btn-div {
    margin-top: 8px;
}

/* ========== Responsive: collapse to icon ========== */

@media (max-width: 700px) {
    .auth-label,
    .arrow-down-login,
    .arrow-down-logout {
        display: none;
    }

    .logout-section,
    .login-section {
        padding: 6px 8px;
    }
}

/* ========== Login Alert ========== */

.login-alert {
    margin-top: 16px;
    display: none;
    color: var(--color-warning-text);
    font-weight: 600;
    font-size: 0.88em;
    text-align: center;
    padding: 10px 18px;
    background: var(--color-warning-bg);
    border: 1px solid var(--color-warning-border);
    border-radius: 8px;
}

.login-alert .fa-exclamation-circle {
    color: var(--color-warning);
}
