/* ═══════════════════════════════════════════════════════════════════════════
   نظام تسجيل المركبات – إدارة المرور بالإسكندرية
   Professional Government UI  |  RTL Arabic
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Reset ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

/* ─── Design tokens ──────────────────────────────────────────────────────────── */
:root {
    --navy:        #1b3a6b;
    --navy-dark:   #122850;
    --navy-light:  #2e5496;
    --navy-hover:  #243f74;
    --gold:        #b8972a;
    --gold-light:  #f5e9c4;
    --white:       #ffffff;
    --page-bg:     #eaecf0;
    --panel-bg:    #ffffff;
    --input-bg:    #f8f9fc;
    --border:      #c8cdd6;
    --border-light:#e4e7ed;
    --text:        #1a1a2e;
    --text-muted:  #5a6070;
    --text-light:  #8a92a0;
    --row-alt:     #f5f7fb;

    --green:       #1a6b3c;
    --green-bg:    #edf7f1;
    --green-border:#b0d9c0;
    --red:         #b91c1c;
    --red-bg:      #fef2f2;
    --red-border:  #fca5a5;
    --amber:       #8a5700;
    --amber-bg:    #fffbeb;
    --amber-border:#fcd34d;
    --blue:        #1a4a7a;
    --blue-bg:     #eff6ff;
    --blue-border: #bfdbfe;

    --shadow-sm:   0 1px 3px rgba(0,0,0,0.10), 0 1px 2px rgba(0,0,0,0.06);
    --shadow:      0 2px 6px rgba(0,0,0,0.10), 0 4px 16px rgba(0,0,0,0.06);
    --shadow-md:   0 4px 12px rgba(0,0,0,0.12), 0 8px 24px rgba(0,0,0,0.06);

    --radius-sm:   3px;
    --radius:      5px;
    --font:        'Segoe UI', 'Helvetica Neue', Arial, sans-serif;

    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
}

/* ─── Base ───────────────────────────────────────────────────────────────────── */
html { font-size: 15px; }
body { font-family: var(--font); background: var(--page-bg); color: var(--text);
       min-height: 100vh; direction: rtl; line-height: 1.5; }
a    { color: var(--navy-light); text-decoration: none; }
a:hover { color: var(--navy); text-decoration: underline; }
ul, ol { margin-inline-start: 18px; margin-bottom: 12px; }
li     { font-size: 0.88em; margin: 5px 0; }

/* ─── Site header ────────────────────────────────────────────────────────────── */
.site-header {
    background: var(--navy);
    color: var(--white);
    box-shadow: 0 2px 8px rgba(0,0,0,0.35);
    position: sticky;
    top: 0;
    z-index: 200;
    border-bottom: 3px solid var(--gold);
}
.header-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-5);
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 58px;
    gap: var(--space-4);
}
.header-brand { display: flex; align-items: center; gap: var(--space-3); }
.header-emblem {
    width: 38px; height: 38px;
    background: var(--gold);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.header-title    { font-size: 0.95em; font-weight: 700; letter-spacing: 0.3px; }
.header-subtitle { font-size: 0.72em; color: rgba(255,255,255,0.60); }
.header-user     { display: flex; align-items: center; gap: var(--space-3); font-size: 0.82em; }
.header-user .user-pill {
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.18);
    padding: 3px 10px; border-radius: 20px;
    display: flex; align-items: center; gap: 5px;
}
.header-user .user-pill span   { color: rgba(255,255,255,0.65); font-size: 0.88em; }
.header-user .user-pill strong { color: var(--white); }
.header-user .logout-link {
    color: var(--gold-light); font-weight: 600;
    border: 1px solid rgba(184,151,42,0.45);
    padding: 4px 12px; border-radius: var(--radius-sm);
    transition: background 0.15s;
}
.header-user .logout-link:hover { background: rgba(184,151,42,0.15); text-decoration: none; }

/* ─── Secondary nav ──────────────────────────────────────────────────────────── */
.site-nav { background: var(--navy-dark); }
.site-nav-inner {
    max-width: 1200px; margin: 0 auto; padding: 0 var(--space-5);
    display: flex; align-items: stretch; min-height: 38px;
}
.site-nav a {
    color: rgba(255,255,255,0.72); text-decoration: none;
    font-size: 0.80em; font-weight: 500;
    padding: 0 var(--space-4);
    display: flex; align-items: center; white-space: nowrap;
    border-inline-start: 1px solid rgba(255,255,255,0.09);
    transition: background 0.15s, color 0.15s;
    position: relative;
}
.site-nav a:first-child { border-inline-start: none; }
.site-nav a:hover  { background: rgba(255,255,255,0.09); color: var(--white); text-decoration: none; }
.site-nav a.active { background: var(--navy-hover); color: var(--white); font-weight: 600; }
.site-nav a.active::after {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0;
    height: 2px; background: var(--gold);
}

/* ─── Breadcrumb ─────────────────────────────────────────────────────────────── */
.breadcrumb {
    font-size: 0.78em; color: var(--text-muted);
    margin: 0 0 var(--space-4);
    display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.breadcrumb a { color: var(--navy-light); }
.breadcrumb a:hover { color: var(--navy); }
.breadcrumb .sep { color: var(--border); user-select: none; }
.breadcrumb .current { color: var(--text); font-weight: 500; }

/* ─── Page layout ────────────────────────────────────────────────────────────── */
.page-wrapper {
    max-width: 1200px; margin: 0 auto;
    padding: var(--space-6) var(--space-5) 48px;
}
/* Width modifiers – replaces inline max-width overrides */
.page-wrapper.narrow  { max-width: 580px; }
.page-wrapper.medium  { max-width: 820px; }

/* ─── Page title row ─────────────────────────────────────────────────────────── */
.page-title {
    display: flex; align-items: center; gap: var(--space-3);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--navy);
}
.page-title h1 {
    font-size: 1.30em; font-weight: 700; color: var(--navy);
    letter-spacing: 0.2px;
}
.title-icon {
    width: 32px; height: 32px; background: var(--navy); color: var(--white);
    border-radius: var(--radius-sm); display: flex; align-items: center;
    justify-content: center; font-size: 0.85em; flex-shrink: 0;
}
/* Optional right-side actions inside page-title */
.page-title .title-actions { margin-inline-start: auto; display: flex; gap: var(--space-2); }

/* ─── Info bar ───────────────────────────────────────────────────────────────── */
.info-bar {
    background: #f2f4f8; border: 1px solid var(--border);
    border-radius: var(--radius); padding: var(--space-3) var(--space-4);
    display: flex; gap: var(--space-6); flex-wrap: wrap;
    align-items: center; margin-bottom: var(--space-4);
    font-size: 0.86em;
}
.info-bar dt { color: var(--text-muted); font-weight: 600; display: inline; }
.info-bar dd { color: var(--text); display: inline; margin-inline-start: 4px; }

/* ─── Cards ──────────────────────────────────────────────────────────────────── */
.card {
    background: var(--panel-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-4);
    overflow: hidden;
}
.card-header {
    background: #f2f4f8; border-bottom: 1px solid var(--border);
    padding: var(--space-3) var(--space-4);
    font-size: 0.85em; font-weight: 700; color: var(--navy);
    display: flex; align-items: center; gap: var(--space-2);
    min-height: 40px;
}
.card-header .card-header-action {
    margin-inline-start: auto;
}
.card-body { padding: var(--space-4); }
.card-body.flush { padding: 0; }
.card-body.spacious { padding: var(--space-5) var(--space-6); }

/* ─── Stat cards ─────────────────────────────────────────────────────────────── */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: var(--space-4); margin-bottom: var(--space-4);
}
.stat-card {
    background: var(--panel-bg);
    border: 1px solid var(--border);
    border-top: 3px solid var(--navy);
    border-radius: var(--radius);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
    display: flex; flex-direction: column; gap: 6px;
}
.stat-card.gold   { border-top-color: var(--gold); }
.stat-card.green  { border-top-color: var(--green); }
.stat-card.red    { border-top-color: var(--red); }

.stat-card-icon {
    width: 36px; height: 36px; border-radius: var(--radius-sm);
    background: var(--navy); color: var(--white);
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; margin-bottom: 4px;
}
.stat-card.gold  .stat-card-icon { background: var(--gold); }
.stat-card.green .stat-card-icon { background: var(--green); }
.stat-card.red   .stat-card-icon { background: var(--red); }

.stat-label  { font-size: 0.75em; color: var(--text-muted); font-weight: 600;
               text-transform: uppercase; letter-spacing: 0.5px; }
.stat-value  { font-size: 2.4em; font-weight: 700; color: var(--navy); line-height: 1; }
.stat-card.gold  .stat-value { color: #7a6010; }
.stat-card.green .stat-value { color: var(--green); }
.stat-card.red   .stat-value { color: var(--red); }
.stat-link a {
    font-size: 0.78em; color: var(--navy-light); font-weight: 600;
    border-bottom: 1px solid; padding-bottom: 1px;
}
.stat-link a:hover { color: var(--navy); }

/* ─── Quick-action grid ──────────────────────────────────────────────────────── */
.action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-3);
}
.action-tile {
    background: var(--panel-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-4) var(--space-4);
    text-decoration: none; color: var(--text);
    display: flex; align-items: center; gap: var(--space-3);
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    box-shadow: var(--shadow-sm);
}
.action-tile:hover {
    border-color: var(--navy-light); background: var(--blue-bg);
    box-shadow: var(--shadow); text-decoration: none; color: var(--text);
}
.action-tile-icon {
    width: 40px; height: 40px; flex-shrink: 0; border-radius: var(--radius-sm);
    background: var(--navy); color: var(--white);
    display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.action-tile.green .action-tile-icon { background: var(--green); }
.action-tile.gold  .action-tile-icon { background: var(--gold); }
.action-tile.gray  .action-tile-icon { background: #4a5568; }
.action-tile-label { font-size: 0.88em; font-weight: 600; color: var(--navy); }
.action-tile-desc  { font-size: 0.75em; color: var(--text-muted); margin-top: 1px; }

/* ─── Forms ──────────────────────────────────────────────────────────────────── */
form { margin: 0; }
fieldset {
    border: 1px solid var(--border-light);
    border-radius: var(--radius); padding: var(--space-4);
    margin: 0 0 var(--space-4); background: var(--panel-bg);
}
legend {
    padding: 0 var(--space-2); color: var(--navy);
    font-weight: 700; font-size: 0.80em;
    letter-spacing: 0.5px; text-transform: uppercase;
}
label {
    display: block; margin: var(--space-3) 0 4px;
    font-weight: 600; color: var(--text); font-size: 0.84em;
}
label:first-of-type { margin-top: var(--space-2); }

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="file"],
textarea,
select {
    width: 100%; padding: 9px 11px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 0.90em; font-family: var(--font); color: var(--text);
    background: var(--input-bg);
    transition: border-color 0.15s, box-shadow 0.15s;
    -webkit-appearance: none; appearance: none;
}
input:focus, textarea:focus, select:focus {
    outline: none; border-color: var(--navy-light); background: var(--white);
    box-shadow: 0 0 0 3px rgba(46,84,150,0.13);
}
input[type="file"] { padding: 7px 11px; cursor: pointer; }
select { cursor: pointer; }
.field-hint {
    font-size: 0.78em; color: var(--text-muted);
    margin: 3px 0 var(--space-3); font-style: italic;
}
.required { color: var(--red); font-weight: 700; }

/* Two-column form row */
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    align-items: start;
}
.form-row.thirds { grid-template-columns: 2fr 1fr; }
.form-row .form-field { display: flex; flex-direction: column; }
.form-row .form-field label { margin-top: 0; }

/* ─── Buttons ────────────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    background: var(--navy); color: var(--white);
    padding: 9px 20px; border: 1px solid var(--navy-dark);
    border-radius: var(--radius-sm);
    font-size: 0.87em; font-weight: 600; font-family: var(--font);
    cursor: pointer; text-decoration: none;
    min-height: 38px; white-space: nowrap;
    transition: background 0.15s, border-color 0.15s;
    letter-spacing: 0.2px;
}
.btn:hover { background: var(--navy-dark); text-decoration: none; color: var(--white); }
.btn:active { opacity: 0.9; }

/* Size variants */
.btn-sm  { padding: 6px 14px; font-size: 0.80em; min-height: 32px; }
.btn-lg  { padding: 11px 28px; font-size: 0.93em; min-height: 44px; }

/* Colour variants */
.btn-light    { background: #f2f4f8; color: var(--navy); border-color: var(--border);
                font-weight: 600; }
.btn-light:hover { background: #e4e8f0; color: var(--navy); }

.btn-secondary { background: #6b7280; border-color: #4b5563; color: var(--white); }
.btn-secondary:hover { background: #4b5563; }

.btn-success   { background: var(--green); border-color: #145230; }
.btn-success:hover { background: #145230; }

.btn-danger    { background: var(--red); border-color: #991b1b; }
.btn-danger:hover { background: #991b1b; }

.btn-gold      { background: var(--gold); border-color: #8a6f1f; color: var(--white); }
.btn-gold:hover { background: #8a6f1f; }

/* Full-width */
.btn-block { width: 100%; }

/* Text-only inline button */
.btn-text {
    background: none; border: none; box-shadow: none;
    color: var(--navy-light); cursor: pointer; text-decoration: underline;
    font-size: 0.83em; font-weight: 600; font-family: var(--font);
    padding: 2px 3px; min-height: auto; white-space: nowrap;
}
.btn-text:hover { color: var(--navy); }
.btn-text.danger { color: var(--red); }
.btn-text.warning { color: #b45309; }

/* Button groups */
.btn-group { display: flex; gap: var(--space-2); flex-wrap: wrap; align-items: center; }
.btn-group.full > .btn { flex: 1; }

/* ─── Alert / message boxes ──────────────────────────────────────────────────── */
.alert, .error, .success, .info,
.alert-error, .alert-success, .alert-info, .alert-warning {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    margin: 0 0 var(--space-4);
    border-inline-start: 4px solid;
    font-size: 0.87em; line-height: 1.55;
}
.alert-error, .error {
    background: var(--red-bg); color: var(--red);
    border-color: var(--red);
}
.alert-success, .success {
    background: var(--green-bg); color: var(--green);
    border-color: var(--green);
}
.alert-info, .info {
    background: var(--blue-bg); color: var(--blue);
    border-color: var(--navy-light);
}
.alert-warning {
    background: var(--amber-bg); color: var(--amber);
    border-color: var(--gold);
}

/* ─── Search toolbar ─────────────────────────────────────────────────────────── */
.toolbar {
    display: flex; gap: var(--space-2); align-items: flex-start;
    flex-wrap: wrap; margin-bottom: var(--space-4);
}
.search-form {
    display: flex; gap: var(--space-2); flex: 1; flex-wrap: nowrap;
    min-width: 0;
}
.search-form input[type="text"] {
    flex: 1; min-width: 200px;
}
.search-form .btn { flex-shrink: 0; }

/* ─── Data table ─────────────────────────────────────────────────────────────── */
.table-wrapper { overflow-x: auto; }
.data-table {
    width: 100%; border-collapse: collapse;
    font-size: 0.86em;
}
.data-table thead tr { background: var(--navy); }
.data-table th {
    padding: 10px 13px; text-align: right; color: var(--white);
    font-weight: 600; font-size: 0.81em; letter-spacing: 0.3px;
    border-inline-start: 1px solid rgba(255,255,255,0.10);
    white-space: nowrap;
}
.data-table th:last-child { border-inline-start: none; }
.data-table td {
    padding: 9px 13px; text-align: right;
    border-bottom: 1px solid var(--border-light);
    vertical-align: middle;
}
.data-table tbody tr:nth-child(even) { background: var(--row-alt); }
.data-table tbody tr:hover { background: #e8eef8; }
.data-table tbody tr:nth-child(even):hover { background: #dde7f5; }
/* Special reset/expand rows */
.expand-row { background: var(--amber-bg) !important; }
.expand-row:hover { background: #fef3c7 !important; }

/* Column helpers */
.col-id      { width: 140px; }
.col-status  { width: 90px; }
.col-date    { width: 110px; }
.col-action  { width: 120px; }
.col-phone   { width: 130px; }
.col-narrow  { width: 80px; }

code {
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 0.88em; background: #f0f2f5;
    padding: 1px 5px; border-radius: 2px;
    border: 1px solid var(--border); color: var(--navy-dark);
    word-break: break-all;
}
.code-sm { font-size: 0.78em; }

/* ─── Status badges ──────────────────────────────────────────────────────────── */
.badge {
    display: inline-block; padding: 2px 8px; border-radius: 2px;
    font-size: 0.76em; font-weight: 700; white-space: nowrap;
    letter-spacing: 0.3px; text-transform: uppercase;
    border: 1px solid transparent;
}
.badge-active    { background: #dcfce7; color: var(--green); border-color: var(--green-border); }
.badge-inactive  { background: var(--red-bg); color: var(--red); border-color: var(--red-border); }
.badge-suspended { background: var(--amber-bg); color: var(--amber); border-color: var(--amber-border); }
.badge-admin     { background: #e8edf8; color: var(--navy); border-color: #b0c0e0; }
.badge-officer   { background: #f0f4ff; color: var(--navy-light); border-color: #c5d2ee; }

/* ─── Status dot + label (compact) ──────────────────────────────────────────── */
.status-dot { display: inline-flex; align-items: center; gap: 5px; font-size: 0.84em; }
.status-dot::before {
    content: ''; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.status-dot.active::before    { background: var(--green); }
.status-dot.inactive::before  { background: var(--red); }
.status-dot.suspended::before { background: var(--amber); }

/* ─── Pagination ─────────────────────────────────────────────────────────────── */
.pagination {
    display: flex; justify-content: center; align-items: center;
    gap: var(--space-2); margin: var(--space-5) 0 var(--space-2);
    flex-wrap: wrap;
}
.pagination a {
    display: inline-block; padding: 6px 14px;
    background: var(--navy); color: var(--white) !important;
    border-radius: var(--radius-sm); text-decoration: none;
    font-size: 0.82em; font-weight: 600; border: 1px solid var(--navy-dark);
    transition: background 0.15s;
}
.pagination a:hover { background: var(--navy-dark); text-decoration: none; }
.page-info { color: var(--text-muted); font-size: 0.82em; }

/* ─── Detail grid (info boxes) ───────────────────────────────────────────────── */
.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: var(--space-4); margin-bottom: var(--space-4);
}
.detail-box {
    background: var(--panel-bg); border: 1px solid var(--border);
    border-radius: var(--radius); overflow: hidden;
}
.detail-box-header {
    background: #f2f4f8; border-bottom: 1px solid var(--border);
    padding: var(--space-2) var(--space-4);
    font-size: 0.78em; font-weight: 700; color: var(--navy);
    text-transform: uppercase; letter-spacing: 0.5px;
}
.detail-box-body { padding: var(--space-3) var(--space-4); }
.detail-row {
    display: flex; gap: var(--space-2); padding: 5px 0;
    border-bottom: 1px solid var(--border-light); font-size: 0.87em;
    align-items: baseline;
}
.detail-row:last-child { border-bottom: none; }
.detail-row dt { color: var(--text-muted); font-weight: 600; flex-shrink: 0; min-width: 95px; }
.detail-row dd { color: var(--text); word-break: break-word; }

/* ─── QR widget ──────────────────────────────────────────────────────────────── */
.qr-widget {
    background: var(--white); border: 1px solid var(--border);
    border-radius: var(--radius); padding: var(--space-4);
    text-align: center;
}
.qr-widget img {
    max-width: 160px; display: block; margin: var(--space-3) auto var(--space-2);
    border: 1px solid var(--border);
}
.qr-widget p { font-size: 0.78em; color: var(--text-muted); margin: 0; }

/* ─── Document images ────────────────────────────────────────────────────────── */
.doc-img { width: 100%; border: 1px solid var(--border); border-radius: var(--radius-sm); }

/* ─── Audit action chips ─────────────────────────────────────────────────────── */
.audit-chip {
    display: inline-block; padding: 2px 7px; border-radius: 2px;
    font-size: 0.77em; font-family: 'Consolas', monospace;
    background: #f0f2f5; color: var(--text-muted); border: 1px solid var(--border);
}
.chip-login      { background: var(--blue-bg);  color: var(--blue); border-color: var(--blue-border); }
.chip-logout     { background: #f3edf8;          color: #6a1b9a; border-color: #d9b3f0; }
.chip-register   { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.chip-edit       { background: var(--amber-bg); color: var(--amber); border-color: var(--amber-border); }
.chip-reset      { background: var(--red-bg);   color: var(--red); border-color: var(--red-border); }
.chip-export     { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.chip-add        { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.chip-deactivate { background: var(--red-bg);   color: var(--red); border-color: var(--red-border); }
.chip-activate   { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.chip-change     { background: var(--amber-bg); color: var(--amber); border-color: var(--amber-border); }

/* ─── Vehicle card (officer dashboard grid view) ─────────────────────────────── */
.vehicle-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
    gap: var(--space-4); margin-bottom: var(--space-4);
}
.vehicle-card {
    background: var(--panel-bg); border: 1px solid var(--border);
    border-top: 3px solid var(--navy); border-radius: var(--radius);
    box-shadow: var(--shadow-sm); overflow: hidden;
    display: flex; flex-direction: column;
    transition: box-shadow 0.15s, border-top-color 0.15s;
}
.vehicle-card:hover { box-shadow: var(--shadow); border-top-color: var(--navy-light); }
.vehicle-card-header {
    padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border-light);
}
.vehicle-card-title {
    display: block; font-weight: 700; font-size: 0.93em;
    color: var(--navy); text-decoration: none; line-height: 1.3;
}
.vehicle-card-title:hover { color: var(--navy-light); text-decoration: none; }
.vehicle-card-body  { padding: var(--space-3) var(--space-4); flex: 1; }
.vehicle-card-footer {
    padding: var(--space-2) var(--space-4); border-top: 1px solid var(--border-light);
    background: #f8f9fc;
}
.vc-row { display: flex; gap: var(--space-2); align-items: baseline;
          font-size: 0.83em; margin: 3px 0; }
.vc-row dt { color: var(--text-muted); font-weight: 600; flex-shrink: 0; min-width: 56px; }
.vc-row dd { color: var(--text); }

/* ─── Login page (split panel) ───────────────────────────────────────────────── */
.login-root {
    min-height: 100vh; display: flex; flex-direction: column;
    background: var(--page-bg);
}
.login-split {
    flex: 1; display: grid;
    grid-template-columns: 2fr 3fr;
    min-height: calc(100vh - 40px);
}
.login-brand {
    background: var(--navy);
    padding: 48px 40px;
    display: flex; flex-direction: column;
    justify-content: center; gap: var(--space-5);
    border-inline-end: 3px solid var(--gold);
}
.login-brand-logo {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--gold);
    display: flex; align-items: center; justify-content: center;
    font-size: 30px;
    box-shadow: 0 3px 10px rgba(0,0,0,0.4);
    margin-bottom: var(--space-2);
}
.login-brand h1 { font-size: 1.25em; color: var(--white); font-weight: 700; line-height: 1.3; }
.login-brand p  { font-size: 0.83em; color: rgba(255,255,255,0.60); line-height: 1.6; }
.login-brand hr { border: none; border-top: 1px solid rgba(255,255,255,0.15); margin: var(--space-3) 0; }
.login-features { list-style: none; margin: 0; }
.login-features li {
    font-size: 0.82em; color: rgba(255,255,255,0.75);
    padding: 5px 0; display: flex; align-items: center; gap: var(--space-2);
}
.login-features li::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--gold); flex-shrink: 0;
}

.login-form-side {
    display: flex; align-items: center; justify-content: center;
    padding: 40px 48px;
    background: var(--white);
}
.login-form-box { width: 100%; max-width: 380px; }
.login-form-title {
    font-size: 1.45em; font-weight: 700; color: var(--navy); margin-bottom: 4px;
}
.login-form-sub { font-size: 0.83em; color: var(--text-muted); margin-bottom: var(--space-5); }
.login-form-box label { margin-top: var(--space-4); }
.login-form-box label:first-of-type { margin-top: 0; }
.login-form-box .btn { margin-top: var(--space-5); }
.login-footer {
    background: var(--navy-dark); color: rgba(255,255,255,0.45);
    text-align: center; font-size: 0.73em;
    padding: var(--space-3) var(--space-5);
    border-top: 2px solid var(--gold);
}

/* ─── Site footer ────────────────────────────────────────────────────────────── */
.site-footer {
    background: var(--navy-dark); color: rgba(255,255,255,0.45);
    text-align: center; font-size: 0.73em;
    padding: var(--space-3) var(--space-5);
    margin-top: 40px; border-top: 2px solid var(--gold);
}

/* ─── Responsive – Tablet (≤ 900px) ─────────────────────────────────────────── */
@media (max-width: 900px) {
    .login-split { grid-template-columns: 1fr; }
    .login-brand { display: none; }
    .login-form-side { padding: 32px 24px; }
}

@media (max-width: 768px) {
    .header-title  { font-size: 0.88em; }
    .header-subtitle { display: none; }
    .header-inner  { height: 52px; }

    .page-wrapper  { padding: var(--space-4) var(--space-3) 32px; }

    .stat-grid     { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--space-3); }
    .stat-value    { font-size: 2em; }

    .form-row      { grid-template-columns: 1fr; gap: var(--space-3); }
    .form-row.thirds { grid-template-columns: 1fr; }

    .action-grid   { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }

    .detail-grid   { grid-template-columns: 1fr; }

    .site-nav-inner { overflow-x: auto; }
    .site-nav a    { padding: 0 var(--space-3); font-size: 0.76em; }

    input, textarea, select { font-size: 16px; } /* prevent iOS zoom */

    .data-table    { font-size: 0.80em; }
    .data-table th,
    .data-table td { padding: 8px 10px; }

    .vehicle-grid  { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
}

/* ─── Responsive – Mobile (≤ 480px) ─────────────────────────────────────────── */
@media (max-width: 480px) {
    .page-wrapper { padding: var(--space-3) var(--space-2) var(--space-6); }

    .header-user .user-pill { display: none; }
    .header-emblem { width: 32px; height: 32px; font-size: 16px; }

    .toolbar { flex-direction: column; }
    .search-form { flex-wrap: wrap; }
    .search-form input { min-width: unset; }
    .search-form .btn { width: 100%; }

    .btn-block-mobile { width: 100%; }
    .btn-group { flex-direction: column; }
    .btn-group .btn { width: 100%; }

    .vehicle-grid { grid-template-columns: 1fr; }
    .stat-grid    { grid-template-columns: repeat(2, 1fr); }

    .login-form-side { padding: 24px 16px; }
}

/* ─── Print ──────────────────────────────────────────────────────────────────── */
@media print {
    .site-header, .site-nav, .site-footer,
    .toolbar, .search-form, .pagination,
    .btn, .btn-group, .card-header .card-header-action { display: none !important; }
    body { background: white; }
    .page-wrapper { padding: 0; }
    .card, .vehicle-card, .detail-box { box-shadow: none; border: 1px solid #ccc; }
    .qr-widget { page-break-inside: avoid; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   NEW FEATURE STYLES
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── License status badges ──────────────────────────────────────────────────── */
.badge-license-valid    { background: var(--green-bg);  color: var(--green);  border: 1px solid var(--green-border); }
.badge-license-expiring { background: var(--amber-bg);  color: var(--amber);  border: 1px solid var(--amber-border); }
.badge-license-expired  { background: var(--red-bg);    color: var(--red);    border: 1px solid var(--red-border);   }
.badge-license-none     { background: var(--red-bg);    color: var(--red);    border: 1px solid var(--red-border);   }
.badge-template         { background: #f0f4ff;           color: #3b5bdb;       border: 1px solid #bac8ff;             }

/* ─── QR Scanner page ────────────────────────────────────────────────────────── */
.scanner-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-5);
    padding: var(--space-6) var(--space-4);
}
.scanner-frame {
    position: relative;
    width: 100%;
    max-width: 520px;
    background: #000;
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    aspect-ratio: 1 / 1;
}
.scanner-frame video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.scanner-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}
.scanner-reticle {
    width: 65%;
    height: 65%;
    border: 3px solid var(--gold);
    border-radius: var(--radius);
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.45);
}
.scanner-status {
    font-size: 1em;
    color: var(--text-muted);
    text-align: center;
    min-height: 2.4em;
}
.scanner-status.scanning  { color: var(--navy-light); }
.scanner-status.found     { color: var(--green);       font-weight: 700; }
.scanner-status.error     { color: var(--red);         }
#btn-start-scan {
    min-width: 200px;
}

/* ─── Super admin portal ─────────────────────────────────────────────────────── */
.sa-header {
    background: linear-gradient(135deg, #0d1f3c 0%, #1b3a6b 100%);
    color: #fff;
    border-bottom: 3px solid #e8c84a;
    position: sticky;
    top: 0;
    z-index: 200;
    box-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.sa-header-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 var(--space-5);
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 60px;
    gap: var(--space-4);
}
.sa-brand {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.sa-emblem {
    width: 40px; height: 40px;
    background: #e8c84a;
    color: #0d1f3c;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; font-weight: 900;
    box-shadow: 0 2px 8px rgba(0,0,0,0.4);
    flex-shrink: 0;
}
.sa-title    { font-size: 1em;    font-weight: 700; }
.sa-subtitle { font-size: 0.72em; color: rgba(255,255,255,0.55); }
.sa-user     { display: flex; align-items: center; gap: var(--space-3); font-size: 0.82em; }
.sa-user a   { color: rgba(255,255,255,0.75); }
.sa-user a:hover { color: #fff; }

.sa-nav { background: #122850; border-bottom: 1px solid rgba(255,255,255,0.10); }
.sa-nav-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 var(--space-5);
    display: flex;
    gap: 0;
    overflow-x: auto;
}
.sa-nav a {
    color: rgba(255,255,255,0.70);
    padding: 10px var(--space-4);
    font-size: 0.84em;
    font-weight: 500;
    display: inline-block;
    border-bottom: 2px solid transparent;
    transition: color 0.15s, border-color 0.15s;
    white-space: nowrap;
}
.sa-nav a:hover          { color: #fff; text-decoration: none; }
.sa-nav a.active         { color: #e8c84a; border-bottom-color: #e8c84a; }

/* Super admin stat grid */
.sa-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-5);
}
.sa-stat-card {
    background: var(--panel-bg);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: var(--space-5);
    text-align: center;
    box-shadow: var(--shadow-sm);
}
.sa-stat-value { font-size: 2.4em; font-weight: 800; color: var(--navy); line-height: 1; }
.sa-stat-label { font-size: 0.82em; color: var(--text-muted); margin-top: var(--space-2); }

/* Super admin login */
.sa-login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0d1f3c 0%, #1b3a6b 60%, #243f74 100%);
    direction: rtl;
    font-family: var(--font);
}
.sa-login-card {
    background: #fff;
    border-radius: var(--radius);
    box-shadow: 0 8px 40px rgba(0,0,0,0.4);
    padding: 40px 36px;
    width: 100%;
    max-width: 400px;
    text-align: center;
}
.sa-login-emblem {
    width: 70px; height: 70px;
    background: linear-gradient(135deg, #0d1f3c, #1b3a6b);
    color: #e8c84a;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 30px;
    margin: 0 auto var(--space-4);
    box-shadow: 0 4px 16px rgba(13,31,60,0.5);
}
.sa-login-title    { font-size: 1.3em; font-weight: 800; color: var(--navy); margin-bottom: 4px; }
.sa-login-subtitle { font-size: 0.82em; color: var(--text-muted); margin-bottom: var(--space-5); }

/* ─── Template QR print sheet ────────────────────────────────────────────────── */
.qr-print-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-4);
    padding: var(--space-4);
}
.qr-print-card {
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    padding: var(--space-4);
    text-align: center;
    background: #fff;
    page-break-inside: avoid;
}
.qr-print-card img  { width: 100%; max-width: 160px; }
.qr-print-card code { font-size: 0.72em; display: block; margin-top: var(--space-2); color: var(--text-muted); }

@media print {
    .qr-print-grid { gap: 8px; padding: 0; }
    .qr-print-card { border-color: #aaa; }
    .no-print      { display: none !important; }
}

/* ─── Dark mode ──────────────────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
    :root {
        --page-bg:      #0f1117;
        --panel-bg:     #1a1d27;
        --input-bg:     #1e2235;
        --border:       #2e3447;
        --border-light: #242838;
        --text:         #dde2ed;
        --text-muted:   #8b95a7;
        --text-light:   #5a6275;
        --row-alt:      #161924;
        --navy-light:   #6b9fd4;
        --gold-light:   #f5e9c4;

        --green-bg:     #0c2317;
        --green-border: #1a4a2e;
        --red-bg:       #2b1010;
        --red-border:   #5a2020;
        --amber-bg:     #2a1d05;
        --amber-border: #5a3e10;
        --blue-bg:      #0d1a2b;
        --blue-border:  #1f3a5a;

        --shadow-sm: 0 1px 3px rgba(0,0,0,0.5), 0 1px 2px rgba(0,0,0,0.4);
        --shadow:    0 2px 6px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.4);
        --shadow-md: 0 4px 12px rgba(0,0,0,0.6), 0 8px 24px rgba(0,0,0,0.4);
    }

    /* ── Hard-coded white/light backgrounds ─────────────────────────────────── */
    .login-form-side,
    .sa-login-card,
    .qr-print-card,
    .qr-widget { background: var(--panel-bg); }

    /* input:focus uses var(--white) */
    input:focus, textarea:focus, select:focus { background: #252840; }

    /* Hard-coded #f2f4f8 */
    .card-header,
    .detail-box-header,
    .info-bar         { background: #1e2235; }
    .vehicle-card-footer { background: #1e2235; }

    /* ── Navy used as text — lighten for dark backgrounds ───────────────────── */
    .page-title h1,
    .card-header,
    .detail-box-header,
    legend,
    .action-tile-label,
    .vehicle-card-title,
    .login-form-title,
    .sa-login-title,
    .sa-stat-value    { color: #8ab4e0; }

    .stat-value              { color: #8ab4e0; }
    .stat-card.gold  .stat-value { color: #e8c84a; }
    .stat-card.green .stat-value { color: #4ade80; }
    .stat-card.red   .stat-value { color: #f87171; }

    .title-icon          { background: #2a4a80; }
    .page-title          { border-bottom-color: #2a4a80; }

    a                    { color: var(--navy-light); }
    .breadcrumb .current { color: var(--text); }
    .stat-link a         { color: var(--navy-light); }
    .vehicle-card-title:hover { color: var(--navy-light); }

    /* ── Table ───────────────────────────────────────────────────────────────── */
    .data-table tbody tr:hover                 { background: #1d2540; }
    .data-table tbody tr:nth-child(even):hover { background: #1a2238; }

    /* ── Code ────────────────────────────────────────────────────────────────── */
    code { background: #1e2235; border-color: var(--border); color: #a8b8d0; }

    /* ── Badges ──────────────────────────────────────────────────────────────── */
    .badge-active    { background: #0c2317; color: #4ade80; border-color: #1a4a2e; }
    .badge-inactive  { background: #2b1010; color: #f87171; border-color: #5a2020; }
    .badge-suspended { background: #2a1d05; color: #fbbf24; border-color: #5a3e10; }
    .badge-admin     { background: #1a2540; color: #8ab4e0; border-color: #2a3a60; }
    .badge-officer   { background: #1a2235; color: #7090cc; border-color: #253050; }
    .badge-template  { background: #1a1f40; color: #7b8ff5; border-color: #2a3570; }

    .badge-license-valid            { background: #0c2317; color: #4ade80; border-color: #1a4a2e; }
    .badge-license-expiring         { background: #2a1d05; color: #fbbf24; border-color: #5a3e10; }
    .badge-license-expired,
    .badge-license-none             { background: #2b1010; color: #f87171; border-color: #5a2020; }

    /* ── Audit chips ─────────────────────────────────────────────────────────── */
    .audit-chip  { background: #1e2235; color: var(--text-muted); border-color: var(--border); }
    .chip-logout { background: #2a1040; color: #c084fc; border-color: #5b21b6; }

    /* ── Misc ────────────────────────────────────────────────────────────────── */
    .expand-row       { background: #2a1d05 !important; }
    .expand-row:hover { background: #3a2a07 !important; }

    .action-tile:hover { background: #1d2540; }

    .btn-light       { background: #1e2235; color: var(--text); border-color: var(--border); }
    .btn-light:hover { background: #252840; color: var(--text); }

    .scanner-status.scanning { color: var(--navy-light); }
}
