/* =============================================================
   Sobi Desk Cases Redesign
   Scope: all-cases workspace presentation only.
   ============================================================= */

.cases-workspace {
  display: grid;
  gap: 12px;
  padding: 18px;
  min-width: 0;
}

.cases-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.cases-hero-main {
  min-width: 0;
}

.cases-eyebrow {
  color: var(--text3);
  font-size: 10px;
  font-weight: 750;
  letter-spacing: .35px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.cases-hero h1 {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-size: 22px;
  line-height: 1.2;
  font-weight: 760;
  letter-spacing: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.cases-hero h1 i {
  color: var(--accent2);
  font-size: 22px;
  flex-shrink: 0;
}

.cases-hero p {
  color: var(--text2);
  font-size: 12px;
  line-height: 1.6;
  margin-top: 6px;
  max-width: 660px;
}

.cases-primary-action {
  min-height: 34px;
  border-radius: 7px;
  justify-content: center;
}

.cases-metrics {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.case-metric {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  min-height: 66px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-metric i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: var(--bg3);
  color: var(--text3);
  font-size: 16px;
  flex-shrink: 0;
}

.case-metric div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.case-metric strong {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.case-metric span {
  color: var(--text3);
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.case-metric.accent i,
.case-metric.accent strong {
  color: var(--accent2);
}

.case-metric.warn i,
.case-metric.warn strong {
  color: var(--warn);
}

.case-metric.danger i,
.case-metric.danger strong {
  color: var(--danger);
}

.case-metric.info i,
.case-metric.info strong {
  color: var(--accent3);
}

.case-metric.success i,
.case-metric.success strong {
  color: var(--success);
}

.cases-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1.5fr) repeat(3, minmax(140px, .75fr)) auto;
  gap: 8px;
  align-items: end;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.cases-search,
.cases-filter {
  min-width: 0;
}

.cases-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg3);
  color: var(--text3);
}

.cases-search:focus-within {
  border-color: var(--accent2);
}

.cases-search i {
  font-size: 15px;
  flex-shrink: 0;
}

.cases-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 12.5px;
}

.cases-search input::placeholder {
  color: var(--text3);
}

.cases-filter {
  display: grid;
  gap: 4px;
}

.cases-filter span {
  color: var(--text3);
  font-size: 10px;
  font-weight: 700;
}

.cases-filter select {
  width: 100%;
  min-width: 0;
  height: 40px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg3);
  color: var(--text);
  font: inherit;
  font-size: 12px;
  padding: 0 9px;
  outline: 0;
}

.cases-filter select:focus {
  border-color: var(--accent2);
}

.cases-reset {
  min-height: 40px;
  justify-content: center;
}

.cases-reset:disabled {
  opacity: .45;
  cursor: default;
}

.cases-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
  align-items: start;
}

.case-column {
  min-width: 0;
  min-height: 190px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-column-head {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 28px;
  margin-bottom: 9px;
}

.case-column-head strong {
  margin-inline-start: auto;
  color: var(--text3);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}

.case-status-badge {
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-column-empty {
  display: grid;
  place-items: center;
  min-height: 110px;
  border: 1px dashed var(--border);
  border-radius: 7px;
  color: var(--text3);
  font-size: 11px;
  text-align: center;
}

.case-card {
  position: relative;
  display: grid;
  gap: 8px;
  width: 100%;
  min-width: 0;
  margin-bottom: 7px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg3);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  text-align: start;
  transition: border-color .15s, transform .15s, background .15s;
}

.case-card:hover,
.case-card:focus-visible {
  border-color: var(--accent2);
  background: var(--bg4);
  outline: none;
  transform: translateY(-1px);
}

.case-priority-line {
  position: absolute;
  inset-block: 10px;
  inset-inline-start: 0;
  width: 3px;
  border-radius: 3px;
  background: var(--text3);
}

.case-card.priority-urgent .case-priority-line,
.case-card.priority-high .case-priority-line {
  background: var(--danger);
}

.case-card.priority-normal .case-priority-line {
  background: var(--success);
}

.case-card.priority-low .case-priority-line {
  background: var(--text3);
}

.case-card-top {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
}

.case-card-title {
  flex: 1;
  min-width: 0;
  color: var(--text);
  font-size: 13px;
  font-weight: 730;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.case-priority-chip {
  flex-shrink: 0;
  max-width: 88px;
  min-height: 21px;
  padding: 3px 7px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--bg2);
  color: var(--text3);
  font-size: 10px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-card.priority-urgent .case-priority-chip,
.case-card.priority-high .case-priority-chip {
  color: var(--danger);
  border-color: rgba(248,113,113,.32);
  background: rgba(248,113,113,.08);
}

.case-card-client,
.case-card-meta,
.case-card-foot {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
  color: var(--text3);
  font-size: 11px;
  line-height: 1.4;
}

.case-card-client {
  color: var(--text2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-card-client i,
.case-card-meta i,
.case-card-foot i {
  font-size: 12px;
  flex-shrink: 0;
}

.case-card-meta {
  flex-wrap: wrap;
}

.case-card-meta span,
.case-card-foot span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
}

.case-card-meta .danger {
  color: var(--danger);
  font-weight: 700;
}

.case-card-meta .warn {
  color: var(--warn);
  font-weight: 700;
}

.case-card-foot {
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

.cases-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: min(420px, calc(100vh - 280px));
  padding: 28px 16px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  background: var(--bg2);
  text-align: center;
}

.cases-empty i {
  color: var(--text3);
  font-size: 38px;
  opacity: .6;
}

.cases-empty h2 {
  color: var(--text);
  font-size: 15px;
  font-weight: 730;
  margin: 0;
}

.cases-empty p {
  max-width: 320px;
  color: var(--text3);
  font-size: 12px;
  line-height: 1.6;
}

body.density-compact .cases-workspace {
  gap: 9px;
  padding: 12px;
}

body.density-compact .case-metric {
  min-height: 54px;
  padding: 8px;
}

body.density-compact .case-card {
  padding: 8px;
}

@media (max-width: 1180px) {
  .cases-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .cases-toolbar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .cases-search {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .cases-workspace {
    padding: 12px;
  }

  .cases-hero {
    grid-template-columns: 1fr;
  }

  .cases-primary-action {
    width: 100%;
  }

  .cases-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cases-toolbar {
    grid-template-columns: 1fr;
  }

  .cases-board {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 430px) {
  .cases-metrics {
    grid-template-columns: 1fr;
  }

  .case-card-top {
    display: grid;
  }

  .case-priority-chip {
    max-width: 100%;
    justify-self: start;
  }
}

/* Selected case inspector */
.cases-detail-shell {
  display: grid;
  gap: 10px;
  align-content: start;
  width: 100%;
  max-width: min(1180px, 100%);
  height: 100%;
  min-height: 0;
  margin: 0 auto;
  padding: 16px 18px 52px;
  min-width: 0;
  overflow-x: hidden;
  overflow-y: auto;
}

.cases-detail-back {
  justify-self: start;
  margin-bottom: 0;
}

.cases-detail-shell .case-detail-inspector {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 0;
  overflow: visible;
}

.cases-detail-shell .inspector-body {
  min-width: 0;
  overflow: visible;
  padding: 18px 20px 36px;
}

.case-detail-inspector .inspector-toolbar {
  gap: 10px;
  max-width: 100%;
}

.case-client-crumb {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--text3);
  cursor: pointer;
  font: inherit;
  font-size: 11px;
}

.case-client-crumb:hover,
.case-client-crumb:focus-visible {
  color: var(--accent2);
  outline: none;
}

.case-client-crumb i {
  font-size: 11px;
  flex-shrink: 0;
}

.case-toolbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.case-detail-body {
  display: grid;
  gap: 12px;
  min-width: 0;
  max-width: 100%;
}

.case-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, 230px);
  gap: 14px;
  align-items: start;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-detail-hero-main {
  min-width: 0;
}

.case-detail-hero h1 {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  color: var(--text);
  font-size: 24px;
  line-height: 1.2;
  font-weight: 760;
  letter-spacing: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.case-detail-hero .case-priority-dot {
  width: 11px;
  height: 11px;
  margin-top: 8px;
}

.case-detail-badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.case-due-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 22px;
  padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--bg3);
  color: var(--text3);
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
}

.case-due-badge i {
  font-size: 11px;
}

.case-due-badge.danger {
  color: var(--danger);
  border-color: rgba(248,113,113,.32);
  background: rgba(248,113,113,.08);
}

.case-due-badge.warn {
  color: var(--warn);
  border-color: rgba(251,191,36,.32);
  background: rgba(251,191,36,.08);
}

.case-status-control {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg3);
}

.case-status-control .fsel {
  width: 100%;
  min-width: 0;
}

.case-summary-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.case-summary-item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  min-height: 68px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-summary-item > i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: var(--bg3);
  color: var(--text3);
  font-size: 16px;
  flex-shrink: 0;
}

.case-summary-item div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.case-summary-item span {
  color: var(--text3);
  font-size: 9.5px;
  font-weight: 750;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.case-summary-item strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-summary-item.info > i,
.case-summary-item.info strong {
  color: var(--accent3);
}

.case-summary-item.warn > i,
.case-summary-item.warn strong {
  color: var(--warn);
}

.case-summary-item.danger > i,
.case-summary-item.danger strong {
  color: var(--danger);
}

.case-summary-item.success > i,
.case-summary-item.success strong {
  color: var(--success);
}

.case-detail-main-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.case-detail-panel {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-detail-wide {
  grid-column: 1 / -1;
}

.case-detail-panel header,
.case-work-section > header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 11px;
}

.case-detail-panel header span,
.case-work-section > header span {
  color: var(--text3);
  font-size: 10px;
  font-weight: 750;
  letter-spacing: .35px;
  text-transform: uppercase;
}

.case-detail-panel header i {
  color: var(--accent2);
  font-size: 17px;
  flex-shrink: 0;
}

.case-work-section > header h2 {
  color: var(--text);
  font-size: 15px;
  line-height: 1.25;
  font-weight: 740;
  margin: 2px 0 0;
}

.case-work-section > header strong {
  color: var(--text3);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

.case-fact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.case-fact {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 8px;
  border-radius: 7px;
  background: var(--bg3);
}

.case-fact span,
.case-client-link span,
.case-activity-preview span {
  color: var(--text3);
  font-size: 10.5px;
}

.case-fact strong,
.case-client-link strong,
.case-activity-preview strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
}

.case-fact strong,
.case-client-link strong {
  white-space: nowrap;
}

.case-client-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
  padding: 10px;
  border-radius: 8px;
  background: var(--bg3);
}

.case-client-link div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.case-notes-preview {
  max-height: 180px;
  overflow: auto;
  color: var(--text2);
  font-size: 12px;
  line-height: 1.7;
  white-space: pre-wrap;
}

.case-activity-preview {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 8px;
  background: var(--bg3);
}

.case-doc-list {
  display: grid;
  gap: 7px;
}

.case-doc-list div {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 8px;
  border-radius: 7px;
  background: var(--bg3);
  color: var(--text2);
  font-size: 12px;
}

.case-doc-list i {
  color: var(--accent2);
  font-size: 14px;
  flex-shrink: 0;
}

.case-doc-list span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-panel-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
  min-height: 32px;
  margin-top: 10px;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: var(--bg3);
  color: var(--text2);
  cursor: pointer;
  font: inherit;
  font-size: 11.5px;
}

.case-panel-action:hover,
.case-panel-action:focus-visible {
  color: var(--text);
  border-color: var(--accent2);
  outline: none;
}

.case-custom-fields {
  padding: 10px;
  border-radius: 8px;
  background: var(--bg3);
}

.case-tag-list {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.case-detail-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 72px;
  padding: 14px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  color: var(--text3);
  font-size: 12px;
  text-align: center;
}

.case-detail-empty i {
  font-size: 17px;
  opacity: .75;
}

.case-detail-tabs {
  max-width: 100%;
  margin-bottom: 0;
  overflow-x: auto;
  overflow-y: hidden;
}

.case-work-section {
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
}

.case-work-section .tl-add-note {
  padding-top: 0;
}

.case-work-section .tl-empty {
  min-height: 160px;
  display: grid;
  place-items: center;
  border: 1px dashed var(--border);
  border-radius: 8px;
  background: var(--bg3);
}

.case-work-section .ck-progress {
  margin-bottom: 12px;
}

body.density-compact .case-detail-body {
  gap: 9px;
}

body.density-compact .case-detail-hero,
body.density-compact .case-detail-panel,
body.density-compact .case-work-section {
  padding: 10px;
}

@media (max-width: 1180px) {
  .case-summary-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .case-detail-hero {
    grid-template-columns: 1fr;
  }

  .case-summary-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .case-detail-main-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .cases-detail-shell {
    padding: 12px 12px 44px;
  }

  .cases-detail-shell .inspector-body {
    padding: 14px 12px 32px;
  }

  .case-detail-inspector .inspector-toolbar {
    align-items: flex-start;
  }

  .case-toolbar-actions {
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .case-detail-hero h1 {
    font-size: 20px;
  }

  .case-summary-strip,
  .case-fact-grid {
    grid-template-columns: 1fr;
  }

  .case-client-link {
    display: grid;
  }

  .case-client-link .btn-icon {
    justify-content: center;
  }

  .case-work-section .tl-add-note {
    display: grid;
  }

  .case-work-section .tl-add-note .fsel {
    width: 100% !important;
  }
}
