.auth-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 32px; background: var(--alt, #f6f8fa); }
.auth-card { background: #fff; border: 1px solid var(--border, #e1e4e8); border-radius: 12px; padding: 40px 36px; max-width: 420px; width: 100%; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.auth-brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--ink, #0A0F14); font-weight: 700; font-size: 18px; margin-bottom: 28px; font-family: var(--sans); }
.auth-brand .b-app { color: var(--green, #00A35B); font-weight: 800; }
.auth-brand .b-tld { color: var(--mute-2, #9AA3AE); font-weight: 500; font-size: 14px; }
.auth-brand:hover { color: var(--green-d, #008A4D); }
.auth-shield { width: 32px; height: 32px; background: #00A35B; color: #fff; border-radius: 8px; padding: 6px; box-sizing: border-box; }
.auth-shield svg { width: 100%; height: 100%; }
.auth-card h1 { font-size: 24px; margin: 0 0 6px; }
.auth-sub { color: var(--mute, #6e7681); margin: 0 0 24px; font-size: 14px; }
.auth-error { background: #fbe1e1; color: #b32424; border: 1px solid #f5c6c6; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }
.auth-success { background: #e6f4eb; color: #207a3a; border: 1px solid #b7d8c1; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }
.auth-hint { font-size: 13px; color: var(--mute, #6e7681); margin: -6px 0 14px; }
.auth-hint-ok { color: #207a3a; margin-left: 6px; }
.link-btn { background: none; border: 0; color: #2da14a; cursor: pointer; padding: 0; font: inherit; text-decoration: underline; }
.link-btn:disabled { color: var(--mute, #6e7681); cursor: default; }
.field { margin-bottom: 16px; }
.field-label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 6px; }
.field-hint { font-size: 12px; color: var(--mute, #6e7681); margin: 4px 0 0; }
.input { width: 100%; padding: 10px 12px; border: 1px solid var(--border, #e1e4e8); border-radius: 8px; font-size: 14px; box-sizing: border-box; }
.input:focus { outline: none; border-color: #2da14a; box-shadow: 0 0 0 3px rgba(45,161,74,0.15); }
.checkbox { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--ink-2, #57606a); margin: 16px 0 12px; cursor: pointer; }
.checkbox input { margin-top: 3px; }
.auth-submit { width: 100%; margin-top: 8px; }
.auth-foot { text-align: center; margin-top: 20px; font-size: 13px; color: var(--mute, #6e7681); }
.auth-foot a { color: #2da14a; }
.dot-sep { margin: 0 10px; color: var(--border, #e1e4e8); }
.auth-brand-wrap { display: flex; justify-content: center; margin-bottom: 16px; }
.auth-cookie-note { text-align: center; margin: 24px 0 0; font-size: 11px; line-height: 1.5; color: var(--mute-2, #9AA3AE); }
.auth-cookie-note a { color: var(--mute, #6e7681); text-decoration: underline; }
