/* ═══════════════════════════════════════════════════════
   EZRP — Shared Styles
   MRO Workflow Automation · ERP Platform
   Elevation-based dark theme with precision blue accent
   ═══════════════════════════════════════════════════════ */

:root {
  /* Elevation surfaces */
  --L0: #0d0f10;    /* deepest — header, status */
  --L1: #121416;    /* table background */
  --L2: #181a1d;    /* panel / controls */
  --L3: #1e2024;    /* inner card */
  --L4: #252830;    /* inputs, text areas */

  /* Typography */
  --T1: #dde1e8;    /* primary — high contrast off-white */
  --T2: #8a919f;    /* secondary labels */
  --T3: #4a5160;    /* tertiary hints */

  /* Accent — precision blue */
  --A:  #2f7fe8;
  --Ah: #4a92f0;
  --Ap: #235fb8;
  --A-dim: rgba(47,127,232,0.12);
  --A-border: rgba(47,127,232,0.3);

  /* Semantic */
  --ok:   #27a85f;  --okH:  #1e8a4c;
  --warn: #d99a14;  --warnH:#b87e0e;
  --err:  #c94040;  --errH: #a53030;

  /* Borders */
  --sep: #252830;
  --bdr: #1e2024;

  /* Mapped aliases for shared components */
  --bg: var(--L0);
  --bg2: var(--L0);
  --bg3: var(--L1);
  --card: var(--L2);
  --card-hover: rgba(255,255,255,0.02);
  --border: var(--sep);
  --text: var(--T1);
  --text-bright: #fff;
  --dim: var(--T2);
  --accent: var(--A);
  --accent-dim: var(--A-dim);
  --accent-border: var(--A-border);
  --accent-hover: var(--Ah);
  --warn: #d99a14;
  --danger: #c94040;
  --blue: #2f7fe8;
  --purple: #8b5cf6;
  --success: #27a85f;
  --mono: 'Consolas', 'Courier New', monospace;
  --font: 'Segoe UI', system-ui, -apple-system, sans-serif;
  --input-bg: var(--L4);
  --input-border: var(--sep);
  --input-focus: var(--A-border);
  --shadow: rgba(0,0,0,0.4);
  --modal-bg: rgba(0,0,0,0.7);
}

/* Light mode */
[data-theme="light"] {
  --L0: #f0f2f5; --L1: #f8f9fb; --L2: #ffffff; --L3: #f0f2f5; --L4: #e8eaef;
  --T1: #1a1d23; --T2: #5a6270; --T3: #8a919f;
  --A: #235fb8; --Ah: #2f7fe8; --Ap: #1a4a8f;
  --A-dim: rgba(35,95,184,0.08); --A-border: rgba(35,95,184,0.25);
  --sep: #d8dbe0; --bdr: #e0e3e8;
  --bg: var(--L0); --bg2: #fff; --bg3: var(--L1);
  --card: var(--L2); --card-hover: rgba(0,0,0,0.02);
  --border: var(--sep); --text: var(--T1); --text-bright: #0d0f10;
  --dim: var(--T2); --accent: var(--A); --accent-dim: var(--A-dim);
  --accent-border: var(--A-border); --accent-hover: var(--Ah);
  --input-bg: var(--L4); --input-border: var(--sep); --input-focus: var(--A-border);
  --shadow: rgba(0,0,0,0.1); --modal-bg: rgba(0,0,0,0.35);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;transition:background 0.3s,color 0.3s}

/* ── Header ────────────────────────────────────────── */
.erp-header{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:var(--L0);border-bottom:1px solid var(--sep)}
.erp-header-left{display:flex;align-items:center;gap:12px}
.erp-logo{width:34px;height:34px;border-radius:7px;background:var(--A);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;color:#fff;font-family:var(--mono);flex-shrink:0;letter-spacing:0.5px}
.erp-header h1{font-size:15px;font-weight:700;color:var(--T1);letter-spacing:-0.01em}
.erp-header .erp-subtitle{font-size:8px;color:var(--T3);text-transform:uppercase;letter-spacing:0.12em}
.erp-header-right{display:flex;align-items:center;gap:8px}

/* Theme toggle */
.theme-toggle{width:34px;height:18px;border-radius:9px;border:none;background:var(--sep);cursor:pointer;position:relative;transition:background 0.3s;padding:0}
.theme-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--T2);transition:transform 0.3s}
[data-theme="light"] .theme-toggle{background:var(--A)}
[data-theme="light"] .theme-toggle::after{transform:translateX(16px);background:#fff}
.theme-label{font-size:10px;color:var(--T3)}

/* View size toggle group */
.view-size-group{display:flex;align-items:center;gap:0;margin-left:6px;border:1px solid var(--sep);border-radius:5px;overflow:hidden}
.view-size-btn{display:flex;align-items:center;justify-content:center;width:28px;height:24px;border:none;background:transparent;color:var(--T3);cursor:pointer;transition:all .15s;font-family:var(--font);padding:0;border-right:1px solid var(--sep)}
.view-size-btn:last-child{border-right:none}
.view-size-btn:hover{background:var(--L3);color:var(--T1)}
.view-size-btn.active{background:var(--A);color:#fff}
[data-theme="light"] .view-size-btn.active{background:var(--A);color:#fff}

/* ── Nav ───────────────────────────────────────────── */
.erp-nav{display:flex;gap:2px;padding:6px 24px;border-bottom:1px solid var(--sep);background:var(--L1);flex-wrap:wrap}
.erp-nav a{padding:6px 12px;border-radius:5px;text-decoration:none;font-size:11px;font-weight:600;color:var(--T2);transition:all 0.15s;border:1px solid transparent;white-space:nowrap}
.erp-nav a:hover{color:var(--T1);background:var(--L3)}
.erp-nav a.active{color:var(--A);background:var(--A-dim);border-color:var(--A-border)}

/* ── Content ───────────────────────────────────────── */
.erp-content{max-width:1500px;margin:0 auto;padding:18px 24px}
.erp-content.narrow{max-width:900px}
.erp-content.mid{max-width:1200px}

/* ── Cards ─────────────────────────────────────────── */
.card{background:var(--L2);border:1px solid var(--sep);border-radius:8px;padding:18px;transition:background 0.3s}
.card h3{font-size:13px;font-weight:700;color:var(--T1);margin-bottom:12px}

/* ── Tables ────────────────────────────────────────── */
.tbl-wrap{background:var(--L1);border:1px solid var(--sep);border-radius:8px;overflow:hidden}
table{width:100%;border-collapse:collapse}
th{font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--A);text-align:left;padding:8px 10px;border-bottom:1px solid var(--sep);background:var(--L0);font-weight:700}
td{font-size:11px;padding:7px 10px;color:var(--T1);border-bottom:1px solid var(--bdr);transition:background 0.1s}
td.mono{font-family:var(--mono);font-size:10px}
tr:hover td{background:rgba(47,127,232,0.04)}

/* ── Forms ─────────────────────────────────────────── */
.toolbar{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap}
input[type="text"],input[type="number"],input[type="email"],input[type="date"],input[type="password"],select,textarea{
  padding:7px 11px;border-radius:5px;border:1px solid var(--sep);background:var(--L4);color:var(--T1);
  font-size:12px;font-family:var(--font);outline:none;transition:border-color 0.2s}
input:focus,select:focus,textarea:focus{border-color:var(--A)}
textarea{resize:vertical;min-height:60px}
.fg{margin-bottom:10px}
.fg label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:0.08em;color:var(--T2);margin-bottom:3px;font-weight:600}
.fg input,.fg select,.fg textarea{width:100%}
.fg.full{grid-column:1/-1}

/* ── Buttons ───────────────────────────────────────── */
.btn{padding:7px 14px;border-radius:5px;border:none;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.btn-accent{background:var(--A);color:#fff}.btn-accent:hover{background:var(--Ah)}
.btn-outline{background:none;border:1px solid var(--sep);color:var(--T2)}.btn-outline:hover{color:var(--T1);border-color:var(--T2)}
.btn-warn{background:var(--warn);color:#000}
.btn-blue{background:var(--blue);color:#fff}
.btn-purple{background:var(--purple);color:#fff}
.btn-sm{padding:4px 9px;font-size:10px}
.btn:disabled{opacity:0.3;cursor:not-allowed}

/* ── Badges ────────────────────────────────────────── */
.badge{display:inline-block;font-size:8px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:0.06em}
.b-receiving{background:rgba(47,127,232,0.12);color:#4a92f0}
.b-inspection{background:rgba(139,92,246,0.12);color:#a78bfa}
.b-disassembly,.b-final_inspection{background:rgba(217,154,20,0.12);color:#d99a14}
.b-evaluation,.b-customer_approval{background:rgba(244,114,182,0.12);color:#f472b6}
.b-repair{background:rgba(217,154,20,0.12);color:#d99a14}
.b-certification{background:rgba(39,168,95,0.12);color:#27a85f}
.b-shipping,.b-shipped{background:rgba(47,127,232,0.12);color:#4a92f0}
.b-closed{background:rgba(255,255,255,0.04);color:var(--T3)}
.b-new{background:rgba(47,127,232,0.12);color:#4a92f0}
.b-quoted,.b-evaluating{background:rgba(139,92,246,0.12);color:#a78bfa}
.b-draft{background:rgba(255,255,255,0.04);color:var(--T3)}
.b-submitted,.b-sent{background:rgba(217,154,20,0.12);color:#d99a14}
.b-approved,.b-received,.b-paid{background:rgba(39,168,95,0.12);color:#27a85f}
.b-issued{background:rgba(217,154,20,0.12);color:#d99a14}
.b-low,.b-out{background:rgba(201,64,64,0.12);color:#c94040}
.b-ok{background:rgba(39,168,95,0.12);color:#27a85f}
.b-trace{background:rgba(139,92,246,0.12);color:#a78bfa}

/* ── Stat Cards ────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:var(--L2);border:1px solid var(--sep);border-radius:8px;padding:14px 16px}
.stat-card .label{font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--T3);margin-bottom:5px;font-weight:600}
.stat-card .value{font-size:24px;font-weight:800;font-family:var(--mono)}
.stat-card .sub{font-size:10px;color:var(--T3);margin-top:2px}

/* ── Modals ────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:var(--modal-bg);display:none;align-items:center;justify-content:center;z-index:100}
.modal-overlay.show{display:flex}
.modal{background:var(--L2);border:1px solid var(--sep);border-radius:10px;padding:22px;max-height:85vh;overflow-y:auto}
.modal h3{font-size:15px;font-weight:700;color:var(--T1);margin-bottom:14px}
.modal label{display:block;font-size:10px;color:var(--T2);margin-bottom:3px;margin-top:10px;text-transform:uppercase;letter-spacing:0.06em;font-weight:600}
.modal input,.modal select,.modal textarea{width:100%}
.modal-actions{display:flex;gap:8px;margin-top:18px;justify-content:flex-end}

/* ── Tabs ──────────────────────────────────────────── */
.tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:1px solid var(--sep)}
.tabs button{background:none;border:none;border-bottom:2px solid transparent;color:var(--T3);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;padding:8px 16px;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.tabs button.active{color:var(--A);border-bottom-color:var(--A)}
.tabs button:hover{color:var(--T1)}

/* ── Utility ───────────────────────────────────────── */
.color-accent{color:var(--A)}.color-warn{color:var(--warn)}.color-danger{color:var(--err)}.color-blue{color:var(--A)}.color-purple{color:var(--purple)}.color-success{color:var(--ok)}
.empty-state{padding:28px;text-align:center;color:var(--T3);font-size:11px}
.section-title{font-size:10px;font-weight:700;color:var(--A);text-transform:uppercase;letter-spacing:0.1em;margin:18px 0 10px;padding-top:14px;border-top:1px solid var(--sep);grid-column:1/-1}
.result{padding:10px;border-radius:6px;margin-top:10px;font-size:11px;display:none;line-height:1.5}
.result.ok{background:rgba(39,168,95,0.1);border:1px solid rgba(39,168,95,0.3);color:#27a85f;display:block}
.result.err{background:rgba(201,64,64,0.1);border:1px solid rgba(201,64,64,0.3);color:#c94040;display:block}

/* ── Global Search ─────────────────────────────────── */
.global-search-wrap{position:relative;flex:1;max-width:440px;min-width:180px}
.global-search-input{width:100%;padding:6px 12px;border-radius:5px;border:1px solid var(--sep);background:var(--L4);color:var(--T1);font-size:11px;font-family:var(--font);outline:none;transition:border-color 0.2s,box-shadow 0.2s}
.global-search-input:focus{border-color:var(--A);box-shadow:0 0 0 2px var(--A-dim)}
.global-search-input::placeholder{color:var(--T3);font-size:10px}
.global-search-results{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--L2);border:1px solid var(--sep);border-radius:8px;box-shadow:0 12px 40px var(--shadow);max-height:400px;overflow-y:auto;z-index:999}
.gsr-item{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--bdr);transition:background 0.1s}
.gsr-item:last-child{border-bottom:none}
.gsr-item:hover{background:rgba(47,127,232,0.06)}
.gsr-icon{font-size:14px;margin-top:1px;flex-shrink:0;width:20px;text-align:center}
.gsr-content{flex:1;min-width:0}
.gsr-title{font-size:11px;font-weight:700;color:var(--T1)}
.gsr-sub{font-size:10px;color:var(--T2);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gsr-detail{font-size:9px;color:var(--T3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gsr-type{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;white-space:nowrap;margin-top:1px}
.gsr-empty{padding:16px;text-align:center;color:var(--T3);font-size:11px}

/* ── Vendor Cards ──────────────────────────────────── */
.vendor-card{background:var(--L2);border:1px solid var(--sep);border-radius:8px;padding:14px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.vendor-card:hover{border-color:var(--T3)}
.vendor-name{font-weight:700;font-size:13px;color:var(--T1)}
.vendor-meta{font-size:10px;color:var(--T2);margin-top:3px}
.stars{color:var(--warn);font-size:11px;letter-spacing:2px}

/* ── Responsive ────────────────────────────────────── */
@media(max-width:1000px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.stats-grid{grid-template-columns:1fr}.erp-nav{gap:1px;padding:6px 12px}}

/* ── Full width — no dead space ────────────────────── */
.erp-content { max-width: 100%; padding: 18px 24px; }
.erp-content.narrow { max-width: 900px; margin: 0 auto; }
.erp-content.mid { max-width: 1200px; margin: 0 auto; }

/* ── Sortable Column Headers ───────────────────────── */
th.sortable { cursor: pointer; user-select: none; position: relative; padding-right: 18px; }
th.sortable:hover { color: var(--Ah); }
th.sortable::after { content: '⇅'; position: absolute; right: 4px; top: 50%; transform: translateY(-50%); font-size: 8px; color: var(--T3); }
th.sortable.asc::after { content: '▲'; color: var(--A); }
th.sortable.desc::after { content: '▼'; color: var(--A); }

/* ── Date range filter popup ───────────────────────── */
.date-filter-popup { position: absolute; top: 100%; left: 0; background: var(--L2); border: 1px solid var(--sep); border-radius: 8px; padding: 12px; box-shadow: 0 8px 24px var(--shadow); z-index: 50; display: none; }
.date-filter-popup.show { display: block; }
.date-filter-popup label { font-size: 10px; color: var(--T2); display: block; margin-bottom: 3px; }
.date-filter-popup input { width: 140px; margin-bottom: 8px; }

/* ── Table full width ──────────────────────────────── */
table { width: 100%; table-layout: auto; }

/* ── Logo image style ──────────────────────────────── */
.erp-logo-img, .erp-header img { width: 32px; height: 32px; border-radius: 6px; }

/* ── Full Width / No Dead Space ────────────────────── */
.erp-content { max-width: 100%; padding: 18px 24px; }
.erp-content.narrow { max-width: 900px; margin: 0 auto; }
.erp-content.mid { max-width: 1200px; margin: 0 auto; }

/* ── Logo Image in Header ──────────────────────────── */
.erp-header-left img { height: 32px; flex-shrink: 0; }

/* ── Sortable Column Headers ───────────────────────── */
th.sortable { cursor: pointer; user-select: none; position: relative; }
th.sortable:hover { color: var(--Ah); background: var(--L1); }
th.sortable::after { content: '⇅'; margin-left: 4px; font-size: 8px; opacity: 0.3; }
th.sortable.asc::after { content: '▲'; opacity: 0.8; color: var(--A); }
th.sortable.desc::after { content: '▼'; opacity: 0.8; color: var(--A); }

/* ── Column Filter Dropdowns ───────────────────────── */
.col-filter { position: relative; display: inline-block; }
.col-filter-btn { background: none; border: none; color: var(--T3); cursor: pointer; font-size: 8px; margin-left: 2px; padding: 1px 3px; border-radius: 2px; }
.col-filter-btn:hover, .col-filter-btn.active { color: var(--A); background: var(--A-dim); }
.col-filter-popup { display: none; position: absolute; top: 100%; left: 0; background: var(--L2); border: 1px solid var(--sep); border-radius: 6px; padding: 8px; min-width: 160px; z-index: 50; box-shadow: 0 8px 24px var(--shadow); }
.col-filter-popup.show { display: block; }
.col-filter-popup label { display: flex; align-items: center; gap: 6px; font-size: 10px; color: var(--T1); padding: 3px 0; cursor: pointer; font-weight: 400; text-transform: none; letter-spacing: 0; }
.col-filter-popup input[type="checkbox"] { cursor: pointer; }
.col-filter-popup input[type="date"] { width: 100%; margin-top: 4px; font-size: 10px; padding: 4px 6px; }

/* ── Date Range Filter ─────────────────────────────── */
.date-filter-row { display: flex; gap: 6px; align-items: center; margin-top: 4px; }
.date-filter-row input { flex: 1; font-size: 10px; padding: 4px 6px; }
.date-filter-row span { font-size: 9px; color: var(--T3); }

/* ── Size Bump (matching EZRP desktop proportions) ── */
td { font-size: 12px; padding: 9px 12px; }
th { font-size: 10px; padding: 10px 12px; }
.erp-nav a { font-size: 12px; padding: 7px 14px; }
.erp-header h1 { font-size: 17px; }
