/* Rust Forge — shared styles for the login + gated app pages.
   Tokens mirror the public site (navy monochrome, mono labels, gold hairline). */
:root{
  --navy:#395083; --navy-d:#22335a; --navy-dd:#192645; --navy-l:#5a6fa0;
  --lgray:#BFC6D2; --ink:#2F2F2F; --paper:#FFFFFF;
  --panel:#F3F5F8; --warm:#F5F2EC; --hair:#dce1ea; --gold:#B98A33;
  --arial: Arial,"Helvetica Neue",Helvetica,sans-serif;
  --mono: ui-monospace,"SF Mono",Menlo,Consolas,"Courier New",monospace;
  --maxw:1100px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--panel);color:var(--ink);font-family:var(--arial);
  -webkit-font-smoothing:antialiased;line-height:1.55;font-size:16px}
h1,h2,h3,h4,p{margin:0}
a{color:inherit}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;font-size:12px;color:var(--navy)}
.eyebrow::before{content:"";display:inline-block;width:22px;height:2px;background:var(--gold);
  vertical-align:middle;margin-right:10px}

/* App top bar */
.appbar{display:flex;align-items:center;gap:16px;padding:14px 28px;background:var(--navy-dd);color:#fff}
.appbar .ralogo{height:30px;width:auto;color:#fff}
.appbar .sp{flex:1}
.appbar .who{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:#c2cbe0;text-align:right;line-height:1.3}
.appbar .who b{color:#fff;font-weight:700}
.appbar .role{display:inline-block;margin-top:3px;padding:2px 8px;border:1px solid rgba(255,255,255,.3);
  border-radius:99px;font-size:10px;letter-spacing:.12em;text-transform:uppercase}
.appbar .out{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  color:#fff;text-decoration:none;border:1.5px solid rgba(255,255,255,.4);border-radius:3px;
  padding:9px 14px;cursor:pointer;background:none;transition:background .2s}
.appbar .out:hover{background:rgba(255,255,255,.12)}

.shell{max-width:var(--maxw);margin:0 auto;padding:48px 28px 80px}
.pagehead{margin-bottom:34px}
.pagehead h1{font-size:34px;font-weight:800;color:var(--navy-d);letter-spacing:-.02em;margin-top:8px}
.pagehead p{color:#5b6373;max-width:60ch;margin-top:10px}

/* Tile grid (hub) */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.tile{display:block;background:#fff;border:1px solid var(--hair);border-radius:8px;padding:24px;
  text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s}
.tile:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(20,30,60,.10);border-color:var(--navy-l)}
.tile .ico{font-size:24px;display:block;margin-bottom:14px}
.tile h3{font-size:18px;color:var(--navy-d);font-weight:800}
.tile p{font-size:13.5px;color:#67707f;margin-top:6px}
.tile .go{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  color:var(--navy);margin-top:14px;display:inline-block}
.tile.soon{opacity:.55;pointer-events:none}
.tile.soon .go::after{content:" · soon"}

/* Table (admin) */
.card{background:#fff;border:1px solid var(--hair);border-radius:8px;overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--hair)}
th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:#67707f;background:var(--panel)}
tr:last-child td{border-bottom:none}
td .nm{font-weight:700;color:var(--navy-d)}
td .em{color:#67707f;font-size:12.5px}
select.role{font-family:var(--mono);font-size:12px;padding:7px 10px;border:1px solid var(--hair);
  border-radius:4px;background:#fff;color:var(--navy-d);text-transform:capitalize}
.pill{display:inline-block;padding:3px 10px;border-radius:99px;font-family:var(--mono);font-size:10px;
  letter-spacing:.1em;text-transform:uppercase}
.pill.admin{background:#efe3cb;color:#7a5a13}
.pill.employee{background:#dde6f6;color:#2c4480}
.pill.customer{background:#dcefe6;color:#1c6a3f}
.pill.vendor{background:#e7ddf6;color:#553a86}
.pill.pending{background:#f0e2e2;color:#8a4a4a}

/* Login + simple centered card */
.centerwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,#22335a 0%,#192645 100%)}
.authcard{background:#fff;border-radius:12px;max-width:430px;width:100%;padding:44px 40px;
  box-shadow:0 30px 70px rgba(10,18,40,.35)}
.authcard .ralogo{height:34px;color:var(--navy-d);margin-bottom:26px}
.authcard h1{font-size:25px;color:var(--navy-d);font-weight:800;letter-spacing:-.015em}
.authcard p.sub{color:#67707f;font-size:14.5px;margin-top:10px;margin-bottom:28px}
.gbtn{display:flex;align-items:center;justify-content:center;gap:11px;width:100%;cursor:pointer;
  border:1.5px solid var(--hair);background:#fff;border-radius:6px;padding:14px;font-size:15px;
  font-weight:600;color:var(--ink);transition:background .18s,border-color .18s}
.gbtn:hover{background:var(--panel);border-color:var(--navy-l)}
.gbtn svg{width:19px;height:19px}
.fineprint{font-size:12px;color:#8a93a3;margin-top:22px;line-height:1.6}
.err{background:#fbeaea;color:#8a3232;font-size:13px;padding:11px 14px;border-radius:6px;margin-top:18px;display:none}
.note{background:#e6f3ec;color:#1c6a3f;font-size:13px;padding:11px 14px;border-radius:6px;margin-top:18px;display:none;line-height:1.5}
.divider{display:flex;align-items:center;gap:12px;margin:22px 0 18px;color:#9aa3b3;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--hair)}
.field{display:block;width:100%;margin-bottom:12px;padding:13px 14px;font-size:15px;
  font-family:var(--arial);border:1.5px solid var(--hair);border-radius:6px;color:var(--ink);background:#fff}
.field:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(57,80,131,.12)}
.submit{width:100%;margin-top:4px;cursor:pointer;border:2px solid var(--navy);background:var(--navy);
  color:#fff;font-weight:700;border-radius:6px;padding:14px;font-size:15px;transition:background .18s}
.submit:hover{background:var(--navy-d)}
.submit:disabled{opacity:.6;cursor:default}
.linkrow{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}
.linkbtn{background:none;border:none;padding:0;cursor:pointer;font-family:var(--arial);
  font-size:13px;color:var(--navy);text-align:left}
.linkbtn:hover{text-decoration:underline}
.choice{display:flex;gap:14px;margin-top:8px}
.choice button{flex:1;background:#fff;border:1.5px solid var(--hair);border-radius:8px;padding:22px 16px;
  cursor:pointer;text-align:left;transition:border-color .18s,background .18s}
.choice button:hover{border-color:var(--navy);background:var(--panel)}
.choice .ico{font-size:22px}
.choice h3{font-size:16px;color:var(--navy-d);margin-top:10px}
.choice p{font-size:12.5px;color:#67707f;margin-top:4px}
.btn{font-family:var(--mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  padding:14px 26px;border:2px solid var(--navy);background:var(--navy);color:#fff;font-weight:700;
  border-radius:4px;cursor:pointer;text-decoration:none;display:inline-block}
.btn:hover{background:var(--navy-d);border-color:var(--navy-d)}
@media(max-width:560px){.shell{padding:32px 18px 64px}.pagehead h1{font-size:27px}}
