
.upm-app *{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.upm-app{
  background:#0B1220;color:#EAF1FB;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;
  --bg:#0B1220;--surf:#101A2C;--card:#162236;--card2:#1B2A42;--bdr:#223049;
  --ink:#EAF1FB;--muted:#8CA0C4;
  --accent:#3B82F6;--accent2:#2563EB;
  --amber:#F59E0B;--amber-d:#B45309;
  --green:#22C55E;--green-d:#15803D;
  --red:#EF4444;--red-d:#B91C1C;
  --purple:#A855F7;
  --teal:#14B8A6;
  /* Full-screen app overlay — covers the theme's header/footer/page title */
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  z-index:99999;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
/* Offset for the WordPress admin toolbar (only visible to logged-in users) */
body.admin-bar .upm-app{ top:32px; }
@media screen and (max-width:782px){
  body.admin-bar .upm-app{ top:46px; }
}
.upm-app.upm-gate{display:flex;align-items:center;justify-content:center;padding:20px}
.upm-login-card{max-width:380px;width:100%;padding:28px;background:#162236;border-radius:14px;border:1px solid #223049}
.upm-login-card h2{margin-bottom:6px;font-size:18px}
.upm-login-card p{color:#8CA0C4;font-size:13px;margin-bottom:18px;line-height:1.6}
.upm-login-card a{color:#3B82F6}
.upm-login-card form p{margin-bottom:12px;color:#EAF1FB}
.upm-login-card label{display:block;margin-bottom:4px;font-size:12px;color:#8CA0C4}
.upm-login-card input[type="text"],.upm-login-card input[type="password"]{
  width:100%;background:#101A2C;border:1px solid #223049;border-radius:9px;padding:10px 11px;color:#EAF1FB;font-size:13px;outline:none;
}
.upm-login-card input[type="submit"]{
  background:#3B82F6;color:#fff;border:none;border-radius:9px;padding:11px 16px;font-weight:700;font-size:13px;cursor:pointer;width:100%;margin-top:6px;
}
.upm-app a{color:inherit}
/* NAV */
.upm-app .nav{background:var(--surf);border-bottom:1px solid var(--bdr);padding:0 12px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100}
.upm-app .nav-logo{display:flex;align-items:center;gap:8px;min-width:0}
.upm-app .nav-logo-img{height:36px;width:36px;object-fit:cover;border-radius:9px;flex-shrink:0;background:var(--card2)}
.upm-app .nav-logo-fallback{height:36px;width:36px;border-radius:9px;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--purple));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:15px;color:#fff}
.upm-app .co-main{font-size:13px;font-weight:800;color:var(--ink);letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46vw}
.upm-app .co-sub{font-size:9px;font-weight:700;color:var(--amber);letter-spacing:1.2px;text-transform:uppercase}
.upm-app .nav-btns{display:flex;gap:4px;align-items:center}
.upm-app .nb{background:transparent;color:var(--muted);border:none;border-radius:9px;width:36px;height:36px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;position:relative}
.upm-app .nb.on{background:var(--accent);color:#fff}
.upm-app .nb-dot{position:absolute;top:3px;right:3px;background:var(--red);color:#fff;font-size:8px;font-weight:800;border-radius:8px;min-width:14px;height:14px;display:flex;align-items:center;justify-content:center;padding:0 3px}

/* BOTTOM NAV */
.upm-app .bnav{position:fixed;bottom:0;left:0;right:0;background:var(--surf);border-top:1px solid var(--bdr);display:flex;justify-content:space-around;padding:7px 0 calc(7px + env(safe-area-inset-bottom));z-index:100}
.upm-app .bn{background:none;border:none;color:var(--muted);cursor:pointer;text-align:center;font-size:10px;font-weight:700;padding:2px 6px}
.upm-app .bn.on{color:var(--accent)}
.upm-app .bn-icon{font-size:19px;display:block;margin-bottom:1px}

/* LAYOUT */
.upm-app .page{max-width:680px;margin:0 auto;padding:14px 14px 90px}
.upm-app .card{background:var(--card);border-radius:13px;border:1px solid var(--bdr);padding:14px;margin-bottom:12px}
.upm-app .card-title{font-weight:800;font-size:14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.upm-app .g2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.upm-app .g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}

/* INPUTS */
.upm-app .inp{background:var(--surf);border:1px solid var(--bdr);border-radius:9px;padding:10px 11px;color:var(--ink);font-size:13px;width:100%;outline:none;font-family:inherit}
.upm-app .inp:focus{border-color:var(--accent)}
.upm-app textarea.inp{resize:vertical;min-height:64px}
.upm-app select.inp{cursor:pointer}
.upm-app .lbl{color:var(--muted);font-size:11px;margin-bottom:4px;display:block;font-weight:600}
.upm-app .fg{margin-bottom:11px}
.upm-app .hint{font-size:10.5px;color:var(--muted);margin-top:4px;line-height:1.5}

/* BUTTONS */
.upm-app .btn{border:none;border-radius:9px;padding:10px 16px;cursor:pointer;font-weight:700;font-size:13px;color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-align:center;text-decoration:none}
.upm-app .btn:active{opacity:.8}
.upm-app .btn-accent{background:var(--accent)}
.upm-app .btn-red{background:var(--red)}
.upm-app .btn-green{background:var(--green)}
.upm-app .btn-amber{background:var(--amber);color:#241600}
.upm-app .btn-purple{background:var(--purple)}
.upm-app .btn-wa{background:#25D366}
.upm-app .btn-ghost{background:var(--card2);color:var(--ink);border:1px solid var(--bdr)}
.upm-app .btn-full{width:100%;display:flex;padding:12px;font-size:14px;margin-bottom:8px}
.upm-app .btn-row{display:flex;gap:8px;flex-wrap:wrap}
.upm-app .btn-row .btn{flex:1;min-width:0}
.upm-app .btn-sm{padding:7px 10px;font-size:11.5px;border-radius:8px}
.upm-app .btn:disabled{opacity:.45;cursor:not-allowed}

/* BADGES */
.upm-app .bdg{border-radius:6px;padding:3px 8px;font-size:10px;font-weight:800;display:inline-block;letter-spacing:.2px}

/* STATS */
.upm-app .stat{background:var(--card);border-radius:12px;border:1px solid var(--bdr);padding:13px}
.upm-app .stat-n{font-size:23px;font-weight:800}
.upm-app .stat-l{color:var(--muted);font-size:10.5px;margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}

/* INFO ROWS */
.upm-app .ir{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--bdr);font-size:13px}
.upm-app .ir:last-child{border:none}
.upm-app .ik{color:var(--muted);flex-shrink:0}
.upm-app .iv{font-weight:700;text-align:right}

/* PRICE BOX */
.upm-app .pbox{background:var(--surf);border-radius:10px;padding:13px;margin-bottom:12px}
.upm-app .pr{display:flex;justify-content:space-between;margin-bottom:7px;font-size:13px}
.upm-app .pfinal{display:flex;justify-content:space-between;padding-top:9px;border-top:1px solid var(--bdr);font-weight:800;font-size:17px;margin-top:4px}

/* TOGGLE / TABS */
.upm-app .tg-grp{display:flex;gap:8px;flex-wrap:wrap}
.upm-app .tg{flex:1;padding:9px 6px;border-radius:9px;border:1.5px solid var(--bdr);background:var(--surf);color:var(--muted);cursor:pointer;font-weight:700;font-size:11.5px;text-align:center;min-width:64px}
.upm-app .tg.on{border-color:var(--accent);background:rgba(59,130,246,.15);color:#cfe0ff}

/* FILTERS */
.upm-app .frow{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;margin-bottom:12px;scrollbar-width:none}
.upm-app .frow::-webkit-scrollbar{display:none}
.upm-app .fb{padding:6px 13px;border-radius:18px;border:1px solid var(--bdr);background:var(--surf);color:var(--muted);cursor:pointer;font-size:12px;font-weight:700;white-space:nowrap}
.upm-app .fb.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* MISC */
.upm-app .back{background:none;border:none;color:var(--muted);cursor:pointer;font-size:22px;padding:0;line-height:1}
.upm-app .empty{text-align:center;color:var(--muted);padding:46px 18px;font-size:14px}
.upm-app .empty .ei{font-size:38px;margin-bottom:10px}
.upm-app .toast{position:fixed;top:64px;left:50%;transform:translateX(-50%);padding:10px 22px;border-radius:10px;z-index:999;font-weight:700;font-size:13.5px;box-shadow:0 4px 20px rgba(0,0,0,.5);display:none;white-space:nowrap;max-width:90vw}

/* SECTION HEADER */
.upm-app .sec-h{font-size:10.5px;font-weight:800;color:var(--amber);text-transform:uppercase;letter-spacing:1px;margin:14px 0 8px;display:flex;align-items:center;gap:8px}
.upm-app .sec-h::after{content:'';flex:1;height:1px;background:var(--bdr)}

/* CALENDAR */
.upm-app .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.upm-app .cal-hdr{text-align:center;font-size:9.5px;font-weight:800;color:var(--muted);padding:4px 0;text-transform:uppercase}
.upm-app .cal-cell{text-align:center;padding:6px 1px;border-radius:8px;cursor:pointer;min-height:40px;border:1px solid transparent}
.upm-app .cal-cell:hover{border-color:var(--accent)}
.upm-app .cal-cell.today{background:var(--accent);color:#fff}
.upm-app .cal-cell.has{background:rgba(245,158,11,.13);border-color:rgba(245,158,11,.3)}
.upm-app .cal-cell.today.has{background:var(--accent)}
.upm-app .cal-cell.other{opacity:.3}
.upm-app .cal-cell.sel{border-color:var(--amber)}
.upm-app .cc-num{font-size:12.5px;font-weight:700}
.upm-app .cc-cnt{font-size:8.5px;font-weight:800;background:var(--amber);color:#241600;border-radius:7px;padding:1px 4px;margin-top:2px;display:inline-block}
.upm-app .cal-cell.today .cc-cnt{background:#fff;color:var(--accent)}
.upm-app .cal-nav-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}
.upm-app .icon-nav{background:var(--surf);border:1px solid var(--bdr);border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;color:var(--ink)}

/* DATE STRIP */
.upm-app .date-strip{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;margin-bottom:10px}
.upm-app .date-strip::-webkit-scrollbar{display:none}
.upm-app .date-chip{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;padding:7px 9px;border-radius:11px;cursor:pointer;border:1.5px solid var(--bdr);background:var(--surf);min-width:46px}
.upm-app .date-chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.upm-app .date-chip .dn{font-size:9px;font-weight:700;opacity:.75;text-transform:uppercase}
.upm-app .date-chip .dd{font-size:15px;font-weight:800;margin-top:1px}
.upm-app .date-chip .dot{width:4px;height:4px;border-radius:50%;background:var(--amber);margin-top:2px}
.upm-app .date-chip .dot.h{opacity:0}

/* BOOKING CARD */
.upm-app .bk-card{background:var(--card);border-radius:13px;border:1px solid var(--bdr);margin-bottom:10px;overflow:hidden}
.upm-app .bk-card.done{border-left:3px solid var(--green)}
.upm-app .bk-card.pend{border-left:3px solid var(--amber)}
.upm-app .bk-top{padding:12px 13px 4px}
.upm-app .bk-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}
.upm-app .time-bdg{font-size:11px;font-weight:800;color:var(--accent);background:rgba(59,130,246,.15);padding:3px 9px;border-radius:20px}
.upm-app .truck-bdg{font-size:11px;font-weight:800;background:rgba(245,158,11,.15);color:var(--amber);padding:3px 9px;border-radius:20px}
.upm-app .card-acts{display:flex;gap:5px;flex-shrink:0}
.upm-app .ibtn{width:27px;height:27px;border-radius:7px;border:1px solid var(--bdr);background:var(--surf);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.upm-app .route-row{display:flex;align-items:flex-start;gap:7px;margin-bottom:4px}
.upm-app .rinfo{flex:1;min-width:0}
.upm-app .rlbl{font-size:8.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.upm-app .raddr{font-size:12px;font-weight:600;line-height:1.4}
.upm-app .bk-foot{display:flex;align-items:center;justify-content:space-between;padding:9px 13px;background:var(--surf);border-top:1px solid var(--bdr);flex-wrap:wrap;gap:8px}
.upm-app .fin-row{display:flex;gap:13px;flex-wrap:wrap}
.upm-app .fin-item .fl{font-size:8.5px;color:var(--muted);font-weight:800;text-transform:uppercase}
.upm-app .fin-item .fv{font-size:12px;font-weight:800}

/* MODAL/OVERLAY */
.upm-app .ov{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:500;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.upm-app .ov.open{opacity:1;pointer-events:all}
.upm-app .modal{background:var(--surf);border-radius:18px 18px 0 0;width:100%;max-width:680px;max-height:92vh;overflow-y:auto;transform:translateY(40px);transition:transform .25s ease}
.upm-app .ov.open .modal{transform:translateY(0)}
.upm-app .modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--bdr);position:sticky;top:0;background:var(--surf);z-index:5}
.upm-app .modal-title{font-size:15.5px;font-weight:800}
.upm-app .modal-close{width:30px;height:30px;border-radius:50%;border:none;background:var(--card2);cursor:pointer;font-size:15px;color:var(--ink);display:flex;align-items:center;justify-content:center}
.upm-app .modal-body{padding:14px 16px 26px}

/* Delete confirm */
.upm-app .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}
.upm-app .modal-box{background:var(--card);border-radius:14px;border:1px solid var(--red);padding:24px;max-width:320px;width:100%;text-align:center}
.upm-app .modal-icon{font-size:38px;margin-bottom:10px}
.upm-app .modal-title2{font-size:17px;font-weight:800;margin-bottom:6px}
.upm-app .modal-msg{font-size:13px;color:var(--muted);margin-bottom:18px;line-height:1.6}
.upm-app .modal-btns{display:flex;gap:10px}
.upm-app .modal-btns .btn{flex:1;padding:11px}

/* DOC CARD */
.upm-app .doc-card{background:var(--card);border-radius:13px;border:1px solid var(--bdr);padding:14px;margin-bottom:12px}
.upm-app .doc-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}
.upm-app .doc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.upm-app .doc-name{font-weight:800;font-size:14px}
.upm-app .doc-sub{font-size:11px;color:var(--muted);margin-top:1px}

/* UPLOAD BOX */
.upm-app .upload-box{border:1.5px dashed var(--bdr);border-radius:11px;padding:16px;text-align:center;cursor:pointer;background:var(--surf)}
.upm-app .upload-box:hover{border-color:var(--accent)}
.upm-app .upload-preview{max-width:100%;max-height:90px;border-radius:8px;margin-bottom:8px;object-fit:contain;background:#fff;padding:4px}

/* item list rows */
.upm-app .item-row{display:flex;gap:8px;margin-bottom:6px;align-items:center}
.upm-app .item-row .inp{flex:1}
.upm-app .qty-inp{width:56px;flex:0 0 56px!important}
.upm-app .rm-btn{width:30px;height:36px;border:1px solid var(--bdr);border-radius:8px;background:var(--surf);color:var(--muted);cursor:pointer;flex-shrink:0}
.upm-app .add-row-btn{background:none;border:1.5px dashed var(--bdr);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--muted);cursor:pointer;width:100%;text-align:left}
.upm-app .add-row-btn:hover{border-color:var(--accent);color:var(--accent)}

/* worker entry box */
.upm-app .we-box{background:var(--surf);border-radius:10px;padding:10px;margin-bottom:8px;border:1px solid var(--bdr)}

/* status pill list */
.upm-app .status-flow{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}

@media print{ .upm-app *{visibility:hidden} }
