/* Case study artifact / reference document pages */

.cs-artifact-page,
.cs-artifact-page .cs-page,
.cs-artifact-page .cs-artifact,
.cs-artifact-page .cs-artifact-topbar {
  text-align: left;
}

.cs-artifact-page .cs-artifact {  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  padding: 0 var(--cs-inset) 96px;
  box-sizing: border-box;
}

.cs-artifact-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px var(--cs-inset) 18px;
  border-bottom: 1px solid var(--cs-hairline);
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
}

.cs-artifact-topbar a {
  color: var(--cs-primary);
  text-decoration: none;
}

.cs-artifact-topbar a:hover {
  text-decoration: underline;
}

.cs-artifact-topbar-meta {
  color: var(--cs-muted);
}

.cs-artifact-header {
  padding: 40px 0 32px;
  border-bottom: 1px solid var(--cs-hairline);
  margin-bottom: 40px;
}

.cs-artifact-kicker {
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--cs-muted);
  margin: 0 0 12px;
}

.cs-artifact-title {
  font-family: var(--cs-font-display);
  font-weight: 400;
  font-size: var(--type-display-m);
  line-height: var(--lh-display);
  letter-spacing: -0.6px;
  color: var(--cs-ink);
  margin: 0 0 8px;
}

.cs-artifact-subtitle {
  font-size: var(--type-body);
  line-height: var(--lh-body-loose);
  color: var(--cs-body);
  margin: 0 0 24px;
  max-width: 65ch;
}

.cs-artifact-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 16px 32px;
  margin: 0;
}

.cs-artifact-meta dt {
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--cs-muted);
  margin: 0 0 4px;
}

.cs-artifact-meta dd {
  font-size: var(--type-body-sm);
  line-height: var(--lh-body);
  color: var(--cs-ink);
  margin: 0;
}

.cs-artifact-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.cs-artifact-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid var(--cs-hairline);
  border-radius: 4px;
  background: var(--cs-canvas);
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--cs-primary);
  text-decoration: none;
  cursor: pointer;
}

.cs-artifact-btn:hover {
  border-color: var(--cs-primary);
}

.cs-artifact-btn--primary {
  background: var(--cs-primary);
  border-color: var(--cs-primary);
  color: var(--cs-canvas);
}

.cs-artifact-btn--primary:hover {
  background: #1f2d49;
  border-color: #1f2d49;
  color: var(--cs-canvas);
}

.cs-artifact-body h2 {
  font-family: var(--cs-font-display);
  font-weight: 400;
  font-size: var(--type-display-xs);
  line-height: 1.25;
  color: var(--cs-ink);
  margin: 40px 0 16px;
}

.cs-artifact-body h2:first-child {
  margin-top: 0;
}

.cs-artifact-body h3 {
  font-family: var(--cs-font-body);
  font-size: var(--type-body);
  font-weight: 500;
  color: var(--cs-ink);
  margin: 28px 0 10px;
}

.cs-artifact-body p,
.cs-artifact-body li {
  font-size: var(--type-body-sm);
  line-height: var(--lh-body-loose);
  color: var(--cs-body);
}

.cs-artifact-body p {
  margin: 0 0 14px;
  max-width: 72ch;
}

.cs-artifact-body ul,
.cs-artifact-body ol {
  margin: 0 0 18px;
  padding-left: 1.25em;
  max-width: 72ch;
}

.cs-artifact-body li {
  margin-bottom: 6px;
}

.cs-artifact-body li ul,
.cs-artifact-body li ol {
  margin-top: 8px;
  margin-bottom: 8px;
}

.cs-artifact-note {
  padding: 16px 20px;
  border-left: 3px solid var(--cs-primary);
  background: var(--cs-soft);
  margin: 24px 0;
  max-width: 72ch;
}

.cs-artifact-note p:last-child {
  margin-bottom: 0;
}

.cs-artifact-table-wrap {
  overflow-x: auto;
  margin: 20px 0 32px;
  border: 1px solid var(--cs-hairline);
  border-radius: 4px;
}

.cs-artifact-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--type-body-sm);
  line-height: var(--lh-body);
}

.cs-artifact-table caption {
  caption-side: top;
  text-align: left;
  padding: 14px 16px;
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--cs-muted);
  border-bottom: 1px solid var(--cs-hairline);
}

.cs-artifact-table th {
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  font-weight: 500;
  text-align: left;
  padding: 12px 16px;
  border-bottom: 1px solid var(--cs-hairline);
  background: var(--cs-soft);
  color: var(--cs-muted);
  white-space: nowrap;
}

.cs-artifact-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--cs-hairline);
  color: var(--cs-body);
  vertical-align: top;
}

.cs-artifact-table tr:last-child td {
  border-bottom: none;
}

.cs-artifact-table tr.cs-artifact-table-total td {
  font-weight: 500;
  color: var(--cs-ink);
  background: var(--cs-soft);
}

.cs-artifact-table td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.cs-artifact-script {
  padding: 20px 24px;
  border: 1px solid var(--cs-hairline);
  border-radius: 4px;
  background: var(--cs-soft);
  font-size: var(--type-body-sm);
  line-height: var(--lh-body-loose);
  color: var(--cs-body);
  max-width: 72ch;
}

.cs-artifact-footer {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--cs-hairline);
  font-family: var(--cs-font-mono);
  font-size: var(--type-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--cs-muted);
}

@media print {
  @page {
    margin: 0.7in;
  }

  html.route-wipe-pending body::before,
  #route-wipe {
    display: none !important;
  }

  body.cs-artifact-printing,
  body.cs-artifact-page {
    text-align: left;
  }

  .nav-container,
  .cs-artifact-topbar,
  .cs-artifact-toolbar,
  .skip-link {
    display: none !important;
  }

  .cs-page,
  .cs-artifact-page .cs-artifact {
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
  }

  .cs-artifact-body,
  .cs-artifact-body p,
  .cs-artifact-body ul,
  .cs-artifact-body ol,
  .cs-artifact-note,
  .cs-artifact-script {
    max-width: none !important;
  }

  .cs-artifact-table-wrap {
    break-inside: avoid;
    overflow: visible;
  }

  .cs-artifact-table th,
  .cs-artifact-table tr.cs-artifact-table-total td {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}
