/* ============================================================
   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); }
}

/* ============================================================
   Sovereign Login Gate — Swiss high-contrast (light), TrustIQ/TrustIQ
   ============================================================ */
.login-gate {
  position: fixed; inset: 0; z-index: 1000; overflow: auto;
  background: #FFFFFF; color: #0B0F19;
  display: grid; place-items: center; padding: 28px;
  font-family: var(--font-body);
}
.login-gate * { box-sizing: border-box; }

.lg-toggles { position: absolute; top: 22px; inset-inline-end: 28px; display: flex; gap: 8px; }
.lg-toggle { display: flex; border: 1px solid #CBD5E1; border-radius: 9px; overflow: hidden; }
.lg-toggle button { padding: 6px 11px; background: #fff; color: #475569; font-size: 12px; font-weight: 700; border: 0; cursor: pointer; }
.lg-toggle button[aria-pressed="true"] { background: #0B0F19; color: #fff; }

.lg-card {
  display: grid; grid-template-columns: 1fr 1fr; width: min(920px, 100%);
  border: 1.5px solid #0B0F19; border-radius: 6px; overflow: hidden; background: #fff;
}
.lg-left {
  padding: 44px 38px; border-inline-end: 1.5px solid #0B0F19; background: #F8FAFC;
  display: flex; flex-direction: column; gap: 16px;
  background-image: linear-gradient(135deg, rgba(11,15,25,0.03) 1px, transparent 1px);
  background-size: 22px 22px;
}
.lg-mark { width: 54px; height: 54px; border-radius: 13px; background: #0B0F19; color: #fff; display: grid; place-items: center; font-family: 'Plus Jakarta Sans', var(--font-head); font-weight: 800; font-size: 28px; }
.lg-brand { font-family: 'Plus Jakarta Sans', var(--font-head); font-weight: 800; font-size: 26px; letter-spacing: .2px; margin: 6px 0 0; color: #0B0F19; }
.lg-brand span { color: #64748B; font-weight: 600; }
.lg-sub { color: #475569; font-size: 14px; line-height: 1.55; margin: 0; max-width: 30ch; }
.lg-tags { margin-block-start: auto; display: flex; flex-direction: column; gap: 8px; }
.lg-tags span { font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase; color: #94A3B8; font-weight: 700; }
.lg-tags span:first-child { color: #0B0F19; }
.lg-tags .lg-tagline { text-transform: none; letter-spacing: .2px; font-size: 13px; font-style: italic; }

.lg-right { padding: 44px 38px; display: flex; flex-direction: column; gap: 14px; }
.lg-secure { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: #047857; background: #ECFDF5; border: 1px solid #A7F3D0; border-radius: 999px; padding: 4px 11px; width: fit-content; }
.lg-secure svg { width: 13px; height: 13px; }
.lg-access { font-family: var(--font-head); font-size: 25px; font-weight: 800; margin: 6px 0 0; }
.lg-hint { color: #64748B; font-size: 13.5px; line-height: 1.55; margin: 0 0 4px; }

.lg-field { display: flex; flex-direction: column; gap: 7px; }
.lg-field > span { font-size: 12px; font-weight: 700; color: #475569; }
.lg-field select {
  padding: 12px 13px; border: 1.5px solid #0B0F19; border-radius: 9px; background: #fff; color: #0B0F19;
  font-family: var(--font-body); font-size: 14px; font-weight: 600; appearance: none; -webkit-appearance: none; cursor: pointer;
  background-image: linear-gradient(45deg, transparent 50%, #0B0F19 50%), linear-gradient(135deg, #0B0F19 50%, transparent 50%);
  background-position: right 14px center, right 9px center; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat;
}
[dir="rtl"] .lg-field select { background-position: left 14px center, left 9px center; }
.lg-input {
  padding: 12px 13px; border: 1.5px solid #0B0F19; border-radius: 9px; background: #fff; color: #0B0F19;
  font-family: var(--font-body); font-size: 14px; font-weight: 600; width: 100%; box-sizing: border-box;
}
.lg-input::placeholder { color: #94A3B8; font-weight: 500; }
.lg-input:focus { outline: none; box-shadow: 0 0 0 3px rgba(16,185,129,.25); border-color: #10B981; }
.lg-err { display: flex; align-items: center; gap: 6px; margin: 2px 0 0; font-size: 12.5px; font-weight: 600; color: #DC2626; }
.lg-err svg { width: 15px; height: 15px; flex: none; }

.lg-cta {
  display: flex; align-items: center; gap: 13px; width: 100%; padding: 14px; margin-top: 4px;
  border: 0; border-radius: 11px; background: #0B0F19; color: #fff; cursor: pointer;
  transition: background var(--dur) var(--ease);
}
.lg-cta:hover { background: #1E293B; }
.lg-cta-logo { width: 36px; height: 36px; border-radius: 9px; display: grid; place-items: center; font-family: var(--font-head); font-weight: 800; font-size: 12px; flex: none; background: #10B981; color: #04130D; }
.lg-cta.nafath  .lg-cta-logo { background: #00843D; color: #fff; }
.lg-cta.uaepass .lg-cta-logo { background: #111; color: #fff; box-shadow: inset 0 0 0 1px #444; }
.lg-cta.kwt .lg-cta-logo { background: linear-gradient(135deg,#007a3d,#ce1126); color: #fff; }
.lg-cta.qat .lg-cta-logo { background: #8a1538; color: #fff; }
.lg-cta.bah .lg-cta-logo { background: #ce1126; color: #fff; }
.lg-cta.omn .lg-cta-logo { background: linear-gradient(135deg,#db161b,#0b6623); color: #fff; }
.lg-cta-txt { flex: 1; text-align: start; font-family: var(--font-head); font-weight: 700; font-size: 14.5px; }
.lg-cta-arrow { width: 18px; height: 18px; flex: none; }
[dir="rtl"] .lg-cta-arrow { transform: scaleX(-1); }
.lg-foot { font-size: 11.5px; color: #94A3B8; line-height: 1.5; margin: 8px 0 0; }

.lg-handshake { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 34px 0; text-align: center; }
.lg-handshake b { font-family: var(--font-head); font-size: 15px; color: #0B0F19; max-width: 28ch; }
.spinner.dark { border: 3px solid #E2E8F0; border-top-color: #0B0F19; }

.lg-applink { position: absolute; bottom: 22px; background: none; border: 1px solid #CBD5E1; border-radius: 999px; padding: 8px 15px; color: #475569; font-weight: 600; font-size: 13px; display: inline-flex; align-items: center; gap: 7px; cursor: pointer; }
.lg-applink svg { width: 14px; height: 14px; }
.lg-applink:hover { border-color: #0B0F19; color: #0B0F19; }

@media (max-width: 720px) {
  .lg-card { grid-template-columns: 1fr; }
  .lg-left { border-inline-end: 0; border-block-end: 1.5px solid #0B0F19; }
}

/* ---- Branded export toolbar ---- */
.export-bar { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.export-bar .export-lbl { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; color: var(--text-muted, #64748B); }
.export-bar .export-lbl svg { width: 14px; height: 14px; }
.btn-export { background: #fff; border: 1px solid var(--line, #E2E8F0); border-radius: 999px; padding: 6px 13px; font-size: 12px; font-weight: 600; color: #0B0F19; cursor: pointer; transition: all .15s ease; }
.btn-export:hover { border-color: var(--emerald, #0E8A5F); color: var(--emerald, #0E8A5F); box-shadow: 0 1px 6px rgba(14,138,95,.15); }
.btn-export:active { transform: translateY(1px); }
