@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;600;700;900&family=Sora:wght@300;400;600;700&display=swap');

:root {
  --bg-primary:#f0f4f8;--bg-secondary:#fff;--bg-card:#fff;
  --bg-sidebar:#0f2140;--bg-header:#fff;
  --text-primary:#0f2140;--text-secondary:#4a5568;--text-muted:#718096;
  --text-sidebar:#e2e8f0;
  --accent:#1a56db;--accent-hover:#1545b8;--accent-light:#ebf0ff;
  --success:#10b981;--success-bg:#d1fae5;
  --danger:#ef4444;--danger-bg:#fee2e2;
  --warning:#f59e0b;--warning-bg:#fef3c7;
  --border:#e2e8f0;--border-focus:#1a56db;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow-md:0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:0 8px 32px rgba(0,0,0,.14);
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;
  --sidebar-width:260px;--header-height:64px;
  --transition:all .22s cubic-bezier(.4,0,.2,1);
}
[data-theme="dark"]{
  --bg-primary:#0d1b2a;--bg-secondary:#162032;--bg-card:#1e2d42;
  --bg-sidebar:#08111d;--bg-header:#162032;
  --text-primary:#e2e8f0;--text-secondary:#a0aec0;--text-muted:#718096;
  --accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#1e3a5f;
  --success:#34d399;--success-bg:#064e3b;
  --danger:#f87171;--danger-bg:#7f1d1d;
  --warning:#fbbf24;--warning-bg:#78350f;
  --border:#2d3f55;--border-focus:#3b82f6;
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);
  --shadow-md:0 4px 16px rgba(0,0,0,.4);
  --shadow-lg:0 8px 32px rgba(0,0,0,.5);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Sora',sans-serif;
  background:var(--bg-primary);color:var(--text-primary);
  transition:background .3s,color .3s;min-height:100vh;
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
[lang="ar"] body,[dir="rtl"] body{font-family:'Cairo',sans-serif}
a{color:var(--accent);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent-hover)}

/* Layout */
.app-layout{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:var(--sidebar-width);background:var(--bg-sidebar);
  position:fixed;top:0;left:0;bottom:0;
  display:flex;flex-direction:column;z-index:100;
  transition:var(--transition);box-shadow:2px 0 16px rgba(0,0,0,.18);overflow-y:auto;
}
[dir="rtl"] .sidebar{left:auto;right:0;box-shadow:-2px 0 16px rgba(0,0,0,.18)}
.sidebar-logo{padding:24px 20px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08)}
.logo-icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.logo-text{color:#fff;font-size:15px;font-weight:700;line-height:1.3}
.logo-sub{color:rgba(255,255,255,.45);font-size:11px}
.sidebar-nav{padding:16px 0;flex:1}
.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:10px 20px;color:var(--text-sidebar);font-size:13.5px;transition:var(--transition)}
.sidebar-nav a .nav-icon{font-size:17px;opacity:.75;flex-shrink:0}
.sidebar-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.sidebar-nav a.active{background:var(--accent);color:#fff;font-weight:600}
.sidebar-nav a.active .nav-icon{opacity:1}
.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);text-decoration:none}
.sidebar-user:hover{background:rgba(255,255,255,.06)}
.sidebar-avatar{width:36px;height:36px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-name{color:#fff;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar-user-role{color:rgba(255,255,255,.4);font-size:11px}

/* Main */
.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}
[dir="rtl"] .main-content{margin-left:0;margin-right:var(--sidebar-width)}

/* Header */
.top-header{height:var(--header-height);background:var(--bg-header);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}
.header-title{font-size:17px;font-weight:700}
.header-actions{display:flex;align-items:center;gap:8px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 20px;font-size:13.5px;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:var(--transition);white-space:nowrap;font-family:inherit;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 14px rgba(26,86,219,.35);color:#fff}
.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1.5px solid var(--border)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{opacity:.9}
.btn-success{background:var(--success);color:#fff}
.btn-sm{padding:6px 14px;font-size:12.5px}
.btn-lg{padding:12px 28px;font-size:15px}
.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);background:var(--bg-primary);border:1.5px solid var(--border);color:var(--text-secondary)}
.btn-icon:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}

/* Toggle */
.toggle-group{display:flex;gap:4px}
.toggle-btn{padding:6px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit;text-decoration:none;display:inline-flex;align-items:center}
.toggle-btn.active,.toggle-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* Page */
.page-content{padding:28px;flex:1}
.page-header{margin-bottom:24px}
.page-header h2{font-size:22px;font-weight:800}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.section-title{font-size:16px;font-weight:700}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:28px}
.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:16px;transition:var(--transition)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.stat-icon.blue{background:var(--accent-light)}
.stat-icon.green{background:var(--success-bg)}
.stat-icon.yellow{background:var(--warning-bg)}
.stat-icon.red{background:var(--danger-bg)}
.stat-value{font-size:26px;font-weight:700;line-height:1}
.stat-label{font-size:12.5px;color:var(--text-muted);margin-top:3px}

/* Card */
.card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}
.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:15px;font-weight:700}
.card-body{padding:22px}

/* Table */
.table-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{background:var(--bg-primary);padding:11px 16px;text-align:start;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}
tbody td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bg-primary)}

/* Badge */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:11.5px;font-weight:600;white-space:nowrap}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-danger{background:var(--danger-bg);color:var(--danger)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}
.badge-info{background:var(--accent-light);color:var(--accent)}

/* Form */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.form-control{width:100%;padding:10px 14px;background:var(--bg-primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:inherit;transition:var(--transition);outline:none}
.form-control:focus{border-color:var(--border-focus);background:var(--bg-secondary);box-shadow:0 0 0 3px rgba(26,86,219,.12)}
.form-control::placeholder{color:var(--text-muted)}
.form-control:disabled{opacity:.6;cursor:not-allowed}
select.form-control{cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Alert */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.alert-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}
.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}

/* Auth */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}
.auth-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:44px 40px;width:100%;max-width:440px;border:1px solid var(--border);animation:fadeSlideUp .5s ease}
.auth-logo{text-align:center;margin-bottom:28px}
.logo-circle{width:64px;height:64px;background:var(--accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 12px}
.auth-logo h1{font-size:22px;font-weight:800}
.auth-tabs{display:flex;background:var(--bg-primary);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px}
.auth-tab{flex:1;padding:8px;text-align:center;border-radius:calc(var(--radius-sm) - 2px);font-size:13.5px;font-weight:600;cursor:pointer;transition:var(--transition);color:var(--text-secondary);border:none;background:transparent;font-family:inherit}
.auth-tab.active{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
.auth-actions-top{position:fixed;top:16px;right:16px;display:flex;gap:8px;z-index:200}
[dir="rtl"] .auth-actions-top{right:auto;left:16px}

/* QR */
.qr-plate{font-size:20px;font-weight:800;letter-spacing:.08em;background:var(--bg-primary);border:2px solid var(--border);border-radius:var(--radius-sm);padding:8px 20px;display:inline-block;margin-top:8px}

/* Vehicle / Verify */
.verify-row{display:flex;justify-content:space-between;align-items:center;padding:13px 22px;border-bottom:1px solid var(--border)}
.verify-row:last-child{border-bottom:none}
.verify-key{font-size:13px;color:var(--text-muted);font-weight:500}
.verify-val{font-size:14px;font-weight:700;color:var(--text-primary)}
.verify-plate-display{font-size:28px;font-weight:900;letter-spacing:.12em;background:rgba(255,255,255,.2);padding:10px 24px;border-radius:var(--radius-sm);display:inline-block;margin-top:10px}
.vehicle-plate-badge{font-family:'Courier New',monospace;font-size:14px;font-weight:800;letter-spacing:.1em;background:var(--bg-primary);border:2px solid var(--border);border-radius:4px;padding:3px 10px;display:inline-block}

/* Drivers */
.drivers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.driver-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:16px;display:flex;align-items:center;gap:14px;transition:var(--transition)}
.driver-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.driver-avatar{width:44px;height:44px;background:var(--accent-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--accent);flex-shrink:0}
.driver-name{font-size:14px;font-weight:700}
.driver-meta{font-size:12px;color:var(--text-muted);margin-top:2px}

/* Doc grid */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.doc-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:16px;border:1.5px solid var(--border);display:flex;align-items:center;gap:14px;transition:var(--transition)}
.doc-card:hover{border-color:var(--accent)}
.doc-icon{font-size:26px}
.doc-name{font-size:14px;font-weight:600}
.doc-meta{font-size:12px;color:var(--text-muted);margin-top:2px}

/* Search hero */
.search-hero{background:linear-gradient(135deg,var(--accent),#0f4c9e);border-radius:var(--radius-lg);padding:36px 32px;text-align:center;color:#fff;margin-bottom:28px}
.search-hero h2{font-size:22px;font-weight:800;margin-bottom:6px}
.search-hero p{opacity:.8;font-size:14px;margin-bottom:20px}
.search-input-group{display:flex;gap:10px;max-width:500px;margin:0 auto}
.search-input-group .form-control{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:#fff}
.search-input-group .form-control::placeholder{color:rgba(255,255,255,.6)}
.search-input-group .form-control:focus{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.7);box-shadow:none}

/* Empty */
.empty-state{text-align:center;padding:52px 20px;color:var(--text-muted)}
.empty-state-icon{font-size:52px;margin-bottom:12px;opacity:.4}
.empty-state h3{font-size:17px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}

/* Helpers */
.font-bold{font-weight:700}
.text-muted{color:var(--text-muted)}
.text-success{color:var(--success)}
.text-danger{color:var(--danger)}
hr{border:none;border-top:1px solid var(--border);margin:20px 0}

/* Animations */
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  [dir="rtl"] .sidebar{transform:translateX(100%)}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0!important;margin-right:0!important}
  .page-content{padding:16px}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .auth-card{padding:28px 20px}
  .mobile-menu-btn{display:flex!important}
  .top-header{padding:0 16px}
}
.mobile-menu-btn{display:none!important}
