:root{
  --bg0:#0a0f1d; --bg1:#0e1424; --surface:#141b2d; --surface2:#1b2438;
  --line:rgba(148,163,184,.14); --line2:rgba(148,163,184,.22);
  --text:#eaf0f9; --muted:#8a99b3; --faint:#5d6b85;
  --primary:#f5a524; --primary-d:#1c1304;
  --blue:#38bdf8; --violet:#a78bfa; --cyan:#22d3ee;
  --green:#34d399; --red:#fb7185;
  --r-lg:18px; --r-md:12px; --r-sm:9px;
  --shadow:0 10px 30px -12px rgba(0,0,0,.6), 0 2px 8px -4px rgba(0,0,0,.5);
  --ring:0 0 0 3px rgba(245,165,36,.28);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--text);line-height:1.5;
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(245,165,36,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(56,189,248,.10), transparent 55%),
    linear-gradient(180deg,var(--bg0),var(--bg1));
  background-attachment:fixed;min-height:100vh;
}
.hidden{display:none !important}
.muted{color:var(--muted);font-size:.86rem}
a{color:var(--blue);text-decoration:none}
::selection{background:rgba(245,165,36,.3)}

/* ---------- top bar ---------- */
#topbar{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:.7rem 1.1rem;position:sticky;top:0;z-index:20;
  background:rgba(12,18,32,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{font-weight:800;font-size:1.05rem;letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}
.brand::before{
  content:"";display:block;width:34px;height:34px;border-radius:10px;flex:0 0 auto;
  background:#fff url("icon-192.png") center/86% no-repeat;
  box-shadow:0 6px 16px -6px rgba(37,99,235,.55);
}
.who{display:flex;align-items:center;gap:.7rem;font-size:.9rem}
#who-name{font-weight:600;color:var(--text)}
@media(max-width:560px){#who-name{display:none}}

/* ---------- layout ---------- */
main{max-width:1140px;margin:0 auto;padding:1.4rem 1.1rem 3rem}
.loading{padding:4rem;text-align:center;color:var(--muted)}
h2{margin:.1rem 0 .3rem;font-size:1.6rem;font-weight:800;letter-spacing:-.02em}
h3{margin:.1rem 0 .9rem;font-size:1.05rem;font-weight:700;letter-spacing:-.01em}
h4{margin:1rem 0 .35rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}

.grid{display:grid;gap:1.2rem}
@media(min-width:820px){
  .grid.two{grid-template-columns:1fr 1fr}
  .grid.side{grid-template-columns:1fr 340px;align-items:start}
}

.card{
  background:linear-gradient(180deg,var(--surface),var(--surface2));
  border:1px solid var(--line);border-radius:var(--r-lg);padding:1.25rem;
  box-shadow:var(--shadow);
}
.card.sticky{position:sticky;top:84px}

/* ---------- forms ---------- */
label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin:.75rem 0 .3rem}
input,select,textarea{
  width:100%;padding:.7rem .8rem;background:rgba(10,15,28,.6);
  border:1px solid var(--line2);border-radius:var(--r-sm);color:var(--text);
  font-size:16px;font-family:inherit;min-height:44px; /* 16px = no iOS zoom; 44px = tap target */
  transition:border-color .15s,box-shadow .15s,background .15s;
}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring);background:rgba(10,15,28,.85)}
textarea{min-height:78px;resize:vertical}
/* locked / disabled fields — clearly greyed out but still readable */
select:disabled,input:disabled,textarea:disabled,.locked{
  opacity:.6;cursor:not-allowed;background:rgba(10,15,28,.35);color:var(--muted);
  border-color:var(--line);-webkit-text-fill-color:var(--muted)}
.row{display:flex;gap:.6rem;align-items:center;margin-top:.7rem;flex-wrap:wrap}
.row > *{flex:1;min-width:0} /* min-width:0 lets long content shrink instead of overflowing */
.row > button,.row > .btn,.row > .btn-blue,.row > .btn-green,.row > .btn-red,.row > .btn-ghost{flex:0 0 auto}

/* ---------- buttons ---------- */
.btn,.btn-blue,.btn-green,.btn-red{
  border:none;padding:.62rem 1.05rem;border-radius:var(--r-sm);font-weight:700;font-size:.9rem;
  cursor:pointer;transition:transform .08s,filter .15s,box-shadow .15s;letter-spacing:-.01em;
  min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;line-height:1.15;
}
.btn:active,.btn-blue:active,.btn-green:active,.btn-red:active{transform:translateY(1px)}
.btn{background:linear-gradient(135deg,var(--primary),#e0901c);color:var(--primary-d);box-shadow:0 8px 20px -10px rgba(245,165,36,.8)}
.btn-blue{background:linear-gradient(135deg,#38bdf8,#0ea5e9);color:#04222e}
.btn-green{background:linear-gradient(135deg,#34d399,#10b981);color:#042a1d}
.btn-red{background:linear-gradient(135deg,#fb7185,#f43f5e);color:#2a0610}
.btn:hover,.btn-blue:hover,.btn-green:hover,.btn-red:hover{filter:brightness(1.08)}
.btn:disabled{opacity:.5;cursor:not-allowed;filter:none}
.btn-ghost{
  background:rgba(148,163,184,.08);color:var(--text);border:1px solid var(--line2);
  padding:.55rem .9rem;border-radius:var(--r-sm);cursor:pointer;font-size:.85rem;font-weight:600;
  min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;line-height:1.15;
  transition:background .15s,border-color .15s;text-decoration:none;
}
.btn-ghost:hover{background:rgba(148,163,184,.16);border-color:var(--line2)}

/* ---------- badges / pills ---------- */
.badge{display:inline-flex;align-items:center;padding:.22rem .6rem;border-radius:999px;font-size:.68rem;
  font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}
.b-PENDING{background:rgba(148,163,184,.16);color:#cbd5e1;border-color:rgba(148,163,184,.25)}
.b-ASSIGNED{background:rgba(56,189,248,.14);color:#7dd3fc;border-color:rgba(56,189,248,.3)}
.b-ACCEPTED{background:rgba(34,211,238,.14);color:#67e8f9;border-color:rgba(34,211,238,.3)}
.b-EN_ROUTE{background:rgba(167,139,250,.16);color:#c4b5fd;border-color:rgba(167,139,250,.32)}
.b-COLLECTED{background:rgba(245,165,36,.16);color:#fcd34d;border-color:rgba(245,165,36,.32)}
.b-OUT_FOR_DELIVERY{background:rgba(34,211,238,.16);color:#67e8f9;border-color:rgba(34,211,238,.34)}
.b-DELIVERED{background:rgba(245,165,36,.16);color:#fcd34d;border-color:rgba(245,165,36,.32)}
.b-COMPLETED{background:rgba(52,211,153,.16);color:#6ee7b7;border-color:rgba(52,211,153,.32)}
.b-REJECTED{background:rgba(251,113,133,.16);color:#fda4af;border-color:rgba(251,113,133,.32)}
.b-CANCELLED{background:rgba(93,107,133,.18);color:#94a3b8;border-color:rgba(93,107,133,.3)}
.b-role{background:linear-gradient(135deg,var(--primary),#e0901c);color:var(--primary-d);text-transform:capitalize}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.45rem;box-shadow:0 0 0 3px rgba(255,255,255,.04)}
.d-available{background:var(--green);box-shadow:0 0 8px var(--green)} .d-busy{background:var(--primary)} .d-offline{background:#5d6b85}

/* ---------- tables ---------- */
table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{text-align:left;padding:.6rem .45rem;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}
tr:last-child td{border-bottom:none}
tr.clickable{cursor:pointer} tr.clickable:hover{background:var(--surface2)}

/* ---------- item / request cards ---------- */
.req-item{
  border:1px solid var(--line);border-radius:var(--r-md);padding:1rem;margin-bottom:.85rem;
  background:linear-gradient(180deg,rgba(27,36,56,.7),rgba(20,27,45,.7));
  transition:border-color .15s,transform .12s;
}
.req-item:hover{border-color:var(--line2);transform:translateY(-1px)}
.req-item .top{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.ref{font-family:ui-monospace,"SF Mono",Menlo,monospace;font-weight:700;color:var(--primary);font-size:.92rem;letter-spacing:.02em}
.urgent{color:var(--red);font-weight:800;font-size:.68rem;text-transform:uppercase;margin-left:.4rem;
  background:rgba(251,113,133,.14);padding:.12rem .45rem;border-radius:6px}
.item-name{margin:.5rem 0 .3rem;font-weight:700;font-size:1.05rem;letter-spacing:-.01em}
.collect-status{
  margin-top:.7rem;padding:.55rem .75rem;border-radius:var(--r-sm);
  background:rgba(10,15,28,.5);border:1px solid var(--line);border-left:3px solid var(--muted);
  font-size:.9rem;font-weight:600;
}
.cs-PENDING{border-left-color:#94a3b8} .cs-ASSIGNED{border-left-color:var(--blue)}
.cs-ACCEPTED{border-left-color:var(--cyan)} .cs-EN_ROUTE{border-left-color:var(--violet)}
.cs-COLLECTED{border-left-color:var(--primary)} .cs-OUT_FOR_DELIVERY{border-left-color:var(--cyan)}
.cs-DELIVERED{border-left-color:var(--primary)} .cs-COMPLETED{border-left-color:var(--green)}
.cs-REJECTED{border-left-color:var(--red)} .cs-CANCELLED{border-left-color:#5d6b85}
.route{margin-top:.4rem}
.job-meta{margin-top:.5rem;font-weight:600}
.live-loc{margin:.55rem 0 0;color:var(--cyan);font-weight:600}

/* ---------- location map ---------- */
.track-map{height:240px;width:100%;border-radius:var(--r-md);overflow:hidden;margin:.5rem 0 .2rem;
  border:1px solid var(--line2);background:#0a0f1d}
.track-map .leaflet-container{background:#0a0f1d;font-family:inherit}
.map-wrap{position:relative}
.map-empty{padding:.7rem;border:1px dashed var(--line2);border-radius:var(--r-md);text-align:center}
.map-legend{margin:.1rem 0 .2rem;font-size:.78rem}
.map-pin{font-size:19px;line-height:1;display:grid;place-items:center;width:34px;height:34px;
  background:rgba(10,15,28,.92);border:2px solid var(--pin,var(--primary));border-radius:50%;
  box-shadow:0 3px 6px rgba(0,0,0,.5)}

/* ---------- address autocomplete ---------- */
.ac-wrap{position:relative}
.ac-list{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:50;
  background:var(--surface2);border:1px solid var(--line2);border-radius:var(--r-sm);
  box-shadow:var(--shadow);max-height:230px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ac-item{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  color:var(--text);font:inherit;font-size:.84rem;padding:.55rem .7rem;line-height:1.35;
  border-bottom:1px solid var(--line);overflow-wrap:anywhere}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item.ac-active{background:rgba(245,165,36,.14)}

/* ---------- proof-of-delivery photo ---------- */
.pod-geo{margin:.1rem 0 .5rem;padding:.5rem .7rem;border-radius:var(--r-sm);font-size:.84rem;font-weight:600;
  background:rgba(56,189,248,.10);border:1px solid rgba(56,189,248,.28);color:#7dd3fc;
  overflow-wrap:anywhere;text-align:left}
.pod-geo.ok{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.32);color:#6ee7b7}
.pod-geo.warn{background:rgba(251,113,133,.12);border-color:rgba(251,113,133,.3);color:#fda4af}
.pod-preview{display:flex;justify-content:center;margin:.2rem 0}
.pod-preview img{max-width:100%;max-height:240px;border-radius:var(--r-md);border:1px solid var(--line2)}
.pod-link{display:block} .pod-img{width:100%;border-radius:var(--r-md);border:1px solid var(--line2);display:block}

/* ---------- timeline ---------- */
.timeline{list-style:none;padding:0;margin:.5rem 0 0}
.timeline li{padding:.4rem 0 .5rem 1.2rem;border-left:2px solid var(--line2);position:relative;font-size:.86rem}
.timeline li:last-child{border-left-color:transparent}
.timeline li::before{content:"";position:absolute;left:-6px;top:.65rem;width:10px;height:10px;border-radius:50%;
  background:var(--primary);box-shadow:0 0 0 3px rgba(245,165,36,.18)}

/* ---------- modals ---------- */
.modal{position:fixed;inset:0;background:rgba(5,8,16,.62);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;z-index:60;
  padding:1rem;padding-bottom:max(1rem,env(safe-area-inset-bottom));animation:fade .15s ease}
.modal-card{
  background:linear-gradient(180deg,var(--surface),var(--surface2));border:1px solid var(--line2);
  border-radius:var(--r-lg);padding:1.5rem;max-width:440px;width:100%;text-align:center;
  max-height:calc(100dvh - 2rem);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.7);animation:pop .18s cubic-bezier(.2,.8,.2,1)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
#reader{width:100%;border-radius:var(--r-md);overflow:hidden;margin:.4rem 0}
#label-body{display:flex;flex-direction:column;align-items:center;gap:.55rem}
.label-qr svg{width:230px;height:230px;background:#fff;padding:12px;border-radius:14px;display:block}
.label-ref{font-family:ui-monospace,Menlo,monospace;font-size:1.35rem;font-weight:800;color:var(--text);letter-spacing:.03em}
.label-item{font-weight:600}

/* ---------- login ---------- */
.login-wrap{max-width:400px;margin:9vh auto 0}
.login-logo{background:#fff;border-radius:14px;padding:1.1rem 1.3rem;margin:0 0 1.3rem;display:flex;justify-content:center;box-shadow:0 10px 30px -12px rgba(37,99,235,.45)}
.login-logo img{width:100%;max-width:260px;height:auto;display:block}
.login-wrap h2{font-size:1.5rem;margin-bottom:1rem}
.login-wrap .card{padding:1.8rem}
.hint{font-size:.78rem;color:var(--muted);margin-top:1.2rem;border-top:1px solid var(--line);padding-top:.9rem;line-height:1.9}
.hint code{color:var(--blue);background:rgba(56,189,248,.1);padding:.05rem .35rem;border-radius:5px}
.err{background:rgba(251,113,133,.14);color:#fda4af;border:1px solid rgba(251,113,133,.3);
  padding:.55rem .75rem;border-radius:var(--r-sm);font-size:.85rem;margin-top:.7rem}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:1.3rem;left:50%;transform:translateX(-50%);
  background:var(--surface2);border:1px solid var(--line2);padding:.7rem 1.1rem;border-radius:var(--r-md);
  z-index:80;font-size:.9rem;font-weight:600;box-shadow:var(--shadow);animation:pop .2s ease}

/* ---------- text-overflow guards ---------- */
body{overflow-wrap:break-word;word-break:normal}
.ref,.item-name,.muted,.route,.collect-status,.label-ref,.label-item,h2,h3{overflow-wrap:anywhere}
.req-item .top{flex-wrap:wrap}
.req-item{overflow:hidden}
td,th{overflow-wrap:anywhere}
#companies,#users{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ---------- icon-action buttons (topbar) ---------- */
.icon-action{gap:.35rem}

/* ---------- mobile bottom navigation ---------- */
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:40;display:none;
  background:rgba(12,18,32,.92);backdrop-filter:blur(16px);
  border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);
}
.bottomnav .nav-btn{
  flex:1 1 0;min-width:0;background:none;border:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;
  padding:.5rem .35rem;min-height:58px;color:var(--muted);font-weight:600;font-size:.7rem;
  letter-spacing:.01em;transition:color .15s,background .15s;
}
.bottomnav .nav-btn .ic{font-size:1.25rem;line-height:1}
.bottomnav .nav-btn .nl{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bottomnav .nav-btn[aria-current="true"]{color:var(--primary)}
.bottomnav .nav-btn[aria-current="true"] .ic{transform:translateY(-1px)}
.bottomnav .nav-btn:active{background:rgba(148,163,184,.08)}

/* ---------- responsive: phones & small tablets ---------- */
@media(max-width:819px){
  main{padding-left:.9rem;padding-right:.9rem;padding-bottom:calc(74px + env(safe-area-inset-bottom))}
  h2{font-size:1.4rem}
  #topbar{gap:.5rem;padding:.6rem .8rem}
  .who{gap:.45rem}
  .card{padding:1rem}
  /* Bottom nav drives a single-pane-at-a-time layout on phones */
  .bottomnav.shown{display:flex}
  .has-mobile-nav .pane{display:none}
  .has-mobile-nav .pane.is-active{display:block}
  /* Card action buttons grow to fill the row (bigger targets, never squashed) */
  .req-item [data-actions]>.btn,
  .req-item [data-actions]>.btn-blue,
  .req-item [data-actions]>.btn-green,
  .req-item [data-actions]>.btn-red,
  .req-item [data-actions]>.btn-ghost{flex:1 1 auto;justify-content:center}
  .req-item [data-actions]>select[data-driver]{flex:1 1 100%}
  /* keep toasts clear of the bottom nav */
  .toast{bottom:calc(82px + env(safe-area-inset-bottom))}
  .track-map{height:220px}
  .label-qr svg{width:190px;height:190px}
}
@media(max-width:560px){
  .who .lbl{display:none}              /* topbar Guide/Logout become icon-only */
  .icon-action{padding:.5rem .6rem}
  table{font-size:.82rem}
  th,td{padding:.5rem .35rem}
  h2{font-size:1.28rem}
  .modal-card{padding:1.2rem}
}

/* ---------- accessibility: focus, motion, contrast ---------- */
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.btn:focus-visible,.btn-blue:focus-visible,.btn-green:focus-visible,.btn-red:focus-visible,
.btn-ghost:focus-visible,.nav-btn:focus-visible,a:focus-visible{
  outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 0 4px rgba(245,165,36,.45)}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .req-item:hover{transform:none}
}

/* ---------- print (QR label) ---------- */
@media print{
  .bottomnav{display:none !important}
  body *{visibility:hidden}
  #label-card,#label-card *{visibility:visible}
  #label-card{position:fixed;inset:0;margin:auto;border:none;box-shadow:none;background:#fff}
  .label-ref,.label-item{color:#000 !important}
  .no-print{display:none}
}
