:root {
    --auth-ink: #1F4D3A;
    --auth-ink-light: #163d2e;
    --auth-accent: #D99A2B;
    --auth-on-accent: #FAF7F0;
    --auth-on-primary: #FAF7F0;
    --auth-primary-tint: #E4EDE1;
    --auth-accent-tint: #F5E6C8;
    --auth-ink-2: #6B635C;
    --auth-ink-3: #A8BFA3;
    --auth-surface: #FAF7F0;
    --auth-surface-2: #F3E7D3;
    --auth-card: #FFFFFF;
    --auth-line: rgba(168, 191, 163, 0.40);
    --auth-positive: #2D6B52;
    --auth-negative: #C76B4A;
    --auth-charcoal: #2E2723;
    --auth-sage: #A8BFA3;
    --auth-honey-dark: #B8841F;
    --auth-terracotta: #C76B4A;
    --auth-surface-container-high: #E8E0D4;
    --auth-focus-ring: rgba(31, 77, 58, 0.18);
    --auth-shadow-warm: rgba(46, 39, 35, 0.06);
    --auth-shadow-raised: 0 2px 8px rgba(46, 39, 35, 0.08);
    --auth-font-sans: 'Figtree', ui-sans-serif, system-ui, sans-serif;
    --auth-radius-md: 0.75rem;
    --auth-radius-full: 9999px;
    --auth-duration-fast: 0.12s;
    --auth-duration-base: 0.2s;
    --auth-ease-standard: cubic-bezier(0.2, 0, 0, 1);
    --auth-ease-emphasized: cubic-bezier(0.2, 0, 0, 1.2);
}

.guest-auth {
    font-family: var(--auth-font-sans);
    background: var(--auth-surface);
    color: var(--auth-charcoal);
}

.guest-auth h1,
.guest-auth h2,
.guest-auth h3 {
    font-family: var(--auth-font-sans);
}

.material-symbols-rounded {
    font-family: 'Material Symbols Rounded';
    font-weight: normal;
    font-style: normal;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-block;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-feature-settings: 'liga';
    font-feature-settings: 'liga';
    -webkit-font-smoothing: antialiased;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.auth-grid {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1.02fr 1fr;
}

.auth-brand-panel {
    position: relative;
    overflow: hidden;
    background: linear-gradient(150deg, var(--auth-ink) 0%, var(--auth-ink-light) 55%, var(--auth-charcoal) 100%);
    color: var(--auth-surface);
    padding: 3.25rem 3.5rem;
    display: flex;
    flex-direction: column;
}

.auth-brand-panel .auth-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    pointer-events: none;
}

.auth-brand-panel .auth-blob--1 {
    right: -7.5rem;
    top: -7.5rem;
    width: 25rem;
    height: 25rem;
    background: rgba(217, 154, 43, 0.20);
}

.auth-brand-panel .auth-blob--2 {
    left: -8.75rem;
    bottom: -10rem;
    width: 23.75rem;
    height: 23.75rem;
    background: rgba(168, 191, 163, 0.22);
}

.auth-brand-panel .auth-grain {
    position: absolute;
    inset: 0;
    opacity: 0.5;
    background-image: radial-gradient(rgba(250, 247, 240, 0.05) 1px, transparent 1px);
    background-size: 22px 22px;
    pointer-events: none;
}

.auth-bp-top {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.6875rem;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.01875em;
    color: var(--auth-on-primary);
    text-decoration: none;
}

.auth-bp-top .auth-bp-pon {
    color: var(--auth-accent);
}

.auth-bp-mid {
    position: relative;
    margin-top: auto;
}

.auth-bp-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--auth-sage);
}

.auth-bp-kicker .dot {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 50%;
    background: var(--auth-accent);
}

.auth-bp-mid h1 {
    font-size: 2.375rem;
    line-height: 1.12;
    font-weight: 700;
    letter-spacing: -0.03125em;
    margin: 1rem 0 0;
    text-wrap: balance;
    max-width: 28.75rem;
    color: var(--auth-on-primary);
}

.auth-bp-mid p {
    font-size: 1.03125rem;
    line-height: 1.6;
    color: rgba(243, 231, 211, 0.86);
    margin: 1.125rem 0 0;
    max-width: 26.875rem;
}

.auth-bp-feats {
    position: relative;
    margin-top: 2.125rem;
    display: flex;
    flex-direction: column;
    gap: 0.9375rem;
}

.auth-bp-feat {
    display: flex;
    align-items: center;
    gap: 0.8125rem;
    font-size: 0.9375rem;
    color: rgba(243, 231, 211, 0.95);
}

.auth-bp-feat-icon {
    width: 2.375rem;
    height: 2.375rem;
    border-radius: 0.6875rem;
    background: rgba(250, 247, 240, 0.10);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.auth-bp-feat-icon .material-symbols-rounded {
    font-size: 1.25rem;
    color: var(--auth-accent);
}

.auth-bp-bottom {
    position: relative;
    margin-top: auto;
    padding-top: 2.5rem;
}

.auth-bp-quote {
    font-size: 0.96875rem;
    line-height: 1.6;
    color: rgba(243, 231, 211, 0.92);
    font-style: italic;
}

.auth-bp-cite {
    display: flex;
    align-items: center;
    gap: 0.6875rem;
    margin-top: 1rem;
}

.auth-bp-cite-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: #8B5E3C;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.9375rem;
    color: var(--auth-on-primary);
}

.auth-bp-cite-who {
    font-size: 0.84375rem;
    line-height: 1.4;
}

.auth-bp-cite-who b {
    display: block;
    color: var(--auth-surface);
    font-weight: 600;
}

.auth-bp-cite-who span {
    color: var(--auth-sage);
}

.auth-form-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem 2.5rem;
    position: relative;
    background: var(--auth-surface);
}

.auth-back-home {
    position: absolute;
    top: 1.75rem;
    inset-inline-end: 2.25rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--auth-ink-2);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    text-decoration: none;
    transition: color var(--auth-duration-fast) var(--auth-ease-standard);
}

.auth-back-home:hover {
    color: var(--auth-ink);
}

.auth-mobile-wordmark {
    display: none;
    align-items: center;
    gap: 0.625rem;
    margin-bottom: 1.75rem;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--auth-ink);
    text-decoration: none;
}

.auth-mobile-wordmark .auth-bp-pon {
    color: var(--auth-accent);
}

.auth-form-card {
    width: 100%;
    max-width: 25.5rem;
}

.auth-form-head h2 {
    font-size: 1.875rem;
    font-weight: 700;
    letter-spacing: -0.0375em;
    margin: 0;
    color: var(--auth-charcoal);
}

.auth-form-head p {
    font-size: 0.9375rem;
    color: var(--auth-ink-2);
    margin: 0.5625rem 0 0;
}

.auth-tabs {
    display: flex;
    background: var(--auth-surface-container-high);
    border-radius: var(--auth-radius-full);
    padding: 0.25rem;
    margin: 1.625rem 0 1.5rem;
    position: relative;
}

.auth-tabs a {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--auth-font-sans);
    font-size: 0.90625rem;
    font-weight: 600;
    color: var(--auth-ink-2);
    padding: 0.6875rem 0;
    border-radius: var(--auth-radius-full);
    text-align: center;
    text-decoration: none;
    position: relative;
    z-index: 2;
    transition: color var(--auth-duration-base) var(--auth-ease-standard);
}

.auth-tabs a.active {
    color: var(--auth-ink);
}

.auth-tab-glider {
    position: absolute;
    top: 0.25rem;
    inset-inline-start: 0.25rem;
    width: calc(50% - 0.25rem);
    height: calc(100% - 0.5rem);
    background: var(--auth-card);
    border-radius: var(--auth-radius-full);
    box-shadow: var(--auth-shadow-raised);
    transition: transform var(--auth-duration-base) var(--auth-ease-emphasized);
    z-index: 1;
}

.auth-tabs[data-mode="register"] .auth-tab-glider {
    transform: translateX(100%);
}

[dir='rtl'] .auth-tabs[data-mode="register"] .auth-tab-glider {
    transform: translateX(-100%);
}

.auth-social {
    display: flex;
    flex-direction: column;
    gap: 0.6875rem;
}

.auth-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    padding: 0.75rem;
    border: 1px solid var(--auth-line);
    border-radius: var(--auth-radius-md);
    background: var(--auth-card);
    font-family: var(--auth-font-sans);
    font-size: 0.90625rem;
    font-weight: 600;
    color: var(--auth-charcoal);
    cursor: not-allowed;
    opacity: 0.72;
}

.auth-social-btn svg {
    width: 1.125rem;
    height: 1.125rem;
    flex-shrink: 0;
}

.auth-social-note {
    font-size: 0.75rem;
    color: var(--auth-ink-3);
    text-align: center;
    margin-top: 0.25rem;
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    margin: 1.375rem 0;
    color: var(--auth-ink-2);
    font-size: 0.78125rem;
    font-weight: 500;
}

.auth-divider::before,
.auth-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--auth-line);
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.auth-field {
    display: flex;
    flex-direction: column;
    gap: 0.4375rem;
}

.auth-field label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--auth-charcoal);
}

.auth-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.auth-input-wrap .auth-input-lead {
    position: absolute;
    inset-inline-start: 0.875rem;
    color: var(--auth-ink-2);
    font-size: 1.1875rem;
    pointer-events: none;
    z-index: 1;
}

.auth-input-wrap input {
    width: 100%;
    font-family: var(--auth-font-sans);
    font-size: 0.9375rem;
    color: var(--auth-charcoal);
    padding: 0.8125rem 0.875rem 0.8125rem 2.75rem;
    border: 1px solid var(--auth-line);
    border-radius: var(--auth-radius-md);
    background: var(--auth-card);
    outline: none;
    transition: border-color var(--auth-duration-fast) var(--auth-ease-standard), box-shadow var(--auth-duration-fast) var(--auth-ease-standard);
}

[dir='rtl'] .auth-input-wrap input {
    padding: 0.8125rem 2.75rem 0.8125rem 0.875rem;
}

.auth-input-wrap input::placeholder {
    color: #A89E94;
}

.auth-input-wrap input:focus {
    border-color: var(--auth-ink);
    box-shadow: 0 0 0 4px var(--auth-focus-ring);
}

.auth-input-wrap input.auth-input-error {
    border-color: var(--auth-negative);
}

.auth-input-wrap .auth-toggle-pw {
    position: absolute;
    inset-inline-end: 0.75rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--auth-ink-2);
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-input-wrap .auth-toggle-pw .material-symbols-rounded {
    font-size: 1.25rem;
}

.auth-input-wrap input.auth-input-with-toggle {
    padding-inline-end: 2.75rem;
}

.auth-pw-meter {
    display: none;
    gap: 0.3125rem;
    margin-top: 0.125rem;
}

.auth-pw-meter.show {
    display: flex;
}

.auth-pw-meter span {
    flex: 1;
    height: 0.25rem;
    border-radius: 99px;
    background: var(--auth-surface-container-high);
    transition: background var(--auth-duration-base) var(--auth-ease-standard);
}

.auth-row-between {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.84375rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.auth-links-inline {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.auth-verify-actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.auth-link-button {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: none;
    font-size: 0.84375rem;
    color: var(--auth-ink-2);
    text-decoration: underline;
    cursor: pointer;
    text-align: center;
}

.auth-link-button:hover {
    color: var(--auth-ink);
}

.auth-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--auth-ink-2);
    cursor: pointer;
    user-select: none;
}

.auth-check input {
    width: 1.0625rem;
    height: 1.0625rem;
    accent-color: var(--auth-ink);
    cursor: pointer;
}

.auth-link {
    color: var(--auth-ink);
    font-weight: 600;
    text-decoration: none;
}

.auth-link:hover {
    text-decoration: underline;
}

.auth-terms {
    font-size: 0.78125rem;
    color: var(--auth-ink-2);
    line-height: 1.5;
}

.auth-submit {
    margin-top: 0.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.8125rem 1rem;
    border: none;
    border-radius: var(--auth-radius-md);
    background: var(--auth-ink);
    color: var(--auth-on-primary);
    font-family: var(--auth-font-sans);
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--auth-duration-fast) var(--auth-ease-standard);
}

.auth-submit:hover {
    background: var(--auth-ink-light);
}

.auth-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.auth-alt {
    text-align: center;
    font-size: 0.875rem;
    color: var(--auth-ink-2);
    margin-top: 1.375rem;
}

.auth-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--auth-ink);
    text-decoration: none;
    margin-bottom: 1.25rem;
}

.auth-back-link:hover {
    text-decoration: underline;
}

.auth-session-status {
    border: 1px solid var(--auth-line);
    background: var(--auth-primary-tint);
    color: var(--auth-ink);
    border-radius: var(--auth-radius-md);
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    margin-bottom: 1rem;
}

.auth-field-error {
    font-size: 0.8125rem;
    color: var(--auth-negative);
    margin-top: 0.25rem;
}

@media (max-width: 880px) {
    .auth-grid {
        grid-template-columns: 1fr;
    }

    .auth-brand-panel {
        display: none;
    }

    .auth-mobile-wordmark {
        display: inline-flex;
    }

    .auth-form-panel {
        padding: 2rem 1.25rem;
        align-items: flex-start;
        padding-top: 4rem;
    }

    .auth-back-home {
        top: 1rem;
        inset-inline-end: 1rem;
    }
}
