/* ── Reset & Base ────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#2563EB; --blue-dark:#1D4ED8; --blue-light:#EFF6FF; --blue-mid:#DBEAFE;
  --green:#16A34A; --green-light:#F0FDF4; --green-border:#BBF7D0;
  --amber:#D97706; --amber-light:#FFFBEB; --amber-border:#FDE68A;
  --red:#DC2626;   --red-light:#FEF2F2;  --red-border:#FCA5A5;
  --navy:#0D1117;  --navy2:#161B22;
  --body:#F1F5F9;  --card:#FFFFFF;
  --text:#0F172A;  --muted:#64748B; --soft:#94A3B8;
  --border:#E2E8F0; --border2:#CBD5E1;
  --shadow-sm:0 1px 2px rgba(0,0,0,.06);
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 8px 32px rgba(0,0,0,.12);
  --r:14px; --r-sm:10px;
  --sidebar-w:248px;
}
html{font-size:15px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:var(--body);color:var(--text);
  display:flex;min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.5}
svg{display:block;flex-shrink:0}
a{color:var(--blue);text-decoration:none}
img{display:block}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);min-height:100vh;
  background:#0D1117;
  display:flex;flex-direction:column;flex-shrink:0;
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  border-right:1px solid rgba(255,255,255,.06);
}
.sidebar-brand{
  padding:1.1rem 1.2rem;min-height:62px;
  display:flex;align-items:center;gap:.65rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.sidebar-company-logo{
  height:32px;max-width:148px;object-fit:contain;
  background:rgba(255,255,255,.92);border-radius:7px;padding:3px 8px;
}
.sidebar-brand-logo{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,#3B82F6,#1D4ED8);
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;font-weight:900;color:#fff;
}
.sidebar-brand-text{font-size:.95rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.sidebar-brand-text span{color:#60A5FA}
.sidebar-nav{flex:1;padding:.5rem .65rem;display:flex;flex-direction:column;gap:.02rem;overflow-y:auto}
.nav-section{
  font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:rgba(255,255,255,.22);padding:.9rem .7rem .25rem;margin-top:.1rem;
}
.nav-link{
  display:flex;align-items:center;gap:.6rem;
  padding:.5rem .75rem;border-radius:8px;
  color:rgba(255,255,255,.48);font-size:.825rem;font-weight:500;
  transition:background .12s,color .12s;position:relative;
}
.nav-link:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.82)}
.nav-link.active{background:rgba(59,130,246,.18);color:#93C5FD;font-weight:600}
.nav-link.active::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:3px;background:#3B82F6;border-radius:0 3px 3px 0;
}
.sidebar-footer{
  padding:.85rem 1.1rem 1rem;border-top:1px solid rgba(255,255,255,.07);
}
.sidebar-user-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.45rem}
.sidebar-avatar{
  width:26px;height:26px;border-radius:7px;background:rgba(59,130,246,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:700;color:#93C5FD;flex-shrink:0;
}
.sidebar-user{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.55);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-logout{display:inline-flex;align-items:center;gap:.3rem;
  font-size:.76rem;color:rgba(255,255,255,.28);transition:color .15s}
.sidebar-logout:hover{color:#EF4444}

/* ── Main Wrapper ────────────────────────────────────────────────────────── */
.main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}
.page-header{
  background:var(--card);border-bottom:1px solid var(--border);
  padding:.85rem 2rem;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:50;
}
.page-header-left h1,.page-title{font-size:.975rem;font-weight:700;color:var(--text);letter-spacing:-.01em}
.page-header-left p,.page-sub{font-size:.775rem;color:var(--muted);margin-top:.1rem}
.page-header h1{font-size:.975rem;font-weight:700;color:var(--text)}
.page-header p{font-size:.775rem;color:var(--muted);margin-top:.1rem}
.container{padding:1.5rem 2rem;max-width:1300px}
.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.75rem;align-items:end}

/* ── Alerts ──────────────────────────────────────────────────────────────── */
.alert{padding:.7rem 1rem;border-radius:10px;margin-bottom:1rem;font-size:.855rem;font-weight:500;
  display:flex;align-items:center;gap:.5rem}
.alert.error{background:var(--red-light);color:#991B1B;border:1px solid var(--red-border)}
.alert.ok-alert{background:var(--green-light);color:#14532D;border:1px solid var(--green-border)}

/* ── Stat-Karten ─────────────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;margin-bottom:1.4rem}
.stat-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  padding:1.1rem 1.25rem 1rem;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:1rem;
  border-left:4px solid transparent;transition:box-shadow .18s;
}
.stat-card:hover{box-shadow:var(--shadow-md)}
.stat-card.blue-card{border-left-color:#3B82F6}
.stat-card.amber-card{border-left-color:#F59E0B}
.stat-card.red-card{border-left-color:#EF4444}
.stat-card.green-card{border-left-color:#22C55E}
.stat-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.stat-icon.blue{background:var(--blue-light)} .stat-icon.blue svg{color:#2563EB}
.stat-icon.amber{background:var(--amber-light)} .stat-icon.amber svg{color:#D97706}
.stat-icon.red{background:var(--red-light)} .stat-icon.red svg{color:#DC2626}
.stat-icon.green{background:var(--green-light)} .stat-icon.green svg{color:#16A34A}
.stat-body{flex:1}
.stat-num{font-size:2rem;font-weight:800;line-height:1;color:var(--text);letter-spacing:-.04em}
.stat-label{font-size:.67rem;color:var(--muted);margin-top:.25rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em}

/* ── Fleet Summary ───────────────────────────────────────────────────────── */
.fleet-summary{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  padding:.9rem 1.5rem;margin-bottom:1.3rem;
  display:flex;align-items:center;gap:0;box-shadow:var(--shadow-sm);
}
.fleet-summary-item{flex:1;text-align:center}
.fleet-summary-sep{width:1px;height:36px;background:var(--border);flex-shrink:0}
.fleet-summary-num{font-size:1.8rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.fleet-summary-num.ok{color:#16A34A}
.fleet-summary-num.warn{color:#D97706}
.fleet-summary-num.danger{color:#DC2626}
.fleet-summary-label{font-size:.68rem;color:var(--muted);margin-top:.2rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em}

/* ── Fleet Vehicle Cards ─────────────────────────────────────────────────── */
.fleet-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1rem;margin-bottom:1.5rem;
}
.fleet-vehicle-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow-sm);padding:1.1rem 1.2rem;
  display:flex;flex-direction:column;gap:.7rem;
  transition:box-shadow .18s,transform .18s;
  border-top:3px solid var(--border2);
}
.fleet-vehicle-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.fleet-vehicle-card.ok{border-top-color:#22C55E}
.fleet-vehicle-card.notice{border-top-color:#3B82F6}
.fleet-vehicle-card.warn{border-top-color:#F59E0B}
.fleet-vehicle-card.danger{border-top-color:#EF4444}
.fvc-header{display:flex;align-items:center;gap:.85rem}
.fvc-img{width:58px;height:38px;object-fit:cover;border-radius:7px;border:1px solid var(--border)}
.fvc-img-placeholder{
  width:58px;height:38px;border-radius:7px;border:1px solid var(--border);
  background:var(--body);display:flex;align-items:center;justify-content:center;
  color:var(--soft);flex-shrink:0;
}
.fvc-plate{font-size:1rem;font-weight:800;color:var(--text);letter-spacing:.02em}
.fvc-model{font-size:.815rem;color:var(--muted);font-weight:500;
  display:flex;align-items:center;gap:.5rem}
.fvc-fuel{
  font-size:.68rem;font-weight:700;padding:.1rem .45rem;border-radius:999px;
  background:var(--blue-light);color:var(--blue);
}
.fvc-dates{display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--border);padding-top:.7rem}
.fvc-date-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.fvc-date-label{font-size:.72rem;font-weight:600;color:var(--muted);white-space:nowrap}
.fvc-missing{font-size:.72rem;color:var(--soft);font-style:italic}
.fvc-service-km{font-size:.75rem;font-weight:600;color:var(--text)}
.fvc-edit-btn{
  margin-top:.2rem;font-size:.78rem;font-weight:600;color:var(--blue);
  padding:.35rem 0;transition:opacity .15s;
}
.fvc-edit-btn:hover{opacity:.7}

/* ── Fleet Alerts (Dashboard Widget) ────────────────────────────────────── */
.fleet-alerts-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow-sm);margin-bottom:1.4rem;overflow:hidden;
}
.fleet-alerts-head{
  padding:.85rem 1.3rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.fleet-alerts-title{
  font-size:.875rem;font-weight:700;color:var(--text);
  display:flex;align-items:center;gap:.5rem;
}
.fleet-alerts-count{
  font-size:.7rem;font-weight:700;
  background:var(--amber-light);color:var(--amber);
  padding:.15rem .55rem;border-radius:999px;border:1px solid var(--amber-border);
}
.fleet-alert-row{
  display:flex;align-items:center;gap:1rem;
  padding:.75rem 1.3rem;border-bottom:1px solid var(--border);transition:background .1s;
}
.fleet-alert-row:last-child{border-bottom:none}
.fleet-alert-row:hover{background:#FAFBFC}
.fleet-alert-plate{font-size:.875rem;font-weight:700;color:var(--text);min-width:88px}
.fleet-alert-model{font-size:.795rem;color:var(--muted);flex:1}
.fleet-alert-items{display:flex;gap:.45rem;flex-wrap:wrap}
.fleet-alert-edit{
  font-size:.76rem;color:var(--muted);padding:.28rem .6rem;border-radius:7px;
  border:1px solid var(--border);background:transparent;cursor:pointer;
  transition:all .15s;font-family:inherit;font-weight:500;white-space:nowrap;
}
.fleet-alert-edit:hover{color:var(--blue);border-color:var(--blue);background:var(--blue-light)}
.fleet-empty{
  padding:2rem;text-align:center;color:var(--muted);font-size:.855rem;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}

/* ── Date Badges ─────────────────────────────────────────────────────────── */
.fleet-date-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.2rem .6rem;border-radius:999px;
  font-size:.7rem;font-weight:700;white-space:nowrap;
}
.fleet-date-badge.ok{background:var(--green-light);color:#14532D;border:1px solid var(--green-border)}
.fleet-date-badge.warn{background:var(--amber-light);color:#78350F;border:1px solid var(--amber-border)}
.fleet-date-badge.danger{background:var(--red-light);color:#7F1D1D;border:1px solid var(--red-border)}
.fleet-date-badge.overdue{background:#DC2626;color:#fff}

/* ── Cards ───────────────────────────────────────────────────────────────── */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:1.25rem 1.5rem;
  box-shadow:var(--shadow-sm);margin-bottom:1.2rem;
}
.card-title{font-size:.875rem;font-weight:700;color:var(--text);margin-bottom:1rem;
  display:flex;align-items:center;gap:.5rem}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}

/* ── Table ───────────────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);
  background:var(--card);box-shadow:var(--shadow-sm)}
.table{width:100%;border-collapse:collapse;background:var(--card)}
.table thead{background:#F8FAFC;border-bottom:1px solid var(--border)}
.table th{
  text-align:left;font-size:.67rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:700;padding:.8rem 1rem;
  white-space:nowrap;
}
.table td{padding:.8rem 1rem;border-bottom:1px solid var(--border);
  font-size:.855rem;vertical-align:middle}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr:hover td{background:#F8FAFC}
.secondary{display:block;font-size:.74rem;color:var(--muted);margin-top:.1rem}
.vehicle-cell{display:flex;align-items:center;gap:.7rem}
.thumb{width:48px;height:32px;object-fit:cover;border-radius:6px;
  border:1px solid var(--border);background:var(--body);flex-shrink:0}
.empty{text-align:center;color:var(--muted);padding:3rem 1rem;font-size:.875rem}

/* ── Badges ──────────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;
  font-size:.7rem;font-weight:700;white-space:nowrap}
.badge.low{background:var(--green-light);color:#14532D;border:1px solid var(--green-border)}
.badge.medium{background:var(--amber-light);color:#78350F;border:1px solid var(--amber-border)}
.badge.high{background:var(--red-light);color:#7F1D1D;border:1px solid var(--red-border)}
.badge-blue{background:var(--blue-light);color:#1E40AF}
.badge-gray{background:#F1F5F9;color:#475569}
.badge-purple{background:#F5F3FF;color:#5B21B6}
.status{display:inline-flex;padding:.2rem .6rem;border-radius:999px;
  font-size:.7rem;font-weight:700}
.status.pending{background:var(--blue-light);color:#1E40AF}
.status.approved{background:var(--green-light);color:#14532D}
.status.flagged{background:var(--red-light);color:#7F1D1D}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.48rem .95rem;border-radius:9px;border:1px solid var(--border);
  background:var(--card);color:var(--text);font-weight:600;cursor:pointer;
  font-size:.83rem;font-family:inherit;transition:all .14s;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.btn:hover{background:#F1F5F9;border-color:var(--border2)}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.primary:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.btn.success{background:#16A34A;border-color:#16A34A;color:#fff}
.btn.success:hover{background:#15803D;border-color:#15803D}
.btn.danger{background:#DC2626;border-color:#DC2626;color:#fff}
.btn.danger:hover{background:#B91C1C;border-color:#B91C1C}
.btn.sm{padding:.32rem .65rem;font-size:.77rem}
.btn.small{padding:.28rem .55rem;font-size:.74rem}
.btn.block{width:100%;justify-content:center}

/* ── Filter Chips ────────────────────────────────────────────────────────── */
.filter-chip{
  display:inline-flex;align-items:center;padding:.22rem .7rem;border-radius:999px;
  font-size:.73rem;font-weight:600;color:var(--muted);border:1px solid var(--border);
  background:var(--card);cursor:pointer;text-decoration:none;transition:all .13s;
}
.filter-chip:hover{color:var(--blue);border-color:var(--blue);background:var(--blue-light)}
.filter-chip.active{color:var(--blue);border-color:var(--blue);background:var(--blue-light)}

/* ── Auth ────────────────────────────────────────────────────────────────── */
body:has(.auth-layout){display:block}
.auth-layout{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.auth-brand{
  background:linear-gradient(160deg,#0D1117 0%,#0f2040 100%);
  display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem;
  position:relative;overflow:hidden;
}
.auth-brand::before{content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.14) 0%,transparent 70%)}
.auth-brand-inner{position:relative;z-index:1;max-width:340px}
.auth-logo{font-size:2.6rem;font-weight:900;color:#fff;letter-spacing:-.04em;margin-bottom:.5rem}
.auth-logo span{color:#60A5FA}
.auth-tagline{color:rgba(255,255,255,.48);font-size:.9rem;line-height:1.6;margin-bottom:2.5rem}
.auth-features{display:flex;flex-direction:column;gap:.85rem}
.auth-feature{display:flex;align-items:center;gap:.75rem;color:rgba(255,255,255,.6);font-size:.86rem}
.auth-feature-icon{width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:rgba(59,130,246,.18);display:flex;align-items:center;justify-content:center}
.auth-feature-icon svg{color:#93C5FD;width:15px;height:15px}
.auth-form-wrap{display:flex;align-items:center;justify-content:center;
  background:#fff;padding:3rem 2rem}
.auth-form-box{width:100%;max-width:380px}
.auth-form-title{font-size:1.5rem;font-weight:800;color:var(--navy);
  letter-spacing:-.03em;margin-bottom:.35rem}
.auth-form-sub{color:var(--muted);font-size:.875rem;margin-bottom:1.8rem}
.auth-link{font-size:.82rem;color:var(--blue);font-weight:500}
.auth-link:hover{text-decoration:underline}
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:.77rem;font-weight:600;color:var(--text);margin-bottom:.35rem}
.form-input{
  width:100%;padding:.6rem .88rem;border:1.5px solid var(--border);border-radius:9px;
  font-size:.875rem;font-family:inherit;background:#fff;color:var(--text);
  transition:border-color .15s,box-shadow .15s;outline:none;
}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .88rem center;padding-right:2.2rem}
@media(max-width:700px){.auth-layout{grid-template-columns:1fr}.auth-brand{display:none}.auth-form-wrap{padding:2rem 1.5rem}}

/* ── Detail ──────────────────────────────────────────────────────────────── */
.back-link{display:inline-flex;align-items:center;gap:.45rem;
  font-size:.82rem;color:#374151;font-weight:600;margin-bottom:1rem;
  background:#fff;border:1.5px solid #E2E8F0;border-radius:99px;
  padding:.45rem 1rem .45rem .7rem;text-decoration:none;
  box-shadow:0 1px 3px rgba(0,0,0,.06);transition:all .15s}
.back-link svg{width:16px;height:16px;color:#6B7280;flex-shrink:0}
.back-link:hover{background:#F8FAFC;border-color:#CBD5E1;color:#111827;box-shadow:0 2px 6px rgba(0,0,0,.09)}
.detail-title{font-size:1.2rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.photos-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.photo-label{font-size:.71rem;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
.photo-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;border:1px solid var(--border)}
.photo-ph{width:100%;aspect-ratio:4/3;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.4rem;
  background:var(--body);border:1.5px dashed var(--border);border-radius:10px;
  color:var(--soft);font-size:.8rem}
.kv{display:grid;grid-template-columns:auto 1fr;gap:.4rem .9rem;align-items:baseline}
.kv dt{font-size:.77rem;color:var(--muted);font-weight:500;white-space:nowrap}
.kv dd{font-size:.855rem;font-weight:600;color:var(--text)}
.map{height:230px;border-radius:10px;border:1px solid var(--border);overflow:hidden}

/* ── Fraud ───────────────────────────────────────────────────────────────── */
.flaglist{list-style:none;padding:0;margin:.7rem 0 .5rem;display:flex;flex-direction:column;gap:.5rem}
.flag-item{display:flex;align-items:flex-start;gap:.7rem;
  padding:.6rem .88rem;border-radius:10px;
  background:var(--amber-light);border:1px solid var(--amber-border)}
.flag-item.critical{background:var(--red-light);border-color:var(--red-border)}
.flagweight{flex:0 0 auto;min-width:30px;height:20px;padding:0 .3rem;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.7rem;color:#fff;background:var(--amber);border-radius:5px;margin-top:.1rem}
.flagweight.crit{background:var(--red)}
.flag-msg{font-size:.835rem;color:var(--text);line-height:1.4}
.no-flags{
  display:flex;align-items:center;gap:.65rem;
  color:#14532D;font-weight:600;font-size:.875rem;
  background:#F0FDF4;border:1px solid #BBF7D0;
  border-radius:10px;padding:.8rem 1rem;
}
.no-flags svg{width:20px;height:20px;flex-shrink:0;color:#16A34A}

/* ── Forms ───────────────────────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1rem;align-items:end}
.form-grid .full{grid-column:1/-1}
.action-bar{display:flex;gap:.7rem;flex-wrap:wrap}
.action-bar form{margin:0}

/* ── Modal ───────────────────────────────────────────────────────────────── */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);
  z-index:9000;align-items:center;justify-content:center}
.modal-backdrop.open{display:flex}
.modal{background:#fff;border-radius:16px;padding:1.75rem;max-width:440px;width:90%;
  box-shadow:var(--shadow-lg);animation:modal-in .2s ease}
@keyframes modal-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.modal-title{font-size:.975rem;font-weight:800;color:var(--text);margin-bottom:1.2rem}
.modal-footer{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.2rem}

/* ── Misc ────────────────────────────────────────────────────────────────── */
.ok{color:var(--green);font-weight:700}
.muted{color:var(--muted)}
.text-sm{font-size:.8rem}
.mt-sm{margin-top:.5rem}
.section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);margin-bottom:.6rem;display:block}
hr.sep{border:none;border-top:1px solid var(--border);margin:1rem 0}

/* ── Damage Reports ──────────────────────────────────────────────────────── */
.damage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;margin-bottom:1.5rem}
.damage-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;
  border-left:4px solid var(--border2);transition:box-shadow .18s;
}
.damage-card:hover{box-shadow:var(--shadow-md)}
.damage-card.status-neu{border-left-color:#EF4444}
.damage-card.status-gesehen{border-left-color:#F59E0B}
.damage-card.status-in_reparatur{border-left-color:#3B82F6}
.damage-card.status-abgeschlossen{border-left-color:#22C55E}
.damage-photos{
  display:flex;gap:4px;padding:10px 10px 0;background:var(--body);
  overflow-x:auto;scrollbar-width:none;
}
.damage-photos::-webkit-scrollbar{display:none}
.damage-thumb{
  width:90px;height:70px;object-fit:cover;border-radius:8px;
  border:1px solid var(--border);cursor:pointer;flex-shrink:0;
  transition:opacity .15s;
}
.damage-thumb:hover{opacity:.85}
.damage-body{padding:.9rem 1.1rem;flex:1;display:flex;flex-direction:column;gap:.55rem}
.damage-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}
.damage-vehicle{font-size:.9rem;font-weight:700;color:var(--text)}
.damage-plate{
  font-size:.72rem;font-weight:700;color:var(--muted);letter-spacing:.04em;
  background:var(--body);border:1px solid var(--border);border-radius:5px;
  padding:.05rem .35rem;margin-top:.2rem;display:inline-block;
}
.damage-meta{font-size:.75rem;color:var(--muted);display:flex;gap:.75rem;align-items:center}
.damage-desc{font-size:.84rem;color:var(--text);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.damage-gps{font-size:.73rem;color:var(--muted);display:flex;align-items:center;gap:.3rem}
.status-update-row{display:flex;gap:.5rem;align-items:center;margin-top:auto;padding-top:.55rem;
  border-top:1px solid var(--border)}
.status-select{
  flex:1;padding:.3rem .6rem;border:1px solid var(--border);border-radius:7px;
  font-size:.78rem;font-family:inherit;background:var(--card);color:var(--text);
  appearance:none;cursor:pointer;
}
.status-select:focus{outline:none;border-color:var(--blue)}
/* Damage status badges */
.badge{display:inline-flex;align-items:center;padding:.12rem .5rem;border-radius:999px;
  font-size:.68rem;font-weight:700;letter-spacing:.02em;white-space:nowrap}
.badge-neu{background:#FEF2F2;color:#B91C1C;border:1px solid #FCA5A5}
.badge-gesehen{background:#FFFBEB;color:#92400E;border:1px solid #FDE68A}
.badge-in_reparatur{background:#EFF6FF;color:#1D4ED8;border:1px solid #BFDBFE}
.badge-abgeschlossen{background:#F0FDF4;color:#14532D;border:1px solid #BBF7D0}
/* Photo lightbox */
#photo-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);
  z-index:9999;align-items:center;justify-content:center;cursor:pointer;
}
#photo-overlay.open{display:flex}
#photo-full{max-width:90vw;max-height:90vh;border-radius:12px;object-fit:contain}

/* ── Pagination ──────────────────────────────────────────────────────────── */
.pagination{
  display:flex;align-items:center;gap:.3rem;justify-content:center;
  padding:.85rem 1rem;border-top:1px solid var(--border);background:var(--card);
}
.page-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:34px;height:34px;padding:0 .6rem;border-radius:8px;
  font-size:.82rem;font-weight:600;color:var(--text);
  border:1px solid var(--border);background:var(--card);
  text-decoration:none;transition:all .13s;white-space:nowrap;
}
.page-btn:hover{background:#F1F5F9;border-color:var(--border2)}
.page-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.page-btn.disabled{color:var(--soft);pointer-events:none}
.page-btn.dots{border:none;background:none;color:var(--muted);pointer-events:none;min-width:20px}

/* ── Stat-Karten klickbar ────────────────────────────────────────────────── */
.stat-link{display:flex;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}
.stat-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ── Charts ──────────────────────────────────────────────────────────────── */
.charts-row{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.2rem}
.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  padding:1.1rem 1.2rem}
.chart-title{font-size:.78rem;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.06em;margin-bottom:.8rem}

/* ── Tabellen-Checkboxen + Bulk-Bar ─────────────────────────────────────── */
.row-cb{cursor:pointer;accent-color:var(--blue);width:15px;height:15px}
#bulk-bar{display:none;background:#EFF6FF;border-bottom:1px solid #BFDBFE;
  padding:.5rem 1rem;align-items:center;gap:.7rem;flex-wrap:wrap}

/* ── Utility ─────────────────────────────────────────────────────────────── */
.hidden{display:none!important}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.1rem 1.2rem;margin-bottom:1rem}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.1rem}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:900px){
  .sidebar{display:none}.main-wrap{margin-left:0}
  .stats{grid-template-columns:1fr 1fr}
  .grid-2,.photos-grid,.form-grid{grid-template-columns:1fr}
  .fleet-grid{grid-template-columns:1fr}
}
@media(max-width:560px){.stats{grid-template-columns:1fr}.container{padding:1rem}}
