/**
 * Login & register pages
 */
.site-ui.auth-page main.min-h-screen {
    min-height: calc(100vh - 4rem);
    background: #f8fafc;
}

.site-ui.auth-page main .bg-gradient-to-br {
    background: linear-gradient(155deg, #0f2847 0%, #1e3a5f 28%, #2d5a45 62%, #79ad87 100%) !important;
    padding-top: 3rem !important;
    padding-bottom: 3.5rem !important;
}

.site-ui.auth-page main .bg-gradient-to-br h1 {
    letter-spacing: -0.02em;
}

.site-ui.auth-page main .bg-gradient-to-br p {
    color: rgba(255, 255, 255, 0.88);
    line-height: 1.55;
}

.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg {
    border-radius: var(--mb-radius-lg) !important;
    border-color: var(--mb-line) !important;
    box-shadow: var(--mb-shadow-md) !important;
    padding: 1.75rem 1.5rem !important;
}

@media (min-width: 768px) {
    .site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg {
        padding: 2rem 2rem !important;
    }
}

.site-ui.auth-page #login-form label,
.site-ui.auth-page #firebase-register-form label {
    color: #334155;
    font-weight: 600;
}

.site-ui.auth-page #login-form input,
.site-ui.auth-page #firebase-register-form input:not([type="checkbox"]),
.site-ui.auth-page #firebase-register-form select {
    min-height: 44px;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    background: #fff !important;
    font-size: max(16px, 0.95rem);
}

@media (min-width: 768px) {
    .site-ui.auth-page #login-form input,
    .site-ui.auth-page #firebase-register-form input:not([type="checkbox"]),
    .site-ui.auth-page #firebase-register-form select {
        font-size: 0.95rem;
    }
}

.site-ui.auth-page #login-form input:focus,
.site-ui.auth-page #firebase-register-form input:focus {
    outline: none;
    border-color: #86efac !important;
    box-shadow: 0 0 0 3px rgba(121, 173, 135, 0.22);
}

.site-ui.auth-page #login-form button[type="submit"],
.site-ui.auth-page #firebase-register-form button[type="submit"] {
    min-height: 48px;
    border-radius: 12px !important;
    font-weight: 700;
    letter-spacing: 0.02em;
    box-shadow: 0 10px 24px rgba(121, 173, 135, 0.25);
}

.site-ui.auth-page #login-form button[type="button"]:disabled,
.site-ui.auth-page #firebase-register-form button:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}

.site-ui.auth-page #login-form .border-input,
.site-ui.auth-page #login-form button.border-input {
    border-color: #e2e8f0 !important;
    background: #f8fafc !important;
    color: #64748b !important;
}

.site-ui.auth-page .auth-message {
    border-radius: 10px;
}

.site-ui.auth-page [data-migration-prompt] {
    border-radius: var(--mb-radius) !important;
}

.site-ui.auth-page #login-form .border-input,
.site-ui.auth-page #login-form input.border-input {
    border: 1px solid #cbd5e1 !important;
    background: #fff !important;
}

.site-ui.auth-page #login-form .bg-primary,
.site-ui.auth-page #login-form button.bg-primary {
    background: var(--mb-green) !important;
    color: #fff !important;
}

.site-ui.auth-page #login-form .relative .absolute,
.site-ui.auth-page #firebase-register-form .relative .absolute {
    border-color: #e2e8f0;
}

.site-ui.auth-page #login-form .text-center.text-sm a,
.site-ui.auth-page #firebase-register-form .text-center.text-sm a {
    font-weight: 700;
    color: var(--mb-blue, #2563eb);
    text-decoration: none;
}

.site-ui.auth-page #login-form .text-center.text-sm a:hover,
.site-ui.auth-page #firebase-register-form .text-center.text-sm a:hover {
    text-decoration: underline;
}

.site-ui.auth-page .auth-message[data-type="error"] {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #b91c1c;
}

.site-ui.auth-page .auth-message[data-type="success"] {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
}

.site-ui.auth-page #firebase-register-form fieldset {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1rem;
    background: #f8fafc;
}

.site-ui.auth-page #firebase-register-form fieldset legend {
    font-weight: 700;
    color: var(--mb-navy, #172033);
    padding: 0 0.25rem;
}

.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 {
    position: relative;
    z-index: 2;
}

.site-ui.auth-page #login-form .bg-primary:hover {
    background: var(--mb-green-hover, #6a9d79) !important;
}

.site-ui.auth-page #login-form .text-muted-foreground::placeholder {
    color: #94a3b8;
}

.site-ui.auth-page main .bg-gradient-to-br {
    border-radius: 0 0 28px 28px;
}

.site-ui.auth-page #login-form .relative:has(.absolute) {
    display: flex;
    align-items: center;
}

.site-ui.auth-page #login-form .border-input + .relative,
.site-ui.auth-page #login-form .relative + button.border-input {
    margin-top: 0.15rem;
}

.site-ui.auth-page main .text-center.text-sm.text-muted-foreground {
    color: #64748b;
    line-height: 1.5;
}

.site-ui.auth-page #login-form button[type="button"].absolute {
    min-width: 44px;
    min-height: 44px;
    border-radius: 0 10px 10px 0;
}

.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg.shadow-lg {
    box-shadow: var(--mb-shadow-md) !important;
}

.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg p,
.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg a {
    font-size: 0.9rem;
}

.site-ui.auth-page main .max-w-md.mx-auto.px-4.-mt-8 > .rounded-lg a {
    font-weight: 700;
    color: var(--mb-blue, #2563eb);
}

.site-ui.auth-page #login-form .auth-message,
.site-ui.auth-page #firebase-register-form .auth-message {
    padding: 0.75rem 1rem;
    border-radius: 10px;
    font-size: 0.88rem;
    font-weight: 600;
}

.site-ui.auth-page [data-migration-prompt] {
    padding: 1rem !important;
    font-size: 0.9rem;
    line-height: 1.55;
}

.site-ui.auth-page #login-form .h-px,
.site-ui.auth-page #firebase-register-form .h-px {
    background: #e2e8f0 !important;
}

.site-ui.auth-page #login-form button[type="button"]:disabled,
.site-ui.auth-page #firebase-register-form button[type="button"]:disabled {
    opacity: 0.55;
    cursor: not-allowed;
    border-radius: 10px !important;
    background: #f8fafc !important;
    color: #64748b !important;
}

.site-ui.auth-page main .rounded-lg > p.text-center {
    margin-top: 1.25rem;
    font-size: 0.9rem;
    color: #64748b;
}

.site-ui.auth-page main .rounded-lg > p.text-center a {
    font-weight: 700;
    color: var(--mb-blue, #2563eb);
}

.site-ui.auth-page .rounded-lg.border.border-blue-200.bg-blue-50,
.site-ui.auth-page .rounded-lg.border.border-red-200.bg-red-50,
.site-ui.auth-page #register-form > .rounded-lg.border {
    border-radius: 10px !important;
    line-height: 1.55;
}

.site-ui.auth-page #register-form > .rounded-lg.border.border-blue-200 {
    background: #eff6ff !important;
    border-color: #bfdbfe !important;
    color: #1e3a8a !important;
    font-size: 0.88rem;
}

.site-ui.auth-page main .rounded-lg > .border-t {
    border-color: var(--mb-line, #d8e6f7) !important;
}

.site-ui.auth-page #login-form button.mb-btn-primary,
.site-ui.auth-page #firebase-register-form button.mb-btn-primary {
    min-height: 48px;
    margin-top: 0.25rem;
}

.site-ui.auth-page #login-form button.mb-btn-secondary,
.site-ui.auth-page #firebase-register-form button.mb-btn-secondary {
    min-height: 48px;
    justify-content: center;
}

.site-ui.auth-page #login-form button.mb-btn-secondary:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.site-ui.auth-page #login-form label[for],
.site-ui.auth-page #firebase-register-form label[for] {
    font-size: 0.88rem;
}

.site-ui.auth-page #login-form .flex.items-center label {
    font-weight: 500;
    color: #475569;
}

.site-ui.auth-page #login-form a.text-blue-600 {
    color: var(--mb-blue, #2563eb) !important;
    font-weight: 700;
}

.site-ui.auth-page #login-form .text-xs.text-gray-400 {
    color: #94a3b8;
    letter-spacing: 0.04em;
}

.site-ui.auth-page #firebase-register-form .rounded-lg.border.bg-blue-50 {
    border-radius: 12px !important;
    border-color: #bfdbfe !important;
    background: #eff6ff !important;
    line-height: 1.55;
}

.site-ui.auth-page main .rounded-lg.shadow-sm {
    border-radius: var(--mb-radius-lg, 16px) !important;
    box-shadow: var(--mb-shadow-md) !important;
}

.site-ui.auth-page main input[type="email"],
.site-ui.auth-page main input[type="password"],
.site-ui.auth-page main input[type="text"] {
    min-height: 44px;
    border-radius: 10px;
}

.site-ui.auth-page #login-form input[type="checkbox"],
.site-ui.auth-page #firebase-register-form input[type="checkbox"] {
    accent-color: var(--mb-green, #79ad87);
}

.site-ui.auth-page #login-form a.text-blue-600 {
    text-decoration: none;
}

.site-ui.auth-page #login-form a.text-blue-600:hover {
    text-decoration: underline;
}

.site-ui.auth-page main .border-t .text-center a {
    font-weight: 700;
    color: var(--mb-blue, #2563eb);
}

.site-ui.auth-page main .border-t .text-center p {
    color: #64748b;
    font-size: 0.9rem;
}

.site-ui.auth-page main .border-t {
    border-color: var(--mb-line, #d8e6f7) !important;
    margin-top: 1.25rem;
    padding-top: 1.25rem;
}

.site-ui.auth-page #firebase-register-form .grid.gap-4 {
    gap: 0.85rem;
}

.site-ui.auth-page #register-form + noscript,
.site-ui.auth-page #firebase-register-form .rounded-lg.border.border-blue-200 {
    line-height: 1.55;
}

.site-ui.auth-page .auth-spacer {
    height: 3rem;
}

.site-ui.auth-page .auth-message[data-state="success"],
.site-ui.auth-page #login-form + .auth-message[data-state="success"] {
    padding: 0.75rem 0.9rem;
    border-radius: 10px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-weight: 600;
    font-size: 0.9rem;
}

.site-ui.auth-page .auth-message[data-state="error"] {
    padding: 0.75rem 0.9rem;
    border-radius: 10px;
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #b91c1c;
    font-weight: 600;
    font-size: 0.9rem;
}

.site-ui.auth-page [data-migration-prompt] {
    border-radius: 12px;
    border: 1px solid #fde68a;
    background: #fffbeb;
    padding: 0.85rem 1rem;
    color: #92400e;
    line-height: 1.55;
    font-size: 0.9rem;
}

.site-ui.auth-page #login-forgot-password {
    appearance: none;
    background: transparent;
    border: none;
    padding: 0.25rem 0.35rem;
    margin: 0;
    font: inherit;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.35;
    color: #166534;
    text-decoration: underline;
    text-underline-offset: 2px;
    cursor: pointer;
    border-radius: 6px;
}

.site-ui.auth-page #login-forgot-password:hover {
    color: #14532d;
}

.site-ui.auth-page #login-forgot-password:focus-visible {
    outline: 2px solid #86efac;
    outline-offset: 2px;
}

.site-ui.auth-page #login-form .flex.items-center.justify-between {
    align-items: flex-start;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.site-ui.auth-page #login-form label:has(#login-remember) {
    align-items: center;
    gap: 0.5rem;
}
