/* ============================================================
   Portal 1 — Enterprise Procurement Web Console
   ============================================================ */

.console { display: grid; grid-template-columns: var(--rail-w) 1fr; min-height: calc(100vh - 56px); }

/* ---- Side rail ---- */
.rail {
  border-inline-end: 1px solid var(--border); padding: var(--s5) var(--s3);
  display: flex; flex-direction: column; gap: var(--s2);
  background: var(--bg-elevated); position: sticky; top: 56px; height: calc(100vh - 56px);
}
.rail .org {
  display: flex; align-items: center; gap: var(--s3); padding: var(--s3); margin-block-end: var(--s3);
  border: 1px solid var(--border); border-radius: var(--r-md); background: var(--bg-card);
  cursor: pointer; transition: border-color var(--dur) var(--ease); text-align: start; width: 100%;
}
.rail .org:hover { border-color: var(--border-strong); }
.rail .org.authed { border-color: rgba(16,185,129,0.35); }
.rail .org span.t-em { display: inline-flex; align-items: center; gap: 3px; font-size: var(--fs-micro); }
.rail .org span.t-em svg { width: 11px; height: 11px; }
.rail .org .logo { width: 32px; height: 32px; border-radius: 8px; background: linear-gradient(135deg,#1e3a5f,#0f1e30); display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; color: #cfe3ff; }
.rail .org b { font-family: var(--font-head); font-size: var(--fs-sm); display: block; }
.rail .org span { font-size: var(--fs-micro); color: var(--text-muted); letter-spacing: 0.06em; }

.rail-group { font-size: var(--fs-micro); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); font-family: var(--font-head); font-weight: 700; padding: var(--s3) var(--s3) var(--s1); }
.nav-item {
  display: flex; align-items: center; gap: var(--s3); padding: 9px var(--s3); border-radius: var(--r-md);
  color: var(--text-body); font-size: var(--fs-body); font-weight: 500; transition: all var(--dur) var(--ease);
  cursor: pointer; user-select: none;
}
.nav-item .ico { width: 17px; height: 17px; flex: none; }
.nav-item .count { margin-inline-start: auto; font-family: var(--font-num); font-size: var(--fs-xs); color: var(--text-muted); background: var(--bg-inset); padding: 1px 7px; border-radius: 99px; }
.nav-item:hover { background: var(--bg-card); color: var(--text-primary); }
.nav-item.active { background: var(--bg-card); color: var(--text-primary); box-shadow: inset 0 0 0 1px var(--border-strong); }
.nav-item.active .ico { color: var(--emerald); }

.rail-foot { margin-top: auto; padding: var(--s3); border: 1px solid var(--border); border-radius: var(--r-md); background: var(--bg-card); }
.rail-foot .trust-ring { display: flex; align-items: center; gap: var(--s3); }

/* ---- Main column ---- */
.main { padding: var(--s6) var(--s8); max-width: 1600px; }
.main-head { display: flex; align-items: flex-start; justify-content: space-between; margin-block-end: var(--s6); flex-wrap: wrap; gap: var(--s4); }
.main-head h1 { font-size: var(--fs-display); letter-spacing: -0.02em; }
.main-head .sub { color: var(--text-body); margin-block-start: 4px; display: flex; align-items: center; gap: var(--s2); font-size: var(--fs-sm); }

.kpi-row { margin-block-end: var(--s6); }

.split { display: grid; grid-template-columns: 1fr 360px; gap: var(--s6); align-items: start; }

/* Toolbar above table */
.tbl-toolbar { display: flex; align-items: center; gap: var(--s3); padding: var(--s4) var(--s5); border-block-end: 1px solid var(--border); flex-wrap: wrap; }
.search {
  display: flex; align-items: center; gap: var(--s2); background: var(--bg-inset); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 8px 12px; min-width: 240px; flex: 1; max-width: 360px;
}
.search input { background: none; border: none; outline: none; color: var(--text-primary); font-family: var(--font-body); font-size: var(--fs-body); flex: 1; }
.search input::placeholder { color: var(--text-muted); }
.search .ico { width: 15px; height: 15px; color: var(--text-muted); }
.chip {
  padding: 6px 11px; border-radius: var(--r-pill); font-size: var(--fs-xs); font-weight: 600; font-family: var(--font-head);
  border: 1px solid var(--border); color: var(--text-body); background: var(--bg-inset); transition: all var(--dur) var(--ease);
}
.chip.active { color: var(--emerald); border-color: rgba(16,185,129,0.4); background: var(--emerald-soft); }
.chip:hover { border-color: var(--border-strong); }

.tbl-scroll { max-height: 560px; overflow: auto; }

/* ---- Vendor profile drawer (right side) ---- */
.profile { position: sticky; top: 80px; }
.profile .ph { display: flex; align-items: center; gap: var(--s4); padding: var(--s5); border-block-end: 1px solid var(--border); }
.profile .ph .co-logo { width: 52px; height: 52px; border-radius: 12px; font-size: 19px; }
.profile-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.profile-stat-grid .ps { padding: var(--s4) var(--s5); border-block-end: 1px solid var(--border-faint); border-inline-end: 1px solid var(--border-faint); }
.profile-stat-grid .ps:nth-child(2n) { border-inline-end: none; }

.event-row { display: flex; align-items: center; gap: var(--s3); padding: 10px var(--s5); border-block-end: 1px solid var(--border-faint); }
.event-row .ev-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.event-row .ev-meta { flex: 1; }
.event-row .ev-meta b { font-size: var(--fs-sm); font-family: var(--font-head); font-weight: 500; }
.event-row .ev-meta span { font-size: var(--fs-micro); color: var(--text-muted); font-family: var(--font-num); display: block; }
.event-row .ev-val { font-family: var(--font-num); font-size: var(--fs-sm); font-weight: 700; }

/* Map-ish ops panel */
.ops-map {
  height: 200px; border-radius: var(--r-md); border: 1px solid var(--border); position: relative; overflow: hidden;
  background:
    linear-gradient(0deg, transparent 24%, rgba(30,41,59,0.5) 25%, rgba(30,41,59,0.5) 26%, transparent 27%, transparent 74%, rgba(30,41,59,0.5) 75%, rgba(30,41,59,0.5) 76%, transparent 77%),
    linear-gradient(90deg, transparent 24%, rgba(30,41,59,0.5) 25%, rgba(30,41,59,0.5) 26%, transparent 27%, transparent 74%, rgba(30,41,59,0.5) 75%, rgba(30,41,59,0.5) 76%, transparent 77%),
    var(--bg-inset);
  background-size: 38px 38px;
}
.ops-pin { position: absolute; width: 10px; height: 10px; }
.ops-pin i { position: absolute; inset: 0; border-radius: 50%; }
.ops-pin .core { background: var(--emerald); box-shadow: 0 0 0 3px var(--emerald-soft); }
.ops-pin .ping { animation: pulse-dot 2s var(--ease) infinite; }
.ops-pin.am .core { background: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }
.ops-pin.red .core { background: var(--red); box-shadow: 0 0 0 3px var(--red-soft); }

@media (max-width: 1200px) { .split { grid-template-columns: 1fr; } .profile { position: static; } }
@media (max-width: 1000px) {
  .console { grid-template-columns: 1fr; }
  .rail { display: none; }
  .main { padding: var(--s5); }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .main-head h1 { font-size: var(--fs-h1); }
}
