:root{--color-primary:#1d4ed8;--color-primary-light:#3b82f6;--color-primary-pale:#60a5fa;--color-primary-50:#eff6ff;--color-primary-100:#dbeafe;--color-primary-200:#bfdbfe;--color-sky-700:#0369a1;--color-sky-900:#0c4a6e;--color-sky-50:#f0f9ff;--color-sky-100:#e0f2fe;--color-sky-200:#bae6fd;--color-cyan-50:#ecfeff;--color-cyan-100:#cffafe;--color-cyan-200:#a5f3fc;--color-cyan-400:#22d3ee;--color-cyan-600:#0891b2;--color-amber-50:#fffbeb;--color-amber-100:#fef3c7;--color-amber-200:#fde68a;--color-amber-500:#f59e0b;--color-amber-600:#d97706;--color-amber-700:#b45309;--color-amber-800:#92400e;--color-purple-50:#faf5ff;--color-purple-100:#f3e8ff;--color-purple-200:#e9d5ff;--color-purple-500:#a855f7;--color-purple-600:#9333ea;--color-purple-700:#7e22ce;--color-green-50:#f0fdf4;--color-green-100:#dcfce7;--color-green-200:#bbf7d0;--color-green-500:#22c55e;--color-green-600:#16a34a;--color-green-700:#15803d;--color-navy-900:#1e3a8a;--color-navy-800:#1e40af;--color-navy-700:#1d4ed8;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-500:#6b7280;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-slate-700:#334155;--color-slate-500:#64748b;--color-slate-400:#94a3b8;--color-slate-50:#f8fafc;--color-red-50:#fef2f2;--color-red-100:#fee2e2;--color-red-200:#fecaca;--color-red-500:#ef4444;--color-red-600:#dc2626;--color-red-700:#b91c1c;--color-red-800:#991b1b;--font-body:"DM Sans",sans-serif;--font-display:"Sora",sans-serif;--font-mono:monospace;--radius-sm:8px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001a;--shadow-xl:0 16px 40px #0000001f;--shadow-card:0 2px 12px #2563eb12;--shadow-card-hover:0 12px 32px #2563eb21;--shadow-header:0 2px 16px #2563eb0f;--shadow-btn-primary:0 3px 10px #2563eb4d;--shadow-avatar:0 4px 12px #2563eb59;--shadow-bar:0 4px 12px #2563eb40;--shadow-notif-dot:0 0 0 2px #fff;--shadow-status-dot:0 0 6px #3b82f6;--bg-page:linear-gradient(135deg,#f0f4ff 0%,#f8faff 50%,#eff6ff 100%);--bg-page-alt:linear-gradient(135deg,#f8fafc 0%,#eff6ff 40%,#faf5ff 100%);--bg-view-page:linear-gradient(135deg,#eff6ff 0%,#fff 50%,#faf5ff 100%);--gradient-bar:linear-gradient(180deg,#3b82f6,#1d4ed8);--gradient-bar-h:linear-gradient(90deg,#2563eb,#60a5fa);--gradient-primary:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));--gradient-avatar:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));--gradient-blue-btn:linear-gradient(to right,#2563eb,#1d4ed8);--gradient-amber-btn:linear-gradient(to right,#f59e0b,#d97706);--gradient-green-btn:linear-gradient(to right,#22c55e,#16a34a);--gradient-cluster-badge:linear-gradient(to right,#3b82f6,#2563eb);--gradient-stat-panel:linear-gradient(135deg,#3b82f6,#9333ea);--page-padding-x:32px;--page-padding-y:24px;--section-gap:24px}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg-page);color:var(--color-slate-700);-webkit-font-smoothing:antialiased;margin:0}p,h1,h2,h3,h4{margin:0}a{text-decoration:none}.dash-scrollbar::-webkit-scrollbar{width:5px}.dash-scrollbar::-webkit-scrollbar-thumb{background:var(--color-primary-200);border-radius:4px}.custom-scrollbar::-webkit-scrollbar{width:6px;height:6px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:#93c5fd;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#60a5fa}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.fade-up{animation:.35s both fade-up}.fade-up:first-child{animation-delay:0s}.fade-up:nth-child(2){animation-delay:70ms}.fade-up:nth-child(3){animation-delay:.14s}.fade-up:nth-child(4){animation-delay:.21s}.fade-up:nth-child(5){animation-delay:.28s}.fade-up:nth-child(6){animation-delay:.35s}.dash-root{font-family:var(--font-body);background:var(--bg-page);height:100vh;display:flex;overflow:hidden}.dash-root *{box-sizing:border-box}.dash-body{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.dash-main{min-height:0;padding:var(--page-padding-y)var(--page-padding-x);gap:var(--section-gap);flex-direction:column;flex:1;display:flex;overflow-y:auto}.stats-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.chart-activity-grid{grid-template-columns:1fr 360px;gap:18px;display:grid}.quick-grid{grid-template-columns:repeat(8,1fr);gap:10px;display:grid}.bar-chart-row{align-items:flex-end;gap:10px;height:220px;display:flex}.chart-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.page-layout{background:var(--bg-page-alt);height:100vh;font-family:var(--font-body);display:flex;overflow:hidden}.page-content{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.page-main{min-height:0;padding:var(--page-padding-y)var(--page-padding-x);gap:var(--section-gap);flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header--tall{height:80px}.loading-screen{background:var(--bg-page);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-screen__inner{flex-direction:column;align-items:center;gap:16px;display:flex}.loading-screen__text{color:var(--color-primary);font-size:14px;font-weight:500}.loading-screen__card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-2xl);border:1px solid var(--color-primary-100);box-shadow:var(--shadow-xl);text-align:center;background:#ffffffd9;flex-direction:column;align-items:center;gap:16px;padding:64px;display:flex}.spinner{border:4px solid var(--color-primary-200);border-top-color:var(--color-primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.spinner--lg{border-width:4px;border-color:var(--color-primary-light);border-top-color:var(--color-primary);width:64px;height:64px}.spinner--sm{border-width:2px;border-color:var(--color-primary-200);border-top-color:var(--color-primary);width:16px;height:16px}.page-header{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1.5px solid var(--color-primary-100);height:72px;padding:0 var(--page-padding-x);box-shadow:var(--shadow-header);background:#ffffffd9;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.page-header__title{color:var(--color-navy-900);font-size:21px;font-weight:700;font-family:var(--font-display);letter-spacing:-.3px}.page-header__subtitle{color:var(--color-primary-pale);margin-top:1px;font-size:12.5px}.page-header__subtitle strong{color:var(--color-navy-800);font-weight:700}.page-header__actions{align-items:center;gap:12px;display:flex}.divider-v{background:var(--color-primary-100);width:1px;height:36px}.user-info{align-items:center;gap:10px;display:flex}.user-info__text{text-align:right}.user-info__name{color:var(--color-navy-900);font-size:13px;font-weight:700;line-height:1.3}.user-info__role{color:var(--color-primary-pale);text-transform:capitalize;font-size:11px;font-weight:500}.user-block{align-items:center;gap:10px;display:flex}.user-block__text{text-align:right}.user-block__name{color:var(--color-navy-900);font-size:13px;font-weight:700;line-height:1.3}.user-block__role{color:var(--color-primary-pale);text-transform:capitalize;font-size:11px;font-weight:500}.user-block__avatar{border-radius:var(--radius-md);background:var(--gradient-avatar);color:#fff;width:40px;height:40px;box-shadow:var(--shadow-avatar);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.user-block__avatar--lg{border-radius:12px;width:44px;height:44px;font-size:16px;box-shadow:0 4px 14px #2563eb4d}.header-divider{background:var(--color-primary-100);width:1px;height:36px}.notif-btn{border-radius:var(--radius-md);border:1.5px solid var(--color-primary-100);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,transform .15s;display:flex;position:relative}.notif-btn:hover{transform:scale(1.05);background:var(--color-primary-50)!important}.notif-btn__dot{background:var(--color-red-600);width:7px;height:7px;box-shadow:var(--shadow-notif-dot);border-radius:50%;animation:2s ease-in-out infinite pulse-dot;position:absolute;top:8px;right:8px}.logout-btn{border-radius:var(--radius-md);border:1.5px solid var(--color-red-200);color:var(--color-red-600);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;align-items:center;gap:7px;padding:8px 14px;transition:all .15s;display:flex}.logout-btn:hover{background:var(--color-red-50)!important;border-color:var(--color-red-200)!important}.avatar{border-radius:var(--radius-md);background:var(--gradient-avatar);color:#fff;width:40px;height:40px;box-shadow:var(--shadow-avatar);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.card{border-radius:var(--radius-xl);border:1.5px solid var(--color-primary-100);box-shadow:var(--shadow-card);background:#fff}.card-padded{padding:22px 24px}.card-header{border-bottom:1.5px solid var(--color-primary-50);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-title{color:var(--color-navy-900);font-size:15px;font-weight:700;font-family:var(--font-display)}.card-subtitle{color:var(--color-primary-pale);margin-top:2px;font-size:12px}.section-head{margin-bottom:16px}.list-page-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.back-btn{color:var(--color-primary);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:8px;transition:color .15s;display:flex}.back-btn:hover{color:var(--color-navy-700)}.back-btn__icon{border-radius:var(--radius-sm);border:1px solid var(--color-primary-200);box-shadow:var(--shadow-sm);background:#fff;justify-content:center;align-items:center;padding:8px;transition:box-shadow .15s;display:flex}.back-btn:hover .back-btn__icon{box-shadow:var(--shadow-md)}.back-btn__label{font-weight:600}.add-btn{border-radius:var(--radius-md);background:var(--gradient-blue-btn);color:#fff;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);box-shadow:var(--shadow-btn-primary);border:none;align-items:center;gap:8px;padding:10px 20px;transition:opacity .15s,transform .15s;display:inline-flex}.add-btn:hover{opacity:.92;transform:translateY(-1px)}.add-btn:disabled{background:var(--color-gray-300);cursor:not-allowed;opacity:1;transform:none}.alert{border-radius:var(--radius-lg);margin-bottom:8px;padding:16px 24px;font-size:14px;font-weight:500}.alert--error{background:var(--color-red-50);border-left:4px solid var(--color-red-500);color:var(--color-red-700);box-shadow:var(--shadow-sm)}.alert--success{background:var(--color-green-50);border-left:4px solid var(--color-green-500);color:var(--color-green-700)}.alert--warning{background:var(--color-amber-50);border-left:4px solid var(--color-amber-500);color:var(--color-amber-800)}.alert--info{background:var(--color-primary-50);border-left:4px solid var(--color-primary-light);color:var(--color-navy-800)}.empty-state{border:2px dashed var(--color-primary-200);border-radius:var(--radius-xl);text-align:center;background:#fff9;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 40px;display:flex}.empty-state__icon{background:var(--color-primary-50);border-radius:50%;padding:16px}.empty-state__title{color:var(--color-gray-800);font-size:20px;font-weight:700}.empty-state__text{color:var(--color-slate-500);font-size:14px}.data-table-wrapper{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);border:1.5px solid var(--color-primary-100);box-shadow:var(--shadow-card);background:#ffffffd9;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead tr{background:#f0f6ff}.data-table th{text-align:left;color:#2563eb;letter-spacing:.07em;text-transform:uppercase;border-bottom:1.5px solid var(--color-primary-100);padding:12px 20px;font-size:10.5px;font-weight:700}.data-table td{border-bottom:1px solid #f0f6ff;padding:14px 20px}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:#eff6ff99}.route-row{transition:background .15s}.route-row:hover{background:#eff6ff99!important}.cell-id{font-family:var(--font-mono);color:var(--color-primary);font-size:13px;font-weight:600}.cell-route-id{font-size:13px;font-family:var(--font-mono);color:var(--color-slate-700);font-weight:700}.cell-vehicle{font-size:12px;font-family:var(--font-mono);color:var(--color-slate-500)}.cell-driver{color:var(--color-slate-700);font-size:13px;font-weight:500}.cell-origin-dest{align-items:center;gap:6px;display:flex}.cell-origin-dest__city{color:var(--color-navy-900);font-size:13px;font-weight:600}.cell-progress{align-items:center;gap:10px;display:flex}.cell-progress__pct{color:var(--color-navy-800);min-width:36px;font-size:12px;font-weight:700}.cell-branch-name{align-items:center;gap:10px;display:flex}.cell-branch-name__icon{background:var(--color-primary-100);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;padding:8px;display:flex}.cell-branch-name__text{color:var(--color-gray-900);font-size:14px;font-weight:700}.cell-company__name{color:var(--color-gray-900);font-size:14px;font-weight:600}.cell-company__code{font-size:12px;font-family:var(--font-mono);color:var(--color-primary);margin-top:2px}.cell-branch-code{font-family:var(--font-mono);color:var(--color-navy-700);background:var(--color-primary-50);border-radius:var(--radius-sm);border:1px solid var(--color-primary-200);padding:6px 10px;font-size:13px;font-weight:700;display:inline-block}.cell-location{color:var(--color-gray-800);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.cell-contact{align-items:center;gap:6px;display:flex}.cell-contact__name{color:var(--color-gray-900);font-size:14px;font-weight:600}.cell-contact__designation{color:var(--color-primary);font-size:12px}.cell-cluster-badge{border-radius:var(--radius-full);background:var(--gradient-cluster-badge);color:#fff;align-items:center;padding:5px 12px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 2px 6px #2563eb4d}.action-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s,color .15s,transform .12s;display:flex}.action-btn:hover{transform:scale(1.1)}.action-btn--view{background:var(--color-primary-50);color:var(--color-primary)}.action-btn--view:hover{background:var(--color-primary-100)}.action-btn--edit{background:var(--color-amber-50);color:var(--color-amber-600)}.action-btn--edit:hover{background:var(--color-amber-100)}.action-btn--delete{background:var(--color-red-50);color:var(--color-red-600)}.action-btn--delete:hover{background:var(--color-red-100)}.action-group{align-items:center;gap:6px;display:flex}.list-summary{justify-content:center;padding:8px 0 4px;display:flex}.summary-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);border:1.5px solid var(--color-primary-100);box-shadow:var(--shadow-card);background:#ffffffd9;align-items:center;gap:14px;padding:14px 28px;display:flex}.summary-badge__icon{background:var(--color-primary-50);border-radius:var(--radius-md);border:1px solid var(--color-primary-200);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.summary-badge__label{color:var(--color-slate-500);font-size:12px;font-weight:500}.summary-badge__count{color:var(--color-navy-900);font-size:22px;font-weight:700;font-family:var(--font-display);line-height:1.1}.stat-card{cursor:pointer;box-shadow:var(--shadow-card);background:#fff;border-radius:16px;padding:20px 22px 18px;transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)!important}.stat-card:after{content:"";opacity:0;background:linear-gradient(90deg,#1d4ed8,#60a5fa,#0ea5e9);border-radius:16px 16px 0 0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.stat-card:hover:after{opacity:1}.stat-deco{border-radius:50%;transition:transform .3s;position:absolute}.stat-card:hover .stat-deco{transform:scale(1.18)}.stat-card__top{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex;position:relative}.stat-card__icon{border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.stat-card__value{font-size:34px;font-weight:700;font-family:var(--font-display);letter-spacing:-.5px;line-height:1;position:relative}.stat-card__label{color:var(--color-slate-500);margin-top:4px;font-size:13px;font-weight:600;position:relative}.stat-card__bar-wrap{margin-top:14px;position:relative}.stat-card__bar-meta{justify-content:space-between;margin-top:5px;display:flex}.stat-card__bar-meta-left{color:var(--color-slate-400);font-size:10.5px;font-weight:500}.stat-card__bar-meta-right{font-size:10.5px;font-weight:700}.badge{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-blue{background:var(--color-primary-100);color:var(--color-navy-800);border:1px solid var(--color-primary-200)}.badge-sky{background:var(--color-sky-100);color:var(--color-sky-700);border:1px solid var(--color-sky-200)}.badge-transit{background:var(--color-primary-50);color:var(--color-primary)}.badge-scheduled{background:var(--color-slate-50);color:var(--color-slate-700)}.badge__dot{background:var(--color-primary-light);width:6px;height:6px;box-shadow:var(--shadow-status-dot);border-radius:50%;margin-right:5px}.progress-track{background:var(--color-primary-100);border-radius:10px;height:6px;overflow:hidden}.progress-track--thin{border:1px solid var(--color-primary-100);height:5px}.progress-fill{background:var(--gradient-bar-h);border-radius:10px;height:100%;transition:width .5s}.quick-card{cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:7px;padding:14px 8px;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 1px 6px #2563eb0d}.quick-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb1f!important}.quick-card__icon-box{background:#fff;border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.quick-card__label{color:var(--color-slate-700);text-align:center;font-size:10.5px;font-weight:600;line-height:1.3}.bar-col{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.bar-col:hover .bar-fill{filter:brightness(1.15)}.bar-col__value{color:var(--color-primary-pale);font-size:10.5px;font-weight:700}.bar-col__day{color:var(--color-slate-400);font-size:11px;font-weight:600}.bar-fill{background:var(--gradient-bar);width:100%;box-shadow:var(--shadow-bar);border-radius:6px 6px 0 0;transition:filter .15s}.activity-list{flex-direction:column;gap:6px;display:flex}.activity-row{cursor:pointer;border-radius:10px;align-items:flex-start;gap:10px;padding:10px;transition:background .15s;display:flex}.activity-row:hover{background:#f8faff!important}.activity-row__icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.activity-row__body{flex:1;min-width:0}.activity-row__action{color:var(--color-navy-900);font-size:12.5px;font-weight:600;line-height:1.3}.activity-row__detail{color:var(--color-slate-500);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.activity-row__time{color:var(--color-slate-400);margin-top:2px;font-size:10.5px}.btn-primary{border-radius:var(--radius-md);background:var(--gradient-primary);color:#fff;cursor:pointer;font-size:12.5px;font-weight:600;font-family:var(--font-body);box-shadow:var(--shadow-btn-primary);border:none;align-items:center;gap:6px;padding:8px 14px;transition:opacity .15s,transform .15s;display:inline-flex}.btn-primary:hover{opacity:.92;transform:translateY(-1px)}.btn-ghost-blue{color:#2563eb;cursor:pointer;font-size:12.5px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;border-radius:7px;padding:5px 10px;transition:background .15s}.btn-ghost-blue:hover{background:var(--color-primary-50)}.btn-submit{border-radius:var(--radius-lg);background:var(--gradient-blue-btn);color:#fff;cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);box-shadow:var(--shadow-btn-primary);border:none;flex:1;padding:14px 24px;transition:opacity .15s,transform .15s,box-shadow .15s}.btn-submit:hover{opacity:.93;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-submit:disabled{background:var(--color-gray-300);cursor:not-allowed;box-shadow:none;transform:none}.btn-cancel{border-radius:var(--radius-lg);border:2px solid var(--color-gray-300);color:var(--color-gray-700);cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);background:0 0;padding:14px 24px;transition:background .15s,border-color .15s}.btn-cancel:hover{background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-cancel:disabled{cursor:not-allowed}.btn-amber{border-radius:var(--radius-lg);background:var(--gradient-amber-btn);color:#fff;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);border:none;align-items:center;gap:8px;padding:12px 20px;transition:opacity .15s;display:inline-flex;box-shadow:0 3px 10px #d977064d}.btn-amber:disabled{background:var(--color-gray-300);cursor:not-allowed}.btn-green{border-radius:var(--radius-lg);background:var(--gradient-green-btn);color:#fff;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-body);border:none;align-items:center;gap:8px;padding:8px 16px;transition:opacity .15s;display:inline-flex;box-shadow:0 3px 10px #16a34a40}.btn-green:hover{opacity:.92}.btn-remove{border-radius:var(--radius-sm);cursor:pointer;color:var(--color-red-600);background:0 0;border:none;padding:8px;transition:color .15s,background .15s}.btn-remove:hover{color:var(--color-red-700);background:var(--color-red-50)}.btn-edit-page{border-radius:var(--radius-lg);background:var(--gradient-blue-btn);color:#fff;cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-body);box-shadow:var(--shadow-btn-primary);border:none;align-items:center;gap:8px;padding:12px 24px;transition:opacity .15s,box-shadow .15s,transform .15s;display:inline-flex}.btn-edit-page:hover{opacity:.93;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.select-styled{border:1.5px solid var(--color-primary-100);color:var(--color-slate-700);font-size:12px;font-family:var(--font-body);cursor:pointer;background:#f8faff;border-radius:9px;outline:none;padding:6px 12px;font-weight:500}.select-styled:focus{border-color:var(--color-primary-light)}.form-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);background:#ffffffd9;border:1px solid #bfdbfe99;overflow:hidden}.form-body{flex-direction:column;gap:32px;padding:32px;display:flex}.form-section{border-bottom:2px solid var(--color-primary-100);padding-bottom:32px}.form-section:last-child{border-bottom:none;padding-bottom:0}.form-section__heading{color:var(--color-gray-800);align-items:center;gap:10px;margin-bottom:24px;font-size:20px;font-weight:700;display:flex}.form-section__heading-row{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.form-section__icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;padding:8px;display:flex}.form-section__icon--blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.form-section__icon--amber{background:linear-gradient(135deg,#f59e0b,#d97706)}.form-section__icon--purple{background:linear-gradient(135deg,#a855f7,#9333ea)}.form-section__icon--cyan{background:linear-gradient(135deg,#22d3ee,#0891b2)}.form-section__body{border-radius:var(--radius-lg);border-style:solid;border-width:1px;padding:24px}.form-section__body--blue{background:linear-gradient(135deg,var(--color-primary-50),#fff);border-color:var(--color-primary-100)}.form-section__body--amber{background:linear-gradient(135deg,var(--color-amber-50),#fff);border-color:var(--color-amber-100)}.form-section__body--purple{background:linear-gradient(135deg,var(--color-purple-50),#fff);border-color:var(--color-purple-100)}.form-section__body--cyan{background:linear-gradient(135deg,var(--color-cyan-50),#fff);border-color:var(--color-cyan-100);border-width:2px}.form-label{color:var(--color-gray-700);margin-bottom:8px;font-size:14px;font-weight:700;display:block}.form-label__required{color:var(--color-red-500);margin-left:2px}.form-input{border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);width:100%;font-size:14px;font-family:var(--font-body);color:var(--color-gray-900);background:#fff;outline:none;padding:12px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:var(--color-gray-300)}.form-input--mono{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.form-input--readonly{background:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}.form-input--focus-amber:focus{border-color:var(--color-amber-500);box-shadow:0 0 0 3px #f59e0b1f}.form-input--focus-purple:focus{border-color:var(--color-purple-500);box-shadow:0 0 0 3px #a855f71f}.form-select{border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);width:100%;font-size:14px;font-weight:700;font-family:var(--font-body);color:var(--color-gray-900);cursor:pointer;background:#fff;outline:none;padding:12px;transition:border-color .15s}.form-select:focus{border-color:var(--color-primary-light)}.form-select--amber:focus{border-color:var(--color-amber-500)}.form-select--purple:focus{border-color:var(--color-purple-500)}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}@media (max-width:768px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}}.form-col-2{grid-column:span 2}.form-checkbox-list{border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);background:#fff;max-height:192px;padding:16px;overflow-y:auto}.form-checkbox-list__empty{color:var(--color-gray-500);text-align:center;padding:16px 0;font-size:14px}.form-checkbox-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:12px;padding:12px;transition:background .12s;display:flex}.form-checkbox-item:hover{background:var(--color-primary-50)}.form-checkbox-item__name{color:var(--color-gray-900);font-size:14px;font-weight:700}.form-checkbox-item__code{color:var(--color-gray-500);font-size:13px;font-family:var(--font-mono)}.form-selection-confirm{background:var(--color-primary-50);border-radius:var(--radius-sm);border:1px solid var(--color-primary-200);color:var(--color-navy-800);margin-top:8px;padding:12px 16px;font-size:13px;font-weight:700}.form-field{flex-direction:column;display:flex}.form-fields-stack{flex-direction:column;gap:16px;display:flex}.gst-item{border:2px solid var(--color-amber-200);border-radius:var(--radius-lg);background:#fff;justify-content:space-between;align-items:flex-start;padding:16px;transition:border-color .15s;display:flex}.gst-item:hover{border-color:var(--color-amber-500)}.gst-item__body{flex:1}.gst-item__company{color:var(--color-navy-800);margin-bottom:4px;font-size:15px;font-weight:700}.gst-item__state{color:var(--color-gray-900);font-size:15px;font-weight:700}.gst-item__state-code{font-size:13px;font-family:var(--font-mono);color:var(--color-amber-600);margin-left:8px}.gst-item__number{font-family:var(--font-mono);color:var(--color-amber-700);font-weight:700}.gst-item__address{color:var(--color-gray-500);margin-top:4px;font-size:13px}.validation-msg{border-radius:var(--radius-lg);align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:700;display:flex}.validation-msg--loading{color:var(--color-primary);background:var(--color-primary-50);border:1px solid var(--color-primary-200)}.validation-msg--valid{color:var(--color-green-600);background:var(--color-green-50);border:1px solid var(--color-green-200)}.validation-msg--error{color:var(--color-red-600);background:var(--color-red-50);border:1px solid var(--color-red-200);align-items:flex-start}.form-no-company{background:var(--color-amber-50);border:2px solid var(--color-amber-200);border-radius:var(--radius-lg);text-align:center;padding:24px}.form-no-company__icon{background:var(--color-amber-100);border-radius:50%;margin-bottom:12px;padding:16px;display:inline-block}.form-no-company__title{color:var(--color-amber-800);font-size:17px;font-weight:700}.form-no-company__desc{color:var(--color-amber-600);margin-top:8px;font-size:13px}.contact-card{background:linear-gradient(135deg,var(--color-purple-50),#fff);border-radius:var(--radius-lg);border:2px solid var(--color-purple-100);padding:24px}.contact-card__header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.contact-card__title{color:var(--color-gray-800);font-size:15px;font-weight:700}.cluster-item{border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);cursor:pointer;background:#fff;align-items:flex-start;padding:16px;transition:background .15s,border-color .15s;display:flex}.cluster-item:hover{background:var(--color-cyan-50);border-color:var(--color-cyan-400)}.cluster-item__body{flex:1;margin-left:12px}.cluster-item__name{color:var(--color-gray-900);font-size:15px;font-weight:700}.cluster-item__code{color:var(--color-gray-500);font-size:13px;font-family:var(--font-mono);margin-top:2px;font-weight:500}.cluster-type-pill{border-radius:var(--radius-full);align-items:center;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.cluster-type-pill--accounting{color:#1d4ed8;background:linear-gradient(90deg,#dbeafe,#eff6ff);border:1px solid #bfdbfe}.cluster-type-pill--service{color:#0891b2;background:linear-gradient(90deg,#cffafe,#ecfeff);border:1px solid #a5f3fc}.cluster-type-pill--billing{color:#4338ca;background:linear-gradient(90deg,#e0e7ff,#eef2ff);border:1px solid #c7d2fe}.cluster-type-pill--default{color:#475569;background:linear-gradient(90deg,#f1f5f9,#f8fafc);border:1px solid #e2e8f0}.cluster-selected-bar{background:linear-gradient(to right,var(--color-cyan-100),var(--color-cyan-50));border-radius:var(--radius-lg);border:2px solid var(--color-cyan-200);color:var(--color-cyan-600);margin-top:16px;padding:16px;font-size:13px;font-weight:700}.cluster-empty{text-align:center;padding:48px 0}.cluster-empty__icon{background:var(--color-cyan-100);border-radius:50%;margin-bottom:16px;padding:24px;display:inline-block}.cluster-empty__title{color:var(--color-gray-700);font-size:17px;font-weight:700}.cluster-empty__desc{color:var(--color-gray-500);margin-top:8px;font-size:13px}.form-submit-row{border-top:2px solid var(--color-primary-100);gap:12px;padding-top:32px;display:flex}.view-page{background:var(--bg-view-page);min-height:100vh;font-family:var(--font-body);padding:24px}.view-page__inner{flex-direction:column;gap:24px;max-width:1200px;margin:0 auto;display:flex}.view-header{border-radius:var(--radius-2xl);border:1px solid var(--color-primary-100);box-shadow:var(--shadow-lg);background:#fff;justify-content:space-between;align-items:center;padding:32px;display:flex}.view-header__left{align-items:center;gap:16px;display:flex}.view-header__back{border-radius:var(--radius-lg);border:1px solid var(--color-primary-200);box-shadow:var(--shadow-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:12px;transition:box-shadow .15s;display:flex}.view-header__back:hover{box-shadow:var(--shadow-md)}.view-header__title{background:linear-gradient(90deg,#2563eb,#9333ea);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:12px;font-size:28px;font-weight:800;display:flex}.view-header__subtitle{color:var(--color-gray-500);margin-top:4px;font-size:14px;font-weight:500}.view-grid{grid-template-columns:1fr 1fr 1fr;align-items:start;gap:24px;display:grid}.view-grid__main{flex-direction:column;grid-column:span 2;gap:24px;display:flex}.view-grid__aside{flex-direction:column;gap:24px;display:flex}.detail-card{border-radius:var(--radius-2xl);border:1px solid var(--color-primary-100);box-shadow:var(--shadow-lg);background:#fff;padding:32px}.detail-card__header{border-bottom:2px solid var(--color-primary-100);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.detail-card__icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;padding:12px;display:flex}.detail-card__icon--blue{background:var(--color-primary-50)}.detail-card__icon--purple{background:var(--color-purple-50)}.detail-card__icon--amber{background:var(--color-amber-50)}.detail-card__icon--cyan{background:var(--color-cyan-50)}.detail-card__title{color:var(--color-gray-900);font-size:22px;font-weight:700}.detail-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.detail-grid__full{grid-column:span 2}.detail-field__label{color:var(--color-gray-500);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.detail-value{border-radius:var(--radius-lg);align-items:center;gap:12px;padding:16px;display:flex}.detail-value--blue{background:var(--color-primary-50)}.detail-value--purple{background:var(--color-purple-50)}.detail-value--orange{background:#fff7ed}.detail-value--gray{background:var(--color-gray-50)}.detail-value--green{background:var(--color-green-50)}.detail-value__text{color:var(--color-gray-900);font-size:17px;font-weight:700}.detail-value__mono{font-size:17px;font-weight:700;font-family:var(--font-mono)}.detail-value__sub{font-size:13px;font-family:var(--font-mono);margin-top:2px}.detail-company-list{background:var(--color-green-50);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:16px;display:flex}.detail-company-item{border-radius:var(--radius-sm);border:1px solid var(--color-green-200);background:#fff;padding:8px 12px}.detail-company-item__name{color:var(--color-gray-900);font-size:15px;font-weight:700}.detail-company-item__code{font-size:12px;font-family:var(--font-mono);color:var(--color-green-600)}.status-chip{border-radius:var(--radius-lg);align-items:center;gap:8px;padding:12px 16px;font-size:17px;font-weight:700;display:inline-flex}.status-chip--active{background:var(--color-gray-50);color:var(--color-green-600)}.status-chip--inactive{background:var(--color-gray-50);color:var(--color-red-600)}.contact-view-card{background:linear-gradient(135deg,var(--color-purple-50),#fff);border-radius:var(--radius-lg);border:2px solid var(--color-purple-100);padding:24px}.contact-view-card__title{color:var(--color-gray-900);align-items:center;gap:8px;margin-bottom:16px;font-size:17px;font-weight:700;display:flex}.contact-view-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.contact-view-grid__full{grid-column:span 2}.contact-view-field__label{color:var(--color-gray-500);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.contact-view-value{border-radius:var(--radius-lg);background:#fff;align-items:center;gap:12px;padding:12px;display:flex}.contact-view-value--purple{border:1px solid var(--color-purple-200)}.gst-view-card{background:linear-gradient(135deg,var(--color-amber-50),#fff);border-radius:var(--radius-lg);border:2px solid var(--color-amber-200);padding:24px}.gst-view-card__title{color:var(--color-gray-900);align-items:center;gap:8px;margin-bottom:16px;font-size:17px;font-weight:700;display:flex}.gst-view-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.gst-view-grid__full{grid-column:span 2}.gst-view-value{border-radius:var(--radius-lg);border:1px solid var(--color-amber-200);background:#fff;padding:12px}.gst-view-value__number{font-size:17px;font-family:var(--font-mono);color:var(--color-amber-700);font-weight:700}.gst-view-value__state{color:var(--color-gray-900);font-size:15px;font-weight:600}.gst-view-value__code{font-size:12px;font-family:var(--font-mono);color:var(--color-amber-600);margin-left:8px}.gst-view-value__text{color:var(--color-gray-900);font-size:15px;font-weight:600}.cluster-chip{background:linear-gradient(to right,var(--color-cyan-50),var(--color-primary-50));border-radius:var(--radius-lg);border:1px solid var(--color-cyan-200);box-shadow:var(--shadow-sm);align-items:center;gap:12px;padding:16px;transition:box-shadow .15s;display:flex}.cluster-chip:hover{box-shadow:var(--shadow-md)}.cluster-chip__icon{background:var(--color-cyan-100);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;padding:8px;display:flex}.cluster-chip__name{color:var(--color-gray-900);font-size:17px;font-weight:700}.cluster-chip__code{font-size:13px;font-family:var(--font-mono);color:var(--color-cyan-600)}.stat-panel{background:var(--gradient-stat-panel);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);color:#fff;padding:32px}.stat-panel__title{margin-bottom:24px;font-size:20px;font-weight:700}.stat-panel__list{flex-direction:column;gap:16px;display:flex}.stat-panel__row{justify-content:space-between;align-items:center;display:flex}.stat-panel__label{opacity:.9;font-size:15px;font-weight:600}.stat-panel__value{font-size:22px;font-weight:700}.view-empty{text-align:center;padding:32px 0}.view-empty__icon{background:var(--color-gray-50);border-radius:50%;margin-bottom:16px;padding:24px;display:inline-block}.view-empty__text{color:var(--color-gray-500);font-size:15px;font-weight:600}.view-error-page{background:var(--bg-view-page);min-height:100vh;padding:24px}.view-error-page__inner{max-width:800px;margin:0 auto}.view-error-card{background:var(--color-red-50);border-left:4px solid var(--color-red-500);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px}.view-error-card__content{align-items:center;gap:16px;display:flex}.view-error-card__title{color:var(--color-red-800);margin-bottom:8px;font-size:22px;font-weight:700}.view-error-card__msg{color:var(--color-red-600);font-size:15px}.search-bar-wrap{flex:1;position:relative}.search-bar-wrap__icon{pointer-events:none;color:var(--color-gray-300);display:flex;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-bar{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);width:100%;font-size:14px;font-family:var(--font-body);background:#fff;outline:none;padding:10px 16px 10px 44px;transition:border-color .15s,box-shadow .15s}.search-bar:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f61f}.search-bar::placeholder{color:var(--color-gray-300)}.controls-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;flex-direction:column;gap:16px;margin-bottom:24px;padding:20px;display:flex}.controls-panel__row{align-items:center;gap:12px;display:flex}.filter-pills{flex-wrap:wrap;gap:8px;display:flex}.filter-pill{border-radius:var(--radius-lg);font-size:13px;font-weight:600;font-family:var(--font-body);border:2px solid var(--color-gray-200);color:var(--color-gray-500);cursor:pointer;white-space:nowrap;background:#fff;padding:8px 16px;transition:border-color .15s,color .15s,background .15s}.filter-pill:hover{border-color:var(--color-primary-200);color:var(--color-primary)}.filter-pill--active{background:var(--gradient-blue-btn);color:#fff;box-shadow:var(--shadow-btn-primary);border-color:#0000}.stat-mini-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;display:grid}@media (max-width:1024px){.stat-mini-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.stat-mini-grid{grid-template-columns:1fr}}.stat-mini-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;align-items:center;gap:16px;padding:20px;display:flex}.stat-mini-card__icon{border-radius:var(--radius-lg);background:var(--color-primary-50);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-mini-card__label{color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.stat-mini-card__value{color:var(--color-gray-900);margin-top:2px;font-size:20px;font-weight:700;line-height:1.2}.vehicle-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;display:grid}@media (max-width:1280px){.vehicle-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.vehicle-grid{grid-template-columns:1fr}}.vehicle-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);cursor:pointer;background:#ffffffd9;border:1px solid #bfdbfe99;flex-direction:column;transition:box-shadow .2s,border-color .2s;display:flex;overflow:hidden}.vehicle-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-primary-light)}.vehicle-card__header{background:var(--gradient-blue-btn);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.vehicle-card__header-left{align-items:center;gap:12px;display:flex}.vehicle-card__icon{border-radius:var(--radius-lg);background:#fff3;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.vehicle-card__name{color:#fff;font-size:14px;font-weight:700;line-height:1.3}.vehicle-card__sub{color:#dbeafe;margin-top:2px;font-size:12px}.vehicle-card__payload-badge{border-radius:var(--radius-full);color:#fff;white-space:nowrap;background:#fff3;border:1px solid #ffffff4d;padding:4px 10px;font-size:11px;font-weight:700}.vehicle-card__body{flex-direction:column;flex:1;padding:20px;display:flex}.vehicle-card__desc{color:var(--color-gray-500);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:12px;line-height:1.6;display:-webkit-box;overflow:hidden}.vehicle-dims{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;display:grid}.vehicle-dim{background:var(--color-primary-50);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);text-align:center;padding:10px}.vehicle-dim__label{color:var(--color-primary-pale);margin-bottom:2px;font-size:11px;font-weight:700}.vehicle-dim__value{color:var(--color-gray-900);font-size:13px;font-weight:700}.vehicle-payload{background:var(--color-primary-50);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}.vehicle-payload__label{color:var(--color-gray-500);align-items:center;gap:8px;font-size:12px;font-weight:500;display:flex}.vehicle-payload__value{color:var(--color-gray-900);text-align:right;font-size:14px;font-weight:700}.vehicle-payload__tol{color:var(--color-slate-400);font-size:11px}.vehicle-card__actions{border-top:1px solid var(--color-primary-100);gap:8px;margin-top:auto;padding-top:12px;display:flex}.vehicle-card__btn-edit{background:var(--gradient-blue-btn);color:#fff;border-radius:var(--radius-lg);font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;box-shadow:var(--shadow-btn-primary);border:none;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px;transition:opacity .15s;display:flex}.vehicle-card__btn-edit:hover{opacity:.9}.vehicle-card__btn-delete{border:2px solid var(--color-primary-200);color:var(--color-primary-pale);border-radius:var(--radius-lg);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:10px 16px;transition:background .15s,border-color .15s;display:flex}.vehicle-card__btn-delete:hover{background:var(--color-primary-50);border-color:var(--color-primary-light)}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.45}}.skeleton-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;padding:24px;animation:1.5s ease-in-out infinite skeleton-pulse}.skeleton-card__top{gap:16px;margin-bottom:20px;display:flex}.skeleton-card__avatar{background:var(--color-primary-100);border-radius:var(--radius-lg);flex-shrink:0;width:48px;height:48px}.skeleton-card__lines{flex-direction:column;flex:1;gap:8px;padding-top:4px;display:flex}.skeleton-line{background:var(--color-primary-50);border-radius:6px;height:12px}.skeleton-line--wide{width:75%}.skeleton-line--mid{width:50%}.skeleton-line--full{width:100%}.skeleton-card__body{flex-direction:column;gap:8px;display:flex}.empty-state--search{text-align:center;color:var(--color-slate-400);padding:80px 40px}.empty-state--search__icon{opacity:.2;margin:0 auto 16px;display:block}.empty-state--search__title{color:var(--color-gray-500);margin-bottom:4px;font-size:18px;font-weight:700}.empty-state--search__sub{color:var(--color-slate-400);font-size:14px}.pagination{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.pagination__info{color:var(--color-gray-500);font-size:13px}.pagination__info strong{color:var(--color-gray-900);font-weight:700}.pagination__controls{align-items:center;gap:8px;display:flex}.pagination__btn{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);cursor:pointer;color:var(--color-gray-500);background:0 0;justify-content:center;align-items:center;padding:10px;transition:border-color .15s,background .15s;display:flex}.pagination__btn:hover:not(:disabled){border-color:var(--color-primary-200);background:var(--color-primary-50)}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__page{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);cursor:pointer;width:40px;height:40px;font-size:13px;font-weight:700;font-family:var(--font-body);color:var(--color-gray-500);background:0 0;transition:border-color .15s,color .15s}.pagination__page:hover{border-color:var(--color-primary-200);color:var(--color-primary)}.pagination__page--active{background:var(--gradient-blue-btn);color:#fff;box-shadow:var(--shadow-btn-primary);border-color:#0000}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);background:#fff;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0000002e}.modal::-webkit-scrollbar{width:5px}.modal::-webkit-scrollbar-thumb{background:var(--color-primary-200);border-radius:4px}.modal__header{background:var(--gradient-blue-btn);border-radius:var(--radius-xl)var(--radius-xl)0 0;justify-content:space-between;align-items:center;padding:24px;display:flex}.modal__header-left{align-items:center;gap:12px;display:flex}.modal__header-icon{border-radius:var(--radius-lg);background:#fff3;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.modal__header-title{color:#fff;font-size:17px;font-weight:700}.modal__header-sub{color:#dbeafe;margin-top:2px;font-size:12px}.modal__close{border-radius:var(--radius-md);cursor:pointer;color:#fff;background:0 0;border:none;padding:8px;transition:background .15s}.modal__close:hover{background:#fff3}.modal__body{flex-direction:column;gap:20px;padding:24px;display:flex}.modal__section-label{color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:700}.modal__section-text{color:var(--color-gray-800);font-size:14px;line-height:1.6}.modal-spec-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.modal-spec{background:var(--color-primary-50);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);text-align:center;padding:16px}.modal-spec__label{color:var(--color-primary-pale);margin-bottom:4px;font-size:11px;font-weight:700}.modal-spec__value{color:var(--color-gray-900);font-size:15px;font-weight:700}.modal-info-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.modal-info{background:var(--color-primary-50);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);padding:16px}.modal-info__label{color:var(--color-gray-500);margin-bottom:4px;font-size:11px;font-weight:700}.modal-info__value{color:var(--color-gray-900);font-size:15px;font-weight:700}.modal__footer{border-top:1px solid var(--color-primary-100);gap:12px;padding-top:16px;display:flex}.modal-form-label{color:var(--color-gray-700);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.modal-form-section-label{color:var(--color-gray-700);margin-bottom:12px;font-size:13px;font-weight:700}.modal-input{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);width:100%;font-size:14px;font-family:var(--font-body);background:#fff;outline:none;padding:12px;transition:border-color .15s,box-shadow .15s}.modal-input:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f61f}.modal-input::placeholder{color:var(--color-gray-300)}.modal-textarea{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);width:100%;font-size:14px;font-family:var(--font-body);resize:none;background:#fff;outline:none;padding:12px;transition:border-color .15s,box-shadow .15s}.modal-textarea:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f61f}.modal-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.modal-grid-3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.icon-btn{border-radius:var(--radius-lg);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:12px;transition:background .15s,transform .15s;display:flex}.icon-btn:hover{background:var(--color-primary-50);transform:scale(1.05)}.booking-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:0;display:grid}@media (max-width:768px){.booking-stats-grid{grid-template-columns:repeat(2,1fr)}}.booking-stat{border-radius:var(--radius-lg);border-style:solid;border-width:1px;padding:16px}.booking-stat--blue{background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));border-color:var(--color-primary-200)}.booking-stat--amber{background:linear-gradient(135deg,var(--color-amber-50),var(--color-amber-100));border-color:var(--color-amber-200)}.booking-stat--green{background:linear-gradient(135deg,var(--color-green-50),var(--color-green-100));border-color:var(--color-green-200)}.booking-stat--red{background:linear-gradient(135deg,var(--color-red-50),var(--color-red-100));border-color:var(--color-red-200)}.booking-stat__label{text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:700}.booking-stat--blue .booking-stat__label{color:var(--color-navy-800)}.booking-stat--amber .booking-stat__label{color:var(--color-amber-700)}.booking-stat--green .booking-stat__label{color:var(--color-green-700)}.booking-stat--red .booking-stat__label{color:var(--color-red-700)}.booking-stat__value{color:var(--color-gray-900);font-size:24px;font-weight:700}.filter-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;flex-direction:column;gap:24px;margin-bottom:32px;padding:24px;display:flex}.filter-panel__row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.filter-select{border:1px solid var(--color-primary-200);border-radius:var(--radius-lg);font-size:14px;font-family:var(--font-body);color:var(--color-gray-700);cursor:pointer;background:#fff;outline:none;padding:12px 16px;transition:border-color .15s}.filter-select:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #3b82f61a}.filter-select--wide{min-width:170px}.sort-toggle-btn{border:1px solid var(--color-primary-200);border-radius:var(--radius-lg);color:var(--color-primary);cursor:pointer;background:#fff;justify-content:center;align-items:center;padding:12px;transition:background .15s;display:flex}.sort-toggle-btn:hover{background:var(--color-primary-50)}.sort-active-tag{background:var(--color-primary-100);color:var(--color-navy-800);border-radius:var(--radius-full);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.sort-active-tag__clear{cursor:pointer;color:inherit;background:0 0;border:none;align-items:center;margin-left:2px;padding:0;transition:color .12s;display:flex}.sort-active-tag__clear:hover{color:var(--color-red-500)}.sort-active-row{align-items:center;gap:8px;display:flex}.sort-active-row__label{color:var(--color-primary);font-size:12px;font-weight:700}.quick-filters-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;margin-bottom:32px;padding:24px}.quick-filters-panel__heading{align-items:center;gap:12px;margin-bottom:16px;display:flex}.quick-filters-panel__icon{background:var(--color-primary-50);border-radius:var(--radius-sm);justify-content:center;align-items:center;padding:8px;display:flex}.quick-filters-panel__title{color:var(--color-gray-900);font-size:17px;font-weight:700}.quick-filter-btns{flex-wrap:wrap;gap:12px;display:flex}.qf-btn{border-radius:var(--radius-lg);font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;box-shadow:var(--shadow-sm);align-items:center;gap:8px;padding:10px 24px;transition:all .15s;display:inline-flex}.qf-btn:hover{box-shadow:var(--shadow-md)}.qf-btn__count{border-radius:var(--radius-full);background:#ffffff40;padding:2px 10px;font-size:12px;font-weight:700}.qf-btn--all{color:var(--color-gray-700);border:1px solid var(--color-gray-300);background:#fff}.qf-btn--pending{color:var(--color-amber-700);border:1px solid var(--color-amber-200);background:#fff}.qf-btn--accepted{color:var(--color-primary);border:1px solid var(--color-primary-200);background:#fff}.qf-btn--progress{color:var(--color-purple-600);border:1px solid var(--color-purple-200);background:#fff}.qf-btn--complete{color:var(--color-green-700);border:1px solid var(--color-green-200);background:#fff}.qf-btn--cancel{color:var(--color-red-600);border:1px solid var(--color-red-200);background:#fff}.qf-btn--all:hover{background:var(--color-gray-50)}.qf-btn--pending:hover{background:var(--color-amber-50)}.qf-btn--accepted:hover{background:var(--color-primary-50)}.qf-btn--progress:hover{background:var(--color-purple-50)}.qf-btn--complete:hover{background:var(--color-green-50)}.qf-btn--cancel:hover{background:var(--color-red-50)}.qf-btn--all.qf-btn--on{color:#fff;background:linear-gradient(90deg,#4b5563,#374151);border-color:#0000;box-shadow:0 3px 10px #3741514d}.qf-btn--pending.qf-btn--on{color:#fff;background:linear-gradient(90deg,#f59e0b,#d97706);border-color:#0000;box-shadow:0 3px 10px #f59e0b59}.qf-btn--accepted.qf-btn--on{background:var(--gradient-blue-btn);color:#fff;box-shadow:var(--shadow-btn-primary);border-color:#0000}.qf-btn--progress.qf-btn--on{color:#fff;background:linear-gradient(90deg,#a855f7,#9333ea);border-color:#0000;box-shadow:0 3px 10px #a855f759}.qf-btn--complete.qf-btn--on{color:#fff;background:linear-gradient(90deg,#22c55e,#16a34a);border-color:#0000;box-shadow:0 3px 10px #22c55e59}.qf-btn--cancel.qf-btn--on{color:#fff;background:linear-gradient(90deg,#ef4444,#dc2626);border-color:#0000;box-shadow:0 3px 10px #ef444459}.qf-btn--on .qf-btn__count{background:#fff3}.booking-table-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:#ffffffd9;border:1px solid #bfdbfe99;margin-bottom:32px;overflow:hidden}.booking-table{border-collapse:collapse;width:100%}.booking-table thead tr{background:#eff6ffcc}.booking-table th{text-align:left;color:var(--color-navy-800);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:16px 24px;font-size:11px;font-weight:700}.booking-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .12s}.booking-table th.sortable:hover{color:var(--color-navy-900)}.booking-table tbody tr{border-top:1px solid #dbeafe80;transition:background .12s}.booking-table tbody tr:hover{background:#eff6ff80}.booking-table tbody tr.highlighted{border-left:4px solid var(--color-primary-light);background:#eff6ffd9}.booking-table td{vertical-align:middle;padding:16px 24px}.booking-cell-customer__name{color:var(--color-gray-900);font-size:14px;font-weight:600}.booking-cell-customer__phone{color:var(--color-gray-500);margin-top:2px;font-size:12px}.booking-route{flex-direction:column;gap:4px;max-width:200px;display:flex}.booking-route__row{align-items:center;gap:6px;display:flex}.booking-route__dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.booking-route__dot--from{background:var(--color-green-500)}.booking-route__dot--to{background:var(--color-red-500)}.booking-route__addr{color:var(--color-gray-500);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.booking-vehicle{align-items:center;gap:6px;display:flex}.booking-vehicle__type{color:var(--color-gray-700);white-space:nowrap;font-size:14px}.booking-vehicle__weight{color:var(--color-gray-500);margin-top:2px;font-size:12px}.booking-date{color:var(--color-gray-700);white-space:nowrap;font-size:14px}.booking-date__time{color:var(--color-gray-500);margin-top:2px;font-size:12px}.status-badge{border-radius:var(--radius-full);color:#fff;white-space:nowrap;box-shadow:var(--shadow-sm);align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.status-badge--pending{background:linear-gradient(90deg,#f59e0b,#d97706)}.status-badge--accepted{background:linear-gradient(90deg,#3b82f6,#2563eb)}.status-badge--complete{background:linear-gradient(90deg,#22c55e,#16a34a)}.status-badge--cancel{background:linear-gradient(90deg,#ef4444,#dc2626)}.status-badge--progress{background:linear-gradient(90deg,#a855f7,#9333ea)}.status-badge--default{background:linear-gradient(90deg,#9ca3af,#6b7280)}.mode-badge{border-radius:var(--radius-full);color:#fff;white-space:nowrap;box-shadow:var(--shadow-sm);align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-flex}.mode-badge--now{background:linear-gradient(90deg,#f97316,#ea580c)}.mode-badge--scheduled{background:linear-gradient(90deg,#6366f1,#4f46e5)}.tbl-action-btn{border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:10px;transition:background .15s,color .15s;display:flex}.tbl-action-btn:hover{box-shadow:var(--shadow-md)}.tbl-action-btn--view{color:var(--color-primary)}.tbl-action-btn--view:hover{background:var(--color-primary);color:#fff}.tbl-action-btn--edit{color:var(--color-primary)}.tbl-action-btn--edit:hover{background:var(--color-primary);color:#fff}.tbl-action-btn--delete{color:var(--color-red-600)}.tbl-action-btn--delete:hover{background:var(--color-red-600);color:#fff}.booking-table-state{text-align:center;padding:80px 24px}.booking-table-state__spinner{border:4px solid var(--color-primary-light);border-top-color:#0000;border-radius:50%;width:64px;height:64px;margin-bottom:24px;animation:.8s linear infinite spin;display:inline-block}.booking-table-state__icon{background:var(--color-primary-50);border-radius:50%;margin-bottom:24px;padding:32px;display:inline-block}.booking-table-state__title{color:var(--color-gray-900);margin-bottom:8px;font-size:22px;font-weight:700}.booking-table-state__sub{color:var(--color-primary);font-size:16px}.booking-table-footer{border-top:1px solid var(--color-primary-100);background:#eff6ff66;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.booking-table-footer__info{color:var(--color-gray-500);font-size:13px}.booking-table-footer__controls{align-items:center;gap:8px;display:flex}.booking-table-footer__page-info{color:var(--color-gray-700);padding:0 16px;font-size:13px;font-weight:700}.booking-table-footer__btn{border-radius:var(--radius-lg);border:1px solid var(--color-primary-200);cursor:pointer;color:var(--color-primary);box-shadow:var(--shadow-sm);background:0 0;justify-content:center;align-items:center;padding:10px;transition:background .15s,color .15s;display:flex}.booking-table-footer__btn:hover:not(:disabled){background:var(--color-primary);color:#fff}.booking-table-footer__btn:disabled{opacity:.4;cursor:not-allowed}.modal--wide{max-width:896px}.modal-sub-header{border-bottom:1px solid var(--color-primary-100);background:linear-gradient(to right,var(--color-primary-50),#dbeafe4d);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.modal-sub-header__title{color:var(--color-gray-900);font-size:20px;font-weight:700}.modal-sub-header__subtitle{color:var(--color-primary);font-size:13px;font-family:var(--font-mono);margin-top:2px}.modal-sub-header__close{border-radius:var(--radius-sm);cursor:pointer;color:var(--color-gray-500);background:0 0;border:none;padding:8px;transition:background .12s}.modal-sub-header__close:hover{background:#fff}.modal-scroll-body{max-height:calc(90vh - 140px);padding:24px;overflow-y:auto}.modal-scroll-body::-webkit-scrollbar{width:5px}.modal-scroll-body::-webkit-scrollbar-thumb{background:var(--color-primary-200);border-radius:4px}.modal-section-title{color:var(--color-gray-900);align-items:center;gap:8px;margin-bottom:16px;padding-top:8px;font-size:17px;font-weight:700;display:flex}.modal-detail-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.modal-detail-grid__full{grid-column:span 2}.modal-detail-label{color:var(--color-gray-500);align-items:center;gap:4px;margin-bottom:4px;font-size:13px;font-weight:700;display:flex}.modal-detail-value{color:var(--color-gray-900);font-size:14px}.modal-detail-value--mono{font-family:var(--font-mono);letter-spacing:.1em;font-size:20px;font-weight:700}.modal-route-block{background:var(--color-primary-50);border-radius:var(--radius-lg);flex-direction:column;gap:4px;padding:16px;display:flex}.modal-route-block__stop{gap:12px;display:flex}.modal-route-block__dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:3px}.modal-route-block__dot--from{background:var(--color-green-500)}.modal-route-block__dot--to{background:var(--color-red-500)}.modal-route-block__dir-label{text-transform:uppercase;margin-bottom:2px;font-size:11px;font-weight:700}.modal-route-block__dir-label--from{color:var(--color-green-700)}.modal-route-block__dir-label--to{color:var(--color-red-700)}.modal-route-block__addr{color:var(--color-gray-900);font-size:14px}.modal-route-block__coords{color:var(--color-gray-500);margin-top:2px;font-size:12px}.modal-route-block__divider{background:var(--color-primary-200);width:2px;height:24px;margin-left:5px}.modal-chips-row{flex-wrap:wrap;grid-column:span 2;align-items:center;gap:12px;display:flex}.mode-chip{border-radius:var(--radius-full);align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:700;display:inline-flex}.mode-chip--now{color:#c2410c;background:#ffedd5}.mode-chip--scheduled{color:#4338ca;background:#e0e7ff}.mode-chip--accepted{background:var(--color-green-100);color:var(--color-green-700)}.req-chip{border-radius:var(--radius-full);padding:6px 12px;font-size:12px;font-weight:700}.req-chip--active{background:var(--color-primary);color:#fff}.req-chip--inactive{background:var(--color-gray-100);color:var(--color-gray-400);text-decoration:line-through}.driver-chip{background:var(--color-amber-100);color:var(--color-amber-700);border-radius:var(--radius-full);padding:4px 12px;font-size:12px;font-weight:700}.modal-instructions{background:var(--color-gray-50);border-radius:var(--radius-sm);color:var(--color-gray-900);padding:12px;font-size:14px}.modal-timestamps{color:var(--color-gray-500);border-top:1px solid var(--color-gray-100);flex-wrap:wrap;grid-column:span 2;gap:24px;padding-top:16px;font-size:12px;display:flex}.modal-footer-bar{border-top:1px solid var(--color-primary-100);background:var(--color-gray-50);justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px;display:flex}.req-checkbox-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (max-width:640px){.req-checkbox-grid{grid-template-columns:repeat(2,1fr)}}.req-checkbox-item{border-radius:var(--radius-lg);border:2px solid var(--color-gray-200);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:border-color .12s,background .12s;display:flex}.req-checkbox-item--on{border-color:var(--color-primary-light);background:var(--color-primary-50)}.req-checkbox-item--off{background:var(--color-gray-50)}.req-checkbox-item__label{text-transform:capitalize;font-size:13px;font-weight:700}.req-checkbox-item--on .req-checkbox-item__label{color:var(--color-navy-800)}.req-checkbox-item--off .req-checkbox-item__label{color:var(--color-gray-500)}.rupee-icon{font-size:16px;font-weight:800;display:inline-flex}.rupee-icon--sm{font-size:13px;font-weight:800;display:inline-flex}
