/* ===== Adept Electricals — shared design system ===== */
:root{
  --bg:#0f172a; --bg-2:#1e293b;
  --surface:#f6f7f9; --card:#ffffff;
  --ink:#0f172a; --ink-2:#475569; --ink-3:#94a3b8;
  --line:#e9ecf2; --line-2:#f1f3f7;
  --primary:#1d4ed8; --primary-d:#1e40af; --primary-l:#eef3ff;
  --accent:#f59e0b; --accent-d:#b45309; --accent-l:#fff6e6;
  --ok:#16a34a; --ok-l:#e8f8ee;
  --warn:#d97706; --warn-l:#fef2e0;
  --danger:#dc2626; --danger-l:#fdecec;
  --info:#0891b2; --info-l:#e6f6fa;
  --r:14px; --r-sm:10px;
  --sh:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
  --sh-lg:0 14px 36px -10px rgba(16,24,40,.22);
  --side:248px;
  --brand:#1d4ed8; --brand-d:#1e40af; --brand-grad:linear-gradient(135deg,#1d4ed8,#3b82f6);
}
.role-admin   {--brand:#1d4ed8;--brand-d:#1e40af;--brand-grad:linear-gradient(135deg,#1d4ed8,#3b82f6)}
.role-staff   {--brand:#0891b2;--brand-d:#0e7490;--brand-grad:linear-gradient(135deg,#0891b2,#06b6d4)}
.role-vendor  {--brand:#ea580c;--brand-d:#b45309;--brand-grad:linear-gradient(135deg,#ea580c,#f59e0b)}
.role-customer{--brand:#1d4ed8;--brand-d:#1e40af;--brand-grad:linear-gradient(135deg,#1d4ed8,#3b82f6)}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--surface);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;font-weight:700;letter-spacing:-.01em}
.tab-num{font-variant-numeric:tabular-nums}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.shell{display:flex;min-height:100vh}

/* ---- sidebar (admin/staff dark) ---- */
.sidebar{width:var(--side);background:var(--bg);color:#cbd5e1;position:fixed;inset:0 auto 0 0;z-index:60;display:flex;flex-direction:column;transition:transform .28s cubic-bezier(.4,0,.2,1)}
.sidebar.light{background:var(--card);border-right:1px solid var(--line);color:var(--ink-2)}
.brand{display:flex;align-items:center;gap:11px;padding:20px 20px 16px}
.sidebar:not(.light) .brand{padding-bottom:18px}
.bolt{width:38px;height:38px;border-radius:11px;flex:none;background:var(--brand-grad);display:grid;place-items:center;box-shadow:0 8px 18px -6px rgba(0,0,0,.35)}
.brand .nm{font-family:'Space Grotesk';font-weight:700;font-size:15px;line-height:1.15}
.sidebar:not(.light) .brand .nm{color:#fff}
.brand .sub{font-size:10.5px;color:#64748b;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.nav{flex:1;overflow-y:auto;padding:10px 12px 14px}
.nav-grp{margin-top:6px}
.nav-grp .lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#475569;font-weight:700;padding:8px 12px 4px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:#94a3b8;font-weight:500;font-size:13.5px;margin-bottom:2px;transition:.15s}
.sidebar.light .nav-item{color:var(--ink-2)}
.nav-item svg{width:18px;height:18px;flex:none;stroke-width:1.9}
.nav-item:hover{background:#1e293b;color:#e2e8f0}
.sidebar.light .nav-item:hover{background:var(--surface);color:var(--ink)}
.nav-item.on{background:var(--brand);color:#fff;box-shadow:0 6px 16px -6px rgba(0,0,0,.4)}
.nav-item.on svg{color:#fff}
.nav-item .pill{margin-left:auto;background:var(--accent);color:#111;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:20px}
.nav-item.on .pill{background:rgba(255,255,255,.25);color:#fff}
.side-foot{padding:12px;border-top:1px solid #1e293b}
.sidebar.light .side-foot{border-top:1px solid var(--line-2)}
.who{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}
.av{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;background:var(--brand-grad)}
.who .nm{font-size:12.5px;color:#e2e8f0;font-weight:600;line-height:1.2}
.sidebar.light .who .nm{color:var(--ink)}
.who .rl{font-size:10.5px;color:#64748b}
.lockbox{margin:8px 12px;background:#1e293b;border-radius:12px;padding:13px;font-size:11.5px;color:#64748b;line-height:1.45}
.lockbox b{color:#94a3b8;display:flex;align-items:center;gap:6px;margin-bottom:5px;font-size:12px}
.lockbox svg{width:14px;height:14px}

/* ---- main + topbar ---- */
.main{flex:1;margin-left:var(--side);display:flex;flex-direction:column;min-width:0}
.main.full{margin-left:0}
.topbar{height:62px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;padding:0 22px}
.menu-btn{display:none;width:38px;height:38px;border-radius:10px;align-items:center;justify-content:center;color:var(--ink-2)}
.menu-btn:hover{background:var(--line-2)}
.search{flex:1;max-width:420px;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:9px 13px;color:var(--ink-3)}
.search input{border:none;background:none;outline:none;flex:1;font-size:13.5px;color:var(--ink)}
.search svg{width:17px;height:17px;flex:none}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--ink-2);position:relative}
.icon-btn:hover{background:var(--line-2)}
.icon-btn svg{width:20px;height:20px}
.dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid #fff}
.cta{background:var(--brand);color:#fff;font-weight:600;font-size:13px;padding:9px 15px;border-radius:11px;display:inline-flex;align-items:center;gap:7px}
.cta:hover{background:var(--brand-d)}
.cta svg{width:16px;height:16px}

/* mobile app bar (customer/vendor) */
.appbar{display:none;height:58px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;align-items:center;gap:11px;padding:0 16px}
.appbar .bolt{width:32px;height:32px;border-radius:9px}
.appbar .ttl{font-family:'Space Grotesk';font-weight:700;font-size:15px}
.appbar .bell{margin-left:auto;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--ink-2);position:relative}

.content{padding:24px 22px 90px;max-width:1280px;width:100%;margin:0 auto}
.content.narrow{max-width:1040px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.page-head .eyebrow{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:5px}
.page-head h1{font-size:23px}
.page-head p{color:var(--ink-2);font-size:13.5px;margin-top:3px}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpis.c3{grid-template-columns:repeat(3,1fr)}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 17px;box-shadow:var(--sh)}
.kpi .ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;margin-bottom:12px}
.kpi .ico svg{width:21px;height:21px}
.kpi .lbl{font-size:12px;color:var(--ink-2);font-weight:500}
.kpi .val{font-family:'Space Grotesk';font-size:25px;font-weight:700;margin-top:3px}
.b-blue{background:var(--primary-l);color:var(--primary)}
.b-amber{background:var(--accent-l);color:var(--accent-d)}
.b-green{background:var(--ok-l);color:var(--ok)}
.b-cyan{background:var(--info-l);color:var(--info)}

/* ---- cards / grid ---- */
.grid{display:grid;gap:14px}
.g-2-1{grid-template-columns:2fr 1fr}
.g-2{grid-template-columns:1fr 1fr}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh)}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line-2)}
.card-h h3{font-size:15px}
.card-h .more{font-size:12.5px;color:var(--brand);font-weight:600}
.card-b{padding:18px}

/* ---- table ---- */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);font-weight:700;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface)}
.u{display:flex;align-items:center;gap:10px}
.u .ua{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-weight:700;font-size:12px;color:#fff;background:var(--brand-grad)}
.u .un{font-weight:600;color:var(--ink)}
.u .ue{font-size:11.5px;color:var(--ink-3)}
.muted{color:var(--ink-3)}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.badge .bd{width:6px;height:6px;border-radius:50%}
.s-pending{background:var(--warn-l);color:var(--warn)} .s-pending .bd{background:var(--warn)}
.s-assigned{background:var(--info-l);color:var(--info)} .s-assigned .bd{background:var(--info)}
.s-progress{background:var(--primary-l);color:var(--primary)} .s-progress .bd{background:var(--primary)}
.s-done{background:var(--ok-l);color:var(--ok)} .s-done .bd{background:var(--ok)}
.s-rej{background:var(--danger-l);color:var(--danger)} .s-rej .bd{background:var(--danger)}

/* ---- buttons ---- */
.btn-sm{font-size:12px;font-weight:600;padding:6px 12px;border-radius:9px;display:inline-flex;align-items:center;gap:5px}
.btn-primary{background:var(--brand);color:#fff} .btn-primary:hover{background:var(--brand-d)}
.btn-blue{background:var(--primary);color:#fff} .btn-blue:hover{background:var(--primary-d)}
.btn-ghost{background:var(--surface);color:var(--ink-2);border:1px solid var(--line)} .btn-ghost:hover{border-color:var(--ink-3)}
.btn-ok{background:var(--ok-l);color:var(--ok)} .btn-ok:hover{background:#d6f3e0}
.btn-rej{background:var(--danger-l);color:var(--danger)} .btn-rej:hover{background:#fbd9d9}
.btn-sm svg{width:14px;height:14px}
.btn{font-weight:700;font-size:14px;padding:13px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn svg{width:17px;height:17px}
.btn-accept{background:var(--ok);color:#fff} .btn-accept:hover{background:#15803d}
.btn-reject{background:var(--surface);color:var(--danger);border:1px solid var(--line)} .btn-reject:hover{background:var(--danger-l)}

/* ---- chips ---- */
.chips{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.chip{font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:20px;background:var(--card);border:1px solid var(--line);color:var(--ink-2)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip .c{margin-left:6px;background:rgba(0,0,0,.08);padding:0 6px;border-radius:10px;font-size:11px}
.chip.on .c{background:rgba(255,255,255,.2)}

/* ---- forms ---- */
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-family:inherit;font-size:13.5px;outline:none;background:var(--card)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--primary-l)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* ---- alerts ---- */
.flash{display:flex;align-items:center;gap:10px;background:var(--ok-l);color:#166534;border:1px solid #bbf7d0;border-radius:12px;padding:12px 15px;margin-bottom:16px;font-size:13.5px;font-weight:500}
.flash.err{background:var(--danger-l);color:#991b1b;border-color:#fecaca}
.flash svg{width:18px;height:18px;flex:none}

/* ---- rows (requests/jobs/tasks/invoices) ---- */
.rowi{display:flex;align-items:center;gap:13px;padding:14px 18px;border-bottom:1px solid var(--line-2)}
.rowi:last-child{border-bottom:none}
.rowi .ri{width:44px;height:44px;border-radius:12px;flex:none;display:grid;place-items:center;color:#fff;font-weight:700}
.rowi .ri svg{width:21px;height:21px}
.rowi .rinfo{flex:1;min-width:0}
.rowi .rinfo .t{font-weight:600;font-size:14px}
.rowi .rinfo .m{font-size:12px;color:var(--ink-3)}
.rowi .rright{text-align:right;flex:none}

/* ---- service picker ---- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:680px){.svc-grid.cols3{grid-template-columns:repeat(3,1fr)}}
.svc{border:1.5px solid var(--line);border-radius:14px;padding:16px;transition:.15s;cursor:pointer;text-align:left;background:var(--card);display:block}
.svc:hover{border-color:var(--brand);background:var(--primary-l)}
.svc.sel{border-color:var(--brand);background:var(--primary-l);box-shadow:0 0 0 3px var(--primary-l)}
.svc .si{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:11px;font-size:22px}
.svc .sn{font-weight:700;font-size:14px}
.svc .sd{font-size:12px;color:var(--ink-3);margin-top:3px}

/* ---- tracker stepper ---- */
.track{position:relative;padding-left:8px}
.step{display:flex;gap:15px;padding-bottom:26px;position:relative}
.step:last-child{padding-bottom:0}
.step::before{content:"";position:absolute;left:13px;top:28px;bottom:-2px;width:2px;background:var(--line)}
.step:last-child::before{display:none}
.step.done::before{background:var(--ok)}
.dot-st{width:28px;height:28px;border-radius:50%;flex:none;display:grid;place-items:center;background:var(--line-2);color:var(--ink-3);z-index:1;border:3px solid var(--card)}
.dot-st svg{width:14px;height:14px}
.step.done .dot-st{background:var(--ok);color:#fff}
.step.active .dot-st{background:var(--brand);color:#fff;box-shadow:0 0 0 4px var(--primary-l)}
.step .stx .t{font-weight:600;font-size:14px;color:var(--ink-3)}
.step.done .stx .t,.step.active .stx .t{color:var(--ink)}
.step .stx .m{font-size:12px;color:var(--ink-3);margin-top:2px}

/* ---- bottom nav (customer/vendor) ---- */
.botnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));justify-content:space-around;box-shadow:0 -8px 24px -12px rgba(16,24,40,.18)}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;color:var(--ink-3);font-size:10.5px;font-weight:600;border-radius:14px;max-width:84px;position:relative;transition:.15s}
.bn svg{width:23px;height:23px;stroke-width:1.9;transition:.15s}
.bn.on{color:var(--brand)}
.bn.on svg{transform:translateY(-1px)}
.bn .nbadge{position:absolute;top:2px;right:18px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;min-width:15px;height:15px;border-radius:8px;display:grid;place-items:center;padding:0 3px}
.bn.fab{position:relative}
.bn.fab .fb{width:50px;height:50px;border-radius:17px;background:var(--brand-grad);display:grid;place-items:center;color:#fff;margin-top:-24px;box-shadow:0 12px 22px -6px rgba(0,0,0,.4)}
.bn.fab .fb svg{width:25px;height:25px;stroke-width:2.4}

.overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:55}
.overlay.on{display:block}

/* ---- modal sheet ---- */
.scrim{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);z-index:80;display:none;align-items:flex-end;justify-content:center}
.scrim.on{display:flex}
.sheet{background:var(--card);width:100%;max-width:480px;border-radius:20px 20px 0 0;max-height:88vh;overflow-y:auto}
@media(min-width:700px){.scrim{align-items:center}.sheet{border-radius:20px}}
.sheet-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--card)}
.sheet-h h3{font-size:17px}
.sheet-b{padding:20px}
.sheet-foot{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--line-2)}
.sheet-foot .cta{flex:1;justify-content:center;padding:12px}
.btn-line{flex:1;justify-content:center;padding:12px;background:var(--surface);border:1px solid var(--line);border-radius:11px;font-weight:600;color:var(--ink-2);text-align:center}

/* ---- pagination ---- */
.pager{display:flex;gap:6px;justify-content:center;margin-top:18px}
.pager a,.pager span{padding:7px 12px;border-radius:9px;font-size:13px;font-weight:600;border:1px solid var(--line);background:var(--card);color:var(--ink-2)}
.pager .on{background:var(--brand);color:#fff;border-color:var(--brand)}

@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.g-2-1,.g-2{grid-template-columns:1fr}}
@media(max-width:860px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:none}.main{margin-left:0}.menu-btn{display:flex}.cta .t{display:none}}
@media(max-width:900px){
  .has-bottom .sidebar{display:none}
  .has-bottom .main{margin-left:0}
  .has-bottom .appbar{display:flex}
  .has-bottom .botnav{display:flex}
  .has-bottom .topbar{display:none}
  .has-bottom .content{padding:18px 14px 100px}
}
@media(max-width:560px){.kpis{grid-template-columns:1fr}.content{padding:18px 14px 90px}.topbar{padding:0 14px}.search{display:none}.page-head h1{font-size:21px}}
.scroll-hide::-webkit-scrollbar{width:6px;height:6px}.scroll-hide::-webkit-scrollbar-thumb{background:#334155;border-radius:6px}

/* brand logo badge (sidebar/appbar) */
.bolt.logo-badge{background:#fff;padding:2px;overflow:hidden;border-radius:50%}
.bolt.logo-badge img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}

/* ============ ADMIN PRO THEME (colorful + attractive) ============ */
/* richer dark sidebar */
.role-admin .sidebar:not(.light),
.role-staff .sidebar:not(.light){
  background:linear-gradient(185deg,#142544 0%,#0d1830 55%,#0a1426 100%);
  border-right:1px solid rgba(255,255,255,.05)}
.role-admin .sidebar .nav-item,
.role-staff .sidebar .nav-item{color:#c3cee0;font-weight:600}
.role-admin .sidebar .nav-grp .lbl,
.role-staff .sidebar .nav-grp .lbl{color:#6b81a8}
.role-admin .sidebar .nav-item:hover,
.role-staff .sidebar .nav-item:hover{background:rgba(255,255,255,.06);color:#fff}

/* colored icon chips inside nav */
.nav-item .ni-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none;transition:.15s}
.nav-item .ni-ic svg{width:17px;height:17px}
.nav-item.on{background:var(--brand-grad)!important;color:#fff!important;box-shadow:0 10px 22px -8px rgba(31,78,216,.55)}
.nav-item.on .ni-ic{background:rgba(255,255,255,.22)!important;color:#fff!important}

/* vibrant KPI cards */
.kpi{position:relative;overflow:hidden;transition:.18s;border:1px solid var(--line)}
.kpi:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(16,24,40,.28)}
.kpi::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--kc,#3b82f6)}
.kpi .ico{color:#fff!important;box-shadow:0 8px 16px -6px rgba(0,0,0,.25)}
.kpi .val{font-size:27px}
.kpi .delta{font-size:11px;font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:4px;color:var(--ink-3)}
.k-indigo{--kc:#6366f1} .k-indigo .ico{background:linear-gradient(135deg,#4f46e5,#6366f1)}
.k-blue{--kc:#3b82f6}   .k-blue .ico{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.k-green{--kc:#22c55e}  .k-green .ico{background:linear-gradient(135deg,#16a34a,#22c55e)}
.k-amber{--kc:#f59e0b}  .k-amber .ico{background:linear-gradient(135deg,#d97706,#f59e0b)}
.k-cyan{--kc:#06b6d4}   .k-cyan .ico{background:linear-gradient(135deg,#0891b2,#06b6d4)}
.k-rose{--kc:#f43f5e}   .k-rose .ico{background:linear-gradient(135deg,#e11d48,#f43f5e)}
.k-violet{--kc:#8b5cf6} .k-violet .ico{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}
.k-teal{--kc:#14b8a6}   .k-teal .ico{background:linear-gradient(135deg,#0d9488,#14b8a6)}

/* nicer cards + headers */
.card{border-radius:16px}
.card-h h3{font-size:15.5px}
.page-head h1{font-size:25px}
.cta{box-shadow:0 8px 18px -8px rgba(31,78,216,.5)}

/* mini bar chart */
.minibars{display:flex;align-items:flex-end;gap:10px;height:90px;padding:6px 2px}
.minibars .mb{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.minibars .mb .bar{width:100%;max-width:34px;border-radius:7px 7px 0 0;background:var(--brand-grad);min-height:6px}
.minibars .mb .lb{font-size:10.5px;color:var(--ink-3);font-weight:600}

/* status mini legend row */
.statrow{display:flex;flex-wrap:wrap;gap:8px}
.stat-pill{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:8px 12px;font-size:12.5px;font-weight:600}
.stat-pill .n{margin-left:auto;font-family:'Space Grotesk';font-weight:700}

/* ============ VIBRANT v4 — colorful KPIs, hero, logout ============ */
/* tinted multi-color KPI cards */
.kpi.k-violet{background:linear-gradient(160deg,#fbf6ff,#f1e6ff);border-color:#ecd9ff}
.kpi.k-amber {background:linear-gradient(160deg,#fffaf0,#fdeecf);border-color:#fce3b0}
.kpi.k-blue  {background:linear-gradient(160deg,#f2f7ff,#e2edff);border-color:#cfe0ff}
.kpi.k-cyan  {background:linear-gradient(160deg,#edfcff,#d6f2fa);border-color:#bfeaf6}
.kpi.k-rose  {background:linear-gradient(160deg,#fff4f6,#ffe1e7);border-color:#ffd0da}
.kpi.k-indigo{background:linear-gradient(160deg,#f4f5ff,#e6e8ff);border-color:#d6d9ff}
.kpi.k-green {background:linear-gradient(160deg,#f0fdf5,#d6f7e2);border-color:#bdf0cf}
.kpi.k-teal  {background:linear-gradient(160deg,#edfdfa,#d2f6ee);border-color:#b9efe2}
.kpi::before{height:4px}
.kpi .ico{width:46px;height:46px;border-radius:13px}
.kpi .ico svg{width:23px;height:23px}
.kpi .lbl{color:#475569;font-weight:600}
.kpi .val{font-size:30px;color:#0f172a}

/* gradient hero banner */
.hero{position:relative;overflow:hidden;border-radius:20px;padding:24px 26px;margin-bottom:20px;color:#fff;
  background:radial-gradient(120% 140% at 100% 0%, #2a4fb0 0%, #16243f 45%, #0d1830 100%);
  display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 18px 40px -18px rgba(13,24,48,.6)}
.hero::after{content:"";position:absolute;right:-30px;top:-40px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,160,18,.25),transparent 62%)}
.hero>*{position:relative;z-index:1}
.hero .eyebrow{color:#9db4e6;letter-spacing:.12em}
.hero h2{font-size:24px;font-weight:700;margin-top:2px}
.hero .sub{color:#cdd9f0;font-size:13.5px;margin-top:5px}
.hero .hero-cta{background:#fff;color:#16243f;font-weight:700;font-size:13.5px;padding:11px 16px;border-radius:12px;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.hero .hero-cta svg{width:16px;height:16px}
.hero .hr-mini{display:flex;gap:22px;margin-top:14px}
.hero .hr-mini b{display:block;font-family:'Space Grotesk';font-size:20px;line-height:1}
.hero .hr-mini span{font-size:11px;color:#9db4e6;text-transform:uppercase;letter-spacing:.05em}

/* clearer logout button in sidebar footer */
.who-row{display:flex;align-items:center;gap:8px}
.who-row .who{flex:1;min-width:0}
.logout-btn{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex:none;
  background:rgba(239,68,68,.14);color:#fca5a5;transition:.15s;cursor:pointer;border:none}
.logout-btn:hover{background:#ef4444;color:#fff}
.logout-btn svg{width:19px;height:19px}
.sidebar.light .logout-btn{background:#fee2e2;color:#dc2626}
.sidebar.light .logout-btn:hover{background:#dc2626;color:#fff}

/* richer card headers + table header tint */
.card-h{background:linear-gradient(0deg,transparent,rgba(31,78,216,.02))}
thead th{background:#f8fafc}
.minibars .mb .bar{background:linear-gradient(180deg,#3b82f6,#1d4ed8);box-shadow:0 6px 14px -6px rgba(31,78,216,.5)}

/* ============ CUSTOMER APP — super colorful + smooth (v5) ============ */
html{scroll-behavior:smooth}
.has-bottom .content{-webkit-overflow-scrolling:touch}

/* entrance animation */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.anim{animation:fadeUp .45s cubic-bezier(.22,1,.36,1) both}

/* vibrant customer hero */
.chero{position:relative;overflow:hidden;border-radius:22px;padding:24px 22px;margin-bottom:18px;color:#fff;
  background:linear-gradient(135deg,#1f4ed8 0%,#2563eb 45%,#1733a6 100%);
  box-shadow:0 20px 42px -16px rgba(31,78,216,.6)}
.chero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 120% at 90% -10%, rgba(255,255,255,.18), transparent 60%)}
.chero .hi{font-size:13px;opacity:.9;position:relative}
.chero .cn{font-family:'Space Grotesk';font-size:23px;font-weight:700;margin-top:2px;position:relative}
.chero-btn{display:inline-flex;align-items:center;gap:8px;margin-top:16px;background:#fff;color:#1f4ed8;font-weight:700;font-size:14px;padding:12px 18px;border-radius:13px;position:relative;transition:transform .12s;box-shadow:0 10px 20px -8px rgba(0,0,0,.3)}
.chero-btn:active{transform:scale(.96)}
.chero-btn svg{width:17px;height:17px}
.chero .wbolt{position:absolute;right:-10px;bottom:-30px;opacity:.16;z-index:0}

/* app stat cards (colorful, mobile horizontal scroll) */
.appstats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.app-stat{border:1px solid var(--line);border-radius:18px;padding:15px;position:relative;overflow:hidden;transition:transform .12s}
.app-stat:active{transform:scale(.97)}
.app-stat .ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:#fff;margin-bottom:11px;box-shadow:0 8px 16px -6px rgba(0,0,0,.25)}
.app-stat .ic svg{width:21px;height:21px}
.app-stat .lb{font-size:12px;color:#475569;font-weight:600;line-height:1.25}
.app-stat .vl{font-family:'Space Grotesk';font-size:23px;font-weight:700;margin-top:3px;color:#0f172a;white-space:nowrap}
.app-stat.s-blue{background:linear-gradient(160deg,#eff5ff,#dbe9ff);border-color:#cfe0ff}  .s-blue .ic{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.app-stat.s-green{background:linear-gradient(160deg,#effdf4,#d6f7e2);border-color:#bdf0cf} .s-green .ic{background:linear-gradient(135deg,#16a34a,#22c55e)}
.app-stat.s-amber{background:linear-gradient(160deg,#fffaf0,#fdeecf);border-color:#fce3b0} .s-amber .ic{background:linear-gradient(135deg,#d97706,#f59e0b)}
@media(max-width:600px){
  .appstats{display:flex;overflow-x:auto;gap:12px;scroll-snap-type:x mandatory;padding:2px 2px 6px;margin-left:-2px;margin-right:-2px}
  .appstats::-webkit-scrollbar{display:none}
  .appstats .app-stat{min-width:44%;flex:0 0 auto;scroll-snap-align:start}
}

/* section heads (app style) */
.sec-head{display:flex;align-items:center;justify-content:space-between;margin:6px 2px 12px}
.sec-head h3{font-size:16px}
.sec-head a{font-size:13px;color:var(--brand);font-weight:700}

/* colorful service tiles + tap feedback */
.svc{transition:transform .12s cubic-bezier(.22,1,.36,1),box-shadow .2s,border-color .2s,background .2s}
.svc:active{transform:scale(.95)}
.svc .si{box-shadow:0 6px 14px -8px rgba(0,0,0,.25)}

/* app row cards */
.app-list .rowi{transition:background .15s}
.app-list .rowi:active{background:var(--surface)}

/* bottom nav: smooth active pill */
.bn{transition:color .15s,transform .15s}
.bn.on::after{content:"";position:absolute;bottom:2px;width:5px;height:5px;border-radius:50%;background:var(--brand)}
.bn:active{transform:scale(.92)}

/* settings: logo preview + file input */
.logo-row{display:flex;gap:16px;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line-2)}
.logo-prev{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid var(--line);flex:none;background:#fff;display:grid;place-items:center}
.logo-prev img{width:100%;height:100%;object-fit:cover}
.file-in{margin-top:6px;font-size:13px;width:100%;padding:9px 10px;border:1.5px dashed var(--line);border-radius:10px;background:var(--surface);cursor:pointer}
.file-in::file-selector-button{margin-right:10px;border:none;background:var(--brand);color:#fff;padding:7px 12px;border-radius:8px;font-weight:600;cursor:pointer}

/* ===== Rate & Pricing page ===== */
.addsvc{display:none;margin-bottom:18px;border:1px solid #d3e0fb}
.addsvc.show{display:block;animation:fadeUp .3s ease both}
.svc-form{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:8px}
@media(max-width:760px){.svc-form{grid-template-columns:repeat(2,1fr)}.svc-form .field[style*="span 4"]{grid-column:span 2!important}.svc-form .field[style*="span 2"]{grid-column:span 2!important}}
.color-in{height:42px;padding:4px;cursor:pointer}

.rate-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:880px){.rate-grid{grid-template-columns:1fr}}
.rate-card{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;position:relative;transition:.18s;box-shadow:var(--sh)}
.rate-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--sc)}
.rate-card:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(16,24,40,.26)}
.rate-top{display:flex;align-items:center;gap:12px;padding:16px 16px 10px}
.rate-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;flex:none}
.rate-nm{font-weight:700;font-size:15.5px;color:var(--ink)}
.rate-sl{font-size:11px}
.del-btn{width:36px;height:36px;border-radius:10px;border:none;background:#fef2f2;color:#dc2626;display:grid;place-items:center;cursor:pointer;flex:none;transition:.15s}
.del-btn:hover{background:#dc2626;color:#fff}
.del-btn svg{width:17px;height:17px}
.rate-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:0 16px 12px}
.rate-foot{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--line-2);background:var(--surface)}

/* toggle switch */
.switch{display:inline-flex;align-items:center;gap:9px;cursor:pointer;user-select:none}
.switch input{display:none}
.switch .sl{width:40px;height:23px;border-radius:20px;background:#cbd5e1;position:relative;transition:.2s;flex:none}
.switch .sl::after{content:"";position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch input:checked + .sl{background:#22c55e}
.switch input:checked + .sl::after{left:19px}
.switch .tx{font-size:12.5px;font-weight:600;color:var(--ink-2)}

/* vendor register: skill chips + optional label */
.skill-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.skill-chip{display:inline-flex;cursor:pointer}
.skill-chip input{display:none}
.skill-chip span{font-size:12px;font-weight:600;padding:7px 11px;border-radius:20px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);transition:.15s;white-space:nowrap}
.skill-chip input:checked + span{background:#eef3ff;border-color:#1f4ed8;color:#1f4ed8}
.opt{font-weight:500;color:var(--ink-3);font-size:11px}
.auth-card{max-width:412px}

/* per-vendor commission inline editor */
.comm-form{display:flex;align-items:center;gap:6px}
.comm-in{width:92px;padding:7px 9px;font-size:13px;border:1.5px solid var(--line);border-radius:9px;text-align:center}
.comm-in:focus{border-color:var(--brand)}
.comm-save{width:32px;height:32px;border:none;border-radius:9px;background:#22c55e;color:#fff;font-weight:700;cursor:pointer;flex:none;transition:.15s}
.comm-save:hover{background:#16a34a}
.comm-hint{font-size:10.5px;color:var(--ink-3);margin-top:3px;font-weight:600}

/* pincode auto-location message */
.pinmsg{font-size:12px;font-weight:600;min-height:15px;margin:-4px 0 11px}
.pinmsg.ok{color:#16a34a}
.pinmsg.err{color:#dc2626}
.pinmsg.load{color:#2563eb}

/* auth pages — extra polish */
.auth-card .field input:focus,.auth-card .field textarea:focus{border-color:#1f4ed8;box-shadow:0 0 0 3px rgba(31,78,216,.12)}
.auth-card .field input,.auth-card .field textarea{transition:border-color .15s,box-shadow .15s}
.role-tabs a{transition:.15s}
.role-tabs a:hover{border-color:#c3d2f5}
.auth-btn{transition:filter .15s,transform .12s}
.auth-btn:active{transform:scale(.98)}
#state,#district,#block{background:#f8fafc}

/* auth: terms checkbox + vendor docs grid */
.terms{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;color:var(--ink-2);margin:4px 0 16px;cursor:pointer;line-height:1.4}
.terms input{width:auto;margin-top:2px;flex:none}
.terms a{color:var(--brand);font-weight:700}
.docs-head{font-size:13px;font-weight:700;color:var(--ink);margin:14px 0 8px;padding-top:12px;border-top:1px solid var(--line-2)}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
@media(max-width:480px){.doc-grid{grid-template-columns:1fr}}
.doc-grid .field{margin-bottom:4px}
.doc-grid label{font-size:12px}

/* vendor before/after work media */
.wm-up{display:block;border:2px dashed #cbd5e1;border-radius:13px;padding:16px;text-align:center;cursor:pointer;background:var(--surface);margin-bottom:9px;transition:.15s}
.wm-up:hover{border-color:var(--brand);background:#eef3ff}
.wm-up input{display:none}
.wm-up-in{font-size:13px;font-weight:600;color:var(--ink-2);display:block}
.wm-up-in small{display:block;font-size:11px;color:var(--ink-3);font-weight:500;margin-top:3px}
.wm-prev{font-size:12.5px;color:var(--ok,#16a34a);font-weight:700;margin-bottom:10px;min-height:8px}
.wm-label{font-size:12px;font-weight:700;color:var(--ink);margin:12px 0 7px}
.wm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:7px;margin-bottom:6px}
.wm{width:100%;height:76px;object-fit:cover;border-radius:9px;border:1px solid var(--line);background:#000;display:block}

/* mobile appbar logout */
.appbar-logout{display:none}
@media(max-width:900px){
  .appbar-logout{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:#fee2e2;color:#dc2626;margin-left:8px;flex:none}
  .appbar-logout:active{transform:scale(.92)}
  .appbar-logout svg{width:18px;height:18px}
}
