/* Berabera Agent Console — design system
   Thesis: a field activation console. Signature = the activation rail + the
   lock-state flip (amber "unlocked" -> green "secured"). MovaPay orange is the
   sole action accent. */

:root{
  --canvas:#FBFAF7; --surface:#FFFFFF; --surface-2:#F4F1EB;
  --ink:#1A1714; --muted:#6B645C; --faint:#9A938A;
  --muted-2:#8A8278;
  --brand:#F58220; --brand-deep:#C45E00; --brand-tint:#FFF1E3;
  --secure:#0E7C66; --secure-tint:#E1F2EC;
  --alert:#C0392B; --alert-tint:#FBE9E7;
  --hairline:#E7E1D8; --hairline-2:#EFEAE2;
  --ink-inv:#FBFAF7;
  --radius:14px; --radius-sm:9px; --radius-lg:22px;
  --shadow:0 1px 2px rgba(26,23,20,.04), 0 8px 24px -12px rgba(26,23,20,.16);
  --shadow-lg:0 24px 60px -24px rgba(26,23,20,.28);
  --display:'Space Grotesk','Segoe UI',system-ui,-apple-system,sans-serif;
  --body:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono','SF Mono',ui-monospace,'Cascadia Mono',monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--body); background:var(--canvas); color:var(--ink);
  line-height:1.5; font-size:15px; letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;letter-spacing:-.025em;line-height:1.1}
.mono{font-family:var(--mono);font-variant-ligatures:none}

/* ── App shell: nav rail + main ─────────────────────────────────── */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.rail{
  background:var(--surface);border-right:1px solid var(--hairline);
  display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh;
}
.brandmark{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}
.brandmark .logo{width:34px;height:34px;flex:none}
.brandmark .wordmark{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.03em}
.brandmark .wordmark b{color:var(--brand)}
.brandmark .sub{display:block;font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.02em;margin-top:1px}

.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.nav .label{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted-2);padding:14px 10px 6px;font-weight:600}
.nav a{
  display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--ink);font-weight:500;font-size:14px;position:relative;transition:background .12s;
}
.nav a svg{width:18px;height:18px;color:var(--muted);flex:none}
.nav a:hover{background:var(--surface-2)}
.nav a.active{background:var(--brand-tint);color:var(--brand-deep)}
.nav a.active svg{color:var(--brand)}
.nav a.disabled{opacity:.4;cursor:not-allowed}
.nav a.disabled .lockicon{margin-left:auto;width:13px;height:13px}

.rail .me{margin-top:auto;border-top:1px solid var(--hairline);padding-top:14px;display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:14px;flex:none}
.me .who{min-width:0}
.me .who .nm{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.me .who .rl{font-size:11px;color:var(--muted)}

.main{padding:30px 38px 64px;max-width:1180px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;gap:16px;flex-wrap:wrap}
.topbar .crumbs{font-size:13px;color:var(--muted)}
.topbar .crumbs b{color:var(--ink);font-weight:600}
.tenant-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--hairline);border-radius:999px;padding:6px 13px 6px 8px;font-size:13px;font-weight:500;box-shadow:var(--shadow)}
.tenant-chip .dot{width:9px;height:9px;border-radius:50%;background:var(--brand)}

h1.page{font-size:30px;margin-bottom:4px}
.page-sub{color:var(--muted);font-size:15px;margin-bottom:26px;max-width:60ch}

/* ── Cards / grid ───────────────────────────────────────────────── */
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card h3{font-size:16px;margin-bottom:3px}
.card .hint{color:var(--muted);font-size:13px}

.stat{display:flex;flex-direction:column;gap:6px}
.stat .n{font-family:var(--display);font-size:34px;font-weight:600;letter-spacing:-.04em;line-height:1}
.stat .k{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.stat.secure .n{color:var(--secure)}
.stat.brand .n{color:var(--brand-deep)}

/* ── Activation rail (signature) ────────────────────────────────── */
.rail-steps{display:flex;align-items:stretch;gap:0;margin:6px 0 30px;border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.rail-steps .step{flex:1;padding:15px 16px;display:flex;gap:12px;align-items:center;position:relative;border-right:1px solid var(--hairline)}
.rail-steps .step:last-child{border-right:0}
.rail-steps .step .idx{width:28px;height:28px;border-radius:50%;border:1.6px solid var(--hairline);display:grid;place-items:center;font-family:var(--mono);font-size:13px;color:var(--muted);flex:none;background:var(--surface)}
.rail-steps .step .t{font-size:13px;font-weight:600;line-height:1.15}
.rail-steps .step .d{font-size:11px;color:var(--muted)}
.rail-steps .step.done .idx{background:var(--secure);border-color:var(--secure);color:#fff}
.rail-steps .step.active{background:var(--brand-tint)}
.rail-steps .step.active .idx{border-color:var(--brand);color:var(--brand-deep)}
.rail-steps .step.active .t{color:var(--brand-deep)}

/* ── Forms ──────────────────────────────────────────────────────── */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.field .req{color:var(--brand)}
.field input,.field select,.field textarea{
  width:100%;padding:11px 13px;border:1px solid var(--hairline);border-radius:var(--radius-sm);
  font-family:var(--body);font-size:14.5px;background:var(--surface);color:var(--ink);transition:border .12s,box-shadow .12s;
}
.field input.mono{font-family:var(--mono);letter-spacing:.04em}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}
.field .help{font-size:12px;color:var(--muted);margin-top:5px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--body);font-weight:600;font-size:14.5px;padding:11px 20px;border-radius:var(--radius-sm);
  border:1px solid transparent;cursor:pointer;transition:transform .06s,background .12s,box-shadow .12s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 1px 0 var(--brand-deep)}
.btn-primary:hover{background:var(--brand-deep)}
.btn-ghost{background:var(--surface);border-color:var(--hairline);color:var(--ink)}
.btn-ghost:hover{background:var(--surface-2)}
.btn-secure{background:var(--secure);color:#fff}
.btn-danger{background:var(--surface);border-color:var(--alert);color:var(--alert)}
.btn-danger:hover{background:var(--alert-tint)}
.btn svg{width:17px;height:17px}
.btn.lg{padding:13px 26px;font-size:15.5px}

/* ── Device cards ───────────────────────────────────────────────── */
.devices{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.device{display:flex;gap:15px;padding:15px;border:1px solid var(--hairline);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:border .12s,box-shadow .12s,transform .08s}
.device:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.device.chosen{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}
.device .shot{width:74px;height:104px;flex:none;border-radius:9px;background:var(--surface-2);display:grid;place-items:center;overflow:hidden}
.device .shot svg{width:100%;height:100%}
.device .meta h4{font-size:15px;margin-bottom:2px}
.device .meta .brand{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600}
.device .meta .price{font-family:var(--display);font-weight:600;font-size:18px;margin-top:7px;letter-spacing:-.02em}
.device .meta .specs{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.spec{font-size:11px;background:var(--surface-2);border-radius:5px;padding:2px 7px;color:var(--muted);font-weight:500}
.device .meta .stock{font-size:11px;color:var(--secure);font-weight:600;margin-top:6px}

/* ── Lock-state badge (the flip) ────────────────────────────────── */
.lockbadge{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:600;border:1px solid}
.lockbadge svg{width:14px;height:14px}
.lockbadge.unlocked{background:var(--brand-tint);border-color:#F3C99A;color:var(--brand-deep)}
.lockbadge.secured{background:var(--secure-tint);border-color:#A9D9CC;color:var(--secure)}
.lockbadge.none{background:var(--surface-2);border-color:var(--hairline);color:var(--muted)}

/* ── Tables ─────────────────────────────────────────────────────── */
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--hairline)}
td{padding:12px;border-bottom:1px solid var(--hairline-2)}
tr:last-child td{border-bottom:0}
.tag{display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;background:var(--surface-2);color:var(--muted)}
.tag.in_stock{background:var(--secure-tint);color:var(--secure)}
.tag.assigned{background:var(--brand-tint);color:var(--brand-deep)}
.tag.reserved{background:#FFF6E0;color:#8A6D00}

/* ── Receipt ────────────────────────────────────────────────────── */
.receipt{font-family:var(--mono);font-size:13px;line-height:1.7;background:var(--surface);border:1px dashed var(--hairline);border-radius:var(--radius);padding:24px;white-space:pre-wrap;max-width:380px}

/* ── Alerts ─────────────────────────────────────────────────────── */
.banner{border-radius:var(--radius-sm);padding:13px 16px;font-size:14px;font-weight:500;display:flex;gap:10px;align-items:flex-start;margin-bottom:18px}
.banner svg{width:18px;height:18px;flex:none;margin-top:1px}
.banner.ok{background:var(--secure-tint);color:var(--secure)}
.banner.warn{background:#FFF6E0;color:#8A6D00}
.banner.err{background:var(--alert-tint);color:var(--alert)}

/* ── Login ──────────────────────────────────────────────────────── */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth .hero{background:var(--ink);color:var(--ink-inv);padding:56px 56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth .hero .glow{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(245,130,32,.5),transparent 62%);top:-160px;right:-160px;filter:blur(8px)}
.auth .hero .wm{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-.03em;position:relative}
.auth .hero .wm b{color:var(--brand)}
.auth .hero .pitch{position:relative;max-width:30ch}
.auth .hero .pitch h2{font-size:38px;line-height:1.04;letter-spacing:-.03em}
.auth .hero .pitch p{color:#C9C2B8;margin-top:16px;font-size:15px;line-height:1.6}
.auth .hero .marks{display:flex;gap:22px;position:relative;font-size:12.5px;color:#C9C2B8}
.auth .hero .marks b{color:#fff;display:block;font-family:var(--display);font-size:20px}
.auth .form-side{display:grid;place-items:center;padding:40px}
.auth .form-box{width:100%;max-width:360px}
.auth .form-box h1{font-size:26px;margin-bottom:5px}
.auth .form-box .sub{color:var(--muted);margin-bottom:26px;font-size:14px}
.demo-users{margin-top:22px;border-top:1px solid var(--hairline);padding-top:16px}
.demo-users .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:10px}
.demo-users .u{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--muted)}
.demo-users .u b{color:var(--ink);font-weight:600}

@media (max-width:880px){
  .app{grid-template-columns:1fr}.rail{display:none}
  .auth{grid-template-columns:1fr}.auth .hero{display:none}
  .cols-2,.cols-3,.cols-4,.devices,.row{grid-template-columns:1fr}
  .rail-steps{flex-wrap:wrap}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ── CCI control-tower variant (internal MovaPay tool) ─────────────── */
body.cci .rail{background:#15110E;border-right-color:#2A241E}
body.cci .rail .brandmark .wordmark{color:#FBFAF7}
body.cci .rail .nav .label{color:#7C726604}
body.cci .rail .nav .label{color:#8A7E70}
body.cci .rail .nav a{color:#E7E1D8}
body.cci .rail .nav a svg{color:#9A938A}
body.cci .rail .nav a:hover{background:#231D17}
body.cci .rail .nav a.active{background:rgba(245,130,32,.16);color:#F9A24A}
body.cci .rail .nav a.active svg{color:#F58220}
body.cci .rail .me{border-top-color:#2A241E}
body.cci .rail .me .who .nm{color:#FBFAF7}
body.cci .internal-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.07em;color:#F9A24A;background:rgba(245,130,32,.12);
  border:1px solid rgba(245,130,32,.3);border-radius:999px;padding:3px 10px}
.pri-critical{color:var(--alert);font-weight:600}
.pri-high{color:#C45E00;font-weight:600}
.pri-medium{color:var(--muted)}
.pri-low{color:var(--muted-2)}
.tag.open{background:var(--brand-tint);color:var(--brand-deep)}
.tag.in_progress{background:#FFF6E0;color:#8A6D00}
.tag.resolved{background:var(--secure-tint);color:var(--secure)}
.tag.escalated{background:var(--alert-tint);color:var(--alert)}
.lender-row td b{font-weight:600}
.chips{display:flex;gap:5px;flex-wrap:wrap}
.chip2{font-size:11px;background:var(--surface-2);border-radius:5px;padding:2px 8px;color:var(--muted);font-weight:500}

/* ── IMEI scan-first capture ───────────────────────────────────────── */
.imei-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-sm svg{width:15px;height:15px}
.imei-live{font-size:12.5px;font-weight:600;color:var(--muted)}
.imei-live[data-state="ok"]{color:var(--secure)}
.imei-live[data-state="bad"]{color:var(--alert)}
.imei-status[data-state="ok"]{color:var(--secure)}
.imei-status[data-state="bad"]{color:var(--alert)}
.imei-video{display:none;width:100%;max-width:340px;border-radius:10px;margin-top:10px;background:#000;aspect-ratio:4/3;object-fit:cover}
.imei-field input[data-imei]{border-color:var(--hairline)}
