/* ==========================================================================
   ACBIZ CFMS — Auth Pages (Login / Register)
   Minimal branded chrome: small top mark, centered ledger card, quiet
   footer. Uses tokens from brand.css.
   ========================================================================== */

body.auth-app {
    margin: 0;
    min-height: 100vh;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-body);
    display: flex;
    flex-direction: column;
}

.auth-topbar {
    padding: 22px 28px;
}
.auth-topbar a {
    font-family: var(--font-display); font-weight: 700; font-size: 16px;
    color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 8px;
}
.auth-topbar .mark {
    width: 26px; height: 26px; border-radius: 6px;
    background: var(--ledger); color: var(--paper);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-mono); font-size: 12px; font-weight: 500;
}

.auth-wrap {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.auth-card {
    width: 100%;
    max-width: 400px;
    background: var(--paper-raised);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 36px 32px;
    box-shadow: 0 20px 50px -24px rgba(11, 31, 26, 0.25);
}
.auth-eyebrow {
    font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .08em;
    text-transform: uppercase; color: var(--ledger-bright); font-weight: 500;
    display: block; margin-bottom: 8px;
}
.auth-card h2 {
    font-family: var(--font-display); font-size: 24px; font-weight: 700;
    margin: 0 0 26px; letter-spacing: -0.01em;
}

.auth-card .form-group { margin-bottom: 18px; }
.auth-card .form-group label {
    display: block; font-size: 13px; font-weight: 500; margin-bottom: 6px;
    color: var(--ink-soft);
}
.auth-card .form-group input {
    width: 100%; padding: 11px 14px; border: 1px solid var(--line);
    border-radius: 8px; font-size: 14.5px; font-family: var(--font-body);
    background: var(--paper); color: var(--ink); transition: border-color .15s, box-shadow .15s;
}
.auth-card .form-group input:focus {
    outline: none; border-color: var(--ledger-bright);
    box-shadow: 0 0 0 3px rgba(30, 122, 95, 0.14);
    background: var(--paper-raised);
}
.auth-card .form-group input::placeholder { color: #9AA39D; }

.auth-card .btn-primary {
    width: 100%; text-align: center;
    background: var(--ledger); font-family: var(--font-body); font-weight: 600;
    border: none; border-radius: 8px; padding: 12px 20px; font-size: 15px;
    color: var(--paper); cursor: pointer;
}
.auth-card .btn-primary:hover { background: var(--ink); }

.auth-footer {
    margin-top: 22px; text-align: center; font-size: 13.5px; color: var(--ink-soft);
}
.auth-footer a { color: var(--ledger-bright); font-weight: 500; text-decoration: none; }
.auth-footer a:hover { color: var(--ledger); }

.auth-bottombar {
    padding: 18px 28px; text-align: center;
    font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft);
}

/* Flash messages render inside a max-width wrapper in the layout itself,
   so no special-casing needed here. */
