/* =============================================================================
   ST Courier — Main Stylesheet v8.0
   Collapsible sidebar · Refined typography · Modern SaaS
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap');

/* ── DESIGN TOKENS ─────────────────────────────────────────────────────────── */
:root {
  color-scheme: light;

  /* Brand — Red (Primary #DC2626) */
  --brand:      #DC2626;
  --brand-dk:   #b91c1c;
  --brand-lt:   #fef2f2;
  --brand-ring: rgba(220,38,38,.16);

  /* Sidebar — White professional */
  --sidebar-bg:     #ffffff;
  --sidebar-hover:  rgba(220,38,38,.05);
  --sidebar-active: #DC2626;
  --sidebar-w:      220px;
  --sidebar-w-sm:   56px;
  --sidebar-text:   #64748b;
  --sidebar-text-active: #1E293B;

  /* Status */
  --ok:      #10B981; --ok-lt:    #ecfdf5;   /* Tertiary green */
  --amber:   #f59e0b; --amber-lt: #fffbeb;
  --danger:  #DC2626; --danger-lt:#fef2f2;
  --blue:    #3b82f6; --blue-lt:  #eff6ff;
  --violet:  #7c3aed; --violet-lt:#f5f3ff;
  --teal:    #0891b2; --teal-lt:  #ecfeff;
  --rose:    #f43f5e; --rose-lt:  #fff1f2;

  /* Surfaces */
  --bg:      #f0f4f8;
  --surface: #f8fafc;
  --card:    #ffffff;

  /* Text — Neutral #334155 family */
  --text:    #1E293B;
  --text-2:  #334155;
  --text-3:  #64748b;
  --text-4:  #94a3b8;
  --text-5:  #cbd5e1;

  /* Borders */
  --bd:   #e2e8f0;
  --bd-2: #cbd5e1;

  /* Fonts */
  --ff:  'Inter', system-ui, -apple-system, sans-serif;
  --ff2: 'Plus Jakarta Sans', var(--ff);

  /* Type scale */
  --fxs: 11px;  --fsm: 12.5px; --fbs: 14px;
  --fmd: 15.5px; --flg: 18px;  --fxl: 24px;

  /* Radius */
  --r1:4px;--r2:6px;--r3:8px;--r4:12px;--r5:16px;--rfull:9999px;

  /* Shadows */
  --sh0: 0 1px 2px rgba(0,0,0,.04);
  --sh1: 0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --sh2: 0 4px 12px rgba(0,0,0,.07),0 1px 4px rgba(0,0,0,.04);
  --sh3: 0 8px 24px rgba(0,0,0,.09),0 2px 6px rgba(0,0,0,.05);
  --sh4: 0 16px 40px rgba(0,0,0,.11),0 4px 12px rgba(0,0,0,.06);

  --dur:.16s; --ease:cubic-bezier(.4,0,.2,1);
  --topbar: 54px;
}

/* ── RESET ──────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── APP SHELL ──────────────────────────────────────────────────────────────── */
html,body{height:100%;overflow:hidden}
body{
  display:flex;
  font-family:var(--ff);
  font-size:var(--fbs);
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════════════ */
.sidebar{
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  height:100vh;
  background:var(--sidebar-bg);
  border-right:1px solid var(--bd);
  box-shadow:2px 0 12px rgba(0,0,0,.04);
  display:flex;flex-direction:column;
  overflow:visible;          /* allow hub-menu to escape the sidebar bounds */
  overflow-y:auto;           /* but still scroll if content is tall */
  flex-shrink:0;
  position:relative;z-index:200;
  transition:width var(--dur) var(--ease), min-width var(--dur) var(--ease);
}
.sidebar.collapsed{
  width:var(--sidebar-w-sm);
  min-width:var(--sidebar-w-sm);
}

/* Logo */
.sidebar-logo{
  display:flex;align-items:center;gap:10px;
  padding:16px 14px 12px;
  border-bottom:1px solid var(--bd);
  overflow:hidden;flex-shrink:0;
}
.sidebar-logo-mark{
  width:32px;height:32px;border-radius:var(--r3);
  background:var(--brand);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--ff2);font-weight:800;font-size:14px;
  letter-spacing:-1px;flex-shrink:0;
  box-shadow:0 2px 8px rgba(220,38,38,.3);
}
.sidebar-logo-name{
  font-family:var(--ff2);font-size:14.5px;font-weight:800;
  color:var(--text);white-space:nowrap;letter-spacing:-.3px;
}
.sidebar-logo-sub{
  font-size:9.5px;color:var(--text-4);
  text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;margin-top:1px;
}
.sidebar-logo-text{overflow:hidden;transition:opacity var(--dur),width var(--dur);}
.sidebar.collapsed .sidebar-logo-text{opacity:0;width:0;pointer-events:none;}

/* Hub selector wrapper */
.sidebar-hub-wrap{
  padding:10px 8px 6px;
  border-bottom:1px solid var(--bd);
  flex-shrink:0;overflow:visible;
}
.sidebar.collapsed .sidebar-hub-wrap{display:none;}

/* Nav */
.sidebar-nav{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:8px 0 4px;
  scrollbar-width:none;
}
.sidebar-nav::-webkit-scrollbar{width:0}
.sidebar-section-label{
  font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--text-5);
  padding:10px 14px 4px;white-space:nowrap;overflow:hidden;
  transition:opacity var(--dur),height var(--dur),padding var(--dur);
}
.sidebar.collapsed .sidebar-section-label{opacity:0;height:0;padding:0;overflow:hidden;}

.nav-item{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:7px 14px;
  color:var(--sidebar-text);
  font-size:13px;font-weight:500;
  border-radius:0;
  transition:background var(--dur), color var(--dur);
  white-space:nowrap;overflow:hidden;
  position:relative;
  text-decoration:none;
}
.nav-item:hover{
  background:var(--sidebar-hover);
  color:var(--text-2);
}
.nav-item.active{
  background:rgba(220,38,38,.07);
  color:var(--brand);
  font-weight:600;
}
.nav-item.active::before{
  content:'';
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;min-height:22px;
  background:var(--brand);
  border-radius:0 2px 2px 0;
}
.nav-icon{
  font-size:15px;flex-shrink:0;width:20px;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}
.nav-label{
  transition:opacity var(--dur);white-space:nowrap;overflow:hidden;
}
.sidebar.collapsed .nav-label{opacity:0;width:0;pointer-events:none;}
.nav-badge{
  margin-left:auto;font-size:10px;font-weight:700;
  background:var(--surface);color:var(--text-3);
  border:1px solid var(--bd);
  padding:1px 7px;border-radius:var(--rfull);flex-shrink:0;
}
.nav-item.active .nav-badge{background:var(--brand-lt);color:var(--brand);border-color:rgba(220,38,38,.2);}
.sidebar.collapsed .nav-badge{display:none;}

/* Footer */
.sidebar-footer{
  border-top:1px solid var(--bd);
  padding:8px;flex-shrink:0;position:relative;
}
.sidebar-user{
  display:flex;align-items:center;gap:9px;
  padding:8px;border-radius:var(--r3);cursor:pointer;
  transition:background var(--dur);overflow:hidden;
}
.sidebar-user:hover{background:var(--sidebar-hover);}
.sidebar-avatar{
  width:30px;height:30px;border-radius:50%;
  background:var(--brand);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  font-size:12px;font-weight:700;color:#fff;
}
.sidebar-avatar img{width:100%;height:100%;object-fit:cover;}
.sidebar-user-info{overflow:hidden;flex:1;transition:opacity var(--dur);}
.sidebar-user-name{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-user-role{font-size:10px;color:var(--text-3);}
.sidebar.collapsed .sidebar-user-info{opacity:0;width:0;overflow:hidden;}

.sidebar-user-menu{
  display:none;position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);box-shadow:var(--sh4);z-index:400;overflow:hidden;
  animation:modal-in .16s var(--ease);
}
.sidebar-user-menu.open{display:block;}
.sidebar-user-menu-hdr{padding:12px 14px 10px;border-bottom:1px solid var(--bd);}
.sidebar-user-menu-name{font-weight:700;font-size:13px;color:var(--text);}
.sidebar-user-menu-email{font-size:11px;color:var(--text-3);margin-top:1px;word-break:break-all;}
.sidebar-user-menu a,.sidebar-user-menu button{
  display:flex;align-items:center;gap:8px;
  width:100%;padding:9px 14px;font-size:13px;color:var(--text-2);
  transition:background var(--dur);text-align:left;
}
.sidebar-user-menu a:hover,.sidebar-user-menu button:hover{background:var(--surface);color:var(--text);}
.sidebar-user-menu a.danger,.sidebar-user-menu button.danger{color:var(--danger);}
.sidebar-user-menu a.danger:hover{background:var(--danger-lt);}
.sidebar-menu-divider{height:1px;background:var(--bd);}

/* ══════════════════════════════════════════════════════════
   TOPBAR
   ══════════════════════════════════════════════════════════ */
.main-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:0;}
.topbar{
  height:var(--topbar);min-height:var(--topbar);
  display:flex;align-items:center;gap:10px;
  padding:0 20px 0 14px;
  background:var(--card);
  border-bottom:1px solid var(--bd);
  z-index:100;flex-shrink:0;
}
.topbar-toggle{
  display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:var(--r2);
  color:var(--text-3);flex-shrink:0;
  transition:background var(--dur), color var(--dur);cursor:pointer;
}
.topbar-toggle:hover{background:var(--surface);color:var(--text);}
.topbar-title{
  font-family:var(--ff2);font-size:var(--fmd);font-weight:700;
  color:var(--text);letter-spacing:-.3px;white-space:nowrap;
}
.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto;}

/* ── TOPBAR USER PROFILE (top-right) ─────────────────────────────────────── */
.topbar-profile-wrap{
  position:relative;display:flex;align-items:center;gap:8px;
  padding:5px 10px 5px 6px;border-radius:var(--r3);cursor:pointer;
  border:1px solid var(--bd);background:var(--surface2);
  transition:background var(--dur),border-color var(--dur);
  user-select:none;flex-shrink:0;
}
.topbar-profile-wrap:hover{background:var(--surface);border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);}
.topbar-avatar{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;font-family:var(--ff2);
  box-shadow:0 1px 4px rgba(220,38,38,.35);
}
.topbar-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.topbar-user-info{display:flex;flex-direction:column;gap:1px;min-width:0;}
.topbar-user-name{font-size:12.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;}
.topbar-user-role{font-size:10px;color:var(--text-3);white-space:nowrap;}
.topbar-chevron{color:var(--text-3);flex-shrink:0;transition:transform var(--dur);}
.topbar-profile-wrap:hover .topbar-chevron{color:var(--text);}

/* Topbar dropdown */
.topbar-user-dropdown{
  position:fixed;top:56px;right:14px;
  width:240px;background:#fff;border:1px solid var(--bd);
  border-radius:var(--r4);box-shadow:var(--sh4);z-index:9200;
  display:none;animation:dd-in .15s var(--ease);
}
.topbar-user-dropdown.open{display:block;}
@keyframes dd-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.tud-header{display:flex;align-items:center;gap:10px;padding:14px;}
.tud-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:800;font-family:var(--ff2);
}
.tud-info{flex:1;min-width:0;}
.tud-name{font-weight:700;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tud-email{font-size:11px;color:var(--text-3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tud-role-chip{
  display:inline-block;margin-top:4px;
  padding:2px 7px;border-radius:var(--rfull);
  background:var(--brand-lt);color:var(--brand);
  font-size:10px;font-weight:700;letter-spacing:.2px;
}
.tud-divider{height:1px;background:var(--bd);margin:2px 0;}
.tud-item{
  display:flex;align-items:center;gap:9px;
  width:100%;padding:9px 14px;background:none;border:none;
  font-size:13px;color:var(--text-2);cursor:pointer;text-align:left;
  transition:background var(--dur),color var(--dur);text-decoration:none;
}
.tud-item:hover{background:var(--surface);color:var(--text);}
.tud-item svg{color:var(--text-3);flex-shrink:0;}
.tud-item:hover svg{color:var(--brand);}
.tud-danger{color:var(--danger)!important;}
.tud-danger:hover{background:var(--danger-lt)!important;color:var(--danger)!important;}
.tud-danger svg{color:var(--danger)!important;}

/* Hide old sidebar footer now that profile moved to topbar */
.sidebar-footer{display:none!important;}
.topbar-stats{display:flex;align-items:center;gap:14px;}
.topbar-stat{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--text-3);}
.topbar-stat-val{color:var(--text);font-weight:700;}
.topbar-stat-sep{color:var(--text-5);}

/* ── COURIER HUB ──────────────────────────────────────────────────────────── */
.hub-wrap{position:relative;}
.hub-trigger{
  display:flex;align-items:center;gap:8px;
  padding:6px 11px;height:36px;
  background:var(--surface);border:1px solid var(--bd);
  border-radius:var(--r3);color:var(--text-2);
  cursor:pointer;font-size:12.5px;font-weight:600;
  transition:all var(--dur) var(--ease);white-space:nowrap;width:100%;
}
.hub-trigger:hover{background:var(--brand-lt);border-color:rgba(220,38,38,.3);color:var(--brand);}
.hub-default-state,.hub-sel-display{display:flex;align-items:center;gap:7px;flex:1;min-width:0;}
.hub-sel-pill{display:flex;align-items:center;border-radius:var(--r1);padding:2px 5px;overflow:hidden;}
.hub-sel-img{height:18px;max-width:60px;object-fit:contain;}
.hub-sel-text{font-size:12px;font-weight:800;color:var(--text);}
.hub-sel-name{font-size:12.5px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;flex:1;}
.hub-icon-default{font-size:14px;opacity:.6;}
.hub-label-text{font-size:12.5px;flex:1;color:var(--text-3);}
.hub-caret{transition:transform var(--dur) var(--ease);}
.hub-open .hub-caret{transform:rotate(180deg);}
.hub-clear-btn{
  display:none;font-size:10px;color:var(--text-3);
  padding:2px 5px;background:var(--bd);border-radius:var(--r1);cursor:pointer;border:none;
}
.hub-clear-btn:hover{background:rgba(220,38,38,.15);color:var(--brand);}

/* Hub menu — fixed-positioned so sidebar overflow can't clip it */
.hub-menu{
  display:none;position:fixed;
  min-width:310px;width:240px;
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r5);box-shadow:var(--sh4);z-index:9000;
  overflow:hidden;animation:modal-in .16s var(--ease);
}
.hub-wrap.hub-open .hub-menu{display:block;}
.hub-menu-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px 10px;border-bottom:1px solid var(--bd);background:var(--surface);
}
.hub-menu-hdr > div > div:first-child{font-size:13px;font-weight:700;color:var(--text);}
.hub-menu-hdr-sub{font-size:11px;color:var(--text-3);margin-top:1px;}
.hub-search-wrap{padding:10px 10px 4px;}
.hub-search-inp{
  width:100%;height:33px;padding:0 10px 0 32px;
  border:1.5px solid var(--bd);border-radius:var(--r3);font-size:13px;
  background:var(--surface);color:var(--text);
  transition:border-color var(--dur),box-shadow var(--dur);
}
.hub-search-inp:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);background:#fff;}

/* Partner grid */
.hub-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));
  gap:6px;padding:8px 10px 10px;max-height:230px;overflow-y:auto;
}
.hub-grid::-webkit-scrollbar{width:4px;}
.hub-grid::-webkit-scrollbar-thumb{background:var(--bd-2);border-radius:4px;}

.hub-item-wrap{position:relative;}
.hub-item{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 4px 8px;border-radius:var(--r4);cursor:pointer;
  border:1.5px solid var(--bd);background:var(--card);
  transition:all var(--dur) var(--ease);width:100%;
}
.hub-item:hover{
  background:var(--brand-lt);border-color:rgba(192,0,0,.3);
  transform:translateY(-1px);box-shadow:var(--sh1);
}
.hub-item.active,.hub-item.selected{
  background:var(--brand-lt);border-color:var(--brand);
  box-shadow:0 0 0 1px var(--brand);
}
/* Selected checkmark badge */
.hub-item-wrap.selected-wrap::after,
.hub-item.active + .hub-item-selected-mark,
.hub-item.active::after,
.hub-item.selected::after{
  content:'✓';
  position:absolute;top:3px;right:4px;
  font-size:8.5px;font-weight:900;color:var(--brand);
}
.hub-logo-wrap{
  width:48px;height:32px;border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
}
.hub-logo-img{width:100%;height:100%;object-fit:contain;}
.hub-logo-fb{
  font-size:11px;font-weight:900;letter-spacing:-.3px;color:var(--text-2);
}
.hub-item-name{
  font-size:9.5px;color:var(--text-3);text-align:center;
  line-height:1.2;font-weight:600;width:100%;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;
}
.hub-item.active .hub-item-name,.hub-item.selected .hub-item-name{color:var(--brand);font-weight:700;}
.hub-item.active .hub-logo-fb,.hub-item.selected .hub-logo-fb{color:var(--brand);}

/* Delete button (manage mode) */
.hub-del-btn{
  display:none;position:absolute;top:-5px;right:-5px;
  width:18px;height:18px;background:var(--danger);color:#fff;
  border-radius:50%;font-size:9px;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 2px 4px rgba(220,38,38,.4);z-index:1;
}
.hub-manage-mode .hub-del-btn{display:flex;}
.hub-menu-foot{
  padding:8px 10px;border-top:1px solid var(--bd);
  display:flex;gap:6px;background:var(--surface);
}

/* ── GLOBAL SEARCH ──────────────────────────────────────────────────────────── */
.gsearch-wrap{position:relative;}
.gsearch-bar{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);border:1.5px solid var(--bd);
  border-radius:var(--r3);padding:0 10px;height:34px;
  transition:border-color var(--dur),box-shadow var(--dur);min-width:220px;
}
.gsearch-bar:focus-within{
  border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);background:#fff;
}
.gsearch-svg-icon{width:14px;height:14px;flex-shrink:0;color:var(--text-4);}
.gsearch-input{
  border:none;background:transparent;font-size:13px;color:var(--text);
  width:100%;min-width:0;
}
.gsearch-input:focus{outline:none;}
.gsearch-input::placeholder{color:var(--text-4);}
.gsearch-clear{background:none;border:none;color:var(--text-4);cursor:pointer;padding:2px 4px;font-size:13px;display:flex;align-items:center;line-height:1;}
.gsearch-clear:hover{color:var(--text);}
/* Dropdown — position:fixed so it escapes the topbar stacking context */
.gsearch-dropdown{
  position:fixed;
  min-width:340px;max-width:520px;max-height:420px;overflow-y:auto;
  background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);
  box-shadow:var(--sh4);z-index:9100;animation:modal-in .14s var(--ease);
}
.gsearch-dropdown::-webkit-scrollbar{width:4px;}
.gsearch-dropdown::-webkit-scrollbar-thumb{background:var(--bd-2);border-radius:4px;}
/* Items inside dropdown */
.gsd-empty{padding:20px 16px;font-size:13px;color:var(--text-3);text-align:center;}
.gsd-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 14px;width:100%;text-align:left;
  border:none;background:none;cursor:pointer;
  border-bottom:1px solid var(--bd);
  transition:background var(--dur);
}
.gsd-item:last-child{border-bottom:none;}
.gsd-item:hover{background:var(--brand-lt);}
.gsd-avatar{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;margin-top:1px;
}
.gsd-body{flex:1;min-width:0;}
.gsd-route-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:2px;}
.gsd-party{font-size:12.5px;color:var(--text);display:flex;align-items:center;gap:4px;}
.gsd-party-label{
  font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  padding:1px 5px;border-radius:var(--r1);background:var(--surface);color:var(--text-4);
}
.gsd-from-party .gsd-party-label{background:rgba(220,38,38,.08);color:var(--brand);}
.gsd-to-party .gsd-party-label{background:rgba(16,185,129,.08);color:#10B981;}
.gsd-mob{font-size:11.5px;color:var(--text-3);}
.gsd-arrow{font-size:13px;color:var(--text-4);}
.gsd-addr-row{display:flex;align-items:center;gap:6px;margin-bottom:2px;flex-wrap:wrap;}
.gsd-addr{font-size:11px;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px;}
.gsd-arrow-sm{font-size:11px;color:var(--text-5);}
.gsd-meta{font-size:11px;color:var(--text-4);}
/* Legacy selectors (safe to keep) */
.gsearch-results,.gsearch-hdr,.gsearch-item,.gsearch-item-name,.gsearch-item-sub,.gsearch-item-awb{}

/* ── SCROLL CONTENT ─────────────────────────────────────────────────────────── */
.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;}
.main-content::-webkit-scrollbar{width:5px;}
.main-content::-webkit-scrollbar-track{background:transparent;}
.main-content::-webkit-scrollbar-thumb{background:var(--bd-2);border-radius:var(--rfull);}

/* ── PANEL ───────────────────────────────────────────────────────────────────── */
.panel{display:none;}
.panel.active{display:block;}

/* ══════════════════════════════════════════════════════════
   FORM ELEMENTS
   ══════════════════════════════════════════════════════════ */
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{
  font-size:12px;font-weight:600;color:var(--text-2);
  letter-spacing:.15px;
}
.form-input{
  height:38px;padding:0 11px;
  border:1.5px solid var(--bd);border-radius:var(--r3);
  font-size:var(--fbs);color:var(--text);background:var(--card);
  transition:border-color var(--dur),box-shadow var(--dur);width:100%;
}
.form-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);background:#fff;}
.form-input:hover:not(:focus){border-color:var(--bd-2);}
.form-input::placeholder{color:var(--text-5);font-weight:400;}
.form-select{
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:30px;
}
textarea.form-input{height:auto;padding:9px 11px;resize:vertical;}

/* ── BUTTONS ─────────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:7px 14px;border-radius:var(--r3);
  font-size:var(--fbs);font-weight:600;
  border:1px solid transparent;
  transition:all var(--dur) var(--ease);cursor:pointer;white-space:nowrap;
  text-decoration:none;font-family:inherit;
}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn-sm{padding:5px 10px;font-size:var(--fsm);}
.btn-lg{padding:10px 20px;font-size:var(--fmd);}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand);}
.btn-primary:hover{background:var(--brand-dk);border-color:var(--brand-dk);transform:translateY(-1px);box-shadow:0 4px 12px rgba(192,0,0,.3);}
.btn-success{background:var(--ok);color:#fff;border-color:var(--ok);}
.btn-success:hover{background:#15803d;box-shadow:0 4px 12px rgba(22,163,74,.3);transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--text-2);border-color:var(--bd-2);}
.btn-outline:hover{background:var(--surface);border-color:var(--brand);color:var(--brand);}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-3);}
.btn-ghost:hover{background:var(--surface);color:var(--text);}
.btn-danger{background:var(--danger);color:#fff;}
.btn-danger:hover{background:#b91c1c;transform:translateY(-1px);}
.btn-blue{background:var(--blue);color:#fff;}
.btn-blue:hover{background:#1d4ed8;}

/* spinner */
.spinner{
  display:inline-block;width:13px;height:13px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══════════════════════════════════════════════════════════
   SECTION CARD
   ══════════════════════════════════════════════════════════ */
.section-card{
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r5);box-shadow:var(--sh1);overflow:hidden;margin-bottom:16px;
}
.section-card-hdr{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;border-bottom:1px solid var(--bd);
  background:linear-gradient(to bottom,#fff 0%,var(--surface) 100%);
}
.section-card-icon{
  width:28px;height:28px;border-radius:var(--r3);
  background:var(--brand-lt);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-size:14px;
  box-shadow:0 1px 3px rgba(192,0,0,.12);flex-shrink:0;
}
.section-card-title{
  font-family:var(--ff2);font-size:13px;font-weight:800;
  color:var(--text);letter-spacing:-.2px;
}
.section-card-body{padding:18px 20px;}

/* ══════════════════════════════════════════════════════════
   BOOKING FORM
   ══════════════════════════════════════════════════════════ */
.bkf{}
.bkf-hdr{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;background:linear-gradient(to bottom,#fff,var(--surface));
  border-bottom:1px solid var(--bd);
}
.bkf-title{
  font-family:var(--ff2);font-size:14px;font-weight:800;
  color:var(--text);letter-spacing:-.4px;
}
.bkf-hint{font-size:12px;color:var(--text-4);}
.bkf-body{padding:10px 14px;}
.bkf-section{margin-bottom:8px;}
.bkf-section-title{
  display:flex;align-items:center;gap:6px;
  font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--text-4);margin-bottom:6px;
}
.bkf-section-title .section-icon{
  width:16px;height:16px;border-radius:3px;
  background:var(--brand-lt);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-size:9px;
  flex-shrink:0;
}
.bkf-section-title::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(to right,var(--bd),transparent);
}

/* Sender/Receiver grid */
.bkf-parties{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:start;}
.bkf-arrow{
  display:flex;align-items:center;justify-content:center;
  padding-top:24px;color:var(--text-4);font-size:18px;
}
.bkf-party{
  background:var(--surface);border:1px solid var(--bd);
  border-radius:var(--r4);padding:8px 10px;
}
.bkf-party-from{border-left:3px solid var(--brand);}
.bkf-party-to{border-left:3px solid var(--blue);}
.bkf-party-bar{display:flex;align-items:center;gap:7px;margin-bottom:6px;}
.bkf-party-label{
  font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  padding:3px 9px;border-radius:var(--rfull);
}
.bkf-party-from .bkf-party-label{color:var(--brand);background:var(--brand-lt);}
.bkf-party-to   .bkf-party-label{color:var(--blue);background:var(--blue-lt);}
.bkf-lookup{
  margin-left:auto;font-size:11px;font-weight:600;color:var(--brand);
  background:none;border:none;cursor:pointer;padding:3px 8px;border-radius:var(--r2);
  transition:background var(--dur);
}
.bkf-lookup:hover{background:var(--brand-lt);}

.bkf-row{display:grid;gap:6px;margin-bottom:5px;}
.bkf-row.c1{grid-template-columns:1fr;}
.bkf-row.c2{grid-template-columns:1fr 1fr;}
.bkf-row.c3{grid-template-columns:1fr 1fr 1fr;}
.bkf-row.c4{grid-template-columns:repeat(4,1fr);}
.bkf-row.c5{grid-template-columns:repeat(5,1fr);}
.bkf-fg{display:flex;flex-direction:column;gap:2px;}
.bkf-lbl{
  font-size:11px;font-weight:600;color:var(--text-2);
  letter-spacing:.1px;
}
.req{color:var(--danger);}
.bkf-inp,.bkf-sel{
  height:30px;padding:0 8px;
  border:1.5px solid var(--bd);border-radius:var(--r3);
  font-size:var(--fbs);color:var(--text);background:#fff;
  transition:border-color var(--dur),box-shadow var(--dur);width:100%;
}
.bkf-inp:hover:not(:focus),.bkf-sel:hover:not(:focus){border-color:var(--bd-2);}
.bkf-inp:focus,.bkf-sel:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-ring);background:#fff;
}
.bkf-inp::placeholder{color:var(--text-5);font-weight:400;}
.bkf-inp.loading{
  background:linear-gradient(90deg,var(--surface) 25%,var(--bd) 50%,var(--surface) 75%);
  background-size:200% 100%;animation:shimmer 1.2s infinite;
}
.bkf-sel{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;
  padding-right:30px;cursor:pointer;
}

/* Prefix input (phone, amount) */
.bkf-pfx-wrap{
  display:flex;align-items:center;
  border:1.5px solid var(--bd);border-radius:var(--r3);
  overflow:hidden;background:#fff;
  transition:border-color var(--dur),box-shadow var(--dur);
}
.bkf-pfx-wrap:focus-within{
  border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);
}
.bkf-pfx{
  padding:0 8px;background:var(--surface);border-right:1.5px solid var(--bd);
  height:30px;display:flex;align-items:center;
  font-size:var(--fbs);color:var(--text-3);font-weight:600;flex-shrink:0;
  white-space:nowrap;
}
.bkf-inp-pfx{border:none;border-radius:0;box-shadow:none!important;}
.bkf-inp-pfx:focus{box-shadow:none;border-color:transparent;}
.bkf-awb-row{display:flex;align-items:flex-start;gap:6px;flex-wrap:wrap;}
.bkf-awb-row .bkf-inp{flex:1;min-width:140px;}
.bkf-form-hint{font-size:11.5px;color:var(--danger);font-weight:500;}
.bkf-footer{
  display:flex;align-items:center;gap:10px;padding:11px 20px;
  background:var(--surface);border-top:1px solid var(--bd);flex-wrap:wrap;
}
.bkf-notify-row{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap;}
.bkf-notify-lbl{font-size:12px;font-weight:600;color:var(--text-3);white-space:nowrap;}
.bkf-notify-opt{display:flex;align-items:center;gap:5px;font-size:12.5px;cursor:pointer;white-space:nowrap;}
.bkf-notify-opt input{width:14px;height:14px;cursor:pointer;accent-color:var(--primary);}
.bkf-footer-actions{display:flex;align-items:center;gap:8px;margin-left:auto;}
.bkf-textarea{height:auto;padding:8px 10px;resize:vertical;}

/* ── Courier Partner Selection ───────────────────────────────────────────────── */
.courier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;}
.courier-card{
  position:relative;overflow:hidden;
  border:2px solid var(--bd);border-radius:var(--r4);
  padding:14px;background:var(--card);
  cursor:pointer;transition:all var(--dur) var(--ease);
}
.courier-card:hover{border-color:var(--brand);box-shadow:var(--sh2);}
.courier-card.selected{border-color:var(--brand);background:var(--brand-lt);box-shadow:0 0 0 1px var(--brand);}
.courier-card-name{font-weight:700;font-size:14px;color:var(--text);margin-bottom:2px;}
.courier-card-price{font-family:var(--ff2);font-size:18px;font-weight:800;color:var(--brand);}
.courier-card-delivery{font-size:11.5px;color:var(--text-3);margin-top:4px;display:flex;align-items:center;gap:4px;}
.courier-card-tag{
  display:inline-block;font-size:9.5px;font-weight:700;
  padding:2px 7px;border-radius:var(--rfull);margin-top:6px;
  background:var(--surface);color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;
}
.courier-card.selected .courier-card-tag{background:var(--brand);color:#fff;}
.courier-recommended{
  position:absolute;top:10px;right:-18px;
  background:var(--brand);color:#fff;
  font-size:8px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  padding:3px 22px;transform:rotate(45deg);
}
.est-delivery-card{
  background:linear-gradient(135deg,var(--brand-lt) 0%,#fff 100%);
  border:1px solid rgba(192,0,0,.12);border-radius:var(--r4);
  padding:14px 18px;display:flex;align-items:center;gap:14px;
}
.est-delivery-icon{font-size:26px;opacity:.8;}
.est-delivery-title{font-weight:700;font-size:13px;color:var(--brand);margin-bottom:2px;}
.est-delivery-sub{font-size:12.5px;color:var(--text-2);}

/* ── AWB BANNER ─────────────────────────────────────────────────────────────── */
#awb-preview{margin-bottom:16px;}
.awb-banner{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dk) 100%);
  color:#fff;border-radius:var(--r5);padding:18px 22px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  box-shadow:0 4px 20px rgba(192,0,0,.3);
}
.awb-banner-icon{font-size:32px;flex-shrink:0;}
.awb-banner-body{flex:1;min-width:160px;}
.awb-banner-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;opacity:.7;margin-bottom:2px;}
.awb-banner-number{font-family:var(--ff2);font-size:24px;font-weight:800;letter-spacing:2px;line-height:1;}
.awb-banner-sub{font-size:11.5px;opacity:.75;margin-top:4px;display:flex;align-items:center;gap:4px;}
.awb-check{color:#86efac;font-size:13px;}
.awb-banner-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.awb-banner-actions .btn{
  background:rgba(255,255,255,.13);color:#fff;
  border-color:rgba(255,255,255,.18);font-size:11.5px;
}
.awb-banner-actions .btn:hover{background:rgba(255,255,255,.24);transform:translateY(-1px);}
.awb-banner-actions .btn-success{background:rgba(22,163,74,.75);border-color:transparent;}

/* ── TABLE ───────────────────────────────────────────────────────────────────── */
.table-toolbar,.panel-toolbar{
  display:flex;align-items:flex-end;gap:10px;
  padding:11px 18px;background:var(--surface);border-bottom:1px solid var(--bd);flex-wrap:wrap;
}
.table-result-count{padding:6px 18px 0;font-size:var(--fsm);color:var(--text-3);}
.search-wrap{position:relative;display:flex;align-items:center;}
.search-wrap .table-search-icon{position:absolute;left:10px;font-size:13px;pointer-events:none;}
.search-wrap .form-input{padding-left:32px;padding-right:32px;min-width:220px;}
.search-wrap .table-search-icon,.search-wrap .table-search-svg{position:absolute;left:10px;font-size:13px;pointer-events:none;color:var(--text-3);}
.search-clear-btn{position:absolute;right:6px;background:none;border:none;cursor:pointer;color:var(--text-4);padding:4px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r2);}
.search-clear-btn:hover{color:var(--text);background:var(--surface);}
.data-table-wrap{overflow-x:auto;}
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;}
.data-table th{
  background:var(--surface);border-bottom:2px solid var(--bd);
  padding:9px 14px;text-align:left;
  font-size:10.5px;font-weight:700;color:var(--text-3);
  text-transform:uppercase;letter-spacing:.6px;
  position:sticky;top:0;z-index:1;white-space:nowrap;
}
.data-table td{
  padding:10px 14px;border-bottom:1px solid var(--bd);
  vertical-align:middle;color:var(--text-2);line-height:1.45;
}
.data-table tbody tr{transition:background var(--dur);}
.data-table tbody tr:hover td{background:var(--brand-lt);}
.data-table tbody tr:last-child td{border-bottom:none;}
.col-awb{font-weight:800;font-size:12.5px;color:var(--brand);letter-spacing:.5px;font-family:var(--ff2);}

/* Badges */
.badge{
  display:inline-flex;align-items:center;
  padding:2px 8px;border-radius:var(--rfull);
  font-size:10px;font-weight:700;white-space:nowrap;letter-spacing:.3px;
}
.badge-ok,.badge-delivered{background:var(--ok-lt);color:var(--ok);}
.badge-warn{background:var(--amber-lt);color:var(--amber);}
.badge-danger,.badge-failed,.badge-returned{background:var(--danger-lt);color:var(--danger);}
.badge-blue,.badge-transit{background:var(--blue-lt);color:var(--blue);}
.badge-gray,.badge-booked{background:var(--surface);color:var(--text-3);border:1px solid var(--bd);}
.badge-violet{background:var(--violet-lt);color:var(--violet);}
.badge-teal{background:var(--teal-lt);color:var(--teal);}
.badge-picked{background:#fef3c7;color:#92400e;}
.badge-delivery{background:#ede9fe;color:#5b21b6;}
.badge-cancelled{background:#f1f5f9;color:#64748b;border:1px solid var(--bd);}

/* ── BOOKINGS TABLE ──────────────────────────────────────────────────────────── */
.bk-result-bar{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px;border-bottom:1px solid var(--bd);
}
.bk-count-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:var(--rfull);
  background:var(--surface);border:1px solid var(--bd);
  font-size:12px;color:var(--text-2);
}
.bk-count-chip svg{color:var(--text-3);}
.bk-count-chip strong{color:var(--text);font-weight:700;}
.bk-count-chip.bk-count-search{background:var(--brand-lt);border-color:var(--brand);color:var(--brand);}
.bk-count-chip.bk-count-search svg{color:var(--brand);}
.bk-count-chip.bk-count-search strong{color:var(--brand);}
.bk-clear-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:var(--rfull);
  background:none;border:1px solid var(--bd);
  font-size:11.5px;color:var(--text-3);cursor:pointer;
  transition:all var(--dur);
}
.bk-clear-btn:hover{background:var(--danger-lt);border-color:var(--danger);color:var(--danger);}

/* Table rows */
.bk-row td{vertical-align:middle;}
.bk-date{font-size:12px;color:var(--text-3);white-space:nowrap;}
.bk-num{font-variant-numeric:tabular-nums;text-align:right;font-size:13px;color:var(--text-2);}
.bk-unit{font-size:10px;color:var(--text-3);}
.bk-amount{font-weight:700;color:var(--text);}

/* Sender / Recipient two-line cells */
.bk-contact{display:flex;flex-direction:column;gap:2px;min-width:0;}
.bk-contact-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;}
.bk-contact-sub{font-size:11.5px;color:var(--text-3);}

/* Status badge with dot */
.bk-status-badge{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.bk-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;display:inline-block;}

/* Vendor chip */
.bk-vendor-chip{
  display:inline-block;padding:3px 9px;border-radius:var(--rfull);
  font-size:11px;font-weight:700;letter-spacing:.2px;white-space:nowrap;
}

/* Service badge */
.bk-svc-badge{
  display:inline-block;padding:2px 6px;border-radius:4px;
  background:var(--surface);border:1px solid var(--bd);
  font-size:10px;font-weight:800;letter-spacing:.6px;color:var(--text-3);
  font-family:var(--ff2);
}

/* Action icon buttons */
.bk-actions{display:flex;align-items:center;gap:3px;justify-content:center;}
.bk-icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:var(--r3);
  border:1px solid transparent;background:transparent;
  color:var(--text-3);cursor:pointer;
  transition:background var(--dur),color var(--dur),border-color var(--dur);
  flex-shrink:0;
}
.bk-icon-btn:hover{background:var(--surface);border-color:var(--bd);color:var(--text);}
.bk-icon-btn.bk-icon-edit:hover{background:var(--brand-lt);border-color:var(--brand);color:var(--brand);}

/* TOAST ──────────────────────────────────────────────────────────────────── */
.toast-container{
  position:fixed;bottom:22px;right:22px;
  display:flex;flex-direction:column;gap:8px;z-index:10000;pointer-events:none;
}
.toast{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 15px;background:var(--text);color:#fff;
  border-radius:var(--r4);box-shadow:var(--sh4);
  font-size:var(--fbs);font-weight:500;max-width:360px;
  pointer-events:all;animation:toast-in .2s var(--ease);
  border-left:3px solid var(--brand);
}
.toast.toast-ok,.toast.toast-success{border-left-color:var(--ok);}
.toast.toast-error{border-left-color:var(--danger);}
.toast.toast-warn{border-left-color:var(--amber);}
.toast.toast-info{border-left-color:var(--blue);}
@keyframes toast-in{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}

/* ── MODALS ─────────────────────────────────────────────────────────────────── */
.modal-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(15,23,42,.48);backdrop-filter:blur(4px);
  z-index:1000;align-items:center;justify-content:center;padding:20px;
}
.modal-backdrop.open{display:flex;}
.modal{
  background:var(--card);border-radius:var(--r5);box-shadow:var(--sh4);
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:modal-in .2s var(--ease);
}
@keyframes modal-in{from{opacity:0;transform:scale(.97) translateY(-6px)}to{opacity:1;transform:none}}
.modal-hdr,.modal-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:12px;padding:17px 22px 13px;border-bottom:1px solid var(--bd);
}
.modal-ttl,.modal-title{
  font-family:var(--ff2);font-size:var(--fmd);font-weight:700;
  color:var(--text);letter-spacing:-.2px;
}
.modal-sub{font-size:var(--fsm);color:var(--text-3);margin-top:2px;}
.modal-close{
  width:26px;height:26px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r2);font-size:14px;color:var(--text-3);cursor:pointer;
  flex-shrink:0;transition:all var(--dur);
}
.modal-close:hover{background:var(--surface);color:var(--text);}
.modal-icon{font-size:20px;flex-shrink:0;}
.modal-body{padding:20px 24px;}
.modal-actions,.modal-footer{
  padding:13px 22px;border-top:1px solid var(--bd);
  display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;
}

/* ── EMPTY STATE & SKELETON ─────────────────────────────────────────────────── */
.empty-state{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:48px 24px;text-align:center;
}
.empty-state-icon{font-size:40px;margin-bottom:12px;opacity:.6;}
.empty-state-title{
  font-family:var(--ff2);font-size:var(--flg);font-weight:700;
  color:var(--text-2);margin-bottom:6px;
}
.empty-state-desc{font-size:var(--fbs);color:var(--text-3);max-width:340px;line-height:1.65;}
.skeleton-row{
  height:44px;border-radius:var(--r2);margin-bottom:2px;
  background:linear-gradient(90deg,var(--surface) 25%,var(--bd) 50%,var(--surface) 75%);
  background-size:200% 100%;animation:shimmer 1.2s infinite;
}
@keyframes shimmer{to{background-position:-200% 0}}

/* ── STATUS CHECK ───────────────────────────────────────────────────────────── */
/* ── TRACK SHIPMENT — SEARCH SHELL ─────────────────────────────────────────── */
/* ── TRACK PANEL SHELL ──────────────────────────────────────────────────────── */
.sc-shell{width:100%;max-width:960px;}

/* Hero gradient band — bleeds to edges by negating main-content padding */
.sc-hero-band{
  background:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#3730a3 100%);
  padding:24px 40px 22px;
  margin:-20px -20px 16px -20px;
}
.sc-hero-band-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.sc-hero-title{
  font-family:var(--ff2);font-size:20px;font-weight:800;
  color:#fff;letter-spacing:-.4px;
}
.sc-hero-sub{font-size:12.5px;color:rgba(255,255,255,.6);margin-top:3px;}

/* Stats chips inside hero */
.sc-stats-row{display:flex;gap:10px;flex-wrap:wrap;}
.sc-stat-chip{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r3);padding:8px 18px;min-width:76px;
  backdrop-filter:blur(6px);
}
.sc-stat-chip--green{background:rgba(22,163,74,.25);border-color:rgba(22,163,74,.4);}
.sc-stat-chip--blue {background:rgba(37,99,235,.3); border-color:rgba(37,99,235,.4);}
.sc-stat-chip--amber{background:rgba(217,119,6,.25); border-color:rgba(217,119,6,.4);}
.sc-stat-val{
  font-family:var(--ff2);font-size:20px;font-weight:800;
  color:#fff;line-height:1.1;
}
.sc-stat-lbl{font-size:10.5px;color:rgba(255,255,255,.65);font-weight:600;margin-top:2px;white-space:nowrap;}

/* Search card */
.sc-search-card{
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);box-shadow:var(--sh2);
  margin-bottom:16px;overflow:hidden;
}
.sc-search-row{
  display:flex;gap:10px;align-items:center;
  padding:16px 18px;border-bottom:1px solid var(--bd);
}
.sc-filter-row{
  display:flex;gap:16px;align-items:flex-end;
  padding:12px 18px;flex-wrap:wrap;
  background:var(--surface);
}
.sc-filter-group{display:flex;flex-direction:column;gap:3px;}
.sc-filter-lbl{
  font-size:10.5px;font-weight:700;color:var(--text-3);
  text-transform:uppercase;letter-spacing:.5px;
}

/* Search input */
.sc-hero-input-wrap{flex:1;position:relative;display:flex;align-items:center;}
.sc-hero-icon-svg{
  position:absolute;left:13px;color:var(--text-4);pointer-events:none;
  width:16px;height:16px;flex-shrink:0;
}
.sc-hero-clear{
  position:absolute;right:10px;display:flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;color:var(--text-4);
  background:var(--surface);border:1px solid var(--bd);
  cursor:pointer;transition:all var(--dur);
}
.sc-hero-clear:hover{background:var(--brand-lt);color:var(--brand);border-color:var(--brand-ring);}
.sc-hero-inp{
  width:100%;height:42px;padding:0 40px 0 42px;
  border:1.5px solid var(--bd);border-radius:var(--r3);
  font-size:13.5px;background:#fff;color:var(--text);
  transition:border-color var(--dur),box-shadow var(--dur);
}
.sc-hero-inp:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.15);}
.sc-hero-inp::placeholder{color:var(--text-5);}

/* Track button */
.sc-btn{
  height:42px;padding:0 22px;border-radius:var(--r3);
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
  color:#fff;font-size:13.5px;font-weight:700;
  border:none;cursor:pointer;transition:all var(--dur);
  white-space:nowrap;flex-shrink:0;
  display:flex;align-items:center;
  box-shadow:0 2px 8px rgba(79,70,229,.3);
}
.sc-btn:hover{
  background:linear-gradient(135deg,#4338ca,#6d28d9);
  box-shadow:0 4px 14px rgba(79,70,229,.45);transform:translateY(-1px);
}
.sc-btn:active{transform:translateY(0);}

/* Filter selects */
.sc-filter-sel{
  height:32px;padding:0 10px;
  border:1.5px solid var(--bd);border-radius:var(--r2);
  font-size:12px;font-family:var(--ff);color:var(--text-2);
  background:#fff;cursor:pointer;flex-shrink:0;
  transition:border-color var(--dur),box-shadow var(--dur);
}
.sc-filter-sel:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px rgba(99,102,241,.15);}
input.sc-filter-sel{min-width:130px;}

.sc-clear-btn{
  height:32px;padding:0 12px;border-radius:var(--r2);
  font-size:12px;font-weight:600;color:var(--text-3);
  border:1.5px solid var(--bd);background:#fff;cursor:pointer;
  margin-left:auto;white-space:nowrap;flex-shrink:0;
  display:flex;align-items:center;
  transition:all var(--dur);
}
.sc-clear-btn:hover{background:var(--brand-lt);border-color:var(--brand);color:var(--brand);}

/* Professional empty state */
.sc-empty-pro{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 24px;
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);box-shadow:var(--sh1);
  text-align:center;
}
.sc-empty-pro-icon{
  width:80px;height:80px;border-radius:50%;
  background:var(--brand-lt);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.sc-empty-pro-title{
  font-family:var(--ff2);font-size:17px;font-weight:800;
  color:var(--text);margin-bottom:6px;
}
.sc-empty-pro-sub{
  font-size:13px;color:var(--text-3);max-width:380px;line-height:1.6;
  margin-bottom:20px;
}
.sc-empty-pro-tips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;}
.sc-tip-chip{
  padding:5px 12px;border-radius:var(--rfull);
  background:var(--surface);border:1px solid var(--bd);
  font-size:12px;font-weight:600;color:var(--text-3);
}

/* Old plain empty (keep for JS-generated empty states) */
.sc-empty{
  text-align:center;padding:60px 24px;color:var(--text-3);
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);
}
.sc-empty-icon{font-size:44px;margin-bottom:12px;opacity:.5;}
.sc-empty-title{font-family:var(--ff2);font-size:15px;font-weight:700;color:var(--text-2);}
.sc-empty-sub{font-size:13px;color:var(--text-3);margin-top:4px;}

/* Searching indicator */
.sc-searching{
  display:flex;align-items:center;gap:6px;
  padding:18px 20px;font-size:13px;font-weight:600;color:var(--text-3);
  background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);
}
.sc-searching-dot{
  width:7px;height:7px;border-radius:50%;background:var(--brand);
  animation:sc-pulse 1.2s ease-in-out infinite;
}
.sc-searching-dot:nth-child(2){animation-delay:.2s;}
.sc-searching-dot:nth-child(3){animation-delay:.4s;}
@keyframes sc-pulse{0%,80%,100%{opacity:.25;transform:scale(.8);}40%{opacity:1;transform:scale(1);}}

/* Results header */
.sc-results-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;padding:0 2px;
}
.sc-results-count-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:var(--rfull);
  background:var(--surface);border:1px solid var(--bd);
  font-size:12px;font-weight:700;color:var(--text-3);
}
.sc-timeline{
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r5);padding:22px;box-shadow:var(--sh1);
}
.sc-tl-awb{
  font-family:var(--ff2);font-size:17px;font-weight:800;
  letter-spacing:.5px;color:var(--text);
}
.tl-item{display:flex;gap:14px;position:relative;}
.tl-item:not(:last-child)::before{
  content:'';position:absolute;left:9px;top:24px;bottom:-4px;
  width:2px;background:var(--bd-2);
}
.tl-dot{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:2px;
  display:flex;align-items:center;justify-content:center;font-size:10px;
  position:relative;z-index:1;
}
.tl-dot.ok{background:var(--ok);color:#fff;}
.tl-dot.active{background:var(--brand);color:#fff;}
.tl-dot.grey{background:var(--text-5);color:#fff;}
.tl-body{flex:1;padding-bottom:16px;}
.tl-title{font-weight:600;font-size:var(--fbs);color:var(--text);}
.tl-time{font-size:var(--fsm);color:var(--text-4);margin-top:2px;}

/* ── STATUS CHECK RESULT CARDS ──────────────────────────────────────────────── */
.sc-results-count{font-size:12.5px;font-weight:600;color:var(--text-3);margin-bottom:10px;padding:0 2px;}
.sc-card{
  background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);
  box-shadow:var(--sh1);margin-bottom:10px;overflow:hidden;
  transition:box-shadow var(--dur);
}
.sc-card:hover{box-shadow:var(--sh2);}
.sc-card-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:12px 16px 10px;border-bottom:1px solid var(--bd);
  flex-wrap:wrap;gap:6px;
}
.sc-card-awb-block{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.sc-vendor-badge{display:flex;align-items:center;}
.sc-card-awb{
  font-family:var(--ff2);font-size:14px;font-weight:800;
  color:var(--text);letter-spacing:.3px;
}
.sc-card-meta{font-size:11.5px;color:var(--text-4);margin-top:2px;}
.sc-status-pill{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:20px;
  font-size:11.5px;font-weight:700;white-space:nowrap;
}
.sc-card-route{
  display:grid;grid-template-columns:1fr 28px 1fr;
  align-items:start;gap:0;padding:12px 16px;border-bottom:1px solid var(--bd);
}
.sc-card-party{min-width:0;}
.sc-party-label{
  font-size:9.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;margin-bottom:3px;
}
.sc-from-label{color:var(--brand);}
.sc-to-label{color:#2563eb;}
.sc-party-name{font-weight:700;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sc-party-mob{font-size:12px;color:var(--text-3);margin-top:1px;}
.sc-party-city{font-size:11.5px;color:var(--text-4);margin-top:1px;}
.sc-route-arrow{
  display:flex;align-items:center;justify-content:center;
  padding-top:18px;color:var(--text-4);font-size:16px;font-weight:700;
}
.sc-card-footer{
  display:flex;align-items:center;gap:12px;padding:8px 16px;
  background:var(--surface);flex-wrap:wrap;
}
.sc-card-footer span{
  font-size:12px;color:var(--text-3);font-weight:600;
}
.sc-edit-btn{margin-left:auto;flex-shrink:0;}
.sc-empty{text-align:center;padding:40px;color:var(--text-3);}
.sc-empty-icon{font-size:44px;margin-bottom:12px;opacity:.5;}
.sc-empty-title{font-family:var(--ff2);font-size:15px;font-weight:700;color:var(--text-2);}
.sc-empty-sub{font-size:13px;color:var(--text-3);margin-top:4px;}

/* ── SETTINGS ───────────────────────────────────────────────────────────────── */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:760px;}
.settings-card{
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r5);padding:20px;box-shadow:var(--sh1);
}
.settings-card-title{
  font-family:var(--ff2);font-size:13.5px;font-weight:700;
  margin-bottom:14px;color:var(--text);
}

/* ── ADMIN PANEL TABS ────────────────────────────────────────────────────────── */
.adm-tabs{display:flex;gap:2px;border-bottom:2px solid var(--bd);margin-bottom:16px;}
.adm-tab{
  padding:8px 16px;font-size:12.5px;font-weight:600;
  color:var(--text-3);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:all var(--dur);
}
.adm-tab:hover{color:var(--brand);}
.adm-tab.active{color:var(--brand);border-bottom-color:var(--brand);}

/* ── ANALYTICS MODAL ─────────────────────────────────────────────────────────── */
.__an-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(15,23,42,.55);backdrop-filter:blur(4px);
  z-index:1000;align-items:center;justify-content:center;padding:16px;
}
.__an-backdrop.open{display:flex;}
.__an-dialog{
  background:var(--card);border-radius:var(--r5);box-shadow:var(--sh4);
  width:100%;max-width:1040px;max-height:92vh;overflow-y:auto;animation:modal-in .2s var(--ease);
}
.__an-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;border-bottom:1px solid var(--bd);
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dk) 100%);
  border-radius:var(--r5) var(--r5) 0 0;
}
.__an-hdr-left{flex:1;}
.__an-title{font-family:var(--ff2);font-size:16px;font-weight:800;color:#fff;letter-spacing:-.3px;}
.__an-sub{font-size:11.5px;color:rgba(255,255,255,.65);margin-top:2px;}
.__an-close{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r2);font-size:14px;color:rgba(255,255,255,.7);
  cursor:pointer;transition:all var(--dur);background:rgba(255,255,255,.1);
}
.__an-close:hover{background:rgba(255,255,255,.2);color:#fff;}
.__an-filters{
  display:flex;gap:10px;flex-wrap:wrap;
  padding:13px 22px;background:var(--surface);border-bottom:1px solid var(--bd);
}
.__an-fgrp{display:flex;flex-direction:column;gap:3px;}
.__an-flbl{font-size:10px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;}
.__an-finp{
  height:31px;padding:0 8px;border:1px solid var(--bd-2);border-radius:var(--r3);
  font-size:12.5px;color:var(--text);background:var(--card);
}
.__an-finp:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-ring);}
.__an-kpi-row{display:flex;gap:10px;padding:13px 22px;flex-wrap:wrap;}
.__an-kcard{
  flex:1;min-width:120px;background:var(--card);
  border:1px solid var(--bd);border-radius:var(--r4);padding:13px;box-shadow:var(--sh1);
}
.__an-kcard-teal{border-top:3px solid var(--teal);}
.__an-kcard-green{border-top:3px solid var(--ok);}
.__an-kcard-blue{border-top:3px solid var(--blue);}
.__an-kcard-orange{border-top:3px solid var(--amber);}
.__an-kcard-purple{border-top:3px solid var(--violet);}
.__an-kcard-val{font-family:var(--ff2);font-size:21px;font-weight:800;color:var(--text);}
.__an-kcard-sub{font-size:10.5px;color:var(--text-4);}
.__an-kcard-lbl{font-size:10.5px;color:var(--text-3);margin-top:3px;}
.__an-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:13px 22px;}
.__an-span2{grid-column:span 2;}
.__an-span3{grid-column:span 3;}
.__an-card{background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);padding:13px;box-shadow:var(--sh1);}
.__an-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.__an-card-title{font-size:12px;font-weight:700;color:var(--text-2);}
.__an-card-legend{font-size:11px;color:var(--text-4);display:flex;align-items:center;gap:6px;}
.__an-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.__an-chart-wrap{position:relative;}
.__an-send-bar{
  display:flex;align-items:center;gap:8px;
  padding:11px 22px;border-top:1px solid var(--bd);background:var(--surface);
}
.__an-email-inp{
  flex:1;height:35px;padding:0 12px;
  border:1px solid var(--bd-2);border-radius:var(--r3);
  font-size:var(--fbs);background:var(--card);color:var(--text);
}
.__an-email-inp:focus{outline:none;border-color:var(--brand);}
.__an-send-btn{
  height:35px;padding:0 16px;background:var(--brand);color:#fff;
  border-radius:var(--r3);font-size:12.5px;font-weight:600;cursor:pointer;
  border:none;transition:all var(--dur);white-space:nowrap;
}
.__an-send-btn:hover{background:var(--brand-dk);}
.__an-send-result{font-size:12px;padding:3px 22px 8px;color:var(--text-3);}

/* ── PROFILE / LEGACY HEADER DROPDOWN ───────────────────────────────────────── */
.profile-dropdown{position:relative;}
.profile-btn{
  display:flex;align-items:center;gap:7px;
  padding:5px 10px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r3);
  color:rgba(255,255,255,.85);cursor:pointer;font-size:12px;font-weight:500;transition:all var(--dur);
}
.profile-btn:hover{background:rgba(255,255,255,.15);}
.profile-btn-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.profile-btn-caret{opacity:.6;}
.profile-avatar{display:flex;align-items:center;justify-content:center;}
.profile-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  width:220px;background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);box-shadow:var(--sh4);z-index:600;overflow:hidden;animation:modal-in .16s var(--ease);
}
.profile-menu-hdr{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-bottom:1px solid var(--bd);
}
.profile-menu-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.profile-menu-name{font-weight:700;font-size:12.5px;color:var(--text);}
.profile-menu-email{font-size:11px;color:var(--text-3);word-break:break-all;}
.profile-menu-body{padding:4px 0;}
.profile-menu-item,.profile-menu a,.__pd-item{
  display:flex;align-items:center;gap:8px;padding:8px 14px;
  font-size:13px;color:var(--text-2);transition:background var(--dur);cursor:pointer;width:100%;
}
.profile-menu-item:hover,.profile-menu a:hover,.__pd-item:hover{background:var(--surface);color:var(--text);}
.profile-menu-item.danger{color:var(--danger);}
.profile-menu-item.danger:hover{background:var(--danger-lt);}
.profile-menu-divider,.__pd-divider{height:1px;background:var(--bd);margin:4px 0;}

/* ── COPIES PRESET ───────────────────────────────────────────────────────────── */
.copies-preset{
  width:36px;height:36px;border-radius:var(--r3);
  border:2px solid var(--bd-2);background:var(--surface);
  font-size:14px;font-weight:700;color:var(--text-2);cursor:pointer;transition:all var(--dur);
}
.copies-preset:hover{border-color:var(--brand);color:var(--brand);}
.copies-preset-active{border-color:var(--brand);background:var(--brand-lt);color:var(--brand);}

/* ── LEDGER / WALLET ─────────────────────────────────────────────────────────── */
.ledger-summary{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:12px;margin-bottom:16px;
}
.ledger-kcard{
  background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);padding:16px;box-shadow:var(--sh1);
}
.ledger-kcard-label{
  font-size:10.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.6px;color:var(--text-3);
}
.ledger-kcard-val{
  font-family:var(--ff2);font-size:23px;font-weight:800;
  color:var(--text);margin-top:4px;
}
.ledger-kcard-sub{font-size:11px;color:var(--text-4);margin-top:2px;}

/* ── INSURANCE BUTTON ────────────────────────────────────────────────────────── */
#ins-btn,.ins-active{
  height:30px;padding:0 12px;border-radius:var(--r3);
  font-size:11.5px;font-weight:700;cursor:pointer;
  border:1.5px solid var(--bd-2);background:var(--surface);
  color:var(--text-3);transition:all var(--dur);
  width:100%;
}
.ins-active,#ins-btn.active{background:var(--ok-lt);color:var(--ok);border-color:var(--ok);}
#ins-btn:hover{border-color:var(--ok);color:var(--ok);}

/* ── CONTACTS ────────────────────────────────────────────────────────────────── */
.contact-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;border-bottom:1px solid var(--bd);
  transition:background var(--dur);cursor:pointer;
}
.contact-card:hover{background:var(--brand-lt);}
.contact-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;
}
.contact-info{flex:1;min-width:0;}
.contact-name{font-weight:600;font-size:13.5px;color:var(--text);}
.contact-sub{font-size:11.5px;color:var(--text-3);}

/* ── SCALE CARD ──────────────────────────────────────────────────────────────── */
.scale-card{
  background:var(--surface);border:1px solid var(--bd);border-radius:var(--r4);
  padding:14px 18px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:5px;text-align:center;
}
.scale-card-label{
  font-size:10px;font-weight:700;letter-spacing:.8px;
  text-transform:uppercase;color:var(--text-4);
}

/* ── RESPONSIVE ──────────────────────────────────────────────────────────────── */
@media (max-width:900px){
  .sidebar{width:var(--sidebar-w-sm);min-width:var(--sidebar-w-sm);}
  .sidebar-logo-text{opacity:0;width:0;overflow:hidden;pointer-events:none;}
  .sidebar-section-label{opacity:0;height:0;padding:0;overflow:hidden;}
  .nav-label{opacity:0;width:0;overflow:hidden;pointer-events:none;}
  .sidebar-user-info{opacity:0;width:0;overflow:hidden;}
  .sidebar-hub-wrap{display:none;}
}

@media (max-width:620px){
  .topbar{padding:0 12px;}
  .topbar-title{font-size:13.5px;}
  .gsearch-bar{min-width:0;width:120px;}
  .bkf-parties{grid-template-columns:1fr;}
  .bkf-arrow{display:none;}
  .bkf-row.c3,.bkf-row.c4{grid-template-columns:1fr 1fr;}
  .bkf-row.c5{grid-template-columns:1fr 1fr;}
  .main-content{padding:14px;}
  .__an-grid{grid-template-columns:1fr;}
  .__an-span2,.__an-span3{grid-column:span 1;}
  .settings-grid{grid-template-columns:1fr;}
}

@media print{
  .sidebar,.topbar,.bkf-footer,.table-toolbar,.panel-toolbar{display:none!important;}
  .main-wrap{overflow:visible;}
  .main-content{overflow:visible;padding:0;}
  .panel{display:block!important;}
}

/* ═══════════════════════════════════════════════════════════
   BRANCHES & STAFF PANEL
   ═══════════════════════════════════════════════════════════ */

/* Sub-tab bar */
.sub-tab-bar{
  display:flex;gap:4px;padding:0 0 16px 0;
  border-bottom:1px solid var(--bd);margin-bottom:18px;
}
.sub-tab{
  padding:7px 18px;border-radius:var(--r3);border:1px solid transparent;
  font-size:13px;font-weight:600;cursor:pointer;
  color:var(--text-2);background:transparent;transition:all var(--dur);
}
.sub-tab:hover{background:var(--hover);color:var(--text);}
.sub-tab.active{
  background:var(--brand);color:#fff;border-color:var(--brand);
}

/* Branches grid */
.branches-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:16px;
}
.branch-card{
  background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);
  padding:18px;box-shadow:var(--sh1);position:relative;transition:box-shadow var(--dur);
}
.branch-card:hover{box-shadow:var(--sh2);}
.branch-card-primary{border-left:4px solid var(--brand);}
.branch-card-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;}
.branch-card-name{font-size:15px;font-weight:700;color:var(--text);}
.branch-card-badge{
  font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;
  background:#fee2e2;color:#991b1b;text-transform:uppercase;letter-spacing:.5px;
  white-space:nowrap;
}
.branch-card-badge.primary{background:#dcfce7;color:#166534;}
.branch-card-meta{font-size:12.5px;color:var(--text-2);line-height:1.7;}
.branch-card-meta span{display:block;}
.branch-card-stats{
  display:flex;gap:16px;margin-top:14px;padding-top:12px;
  border-top:1px solid var(--bd);
}
.bcs-item{display:flex;flex-direction:column;gap:2px;}
.bcs-val{font-size:18px;font-weight:700;color:var(--text);}
.bcs-lbl{font-size:10px;color:var(--text-3);text-transform:uppercase;font-weight:600;letter-spacing:.5px;}
.branch-card-actions{
  display:flex;gap:8px;margin-top:14px;
}
.branch-card-actions .btn-sm{
  flex:1;padding:6px 0;font-size:12px;text-align:center;
  border-radius:var(--r3);cursor:pointer;border:1px solid var(--bd);
  background:var(--surface);color:var(--text-2);font-weight:600;
  transition:all var(--dur);
}
.branch-card-actions .btn-sm:hover{background:var(--hover);color:var(--text);}
.branch-card-actions .btn-sm.danger{border-color:#fca5a5;color:#b91c1c;}
.branch-card-actions .btn-sm.danger:hover{background:#fee2e2;color:#991b1b;}

/* Empty state for branches */
.branches-empty{
  text-align:center;padding:60px 20px;color:var(--text-3);
}
.branches-empty svg{margin-bottom:14px;opacity:.4;}
.branches-empty p{font-size:14px;margin-top:6px;}

/* Staff table */
.staff-table-wrap{overflow-x:auto;}
.staff-table{
  width:100%;border-collapse:collapse;font-size:13px;
}
.staff-table th{
  text-align:left;font-size:11px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--text-3);
  padding:8px 12px;border-bottom:2px solid var(--bd);white-space:nowrap;
}
.staff-table td{
  padding:11px 12px;border-bottom:1px solid var(--bd);color:var(--text);
  vertical-align:middle;
}
.staff-table tr:last-child td{border-bottom:none;}
.staff-table tr:hover td{background:var(--hover);}
.staff-name{font-weight:600;font-size:13.5px;}
.staff-email{font-size:12px;color:var(--text-2);}
.staff-role-chip{
  display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;
  border-radius:20px;text-transform:uppercase;letter-spacing:.4px;
}
.staff-role-chip.owner{background:#fee2e2;color:#991b1b;}
.staff-role-chip.branch_manager{background:#dbeafe;color:#1d4ed8;}
.staff-role-chip.billing_staff{background:#d1fae5;color:#065f46;}
.staff-role-chip.viewer{background:#f1f5f9;color:#475569;border:1px solid var(--bd);}
.staff-status-dot{
  width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;
}
.staff-status-dot.active{background:#10b981;}
.staff-status-dot.inactive{background:#94a3b8;}
.staff-actions{display:flex;gap:8px;}
.staff-actions button{
  padding:5px 12px;font-size:12px;font-weight:600;border-radius:var(--r3);
  cursor:pointer;border:1px solid var(--bd);background:var(--surface);
  color:var(--text-2);transition:all var(--dur);
}
.staff-actions button:hover{background:var(--hover);color:var(--text);}
.staff-actions button.danger{border-color:#fca5a5;color:#b91c1c;}
.staff-actions button.danger:hover{background:#fee2e2;}
.staff-last-login{font-size:12px;color:var(--text-3);}

/* Branch / Staff Modal */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9000;
  display:flex;align-items:center;justify-content:center;
  animation:fadeIn .15s ease;
}
.modal-box{
  background:var(--card);border-radius:var(--r5);box-shadow:0 20px 60px rgba(0,0,0,.25);
  width:min(520px,95vw);max-height:90vh;overflow-y:auto;
  animation:slideUp .2s ease;
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--bd);
}
.modal-hdr h3{font-size:16px;font-weight:700;color:var(--text);margin:0;}
.modal-close{
  width:32px;height:32px;border-radius:var(--r3);border:none;
  background:transparent;cursor:pointer;color:var(--text-3);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;transition:all var(--dur);
}
.modal-close:hover{background:var(--hover);color:var(--text);}
.modal-body{padding:22px;}
.modal-footer{
  display:flex;justify-content:flex-end;gap:10px;
  padding:16px 22px;border-top:1px solid var(--bd);
}
.form-row{margin-bottom:16px;}
.form-row label{
  display:block;font-size:12px;font-weight:600;color:var(--text-2);
  margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px;
}
.form-row input,
.form-row select,
.form-row textarea{
  width:100%;padding:9px 12px;border:1px solid var(--bd-2);
  border-radius:var(--r3);font-size:13.5px;color:var(--text);
  background:var(--surface);box-sizing:border-box;
  transition:border-color var(--dur),box-shadow var(--dur);
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 2px var(--brand-ring);
}
.form-row textarea{resize:vertical;min-height:70px;}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

/* ═══════════════════════════════════════════════════════════
   CRM TIMELINE
   ═══════════════════════════════════════════════════════════ */
.crm-timeline-wrap{padding:0;}
.crm-timeline-hdr{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:0 0 18px 0;border-bottom:1px solid var(--bd);margin-bottom:24px;
}
.crm-timeline{
  position:relative;padding-left:28px;
}
.crm-timeline::before{
  content:'';position:absolute;left:8px;top:0;bottom:0;
  width:2px;background:var(--bd);
}
.crm-timeline-item{
  position:relative;margin-bottom:22px;
}
.crm-timeline-dot{
  position:absolute;left:-24px;top:10px;
  width:14px;height:14px;border-radius:50%;
}
.crm-timeline-card{
  background:var(--card);border:1px solid var(--bd);border-radius:var(--r4);
  padding:14px 16px;box-shadow:var(--sh1);
}
.crm-timeline-card-hdr{
  display:flex;align-items:center;gap:8px;margin-bottom:10px;
}
.crm-timeline-date{font-size:11px;color:var(--text-3);}
.crm-timeline-body{font-size:13.5px;color:var(--text);line-height:1.6;white-space:pre-wrap;}
.crm-timeline-followup{
  margin-top:10px;padding:6px 10px;border-radius:var(--r3);
  background:#fef3c7;color:#92400e;font-size:12px;font-weight:600;
  display:flex;align-items:center;gap:10px;
}
.crm-timeline-followup.done{background:#f0fdf4;color:#166534;text-decoration:line-through;}
.crm-timeline-followup button{
  margin-left:auto;padding:3px 10px;font-size:11px;font-weight:700;
  border-radius:20px;border:1px solid currentColor;background:transparent;cursor:pointer;
}
.crm-tiny-btn{
  padding:3px 10px;font-size:11px;font-weight:600;border-radius:var(--r3);
  border:1px solid var(--bd);background:var(--surface);cursor:pointer;
  color:var(--text-2);transition:all var(--dur);
}
.crm-tiny-btn:hover{background:var(--hover);}

/* ═══════════════════════════════════════════════════════════
   BILLING & INVOICING
   ═══════════════════════════════════════════════════════════ */
.billing-kpi-row{
  display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px;
}
.billing-kpi{
  flex:1;min-width:130px;background:var(--card);border:1px solid var(--bd);
  border-radius:var(--r4);padding:14px 16px;box-shadow:var(--sh1);
}
.billing-kpi.ok{border-top:3px solid var(--ok);}
.billing-kpi.danger{border-top:3px solid var(--brand);}
.billing-kpi.muted{border-top:3px solid #94a3b8;}
.billing-kpi-val{font-size:20px;font-weight:800;color:var(--text);}
.billing-kpi-lbl{font-size:11px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;}
.overdue-date{color:#b91c1c;font-weight:600;}

/* Invoice line items table inside modal */
.inv-items-table{width:100%;border-collapse:collapse;font-size:12.5px;}
.inv-items-table th{
  text-align:left;font-size:10px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--text-3);padding:5px 6px;
  border-bottom:1px solid var(--bd);
}
.inv-items-table td{padding:5px 4px;border-bottom:1px solid var(--bd);}
.inv-items-table tr:last-child td{border-bottom:none;}
.inv-item-inp{
  width:100%;padding:5px 7px;border:1px solid var(--bd-2);border-radius:var(--r3);
  font-size:12.5px;color:var(--text);background:var(--surface);box-sizing:border-box;
}
.inv-item-inp:focus{outline:none;border-color:var(--brand);}
.inv-item-total{font-weight:600;color:var(--text);text-align:right;padding-right:8px;}
.inv-totals-box{
  background:var(--surface);border:1px solid var(--bd);border-radius:var(--r4);
  padding:14px 16px;margin-top:16px;
}
.inv-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-top:1px solid var(--bd);margin-top:10px;
  font-size:14px;font-weight:700;color:var(--text);
}

/* =============================================================================
   COURIER LOADER — Animated SVG delivery scene
   Unique, brand-specific, professional.
   Usage: <div class="sc-loader-wrap"><div class="sc-loader"></div></div>
   ============================================================================= */

/* ── Overlay (full-screen or panel-relative) ── */
.sc-loader-overlay {
  position: fixed; inset: 0;
  background: rgba(240,244,248,.82);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  z-index: 9000;
  opacity: 0; animation: sclo-fadein .22s var(--ease) forwards;
}
.sc-loader-overlay.sc-loader-hide {
  animation: sclo-fadeout .2s var(--ease) forwards;
}
@keyframes sclo-fadein  { to   { opacity: 1 } }
@keyframes sclo-fadeout { from { opacity: 1 } to { opacity: 0 } }

/* ── Inline (inside a panel, table-wrap, etc.) ── */
.sc-loader-inline {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 48px 24px; width: 100%;
}

/* ── The SVG scene card ── */
.sc-loader {
  display: flex; flex-direction: column;
  align-items: center; gap: 18px;
}

/* SVG canvas */
.sc-loader svg { display: block; overflow: visible; }

/* ── Route path ── */
.sc-route {
  stroke: var(--bd-2); stroke-width: 2; fill: none;
  stroke-dasharray: 6 4;
  animation: sc-route-scroll 1.2s linear infinite;
}
@keyframes sc-route-scroll { to { stroke-dashoffset: -40 } }

/* ── Van body ── */
.sc-van { animation: sc-van-drive 2.4s var(--ease) infinite; }
@keyframes sc-van-drive {
  0%,100% { transform: translateX(0)   translateY(0) }
  25%      { transform: translateX(22px) translateY(-3px) }
  50%      { transform: translateX(44px) translateY(0) }
  75%      { transform: translateX(22px) translateY(-3px) }
}

/* ── Wheels ── */
.sc-wheel { transform-origin: center; animation: sc-spin 0.55s linear infinite; }
@keyframes sc-spin { to { transform: rotate(360deg) } }

/* ── Package bounce above van ── */
.sc-pkg {
  transform-origin: center bottom;
  animation: sc-pkg-bounce 2.4s cubic-bezier(.36,.07,.19,.97) infinite,
             sc-van-drive 2.4s var(--ease) infinite;
}
@keyframes sc-pkg-bounce {
  0%,100%  { transform: translateY(0)  scaleY(1)    scaleX(1) }
  12%      { transform: translateY(-8px) scaleY(1.05) scaleX(.95) }
  24%      { transform: translateY(0)  scaleY(.92)  scaleX(1.06) }
  36%      { transform: translateY(-4px) scaleY(1.02) scaleX(.98) }
  48%      { transform: translateY(0)  scaleY(1)    scaleX(1) }
}

/* ── Scan beam pulse ── */
.sc-beam {
  animation: sc-beam-pulse 1.8s ease-in-out infinite;
  transform-origin: left center;
}
@keyframes sc-beam-pulse {
  0%,100% { opacity: 0; transform: scaleX(0.1) }
  40%,60% { opacity: 1; transform: scaleX(1) }
}

/* ── Progress dots ── */
.sc-dots { display: flex; gap: 6px; }
.sc-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--brand);
  animation: sc-dot-wave 1.2s ease-in-out infinite;
}
.sc-dot:nth-child(1) { animation-delay: 0s }
.sc-dot:nth-child(2) { animation-delay: .16s }
.sc-dot:nth-child(3) { animation-delay: .32s }
@keyframes sc-dot-wave {
  0%,80%,100% { transform: scaleY(1);   opacity: .4 }
  40%         { transform: scaleY(1.7); opacity: 1  }
}

/* ── Label ── */
.sc-loader-label {
  font-size: var(--fsm); font-weight: 600;
  color: var(--text-3); letter-spacing: .2px;
  animation: sc-label-fade 1.8s ease-in-out infinite;
}
@keyframes sc-label-fade {
  0%,100% { opacity: .55 }
  50%     { opacity: 1 }
}

/* ── Skeleton shimmer (for table rows while loading) ── */
.sc-skel {
  background: linear-gradient(90deg,
    var(--bd) 25%, rg
/* ── Shiprocket / Integrations UI ─────────────────────────────────────────── */
.int-conn-row{display:flex;align-items:center;gap:12px;padding:10px 0}
.int-conn-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.int-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:600;line-height:1.6}
.int-badge-ok{background:var(--ok-lt,#dcfce7);color:var(--ok,#16a34a)}
.int-badge-grey{background:var(--surface);color:var(--text-3);border:1px solid var(--bd)}
.sr-step{display:flex;align-items:flex-start;gap:12px;font-size:13px;color:var(--text-2)}
.sr-step-num{width:24px;height:24px;border-radius:50%;background:var(--brand);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.sr-rate-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.sr-rate-table th{text-align:left;padding:7px 10px;font-size:11.5px;color:var(--text-3);font-weight:600;border-bottom:1px solid var(--bd);background:var(--surface)}
.sr-rate-table td{padding:8px 10px;border-bottom:1px solid var(--bd);color:var(--text-2);vertical-align:middle}
.sr-rate-table tr:last-child td{border-bottom:0}
.sr-rate-table tr:hover td{background:var(--surface)}

/* ── Print Style Selector Buttons ─────────────────────────────────────────── */
.print-style-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:10px 6px;border:1.5px solid var(--bd);border-radius:var(--r3);
  background:var(--card);cursor:pointer;transition:border-color .15s,background .15s;
  color:var(--text-2);font-family:inherit;
}
.print-style-btn:hover{border-color:var(--brand);background:rgba(220,38,38,.04)}
.print-style-btn.active{border-color:var(--brand);background:rgba(220,38,38,.07);color:var(--brand)}
.print-style-btn.active div{color:var(--brand)}

/* ═══════════════════════════════════════════════════════════════
   MODULE MANAGER CARDS
   ═══════════════════════════════════════════════════════════════ */
.modules-list{display:flex;flex-direction:column;gap:10px;padding:4px 0}
.module-card{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1.5px solid var(--bd);border-radius:10px;background:var(--surface);transition:border-color .15s,box-shadow .15s}
.module-card.module-on{border-color:var(--bd);background:var(--surface)}
.module-card.module-off{opacity:.65;background:var(--bg)}
.module-card:hover{border-color:var(--brand-lt,#fca5a5);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.module-card-icon{font-size:22px;width:36px;text-align:center;flex-shrink:0}
.module-card-body{flex:1;min-width:0}
.module-card-name{font-weight:600;font-size:14px;color:var(--text);line-height:1.3}
.module-card-desc{font-size:12px;color:var(--text-3);margin-top:2px}
.module-core-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.04em;padding:1px 6px;border-radius:20px;background:var(--info-lt,#eff6ff);color:var(--info,#3b82f6);vertical-align:middle;margin-left:6px;text-transform:uppercase}
/* Toggle switch */
.module-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;flex-shrink:0}
.module-toggle-disabled{cursor:not-allowed;opacity:.5}
.module-toggle input{position:absolute;opacity:0;width:0;height:0}
.module-toggle-track{width:42px;height:24px;border-radius:12px;background:var(--bd);transition:background .2s;position:relative;border:1.5px solid transparent}
.module-toggle input:checked ~ .module-toggle-track{background:var(--ok,#16a34a)}
.module-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform .2s}
.module-toggle input:checked ~ .module-toggle-track .module-toggle-thumb{transform:translateX(18px)}

/* ═══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — BASE LAYOUT
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* App shell */
  .app-shell{flex-direction:column}
  .sidebar{display:none} /* replaced by bottom nav on mobile */
  .main-content{padding:12px 10px 80px;overflow-x:hidden}
  .topbar{padding:0 12px;height:52px}
  .topbar-title{font-size:14px}

  /* Booking form */
  .bkf-row.c2,.bkf-row.c3,.bkf-parties{grid-template-columns:1fr!important;display:flex!important;flex-direction:column}
  .bkf-party{border-right:none!important;border-bottom:1px solid var(--bd);padding-bottom:14px}
  .bkf-party:last-child{border-bottom:none;padding-bottom:0}
  .bkf-footer-actions{flex-direction:column;gap:10px}
  .bkf-footer-actions .btn{width:100%;justify-content:center}
  #btn-book-final{font-size:15px!important;padding:14px!important}

  /* Section cards */
  .section-card-hdr{flex-wrap:wrap;gap:8px}
  .section-card-hdr > [style*="margin-left:auto"]{margin-left:0!important}

  /* Hub grid */
  .hub-grid{grid-template-columns:repeat(3,1fr)!important}

  /* Tables */
  .bk-table{font-size:12px}
  .bk-table th,.bk-table td{padding:8px 6px}
  .bk-actions-col{display:none}

  /* Modals */
  .modal-box{margin:12px;max-height:calc(100vh - 24px);max-width:calc(100vw - 24px)!important}

  /* AWB banner */
  .awb-banner{flex-wrap:wrap;gap:10px}
  .awb-banner-actions{flex-wrap:wrap;gap:6px}
  .awb-banner-actions .btn{flex:1;min-width:100px}

  /* Topbar profile */
  .topbar-user-name{display:none}

  /* Stats row */
  .stats-row,[class*="kcard-row"]{grid-template-columns:repeat(2,1fr)!important}

  /* CRM sub-tabs */
  .crm-subtabs{overflow-x:auto;white-space:nowrap;padding-bottom:4px}
  .crm-subtab{flex-shrink:0}

  /* Ledger cards */
  .ledger-krow{grid-template-columns:repeat(2,1fr)!important}

  /* Module cards */
  .module-card{padding:12px 14px;gap:10px}
  .module-card-icon{font-size:18px;width:28px}

  /* Track panel */
  .sc-hero-band{padding:16px 14px 14px;margin:-12px -10px 14px -10px;}
  .sc-hero-band-inner{flex-direction:column;align-items:flex-start;gap:12px;}
  .sc-stats-row{width:100%;justify-content:space-between;}
  .sc-stat-chip{flex:1;padding:6px 10px;min-width:0;}
  .sc-stat-val{font-size:16px;}
  .sc-search-row{padding:12px 14px;}
  .sc-filter-row{padding:10px 14px;gap:10px;}
  .sc-filter-group{min-width:calc(50% - 6px);}
  .sc-filter-sel{width:100%;}
  .sc-clear-btn{margin-left:0;width:100%;}
}

/* Mobile bottom navigation bar */
@media (max-width: 768px) {
  .mobile-nav{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;
    height:60px;
    background:var(--surface);
    border-top:1.5px solid var(--bd);
    z-index:200;
    justify-content:space-around;
    align-items:stretch;
    box-shadow:0 -2px 12px rgba(0,0,0,.08);
  }
  .mobile-nav-item{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    flex:1;gap:3px;border:none;background:none;cursor:pointer;
    font-size:11px;color:var(--text-3);padding:4px 2px;
    transition:color .15s;
  }
  .mobile-nav-item.active,.mobile-nav-item:hover{color:var(--brand)}
  .mobile-nav-item svg,.mobile-nav-icon{font-size:20px}
}
@media (min-width: 769px) {
  .mobile-nav{display:none}
}

/* Small phones */
@media (max-width: 480px) {
  .hub-grid{grid-template-columns:repeat(2,1fr)!important}
  .bkf-row.c3{grid-template-columns:1fr!important}
  .awb-banner-number{font-size:22px!important}
  .stats-row{grid-template-columns:1fr!important}
}

/* ═══════════════════════════════════════════════════════════════
   INTEGRATIONS PAGE — COMPLETE REDESIGN
   ═══════════════════════════════════════════════════════════════ */

/* Tab bar */
.int-tab-bar{display:flex;gap:4px;padding:4px;background:var(--bg);border-radius:12px;margin-bottom:16px;overflow-x:auto;flex-wrap:nowrap}
.int-tab{display:flex;align-items:center;gap:6px;padding:9px 16px;border-radius:9px;border:none;background:transparent;color:var(--text-3);font-size:13.5px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:inherit}
.int-tab:hover{background:var(--surface);color:var(--text)}
.int-tab.active{background:var(--surface);color:var(--brand);font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.int-tab-icon{font-size:15px}

/* Panel wrapper */
.int-panel{display:flex;flex-direction:column;gap:0}

/* Hero card */
.int-hero-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);border-radius:14px;color:#fff;flex-wrap:wrap}
.int-hero-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap;flex:1}
.int-hero-logo{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.int-hero-name{font-size:20px;font-weight:800;letter-spacing:-.02em;color:#fff}
.int-hero-sub{font-size:12px;color:rgba(255,255,255,.65);margin-top:2px}
.int-hero-right{display:flex;gap:8px;flex-shrink:0}

/* Status pills */
.int-status-pill{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.02em}
.int-status-grey{background:rgba(255,255,255,.15);color:rgba(255,255,255,.8)}
.int-status-ok{background:rgba(22,163,74,.25);color:#4ade80;border:1px solid rgba(22,163,74,.4)}
.int-status-text{font-size:12.5px;color:var(--text-3)}

/* Generic integration card */
.int-card{background:var(--surface);border:1.5px solid var(--bd);border-radius:12px;overflow:hidden;margin-top:12px}
.int-card-hdr{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--bd)}
.int-card-icon{font-size:18px;flex-shrink:0}
.int-card-title{font-weight:700;font-size:15px;color:var(--text)}
.int-card-hint{margin:0;padding:12px 20px 4px;font-size:13px;color:var(--text-3);line-height:1.5}
.int-card-ok{border-color:var(--ok,#16a34a)}
.int-card-info{border-color:var(--info-lt,#bfdbfe)}

/* Connected state */
.int-conn-row{display:flex;align-items:center;gap:14px;padding:16px 20px}
.int-conn-check{width:34px;height:34px;border-radius:50%;background:var(--ok-lt,#dcfce7);color:var(--ok,#16a34a);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;flex-shrink:0}
.int-conn-details{flex:1}
.int-conn-title{font-weight:700;font-size:14px;color:var(--text)}
.int-conn-email{font-size:12px;color:var(--text-3);margin-top:2px}
.int-disconnect-btn{margin-left:auto;color:var(--danger)!important}

/* Form grid */
.int-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px 20px}
.int-fg{display:flex;flex-direction:column;gap:5px}
.int-lbl{font-size:12.5px;font-weight:600;color:var(--text-2)}
.int-form-actions{display:flex;align-items:center;gap:12px;padding:12px 20px 18px}

/* Rate checker form */
.int-rate-form{display:flex;align-items:flex-end;gap:10px;padding:12px 20px;flex-wrap:wrap}
.int-rate-form .int-fg{flex:1;min-width:120px}
.int-fg-check{flex:0;min-width:auto;justify-content:flex-end;padding-bottom:8px}
.int-check-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13.5px;font-weight:600;color:var(--text)}
.int-fg-btn{flex:0;min-width:auto;padding-bottom:0}

/* How it works steps */
.int-steps{display:flex;flex-direction:column;gap:12px;padding:12px 20px 18px}
.int-step{display:flex;align-items:flex-start;gap:12px;font-size:13.5px;color:var(--text-2);line-height:1.5}
.int-step-num{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* Coming soon badge */
.int-badge-coming{margin-left:auto;padding:3px 10px;border-radius:20px;background:var(--warn-lt,#fef3c7);color:var(--warn,#d97706);font-size:11px;font-weight:700;letter-spacing:.05em}

/* Rate results table */
.sr-rate-table{width:100%;border-collapse:collapse;font-size:13px}
.sr-rate-table th{background:var(--bg);padding:9px 12px;text-align:left;font-size:11.5px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1.5px solid var(--bd)}
.sr-rate-table td{padding:10px 12px;border-bottom:1px solid var(--bd);vertical-align:middle}
.sr-rate-table tr:last-child td{border-bottom:none}
.sr-rate-table tr:hover td{background:var(--bg)}
.sr-rate-courier{font-weight:600;color:var(--text)}
.sr-rate-price{font-weight:800;color:var(--brand);font-size:15px}
.sr-rate-eta{font-size:12px;color:var(--text-3)}

/* Mobile adjustments for integrations */
@media (max-width:768px) {
  .int-form-grid{grid-template-columns:1fr}
  .int-rate-form{flex-direction:column}
  .int-rate-form .int-fg{min-width:100%;flex:none}
  .int-hero-card{padding:16px}
  .int-tab-bar{gap:2px;padding:3px}
  .int-tab{padding:8px 12px;font-size:12.5px}
}
