:root{--bg:#f1f0ee;--ink:#21201f;--soft:#7b7770;--line:#e7e4dd;
 --accent:#ffd400;--accent2:#ffc400;--card:#ffffff;--green:#1e8d53;--red:#b42318;
 --radius:16px;--shadow:0 1px 2px rgba(0,0,0,.04)}
*{box-sizing:border-box}html,body{min-height:100%}
html,body{max-width:100%;overflow-x:hidden}
body{margin:0;color:var(--ink);font-family:'Manrope',system-ui,Arial,sans-serif;background:var(--bg)}
h1,h2,h3{font-family:'Sora','Manrope',sans-serif;margin:.2em 0 .5em}
a{color:var(--ink);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--soft)}.money{font-variant-numeric:tabular-nums}

/* Fleetroom topbar (.tb) — used by shared topbar() across all surfaces */
.tb{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:11px 16px}
.tb .logoimg{height:28px;width:28px;border-radius:8px;display:block}
.tb .j{width:28px;height:28px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:800;color:#1b1b1b}
.tb .nm{font-family:'Sora',sans-serif;font-weight:800;font-size:15px}
.tb .sub{color:var(--soft);font-size:12.5px;border-left:1px solid var(--line);padding-left:11px}
.tb .right{margin-left:auto;display:flex;gap:13px;align-items:center;font-size:13px}
.tb .right a{color:var(--soft)}.tb .right a.on{color:var(--ink);font-weight:700}
.tb .right form{margin:0}
.roleswitch{display:inline-flex;background:#f1f0ee;border-radius:10px;padding:3px;gap:2px;margin-left:4px}
.roleswitch .seg{border-radius:8px;padding:5px 12px;font-size:12.5px;font-weight:600;color:#6b6b6b;text-decoration:none}
.roleswitch .seg.on{background:var(--accent);color:#1b1b1b;font-weight:700}
.roleswitch a.seg:hover{background:#fff;text-decoration:none}

/* Login-screen topbar (simple bar) */
.topbar{display:flex;align-items:center;gap:12px;padding:14px 22px;color:var(--ink);background:#fff;border-bottom:1px solid var(--line)}
.topbar .logo{font-family:'Sora',sans-serif;font-weight:800;font-size:19px;display:flex;align-items:center;gap:9px}
.topbar .logo .j{background:var(--accent);color:#1b1b1b;border-radius:8px;padding:2px 9px}
.topbar .logo .logoimg{height:32px;width:32px;border-radius:8px;display:block}
.topbar .sub{color:var(--soft);font-size:13px}
.linkbtn{background:transparent;border:0;color:var(--soft);font:inherit;font-size:13px;cursor:pointer;padding:0}
.linkbtn:hover{color:var(--ink)}

.wrap{max-width:1080px;margin:8px auto 40px;padding:0 16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin:0 0 16px;box-shadow:var(--shadow);overflow-x:auto}
.card h3{margin-top:0}
.scrollbox{max-height:62vh;overflow:auto;border:1px solid var(--line);border-radius:12px;margin:0 0 8px}
.scrollbox>table{margin:0}
.scrollbox table tr:first-child th{position:sticky;top:0;background:var(--card);z-index:2;box-shadow:0 1px 0 var(--line)}
.kpis{display:flex;gap:14px;flex-wrap:wrap;margin:0 0 16px}
.kpi{flex:1;min-width:140px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .n{font-family:'Sora',sans-serif;font-size:30px;font-weight:800;line-height:1}
.kpi .l{color:var(--soft);font-size:13px;margin-top:6px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
th{background:transparent;color:var(--soft);font-weight:600;font-size:12.5px;line-height:1.25}
td{border-bottom:1px solid #f0eee8}
td button,td .btn,td a.btn{padding:6px 11px;font-size:12.5px;border-radius:8px;white-space:nowrap}
td.money,td .money{white-space:nowrap}
input,button,select{font:inherit;padding:11px 13px;border-radius:10px;border:1px solid #e3e1dc;background:#fff}
button,.btn{background:var(--accent);border:0;font-weight:800;cursor:pointer;color:#1b1b1b;border-radius:10px}
button:hover,.btn:hover{background:var(--accent2)}
button.copy,.btn-dark{background:#21201f;color:#fff}button.copy:hover,.btn-dark:hover{background:#34322e}
.btn-danger{background:#e7503a;color:#fff}.btn-danger:hover{background:#cf4430}
.dup-actions{display:flex;gap:6px;flex-wrap:wrap}
.dup-legend{font-size:12.5px;color:var(--soft);margin:2px 0 10px}
.dup-banner{background:#fff7e6;border:1px solid #f0d488;border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:12px;margin-bottom:12px}
a.btn{display:inline-block;text-decoration:none;padding:11px 18px}
.linkbig{font-size:16px}
.notice{background:#fff3cd;border-radius:10px;padding:10px 12px;margin:0 0 12px;font-size:14px;color:#5c4d00}
.inlineform{display:inline}
.pager{display:flex;gap:14px;align-items:center;margin-top:12px;font-size:14px}
.link{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
form.inline{display:flex;gap:10px;flex-wrap:wrap;align-items:end}
label{display:block;font-size:12px;color:var(--soft);margin:0 0 4px}
.loginbox{max-width:380px;margin:8vh auto;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 26px;box-shadow:var(--shadow)}
.loginbox h2{margin-top:0}.loginbox input{width:100%;margin:0 0 12px}.loginbox button{width:100%}
pre{white-space:pre-wrap;word-break:break-word;background:#f2f1ef;color:#21201f;padding:14px;border-radius:12px;font-size:12.5px;border:1px solid var(--line)}

/* Master-detail */
.master{display:flex;gap:16px;align-items:flex-start}
.master-left{flex:0 0 240px;min-width:210px;max-height:calc(100vh - 150px);overflow-y:auto}
.master-right{flex:1;min-width:0}

/* Fleetroom search + list + card components */
.srch{display:flex;gap:8px;margin:0 0 14px}
.srch .box{flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:0 13px}
.srch .box svg{flex:0 0 auto}
.srch input{flex:1;border:0;background:transparent;padding:12px 0}.srch input:focus{outline:none}
.rlist{display:flex;flex-direction:column;gap:2px}
.rrow{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:10px;border-left:3px solid transparent;color:var(--ink)}
.rrow:hover{background:#faf9f7}
.rrow.on{background:#fff7d6;border-left-color:var(--accent)}
.rrow .nm{flex:1;min-width:0;font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rrow .nm small{display:block;color:var(--soft);font-weight:400;font-size:11.5px}
.rrow .bal{font-weight:700;font-size:12.5px;font-variant-numeric:tabular-nums}.rrow .bal.z{color:var(--soft);font-weight:400}
.rhead{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:6px}.rhead h3{margin:0;font-size:18px}
.pill{font-size:12px;color:#6b6b6b;background:#f1f0ee;border-radius:20px;padding:3px 11px}
.rhead .ghost{margin-left:auto}
.ghost{background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:7px 11px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px}
.ghost:hover{background:#faf9f7;border-color:#d9d5cc}
.chips{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.chips form{margin:0}
.tilelink{text-decoration:none;color:inherit;display:block;cursor:pointer}
.tilelink:hover{border-color:#d9d5cc;background:#fffdf7;text-decoration:none}
th a{color:var(--soft)}th a:hover{color:var(--ink)}
.totrow{display:flex;gap:18px;flex-wrap:wrap;margin:6px 0 14px;font-size:13px;color:var(--soft)}
.totrow b{color:var(--ink);font-size:15px;margin-left:4px}.totrow .wait{color:#8a6400}
.addbox{border:1px dashed #d9d5cc;border-radius:12px;padding:13px 14px;margin:0 0 15px;background:#faf9f7}.addbox h4{margin:0 0 9px;font-size:13.5px;font-weight:700}
.badge{border-radius:7px;padding:2px 9px;font-size:11.5px;font-weight:600;white-space:nowrap}
.badge.ok{background:#e6f4ec;color:#1e7a47}.badge.wait{background:#fbf0d0;color:#8a6400}.badge.dup{background:#ececea;color:#6b6b6b}

/* Links styled as buttons/rows/chips opt out of the global underline-on-hover */
.rrow:hover,.ghost:hover,a.btn:hover,.tb .right a:hover{text-decoration:none}

@media(max-width:640px){
  .wrap{padding:0 12px}
  .topbar{padding:14px 14px;flex-wrap:wrap}.topbar .logo{font-size:17px}
  .tb{flex-wrap:wrap}.srch{flex-wrap:wrap}
  .card{padding:16px 14px}
  .kpis{gap:10px}.kpi{min-width:46%;padding:13px 14px}.kpi .n{font-size:24px}
  /* Master list stays a capped, self-scrolling box so the detail isn't pushed far below a long list.
     align-items:stretch + width:100% on both panes is CRITICAL: the base .master uses
     align-items:flex-start, which on a column layout sizes the right pane to its CONTENT width — a
     wide table then made the whole page overflow (no scroll, pay button clipped). Stretching to 100%
     lets the inner scroller clip+scroll the table instead. (This is why standalone scout pages
     scrolled but the master-detail referral page didn't.) */
  .master{flex-direction:column;align-items:stretch}
  .master-left{flex-basis:auto;max-height:55vh;overflow:auto;width:100%}
  .master-right{width:100%;min-width:0}

  /* Forms — full-width vertical stack, comfortable tap targets.
     !important overrides inline style="flex:2 1 240px" / width:120px on fields — in a column
     flex layout an inline flex-basis becomes the item's HEIGHT, which created huge empty boxes. */
  form.inline{flex-direction:column;align-items:stretch}
  form.inline>div{flex:0 0 auto!important;width:100%}
  form.inline input:not([type=checkbox]):not([type=radio]),form.inline select,form.inline textarea,form.inline button,form.inline .btn{width:100%!important}
  .link input{min-width:0;width:100%}
  input,select,button,.btn,a.btn{min-height:44px}

  /* Data tables (.rtable) -> COMPACT cards on mobile. Horizontal scroll proved unreliable on iOS,
     so each row becomes a full-width card (no sideways scrolling): each cell is a tight
     "label: value" line, and the actions cell becomes a full-width button — so the pay button is
     always visible without any scrolling. .scrollbox loses its height cap on mobile (cards flow). */
  .scrollbox{max-height:none;overflow:visible;border:0}
  table.rtable,table.rtable tbody,table.rtable tr,table.rtable td{display:block;width:100%}
  table.rtable tr:first-child{display:none}                                   /* header row hidden */
  table.rtable tr{border:1px solid var(--line);border-radius:12px;padding:8px 13px;margin:0 0 8px;background:var(--card)}
  table.rtable td{display:flex;justify-content:space-between;gap:12px;align-items:center;border:0;padding:3px 0;text-align:right;white-space:normal;font-size:13.5px}
  table.rtable td::before{content:attr(data-label);color:var(--soft);font-size:12px;font-weight:600;text-align:left;flex:0 0 auto}
  table.rtable td[data-label=""]{justify-content:stretch}
  table.rtable td[data-label=""]::before{display:none}
  table.rtable td.actions{flex-direction:column;align-items:stretch;gap:6px;margin-top:6px}
  table.rtable td form,table.rtable td .btn,table.rtable td button,table.rtable td a.btn{width:100%}

  /* EXCEPTION — referrals stay a real TABLE with horizontal scroll (per request). A single-axis
     scroller (overflow-x only) scrolls reliably on iOS where a both-axes container did not;
     width:max-content forces the table past the screen so there's something to scroll. Two wrappers:
     .scrollbox.refscroll (admin — keeps its desktop vertical scrollbox) and .scrollx (cabinets). */
  .scrollbox.refscroll{max-height:none;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
  .scrollx{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
  table.rscroll{width:max-content;min-width:100%}
  table.rscroll th,table.rscroll td{white-space:nowrap}
}
.dr-hide{display:none!important}
.dimmed{opacity:.45;pointer-events:none}
.tg{background:transparent;border:0;color:var(--soft);font-weight:800;cursor:pointer;padding:0 6px;border-radius:8px;font-size:13px}
.tg:hover{background:rgba(0,0,0,.06)}
