:root{--navy:#0d2e4f;--navy2:#12426e;--blue:#1f6fb2;--green:#6cc04a;--ink:#15212e;--muted:#5b6b7a;--bg:#f4f7fb;--card:#fff;--line:#e3e9f0}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,'Segoe UI',Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--navy);color:#fff;padding:14px 22px}
.brand{color:#fff;font-weight:800;font-size:20px;letter-spacing:-.5px}
.brand:hover{text-decoration:none}
.brand span{color:var(--green)}
.topbar nav a{color:#cdd9e6;margin-left:18px;font-weight:600}
.topbar nav a:hover{color:#fff;text-decoration:none}
.wrap{max-width:980px;margin:28px auto;padding:0 18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px;box-shadow:0 1px 2px rgba(16,40,70,.04)}
h1{font-size:24px;margin:.2em 0 .35em}
h2{font-size:18px;margin:0 0 12px}
.muted{color:var(--muted)}
label{display:block;font-weight:600;font-size:13px;margin:12px 0 5px}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:15px;font-family:inherit;background:#fff}
input:focus,select:focus{outline:none;border-color:var(--blue)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>div{flex:1;min-width:150px}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#06310f;border:none;border-radius:10px;padding:11px 18px;font-weight:700;font-size:15px;cursor:pointer;margin-right:8px}
.btn:hover{filter:brightness(1.04)}
.btn.secondary{background:#eef2f7;color:var(--ink);border:1px solid var(--line)}
.btn.blue{background:var(--blue);color:#fff}
.btn.danger{background:#e5484d;color:#fff}
.btn.block{display:flex;width:100%;justify-content:center;margin-right:0}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:capitalize}
.pill.open{background:#e7f0fb;color:#1b5e9c}
.pill.claimed,.pill.on_site,.pill.pending{background:#fff3df;color:#9a6500}
.pill.checked_in,.pill.completed{background:#e9f6e0;color:#3f6d1a}
.pill.signed_off,.pill.paid,.pill.approved{background:#dff3ea;color:#0f7048}
.pill.rejected{background:#fde7e7;color:#b3261e}
.err{background:#fde7e7;color:#b3261e;border:1px solid #f6c9c9;padding:10px 12px;border-radius:9px;margin-bottom:12px;font-size:14px}
.authcard{max-width:420px;margin:56px auto}
/* login portal variants — dealer (light) vs admin hub (dark ops console) */
.auth-badge{display:inline-block;font-weight:700;font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:4px 11px;border-radius:999px;margin-bottom:12px}
.auth-badge.dealer{background:#e9f6e0;color:#3f6d1a}
.auth-badge.hub{background:#103a63;color:#7fc4ff}
.authcard.auth-dealer{border-top:4px solid var(--green)}
.authcard.auth-hub{background:var(--navy);border:1px solid #16385c;box-shadow:0 8px 30px rgba(7,24,42,.28)}
.auth-hub h1{color:#fff}
.auth-hub .muted{color:#9fb3c8}
.auth-hub label{color:#b9cadb}
.auth-hub input{background:#0e2c49;border:1px solid #5b82ad;color:#eaf2fb}
.auth-hub input:focus{border-color:#7fc0ff;outline:2px solid rgba(127,192,255,.5);outline-offset:1px}
.auth-hub .err{background:#3a1620;color:#ffb4b4;border-color:#5a2230}
.auth-feature{list-style:none;padding:0;margin:16px 0 0}
.auth-feature li{position:relative;padding:5px 0 5px 24px;font-size:14px;color:var(--muted)}
.auth-feature li::before{content:'';position:absolute;left:4px;top:11px;width:8px;height:8px;border-radius:2px;background:var(--green)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.stat{background:var(--navy);color:#fff;border-radius:12px;padding:16px;font-size:13px;color:#bcccdd}
.stat b{font-size:26px;display:block;color:#fff;margin-bottom:2px}
.right{text-align:right}
.empty{color:var(--muted);padding:18px;text-align:center}
