/* ═══════════════════════════════════════════════════
   AUTOCARE HUB v5 — Exact match to React preview
   ═══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700;900&family=JetBrains+Mono:wght@400;700&display=swap');

/* ── LIGHT MODE (default) ─────────────────────────── */
:root {
  --bg:       #f1f5f9;
  --card:     #ffffff;
  --topbar:   #ffffff;
  --inp:      #f8fafc;
  --border:   #e2e8f0;
  --border2:  #cbd5e1;
  --t1:       #0f172a;
  --t2:       #475569;
  --t3:       #94a3b8;
  --shadow:   0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg:0 20px 48px rgba(0,0,0,0.12);

  /* color tokens */
  --blue:    #2563eb;
  --cyan:    #0891b2;
  --green:   #15803d;
  --amber:   #b45309;
  --rose:    #be123c;
  --violet:  #6d28d9;

  /* icon bg (light) */
  --ic-blue:   #dbeafe;
  --ic-cyan:   #cffafe;
  --ic-green:  #dcfce7;
  --ic-amber:  #fef3c7;
  --ic-rose:   #ffe4e6;
  --ic-violet: #ede9fe;

  /* badge bg (light) */
  --badge-green:  #dcfce7; --badge-green-t:  #15803d;
  --badge-blue:   #dbeafe; --badge-blue-t:   #1d4ed8;
  --badge-amber:  #fef3c7; --badge-amber-t:  #b45309;
  --badge-rose:   #ffe4e6; --badge-rose-t:   #be123c;
  --badge-cyan:   #cffafe; --badge-cyan-t:   #0e7490;

  /* alert bg */
  --alert-danger:  #fff1f2;
  --alert-warning: #fffbeb;
  --alert-info:    #eff6ff;

  /* status */
  --status-active-bg: #dcfce7;
  --status-active-t:  #15803d;

  --r:  10px;
  --r2: 14px;
  --r3: 18px;
  --r4: 22px;

  /* compat aliases for PHP inline styles */
  --blue-hi:    #2563eb;
  --cyan-hi:    #0891b2;
  --green-hi:   #15803d;
  --amber-hi:   #b45309;
  --rose-hi:    #be123c;
  --violet-hi:  #6d28d9;
  --blue-dim:   #dbeafe;
  --cyan-dim:   #cffafe;
  --green-dim:  #dcfce7;
  --amber-dim:  #fef3c7;
  --rose-dim:   #ffe4e6;
  --violet-dim: #ede9fe;
  --green-glow: rgba(21,128,61,.2);
  --bg:         #f1f5f9;
  --surface2:   #f8fafc;
}

/* ── DARK MODE ────────────────────────────────────── */
body.dark {
  --bg:       #0f172a;
  --card:     #1e293b;
  --topbar:   #1e293b;
  --inp:      #0f172a;
  --border:   #334155;
  --border2:  #475569;
  --t1:       #f1f5f9;
  --t2:       #94a3b8;
  --t3:       #64748b;
  --shadow:   0 1px 3px rgba(0,0,0,0.5);
  --shadow-md:0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg:0 20px 48px rgba(0,0,0,0.6);

  --blue:    #3b82f6;
  --cyan:    #22d3ee;
  --green:   #22c55e;
  --amber:   #f59e0b;
  --rose:    #ef4444;
  --violet:  #a78bfa;

  --ic-blue:   rgba(255,255,255,0.07);
  --ic-cyan:   rgba(255,255,255,0.07);
  --ic-green:  rgba(255,255,255,0.07);
  --ic-amber:  rgba(255,255,255,0.07);
  --ic-rose:   rgba(255,255,255,0.07);
  --ic-violet: rgba(255,255,255,0.07);

  --badge-green:  #0a2e1e; --badge-green-t:  #6ee7b7;
  --badge-blue:   #1e3a5f; --badge-blue-t:   #93c5fd;
  --badge-amber:  #2e1e06; --badge-amber-t:  #fcd34d;
  --badge-rose:   #2e0a16; --badge-rose-t:   #fda4af;
  --badge-cyan:   #0c3040; --badge-cyan-t:   #67e8f9;

  --alert-danger:  #2e0a16;
  --alert-warning: #2e1e06;
  --alert-info:    #1e3a5f;

  --status-active-bg: #0a2e1e;
  --status-active-t:  #6ee7b7;

  --blue-hi:    #93c5fd;
  --cyan-hi:    #67e8f9;
  --green-hi:   #6ee7b7;
  --amber-hi:   #fcd34d;
  --rose-hi:    #fda4af;
  --violet-hi:  #c4b5fd;
  --blue-dim:   #1e3a5f;
  --cyan-dim:   #0c3040;
  --green-dim:  #0a2e1e;
  --amber-dim:  #2e1e06;
  --rose-dim:   #2e0a16;
  --violet-dim: #1e1040;
  --green-glow: rgba(34,197,94,.15);
  --surface2:   #1e293b;
}

/* ── RESET ────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:'Cairo',Tahoma,sans-serif;
  background:var(--bg); color:var(--t1);
  min-height:100vh; overflow-x:hidden;
  line-height:1.6; transition:background .25s,color .25s;
}
a{text-decoration:none;color:inherit}

/* ── KEYFRAMES ────────────────────────────────────── */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* ── LAYOUT ───────────────────────────────────────── */
.app-wrapper   {display:flex;min-height:100vh}
.main-content  {flex:1;display:flex;flex-direction:column;min-width:0;margin-right:220px;transition:margin-right .3s}
.main-content.sidebar-collapsed{margin-right:64px}
.page-body     {flex:1;padding:20px 22px;background:var(--bg)}

/* ── SIDEBAR ──────────────────────────────────────── */
.sidebar{
  width:220px;height:100vh;position:fixed;top:0;right:0;
  background:#020617;
  display:flex;flex-direction:column;
  z-index:100;transition:width .3s,transform .3s;overflow:hidden;
  border-left:1px solid rgba(255,255,255,0.06);
}
body:not(.dark) .sidebar{background:#0f172a}
.sidebar.collapsed{width:64px}

.sidebar-logo{
  padding:16px;border-bottom:1px solid rgba(255,255,255,0.07);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.logo-icon{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:#2563eb;display:flex;align-items:center;justify-content:center;
  font-size:18px;box-shadow:0 4px 12px rgba(37,99,235,.5);
}
.logo-text{overflow:hidden;transition:opacity .2s}
.logo-text h1{font-size:13px;font-weight:900;color:#fff;white-space:nowrap}
.logo-text span{font-size:9px;color:#64748b;font-weight:600}
.sidebar.collapsed .logo-text{opacity:0;width:0}

.sb-admin{
  display:flex;align-items:center;gap:9px;
  padding:9px 11px;margin:8px 8px 4px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.07);border-radius:10px;
}
.sb-avatar{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:#2563eb;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:900;color:#fff;position:relative;
}
.sb-online{
  position:absolute;bottom:1px;left:1px;
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;border:2px solid #020617;
}
body:not(.dark) .sb-online{border-color:#0f172a}
.sb-aname{font-size:11px;font-weight:700;color:#f1f5f9}
.sb-arole{font-size:9px;color:#93c5fd;margin-top:1px}
.sidebar.collapsed .sb-admin{padding:8px;justify-content:center}
.sidebar.collapsed .sb-aname,
.sidebar.collapsed .sb-arole{display:none}

.sb-clock{
  text-align:center;padding:7px;margin:0 8px 8px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);border-radius:10px;
}
.sb-clock-t{font-family:'JetBrains Mono',monospace;font-size:17px;font-weight:700;color:#93c5fd;letter-spacing:2px}
.sb-clock-d{font-size:8.5px;color:#475569;margin-top:2px}
.sidebar.collapsed .sb-clock{display:none}

.nav-section{padding:0 8px;flex:1;overflow-y:auto}
.nav-title{
  font-size:9px;font-weight:700;color:#475569;
  text-transform:uppercase;letter-spacing:1.5px;
  padding:8px 8px 4px;
}
.sidebar.collapsed .nav-title{display:none}
.side-nav{display:flex;flex-direction:column;gap:2px;margin-bottom:4px}
.side-nav a{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:9px;
  color:#94a3b8;font-size:12px;font-weight:600;
  transition:all .18s;white-space:nowrap;
}
.side-nav a:hover{background:rgba(255,255,255,0.07);color:#f1f5f9}
.side-nav a.active{
  background:#2563eb;color:#fff;
  box-shadow:0 2px 8px rgba(37,99,235,.4);
}
.nav-icon{
  width:28px;height:28px;border-radius:7px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;background:rgba(255,255,255,0.07);
}
.side-nav a.active .nav-icon{background:rgba(255,255,255,0.2)}
.nav-label{flex:1}
.nav-badge{
  font-size:10px;font-weight:800;padding:2px 7px;
  border-radius:20px;background:#2563eb;color:#fff;
}
.nav-badge.amber{background:#f59e0b}
.nav-badge.rose {background:#ef4444}
.sidebar.collapsed .nav-label,
.sidebar.collapsed .nav-badge{display:none}
.sidebar.collapsed .side-nav a{padding:9px;justify-content:center}

.sidebar-toggle-btn{
  width:100%;padding:11px;border:none;background:none;
  border-top:1px solid rgba(255,255,255,0.07);
  color:#475569;cursor:pointer;font-size:13px;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.sidebar-toggle-btn:hover{color:#93c5fd;background:rgba(255,255,255,0.05)}

/* ── TOPBAR ───────────────────────────────────────── */
.topbar{
  height:58px;background:var(--topbar);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;flex-shrink:0;position:sticky;top:0;z-index:50;
  box-shadow:var(--shadow);
}
.topbar-left{display:flex;align-items:center;gap:14px}
.page-title  {font-size:15px;font-weight:800;color:var(--t1)}
.page-subtitle{font-size:10px;color:var(--t3)}
.topbar-right{display:flex;align-items:center;gap:8px}

.search-box{
  display:flex;align-items:center;gap:8px;
  background:var(--inp);border:1px solid var(--border);
  border-radius:9px;padding:6px 11px;width:170px;transition:all .2s;
}
.search-box:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.search-box i  {color:var(--t3);font-size:11px}
.search-box input{
  background:none;border:none;outline:none;
  color:var(--t1);font-size:12px;font-family:'Cairo',sans-serif;width:100%;
}
.search-box input::placeholder{color:var(--t3)}

.icon-btn{
  width:34px;height:34px;border-radius:8px;
  background:var(--inp);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--t2);cursor:pointer;position:relative;
  transition:all .2s;font-size:13px;
}
.icon-btn:hover{background:var(--border);color:var(--t1)}
.notif-dot{
  position:absolute;top:5px;right:5px;
  width:7px;height:7px;border-radius:50%;
  background:#ef4444;border:2px solid var(--topbar);
  animation:blink 2s infinite;
}

/* ── WELCOME BANNER ───────────────────────────────── */
/* Solid navy — always visible */
.welcome-banner{
  background:#1e3a8a;
  border-radius:var(--r4);padding:22px 26px;margin-bottom:18px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  position:relative;overflow:hidden;
  box-shadow:0 8px 24px rgba(30,58,138,.4);
  animation:rise .4s ease both;
}
.welcome-banner::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:160px;height:160px;border-radius:50%;
  background:rgba(147,197,253,.1);pointer-events:none;
}
.welcome-left {position:relative;z-index:1}
.welcome-title{font-size:19px;font-weight:900;color:#fff;margin-bottom:5px}
.welcome-sub  {font-size:11px;color:#93c5fd;margin-bottom:11px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.welcome-chips{display:flex;gap:7px;flex-wrap:wrap}
.wchip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;
  cursor:pointer;transition:all .18s;text-decoration:none;
}
.wchip.rose  {background:rgba(239,68,68,.25);  color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.wchip.amber {background:rgba(245,158,11,.25); color:#fcd34d;border:1px solid rgba(245,158,11,.3)}
.wchip.green {background:rgba(16,185,129,.25); color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}
.wchip:hover {filter:brightness(1.15);transform:translateY(-1px)}

.welcome-stats  {display:flex;align-items:center;gap:18px;position:relative;z-index:1;flex-shrink:0}
.welcome-divider{width:1px;height:38px;background:rgba(255,255,255,.15)}
.welcome-stat   {text-align:center}
.welcome-stat-val{font-family:'JetBrains Mono',monospace;font-size:24px;font-weight:700;color:#fff;line-height:1}
.welcome-stat-label{font-size:9px;color:#93c5fd;margin-top:3px;font-weight:600}

/* ── KPI CARDS ────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.kpi-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r3);padding:16px 18px;
  box-shadow:var(--shadow);animation:rise .4s ease both;
  transition:transform .22s,box-shadow .22s;
}
.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.kpi-head {display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.kpi-icon {
  width:44px;height:44px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.kpi-icon.blue  {background:var(--ic-blue)}
.kpi-icon.cyan  {background:var(--ic-cyan)}
.kpi-icon.amber {background:var(--ic-amber)}
.kpi-icon.rose  {background:var(--ic-rose)}
.kpi-icon.green {background:var(--ic-green)}
.kpi-icon.violet{background:var(--ic-violet)}

.kpi-trend{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;background:var(--inp);border:1px solid var(--border);color:var(--t2)}
.kpi-trend.up  {background:var(--badge-rose);  color:var(--badge-rose-t)}
.kpi-trend.down{background:var(--badge-green); color:var(--badge-green-t)}

.kpi-value{font-size:26px;font-weight:900;color:var(--t1);font-family:'JetBrains Mono',monospace;letter-spacing:-1px;line-height:1}
.kpi-label{font-size:11px;color:var(--t2);margin-top:4px;font-weight:600}
.kpi-sparkline{display:flex;align-items:flex-end;gap:2px;height:24px;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}
.kpi-sparkline span{flex:1;border-radius:2px 2px 0 0;min-height:4px;opacity:.5}
.kpi-card.blue-card  .kpi-sparkline span{background:#2563eb}
.kpi-card.cyan-card  .kpi-sparkline span{background:#0891b2}
.kpi-card.amber-card .kpi-sparkline span{background:#d97706}
.kpi-card.rose-card  .kpi-sparkline span{background:#ef4444}

/* ── SMART STATS ROW ──────────────────────────────── */
.smart-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:11px;margin-bottom:18px}
.smart-stat-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2);padding:13px 15px;
  display:flex;align-items:center;gap:11px;
  box-shadow:var(--shadow);transition:all .22s;animation:rise .4s ease both;
}
.smart-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.ss-icon {width:36px;height:36px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px}
.ss-value{font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700;color:var(--t1)}
.ss-label{font-size:10px;color:var(--t3);font-weight:600}

/* ── HEALTH GRID ──────────────────────────────────── */
.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:11px;margin-bottom:18px}
.health-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2);padding:13px 15px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);transition:all .22s;
}
.health-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.health-emoji{font-size:26px;flex-shrink:0}
.health-body {flex:1;min-width:0}
.health-name {font-size:12px;font-weight:800;color:var(--t1);margin-bottom:2px}
.health-meta {font-size:10px;color:var(--t3);margin-bottom:6px}
.health-bar-wrap{height:5px;background:var(--border);border-radius:10px;overflow:hidden;margin-bottom:5px}
.health-bar {height:100%;border-radius:10px;transition:width 1s ease}
.health-score-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.health-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:9.5px;font-weight:700}
.health-tag.rose  {background:var(--alert-danger);  color:var(--badge-rose-t)}
.health-tag.amber {background:var(--alert-warning);  color:var(--badge-amber-t)}
.health-tag.green {background:var(--status-active-bg);color:var(--status-active-t)}

/* ── SECTION TITLE ────────────────────────────────── */
.dash-section-title{
  font-size:10px;font-weight:800;color:var(--t3);
  text-transform:uppercase;letter-spacing:1.5px;
  display:flex;align-items:center;gap:9px;margin-bottom:12px;
}
.dash-section-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── CAR CARDS ────────────────────────────────────── */
.cars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px;margin-bottom:22px}

.car-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r4);overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .28s,box-shadow .28s,border-color .2s;
  animation:rise .4s ease both;display:block;
}
.car-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--border2)}

/* Banner — SOLID COLOR, always visible */
.car-card-banner{
  height:88px;position:relative;overflow:hidden;
  background:#3b82f6; /* fallback */
}
.car-bg-icon{
  position:absolute;right:-6px;top:50%;transform:translateY(-50%);
  font-size:74px;opacity:.2;pointer-events:none;z-index:1;
  transition:opacity .3s;
}
.car-card:hover .car-bg-icon{opacity:.32}

.car-banner-badges{position:absolute;top:9px;left:9px;z-index:3;display:flex;gap:5px}
.cc-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;padding:3px 8px;border-radius:20px}
.cc-badge.rose {background:#ef4444;color:#fff}
.cc-badge.amber{background:#f59e0b;color:#fff}

.car-health-ring{
  position:absolute;top:8px;right:8px;z-index:3;
  width:46px;height:46px;display:flex;align-items:center;justify-content:center;
}
.car-health-ring > span{
  position:absolute;font-size:8px;font-weight:900;color:#fff;
  text-align:center;line-height:1;
}
.car-card-icon{
  position:absolute;bottom:-17px;right:14px;z-index:3;
  width:44px;height:44px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  background:var(--card);border:3px solid var(--card);
  box-shadow:0 4px 12px rgba(0,0,0,.25);transition:transform .28s;
}
.car-card:hover .car-card-icon{transform:scale(1.1) rotate(-6deg)}

.car-card-body{padding:24px 16px 16px}
.car-card-name{font-size:14px;font-weight:900;color:var(--t1)}
.car-card-meta{
  font-size:11px;color:var(--t2);margin-top:3px;font-weight:600;
  display:flex;align-items:center;gap:5px;
}
.car-card-meta::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--car-accent,#2563eb)}

.car-status-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;margin-top:7px;
  background:var(--status-active-bg);color:var(--status-active-t);
}

.odometer-display{
  display:flex;align-items:center;gap:7px;
  background:var(--inp);border:1px solid var(--border);
  border-radius:9px;padding:7px 11px;margin-top:10px;
}
.odo-label{font-size:10px;color:var(--t2)}
.odo-val  {margin-right:auto;font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700}

.car-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.car-stat {background:var(--inp);border:1px solid var(--border);border-radius:8px;padding:8px 10px;transition:all .2s}
.car-stat:hover{background:var(--border)}
.car-stat-label{font-size:9px;color:var(--t3);margin-bottom:2px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.car-stat-value{font-size:12px;font-weight:800;color:var(--t1)}
.car-stat-value.mono{font-family:'JetBrains Mono',monospace}

.add-car-card{
  display:flex!important;flex-direction:column;
  align-items:center!important;justify-content:center!important;
  min-height:180px;border-style:dashed!important;
  opacity:.5;transition:opacity .3s,transform .3s!important;
}
.add-car-card:hover{opacity:.9!important;transform:translateY(-4px)!important}
.add-car-inner{display:flex;flex-direction:column;align-items:center;gap:9px}
.add-car-icon {width:50px;height:50px;border-radius:13px;background:var(--ic-blue);display:flex;align-items:center;justify-content:center;font-size:22px}
.add-car-text {color:var(--t2);font-size:12px;font-weight:700}

/* ── CHART CARDS ──────────────────────────────────── */
.chart-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r3);padding:18px;
  box-shadow:var(--shadow);animation:rise .4s ease both;
}
.chart-card-title{
  font-size:13px;font-weight:800;color:var(--t1);
  display:flex;align-items:center;gap:8px;margin-bottom:14px;
}
.chart-card-title i{color:var(--blue)}
.chart-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--inp);border:1px solid var(--border);color:var(--t3);margin-right:auto}
.chart-wrap canvas{max-height:240px}
.charts-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.charts-grid-3{display:grid;grid-template-columns:1fr 280px 240px;gap:14px;margin-bottom:22px}

/* ── QUICK LINKS ──────────────────────────────────── */
.quick-links{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:12px;padding-top:11px;border-top:1px solid var(--border)}
.ql-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;border-radius:9px;background:var(--inp);border:1px solid var(--border);color:var(--t3);font-size:10px;font-weight:700;text-decoration:none;transition:all .2s}
.ql-item i{font-size:14px;color:var(--blue)}
.ql-item:hover{background:var(--border);color:var(--t1);transform:translateY(-2px)}

/* ── TIMELINE ─────────────────────────────────────── */
.timeline{position:relative;padding-right:18px}
.timeline::before{content:'';position:absolute;right:6px;top:0;bottom:0;width:2px;background:var(--border)}
.tl-item{position:relative;padding-bottom:12px;padding-right:20px}
.tl-dot {
  position:absolute;right:-3px;top:6px;
  width:11px;height:11px;border-radius:50%;
  background:var(--card);border:2.5px solid var(--blue);
  transition:transform .2s;
}
.tl-item:hover .tl-dot{transform:scale(1.3)}
.tl-dot.maintenance{border-color:#22c55e}
.tl-dot.repair     {border-color:#ef4444}
.tl-dot.expense    {border-color:#f59e0b}
.tl-content{
  background:var(--inp);border:1px solid var(--border);
  border-radius:10px;padding:9px 12px;
  display:flex;justify-content:space-between;align-items:center;
  transition:all .2s;
}
.tl-content:hover{background:var(--border);transform:translateX(-3px)}
.tl-main  {flex:1}
.tl-title {font-size:12px;font-weight:700;color:var(--t1)}
.tl-desc  {font-size:10.5px;color:var(--t3);margin-top:2px}
.tl-date  {font-size:9.5px;color:var(--t3);margin-top:3px}
.tl-cost  {font-size:12px;font-weight:800;color:#f59e0b;font-family:'JetBrains Mono',monospace;white-space:nowrap;padding-right:8px}

/* ── ALERTS ───────────────────────────────────────── */
/* Match React: solid bg, border-right colored */
.alert-item{
  display:flex;gap:11px;padding:11px 13px;
  border-radius:10px;margin-bottom:8px;
  transition:all .2s;animation:rise .4s ease both;
  border-right:4px solid transparent;
}
.alert-item.danger {background:var(--alert-danger); border-color:#ef4444}
.alert-item.warning{background:var(--alert-warning);border-color:#f59e0b}
.alert-item.info   {background:var(--alert-info);   border-color:#3b82f6}
.alert-item:hover  {transform:translateX(-4px);box-shadow:var(--shadow)}
.alert-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.alert-item.danger  .alert-icon{background:rgba(239,68,68,.12); color:#ef4444}
.alert-item.warning .alert-icon{background:rgba(245,158,11,.12);color:#f59e0b}
.alert-item.info    .alert-icon{background:rgba(59,130,246,.12);color:#3b82f6}
.alert-body  {flex:1}
.alert-car   {font-size:10px;font-weight:700;color:var(--t3);margin-bottom:2px;text-transform:uppercase;letter-spacing:.4px}
.alert-msg   {font-size:12px;color:var(--t1);font-weight:600}
.alert-meta  {font-size:9.5px;color:var(--t3);margin-top:3px}

/* ── GENERAL CARD ─────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:18px;box-shadow:var(--shadow);animation:rise .4s ease both}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.card-title {font-size:13px;font-weight:800;color:var(--t1);display:flex;align-items:center;gap:8px}
.card-title i{color:var(--blue)}

/* ── TABLE ────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:12.5px}
.data-table thead th{background:var(--inp);color:var(--t3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:10px 13px;text-align:right;border-bottom:1px solid var(--border);white-space:nowrap}
.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
.data-table tbody tr:hover{background:var(--inp)}
.data-table tbody tr:last-child{border-bottom:none}
.data-table td{padding:10px 13px;color:var(--t1);vertical-align:middle}
.data-table td.muted{color:var(--t3)}
.data-table td.mono {font-family:'JetBrains Mono',monospace;font-size:11.5px}

/* ── BADGES ───────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:700}
.badge-green {background:var(--badge-green); color:var(--badge-green-t)}
.badge-blue  {background:var(--badge-blue);  color:var(--badge-blue-t)}
.badge-amber {background:var(--badge-amber); color:var(--badge-amber-t)}
.badge-rose  {background:var(--badge-rose);  color:var(--badge-rose-t)}
.badge-cyan  {background:var(--badge-cyan);  color:var(--badge-cyan-t)}

/* ── BUTTONS ──────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 17px;border-radius:var(--r);font-family:'Cairo',sans-serif;font-size:12.5px;font-weight:700;border:1px solid transparent;cursor:pointer;transition:all .2s}
.btn-primary {background:#2563eb;color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.25)}
.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 18px rgba(37,99,235,.35)}
.btn-secondary{background:var(--inp);border-color:var(--border2);color:var(--t1)}
.btn-secondary:hover{background:var(--border);transform:translateY(-1px)}
.btn-danger  {background:var(--alert-danger); border-color:rgba(239,68,68,.2);color:var(--badge-rose-t)}
.btn-danger:hover{filter:brightness(.95);transform:translateY(-1px)}
.btn-success {background:var(--status-active-bg);border-color:rgba(21,128,61,.2);color:var(--status-active-t)}
.btn-sm  {padding:6px 12px;font-size:11.5px;border-radius:8px}
.btn-icon{width:34px;height:34px;padding:0;justify-content:center}

/* ── FORMS ────────────────────────────────────────── */
.form-group {margin-bottom:14px}
.form-label {display:block;font-size:11px;font-weight:700;color:var(--t2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.form-control{
  width:100%;padding:9px 12px;
  background:var(--inp);border:1px solid var(--border);
  border-radius:var(--r);color:var(--t1);
  font-family:'Cairo',sans-serif;font-size:13px;
  transition:all .2s;outline:none;
}
.form-control:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-control::placeholder{color:var(--t3)}
select.form-control option{background:var(--card);color:var(--t1)}
textarea.form-control{resize:vertical;min-height:80px}
.form-row {display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.form-hint{font-size:10.5px;color:var(--t3);margin-top:4px}

/* ── MODAL ────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .2s}
.modal-overlay.hidden{display:none}
.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--r4);padding:22px;width:100%;max-width:510px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn .22s cubic-bezier(.34,1.56,.64,1) both}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:13px;border-bottom:1px solid var(--border)}
.modal-title {font-size:14px;font-weight:900;color:var(--t1);display:flex;align-items:center;gap:9px}
.modal-title i{color:var(--blue)}
.modal-close {width:30px;height:30px;border-radius:8px;background:var(--inp);border:1px solid var(--border);color:var(--t3);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.modal-close:hover{background:var(--alert-danger);color:var(--badge-rose-t)}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;padding-top:13px;border-top:1px solid var(--border)}

/* ── TOAST ────────────────────────────────────────── */
.toast-container{position:fixed;bottom:20px;left:20px;z-index:300;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;padding:11px 15px;border-radius:11px;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-md);min-width:260px;animation:slideInRight .3s ease;font-size:12.5px;font-weight:600;color:var(--t1);border-right:4px solid transparent}
.toast.success{border-right-color:#22c55e}
.toast.error  {border-right-color:#ef4444}
.toast.warning{border-right-color:#f59e0b}
.toast.success i{color:#22c55e}
.toast.error   i{color:#ef4444}
.toast.warning i{color:#f59e0b}

/* ── MISC ─────────────────────────────────────────── */
.progress-bar-wrap{background:var(--border);border-radius:20px;overflow:hidden;height:5px}
.progress-bar{height:100%;border-radius:20px;transition:width 1s ease}
.progress-bar.blue {background:#2563eb}
.progress-bar.green{background:#22c55e}
.progress-bar.amber{background:#f59e0b}
.progress-bar.rose {background:#ef4444}

.tabs{display:flex;gap:4px;background:var(--inp);border-radius:11px;padding:4px;margin-bottom:18px;border:1px solid var(--border)}
.tab-btn{flex:1;padding:7px 10px;border-radius:8px;background:none;border:none;color:var(--t3);font-family:'Cairo',sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}
.tab-btn.active{background:var(--card);color:var(--t1);box-shadow:var(--shadow)}
.tab-content{display:none}
.tab-content.active{display:block;animation:fade .3s ease}

.filter-bar {display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.filter-chip{padding:5px 11px;border-radius:20px;background:var(--card);border:1px solid var(--border);color:var(--t2);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s}
.filter-chip:hover {background:var(--inp);border-color:var(--border2);color:var(--t1)}
.filter-chip.active{background:var(--badge-blue);border-color:rgba(37,99,235,.25);color:var(--badge-blue-t)}

.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}
.section-title {font-size:15px;font-weight:900;color:var(--t1);display:flex;align-items:center;gap:8px}
.section-title i{color:var(--blue)}

.stat-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border)}
.stat-row:last-child{border-bottom:none}
.stat-row-label{font-size:12px;color:var(--t3)}
.stat-row-value{font-size:13px;font-weight:800;color:var(--t1)}
.stat-row-value.mono{font-family:'JetBrains Mono',monospace}

.empty-state{text-align:center;padding:44px 20px;color:var(--t3)}
.empty-state i{font-size:38px;display:block;margin-bottom:10px;color:var(--t3)}
.empty-state p{font-size:12.5px}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:20px}

/* ── RESPONSIVE ───────────────────────────────────── */
@media(max-width:1300px){
  .charts-grid-3{grid-template-columns:1fr 1fr}
  .charts-grid-3>:last-child{grid-column:1/-1}
  .smart-stats-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .main-content{margin-right:0}
  .sidebar{transform:translateX(100%)}
  .sidebar.mobile-open{transform:translateX(0)}
}
@media(max-width:900px){
  .charts-grid-2,.charts-grid-3{grid-template-columns:1fr}
  .welcome-banner{flex-direction:column;align-items:flex-start}
  .welcome-stats {width:100%;justify-content:space-around}
  .smart-stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .page-body{padding:12px}
  .topbar{padding:0 14px}
  .search-box{display:none}
  .smart-stats-row,.health-grid{grid-template-columns:1fr 1fr}
}
