/* ============================================================
   Autophix CRM — Admin Stylesheet
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg:       #0a0a0a;
  --surface:  #141414;
  --panel:    #1c1c1c;
  --panel2:   #242424;
  --border:   rgba(255,255,255,0.08);
  --border2:  rgba(255,255,255,0.14);
  --red:      #e63232;
  --red-d:    #b82a2a;
  --green:    #27ae60;
  --amber:    #e67e22;
  --blue:     #2980b9;
  --purple:   #8e44ad;
  --teal:     #16a085;
  --white:    #f0eeea;
  --muted:    rgba(240,238,234,0.45);
  --mono:     'JetBrains Mono', monospace;
  --body:     'DM Sans', sans-serif;
  --sidebar-w: 230px;
  --topbar-h:  58px;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:15px; }
body { font-family:var(--body); background:var(--bg); color:var(--white); line-height:1.6; }

a { color:var(--red); text-decoration:none; }
a:hover { color:var(--white); }
input, select, textarea, button { font-family:var(--body); }

/* ── Layout ─────────────────────────────────────────────── */
.admin-body  { overflow:hidden; height:100vh; }
.admin-wrap  { display:flex; height:100vh; }
.admin-main  { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.admin-content { flex:1; overflow-y:auto; padding:28px 32px; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar {
  width:var(--sidebar-w); background:var(--surface);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column; flex-shrink:0;
  height:100vh; overflow-y:auto;
}
.sidebar-brand { padding:20px 20px 16px; border-bottom:1px solid var(--border); }
.brand-link { font-family:var(--mono); font-size:22px; font-weight:900; color:var(--white); letter-spacing:2px; }
.brand-link span { color:var(--red); }
.brand-sub { font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:2px; margin-top:2px; text-transform:uppercase; }

.sidebar-nav { flex:1; padding:12px 0; }
.sidebar-nav ul { list-style:none; }
.sidebar-nav .nav-label {
  font-family:var(--mono); font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:var(--muted); padding:14px 20px 4px;
}
.sidebar-nav li a {
  display:flex; align-items:center; gap:10px;
  padding:9px 20px; color:var(--muted); font-size:13px;
  transition:background .15s, color .15s;
}
.sidebar-nav li a .icon { font-size:15px; width:18px; text-align:center; }
.sidebar-nav li a:hover, .sidebar-nav li.active a {
  background:var(--panel); color:var(--white);
}
.sidebar-nav li.active a { border-left:2px solid var(--red); }

.sidebar-footer { padding:16px 20px; border-top:1px solid var(--border); }
.admin-user { display:flex; align-items:center; gap:10px; }
.admin-avatar { width:34px; height:34px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; flex-shrink:0; }
.admin-name { font-size:13px; font-weight:500; }
.logout-link { font-size:11px; color:var(--muted); }
.logout-link:hover { color:var(--red); }

/* ── Topbar ─────────────────────────────────────────────── */
.admin-topbar {
  height:var(--topbar-h); background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:16px; padding:0 28px;
}
.topbar-title { font-family:var(--mono); font-size:13px; color:var(--muted); flex:1; }
.topbar-actions { display:flex; gap:8px; }
.menu-toggle { display:none; background:none; border:none; color:var(--white); font-size:20px; cursor:pointer; }

/* ── Alerts ─────────────────────────────────────────────── */
.alert { padding:12px 20px; margin:0 32px 0; font-size:13px; border-radius:3px; }
.alert-success { background:rgba(39,174,96,.12); border-left:3px solid var(--green); color:#7dcea0; }
.alert-error   { background:rgba(230,50,50,.12);  border-left:3px solid var(--red);   color:#ec7575; }

/* ── Page header ─────────────────────────────────────────── */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.page-header-left { display:flex; align-items:baseline; gap:12px; }
.page-header h2 { font-family:var(--mono); font-size:20px; font-weight:500; color:var(--white); }
.record-count { font-family:var(--mono); font-size:11px; color:var(--muted); background:var(--panel2); padding:2px 8px; border-radius:10px; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn { display:inline-block; padding:9px 20px; border-radius:2px; font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; border:1px solid transparent; transition:.2s; text-decoration:none; white-space:nowrap; }
.btn-primary { background:var(--red); color:#fff; border-color:var(--red); }
.btn-primary:hover { background:var(--red-d); color:#fff; }
.btn-outline { background:transparent; color:var(--white); border-color:var(--border2); }
.btn-outline:hover { border-color:var(--white); }
.btn-ghost { background:transparent; color:var(--muted); border-color:transparent; }
.btn-ghost:hover { color:var(--white); }
.btn-red { border-color:var(--red); color:var(--red); }
.btn-red:hover { background:var(--red); color:#fff; }
.btn-sm { padding:6px 14px; font-size:10px; }
.btn-xs { padding:4px 10px; font-size:10px; }
.btn-full { width:100%; text-align:center; }

/* ── Badges ─────────────────────────────────────────────── */
.badge { display:inline-block; padding:2px 8px; border-radius:2px; font-family:var(--mono); font-size:10px; letter-spacing:.04em; text-transform:uppercase; white-space:nowrap; }
.badge-grey   { background:rgba(255,255,255,.07); color:#aaa; }
.badge-red    { background:rgba(230,50,50,.15); color:#e87979; }
.badge-green  { background:rgba(39,174,96,.15); color:#7dcea0; }
.badge-amber  { background:rgba(230,126,34,.15); color:#e8aa79; }
.badge-blue   { background:rgba(41,128,185,.15); color:#79b4e8; }
.badge-purple { background:rgba(142,68,173,.15); color:#c39bd3; }
.badge-teal   { background:rgba(22,160,133,.15); color:#7ecec4; }

/* ── Table ─────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; border-radius:4px; border:1px solid var(--border); }
.data-table { width:100%; border-collapse:collapse; }
.data-table thead tr { background:var(--panel2); }
.data-table th { padding:10px 14px; text-align:left; font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--border); white-space:nowrap; }
.data-table td { padding:10px 14px; border-bottom:1px solid var(--border); font-size:13px; vertical-align:middle; }
.data-table tbody tr:last-child td { border-bottom:none; }
.data-table tbody tr:hover { background:var(--panel); }
.data-table-sm th, .data-table-sm td { padding:7px 12px; }
.row-overdue { background:rgba(230,50,50,.04)!important; }
.row-actions { display:flex; gap:10px; align-items:center; }
.row-actions a { font-size:15px; color:var(--muted); transition:.15s; }
.row-actions a:hover { color:var(--white); }
.row-link { color:var(--white); font-weight:500; }
.row-link:hover { color:var(--red); }
.row-sub { font-size:11px; color:var(--muted); margin-top:2px; }
.text-center { text-align:center; }
.text-red { color:#e87979; }
.empty-state { text-align:center; color:var(--muted); padding:40px; font-size:13px; }

/* ── Plate tag ─────────────────────────────────────────── */
.plate-tag { font-family:var(--mono); font-size:12px; background:#f0d060; color:#111; padding:2px 7px; border-radius:2px; letter-spacing:1px; font-weight:700; }
.mono { font-family:var(--mono); font-size:12px; }

/* ── Filter bar ─────────────────────────────────────────── */
.filter-bar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; align-items:center; }
.filter-bar input[type="text"], .filter-bar input[type="search"] {
  background:var(--panel); border:1px solid var(--border2); border-radius:2px;
  padding:8px 12px; color:var(--white); font-size:13px; min-width:200px; outline:none;
}
.filter-bar select { background:var(--panel); border:1px solid var(--border2); border-radius:2px; padding:8px 12px; color:var(--white); font-size:13px; outline:none; }

/* ── Stats grid ─────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-bottom:24px; }
.stat-card { background:var(--panel); border:1px solid var(--border); border-radius:4px; padding:20px; display:flex; gap:14px; align-items:center; }
.stat-card--alert { border-color:rgba(230,50,50,.3); }
.stat-icon { font-size:24px; }
.stat-num { font-family:var(--mono); font-size:28px; font-weight:700; line-height:1; }
.stat-label { font-size:11px; color:var(--muted); margin-top:3px; }

.revenue-banner { background:var(--panel2); border:1px solid var(--border); border-radius:4px; padding:18px 24px; display:flex; align-items:center; gap:32px; margin-bottom:24px; }
.rev-item { flex:1; }
.rev-label { font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.rev-num { font-family:var(--mono); font-size:24px; font-weight:700; color:var(--white); }
.rev-num--alert { color:#7dcea0; }
.rev-divider { width:1px; height:40px; background:var(--border2); }
.rev-actions { flex:0; }

/* ── Dashboard 3-panel ──────────────────────────────────── */
.dash-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.dash-card { background:var(--panel); border:1px solid var(--border); border-radius:4px; display:flex; flex-direction:column; }
.dash-card-header { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--border); }
.dash-card-header h3 { font-size:13px; font-weight:500; }
.link-sm { font-family:var(--mono); font-size:10px; color:var(--muted); }
.link-sm:hover { color:var(--red); }
.dash-card-body { flex:1; padding:4px 0; }
.dash-row { display:flex; align-items:center; justify-content:space-between; padding:10px 18px; border-bottom:1px solid var(--border); }
.dash-row:last-child { border-bottom:none; }
.dash-row-title { font-size:13px; }
.dash-row-title a { color:var(--white); }
.dash-row-sub { font-size:11px; color:var(--muted); margin-top:2px; }

/* ── Forms ─────────────────────────────────────────────── */
.crm-form { max-width:900px; }
.form-section { background:var(--panel); border:1px solid var(--border); border-radius:4px; padding:24px; margin-bottom:16px; }
.form-section-title { font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; }
.form-grid { display:grid; gap:16px; }
.form-grid-2 { grid-template-columns:1fr 1fr; }
.form-grid-3 { grid-template-columns:1fr 1fr 1fr; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.form-group input, .form-group select, .form-group textarea {
  background:var(--panel2); border:1px solid var(--border2); border-radius:2px;
  padding:10px 12px; color:var(--white); font-size:14px; outline:none; transition:border-color .2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--red); }
.form-group textarea { resize:vertical; min-height:90px; }
.form-group select option { background:var(--panel2); }
.form-group.has-error input, .form-group.has-error select { border-color:var(--red); }
.field-error { font-size:11px; color:#e87979; }
.form-actions { display:flex; gap:12px; align-items:center; padding-top:8px; }
.form-options { background:transparent; border:none; padding:0; }
.checkbox-label { display:flex; align-items:center; gap:8px; font-size:13px; cursor:pointer; }
.checkbox-label input { width:auto; }

/* ── Client summary box ─────────────────────────────────── */
.client-summary-box { background:var(--panel2); border:1px solid var(--border2); border-radius:3px; padding:14px 16px; }
.csb-name { font-size:15px; font-weight:500; margin-bottom:4px; }
.csb-meta { font-size:13px; color:var(--muted); display:flex; align-items:center; gap:10px; flex-wrap:wrap; }

/* ── Line items table ───────────────────────────────────── */
.line-items-wrap { background:var(--panel2); border:1px solid var(--border); border-radius:3px; overflow:hidden; margin-bottom:12px; }
.line-items-table { width:100%; border-collapse:collapse; }
.line-items-table th { padding:8px 12px; font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); background:var(--panel); border-bottom:1px solid var(--border); text-align:left; }
.line-items-table td { padding:6px 8px; border-bottom:1px solid var(--border); vertical-align:middle; }
.line-items-table td input, .line-items-table td select {
  background:var(--panel); border:1px solid transparent; border-radius:2px;
  padding:5px 8px; color:var(--white); font-size:13px; width:100%;
}
.line-items-table td input:focus, .line-items-table td select:focus { border-color:var(--red); }
.line-items-table td.td-remove { width:32px; text-align:center; }
.remove-btn { background:none; border:none; color:var(--muted); cursor:pointer; font-size:16px; }
.remove-btn:hover { color:var(--red); }

/* ── Totals box ─────────────────────────────────────────── */
.totals-box { background:var(--panel2); border:1px solid var(--border); border-radius:3px; padding:20px; }
.totals-row { display:flex; justify-content:space-between; padding:6px 0; font-size:14px; border-bottom:1px solid var(--border); }
.totals-row:last-child { border-bottom:none; }
.totals-total { font-family:var(--mono); font-size:18px; font-weight:700; color:var(--red); padding-top:10px; margin-top:6px; }
.quote-totals-section { background:transparent; border:none; padding:0; }

/* ── Card ─────────────────────────────────────────────── */
.card { background:var(--panel); border:1px solid var(--border); border-radius:4px; }
.card-header { padding:14px 18px; border-bottom:1px solid var(--border); }
.card-header h4 { font-size:14px; font-weight:500; }
.card-body { padding:18px; }

/* ── Info box ─────────────────────────────────────────── */
.info-box { background:var(--panel); border:1px solid var(--border); border-radius:4px; padding:18px; }
.info-box-title { font-family:var(--mono); font-size:16px; font-weight:700; color:var(--red); margin-bottom:12px; }
.info-table { width:100%; border-collapse:collapse; }
.info-table td { padding:7px 0; font-size:13px; border-bottom:1px solid var(--border); }
.info-table td:first-child { color:var(--muted); width:40%; }
.info-table tr:last-child td { border-bottom:none; }

/* ── Status tabs ─────────────────────────────────────────── */
.status-tabs { display:flex; gap:2px; margin-bottom:20px; border-bottom:1px solid var(--border); }
.status-tab { padding:10px 18px; font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); text-decoration:none; border-bottom:2px solid transparent; margin-bottom:-1px; transition:.2s; }
.status-tab:hover { color:var(--white); }
.tab-active { color:var(--white); border-bottom-color:var(--red); }
.tab-count { display:inline-block; background:var(--panel2); padding:1px 6px; border-radius:8px; font-size:10px; margin-left:4px; }

/* ── Settings tabs ─────────────────────────────────────── */
.settings-tabs { display:flex; gap:4px; margin-bottom:24px; }
.stab { padding:8px 16px; background:var(--panel); border:1px solid var(--border); border-radius:2px; font-family:var(--mono); font-size:11px; color:var(--muted); }
.stab:hover { color:var(--white); }
.stab-active { background:var(--red); border-color:var(--red); color:#fff; }

/* ── Autocomplete ─────────────────────────────────────── */
.autocomplete-results { position:absolute; z-index:100; background:var(--panel); border:1px solid var(--border2); border-radius:2px; min-width:300px; max-height:240px; overflow-y:auto; box-shadow:0 8px 24px rgba(0,0,0,.5); }
.ac-item { padding:10px 14px; cursor:pointer; border-bottom:1px solid var(--border); }
.ac-item:hover { background:var(--panel2); }
.ac-sub { font-size:11px; color:var(--muted); display:block; margin-top:2px; }

/* ── Pagination ─────────────────────────────────────────── */
.pagination { margin-top:20px; }
.pagination ul { display:flex; list-style:none; gap:4px; }
.pagination ul li a, .pagination ul li span { display:block; padding:6px 12px; background:var(--panel); border:1px solid var(--border); border-radius:2px; font-family:var(--mono); font-size:11px; color:var(--muted); }
.pagination ul li a:hover { border-color:var(--red); color:var(--white); }
.pagination ul li.active a { background:var(--red); border-color:var(--red); color:#fff; }
.pagination ul li.disabled span { opacity:.4; }

/* ── Login ─────────────────────────────────────────────── */
.login-body { background:var(--bg); display:flex; align-items:center; justify-content:center; min-height:100vh; }
.login-wrap { background:var(--surface); border:1px solid var(--border); border-radius:4px; padding:40px 36px; width:100%; max-width:400px; }
.login-brand { font-family:var(--mono); font-size:32px; font-weight:900; color:var(--white); text-align:center; letter-spacing:4px; }
.login-brand span { color:var(--red); }
.login-sub { font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); text-align:center; margin-bottom:28px; margin-top:4px; }
.login-form .form-group { margin-bottom:16px; }
.login-form .form-group label { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.login-form .form-group input { width:100%; background:var(--panel); border:1px solid var(--border2); border-radius:2px; padding:11px 14px; color:var(--white); font-size:14px; outline:none; }
.login-form .form-group input:focus { border-color:var(--red); }

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:1024px) {
  .stats-grid { grid-template-columns:repeat(3,1fr); }
  .dash-grid  { grid-template-columns:1fr 1fr; }
  .form-grid-3 { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .admin-body { overflow:auto; height:auto; }
  .admin-wrap { flex-direction:column; height:auto; }
  .sidebar { position:fixed; top:0; left:-var(--sidebar-w); width:var(--sidebar-w); z-index:200; transition:left .3s; }
  .sidebar.open { left:0; }
  .admin-main { height:auto; overflow:visible; }
  .admin-content { padding:16px; }
  .menu-toggle { display:block; }
  .topbar-actions { display:none; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .dash-grid  { grid-template-columns:1fr; }
  .form-grid-2, .form-grid-3 { grid-template-columns:1fr; }
  .crm-form { max-width:100%; }
  .revenue-banner { flex-direction:column; gap:16px; }
}
