.us-auth {
    padding: var(--space-8) 0;
}

.us-auth__shell {
    display: grid;
    place-items: center;
}

.us-auth-card {
    width: min(100%, 560px);
    display: grid;
    gap: var(--space-5);
}

.us-auth-card--wide {
    width: min(100%, 620px);
}

.us-auth-card__header {
    display: grid;
    gap: var(--space-2);
}

.us-auth-card__header p,
.us-auth-footer {
    margin: 0;
    color: var(--text-muted);
}

.us-auth-socials {
    display: grid;
    gap: var(--space-3);
}

.us-auth-social {
    justify-content: center;
    gap: 0.75rem;
}

.us-auth-divider {
    position: relative;
    text-align: center;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
}

.us-auth-divider::before {
    content: '';
    position: absolute;
    inset: 50% 0 auto;
    border-top: 1px solid var(--border);
}

.us-auth-divider span {
    position: relative;
    display: inline-block;
    padding: 0 0.9rem;
    background: var(--card-bg);
}

.us-password-field {
    position: relative;
}

.us-password-field input {
    padding-right: 3.25rem;
}

.us-password-toggle {
    position: absolute;
    top: 50%;
    right: 0.85rem;
    transform: translateY(-50%);
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--text-muted);
}

.us-password-toggle:hover {
    background: var(--surface-soft);
    color: var(--text);
}

.us-auth-actions-row {
    display: flex;
    justify-content: flex-end;
    margin-top: calc(var(--space-4) * -0.5);
}

@media (max-width: 640px) {
    .us-auth-card,
    .us-auth-card--wide {
        width: 100%;
    }
}

.us-member-register .us-auth-card--wide {
    width: min(100%, 760px);
}

.us-membership-claim-card,
.us-membership-wait-card,
.us-membership-social-note {
    padding: var(--space-4);
    border: 1px solid var(--card-border-color-soft);
    border-radius: var(--radius-4);
    background: var(--surface-soft);
}

.us-membership-claim-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
}

.us-membership-claim-card h2,
.us-membership-claim-card p,
.us-membership-social-note p {
    margin: 0;
}

.us-membership-claim-card p,
.us-membership-social-note,
.us-membership-wait-card {
    color: var(--text-muted);
    line-height: 1.55;
}

.us-membership-claim-card__meta {
    display: grid;
    gap: 0.2rem;
    text-align: right;
    color: var(--text-muted);
}

.us-membership-claim-card__meta span {
    color: var(--brand-700);
    font-weight: var(--font-weight-semibold);
}

@media (max-width: 680px) {
    .us-membership-claim-card {
        display: grid;
    }
    .us-membership-claim-card__meta {
        text-align: left;
    }
}

.us-member-register-page {
    min-height: 100vh;
    margin: 0;
    color: var(--text);
}

.us-member-register-page__panel {
    grid-template-columns: minmax(0, 0.95fr) minmax(520px, 1.05fr);
    min-height: min(860px, calc(100vh - 3rem));
}

.us-member-register-form-panel {
    display: grid;
    align-items: center;
    padding: clamp(1.4rem, 3vw, 3.2rem);
    background: var(--surface);
}

.us-member-register-form-panel__inner {
    display: grid;
    gap: var(--space-4);
    width: min(100%, 590px);
    margin: 0 auto;
}

.us-member-register-card__head {
    display: grid;
    gap: var(--space-2);
}

.us-member-register-card__head h2 {
    margin: 0;
    color: var(--text);
    font-size: clamp(1.7rem, 2.2vw, 2.2rem);
    line-height: 1.08;
    letter-spacing: -0.045em;
    font-weight: var(--font-weight-semibold);
}

.us-member-register-card__head p {
    margin: 0;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
    line-height: 1.7;
}

.us-member-register-confirmed {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-3);
    align-items: center;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(18, 107, 70, 0.18);
    border-radius: var(--radius-lg);
    background: rgba(18, 107, 70, 0.06);
}

.us-member-register-confirmed--waiting {
    border-color: rgba(118, 84, 199, 0.20);
    background: rgba(118, 84, 199, 0.07);
}

.us-member-register-confirmed i {
    width: 2.45rem;
    height: 2.45rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-pill);
    background: var(--surface);
    color: var(--success);
    box-shadow: 0 10px 22px rgba(74, 58, 125, 0.10);
}

.us-member-register-confirmed--waiting i {
    color: var(--brand-500);
}

.us-member-register-confirmed strong,
.us-member-register-confirmed span {
    display: block;
}

.us-member-register-confirmed strong {
    color: var(--text);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
}

.us-member-register-confirmed span {
    margin-top: 0.14rem;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-member-register-form {
    display: grid;
    gap: var(--space-3);
}

.us-member-register-form .us-field span {
    color: var(--text);
}

.us-member-register-form .us-field input,
.us-member-register-form .us-field textarea,
.us-member-register-form .us-field select {
    background: var(--surface);
    color: var(--text);
    border-color: var(--border);
}

.us-member-register-form .us-field input:focus,
.us-member-register-form .us-field textarea:focus,
.us-member-register-form .us-field select:focus {
    border-color: rgba(118, 84, 199, 0.62);
    box-shadow: 0 0 0 4px rgba(118, 84, 199, 0.11);
}

.us-member-register-email-field {
    padding: 0.85rem;
    border: 1px solid rgba(118, 84, 199, 0.20);
    border-radius: var(--radius-md);
    background: rgba(118, 84, 199, 0.055);
}

.us-member-register-email-help {
    display: flex;
    gap: 0.4rem;
    align-items: flex-start;
    color: var(--brand-700);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-member-register-email-help i {
    margin-top: 0.16rem;
}

.us-member-register-upload em {
    color: var(--text-subtle);
    font-style: normal;
    font-weight: var(--font-weight-regular);
}

.us-member-register-consent {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(118, 84, 199, 0.18);
    border-radius: var(--radius-lg);
    background: rgba(118, 84, 199, 0.05);
}

.us-member-register-consent--plain {
    background: rgba(118, 84, 199, 0.04);
}

.us-member-register-consent__control {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-top: 0.1rem;
}

.us-member-register-consent__copy {
    display: grid;
    gap: 0.18rem;
}

.us-member-register-consent__copy strong {
    color: var(--text);
    font-size: var(--font-size-sm);
    line-height: 1.45;
}

.us-member-register-consent__copy small {
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-member-register-consent__error {
    margin-top: -0.45rem;
}

.us-member-register-submit {
    min-height: 3.25rem;
    font-size: var(--font-size-md);
    box-shadow: 0 14px 28px rgba(118, 84, 199, 0.24);
}

.us-member-register-footer-note {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    margin: 0;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-member-register-footer-note i,
.us-member-register-footer-note a {
    color: var(--brand-500);
}

.us-member-register-footer-note a {
    font-weight: var(--font-weight-semibold);
}

@media (max-width: 980px) {
    .us-member-register-page__panel {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .us-member-register-page .us-login-welcome {
        min-height: 350px;
        padding: clamp(1.5rem, 6vw, 2.75rem);
    }

    .us-member-register-form-panel {
        padding: clamp(1.5rem, 6vw, 2.75rem);
    }
}

@media (max-width: 620px) {
    .us-member-register-page__stage {
        display: block;
        padding: 0;
    }

    .us-member-register-page__panel {
        border: 0;
        border-radius: 0;
        box-shadow: none;
    }

    .us-member-register-page .us-login-welcome {
        min-height: 285px;
    }

    .us-member-register-page .us-login-welcome__promise {
        display: grid;
    }

    .us-member-register-form-panel {
        padding: 1.35rem 1rem 2rem;
    }

    .us-member-register-card__head h2 {
        font-size: clamp(1.6rem, 8vw, 1.95rem);
    }

    .us-member-register-form .us-form__grid {
        grid-template-columns: 1fr;
    }
}

/* Standalone member login */
.us-login-shell {
    min-height: 100vh;
    background: var(--bg);
}

.us-main--login {
    min-height: 100vh;
}

.us-login-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 3vw, 2.5rem);
    background:
        radial-gradient(circle at 12% 12%, rgba(118, 84, 199, 0.12), transparent 34%),
        radial-gradient(circle at 88% 86%, rgba(166, 144, 232, 0.13), transparent 31%),
        var(--bg);
}

.us-login-page__stage {
    width: min(1120px, 100%);
}

.us-login-page__panel {
    display: grid;
    grid-template-columns: minmax(0, 1.06fr) minmax(380px, 0.94fr);
    min-height: min(720px, calc(100vh - 3rem));
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 30px;
    background: var(--surface);
    box-shadow: 0 32px 90px rgba(74, 58, 125, 0.16);
}

.us-login-welcome {
    position: relative;
    isolation: isolate;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: var(--space-6);
    padding: clamp(2rem, 5vw, 4.25rem);
    overflow: hidden;
    background:
        linear-gradient(145deg, rgba(101, 70, 180, 0.97), rgba(129, 97, 207, 0.95)),
        var(--brand-500);
    color: #fff;
}

.us-login-welcome::before,
.us-login-welcome::after {
    content: '';
    position: absolute;
    z-index: -1;
    border-radius: 50%;
    pointer-events: none;
}

.us-login-welcome::before {
    width: 25rem;
    height: 25rem;
    top: -11rem;
    right: -11rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: 0 0 0 4rem rgba(255, 255, 255, 0.035), 0 0 0 8rem rgba(255, 255, 255, 0.025);
}

.us-login-welcome::after {
    width: 18rem;
    height: 18rem;
    left: -8rem;
    bottom: -8rem;
    background: rgba(255, 255, 255, 0.055);
}

.us-login-welcome__brand {
    display: inline-flex;
    width: fit-content;
}

.us-login-welcome__brand img {
    width: min(230px, 64vw);
    max-height: 72px;
    object-fit: contain;
    object-position: left center;
}

.us-login-welcome__content {
    display: grid;
    gap: var(--space-5);
    max-width: 42rem;
}

.us-login-welcome__eyebrow,
.us-login-form-panel__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.us-login-welcome__eyebrow {
    color: rgba(255, 255, 255, 0.78);
}

.us-login-welcome h1 {
    margin: 0;
    max-width: 12ch;
    color: #fff;
    font-size: clamp(2.2rem, 4.35vw, 4.15rem);
    line-height: 0.98;
    letter-spacing: -0.07em;
    font-weight: var(--font-weight-semibold);
}

.us-login-welcome h1 em {
    display: inline-block;
    color: rgba(255, 255, 255, 0.83);
    font-family: var(--font-serif);
    font-weight: 600;
    letter-spacing: -0.055em;
}

.us-login-welcome p {
    max-width: 35rem;
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.04rem;
    line-height: 1.8;
}

.us-login-welcome__promise {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-3);
    align-items: center;
    max-width: 34rem;
    padding: var(--space-4);
    border: 1px solid rgba(255, 255, 255, 0.17);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.10);
    backdrop-filter: blur(12px);
}

.us-login-welcome__promise i {
    width: 2.65rem;
    height: 2.65rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.16);
}

.us-login-welcome__promise strong,
.us-login-welcome__promise span {
    display: block;
}

.us-login-welcome__promise strong {
    color: #fff;
    font-size: var(--font-size-sm);
}

.us-login-welcome__promise span {
    margin-top: 0.2rem;
    color: rgba(255, 255, 255, 0.73);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-login-welcome__footer {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3) var(--space-5);
    color: rgba(255, 255, 255, 0.76);
    font-size: var(--font-size-sm);
}

.us-login-welcome__footer span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.us-login-form-panel {
    display: grid;
    align-items: center;
    padding: clamp(1.5rem, 4vw, 4.25rem);
    background: var(--surface);
}

.us-login-form-panel__inner {
    display: grid;
    gap: var(--space-5);
    width: min(100%, 430px);
    margin: 0 auto;
}

.us-login-form-panel__eyebrow {
    color: var(--brand-500);
}

.us-login-form-panel h2 {
    margin: 0;
    color: var(--text);
    font-size: clamp(1.72rem, 2.15vw, 2.18rem);
    line-height: 1.08;
    letter-spacing: -0.045em;
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
}

.us-login-form-panel .us-auth-card__header {
    gap: var(--space-3);
}

.us-login-form-panel .us-auth-card__header p {
    line-height: 1.7;
}

.us-login-form {
    display: grid;
    gap: var(--space-4);
}

.us-login-form__submit {
    min-height: 3.2rem;
    box-shadow: 0 14px 28px rgba(118, 84, 199, 0.24);
}

.us-login-form-panel__note {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    margin: 0;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-login-form-panel__note i {
    color: var(--brand-500);
}

@media (max-width: 860px) {
    .us-login-page__panel {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .us-login-welcome {
        min-height: 360px;
        padding: clamp(1.5rem, 6vw, 2.75rem);
    }

    .us-login-welcome h1 {
        max-width: 13ch;
        font-size: clamp(2.15rem, 8vw, 3.85rem);
    }

    .us-login-welcome__footer {
        display: none;
    }

    .us-login-form-panel {
        padding: clamp(1.5rem, 6vw, 2.75rem);
    }
}

@media (max-width: 520px) {
    .us-login-page {
        display: block;
        padding: 0;
    }

    .us-login-page__panel {
        border: 0;
        border-radius: 0;
        box-shadow: none;
    }

    .us-login-welcome {
        min-height: 300px;
    }

    .us-login-welcome__promise {
        display: none;
    }

    .us-login-form-panel {
        padding: 1.4rem 1rem 2rem;
    }

    .us-login-form-panel h2 {
        white-space: normal;
        font-size: clamp(1.65rem, 8vw, 2rem);
    }
}

/* Standalone password recovery pages */
.us-login-shell .us-auth {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 3vw, 2.5rem);
    background:
        radial-gradient(circle at 12% 12%, rgba(118, 84, 199, 0.10), transparent 34%),
        radial-gradient(circle at 88% 86%, rgba(166, 144, 232, 0.11), transparent 31%),
        var(--bg);
}

.us-login-shell .us-auth__shell {
    width: min(100%, 560px);
}

.us-login-shell .us-auth-card {
    width: 100%;
    padding: clamp(1.3rem, 3vw, 2rem);
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface);
    box-shadow: 0 22px 60px rgba(74, 58, 125, 0.12);
}

.us-login-shell .us-auth-card .us-page-title-compact {
    margin: 0;
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1.15;
    letter-spacing: -0.04em;
}

.us-login-shell .us-auth-footer {
    text-align: center;
}


/* Paid registration instant handoff */
.us-member-register-order-card,
.us-member-register-waiting {
    display: flex;
    gap: 0.9rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid rgba(98, 74, 170, 0.18);
    border-radius: 18px;
    background: linear-gradient(135deg, var(--surface-soft), var(--surface));
    box-shadow: 0 12px 28px rgba(78, 59, 135, 0.08);
}

.us-member-register-order-card__icon,
.us-member-register-waiting > .us-member-register-spinner {
    flex: 0 0 auto;
}

.us-member-register-order-card__icon {
    display: grid;
    place-items: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(135deg, var(--brand-500), var(--brand-700));
    box-shadow: 0 9px 20px rgba(98, 74, 170, 0.24);
}

.us-member-register-order-card__body {
    min-width: 0;
    display: grid;
    gap: 0.28rem;
}

.us-member-register-order-card__eyebrow {
    color: var(--brand-700);
    font-size: var(--font-size-xs);
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.us-member-register-order-card__body > strong {
    color: var(--text);
    font-size: 1.02rem;
}

.us-member-register-order-card dl {
    display: grid;
    gap: 0.25rem;
    margin: 0.35rem 0 0;
}

.us-member-register-order-card dl > div {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
}

.us-member-register-order-card dt {
    font-weight: 700;
}

.us-member-register-order-card dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.us-member-register-waiting {
    align-items: center;
}

.us-member-register-waiting strong,
.us-member-register-waiting span {
    display: block;
}

.us-member-register-waiting span {
    margin-top: 0.2rem;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
    line-height: 1.55;
}

.us-member-register-spinner {
    width: 2rem;
    height: 2rem;
    border: 3px solid rgba(118, 84, 199, 0.16);
    border-top-color: var(--brand-600);
    border-radius: 999px;
    animation: us-member-register-spin 0.85s linear infinite;
}

.us-member-register-lookup[hidden] {
    display: none;
}

@keyframes us-member-register-spin {
    to { transform: rotate(360deg); }
}

@media (max-width: 520px) {
    .us-member-register-order-card,
    .us-member-register-waiting {
        border-radius: 15px;
        padding: 0.9rem;
    }
}

.us-member-register-gender-picker {
    min-width: 0;
    margin: 0;
    padding: 0.95rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--surface-soft);
}

.us-member-register-gender-picker legend {
    padding: 0 0.35rem;
    color: var(--text);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
}

.us-member-register-gender-picker > p {
    margin: 0 0 0.8rem;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.55;
}

.us-member-register-gender-picker__options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
}

.us-member-register-gender-option {
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr);
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
    padding: 0.72rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--surface);
    cursor: pointer;
    transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.us-member-register-gender-option:has(input:checked) {
    border-color: var(--brand-500);
    background: color-mix(in srgb, var(--brand-500) 8%, var(--surface));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-500) 14%, transparent);
}

.us-member-register-gender-option input {
    margin: 0;
    accent-color: var(--brand-500);
}

.us-member-register-gender-option img {
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--border);
}

.us-member-register-gender-option span,
.us-member-register-gender-option strong,
.us-member-register-gender-option small {
    display: block;
    min-width: 0;
}

.us-member-register-gender-option strong {
    color: var(--text);
    font-size: var(--font-size-sm);
}

.us-member-register-gender-option small {
    margin-top: 0.12rem;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    line-height: 1.35;
}

@media (max-width: 560px) {
    .us-member-register-gender-picker__options {
        grid-template-columns: 1fr;
    }
}

