/* ============================================================
   Layer 6: Table primitives
   The .cms-shell admin frame, .cms-table family, the stats strip,
   filter row, search field, and row actions.
   ============================================================ */

.cms-shell {
  display: grid; grid-template-columns: 210px 1fr;
  border: var(--rule); border-radius: 4px; overflow: hidden;
  min-height: 660px;
  background: var(--surface);
}
.cms-sidebar {
  background-color: var(--neutral);
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%224%22%20height%3D%224%22%3E%3Crect%20width%3D%224%22%20height%3D%224%22%20fill%3D%22%23e8e8e8%22/%3E%3Ccircle%20cx%3D%220%22%20cy%3D%220%22%20r%3D%221.5%22%20fill%3D%22%23b8b6b2%22%20opacity%3D%220.15%22/%3E%3C/svg%3E");
  background-size: 4px 4px;
  display: flex; flex-direction: column;
  border-right: var(--rule);
}
.cms-logo { padding: var(--space-20) var(--space-20) var(--space-16); font-family: var(--font-serif); font-style: italic; font-size: var(--text-h5); color: var(--primary); border-bottom: var(--rule); line-height: 1.3; }
.cms-nav-group { padding: var(--space-16) 0 var(--space-8); }
.cms-nav-lbl { font-family: var(--font); font-size: var(--text-tiny); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--primary); padding: 0 var(--space-20) var(--space-8); }
.cms-item { display: flex; align-items: center; gap: 10px; padding: var(--space-8) var(--space-20); font-family: var(--font); font-size: var(--text-meta); font-weight: 500; color: var(--primary); cursor: pointer; transition: all 0.12s; }
.cms-item:hover { background: var(--ink-08); color: var(--primary); }
.cms-item.on { background: var(--primary); color: var(--surface); font-weight: 600; }
.cms-item svg { width: 14px; height: 14px; color: var(--primary); opacity: 1; flex-shrink: 0; }
.cms-item.on svg { opacity: 1; color: var(--surface); }
.cms-hr { height: 1px; background: var(--ink-18); margin: 6px 0; }
.cms-badge { margin-left: auto; background: transparent; color: var(--primary); border: 1px solid var(--primary); font-family: var(--font-cond); font-size: var(--text-tiny); font-weight: 700; padding: 1px 6px; border-radius: 2px; letter-spacing: 0.06em; }

.cms-main { display: flex; flex-direction: column; }
.cms-topbar { display: flex; align-items: center; justify-content: space-between; padding: 14px var(--space-24); border-bottom: var(--rule); }
/* DS showcase only — mirrors style-cms.css's .view-title canonical rule so
   the documented "CMS page title" look matches what runs in production. */
.cms-page-title { font-family: var(--font-serif); font-style: italic; font-size: 26px; font-weight: 400; letter-spacing: -0.01em; color: var(--primary); line-height: 1.2; }
.cms-actions { display: flex; gap: var(--space-8); }
.cms-btn-sec { padding: 7px 14px; border-radius: 3px; background: transparent; border: 1px solid var(--primary); color: var(--primary); font-family: var(--font-cond); font-size: var(--text-label); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer; }
.cms-btn-sec:hover { border-color: var(--primary); color: var(--primary); }
.cms-btn-pri { padding: 7px 14px; border-radius: 3px; background: var(--primary); border: 1px solid var(--primary); color: var(--white); font-family: var(--font-cond); font-size: var(--text-label); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer; }
.cms-content { padding: 22px var(--space-24); flex: 1; }

.cms-stats { display: flex; border: var(--rule); border-radius: 3px; overflow: hidden; margin-bottom: 18px; }
.cms-stat {
  flex: 1; padding: var(--space-12) var(--space-16);
  background-color: var(--neutral);
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%224%22%20height%3D%224%22%3E%3Crect%20width%3D%224%22%20height%3D%224%22%20fill%3D%22%23e8e8e8%22/%3E%3Ccircle%20cx%3D%220%22%20cy%3D%220%22%20r%3D%221.5%22%20fill%3D%22%23b8b6b2%22%20opacity%3D%220.15%22/%3E%3C/svg%3E");
  background-size: 4px 4px;
  border-right: var(--rule);
}
.cms-stat:last-child { border-right: none; }
.cms-stat-val { font-size: var(--text-body-lg); font-weight: 700; letter-spacing: -0.02em; }
.cms-stat-lbl { font-family: var(--font); font-size: var(--text-label); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--secondary); margin-top: 2px; }

.cms-filter { display: flex; gap: 10px; align-items: center; margin-bottom: var(--space-16); flex-wrap: wrap; }
.cms-search { flex: 1; min-width: 160px; padding: 7px var(--space-12); border: 1px solid var(--primary); border-radius: 3px; background: var(--surface); font-family: var(--font); font-size: var(--text-meta); color: var(--primary); outline: none; }
.cms-search:focus { border-color: var(--primary); }
.cms-search::placeholder { color: var(--secondary); }

.cms-table { width: 100%; border-collapse: collapse; }
.cms-table th:first-child { width: 216px; max-width: 216px; }
.cms-table th { font-family: var(--font-cond); font-size: var(--text-label); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--primary); text-align: left; padding: var(--space-8) var(--space-12); border-bottom: var(--rule); }
.cms-table td { padding: 11px var(--space-12); border-bottom: 1px solid var(--ink-12); font-size: var(--text-meta); font-weight: 500; color: var(--secondary); vertical-align: middle; }
.cms-table td:nth-child(4) { font-size: var(--text-pill); }
.cms-table tr:hover td { background: var(--ink-08); }
.td-title { font-weight: 600 !important; color: var(--primary) !important; width: 216px; max-width: 216px; }

.row-act { display: flex; gap: 6px; }
