/* /members/assets/css/members-auth.css — logged-out member pages rendered
   inside the PUBLIC site chrome (header/nav/footer of sahara.studio).
   Everything is scoped under .member-auth so the site's own styles are
   untouched; the card inherits the site's font. Tokens mirror members.css
   (rose #B57170 = the site's own accent). Logged-in pages use members.css. */

.member-auth {
    --paper:       #FFFFFF;
    --paper-warm:  #F4F4F4;
    --ink-0:       #1A1A1A;
    --ink-1:       #3F3F3F;
    --ink-2:       #6B6B6B;
    --ink-3:       #A0A0A0;
    --rule:        #E4E4E0;
    --rule-strong: #C8C8C2;
    --accent:      #B57170;
    --accent-deep: #82514F;
    --accent-soft: #EBD6D5;
    --radius-card: 8px;

    width: 980px;
    margin: 0 auto;
    padding: 56px 0 72px;
    display: flex;
    justify-content: center;
}

.member-auth .auth-card {
    width: 430px;
    max-width: 100%;
    box-sizing: border-box;
    background: var(--paper);
    border: 1px solid var(--rule);
    border-top: 4px solid var(--accent);
    border-radius: var(--radius-card);
    box-shadow: 0 1px 0 rgba(27,24,20,0.03), 0 12px 28px -18px rgba(27,24,20,0.16);
    padding: 32px 30px;
    color: var(--ink-0);
    text-align: left;
    font-size: 14px;
    line-height: 1.5;
}

/* Brand block inside the card */
.member-auth .topbar__brand { display: flex; align-items: center; gap: 12px; font-weight: 600; font-size: 16px; color: var(--ink-0); text-decoration: none; }
.member-auth .topbar__mark { width: 12px; height: 12px; background: var(--accent); transform: rotate(45deg); flex: none; }
.member-auth .topbar__text { display: flex; flex-direction: column; gap: 3px; }
.member-auth .topbar__name { line-height: 1; letter-spacing: -0.015em; }
.member-auth .topbar__sub { font-size: 9px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--accent); font-weight: 500; line-height: 1; }

.member-auth h1 { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; margin: 22px 0 6px; color: var(--ink-0); }
.member-auth p { margin: 8px 0; }

/* Forms */
.member-auth form { margin-top: 18px; display: grid; gap: 14px; }
.member-auth label.field { display: block; font-size: 13px; color: var(--ink-2); }
.member-auth label.field span { display: block; margin-bottom: 5px; }
.member-auth input[type=text],
.member-auth input[type=email],
.member-auth input[type=password] {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 12px;
    border: 1px solid var(--rule);
    border-radius: var(--radius-card);
    font-size: 14px;
    background: #fff;
    color: var(--ink-0);
}
.member-auth input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.member-auth label.check { display: flex; align-items: flex-start; gap: 9px; font-size: 13.5px; cursor: pointer; color: var(--ink-1); }
.member-auth label.check input { margin-top: 3px; accent-color: var(--accent); }
.member-auth .hint { font-size: 12px; color: var(--ink-2); margin: 6px 0 0; }

/* Buttons — same admin-derived system as the portal */
.member-auth .btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--ink-0);
    background: transparent;
    border: 1px solid var(--rule-strong);
    border-radius: 999px;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.member-auth .btn:hover { background: var(--paper-warm); border-color: var(--ink-3); color: var(--ink-0); text-decoration: none; }
.member-auth .btn--primary {
    color: var(--paper);
    background: var(--ink-0);
    border-color: var(--ink-0);
    box-shadow: 0 8px 22px -12px rgba(27,24,20,0.4);
}
.member-auth .btn--primary:hover { color: var(--paper); background: var(--accent); border-color: var(--accent); }

/* Flash banners */
.member-auth .flash { padding: 12px 16px; border-radius: var(--radius-card); margin: 14px 0 4px; font-size: 13.5px; }
.member-auth .flash--ok { background: rgba(107, 130, 101, 0.14); color: #4F6248; }
.member-auth .flash--err { background: rgba(158, 74, 46, 0.12); color: #9E4A2E; }

/* Links row under the form */
.member-auth .auth-links { margin-top: 18px; font-size: 13px; display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.member-auth .auth-links a { color: var(--accent); }

/* Honeypot — visually gone, still in the DOM for bots. */
.member-auth .hp-field { position: absolute; left: -9999px; top: -9999px; height: 1px; overflow: hidden; }
