/* ============================================================
   sobi-workspace-identity.css
   Workspace Personality & Operational Identity Pass
   Parts 2–11: Depth, personality, search, highlights,
   sidebar/inspector atmosphere, micro-interactions, themes.
   Loads last — highest visual priority.
   ============================================================ */

/* ── PART 2: Elevation & Depth Tokens ─────────────────────── */
:root {
  /* Elevation stack */
  --elev-0: none;
  --elev-1: 0 1px 3px rgba(0,0,0,.16), 0 0 0 1px rgba(255,255,255,.03);
  --elev-2: 0 4px 14px rgba(0,0,0,.22), 0 0 0 1px rgba(255,255,255,.04);
  --elev-3: 0 12px 36px rgba(0,0,0,.30), 0 0 0 1px rgba(255,255,255,.05);

  /* Glow tokens */
  --glow-accent:  0 0 0 3px rgba(108,99,255,.14);
  --glow-ok:      0 0 0 3px rgba(52,211,153,.14);
  --glow-warn:    0 0 0 3px rgba(251,191,36,.14);
  --glow-danger:  0 0 0 3px rgba(248,113,113,.14);

  /* Sidebar atoms */
  --sb-active-bg:  rgba(108,99,255,.10);
  --sb-hover-bg:   rgba(255,255,255,.04);
  --sb-active-glow: inset 3px 0 0 var(--accent2);

  /* Surface tokens */
  --surface-sunken:  var(--bg);
  --surface-base:    var(--bg2);
  --surface-raised:  var(--bg3);
}

/* Light-mode elevation adjustments */
.light {
  --elev-1: 0 1px 3px rgba(0,0,0,.09), 0 0 0 1px rgba(0,0,0,.04);
  --elev-2: 0 4px 14px rgba(0,0,0,.10), 0 0 0 1px rgba(0,0,0,.05);
  --elev-3: 0 12px 36px rgba(0,0,0,.12), 0 0 0 1px rgba(0,0,0,.05);
  --sb-active-bg:  rgba(91,82,232,.08);
  --sb-hover-bg:   rgba(0,0,0,.04);
  --sb-active-glow: inset 3px 0 0 var(--accent);
}

/* ── PART 1/9: Dashboard Hero ──────────────────────────────── */
.dash-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg,
    rgba(108,99,255,.06) 0%,
    rgba(56,189,248,.03) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.dash-hero::before {
  content: '';
  position: absolute;
  top: 0; inset-inline-start: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--accent2) 0%, var(--accent3) 100%);
  border-radius: 0 2px 2px 0;
}
.dash-hero-left { min-width: 0; }
.dash-greeting {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.3px;
  margin-bottom: 4px;
}
.dash-date {
  font-size: 11px;
  color: var(--text3);
  font-weight: 500;
}
.dash-total {
  font-size: 10px;
  color: var(--text3);
  margin-top: 3px;
  opacity: .75;
}
.dash-hero-right {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
  flex-shrink: 0;
}
.dash-status-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--border);
  background: var(--bg3);
  white-space: nowrap;
  letter-spacing: .1px;
}
.dash-status-ok {
  color: var(--success);
  border-color: rgba(52,211,153,.22);
  background: rgba(52,211,153,.07);
}
.dash-status-warn {
  color: var(--warn);
  border-color: rgba(251,191,36,.22);
  background: rgba(251,191,36,.07);
}
.dash-status-danger {
  color: var(--danger);
  border-color: rgba(248,113,113,.22);
  background: rgba(248,113,113,.07);
}
@media (max-width: 700px) {
  .dash-hero {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
  }
  .dash-hero-right { justify-content: flex-start; }
}

/* ── PART 3: Status Pulse Animation ────────────────────────── */
@keyframes statusPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .5; transform: scale(.85); }
}
@keyframes statusRing {
  0%   { box-shadow: 0 0 0 0 currentColor; opacity: .5; }
  100% { box-shadow: 0 0 0 5px currentColor; opacity: 0; }
}

.status-pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--success);
  flex-shrink: 0;
  display: inline-block;
}
.status-pulse.warn {
  background: var(--warn);
  animation: statusPulse 2s ease-in-out infinite;
}
.status-pulse.danger {
  background: var(--danger);
  animation: statusPulse 1.4s ease-in-out infinite;
}

/* ── PART 2 cont: Surface Depth ────────────────────────────── */

/* Cards get a subtle elevation */
.ops-card { box-shadow: var(--elev-1); }
.ops-card[onclick]:hover { box-shadow: var(--elev-2); }

/* Selected list item — inset accent + elevation */
.ws-row.active {
  box-shadow: var(--sb-active-glow), var(--elev-1) !important;
}

/* Table row selected */
.ws-table tr.active td {
  background: rgba(108,99,255,.07) !important;
  box-shadow: inset 3px 0 0 var(--accent2);
}

/* Inspector toolbar shadow */
.inspector-toolbar {
  box-shadow: 0 1px 0 var(--border), 0 2px 6px rgba(0,0,0,.06);
}

/* Inspector header — elevated card */
.inspector-header {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 16px 18px !important;
  box-shadow: var(--elev-1);
  margin-bottom: 20px !important;
}
.inspector-header h1 {
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -.4px;
}

/* Command palette elevation */
.cmd-box {
  box-shadow: var(--elev-3), inset 0 1px 0 rgba(255,255,255,.04);
}

/* Quick peek elevation */
.qp-modal {
  box-shadow: var(--elev-3);
}

/* Modal elevation */
.modal {
  box-shadow: var(--elev-3);
}

/* ── PART 3: Product Personality ───────────────────────────── */

/* Sidebar active item — gradient tint + edge glow */
.nav-item.active {
  background: linear-gradient(90deg, var(--sb-active-bg) 0%, transparent 90%) !important;
  box-shadow: var(--sb-active-glow);
  color: var(--accent2) !important;
}
.nav-item.active::before {
  background: linear-gradient(180deg, var(--accent2) 0%, var(--accent) 100%) !important;
}

/* Topbar brand line — subtle underline accent */
#topbar::after {
  content: '';
  position: absolute;
  bottom: 0; inset-inline-start: 0;
  width: 100%; height: 1px;
  background: linear-gradient(90deg,
    rgba(108,99,255,.3) 0%,
    transparent 40%,
    transparent 60%,
    rgba(56,189,248,.2) 100%);
  pointer-events: none;
}

/* Warning ops-card — glow border */
.ops-card.danger {
  box-shadow: var(--elev-1), var(--glow-danger) !important;
  border-color: rgba(248,113,113,.3) !important;
}
.ops-card.warn {
  box-shadow: var(--elev-1), var(--glow-warn) !important;
  border-color: rgba(251,191,36,.25) !important;
}

/* ── PART 4: Search Importance ─────────────────────────────── */

/* Primary search feel — slightly elevated when idle */
.topbar-search-bar {
  box-shadow: var(--elev-1);
  background: var(--bg3) !important;
}
.topbar-search-bar:hover {
  box-shadow: var(--elev-1), 0 0 0 2px rgba(108,99,255,.1) !important;
}

/* Glow when command palette is open (CSS :has — modern browsers) */
body:has(#sobi-cmd) .topbar-search-bar {
  border-color: var(--accent) !important;
  box-shadow: var(--elev-1), var(--glow-accent) !important;
  background: var(--bg4) !important;
}

/* Fade-transition on placeholder text swap */
#topbar-search-ph {
  transition: opacity 300ms ease;
}

/* ── PART 5: Operational Highlight System ──────────────────── */

/* Warning badge on sidebar nav */
.badge.badge-warn   { background: rgba(251,191,36,.15);  color: var(--warn);   font-weight: 700; }
.badge.badge-danger { background: rgba(248,113,113,.15); color: var(--danger); font-weight: 700; }

/* Expiry row — subtle danger border */
.ops-row.ops-row-expired {
  border: 1px solid rgba(248,113,113,.2);
  border-radius: 8px;
  background: rgba(248,113,113,.04);
}
.ops-row.ops-row-warn {
  border: 1px solid rgba(251,191,36,.15);
  border-radius: 8px;
}

/* Expiry warning banner — refined */
.inspector-body > div[style*="rgba(251,191,36"] {
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--glow-warn);
}

/* Status tags with slight glow for urgency */
.tg-r { box-shadow: inset 0 0 0 1px rgba(248,113,113,.3); }
.tg-y { box-shadow: inset 0 0 0 1px rgba(251,191,36,.25); }

/* ── PART 6: Sidebar Atmosphere ────────────────────────────── */

/* Sidebar — subtle inner gradient for depth */
#sidebar {
  background: var(--bg2);
  border-inline-end: 1px solid var(--border);
}

/* Hover atmosphere — soft fill */
.nav-item:hover {
  background: var(--sb-hover-bg) !important;
}

/* Icon on active — brighter */
.nav-item.active i { opacity: 1 !important; color: var(--accent2); }

/* Section label — better readability */
.sb-lbl {
  font-size: 9px !important;
  opacity: .6;
  letter-spacing: 1.2px !important;
}

/* Section separator — softer */
.sb-sec + .sb-sec {
  border-top: 1px solid rgba(255,255,255,.04) !important;
}
.light .sb-sec + .sb-sec {
  border-top: 1px solid rgba(0,0,0,.07) !important;
}

/* Badge counts — tighter */
.nav-item .badge {
  font-size: 9px !important;
  min-width: 16px;
  text-align: center;
}

/* ── PART 7: Inspector Atmosphere ──────────────────────────── */

/* Inspector background — slightly sunken from sidebar */
.inspector {
  background: var(--bg) !important;
}
.inspector-body {
  background: var(--bg);
}

/* Seg-tab active — subtle accent glow */
.seg-tab.active {
  color: var(--accent2) !important;
  box-shadow: var(--elev-1), inset 0 -2px 0 var(--accent2) !important;
}

/* Info-box — monospace values */
.info-box-v {
  font-size: 12.5px !important;
  line-height: 1.5;
}

/* KV rows — better visual separation */
.kv {
  border-bottom: 1px dashed rgba(255,255,255,.06) !important;
}
.light .kv {
  border-bottom: 1px dashed rgba(0,0,0,.07) !important;
}

/* Smart summary pills — accent color emphasis */
.smart-pill i {
  color: var(--accent2);
}

/* Relation tree group header */
.rel-tree-group > summary {
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3) !important;
}
.rel-tree-group > summary:hover {
  color: var(--text) !important;
}

/* Relation card hover — accent glow */
.rel-card:hover {
  box-shadow: var(--elev-1);
}

/* Activity list — better typography */
.activity-row {
  color: var(--text3);
  font-size: 10.5px !important;
}
.activity-row:nth-child(odd) {
  background: rgba(255,255,255,.015);
}
.light .activity-row:nth-child(odd) {
  background: rgba(0,0,0,.02);
}

/* Empty state icon — accent tinted */
.ws-empty-pro .emp-icon i {
  opacity: .7;
}

/* ── PART 8: Micro-interactions & Flow ─────────────────────── */

/* Button press feedback */
.btn-primary:active {
  transform: scale(.97) !important;
  filter: brightness(.95);
}
.btn-icon:active {
  transform: scale(.93) !important;
}
.ic-btn:active { transform: scale(.88) !important; }

/* Icon button hover — subtle glow */
.ic-btn:hover {
  box-shadow: 0 0 0 2px rgba(108,99,255,.12);
}

/* Card hover — micro lift */
.ws-row:hover {
  box-shadow: var(--elev-1) !important;
}

/* Ops-row hover */
.ops-row:hover {
  box-shadow: var(--elev-0);
  transform: translateX(1px);
}
.rtl-app .ops-row:hover { transform: translateX(-1px); }

/* Ops section hover — micro elevation */
.ops-section {
  transition: box-shadow 140ms ease;
}

/* Seg-tabs focus ring */
.seg-tab:focus-visible {
  outline: 2px solid var(--accent2);
  outline-offset: 1px;
}

/* Relation card — chevron hint */
.rel-card::after {
  content: '';
  width: 12px; height: 12px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%239ea3c0' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M9 18l6-6-6-6'/%3E%3C/svg%3E") center/contain no-repeat;
  flex-shrink: 0;
  opacity: .4;
  transition: opacity 120ms;
}
.rtl-app .rel-card::after {
  transform: scaleX(-1);
}
.rel-card:hover::after { opacity: .8; }

/* ── PART 9: Operational Widget Styles ─────────────────────── */

/* Infrastructure health rows */
.health-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  border-radius: 7px;
  font-size: 11px;
  margin-bottom: 3px;
}
.health-row-icon {
  width: 22px; height: 22px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.health-row-label {
  min-width: 70px;
  font-weight: 600;
  color: var(--text2);
  font-size: 11px;
}
.health-bar-wrap {
  flex: 1;
  min-width: 0;
}
.health-bar {
  height: 5px;
  border-radius: 3px;
  background: var(--bg4);
  overflow: hidden;
  display: flex;
}
.health-bar-seg {
  height: 100%;
  min-width: 4px;
  transition: flex 400ms ease;
}
.seg-ok     { background: var(--success); }
.seg-warn   { background: var(--warn); }
.seg-danger { background: var(--danger); }
.health-row-count {
  font-size: 10px;
  font-weight: 700;
  min-width: 28px;
  text-align: end;
  font-variant-numeric: tabular-nums;
}
.health-count-ok     { color: var(--success); }
.health-count-warn   { color: var(--warn); }
.health-count-danger { color: var(--danger); }

/* Infra health badge */
.infra-badge {
  font-size: 9.5px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
}
.infra-badge-ok     { background: rgba(52,211,153,.12); color: var(--success); }
.infra-badge-warn   { background: rgba(251,191,36,.12); color: var(--warn); }
.infra-badge-danger { background: rgba(248,113,113,.12); color: var(--danger); }

/* ── PART 10: Theme Refinement ─────────────────────────────── */

/* Dark mode — better surface differentiation */
:root {
  --bg:  #0e1016;
  --bg2: #181b28;
  --bg3: #1f2333;
  --bg4: #272c40;
  --border: #2b2f45;
  --text: #eaebf3;
  --text2: #a0a5c0;
  --text3: #5a5f7a;
}

/* Light mode — better surface clarity */
.light {
  --bg:  #f4f5fb;
  --bg2: #ffffff;
  --bg3: #eef0f9;
  --bg4: #e4e7f3;
  --border: #d6d9ef;
  --text: #1a1d2e;
  --text2: #4a5080;
  --text3: #868db5;
  --accent: #5b52e8;
  --accent2: #7c6ff7;
}

/* Softer scrollbar in dark */
::-webkit-scrollbar-thumb { background: var(--bg4) !important; }
::-webkit-scrollbar-thumb:hover { background: var(--text3) !important; }

/* ── PART 11: Consistency Audit ────────────────────────────── */

/* Icon sizing — normalize */
.nav-item i, .bnav-item i {
  font-size: 16px !important;
}
.cmd-item-icon i {
  font-size: 14px !important;
}
.ops-row-icon i {
  font-size: 13px !important;
}
.rel-card-icon i {
  font-size: 13px !important;
}
.qp-head-icon i {
  font-size: 15px !important;
}

/* Border-radius consistency */
.ops-section, .activity-list {
  border-radius: var(--radius) !important;
  overflow: hidden;
}
.cmd-box { border-radius: 14px !important; }
.qp-modal { border-radius: 14px !important; }
.modal { border-radius: var(--radius-lg) !important; }

/* Tag consistency */
.tag { letter-spacing: .15px !important; }

/* Overlay backdrop */
.overlay {
  background: rgba(0,0,0,.55) !important;
}

/* Consistent shadow on static cards */
.stat { box-shadow: var(--elev-1); }
.analytics-panel { box-shadow: var(--elev-1); }
.note-card { box-shadow: var(--elev-1); }

/* Button group alignment */
.mfoot { gap: 8px !important; }

/* Tooltip-style title attributes — keep accessible */
[title] { cursor: default; }
button[title] { cursor: pointer; }

/* Table header consistent */
.ws-table th {
  background: var(--bg3) !important;
  border-bottom: 1px solid var(--border) !important;
}

/* ── PART 12: Performance Protection ───────────────────────── */
/* Use contain to limit repaint scope on heavy panels */
.ws-items { contain: layout style; }
.cmd-results { contain: layout style; }
.ops-section-body { contain: layout style; }

/* Hint browser about composited elements */
.cmd-box { will-change: transform, opacity; }
.qp-modal { will-change: transform, opacity; }
.inspector { will-change: contents; }

/* Ensure transitions only animate cheap properties */
.ops-row { contain: layout; }

/* ── Misc polish ───────────────────────────────────────────── */

/* Workspace select — better */
.ws-select { border-radius: 7px !important; }

/* Progress fill — smooth */
.progress-fill { transition: width 500ms var(--ease-out) !important; }

/* Sync toast */
#sync-toast {
  border-radius: 20px !important;
  box-shadow: var(--elev-2) !important;
}

/* Offline badge */
#offline-badge {
  box-shadow: var(--elev-1);
  font-size: 9.5px;
}

/* Pin box */
.pin-box { box-shadow: var(--elev-3) !important; }

/* Tag chips active focus ring */
.tag-chip.active {
  box-shadow: 0 0 0 2px rgba(108,99,255,.2);
}

/* Kanban cards elevation */
.kanban-card {
  box-shadow: var(--elev-1);
  transition: box-shadow 140ms, transform 140ms, border-color 140ms;
}
.kanban-card:hover {
  box-shadow: var(--elev-2) !important;
  transform: translateY(-1px);
}

/* Inspector notes textarea focus */
.notes-ta:focus {
  box-shadow: var(--glow-accent) !important;
}

/* Remove outline from focused btn-icon when mouse-clicked */
.btn-icon:focus:not(:focus-visible) { outline: none; }

/* Search hit elevation */
.search-hit {
  box-shadow: var(--elev-0) !important;
  transition: box-shadow 140ms, border-color 140ms, background 140ms !important;
}
.search-hit:hover {
  box-shadow: var(--elev-1) !important;
}

/* Responsive: mobile inspector improved */
@media (max-width: 700px) {
  .inspector-header {
    padding: 12px 14px !important;
    margin-bottom: 14px !important;
  }
  .dash-hero { margin-bottom: 14px !important; }
  .ops-card-value { font-size: 26px !important; }
}

/* Dot in inspector header — larger */
.inspector-header h1 span[style*="border-radius:50%"] {
  width: 10px !important;
  height: 10px !important;
}
