:root{
  --ink:#101827;
  --muted:#64748b;
  --line:#d9e0ea;
  --paper:#ffffff;
  --wash:#f4f7fb;
  --navy:#0f1f35;
  --navy-2:#162b49;
  --gold:#c89b3c;
  --blue:#2563eb;
  --teal:#0f766e;
  --green:#15803d;
  --red:#b91c1c;
  --amber:#b45309;
  --violet:#6d28d9;
  --radius:8px;
  --shadow:0 10px 30px rgba(15,23,42,.12);
}

*{box-sizing:border-box}
html{min-height:100%;background:var(--wash)}
body{margin:0;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);background:var(--wash);font-size:14px;line-height:1.45}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
button:disabled{cursor:not-allowed}
.hidden{display:none!important}

.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(120px);z-index:1000;background:var(--ink);color:#fff;border-radius:var(--radius);padding:10px 14px;max-width:min(92vw,520px);box-shadow:var(--shadow);transition:transform .18s ease}
.toast.show{transform:translateX(-50%) translateY(0)}

.auth-screen{min-height:100vh;display:grid;grid-template-rows:auto 1fr}
.auth-brand{background:var(--navy);color:#fff;padding:22px 18px}
.brand-lockup{display:flex;gap:12px;align-items:center}
.brand-mark{width:46px;height:46px;border-radius:8px;border:1px solid rgba(255,255,255,.28);background:linear-gradient(135deg,#223a62,#0f1f35);display:grid;place-items:center;color:var(--gold);font-weight:900}
.brand-mark.sm{width:34px;height:34px;font-size:12px}
.brand-name{font-size:25px;font-weight:850;letter-spacing:0}
.brand-sub,.side-sub{font-size:11px;color:rgba(255,255,255,.62);text-transform:uppercase;letter-spacing:1px}
.auth-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:20px}
.auth-metrics div{border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:10px;background:rgba(255,255,255,.06)}
.auth-metrics strong{display:block;font-size:18px;color:var(--gold)}
.auth-metrics span{display:block;font-size:11px;color:rgba(255,255,255,.68)}
.auth-panel{padding:16px;align-self:start;width:min(100%,760px);margin:0 auto}
.segmented{display:flex;background:#e6ebf2;border-radius:8px;padding:3px;margin-bottom:14px}
.seg-btn{flex:1;border:0;border-radius:6px;background:transparent;color:var(--muted);font-weight:750;padding:9px}
.seg-btn.active{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(15,23,42,.12)}
.account-type-toggle .seg-btn{display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer}
.account-type-toggle input{position:absolute;opacity:0;pointer-events:none}

form label{display:flex;flex-direction:column;gap:5px;color:#475569;font-weight:720;font-size:12px;margin-bottom:10px}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;padding:10px 11px;outline:none}
.inline-select{width:auto;min-width:150px;padding:8px 10px}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.11)}
.form-grid{display:grid;gap:10px}
.form-grid.two,.form-grid.three,.form-grid.four{grid-template-columns:1fr}
.section-kicker{font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:16px 0 8px}
.checkline{display:flex;flex-direction:row;align-items:flex-start;gap:8px;color:#334155;font-size:13px;font-weight:620}
.checkline input{width:17px;height:17px;accent-color:var(--blue);flex:none;margin-top:2px}
.toggle-grid{display:grid;gap:9px;margin:8px 0 4px}

.btn,.icon-btn{border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:800;min-height:38px;padding:9px 12px}
.btn.primary{background:var(--blue);color:#fff}
.btn.accent{background:var(--gold);color:#111827}
.btn.ghost{background:#e8eef7;color:#172033}
.btn.danger{background:#fee2e2;color:var(--red)}
.btn.success{background:#dcfce7;color:var(--green)}
.btn.block{width:100%}
.btn:disabled{opacity:.48;cursor:not-allowed}
.icon-btn{width:38px;padding:0;background:#e8eef7;color:#172033;font-size:19px}

.app-shell{min-height:100vh;padding-bottom:58px}
.side-nav{display:none}
.main-panel{min-width:0}
.topbar{position:sticky;top:0;z-index:20;background:rgba(244,247,251,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:12px 14px;display:flex;justify-content:space-between;gap:12px;align-items:center}
.view-title{font-size:22px;font-weight:850}
.view-subtitle{font-size:12px;color:var(--muted)}
.top-actions{display:flex;align-items:center;gap:8px}
.view{display:none;padding:14px}
.view.active{display:block}

.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--navy);display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid rgba(255,255,255,.09)}
.nav-btn{border:0;background:transparent;color:rgba(255,255,255,.58);font-weight:760;padding:10px 6px;border-radius:0;position:relative}
.nav-btn.active{color:var(--gold)}
.nav-badge{position:absolute;top:4px;right:5px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#dc2626;color:#fff;font-size:10px;line-height:16px;text-align:center;font-weight:900}

.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}
.stat,.panel,.job-card,.record-card,.plan-card,.route-stop,.evidence-tile{background:#fff;border:1px solid var(--line);border-radius:8px}
.stat{padding:13px}
.stat strong{display:block;font-size:25px;line-height:1;color:var(--ink)}
.stat span{display:block;color:var(--muted);font-size:12px;margin-top:5px}
.panel{padding:13px;margin-bottom:12px}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.panel-title{font-size:14px;font-weight:850}
.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.toolbar .search{flex:1;min-width:190px}

.performance-form{display:grid;grid-template-columns:1fr;gap:8px;align-items:end;margin-bottom:12px}
.performance-form label{margin-bottom:0}
.performance-chart{display:grid;gap:9px}
.perf-row{display:grid;grid-template-columns:78px 1fr 46px;gap:10px;align-items:center}
.perf-month{font-size:12px;font-weight:850;color:#334155}
.perf-bars{display:grid;gap:4px}
.perf-track{height:18px;border-radius:999px;background:#edf2f7;position:relative;overflow:hidden}
.perf-goal,.perf-actual{position:absolute;left:0;top:0;bottom:0;border-radius:999px}
.perf-goal{background:#bfdbfe}
.perf-actual{background:linear-gradient(90deg,var(--teal),var(--green));height:10px;top:4px;bottom:auto}
.perf-legend{display:flex;justify-content:space-between;color:var(--muted);font-size:11px}
.perf-row strong{font-size:12px;text-align:right}
.perf-row strong.good{color:var(--green)}
.perf-row strong.warn{color:var(--amber)}
.perf-row strong.bad{color:var(--red)}

.job-list,.record-grid,.plan-grid,.admin-grid{display:grid;gap:10px}
.job-card{padding:13px;display:grid;gap:8px}
.job-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.job-num{font:800 11px/1.2 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--blue)}
.job-name{font-size:16px;font-weight:850;margin-top:2px}
.job-address{font-size:12px;color:var(--muted)}
.pill-row{display:flex;flex-wrap:wrap;gap:6px}
.pill{display:inline-flex;align-items:center;min-height:22px;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:850;background:#e8eef7;color:#334155}
.pill.critical{background:#fee2e2;color:var(--red)}
.pill.specialty{background:#fef3c7;color:var(--amber)}
.pill.standard{background:#dcfce7;color:var(--green)}
.pill.open{background:#dbeafe;color:#1d4ed8}
.pill.served{background:#dcfce7;color:var(--green)}
.pill.nonservice{background:#fee2e2;color:var(--red)}
.pill.pending{background:#fef3c7;color:var(--amber)}
.pill.submitted,.pill.accepted,.pill.assigned{background:#dbeafe;color:#1d4ed8}
.pill.suspended,.pill.license_revoked,.pill.payment_suspended,.pill.denied{background:#fee2e2;color:var(--red)}

.detail-head{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.qr-box{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px;text-align:center}
.qr-box{display:grid;gap:6px;place-items:center;color:var(--muted);font-size:12px}
.qr-img{width:136px;height:136px;object-fit:contain;border-radius:4px}
.detail-grid{display:grid;grid-template-columns:1fr;gap:12px}
.kv{display:grid;grid-template-columns:125px 1fr;gap:8px;padding:8px 0;border-bottom:1px solid #eef2f7}
.kv:last-child{border-bottom:0}
.kv span:first-child{font-size:11px;color:var(--muted);font-weight:850;text-transform:uppercase}
.kv span:last-child{font-weight:650}
.attempt-card{border-left:4px solid var(--blue);background:#f8fafc;border-radius:8px;padding:10px;margin-bottom:8px}
.attempt-card strong{display:block;font-size:12px}
.attempt-card p{margin:4px 0 0;color:#334155}
.evidence-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.evidence-tile{min-height:82px;display:grid;place-items:center;text-align:center;padding:8px;color:var(--muted);font-size:12px;overflow:hidden;position:relative}
.evidence-tile img{width:100%;height:100%;object-fit:cover}
.attachment-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:6px;position:relative;z-index:2}
.attachment-actions a,.attachment-actions button{border:0;border-radius:6px;background:#e8eef7;color:#172033;text-decoration:none;font-size:11px;font-weight:850;padding:4px 6px;min-height:0}
.attachment-actions button.danger{background:#fee2e2;color:var(--red)}
.evidence-tile small{position:absolute;left:4px;right:4px;bottom:4px;background:rgba(15,23,42,.76);color:#fff;border-radius:6px;padding:3px 5px;font-size:10px;line-height:1.2}
.evidence-tile:has(.attachment-actions) small{position:static;margin-top:4px}

.route-map{height:260px;border-radius:8px;border:1px solid var(--line);position:relative;overflow:hidden;background:#dbe7f0;margin-bottom:12px}
.route-map:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(71,85,105,.28) 0 1px,transparent 1px 38px),repeating-linear-gradient(90deg,rgba(71,85,105,.28) 0 1px,transparent 1px 38px)}
.route-line{position:absolute;height:4px;background:var(--blue);transform-origin:left center;border-radius:999px;opacity:.78}
.map-pin{position:absolute;width:28px;height:28px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--red);border:3px solid #fff;box-shadow:0 5px 14px rgba(15,23,42,.22)}
.map-pin span{display:block;transform:rotate(45deg);font-size:10px;font-weight:900;color:#fff;text-align:center;line-height:22px}
.route-stop{padding:11px;display:flex;gap:10px;align-items:center}
.stop-num{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:var(--navy);color:#fff;font-weight:850;flex:none}
.stop-info{min-width:0}
.stop-info strong{display:block}
.stop-info span{display:block;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.record-card{padding:12px;display:grid;gap:4px}
.record-card strong{font-size:15px}
.record-card span{color:var(--muted);font-size:12px}
.record-card.completion-alert{border-color:#ef4444;background:#fff1f2}
.record-card.completion-alert strong{color:var(--red)}
.record-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.match-note{font-size:11px;color:var(--muted);font-weight:800;margin:4px 0}
.credential-card{background:linear-gradient(135deg,#0f1f35,#1f3c64);border-radius:8px;color:#fff;padding:18px;position:relative;overflow:hidden;margin-bottom:12px}
.credential-card:after{content:"DOCKETSERVE";position:absolute;right:-20px;bottom:4px;font-size:44px;font-weight:950;color:rgba(255,255,255,.06)}
.credential-card .brand-sub{color:var(--gold)}
.credential-name{font-size:23px;font-weight:900;margin-top:18px}
.credential-meta{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:rgba(255,255,255,.72);font-size:12px}
.credential-qr{display:inline-grid;gap:5px;place-items:center;margin-top:14px;padding:8px;border-radius:8px;background:#fff;color:var(--ink);font-size:11px;font-weight:800}
.credential-qr .qr-img{width:118px;height:118px}
.credential-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px;border-top:1px solid rgba(255,255,255,.16);padding-top:12px}
.credential-row span{font-size:10px;text-transform:uppercase;color:rgba(255,255,255,.58);display:block}
.credential-row strong{font-size:13px}

.plan-card{padding:14px}
.plan-card h3{margin:0;font-size:16px}
.price{font-size:26px;font-weight:900;margin:4px 0}
.plan-card ul{padding-left:18px;margin:8px 0 0;color:#334155}
.plan-card li{margin:4px 0}

.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:8px;background:#fff}
table{width:100%;border-collapse:collapse;min-width:720px}
th,td{padding:10px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:middle}
th{background:#f8fafc;color:#64748b;text-transform:uppercase;font-size:11px;letter-spacing:.6px}
td{font-size:13px}

.modal{width:min(94vw,760px);max-height:88vh;border:0;border-radius:8px;padding:0;box-shadow:var(--shadow)}
.modal.compact{width:min(94vw,480px)}
.modal::backdrop{background:rgba(15,23,42,.58)}
.modal form{padding:14px}
.modal-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:12px}
.modal h2{margin:0;font-size:19px}
.modal p{margin:3px 0 0;color:var(--muted);font-size:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;flex-wrap:wrap}

.empty{border:1px dashed #bdc7d5;border-radius:8px;padding:22px;text-align:center;color:var(--muted);background:#fff}
.notice{border-radius:8px;padding:10px 12px;margin-bottom:12px;background:#fffbeb;border:1px solid #f8d36b;color:#7c2d12;font-weight:650}
.notice.compact{font-size:12px;margin:8px 0 0}

@media (min-width:640px){
  .form-grid.two{grid-template-columns:repeat(2,1fr)}
  .form-grid.three{grid-template-columns:repeat(3,1fr)}
  .form-grid.four{grid-template-columns:repeat(4,1fr)}
  .toggle-grid{grid-template-columns:repeat(3,1fr)}
  .record-grid,.plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-head{flex-direction:row;align-items:stretch}
  .qr-box{width:320px;flex:none}
  .performance-form{grid-template-columns:1fr 1fr 1fr auto}
}

@media (min-width:920px){
  .auth-screen{grid-template-columns:420px 1fr;grid-template-rows:1fr}
  .auth-brand{padding:34px;display:flex;flex-direction:column;justify-content:center}
  .auth-panel{align-self:center}
  .app-shell{display:grid;grid-template-columns:240px 1fr;padding-bottom:0}
  .side-nav{display:flex;position:sticky;top:0;height:100vh;background:var(--navy);color:#fff;flex-direction:column;padding:14px}
  .side-brand{display:flex;gap:10px;align-items:center;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:12px}
  .side-title{font-size:18px;font-weight:900}
  .side-nav nav{display:grid;gap:3px}
  .side-nav .nav-btn{border-radius:8px;text-align:left;color:rgba(255,255,255,.66);padding:11px 12px}
  .side-nav .nav-btn.active{background:rgba(200,155,60,.14);color:var(--gold)}
  .logout-btn{margin-top:auto}
  .mobile-nav{display:none}
  .view{padding:20px}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .job-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-grid{grid-template-columns:1.05fr .95fr}
  .admin-grid{grid-template-columns:1fr 1fr}
}

/* v0.3.8 additions */
.pill-circuit{display:inline-block;background:#e0f0ff;color:#0c4a8c;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}
#invoiceJobContext{background:#f0f7ff;border-left:3px solid #3b82f6;padding:8px 12px;border-radius:0 6px 6px 0;font-size:12px;color:#1e3a5f;margin-bottom:4px}
#invoiceClientDisplay{color:var(--muted,#6b7280);font-style:italic}
#serviceDisclaimerModal{border:none;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.35);padding:0;max-width:520px;width:95vw}
#serviceDisclaimerModal::backdrop{background:rgba(0,0,0,0.55)}

/* ── Jobs tab: active-only default + count bar ─────────────────────────── */
.jobs-count-bar{font-size:12px;color:var(--muted);padding:6px 2px 10px;border-bottom:1px solid var(--line);margin-bottom:10px}
.jobs-count-link{color:var(--blue);cursor:pointer;text-decoration:underline;font-weight:600}
.jobs-count-link:hover{color:var(--navy)}
