/* DPX Brand UI – report.css */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&display=swap');
:root{
  --bg:#0b1220; --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.12);
  --text:#e7eef7; --muted:#a8b6c8; --muted2:#7f93ac;
  --accent:#16c172; --danger:#ef4444;
  --shadow:0 10px 30px rgba(0,0,0,.35); --radius:14px;
}
*{box-sizing:border-box} html,body{height:100%}
body{
  margin:0; font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  background: radial-gradient(1100px 600px at 10% 0%, rgba(22,193,114,.14), transparent 55%),
              radial-gradient(900px 500px at 100% 0%, rgba(17,169,96,.10), transparent 55%),
              var(--bg);
  color:var(--text);
}
.app{min-height:100%;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:0;
background:rgba(11,18,32,.78);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px}
.logo{
  width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.6px;background:linear-gradient(135deg, rgba(22,193,114,.95), rgba(17,169,96,.75));
  color:#04130c;box-shadow:0 10px 22px rgba(22,193,114,.18);
}
.brandTitle{font-size:16px;font-weight:800}
.brandSub{font-size:12px;color:var(--muted);margin-top:2px}
.topbarActions{display:flex;align-items:center;gap:10px}
.pill{font-size:12px;color:var(--muted);border:1px solid var(--line);background:rgba(255,255,255,.03);
  padding:8px 10px;border-radius:999px}
.btn{
  border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);
  padding:10px 12px;border-radius:12px;font-weight:700;text-decoration:none;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:transform .05s ease,border-color .2s ease;
}
.btn:hover{border-color:var(--line2)} .btn:active{transform:translateY(1px)}
.btn.primary{border-color:rgba(22,193,114,.35);background:linear-gradient(135deg, rgba(22,193,114,.95), rgba(17,169,96,.75));color:#04130c}
.btn.ghost{background:rgba(255,255,255,.03)} .btn.small{padding:8px 10px;border-radius:10px;font-size:13px}
.main{display:grid;grid-template-columns:360px 1fr;gap:16px;padding:16px;max-width:1400px;width:100%;margin:0 auto}
.panel,.tableCard{background:rgba(15,27,47,.75);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.panel{padding:14px}
.panelHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
/* v19: Filters heading + Preview button above the panel, sticky under topbar */
.stickyPanelHeader{
  position: sticky;
  top: calc(16px + 60px + 16px); /* matches .topbar padding + logo height */
  z-index: 19; /* below .topbar (z-index:20) */
  margin-bottom: 10px;
  padding: 8px 2px;
  background: rgba(11,18,32,.78);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
/* Grid placement: header sits above left panel; preview content spans rows */
.stickyPanelHeader{ grid-column: 1; grid-row: 1; }
.panel{ grid-column: 1; grid-row: 2; }
.content{ grid-column: 2; grid-row: 1 / span 2; }
.panelTitle{font-size:14px;font-weight:900}
.field{margin-top:12px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.field input,.field select{
  width:100%;padding:10px 10px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--text);outline:none
}
.field input:focus,.field select:focus{border-color:rgba(22,193,114,.35);box-shadow:0 0 0 4px rgba(22,193,114,.10)}
.hint{margin-top:8px;font-size:12px;color:var(--muted2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.divider{height:1px;background:var(--line);margin:14px 0}
.statusArea{margin-top:12px;min-height:18px;font-size:13px;color:var(--muted)}
.combo{display:flex;flex-direction:column;gap:8px}
.content{
  display:flex;flex-direction:column;gap:12px;
  position:sticky;top:92px;
  height:calc(100vh - 108px);
  overflow:hidden;
}
.contentTitle{font-size:14px;font-weight:900}
.contentSub{font-size:12px;color:var(--muted);margin-top:4px}
.tableCard{overflow:hidden}
.tableWrap{overflow:auto;max-height:calc(100vh - 260px);min-height:200px}
table{width:100%;border-collapse:collapse;font-size:12px}
thead th{
  position:sticky;top:0;z-index:5;background:rgba(11,18,32,.95);border-bottom:1px solid var(--line);
  padding:10px 10px;text-align:left;white-space:nowrap
}
tbody td{border-bottom:1px solid rgba(255,255,255,.06);padding:9px 10px;white-space:nowrap}
tbody tr:hover{background:rgba(255,255,255,.03)}
th.num,td.num{text-align:right}
.tableFooter{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:rgba(255,255,255,.02);border-top:1px solid rgba(255,255,255,.06)}
.smallMuted{font-size:12px;color:var(--muted)}
@media (max-width:980px){.main{grid-template-columns:1fr}.tableWrap{max-height:55vh}.stickyPanelHeader,.panel,.content{grid-column:1;grid-row:auto}}
select option{
  background: #0b1220;
  color: var(--text);
}

/* v2: ensure horizontal scroll stays within table (no page overflow) */
.tableCard{overflow:hidden}
.tableWrap{overflow-x:auto;overflow-y:auto;max-width:100%}
#previewTable{min-width:1200px}

/* v4: multi-project picker */
.btnRow{display:flex;gap:8px;margin-top:8px}
#projectSelect{width:100%;min-height:180px}

#projectCount{font-weight:600;margin-left:6px}

/* v6: logo + multi-project picker */
.brandLogo{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}
.btnRow{display:flex;gap:10px;align-items:center;margin-top:10px;flex-wrap:wrap}
.pill.small{padding:6px 10px;font-size:12px;border-radius:999px}
#projectSelect{width:100%;min-height:210px}

/* v7: project checkbox list (no cmd/ctrl needed) */
.projectList{
  width:100%;
  max-height:240px;
  overflow:auto;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:8px;
  background:rgba(0,0,0,.12);
}
.projectItem{
  display:flex;
  align-items:center;
  gap:10px;
  padding:7px 8px;
  border-radius:10px;
  cursor:pointer;
}
.projectItem:hover{background:rgba(255,255,255,.06)}
.projectItem input{transform:scale(1.05)}
.projectName{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* v11: white logo badge */
.brandLogo{
  background:#ffffff;
  padding:8px 10px;
  border-radius:12px;
  box-shadow:0 6px 18px rgba(0,0,0,.18), inset 0 0 0 1px rgba(0,0,0,.06);
}

/* v12: bigger logo in badge */
.brandLogo{
  width:64px;
  height:64px;
  padding:10px 12px;
  border-radius:14px;
}

/* v13: logo larger, no white background */
.brandLogo{
  width:56px;
  height:56px;
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

/* v13: project list highlight selection (no checkboxes) */
.projectItem{ user-select:none; }
.projectItem.selected{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.16); }
.projectItem .dot{
  width:10px;height:10px;border-radius:999px;
  background:rgba(255,255,255,.28);
  box-shadow: inset 0 0 0 2px rgba(0,0,0,.22);
}
.projectItem.selected .dot{ background:rgba(255,255,255,.88); }

#vendorSearch{ flex:1; min-width: 180px; }

/* v14: project list smaller font */
.projectName{ font-size: 13px; }

/* v14: logo slightly bigger without badge */
.brandLogo{ width:60px; height:60px; }

/* v14: company name line above preview */
.companyLine{
  font-size:14px;
  font-weight:900;
  opacity:1;
  margin-bottom:6px;
}

/* v15: smaller project font + tighter rows */
.projectName{ font-size: 12px; }
.projectItem{ padding: 6px 7px; }

/* v15: vendor search a bit wider */
#vendorSearch{ min-width: 220px; }


/* v18 layout fixes */
.row{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:nowrap;
}
.row input, .row select{
  flex:1 1 auto;
  min-width: 0;
}
.row .btn{
  flex:0 0 auto;
}
.keyRow input{
  flex:1 1 auto;
}


/* v24: contentHeader no longer needs sticky — parent .content is sticky */
.contentHeader{
  padding: 8px 2px 10px 2px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
  flex-shrink:0;
}


/* v22: constrain topbar content to match main width */
.topbarInner{
  max-width:1400px;
  width:100%;
  margin:0 auto;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}


/* v22b: if the page scrolls (not the tableWrap), keep table headers below sticky content header */
:root{ --stickyStackTop: calc(16px + 60px + 16px + 44px); } /* topbar+gap+approx header */

thead th{position:sticky !important;top:0 !important;z-index:5;background:rgba(11,18,32,.98) !important;}

/* v24: tableCard fills remaining height so tableWrap scrolls internally */
.tableCard{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.tableWrap{flex:1;overflow:auto;max-height:none !important;}
