/* DRAFTSPACE — projects page styles */

.wrap { max-width: 1280px; margin: 0 auto; padding: 32px 48px 64px; }

/* Page header */
.proj-head {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px; align-items: end;
  padding-bottom: 24px;
  border-bottom: 1px dashed var(--ds-rule-dash);
  margin-bottom: 32px;
}
.proj-head .anno { font-family: var(--ds-font-mono); font-size: 11px; color: var(--ds-mint); text-transform: uppercase; letter-spacing: 0.16em; margin-bottom: 12px; }
.proj-head h1 { font-family: var(--ds-font-display); font-size: 56px; font-weight: 600; letter-spacing: -0.03em; margin: 0; line-height: 1; color: var(--ds-fg); }
.proj-head h1 em { font-family: var(--ds-font-serif); font-style: italic; color: var(--ds-mint); font-variation-settings: "opsz" 144, "wght" 400; }
.proj-head .sub { font-family: var(--ds-font-serif); font-style: italic; font-size: 18px; color: var(--ds-fg-dim); margin-top: 12px; max-width: 50ch; }
.proj-head .stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.proj-head .stat { font-family: var(--ds-font-mono); font-size: 11px; color: var(--ds-fg-mute); text-transform: uppercase; letter-spacing: 0.16em; }
.proj-head .stat strong { display: block; font-family: var(--ds-font-display); font-size: 28px; color: var(--ds-fg); font-weight: 600; text-transform: none; letter-spacing: -0.02em; margin-top: 4px; }

/* Featured cards */
.featured {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}
.card {
  border: 1px solid var(--ds-rule);
  background: var(--ds-bg-2);
  border-radius: var(--ds-radius);
  overflow: hidden;
  display: flex; flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--ds-dur) var(--ds-easing);
}
.card:hover { border-color: var(--ds-mint); }
.card .diag {
  height: 200px;
  background: var(--ds-bg);
  border-bottom: 1px dashed var(--ds-rule-dash);
  background-image: var(--ds-grid-bg);
  background-size: var(--ds-grid-size);
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.card .diag svg { display: block; width: 100%; height: 100%; position: absolute; inset: 0; }
.card .diag .corner { position: absolute; width: 8px; height: 8px; border: 1px solid var(--ds-mint); opacity: 0.4; }
.card .diag .corner.tl { top: 6px; left: 6px; border-right: 0; border-bottom: 0; }
.card .diag .corner.tr { top: 6px; right: 6px; border-left: 0; border-bottom: 0; }
.card .diag .corner.bl { bottom: 6px; left: 6px; border-right: 0; border-top: 0; }
.card .diag .corner.br { bottom: 6px; right: 6px; border-left: 0; border-top: 0; }
.card .diag .diag-label { font-family: var(--ds-font-mono); font-size: 10px; color: var(--ds-fg-mute); text-transform: uppercase; letter-spacing: 0.16em; position: relative; z-index: 1; }
.card .body { padding: 20px 22px 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.card .meta { display: flex; gap: 12px; font-family: var(--ds-font-mono); font-size: 10px; color: var(--ds-fg-mute); text-transform: uppercase; letter-spacing: 0.16em; }
.card .meta .status-dot::before { content: "● "; }
.card .meta .status-dot.ok::before     { color: var(--ds-mint); }
.card .meta .status-dot.wip::before    { color: var(--ds-amber); }
.card .meta .status-dot.archive::before { color: var(--ds-fg-mute); }
.card h3 { font-family: var(--ds-font-display); font-size: 22px; font-weight: 600; margin: 0; letter-spacing: -0.01em; color: var(--ds-fg); }
.card .desc { color: var(--ds-fg-dim); font-size: 14px; line-height: 1.55; }
.card .card-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; padding-top: 8px; }
.card .card-tag {
  display: inline-block; padding: 2px 8px;
  border: 1px solid var(--ds-rule);
  border-radius: 999px;
  font-family: var(--ds-font-mono);
  font-size: 10px;
  color: var(--ds-fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.card .arrow { align-self: flex-end; font-family: var(--ds-font-mono); font-size: 12px; color: var(--ds-fg-mute); transition: all var(--ds-dur) var(--ds-easing); }
.card:hover .arrow { color: var(--ds-mint); transform: translateX(4px); }

/* Filter row */
.filter-row {
  display: flex; gap: 16px; align-items: center;
  padding: 16px 0;
  border-top: 1px dashed var(--ds-rule-dash);
  border-bottom: 1px dashed var(--ds-rule-dash);
  font-family: var(--ds-font-mono); font-size: 11px;
  color: var(--ds-fg-mute);
}
.filter-row .lbl { text-transform: uppercase; letter-spacing: 0.16em; }

/* Table tweaks on top of ds-table base */
.ds-table tr { cursor: pointer; }
.ds-table tr:hover { background: var(--ds-bg-3); }
.ds-table td.t-name { color: var(--ds-fg); font-weight: 500; }
.ds-table td.t-name a { color: inherit; text-decoration: none; }
.ds-table tr:hover td.t-name a { color: var(--ds-mint); }
.ds-table td.t-lang { font-family: var(--ds-font-mono); }
.ds-table td.t-status .pill {
  display: inline-block; padding: 1px 8px;
  font-family: var(--ds-font-mono); font-size: 10px;
  border: 1px solid var(--ds-rule);
  border-radius: 999px;
  text-transform: uppercase; letter-spacing: 0.08em;
}
.ds-table td.t-status .pill.ok      { color: var(--ds-mint);     border-color: rgba(125,249,196,0.3); }
.ds-table td.t-status .pill.wip     { color: var(--ds-amber);    border-color: rgba(251,176,64,0.3); }
.ds-table td.t-status .pill.archive { color: var(--ds-fg-mute); }
.ds-table th[data-sort] { cursor: pointer; user-select: none; }
.ds-table th[data-sort]::after { content: " ↕"; opacity: 0.3; }
.ds-table th[data-sort][aria-sort="asc"]::after  { content: " ▴"; opacity: 1; color: var(--ds-mint); }
.ds-table th[data-sort][aria-sort="desc"]::after { content: " ▾"; opacity: 1; color: var(--ds-mint); }
.spark-cell svg { display: block; height: 18px; width: 80px; }
