.dash-page-shell-auth {
    max-width: 1280px;
    width: min(100%, 1280px);
    box-sizing: border-box;
    padding-top: 34px;
    padding-bottom: 56px;
}

.login-shell {
    min-height: calc(100vh - 190px);
    display: grid;
    place-items: center;
    padding: 18px 0 12px;
    width: 100%;
    min-width: 0;
}

#loginSection.login-card,
.auth-card {
    width: min(100%, 460px);
    min-width: 0;
    margin: 0 auto;
    padding: 28px 28px 24px;
    border-radius: 28px;
    border: 1px solid rgba(203, 213, 225, 0.18);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.95) 100%);
    box-shadow: 0 28px 60px rgba(15, 23, 42, 0.3);
    backdrop-filter: blur(12px);
    overflow-x: clip;
}

.login-head {
    margin-bottom: 22px;
    text-align: left;
}

.auth-head {
    margin-bottom: 24px;
}

.login-head.auth-head {
    text-align: center;
}

.login-head h1 {
    margin: 0;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(2rem, 4vw, 2.45rem);
    line-height: 0.98;
    letter-spacing: -0.05em;
    color: #0f172a;
    white-space: nowrap;
}

/* Activation/onboarding title: override generic login heading rules */
.login-head.auth-head h1 {
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.08;
    font-size: clamp(1.65rem, 2.6vw, 2.05rem);
}

.login-head p {
    margin: 10px 0 0;
    color: #475569;
    font: 500 1rem/1.55 "Plus Jakarta Sans", sans-serif;
}

.login-form {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.auth-form {
    gap: 18px;
}

.login-field {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.auth-message {
    margin-top: 16px;
}

.login-card .form-label {
    color: #334155;
    font: 700 0.92rem/1.2 "Plus Jakarta Sans", sans-serif;
}

.login-card .form-input {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: 56px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid #cbd5e1;
    background: rgba(255, 255, 255, 0.92);
    color: #0f172a;
    font: 600 1.02rem/1.2 "Plus Jakarta Sans", sans-serif;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.login-card .form-input::placeholder {
    color: #94a3b8;
}

.login-card .form-input:focus {
    border-color: rgba(255, 91, 61, 0.45);
    box-shadow: 0 0 0 4px rgba(255, 91, 61, 0.12);
}

.login-submit-btn {
    appearance: none;
    -webkit-appearance: none;
    display: inline-flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    min-height: 58px;
    padding: 0.95rem 1.7rem;
    border-radius: 999px;
    border: 1px solid #c92b1b;
    background: linear-gradient(135deg, #ff5b3d 0%, #ea2f1c 100%);
    color: #ffffff;
    font: 800 1.08rem/1 "Plus Jakarta Sans", sans-serif;
    box-shadow: 0 18px 35px rgba(234, 47, 28, 0.28);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
    cursor: pointer;
}

.login-submit-btn:hover:not(:disabled) {
    transform: translateY(-1px) scale(1.01);
}

.login-submit-btn:disabled {
    opacity: 0.72;
    cursor: not-allowed;
    box-shadow: none;
}

.login-message {
    margin-top: 16px;
    border-radius: 18px;
    padding: 12px 14px;
    text-align: center;
}

.login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0 16px;
    color: #64748b;
    font: 700 0.82rem/1 "Plus Jakarta Sans", sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.login-divider::before,
.login-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, rgba(148, 163, 184, 0), rgba(148, 163, 184, 0.7), rgba(148, 163, 184, 0));
}

.google-login-wrap {
    display: flex;
    justify-content: center;
    padding: 6px 0 2px;
    width: 100%;
    min-width: 0;
}

#googleSignInBtn {
    width: 100%;
    min-height: 54px;
    display: flex;
    justify-content: center;
}

#googleSignInBtn > div,
#googleSignInBtn iframe {
    border-radius: 999px !important;
}

.login-card .form-input:-webkit-autofill,
.login-card .form-input:-webkit-autofill:hover,
.login-card .form-input:-webkit-autofill:focus {
    -webkit-text-fill-color: #0f172a;
    transition: background-color 9999s ease-out 0s;
    box-shadow: inset 0 0 0 9999px rgba(255, 255, 255, 0.92);
    width: 100% !important;
    max-width: 100% !important;
}

.login-help {
    margin-top: 18px;
    text-align: center;
}

.login-reset-link,
.login-reset-link:visited,
.login-reset-link:active {
    color: #475569;
    text-decoration: none;
    font: 700 0.96rem/1.3 "Plus Jakarta Sans", sans-serif;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: color 0.18s ease, transform 0.18s ease;
    cursor: pointer;
}

.login-reset-link:hover,
.login-reset-link:focus-visible {
    color: #0f172a;
    transform: translateY(-1px);
}

/* Auth pages: always show pointer on interactive controls. */
.login-card a,
.login-card button,
.login-card [role="button"],
.login-card input[type="submit"],
.login-card input[type="button"],
#googleSignInBtn {
    cursor: pointer;
}

/* Hard override: some global styles can flatten cursors on auth pages. */
.login-shell a,
.login-shell button,
.login-shell [role="button"],
.login-shell input[type="submit"],
.login-shell input[type="button"],
.login-shell .login-reset-link,
.login-shell .login-submit-btn,
.login-shell #googleSignInBtn {
    cursor: pointer !important;
}

.login-shell button:disabled,
.login-shell input:disabled {
    cursor: not-allowed !important;
}

/* Login page only: neutral website-aligned skin (first migration step). */
body[data-page-name="login"] {
    background: #f4f7fc !important;
}

body[data-page-name="login"] .dash-page-shell-auth {
    max-width: 1180px;
    padding-top: 48px;
    padding-bottom: 60px;
}

body[data-page-name="login"] .login-shell {
    min-height: calc(100vh - 240px);
    padding: 0;
}

body[data-page-name="login"] #loginSection.login-card {
    width: min(100%, 470px);
    border-radius: 24px;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    backdrop-filter: none;
}

body[data-page-name="login"] .login-head h1 {
    font-family: "Plus Jakarta Sans", "Inter", sans-serif;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #0f172a;
}

body[data-page-name="login"] .login-head {
    text-align: center;
}

body[data-page-name="login"] .login-card .form-input {
    background: #ffffff;
    border-color: #d7e0ec;
    box-shadow: none;
}

body[data-page-name="login"] .login-card .form-input:focus {
    border-color: rgba(255, 91, 61, 0.52);
    box-shadow: 0 0 0 4px rgba(255, 91, 61, 0.12);
}

/* Next step: /new_password aligned to the same neutral style. */
body[data-page-name="new password"] {
    background: #f4f7fc !important;
}

body[data-page-name="new password"] .dash-page-shell-auth {
    max-width: 1180px;
    padding-top: 48px;
    padding-bottom: 60px;
}

body[data-page-name="new password"] .login-shell {
    min-height: calc(100vh - 240px);
    padding: 0;
}

body[data-page-name="new password"] .auth-card {
    width: min(100%, 470px);
    border-radius: 24px;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    backdrop-filter: none;
}

body[data-page-name="new password"] .login-head {
    text-align: center;
}

body[data-page-name="new password"] .login-head h1 {
    font-family: "Plus Jakarta Sans", "Inter", sans-serif;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #0f172a;
}

body[data-page-name="new password"] .login-card .form-input {
    background: #ffffff;
    border-color: #d7e0ec;
    box-shadow: none;
}

body[data-page-name="new password"] .login-card .form-input:focus {
    border-color: rgba(255, 91, 61, 0.52);
    box-shadow: 0 0 0 4px rgba(255, 91, 61, 0.12);
}

/* /restore_account, /active_account, /dashboard/logout aligned to same style */
body[data-page-name="restore account"],
body[data-page-name="activation"],
body[data-page-name="logout"] {
    background: #f4f7fc !important;
}

body[data-page-name="restore account"] .dash-page-shell-auth,
body[data-page-name="activation"] .dash-page-shell-auth,
body[data-page-name="logout"] .dash-page-shell-auth {
    max-width: 1180px;
    padding-top: 48px;
    padding-bottom: 60px;
}

body[data-page-name="restore account"] .login-shell,
body[data-page-name="activation"] .login-shell,
body[data-page-name="logout"] .login-shell {
    min-height: calc(100vh - 240px);
    padding: 0;
}

body[data-page-name="restore account"] .auth-card,
body[data-page-name="activation"] .auth-card,
body[data-page-name="logout"] .auth-card {
    width: min(100%, 470px);
    border-radius: 24px;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    backdrop-filter: none;
}

body[data-page-name="restore account"] .login-head,
body[data-page-name="activation"] .login-head,
body[data-page-name="logout"] .login-head {
    text-align: center;
}

body[data-page-name="restore account"] .login-head h1,
body[data-page-name="activation"] .login-head h1,
body[data-page-name="logout"] .login-head h1 {
    font-family: "Plus Jakarta Sans", "Inter", sans-serif;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #0f172a;
}

body[data-page-name="activation"] .login-head.auth-head p,
body[data-page-name="restore account"] .login-head.auth-head p {
    text-align: left;
}

body[data-page-name="restore account"] .login-card .form-input,
body[data-page-name="activation"] .login-card .form-input,
body[data-page-name="logout"] .login-card .form-input {
    background: #ffffff;
    border-color: #d7e0ec;
    box-shadow: none;
}

body[data-page-name="restore account"] .login-card .form-input:focus,
body[data-page-name="activation"] .login-card .form-input:focus,
body[data-page-name="logout"] .login-card .form-input:focus {
    border-color: rgba(255, 91, 61, 0.52);
    box-shadow: 0 0 0 4px rgba(255, 91, 61, 0.12);
}

@media (max-width: 700px) {
    .dash-page-shell-auth {
        padding-top: 22px;
        padding-bottom: 40px;
    }

    .login-shell {
        min-height: auto;
        padding-top: 8px;
    }

    #loginSection.login-card,
    .auth-card {
        padding: 22px 18px 20px;
        border-radius: 24px;
    }

    .login-head {
        margin-bottom: 18px;
    }

    .login-head p {
        font-size: 0.95rem;
    }

    .login-head h1 {
        white-space: normal;
    }

    .login-head.auth-head h1,
    .login-head.auth-head p {
        text-align: center;
    }

    .login-card .form-input {
        min-height: 52px;
        font-size: 0.98rem;
    }

    body[data-page-name="login"] .dash-page-shell-auth {
        padding-top: 28px;
        padding-bottom: 42px;
    }

    body[data-page-name="login"] .login-shell {
        min-height: auto;
    }

    body[data-page-name="new password"] .dash-page-shell-auth {
        padding-top: 28px;
        padding-bottom: 42px;
    }

    body[data-page-name="new password"] .login-shell {
        min-height: auto;
    }

    body[data-page-name="restore account"] .dash-page-shell-auth,
    body[data-page-name="activation"] .dash-page-shell-auth,
    body[data-page-name="logout"] .dash-page-shell-auth {
        padding-top: 28px;
        padding-bottom: 42px;
    }

    body[data-page-name="restore account"] .login-shell,
    body[data-page-name="activation"] .login-shell,
    body[data-page-name="logout"] .login-shell {
        min-height: auto;
    }
}
