/* =========================================================================
   Voxelmaps · auth.css · login + signup pages (engine v0.4.0)
   Brand-token import same as the rest of the app.
   ========================================================================= */

:root{
  --vox-cyan:#00a8e9; --vox-blue:#007da7; --vox-navy:#003458;
  --vox-navy-2:#022844; --vox-ink:#0a1626;
  --bg:#f4f6f9; --surface:#ffffff; --surface-2:#f9fafc;
  --line:#e3e8ef; --line-2:#d2dae4;
  --text:#0a1626; --text-2:#475569; --text-3:#94a3b8;
  --success:#10b981; --warn:#f59e0b; --danger:#ef4444;
  --radius-sm:8px; --radius:14px; --radius-lg:22px;
  --shadow-sm: 0 1px 2px rgba(10,22,38,.06), 0 1px 3px rgba(10,22,38,.04);
  --shadow:    0 4px 14px rgba(10,22,38,.08), 0 2px 4px rgba(10,22,38,.04);
  --shadow-lg: 0 24px 60px -20px rgba(0,52,88,.35), 0 8px 20px rgba(10,22,38,.08);
  --font-display:"Bricolage Grotesque","Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  --font-body:"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
}
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body); color:var(--text);
  background:linear-gradient(140deg, var(--vox-navy) 0%, var(--vox-navy-2) 50%, #001a2e 100%);
  min-height:100vh; -webkit-font-smoothing:antialiased; line-height:1.5;
  display:grid; place-items:center; padding:24px;
}
button{font:inherit;color:inherit;border:0;background:none;cursor:pointer}
input{font:inherit;color:inherit}

.auth-card{
  position:relative;
  width:min(440px, 100%);
  background:var(--surface);
  border-radius:var(--radius-lg);
  padding:36px 32px;
  box-shadow:var(--shadow-lg);
}
.auth-brand{display:flex;align-items:center;gap:10px;color:var(--vox-navy);font-weight:700;margin-bottom:18px}
.auth-brand svg{width:32px;height:32px}
.auth-brand__name{font-family:var(--font-display);letter-spacing:-.02em;font-size:18px}
.auth-brand__divider{width:1px;height:18px;background:var(--line-2);margin:0 4px}
.auth-brand__page{font-size:13px;color:var(--text-2);font-weight:500}

.auth-card h1{
  font-family:var(--font-display);font-weight:700;
  font-size:26px;letter-spacing:-.02em;line-height:1.15;
  margin:0 0 6px;color:var(--vox-navy);
}
.auth-card .lede{margin:0 0 22px;color:var(--text-2);font-size:14.5px}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field__label{font-size:13px;font-weight:600;color:var(--vox-navy)}
.field input[type=text],
.field input[type=email],
.field input[type=password]{
  width:100%;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:11px 13px;font-size:15px;color:var(--text);
  transition:border-color .15s,background .15s,box-shadow .15s;
}
.field input:focus{
  outline:0;border-color:var(--vox-cyan);
  background:var(--surface);box-shadow:0 0 0 3px rgba(0,168,233,.14);
}
.field__hint{font-size:12px;color:var(--text-3)}

.auth-honeypot{position:absolute;left:-9999px;top:-9999px;opacity:0;pointer-events:none;height:0;width:0}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:99px;
  font-weight:600;font-size:15px;letter-spacing:-.005em;
  transition:all .2s cubic-bezier(.2,.8,.2,1);cursor:pointer;width:100%;
}
.btn--primary{background:var(--vox-navy);color:#fff;box-shadow:0 6px 16px -4px rgba(0,52,88,.4)}
.btn--primary:hover:not([disabled]){background:var(--vox-blue);transform:translateY(-1px)}
.btn[disabled]{opacity:.55;cursor:not-allowed}

.auth-foot{margin-top:18px;font-size:13.5px;color:var(--text-2);text-align:center}
.auth-foot a{color:var(--vox-blue);text-decoration:none;font-weight:600}
.auth-foot a:hover{text-decoration:underline}

.flash-msg{
  margin:0 0 14px;padding:10px 12px;border-radius:var(--radius-sm);
  font-size:13.5px;border:1px solid;line-height:1.5;
}
.flash-msg--err{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.flash-msg--ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.flash-msg--info{background:#eff6fb;border-color:#cfe5f3;color:#003458}
