:root{
  --ft-bg: #f2f5f9;
  --ft-surface: #ffffff;
  --ft-surface-muted: #f7f9fc;
  --ft-border: #dfe6ef;
  --ft-text: #0f172a;
  --ft-muted: #5b6b7f;
  --ft-primary: #1f7f79;
  --ft-primary-strong: #155f5a;
  --ft-accent: #f59e0b;
  --ft-danger: #ef4444;
  --ft-success: #16a34a;
  --ft-warning: #f59e0b;
  --ft-shadow-strength: 0.08;
  --ft-shadow: 0 16px 40px rgba(15, 23, 42, var(--ft-shadow-strength));
  --ft-radius-card: 18px;
  --ft-radius-input: 14px;
  --ft-card-padding: 18px;
  --ft-table-row-gap: 10px;
  --ft-table-cell-padding-y: 12px;
  --ft-table-cell-padding-x: 16px;
  --ft-topbar-height: 62px;
  --ft-topbar-bg: rgba(255,255,255,0.85);
  --ft-topbar-text: #0f172a;
  --ft-sidebar-bg: rgba(15,23,42,0.95);
  --ft-sidebar-text: #eef2f7;
  --ft-sidebar-active: #1f7f79;
  --ft-bg-gradient-a: rgba(31,127,121,.35);
  --ft-bg-gradient-b: rgba(245,158,11,.25);
  --ft-font-family: "DM Sans", sans-serif;
  --ft-font-scale: 1;
  --ft-btn-scale: 1;

  /* Premium SaaS Design System (extended, non-breaking) */
  /* Light mode tokens */
  --premium-bg-main: #FBF9F6;
  --premium-bg-card: #FFFFFF;
  --premium-text-primary: #1A1A1A;
  --premium-text-secondary: #666666;
  --premium-accent-glow: rgba(139, 92, 246, 0.05);

  /* Shared assets */
  --premium-gradient: linear-gradient(135deg, #C4B5FD 0%, #DDD6FE 52%, #7DD3FC 100%);
  --premium-border-opacity: 0.08;
  --premium-standard-border: 1px solid rgba(26, 26, 26, var(--premium-border-opacity));
}

/* Dark mode tokens */
[data-theme="dark"],
.theme-dark,
.dark{
  --premium-bg-main: #0F172A;
  --premium-bg-card: #1E293B;
  --premium-text-primary: #F8FAFC;
  --premium-text-secondary: #CBD5E1;
  --premium-accent-glow: rgba(139, 92, 246, 0.2);
  --premium-border-opacity: 0.1;
  --premium-standard-border: 1px solid rgba(248, 250, 252, var(--premium-border-opacity));
}

/* Premium utilities */
.premium-gradient{
  background-image: var(--premium-gradient);
}

.standard-border{
  border: var(--premium-standard-border);
}

*{box-sizing:border-box;}
body{
  font-family: var(--ft-font-family);
  font-size: calc(14px * var(--ft-font-scale));
  background: var(--ft-bg);
  color: var(--ft-text);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ft-app{
  position: relative;
  min-height: 100vh;
  overflow-x: hidden;
}
.ft-app::before,
.ft-app::after{
  content: "";
  position: fixed;
  inset: auto;
  width: 540px;
  height: 540px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  opacity: .45;
}
.ft-app::before{
  top: -160px;
  right: -180px;
  background: radial-gradient(circle at 30% 30%, var(--ft-bg-gradient-a), rgba(31,127,121,0));
}
.ft-app::after{
  bottom: -200px;
  left: -220px;
  background: radial-gradient(circle at 30% 30%, var(--ft-bg-gradient-b), rgba(245,158,11,0));
}

.ft-topbar{
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(16px);
  background: var(--ft-topbar-bg);
  border-bottom: 1px solid color-mix(in srgb, var(--ft-border) 70%, transparent);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: var(--ft-topbar-height);
}
.ft-topbar .brand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--ft-font-family);
  font-weight: 700;
  color: var(--ft-topbar-text);
  text-decoration: none;
  letter-spacing: .01em;
}
.ft-topbar .brand img{
  width: 34px;
  height: 34px;
  object-fit: contain;
}
.ft-topbar-actions{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.ft-layout{
  display: flex;
  min-height: calc(100vh - var(--ft-topbar-height));
  position: relative;
}

.ft-sidebar{
  width: 260px;
  padding: 18px 14px;
  background: var(--ft-sidebar-bg);
  color: var(--ft-sidebar-text);
  border-right: 1px solid color-mix(in srgb, var(--ft-border) 55%, transparent);
}
.ft-sidebar .menu-title{
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: color-mix(in srgb, var(--ft-sidebar-text) 70%, transparent);
  padding: 8px 12px;
}
.ft-sidebar .nav-link{
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--ft-sidebar-text);
  padding: 10px 12px;
  border-radius: var(--ft-radius-input);
  margin: 4px 0;
  text-decoration: none;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.ft-sidebar .nav-link:hover{
  background: color-mix(in srgb, var(--ft-primary) 20%, transparent);
  color: #fff;
  transform: none;
}
.ft-sidebar .nav-link.active{
  background: color-mix(in srgb, var(--ft-sidebar-active) 30%, transparent);
  color: #fff;
  position: relative;
}
.ft-sidebar .nav-link.active::before{
  content:"";
  position:absolute;
  left:-12px;
  top:10px;
  bottom:10px;
  width:4px;
  background: var(--ft-accent);
  border-radius: 0;
}

.ft-content{
  flex: 1;
  padding: 22px 28px 40px;
}

.card,
.ft-card{
  background: var(--ft-surface);
  border: 1px solid color-mix(in srgb, var(--ft-border) 70%, transparent);
  border-radius: var(--ft-radius-card);
  box-shadow: var(--ft-shadow);
  padding: var(--ft-card-padding);
  margin-bottom: 16px;
  animation: ft-rise .6s ease both;
}
.card-header{
  background: transparent;
  border-bottom: 1px solid color-mix(in srgb, var(--ft-border) 70%, transparent);
  font-weight: 600;
  padding-bottom: 10px;
}
.card-body{padding: 14px 0 0;}

.table{
  border-collapse: separate;
  border-spacing: 0 var(--ft-table-row-gap);
}
.table thead th{
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ft-muted);
  border: 0;
}
.table th,
.table td{
  padding: var(--ft-table-cell-padding-y) var(--ft-table-cell-padding-x);
}
.table tbody tr{
  background: var(--ft-surface);
  border: 1px solid var(--ft-border);
  box-shadow: none;
  transition: none;
}
.table tbody tr:hover{
  transform: none;
  box-shadow: none;
}

/* Normalize tables and headers across views */
.ft-content table{
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}
.ft-content table thead th{
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ft-muted);
  border: 1px solid var(--ft-border);
  background: var(--ft-surface-muted);
}
.ft-content table th,
.ft-content table td{
  padding: var(--ft-table-cell-padding-y) var(--ft-table-cell-padding-x);
  border: 1px solid var(--ft-border);
}
.ft-content table tbody tr{
  background: var(--ft-surface);
  border: 1px solid var(--ft-border);
  box-shadow: none;
  transition: none;
}
.ft-content table tbody tr:hover{
  transform: none;
  box-shadow: none;
}
.ft-content .card > h2,
.ft-content .card > h3{
  margin: 0;
  font-weight: 700;
}
.ft-content .card > h2 + div,
.ft-content .card > h3 + div{
  margin-top: 6px;
  color: var(--ft-muted);
  font-size: 13px;
}
.table tbody td{
  border: 1px solid var(--ft-border);
  padding: var(--ft-table-cell-padding-y) var(--ft-table-cell-padding-x);
}

.badge,
.pill,
.status-pill{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--ft-radius-input);
  font-size: 12px;
  font-weight: 600;
  background: color-mix(in srgb, var(--ft-primary) 15%, transparent);
  color: var(--ft-primary);
  border: 1px solid color-mix(in srgb, var(--ft-primary) 30%, transparent);
}
.status-success{ background: rgba(25,135,84,.12); color: var(--ft-success); border-color: rgba(25,135,84,.35); }
.status-warning{ background: rgba(255,193,7,.18); color: #856404; border-color: rgba(255,193,7,.45); }
.status-danger{ background: rgba(220,53,69,.12); color: var(--ft-danger); border-color: rgba(220,53,69,.35); }

.btn{
  border-radius: calc(4px * var(--ft-btn-scale));
  font-weight: 600;
  padding: calc(10px * var(--ft-btn-scale)) calc(16px * var(--ft-btn-scale));
  min-height: calc(40px * var(--ft-btn-scale));
  height: calc(40px * var(--ft-btn-scale));
  font-size: calc(14px * var(--ft-btn-scale));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.btn:not(.btn-sm):not(.btn-lg){
  height: calc(40px * var(--ft-btn-scale));
}
.btn-primary{
  background: var(--ft-surface);
  border: 1px solid var(--ft-border);
  color: var(--ft-text);
}
.btn-primary:hover{ background: var(--ft-surface-muted); transform: none; box-shadow: none; }
.btn-outline-secondary,
.btn-outline-dark,
.btn-outline-primary,
.btn-outline-light{
  border: 1px solid var(--ft-border);
  color: var(--ft-text);
  background: var(--ft-surface);
}
.btn-secondary{
  background: var(--ft-surface);
  color: var(--ft-text);
  border: 1px solid var(--ft-border);
}
.btn-secondary:hover{
  background: var(--ft-surface-muted);
  border-color: var(--ft-border);
}
.btn-danger{ background: var(--ft-surface); border: 1px solid var(--ft-border); color: var(--ft-text); }
.btn-danger:hover{ background: var(--ft-surface-muted); border-color: var(--ft-border); }
.btn-success{ background: var(--ft-surface); border: 1px solid var(--ft-border); color: var(--ft-text); }
.btn-success:hover{ background: var(--ft-surface-muted); border-color: var(--ft-border); }
.btn-warning{ background: var(--ft-surface); border: 1px solid var(--ft-border); color: var(--ft-text); }
.btn-warning:hover{ background: var(--ft-surface-muted); border-color: var(--ft-border); }
.btn-sm{
  padding: calc(6px * var(--ft-btn-scale)) calc(12px * var(--ft-btn-scale));
  font-size: calc(12px * var(--ft-btn-scale));
  min-height: calc(32px * var(--ft-btn-scale));
}
.btn-lg{ min-height: calc(46px * var(--ft-btn-scale)); }

.form-control,
.form-select,
textarea{
  border-radius: var(--ft-radius-input);
  border: 1px solid var(--ft-border);
  background: var(--ft-surface) !important;
  font-size: 14px;
  padding: 10px 12px;
}
.form-control:not(textarea),
.form-select{
  min-height: 40px;
  height: 40px;
  padding: 8px 12px;
}
.form-control:focus,
.form-select:focus,
textarea:focus{
  border-color: var(--ft-primary);
  box-shadow: none;
}
input::placeholder, textarea::placeholder{ color: #94a3b8; }
label{ font-size: 12px; color: var(--ft-muted); margin-bottom: 6px; }

.ft-lang-toggle .btn{ border-radius: var(--ft-radius-input); min-width: 44px; }

.pagination{ gap: 6px; }
.page-link{
  border-radius: var(--ft-radius-input);
  border: 1px solid color-mix(in srgb, var(--ft-border) 80%, transparent);
  color: var(--ft-text);
  background: var(--ft-surface);
  padding: var(--ft-table-cell-padding-y) var(--ft-table-cell-padding-x);
}
.page-item.active .page-link{
  background: var(--ft-primary);
  border-color: var(--ft-primary);
  color: #fff;
}
.page-item.disabled .page-link{
  color: var(--ft-muted);
  background: var(--ft-surface-muted);
}

.grid.single-col{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ft-driver .ft-topbar{
  background: rgba(15,23,42,0.95);
  color: #fff;
  border-bottom: 1px solid rgba(15,23,42,0.3);
}
.ft-driver .ft-topbar .brand{ color: #fff; }
.ft-driver main{ padding: 16px; }

.status-badge{
  display:inline-block;
  padding:6px 12px;
  border-radius:2px;
  font-size:14px;
  font-weight:700;
  background: var(--ft-surface-muted);
  border: 1px solid var(--ft-border);
}
.status-new{color:#856404;}
.status-confirmed{color:#0d6efd;}
.status-assigned{color:#0d6efd;}
.status-en-route{color:#6f42c1;}
.status-arrived{color:#198754;}
.status-picked-up{color:#198754;}
.status-completed{color:#198754;}
.status-cancelled{color:#dc3545;}
.status-no-show{color:#dc3545;}

@keyframes ft-rise{
  from{opacity:0;transform:translateY(12px);}
  to{opacity:1;transform:translateY(0);}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;}
}

@media (max-width: 1024px){
  .ft-sidebar{ width: 220px; }
}
@media (max-width: 900px){
  .ft-sidebar{ display: none; }
  .ft-content{ padding: 16px; }
  .ft-topbar{ position: sticky; }
}

/* Classic overrides: neutral buttons and status backgrounds */
.ft-content .btn,
.ft-content .btn-primary,
.ft-content .btn-secondary,
.ft-content .btn-success,
.ft-content .btn-warning,
.ft-content .btn-danger,
.ft-content .btn-outline-secondary,
.ft-content .btn-outline-dark,
.ft-content .btn-outline-primary,
.ft-content .btn-outline-light{
  background: var(--ft-surface) !important;
  color: var(--ft-text) !important;
  border: 1px solid var(--ft-border) !important;
  box-shadow: none !important;
}
.ft-content .btn:hover,
.ft-content .btn:focus,
.ft-content .btn:active{
  background: var(--ft-surface-muted) !important;
  border-color: var(--ft-border) !important;
  box-shadow: none !important;
}

/* Force plain-text statuses (no background, no border) */
.ft-content .badge,
.ft-content .pill,
.ft-content .status-pill,
.ft-content .status-badge,
.ft-content .badge-primary,
.ft-content .badge-secondary,
.ft-content .badge-success,
.ft-content .badge-danger,
.ft-content .badge-warning,
.ft-content .badge-info,
.ft-content .badge-light,
.ft-content .badge-dark,
.ft-content .status,
.ft-content .payment-status,
.ft-content .status-label,
.ft-content .status-text,
.ft-content .status-chip,
.ft-content .payment-chip,
.ft-content [class*="status"],
.ft-content [class*="payment"],
.ft-content td [class*="status"],
.ft-content td [class*="payment"]{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

/* Payment column statuses: text-only */
.ft-content td .payment-status,
.ft-content td .status-paid,
.ft-content td .status-unpaid,
.ft-content td .status-payment,
.ft-content td .status-oplacone,
.ft-content td .status-nieoplacone,
.ft-content td .paid,
.ft-content td .unpaid{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

/* "Nowe" status color */
.ft-content .status-new,
.ft-content .status-now,
.ft-content .status-nowe{
  color: #ffc107 !important;
}
.ft-content .status-new{ color:#856404 !important; }
.ft-content .status-confirmed{ color:#0d6efd !important; }
.ft-content .status-assigned{ color:#0d6efd !important; }
.ft-content .status-en-route{ color:#6f42c1 !important; }
.ft-content .status-arrived{ color:#198754 !important; }
.ft-content .status-picked-up{ color:#198754 !important; }
.ft-content .status-completed{ color:#198754 !important; }
.ft-content .status-cancelled{ color:#dc3545 !important; }
.ft-content .status-no-show{ color:#dc3545 !important; }
.form-check-input{
  border-radius: 2px;
  border: 1px solid var(--ft-border);
}
.form-check-input:checked{
  background-color: var(--ft-primary);
  border-color: var(--ft-primary);
}

a{
  color: var(--ft-primary);
  text-decoration: none;
}
a:hover{
  text-decoration: underline;
}

/* UI v2 visual unification across all tabs (style-only, no behavior changes) */
.ft-content{
  color: #1f2937;
}
.ft-content h1,
.ft-content h2,
.ft-content h3,
.ft-content h4,
.ft-content h5{
  color: #1f2937;
  font-weight: 700;
  letter-spacing: .01em;
}
.ft-content .card,
.ft-content .ft-card{
  border-radius: 12px;
  border: 1px solid #d6e1e7;
  background: #f8fbfd;
  box-shadow: none;
}
.ft-content .card .card,
.ft-content .ft-card .card{
  background: #ffffff;
  border-color: #dbe5eb;
}
.ft-content .card-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-top: 2px;
  padding-bottom: 12px;
  border-bottom: 1px solid #dbe5eb;
  color: #21313b;
}
.ft-content .card-body{
  padding-top: 12px;
}

/* Filters and toolbars */
.ft-content .row.g-2,
.ft-content .row.g-3,
.ft-content .row.g-4{
  --bs-gutter-y: .65rem;
}
.ft-content .form-label{
  font-size: 12px;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .03em;
}

/* Table look aligned to UI v2 */
.ft-content table{
  border-radius: 10px;
  overflow: hidden;
}
.ft-content table thead th{
  position: sticky;
  top: 0;
  z-index: 1;
  background: #eef4f8;
  color: #415260;
  border-color: #dbe5eb;
}
.ft-content table tbody td{
  background: #ffffff;
}
.ft-content table tbody tr:hover td{
  background: #f9fcff;
}

/* Badges / statuses */
.ft-content .badge,
.ft-content .status-pill,
.ft-content .pill{
  border-radius: 999px !important;
  padding: 3px 9px !important;
  font-size: 12px;
  font-weight: 700;
  border: 0 !important;
}

/* Alerts */
.ft-content .alert{
  border-radius: 10px;
  border: 1px solid #dbe5eb;
  font-weight: 600;
}

/* Buttons */
.ft-content .btn{
  border-radius: 8px !important;
  font-weight: 700;
  min-height: 38px;
  padding: 8px 14px;
}

/* SyncroLab Premium Light refresh */
:root{
  --ft-bg: #fbf9f6;
  --ft-surface: #ffffff;
  --ft-surface-muted: #f7f5ff;
  --ft-border: #e9e6e0;
  --ft-text: #1a1a1a;
  --ft-muted: #666666;
  --ft-primary: #8b8ff9;
  --ft-primary-strong: #7175ea;
  --ft-shadow-strength: 0.055;
  --ft-shadow: 0 18px 42px rgba(31, 35, 46, var(--ft-shadow-strength));
  --ft-radius-card: 20px;
  --ft-radius-input: 14px;
  --ft-card-padding: 20px;
  --ft-font-family: "Inter", "Geist", "DM Sans", "Segoe UI", sans-serif;
  --ft-topbar-bg: rgba(255,255,255,0.88);
  --ft-topbar-text: #232323;
  --ft-sidebar-bg: rgba(255,255,255,0.8);
  --ft-sidebar-text: #2f2f34;
}

body{
  background: #fbf9f6;
  color: #1a1a1a;
}

.ft-app::before{
  background: radial-gradient(circle at 30% 30%, rgba(206,188,255,.38), rgba(206,188,255,0));
}
.ft-app::after{
  background: radial-gradient(circle at 30% 30%, rgba(174,225,255,.34), rgba(174,225,255,0));
}

.ft-topbar{
  background: var(--ft-topbar-bg);
  border-bottom: 1px solid rgba(223, 218, 209, 0.95);
  backdrop-filter: blur(14px);
}
.ft-topbar-actions{
  color: #2f2f34;
}

.ft-sidebar{
  background: var(--ft-sidebar-bg);
  border-right: 1px solid rgba(225, 221, 215, 0.92);
  backdrop-filter: blur(18px);
  box-shadow: 8px 0 30px rgba(45, 33, 84, 0.05);
}
.ft-sidebar .menu-title{
  color: #8d8798;
}
.ft-sidebar .nav-link{
  color: #2f2f34;
  position: relative;
  gap: 12px;
  font-weight: 600;
}
.ft-sidebar .nav-link::before{
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 999px;
  border: 1.5px solid #a5a4ae;
  flex: 0 0 15px;
  opacity: .9;
}
.ft-sidebar .nav-link:hover{
  color: #1f1f24;
  background: linear-gradient(90deg, rgba(229,225,255,.58), rgba(229,225,255,0));
}
.ft-sidebar .nav-link.active{
  color: #1f1f24;
  background: linear-gradient(90deg, rgba(214,202,255,.78), rgba(253,236,249,.42) 58%, rgba(255,255,255,0));
}
.ft-sidebar .nav-link.active::before{
  left: auto;
  top: auto;
  bottom: auto;
  width: 15px;
  background: linear-gradient(145deg, #9c8cff, #79c7ff);
  border: 0;
  border-radius: 999px;
}

.ft-content{
  padding: 24px 30px 42px;
}

.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  background: #fff !important;
  border: 1px solid #ebe7e0 !important;
  border-radius: 20px !important;
  box-shadow: 0 18px 42px rgba(39, 27, 67, 0.06) !important;
}

.card-header,
.ft-content .card-header{
  border-bottom: 1px solid #f0ece5 !important;
  color: #1f1f25 !important;
}

.ft-content table thead th{
  background: #faf8f4;
  color: #666666;
  border-color: #efebe4;
}
.ft-content table th,
.ft-content table td{
  border-color: #efebe4;
}
.ft-content table tbody tr:hover td{
  background: #f9f8ff;
}

.form-control,
.form-select,
textarea{
  background: #fff !important;
  border: 1px solid #e7e3dd;
  color: #1f1f24;
}
.form-control:focus,
.form-select:focus,
textarea:focus{
  border-color: #c6bbff;
  box-shadow: 0 0 0 3px rgba(198, 187, 255, 0.2);
}

.btn,
.ft-content .btn{
  border-radius: 12px !important;
  border: 1px solid #e6e0f4 !important;
}
.btn-primary,
.ft-content .btn-primary{
  background: #ffffff !important;
  color: #1f1f25 !important;
  border-color: #dfd6f8 !important;
  box-shadow: 0 8px 18px rgba(186, 171, 255, 0.18) !important;
}
.btn-primary:hover,
.ft-content .btn-primary:hover{
  background: #fff !important;
  border-color: #cbc0ef !important;
  box-shadow: 0 10px 22px rgba(181, 163, 255, 0.24) !important;
}
.btn-outline-primary,
.btn-outline-secondary,
.ft-content .btn-outline-primary,
.ft-content .btn-outline-secondary{
  background: #fff !important;
  color: #2f2f34 !important;
  border-color: #e7e3dd !important;
}
.btn-outline-primary:hover,
.btn-outline-secondary:hover,
.ft-content .btn-outline-primary:hover,
.ft-content .btn-outline-secondary:hover{
  background: #faf8ff !important;
}

.text-muted,
.ft-content .text-muted{
  color: #666666 !important;
}

.ui2-pill.st-new{ background:#fff4e5; color:#a36518; }
.ui2-pill.st-confirmed{ background:#eaf2ff; color:#356bb3; }
.ui2-pill.st-route{ background:#f1ecff; color:#6351bb; }
.ui2-pill.st-done{ background:#eafaf1; color:#2a8a5d; }
.ui2-pill.st-cancelled{ background:#fff1f1; color:#b75757; }

/* Dashboard premium sections */
.premium-dash{
  display: grid;
  gap: 16px;
}
.premium-head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}
.premium-title{
  margin: 0;
  font-size: 30px;
  line-height: 1.15;
  letter-spacing: -.02em;
}
.premium-sub{
  margin: 6px 0 0;
  color: #666;
}
.premium-kpis{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.premium-kpi{
  background: #fff;
  border: 1px solid #eee9e2;
  border-radius: 16px;
  padding: 14px 16px;
}
.premium-kpi .label{
  color: #666;
  font-size: 12px;
}
.premium-kpi .value{
  margin-top: 6px;
  color: #1a1a1a;
  font-size: 28px;
  font-weight: 700;
}
.premium-kpi .value.value-compact{
  font-size: 18px;
}
.premium-grid{
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
}
.premium-plot{
  height: 215px;
  width: 100%;
}
.premium-bars{
  display: grid;
  gap: 10px;
  margin-top: 8px;
}
.premium-bar-item{
  display: grid;
  grid-template-columns: 122px minmax(0, 1fr) 36px;
  align-items: center;
  gap: 10px;
  color: #555;
  font-size: 13px;
}
.premium-bar-track{
  height: 10px;
  border-radius: 999px;
  background: #f0ece8;
  overflow: hidden;
}
.premium-bar-fill{
  height: 100%;
  border-radius: 999px;
}
.premium-bar-fill.premium-bar-dispatch{ background:#6EA8FF; }
.premium-bar-fill.premium-bar-drivers{ background:#A487FF; }
.premium-bar-fill.premium-bar-fleet{ background:#6FD6A6; }
.premium-lists{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.premium-list{
  display: grid;
  gap: 10px;
}
.premium-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px;
  border-radius: 12px;
  background: #fcfbf8;
  border: 1px solid #f0ece5;
}
.premium-row-left{
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.premium-avatar{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, #ece6ff, #def3ff);
  color: #2a2f45;
  font-size: 12px;
  font-weight: 700;
}
.premium-meta{
  min-width: 0;
}
.premium-meta b{
  display: block;
  color: #1e1f28;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.premium-meta span{
  display: block;
  color: #666;
  font-size: 12px;
}
.premium-progress{
  width: 110px;
  height: 8px;
  border-radius: 999px;
  background: #ece9e2;
  overflow: hidden;
}
.premium-progress > span{
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #86b8ff, #8b8ff9);
}

@media (max-width: 1200px){
  .premium-kpis{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .premium-grid,
  .premium-lists{ grid-template-columns: 1fr; }
}
.ft-content .btn-sm{
  min-height: 32px;
  padding: 6px 10px;
}

/* Modal styling parity with UI v2 */
.modal-content{
  border-radius: 14px;
  border: 1px solid #d6e1e7;
  box-shadow: 0 10px 30px rgba(15,23,42,.12);
}
.modal-header{
  border-bottom: 1px solid #e2e8f0;
}
.modal-footer{
  border-top: 1px solid #e2e8f0;
}

/* Step 2: Premium SaaS skeleton (layout/navigation only) */
.ft-app,
body{
  background: var(--premium-bg-main);
  color: var(--premium-text-primary);
}

.ft-layout{
  background: transparent;
}

.ft-sidebar{
  background: var(--premium-bg-card) !important;
  border-right: var(--premium-standard-border) !important;
  box-shadow: none;
  backdrop-filter: blur(10px);
}

.ft-sidebar .nav-link{
  color: var(--premium-text-primary);
  border-radius: 12px;
  position: relative;
}

.ft-sidebar .nav-link::before{
  content: none;
}

.ft-sidebar .nav-link svg,
.ft-sidebar .nav-link i,
.ft-sidebar .nav-link [data-lucide]{
  stroke-width: 1.5px !important;
}

.ft-sidebar .nav-link.active{
  background: var(--premium-accent-glow) !important;
  color: var(--premium-text-primary) !important;
}

.ft-sidebar .nav-link.active::after{
  content: "";
  position: absolute;
  left: -10px;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 999px;
  background-image: var(--premium-gradient);
}

.ft-topbar{
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: color-mix(in srgb, var(--premium-bg-card) 84%, transparent) !important;
  border-bottom: var(--premium-standard-border);
}

/* Header CTA styling (e.g., New Project) */
.ft-topbar .btn-primary,
.ft-topbar a.btn-primary,
.ft-topbar .btn.new-project,
.ft-topbar [data-action="new-project"]{
  border-radius: 12px !important;
  background: var(--premium-bg-card) !important;
  color: var(--premium-text-primary) !important;
  border: var(--premium-standard-border) !important;
  box-shadow: 0 0 0 1px rgba(139, 92, 246, 0.12), 0 10px 24px rgba(139, 92, 246, 0.18) !important;
}

.ft-topbar .btn-primary:hover,
.ft-topbar a.btn-primary:hover,
.ft-topbar .btn.new-project:hover,
.ft-topbar [data-action="new-project"]:hover{
  box-shadow: 0 0 0 1px rgba(139, 92, 246, 0.18), 0 14px 28px rgba(139, 92, 246, 0.24) !important;
}

/* Theme switcher / toggle minimal premium treatment */
.ft-topbar .theme-switcher,
.ft-topbar .theme-toggle,
.ft-topbar #themeToggle,
.ft-topbar [data-theme-toggle],
.ft-topbar .ft-lang-toggle{
  border: var(--premium-standard-border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--premium-bg-card) 92%, transparent);
  padding: 2px;
}

.ft-topbar .theme-switcher .btn,
.ft-topbar .theme-toggle .btn,
.ft-topbar #themeToggle .btn,
.ft-topbar [data-theme-toggle] .btn,
.ft-topbar .ft-lang-toggle .btn{
  border-radius: 999px !important;
  min-height: 30px;
  padding: 4px 10px;
  border: 0 !important;
  background: transparent !important;
  color: var(--premium-text-secondary) !important;
  box-shadow: none !important;
}

.ft-topbar .theme-switcher .btn.active,
.ft-topbar .theme-toggle .btn.active,
.ft-topbar #themeToggle .btn.active,
.ft-topbar [data-theme-toggle] .btn.active,
.ft-topbar .ft-lang-toggle .btn:focus-visible{
  background: var(--premium-bg-card) !important;
  color: var(--premium-text-primary) !important;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.09) !important;
}

/* Step 3: Premium component details (style-only) */
.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  border-radius: 16px !important;
  border: var(--premium-standard-border) !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06) !important;
}

/* Tables: no heavy grid, soft zebra, larger spacing */
.ft-content table{
  border-collapse: collapse !important;
  border-spacing: 0 !important;
}
.ft-content table thead th{
  background: color-mix(in srgb, var(--premium-bg-card) 92%, #f4f0ff) !important;
  color: var(--premium-text-secondary) !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(26, 26, 26, 0.08) !important;
}
.ft-content table th,
.ft-content table td{
  padding: 14px 16px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(26, 26, 26, 0.07) !important;
}
.ft-content table tbody tr:nth-child(even) td{
  background: rgba(139, 92, 246, 0.02);
}
.ft-content table tbody tr:hover td{
  background: rgba(139, 92, 246, 0.05) !important;
}

/* Buttons: gradient primary + ghost secondary */
.btn-primary,
.ft-content .btn-primary{
  background-image: var(--premium-gradient) !important;
  color: #141414 !important;
  border: 1px solid rgba(139, 92, 246, 0.18) !important;
  box-shadow: 0 10px 24px rgba(125, 96, 245, 0.22) !important;
  transform: scale(1);
  transition: transform .16s ease, box-shadow .18s ease, filter .18s ease;
}
.btn-primary:hover,
.ft-content .btn-primary:hover{
  transform: scale(1.02);
  box-shadow: 0 14px 30px rgba(125, 96, 245, 0.28) !important;
  filter: saturate(1.04);
}
.btn-primary:focus-visible,
.ft-content .btn-primary:focus-visible{
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.2), 0 14px 30px rgba(125, 96, 245, 0.24) !important;
}

.btn-secondary,
.btn-outline-secondary,
.btn-outline-primary,
.ft-content .btn-secondary,
.ft-content .btn-outline-secondary,
.ft-content .btn-outline-primary{
  background: transparent !important;
  color: var(--premium-text-primary) !important;
  border: var(--premium-standard-border) !important;
  box-shadow: none !important;
}
.btn-secondary:hover,
.btn-outline-secondary:hover,
.btn-outline-primary:hover,
.ft-content .btn-secondary:hover,
.ft-content .btn-outline-secondary:hover,
.ft-content .btn-outline-primary:hover{
  background: rgba(139, 92, 246, 0.05) !important;
}

/* Entry animations + unified hover transitions */
@keyframes premium-fade-slide-up{
  from{
    opacity: 0;
    transform: translateY(10px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

.premium-kpi,
.premium-grid .card,
.premium-grid .ft-card,
.premium-lists .card,
.premium-lists .ft-card{
  animation: premium-fade-slide-up 400ms ease-out both;
}

.premium-kpi:nth-child(2){ animation-delay: 40ms; }
.premium-kpi:nth-child(3){ animation-delay: 80ms; }
.premium-kpi:nth-child(4){ animation-delay: 120ms; }

.btn,
.ft-content .btn,
.ft-sidebar .nav-link,
.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card,
.premium-kpi{
  transition: all 0.3s ease-in-out !important;
}

.card:hover,
.ft-card:hover,
.ft-content .card:hover,
.ft-content .ft-card:hover,
.premium-kpi:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.09) !important;
}

@media (max-width: 768px){
  .ft-content{
    padding: 12px !important;
  }

  .card,
  .ft-card,
  .ft-content .card,
  .ft-content .ft-card{
    border-radius: 14px !important;
    padding: 14px !important;
  }

  .premium-dash{
    gap: 12px;
  }
  .premium-title{
    font-size: 24px;
  }
  .premium-sub{
    font-size: 13px;
  }
  .premium-kpis{
    grid-template-columns: 1fr !important;
    gap: 10px;
  }
  .premium-kpi{
    padding: 12px;
    border-radius: 14px;
  }
  .premium-kpi .value{
    font-size: 24px;
  }
  .premium-grid,
  .premium-lists{
    grid-template-columns: 1fr !important;
    gap: 12px;
  }
  .premium-plot{
    height: 180px;
  }
  .premium-bar-item{
    grid-template-columns: 88px minmax(0, 1fr) 30px;
    gap: 8px;
    font-size: 12px;
  }
  .premium-row{
    padding: 9px;
    flex-wrap: wrap;
  }
  .premium-row-left{
    min-width: 0;
    width: 100%;
  }
  .premium-progress{
    width: 100%;
    max-width: none;
  }
  .premium-meta b,
  .premium-meta span{
    white-space: normal;
  }

  .ft-content table{
    width: 100%;
    table-layout: fixed;
  }
  .ft-content table th,
  .ft-content table td{
    padding: 10px 10px !important;
    font-size: 12px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .btn,
  .ft-content .btn{
    min-height: 36px;
    padding: 7px 11px;
    font-size: 13px;
  }
}

/* Dashboard readability hotfix (compact mode) */
.premium-dash{
  gap: 12px !important;
}

.premium-title{
  font-size: 24px !important;
}

.premium-sub{
  margin-top: 4px !important;
  font-size: 13px !important;
}

.premium-kpis{
  gap: 10px !important;
}

.premium-kpi{
  padding: 12px 14px !important;
}

.premium-kpi .label{
  font-size: 11px !important;
}

.premium-kpi .value{
  margin-top: 4px !important;
  font-size: 22px !important;
  line-height: 1.1;
}

.premium-kpi .value.value-compact{
  font-size: 15px !important;
}

.premium-grid{
  gap: 12px !important;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, 1fr) !important;
}

.premium-sync-card .card-body{
  padding-top: 8px !important;
}

.premium-plot{
  height: 132px !important;
}

.premium-allocation-card .premium-bars{
  gap: 8px;
}

.premium-allocation-card .premium-bar-item{
  grid-template-columns: 96px minmax(0, 1fr) 34px !important;
  font-size: 12px !important;
}

@media (max-width: 1200px){
  .premium-grid{
    grid-template-columns: 1fr !important;
  }
  .premium-plot{
    height: 120px !important;
  }
}

/* Full-screen first view for dashboard */
.premium-screen-fit{
  min-height: calc(100vh - 114px);
  max-height: calc(100vh - 114px);
  overflow: hidden;
}

.premium-main-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(340px, 1fr);
  gap: 12px;
  align-items: stretch;
}

.premium-side-stack{
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 12px;
}

.premium-sync-card .card-body{
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.premium-sync-card .premium-plot{
  height: 110px !important;
}

.premium-ops-card .card-body{
  padding-top: 8px !important;
}

.premium-ops-card .text-muted{
  font-size: 11px;
}

.premium-ops-card .fw-semibold{
  font-size: 13px;
}

@media (max-width: 1280px){
  .premium-screen-fit{
    min-height: auto;
    max-height: none;
    overflow: visible;
  }
  .premium-main-grid{
    grid-template-columns: 1fr;
  }
}

/* Theme audit: tokenized text + smooth theme transition helpers */
.transition-colors{
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
}
.duration-500{
  transition-duration: 500ms;
}

body,
.ft-app,
.ft-layout,
.ft-content,
.ft-topbar,
.ft-sidebar,
.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  color: var(--premium-text-primary);
}

h1, h2, h3, h4, h5, h6,
.fw-semibold,
.premium-title,
.premium-kpi .value,
.premium-meta b{
  color: var(--premium-text-primary);
}

.text-muted,
label,
.form-label,
.ft-sidebar .menu-title,
.ft-content table thead th,
.premium-sub,
.premium-kpi .label,
.premium-meta span{
  color: var(--premium-text-secondary) !important;
}

.ft-app,
.ft-topbar,
.ft-sidebar,
.ft-content,
.card,
.ft-card,
.btn,
.form-control,
.form-select,
textarea{
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, box-shadow, transform;
  transition-duration: 500ms;
  transition-timing-function: ease;
}

/* Premium depth pass: glassmorphism, ambient shadows, gradients, spacing */
:root{
  --premium-ring-light: rgba(0, 0, 0, 0.05);
  --premium-ring-dark: rgba(255, 255, 255, 0.1);
  --premium-card-bg-light: rgba(255, 255, 255, 0.7);
  --premium-card-bg-dark: rgba(30, 41, 59, 0.5);
  --premium-ambient-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --premium-primary-gradient-strong: linear-gradient(90deg, #A855F7 0%, #3B82F6 100%);
}

[data-theme="dark"],
.theme-dark,
.dark{
  --premium-card-bg-light: rgba(30, 41, 59, 0.5);
}

.ft-topbar,
.ft-sidebar{
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
}

.ft-topbar{
  border-bottom: 1px solid var(--premium-ring-light) !important;
}

.ft-sidebar{
  border-right: 1px solid var(--premium-ring-light) !important;
}

.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card,
.ui2d-card,
.company-group,
.ui2-table-wrap{
  background: var(--premium-card-bg-light) !important;
  border: 1px solid var(--premium-ring-light) !important;
  border-radius: 24px !important;
  box-shadow: var(--premium-ambient-shadow) !important;
}

[data-theme="dark"] .card,
[data-theme="dark"] .ft-card,
[data-theme="dark"] .ft-content .card,
[data-theme="dark"] .ft-content .ft-card,
[data-theme="dark"] .ui2d-card,
[data-theme="dark"] .company-group,
[data-theme="dark"] .ui2-table-wrap,
.theme-dark .card,
.theme-dark .ft-card,
.theme-dark .ft-content .card,
.theme-dark .ft-content .ft-card,
.theme-dark .ui2d-card,
.theme-dark .company-group,
.theme-dark .ui2-table-wrap,
.dark .card,
.dark .ft-card,
.dark .ft-content .card,
.dark .ft-content .ft-card,
.dark .ui2d-card,
.dark .company-group,
.dark .ui2-table-wrap{
  background: var(--premium-card-bg-dark) !important;
  border-color: var(--premium-ring-dark) !important;
}

.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  padding: 2rem !important;
}

.card .card-header,
.ft-card .card-header{
  padding: 0 0 1rem !important;
}

.card .card-body,
.ft-card .card-body{
  padding: 0 !important;
}

.btn-primary,
.ft-content .btn-primary,
.premium-progress > span,
.premium-bar-fill,
.progress-bar,
[role="progressbar"]{
  background: var(--premium-primary-gradient-strong) !important;
  background-image: var(--premium-primary-gradient-strong) !important;
}

.ft-sidebar .nav-link.active,
.ft-sidebar .nav-link.active:hover{
  box-shadow: 0 0 15px rgba(139, 92, 246, 0.3) !important;
}

/* Typography refresh: Inter + semantic weights */
:root{
  --ft-font-family: "Inter", "DM Sans", "Segoe UI", sans-serif;
}

body,
button,
input,
select,
textarea{
  font-family: "Inter", "DM Sans", "Segoe UI", sans-serif !important;
  font-weight: 400;
}

.table thead th,
.ft-content table thead th,
.btn,
.ft-content .btn,
label,
.form-label,
.ft-sidebar .nav-link,
.menu-title{
  font-family: "Inter", "DM Sans", "Segoe UI", sans-serif !important;
  font-weight: 600 !important;
}

/* Step 2 deep clean visual pass (image_7 -> premium) */
.ft-app{
  background: #FBF9F6 !important;
}

.ft-sidebar{
  background: rgba(15, 23, 42, 0.95) !important;
  border-right: 1px solid rgba(255,255,255,0.08) !important;
}

.ft-sidebar .menu-title,
.ft-sidebar .nav-link{
  color: rgba(241, 245, 249, 0.95) !important;
}

.ft-sidebar .nav-link{
  border-radius: 16px !important;
  padding-left: 14px;
}

.ft-sidebar .nav-link.active{
  background: rgba(139, 92, 246, 0.12) !important;
  box-shadow: 0 0 15px rgba(139, 92, 246, 0.3) !important;
}

.ft-sidebar .nav-link.active::after{
  left: 0 !important;
  width: 2px !important;
  top: 7px !important;
  bottom: 7px !important;
  background-image: var(--premium-primary-gradient-strong) !important;
}

.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  border-radius: 16px !important;
  padding: 16px !important;
  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1) !important;
}

.card .card-header,
.ft-card .card-header{
  padding: 0 0 .9rem !important;
}

.ft-content table{
  background: #fff !important;
}

.ft-content table th,
.ft-content table td{
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.ft-content table tbody tr:nth-child(odd) td{
  background: #ffffff !important;
}

.ft-content table tbody tr:nth-child(even) td{
  background: rgba(15, 23, 42, 0.025) !important;
}

.btn-primary,
.ft-content .btn-primary{
  background-image: var(--premium-primary-gradient-strong) !important;
  border: 0 !important;
}

.btn-primary:hover,
.ft-content .btn-primary:hover{
  transform: scale(1.02);
}

.btn-outline-primary,
.btn-outline-secondary,
.ft-content .btn-outline-primary,
.ft-content .btn-outline-secondary{
  background: transparent !important;
  border: 1px solid rgba(15,23,42,.14) !important;
}

/* ==========================================================
   Modern Classic Enterprise Theme (presentation-only)
   ========================================================== */
:root{
  --ce-primary: #2563EB;
  --ce-primary-hover: #1D4ED8;
  --ce-primary-light: #DBEAFE;
  --ce-success: #16A34A;
  --ce-success-light: #DCFCE7;
  --ce-warning: #F59E0B;
  --ce-warning-light: #FEF3C7;
  --ce-danger: #DC2626;
  --ce-danger-light: #FEE2E2;
  --ce-bg: #F8FAFC;
  --ce-surface: #FFFFFF;
  --ce-surface-muted: #F9FAFB;
  --ce-border: #E5E7EB;
  --ce-text: #111827;
  --ce-text-muted: #6B7280;
  --ce-radius-sm: 8px;
  --ce-radius-md: 12px;
  --ce-radius-lg: 16px;
  --ce-shadow-sm: 0 1px 2px rgba(17,24,39,.04), 0 8px 18px rgba(17,24,39,.05);
  --ce-shadow-md: 0 2px 4px rgba(17,24,39,.05), 0 10px 24px rgba(17,24,39,.06);
  --ce-gradient: linear-gradient(90deg, #2563EB 0%, #3B82F6 100%);
}

body,
.ft-app{
  background: var(--ce-bg) !important;
  color: var(--ce-text) !important;
}

.ft-topbar{
  background: var(--ce-surface) !important;
  border-bottom: 1px solid var(--ce-border) !important;
  box-shadow: 0 1px 0 rgba(17,24,39,.03);
}

.ft-sidebar{
  background: var(--ce-surface) !important;
  border-right: 1px solid var(--ce-border) !important;
  box-shadow: none !important;
}

.ft-sidebar .menu-title{
  color: var(--ce-text-muted) !important;
  font-size: 11px;
  font-weight: 600 !important;
}

.ft-sidebar .nav-link{
  color: var(--ce-text) !important;
  border-radius: var(--ce-radius-md) !important;
  font-weight: 600 !important;
}

.ft-sidebar .nav-link:hover{
  background: rgba(22,163,74,.08) !important;
  color: #15803D !important;
}

.ft-sidebar .nav-link.active{
  background: linear-gradient(90deg, #16A34A 0%, #22C55E 100%) !important;
  color: #fff !important;
  border-color: var(--ce-success) !important;
  box-shadow: 0 6px 14px rgba(22,163,74,.18) !important;
}

.ft-sidebar .nav-link.active::before,
.ft-sidebar .nav-link.active::after{
  background: #ffffff !important;
  width: 3px !important;
}

.ft-content{
  padding: 24px 28px 36px !important;
}

.card,
.ft-card,
.ft-content .card,
.ft-content .ft-card{
  background: var(--ce-surface) !important;
  border: 1px solid var(--ce-border) !important;
  border-radius: var(--ce-radius-lg) !important;
  box-shadow: var(--ce-shadow-sm) !important;
  padding: 20px !important;
}

.card-header,
.ft-content .card-header{
  border-bottom: 1px solid var(--ce-border) !important;
  color: var(--ce-text) !important;
  font-weight: 600 !important;
  padding: 0 0 12px !important;
}

.card-body,
.ft-content .card-body{
  padding: 12px 0 0 !important;
}

/* Buttons: primary / secondary / outline / ghost / danger */
.btn,
.ft-content .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border-radius: 14px !important;
  font-weight: 700 !important;
  font-size: 13px;
  line-height: 1.15;
  padding: 10px 16px;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .15s ease, box-shadow .2s ease !important;
}

.btn-primary,
.ft-content .btn-primary,
.btn:not(.btn-secondary):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-danger):not(.btn-success):not(.btn-warning):not(.btn-link):not(.btn-ghost):not(.secondary):not(.danger),
.ft-content .btn:not(.btn-secondary):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-danger):not(.btn-success):not(.btn-warning):not(.btn-link):not(.btn-ghost):not(.secondary):not(.danger){
  background: var(--ce-gradient) !important;
  color: #fff !important;
  border: 1px solid var(--ce-primary) !important;
  box-shadow: 0 6px 14px rgba(37,99,235,.24) !important;
}

.btn-primary:hover,
.ft-content .btn-primary:hover,
.btn:not(.btn-secondary):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-danger):not(.btn-success):not(.btn-warning):not(.btn-link):not(.btn-ghost):not(.secondary):not(.danger):hover,
.ft-content .btn:not(.btn-secondary):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-danger):not(.btn-success):not(.btn-warning):not(.btn-link):not(.btn-ghost):not(.secondary):not(.danger):hover{
  background: linear-gradient(90deg, #1D4ED8 0%, #2563EB 100%) !important;
  border-color: var(--ce-primary-hover) !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(29,78,216,.24) !important;
}

.btn-secondary,
.btn.secondary,
.ft-content .btn-secondary{
  background: linear-gradient(90deg, #16A34A 0%, #22C55E 100%) !important;
  color: #fff !important;
  border: 1px solid var(--ce-success) !important;
  box-shadow: 0 6px 14px rgba(22,163,74,.18) !important;
}

.btn-secondary:hover,
.btn.secondary:hover,
.ft-content .btn-secondary:hover{
  background: #15803D !important;
  border-color: #15803D !important;
}

.btn-outline-primary,
.btn-outline-secondary,
.ft-content .btn-outline-primary,
.ft-content .btn-outline-secondary,
.btn.btn-outline-dark,
.btn.btn-outline-light{
  background: linear-gradient(90deg, #16A34A 0%, #22C55E 100%) !important;
  color: #fff !important;
  border: 1px solid var(--ce-success) !important;
  box-shadow: 0 6px 14px rgba(22,163,74,.18) !important;
}

.btn-outline-primary:hover,
.btn-outline-secondary:hover,
.btn.btn-outline-dark:hover,
.btn.btn-outline-light:hover,
.ft-content .btn-outline-primary:hover,
.ft-content .btn-outline-secondary:hover{
  background: #15803D !important;
  border-color: #15803D !important;
  color: #fff !important;
}

.btn-link,
.btn-ghost{
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--ce-text-muted) !important;
}

.btn-link:hover,
.btn-ghost:hover{
  color: var(--ce-text) !important;
  background: var(--ce-surface-muted) !important;
}

.btn-danger,
.btn.danger,
.ft-content .btn-danger{
  background: linear-gradient(90deg, #DC2626 0%, #EF4444 100%) !important;
  color: #fff !important;
  border: 1px solid var(--ce-danger) !important;
  box-shadow: 0 6px 14px rgba(220,38,38,.18) !important;
}

.btn-danger:hover,
.btn.danger:hover,
.ft-content .btn-danger:hover{
  background: #B91C1C !important;
  border-color: #B91C1C !important;
}

.btn-success,
.ft-content .btn-success{
  background: linear-gradient(90deg, #16A34A 0%, #22C55E 100%) !important;
  color: #fff !important;
  border: 1px solid var(--ce-success) !important;
  box-shadow: 0 6px 14px rgba(22,163,74,.18) !important;
}

.btn-success:hover,
.ft-content .btn-success:hover{
  background: #15803D !important;
  border-color: #15803D !important;
}

.btn-warning,
.ft-content .btn-warning{
  background: linear-gradient(90deg, #16A34A 0%, #22C55E 100%) !important;
  color: #fff !important;
  border: 1px solid var(--ce-success) !important;
  box-shadow: 0 6px 14px rgba(22,163,74,.18) !important;
}

.btn-warning:hover,
.ft-content .btn-warning:hover{
  background: #15803D !important;
  border-color: #15803D !important;
}

.btn-sm{ min-height: 36px; font-size: 12px; padding: 7px 12px; }
.btn-lg{ min-height: 46px; font-size: 15px; padding: 11px 18px; }

/* Forms */
label,
.form-label{
  color: var(--ce-text-muted) !important;
  font-size: 12px;
  font-weight: 600 !important;
  margin-bottom: 6px;
}

.form-control,
.form-select,
textarea{
  background: var(--ce-surface) !important;
  color: var(--ce-text) !important;
  border: 1px solid var(--ce-border) !important;
  border-radius: var(--ce-radius-md) !important;
  min-height: 40px;
  padding: 10px 12px;
  box-shadow: none !important;
}

.form-control:focus,
.form-select:focus,
textarea:focus{
  border-color: var(--ce-primary) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.16) !important;
}

.is-invalid,
.form-control.is-invalid,
.form-select.is-invalid{
  border-color: #FCA5A5 !important;
  box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
}

.invalid-feedback,
.form-text{
  color: var(--ce-text-muted);
}

/* Tables + pagination */
.table,
.ft-content table{
  width: 100%;
  background: var(--ce-surface) !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  border-radius: var(--ce-radius-md);
}

.table thead th,
.ft-content table thead th{
  background: var(--ce-surface-muted) !important;
  color: var(--ce-text-muted) !important;
  font-size: 12px;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  border: 0 !important;
  border-bottom: 1px solid var(--ce-border) !important;
  padding: 12px 14px !important;
}

.table th,
.table td,
.ft-content table th,
.ft-content table td{
  border: 0 !important;
  border-bottom: 1px solid #EEF2F7 !important;
  padding: 12px 14px !important;
  vertical-align: middle;
}

.table tbody tr:hover td,
.ft-content table tbody tr:hover td{
  background: #F8FAFF !important;
}

.page-link{
  border-radius: var(--ce-radius-sm) !important;
  border: 1px solid var(--ce-border) !important;
  background: var(--ce-surface) !important;
  color: var(--ce-text) !important;
}

.page-item.active .page-link{
  background: var(--ce-primary) !important;
  border-color: var(--ce-primary) !important;
  color: #fff !important;
}

/* Badges / status pills */
.badge,
.status-badge,
.status-pill,
.ui2-pill{
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

.status-success{ color: var(--ce-success) !important; background: var(--ce-success-light) !important; border-color: transparent !important; }
.status-warning{ color: #B45309 !important; background: var(--ce-warning-light) !important; border-color: transparent !important; }
.status-danger{ color: var(--ce-danger) !important; background: var(--ce-danger-light) !important; border-color: transparent !important; }
.status-neutral{ color: var(--ce-text-muted) !important; background: #EEF2F7 !important; border-color: transparent !important; }

/* Page headers / filter bars */
.bookings-topbar,
.filters-bar,
.toolbar{
  gap: 12px !important;
  margin-bottom: 14px !important;
}

.text-muted{ color: var(--ce-text-muted) !important; }
h1,h2,h3,h4,h5,h6{ color: var(--ce-text); }

/* Responsive polish */
@media (max-width: 992px){
  .ft-sidebar{ width: 230px; }
  .ft-content{ padding: 16px !important; }
}

@media (max-width: 768px){
  .card,
  .ft-card,
  .ft-content .card,
  .ft-content .ft-card{
    border-radius: var(--ce-radius-md) !important;
    padding: 14px !important;
  }
  .btn,
  .ft-content .btn{
    min-height: 38px;
    font-size: 13px;
  }
  .table th,
  .table td,
  .ft-content table th,
  .ft-content table td{
    padding: 10px !important;
    font-size: 12px;
  }
}

/* Dashboard first-screen fit (desktop, no scroll) */
.ft-content:has(.premium-screen-fit){
  padding: 12px 16px 14px !important;
  overflow: hidden;
}

.premium-screen-fit{
  height: calc(100dvh - var(--ft-topbar-height) - 26px) !important;
  min-height: calc(100dvh - var(--ft-topbar-height) - 26px) !important;
  max-height: calc(100dvh - var(--ft-topbar-height) - 26px) !important;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 10px !important;
  overflow: hidden !important;
}

.premium-head{
  margin: 0 !important;
}

.premium-kpis{
  gap: 8px !important;
}

.premium-kpi{
  padding: 10px 12px !important;
}

.premium-kpi .value{
  font-size: 20px !important;
}

.premium-main-grid{
  min-height: 0 !important;
  gap: 10px !important;
  grid-template-columns: minmax(0, 1.75fr) minmax(320px, 1fr) !important;
}

.premium-main-grid > .card,
.premium-main-grid > .ft-card,
.premium-side-stack > .card,
.premium-side-stack > .ft-card{
  min-height: 0 !important;
  height: 100%;
}

.premium-sync-card .card-body{
  padding-top: 6px !important;
}

.premium-sync-card .premium-plot{
  height: 96px !important;
}

.premium-allocation-card .premium-bars{
  gap: 6px !important;
}

.premium-allocation-card .premium-bar-item{
  font-size: 12px !important;
}

.premium-ops-card .card-body{
  padding-top: 6px !important;
}

.premium-ops-card .row{
  --bs-gutter-y: .25rem;
}

.premium-ops-card .text-muted{
  font-size: 12px !important;
}

.premium-ops-card .fw-semibold{
  font-size: 13px !important;
}

.premium-ops-card .btn{
  min-height: 34px !important;
  padding: 6px 10px !important;
  font-size: 12px !important;
}

@media (max-width: 1280px){
  .ft-content:has(.premium-screen-fit){
    padding: 14px !important;
    overflow: visible;
  }

  .premium-screen-fit{
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    grid-template-rows: auto;
  }

  .premium-main-grid{
    grid-template-columns: 1fr !important;
  }
}

/* Sidebar cleanup: remove active dot + pink glow */
.ft-sidebar .nav-link::before,
.ft-sidebar .nav-link.active::before{
  content: none !important;
  display: none !important;
}

.ft-sidebar .nav-link.active,
.ft-sidebar .nav-link.active:hover{
  box-shadow: none !important;
  background: #EAF1FF !important;
}

/* Lists readability pass: Bookings/Trips grouped tables */
.ft-content .company-group{
  border: 1px solid var(--ce-border) !important;
  border-radius: 16px !important;
  background: var(--ce-surface) !important;
  box-shadow: 0 1px 2px rgba(17,24,39,.04), 0 10px 20px rgba(17,24,39,.05) !important;
  margin-bottom: 14px !important;
  overflow: hidden !important;
}

.ft-content .company-head{
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%) !important;
  border-bottom: 1px solid #E9EEF5 !important;
  padding: 12px 14px !important;
  gap: 12px !important;
}

.ft-content .company-toggle{
  color: var(--ce-text) !important;
  font-weight: 700 !important;
  letter-spacing: -.01em;
}

.ft-content .company-meta{
  color: var(--ce-text-muted) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  gap: 8px !important;
}

.ft-content .company-meta > span{
  background: #F8FAFC;
  border: 1px solid #E6EBF1;
  border-radius: 999px;
  padding: 2px 8px;
}

.ft-content .company-meta .new-count{
  background: #FFF1DB !important;
  border-color: #F6D7A9 !important;
  color: #9A580A !important;
}

.ft-content .bookings-table-wrap{
  border-top: 0 !important;
}

.ft-content .company-group .table{
  margin-bottom: 0 !important;
  background: #fff !important;
  table-layout: auto;
}

.ft-content .company-group .table thead th{
  position: sticky;
  top: 0;
  z-index: 1;
  background: #F8FAFC !important;
  color: #667085 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-bottom: 1px solid #E6EBF1 !important;
  white-space: nowrap;
}

.ft-content .company-group .table tbody td{
  background: #FFFFFF !important;
  color: #111827 !important;
  border-bottom: 1px solid #EEF2F7 !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
  vertical-align: middle !important;
}

.ft-content .company-group .table tbody tr:nth-child(even) td{
  background: #FCFDFE !important;
}

.ft-content .company-group .table tbody tr:hover td{
  background: #F7FAFF !important;
}

.ft-content .company-group .table .btn.btn-sm,
.ft-content .company-group .table .btn{
  border-radius: 10px !important;
}

.ft-content .company-group .pay-badge,
.ft-content .company-group .status-badge{
  font-weight: 700 !important;
  letter-spacing: .01em;
}

@media (max-width: 992px){
  .ft-content .company-head{
    padding: 10px 12px !important;
  }

  .ft-content .company-meta{
    font-size: 11px !important;
    gap: 6px !important;
  }

  .ft-content .company-group .table th,
  .ft-content .company-group .table td{
    font-size: 12px !important;
    padding: 10px !important;
  }
}

/* Unified list surfaces (Drivers/Fleet/Pricing/Users/Customers/etc.) */
.ft-content .table,
.ft-content .card > table{
  width: 100%;
  background: #fff !important;
  border: 1px solid #E6EBF1;
  border-radius: 12px;
  overflow: hidden;
}

.ft-content .table thead th,
.ft-content .card > table thead th{
  background: #F8FAFC !important;
  color: #667085 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-bottom: 1px solid #E6EBF1 !important;
  white-space: nowrap;
}

.ft-content .table tbody td,
.ft-content .card > table tbody td{
  color: #111827 !important;
  border-bottom: 1px solid #EEF2F7 !important;
  vertical-align: middle !important;
  padding-top: 11px !important;
  padding-bottom: 11px !important;
}

.ft-content .table tbody tr:nth-child(even) td,
.ft-content .card > table tbody tr:nth-child(even) td{
  background: #FCFDFE !important;
}

.ft-content .table tbody tr:hover td,
.ft-content .card > table tbody tr:hover td{
  background: #F7FAFF !important;
}

.ft-content .table .badge,
.ft-content .card > table .badge{
  border-radius: 999px !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
}

.ft-content .table .btn,
.ft-content .card > table .btn{
  border-radius: 10px !important;
}

.ft-content .accordion .accordion-item{
  border: 1px solid #E6EBF1 !important;
  border-radius: 14px !important;
  margin-bottom: 10px;
  overflow: hidden;
  background: #fff;
}

.ft-content .accordion .accordion-button{
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%) !important;
  color: #111827 !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}

.ft-content .accordion .accordion-button:not(.collapsed){
  background: #F4F8FF !important;
}

.ft-content .accordion .accordion-body{
  background: #FFFFFF;
  border-top: 1px solid #EDF2F7;
}

.ft-content details.users-group,
.ft-content details.customers-group{
  border: 1px solid #E5EAF1 !important;
  border-radius: 14px !important;
  background: #FFFFFF !important;
  box-shadow: 0 1px 2px rgba(17,24,39,.04), 0 8px 20px rgba(17,24,39,.04);
  overflow: hidden;
}

.ft-content details.users-group summary,
.ft-content details.customers-group summary{
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%) !important;
  border-bottom: 1px solid #E8EEF5;
  padding: 12px 14px !important;
}

.ft-content .list-group{
  border: 1px solid #E6EBF1;
  border-radius: 12px;
  overflow: hidden;
}

.ft-content .list-group .list-group-item{
  border-color: #EEF2F7 !important;
  padding: 10px 12px;
  background: #fff;
}

@media (max-width: 992px){
  .ft-content .table th,
  .ft-content .table td,
  .ft-content .card > table th,
  .ft-content .card > table td{
    font-size: 12px !important;
    padding: 9px !important;
  }

  .ft-content details.users-group summary,
  .ft-content details.customers-group summary{
    padding: 10px 12px !important;
  }
}

/* Unified status pills (match payment column style) */
.ft-content .status-badge,
.ft-content .status-pill-soft,
.ft-content .badge.status-pill-soft{
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2;
  border: 1px solid transparent !important;
}

.ft-content .status-badge.status-new,
.ft-content .status-pill-soft.status-new{
  color: #9A580A !important;
  background: #FFF1DB !important;
}

.ft-content .status-badge.status-confirmed,
.ft-content .status-badge.status-assigned,
.ft-content .status-pill-soft.status-confirmed,
.ft-content .status-pill-soft.status-assigned{
  color: #0C63C8 !important;
  background: #E7F0FF !important;
}

.ft-content .status-badge.status-en-route,
.ft-content .status-pill-soft.status-en-route{
  color: #5B46C5 !important;
  background: #EEE9FF !important;
}

.ft-content .status-badge.status-arrived,
.ft-content .status-badge.status-picked-up,
.ft-content .status-badge.status-completed,
.ft-content .status-badge.status-dropped-off,
.ft-content .status-pill-soft.status-arrived,
.ft-content .status-pill-soft.status-picked-up,
.ft-content .status-pill-soft.status-completed,
.ft-content .status-pill-soft.status-dropped-off,
.ft-content .status-pill-soft.status-active{
  color: #15803D !important;
  background: #DCFCE7 !important;
}

.ft-content .status-badge.status-cancelled,
.ft-content .status-badge.status-no-show,
.ft-content .status-pill-soft.status-cancelled,
.ft-content .status-pill-soft.status-no-show,
.ft-content .status-pill-soft.status-inactive{
  color: #B91C1C !important;
  background: #FEE2E2 !important;
}

/* Simple readable list mode (low-noise, high-clarity) */
.ft-content .company-group{
  border: 1px solid #E7ECF3 !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  background: #fff !important;
}

.ft-content .company-head{
  background: #FFFFFF !important;
  border-bottom: 1px solid #EAF0F6 !important;
  padding: 11px 14px !important;
}

.ft-content .company-toggle{
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #0F172A !important;
}

.ft-content .company-meta{
  font-size: 12px !important;
  color: #64748B !important;
}

.ft-content .company-meta > span{
  background: #F8FAFC !important;
  border: 1px solid #E7ECF3 !important;
}

.ft-content .company-group .table thead th{
  background: #F8FAFC !important;
  color: #64748B !important;
  text-transform: uppercase;
  letter-spacing: .035em;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-bottom: 1px solid #EAF0F6 !important;
  padding-top: 11px !important;
  padding-bottom: 11px !important;
}

.ft-content .company-group .table tbody td{
  font-size: 14px !important;
  color: #1F2937 !important;
  border-bottom: 1px solid #EEF3F8 !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
  background: #FFFFFF !important;
}

.ft-content .company-group .table tbody tr:nth-child(even) td{
  background: #FFFFFF !important;
}

.ft-content .company-group .table tbody tr:hover td{
  background: #F9FBFF !important;
}

.ft-content .company-group .table td:nth-child(2),
.ft-content .company-group .table td:nth-child(3),
.ft-content .company-group .table td:nth-child(4){
  font-variant-numeric: tabular-nums;
}

.ft-content .company-group .table .btn{
  min-height: 36px;
  padding: 7px 12px;
}

/* B2B Bookings list aligned with Drivers list visual style */
.ft-content .bookings-list-card .company-group{
  border: 1px solid #E6EBF1 !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  background: #FFFFFF !important;
}

.ft-content .bookings-list-card .company-head{
  background: #FFFFFF !important;
  border-bottom: 1px solid #E6EBF1 !important;
}

.ft-content .bookings-list-card .company-toggle{
  color: #111827 !important;
  font-size: 18px !important;
}

.ft-content .bookings-list-card .company-meta{
  color: #6B7280 !important;
}

.ft-content .bookings-list-card .company-meta > span{
  background: #F8FAFC !important;
  border: 1px solid #E6EBF1 !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table{
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  min-width: 1220px;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table thead th{
  background: #F8FAFC !important;
  color: #667085 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-bottom: 1px solid #E6EBF1 !important;
  white-space: nowrap;
}

.ft-content .bookings-list-card .bookings-table-wrap .table tbody td{
  color: #111827 !important;
  border-bottom: 1px solid #EEF2F7 !important;
  vertical-align: middle !important;
  background: #FFFFFF !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table tbody tr:nth-child(even) td{
  background: #FCFDFE !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table tbody tr:hover td{
  background: #F7FAFF !important;
}

/* Remove inner frame in grouped bookings table (keep only outer company-group border) */
.ft-content .bookings-list-card .company-group .collapse,
.ft-content .bookings-list-card .company-group .bookings-table-wrap{
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table,
.ft-content .bookings-list-card .bookings-table-wrap .table thead,
.ft-content .bookings-list-card .bookings-table-wrap .table tbody,
.ft-content .bookings-list-card .bookings-table-wrap .table tr{
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table th:first-child,
.ft-content .bookings-list-card .bookings-table-wrap .table td:first-child{
  border-left: 0 !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table th:last-child,
.ft-content .bookings-list-card .bookings-table-wrap .table td:last-child{
  border-right: 0 !important;
}

.ft-content .bookings-list-card .bookings-table-wrap .table tbody tr:last-child td{
  border-bottom: 0 !important;
}

/* Single-frame tables across system lists: keep only card/group container border */
.ft-content .card .table{
  border: 0 !important;
  border-radius: 0 !important;
  overflow: visible !important;
  box-shadow: none !important;
}

.ft-content .card .table thead,
.ft-content .card .table tbody,
.ft-content .card .table tr{
  border-left: 0 !important;
  border-right: 0 !important;
}

.ft-content .card .table th:first-child,
.ft-content .card .table td:first-child{
  border-left: 0 !important;
}

.ft-content .card .table th:last-child,
.ft-content .card .table td:last-child{
  border-right: 0 !important;
}

.ft-content .card .table tbody tr:last-child td{
  border-bottom: 0 !important;
}

/* Global list tables: match B2B Bookings look across all modules */
.ft-content .card .table,
.ft-content .table-responsive .table,
.ft-content .company-group .table{
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  background: #FFFFFF !important;
}

.ft-content .card .table thead th,
.ft-content .table-responsive .table thead th,
.ft-content .company-group .table thead th{
  background: #F8FAFC !important;
  color: #667085 !important;
  border-bottom: 1px solid #E6EBF1 !important;
}

.ft-content .card .table tbody td,
.ft-content .table-responsive .table tbody td,
.ft-content .company-group .table tbody td{
  background: #FFFFFF !important;
  color: #111827 !important;
  border-bottom: 1px solid #EEF2F7 !important;
  box-shadow: none !important;
}

.ft-content .card .table tbody tr:nth-child(even) td,
.ft-content .table-responsive .table tbody tr:nth-child(even) td,
.ft-content .company-group .table tbody tr:nth-child(even) td{
  background: #FCFDFE !important;
  box-shadow: inset 0 0 0 9999px #FCFDFE !important;
}

.ft-content .card .table tbody tr:hover td,
.ft-content .table-responsive .table tbody tr:hover td,
.ft-content .company-group .table tbody tr:hover td{
  background: #F7FAFF !important;
  box-shadow: inset 0 0 0 9999px #F7FAFF !important;
}

.ft-content .table.table-striped > tbody > tr:nth-of-type(odd) > *,
.ft-content .table.table-striped > tbody > tr:nth-of-type(even) > *{
  --bs-table-accent-bg: transparent !important;
}

/* Drivers list: remove inner side frame, keep only outer card border */
.ft-content .drivers-list-card > table{
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.ft-content .drivers-list-card > table thead,
.ft-content .drivers-list-card > table tbody,
.ft-content .drivers-list-card > table tr{
  border-left: 0 !important;
  border-right: 0 !important;
}

.ft-content .drivers-list-card > table th:first-child,
.ft-content .drivers-list-card > table td:first-child{
  border-left: 0 !important;
}

.ft-content .drivers-list-card > table th:last-child,
.ft-content .drivers-list-card > table td:last-child{
  border-right: 0 !important;
}

.ft-content .drivers-list-card > table tbody tr:last-child td{
  border-bottom: 0 !important;
}

/* Final shell color lock: topbar and sidebar must share the same hard white surface */
.ft-topbar,
.ft-sidebar{
  background: #FFFFFF !important;
  background-image: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.ft-sidebar{
  box-shadow: none !important;
}

/* Final sidebar nav lock: avoid old premium glow/marker flash during page load */
.ft-sidebar .nav-link{
  display: block !important;
  width: 100% !important;
  color: #0F172A !important;
  padding: 12px 14px !important;
  margin: 4px 0 !important;
  border: 1px solid transparent !important;
  border-radius: 14px !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  transition: background-color .16s ease, border-color .16s ease, color .16s ease !important;
}

.ft-sidebar .nav-link:hover{
  background: rgba(37,99,235,.08) !important;
  border-color: #BFDBFE !important;
  color: #1D4ED8 !important;
  box-shadow: none !important;
  transform: none !important;
}

.ft-sidebar .nav-link.active,
.ft-sidebar .nav-link.active:hover{
  background: linear-gradient(90deg, #2563EB 0%, #3B82F6 100%) !important;
  border-color: #2563EB !important;
  color: #FFFFFF !important;
  box-shadow: none !important;
  transform: none !important;
}

.ft-sidebar .nav-link::before,
.ft-sidebar .nav-link::after,
.ft-sidebar .nav-link.active::before,
.ft-sidebar .nav-link.active::after{
  content: none !important;
  display: none !important;
}

/* Final action button size lock: match OPS "Nowa rezerwacja" */
:root{
  --ft-action-btn-height: 34px;
  --ft-action-btn-font-size: 14px;
  --ft-action-btn-pad-y: 6px;
  --ft-action-btn-pad-x: 12px;
  --ft-action-btn-radius: 12px;
}

.btn:not(.btn-link):not(.btn-ghost),
.ft-content .btn:not(.btn-link):not(.btn-ghost),
.btn-sm:not(.btn-link):not(.btn-ghost),
.ft-content .btn-sm:not(.btn-link):not(.btn-ghost){
  min-height: var(--ft-action-btn-height) !important;
  font-size: var(--ft-action-btn-font-size) !important;
  padding: var(--ft-action-btn-pad-y) var(--ft-action-btn-pad-x) !important;
  border-radius: var(--ft-action-btn-radius) !important;
  line-height: 1.15 !important;
}

/* Final app typography lock: match global UI text to table scale */
.ft-topbar,
.ft-sidebar,
.ft-content{
  font-size: 14px;
}

.ft-topbar .brand,
.ft-topbar .btn,
.ft-sidebar .nav-link,
.ft-content .btn,
.ft-content .btn-sm,
.ft-content label,
.ft-content .form-label,
.ft-content .form-control,
.ft-content .form-select,
.ft-content textarea,
.ft-content input,
.ft-content select,
.ft-content .text-muted,
.ft-content .text-secondary,
.ft-content .small,
.ft-content small,
.ft-content .badge,
.ft-content .pill{
  font-size: 14px !important;
}

.ft-content label,
.ft-content .form-label,
.ft-content .text-muted,
.ft-content .text-secondary,
.ft-content .small,
.ft-content small{
  line-height: 1.45 !important;
}

/* Final table typography lock: one font family and crisp rendering across system tables */
.ft-content .table thead th,
.ft-content .card > table thead th,
.ft-content .table-responsive .table thead th,
.ft-content .company-group .table thead th,
.ft-content .bookings-list-card .bookings-table-wrap .table thead th,
.ft-content .system-notifications-table thead th,
.ft-content .ops-table thead th,
.ft-content .ft-drivers-table thead th,
.ft-content .ft-users-table thead th,
.ft-content .ft-fleet-table thead th,
.ft-content .ft-pricing-table thead th,
.ft-content .ft-base-block-table thead th{
  font-family: var(--ft-font-family) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ft-content .table tbody td,
.ft-content .card > table tbody td,
.ft-content .table-responsive .table tbody td,
.ft-content .company-group .table tbody td,
.ft-content .bookings-list-card .bookings-table-wrap .table tbody td,
.ft-content .system-notifications-table tbody td,
.ft-content .ops-table tbody td,
.ft-content .ft-drivers-table tbody td,
.ft-content .ft-users-table tbody td,
.ft-content .ft-fleet-table tbody td,
.ft-content .ft-pricing-table tbody td,
.ft-content .ft-base-block-table tbody td{
  font-family: var(--ft-font-family) !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  font-weight: 400;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ft-content .table tbody td select,
.ft-content .table tbody td input,
.ft-content .table tbody td textarea,
.ft-content .table tbody td .form-select,
.ft-content .table tbody td .form-control,
.ft-content .card > table tbody td select,
.ft-content .card > table tbody td input,
.ft-content .card > table tbody td textarea,
.ft-content .card > table tbody td .form-select,
.ft-content .card > table tbody td .form-control,
.ft-content .table-responsive .table tbody td select,
.ft-content .table-responsive .table tbody td input,
.ft-content .table-responsive .table tbody td textarea,
.ft-content .table-responsive .table tbody td .form-select,
.ft-content .table-responsive .table tbody td .form-control,
.ft-content .company-group .table tbody td select,
.ft-content .company-group .table tbody td input,
.ft-content .company-group .table tbody td textarea,
.ft-content .company-group .table tbody td .form-select,
.ft-content .company-group .table tbody td .form-control,
.ft-content .system-notifications-table tbody td select,
.ft-content .system-notifications-table tbody td input,
.ft-content .system-notifications-table tbody td textarea,
.ft-content .ops-table tbody td select,
.ft-content .ops-table tbody td input,
.ft-content .ops-table tbody td textarea,
.ft-content .ft-drivers-table tbody td select,
.ft-content .ft-drivers-table tbody td input,
.ft-content .ft-drivers-table tbody td textarea,
.ft-content .ft-users-table tbody td select,
.ft-content .ft-users-table tbody td input,
.ft-content .ft-users-table tbody td textarea,
.ft-content .ft-fleet-table tbody td select,
.ft-content .ft-fleet-table tbody td input,
.ft-content .ft-fleet-table tbody td textarea,
.ft-content .ft-pricing-table tbody td select,
.ft-content .ft-pricing-table tbody td input,
.ft-content .ft-pricing-table tbody td textarea,
.ft-content .ft-base-block-table tbody td select,
.ft-content .ft-base-block-table tbody td input,
.ft-content .ft-base-block-table tbody td textarea{
  font-family: var(--ft-font-family) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
