/* Domus Pura shared shells (opt-in, no contour bindings) */

.dp-app-shell {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  min-height: 100dvh;
  background: var(--dp-color-bg-page);
  color: var(--dp-color-text-primary);
  overflow-x: clip;
}

.dp-app-shell__sidebar,
.dp-cabinet-sidebar {
  min-width: 0;
  padding: var(--dp-space-5);
  background: var(--dp-color-bg-surface);
  border-right: var(--dp-border-width) solid var(--dp-color-border-soft);
}

.dp-app-shell__main,
.dp-cabinet-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.dp-app-shell__header,
.dp-cabinet-header,
.dp-public-header {
  min-width: 0;
  padding: var(--dp-space-5);
  border-bottom: var(--dp-border-width) solid var(--dp-color-border-soft);
  background: var(--dp-color-bg-surface);
}

.dp-app-shell__content,
.dp-cabinet-content,
.dp-public-main {
  min-width: 0;
  padding: var(--dp-space-5);
  display: grid;
  gap: var(--dp-space-5);
}

.dp-public-shell {
  min-height: 100dvh;
  background: var(--dp-color-bg-page);
  color: var(--dp-color-text-primary);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow-x: clip;
}

.dp-public-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--dp-space-4);
  align-items: center;
  justify-content: space-between;
}

.dp-public-header__brand {
  min-width: 0;
  font-size: var(--dp-font-size-lg);
  font-weight: var(--dp-font-weight-semibold);
  line-height: var(--dp-line-height-tight);
}

.dp-public-header__nav {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--dp-space-3);
}


/* Compatibility: when legacy .site-header is combined with dp-public-header,
   keep legacy hs2.css visuals as the source of truth. */
.site-header.dp-public-header {
  padding: 0;
  border-bottom: 0;
  background: transparent;
}
.dp-public-section,
.dp-cabinet-section,
.dp-curator-section,
.dp-relator-summary,
.dp-contractor-work-strip,
.dp-contractor-evidence-zone,
.dp-curator-context-bar,
.dp-relator-action-strip {
  min-width: 0;
  display: grid;
  gap: var(--dp-space-4);
  padding: var(--dp-space-4);
  background: var(--dp-color-bg-surface);
  border: var(--dp-border-width) solid var(--dp-color-border-soft);
  border-radius: var(--dp-radius-lg);
}

.dp-public-footer {
  min-width: 0;
  padding: var(--dp-space-4) var(--dp-space-5);
  border-top: var(--dp-border-width) solid var(--dp-color-border-soft);
  color: var(--dp-color-text-secondary);
  background: var(--dp-color-bg-surface);
}

.dp-hero {
  min-width: 0;
  padding: var(--dp-space-6);
  border-radius: var(--dp-radius-xl);
  background: var(--dp-color-bg-surface);
  border: var(--dp-border-width) solid var(--dp-color-border-soft);
}

.dp-hero__content { display: grid; gap: var(--dp-space-3); min-width: 0; }
.dp-hero__eyebrow { margin: 0; font-size: var(--dp-font-size-xs); color: var(--dp-color-text-secondary); }
.dp-hero__title { margin: 0; font-size: var(--dp-font-size-2xl); line-height: var(--dp-line-height-tight); }
.dp-hero__text { margin: 0; color: var(--dp-color-text-secondary); overflow-wrap: anywhere; }
.dp-hero__actions { display: flex; flex-wrap: wrap; gap: var(--dp-space-3); }

.dp-cabinet-shell {
  min-height: 100dvh;
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  background: var(--dp-color-bg-page);
  overflow-x: clip;
}

.dp-cabinet-main { background: var(--dp-color-bg-page); }
.dp-cabinet-context { min-width: 0; display: grid; gap: var(--dp-space-4); }

.dp-admin-shell .dp-cabinet-sidebar { grid-column: 1; }
.dp-admin-shell .dp-cabinet-main { grid-column: 2; }

.dp-curator-shell .dp-cabinet-content,
.dp-relator-shell .dp-cabinet-content,
.dp-contractor-shell .dp-cabinet-content {
  gap: var(--dp-space-4);
}

.dp-shell-nav { min-width: 0; display: grid; gap: var(--dp-space-3); }
.dp-shell-nav__group { min-width: 0; display: grid; gap: var(--dp-space-2); }
.dp-shell-nav__group-button {
  width: 100%;
  display: grid;
  gap: var(--dp-space-1);
  justify-items: start;
  padding: var(--dp-space-2) var(--dp-space-3);
  border: var(--dp-border-width) solid var(--dp-color-border-soft);
  border-radius: var(--dp-radius-md);
  background: var(--dp-color-bg-surface);
  color: var(--dp-color-text-primary);
}
.dp-shell-nav__group-title { font-size: var(--dp-font-size-sm); font-weight: var(--dp-font-weight-semibold); }
.dp-shell-nav__group-note { font-size: var(--dp-font-size-xs); color: var(--dp-color-text-secondary); overflow-wrap: anywhere; }
.dp-shell-nav__items { display: none; min-width: 0; padding-left: var(--dp-space-2); }
.dp-shell-nav__group.is-open .dp-shell-nav__items { display: grid; gap: var(--dp-space-2); }
.dp-shell-nav__item {
  display: block;
  min-width: 0;
  padding: var(--dp-space-2) var(--dp-space-3);
  border: var(--dp-border-width) solid transparent;
  border-radius: var(--dp-radius-sm);
  color: var(--dp-color-text-secondary);
  text-decoration: none;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.dp-shell-nav__item.is-active {
  color: var(--dp-color-text-primary);
  border-color: var(--dp-color-border-medium);
  background: var(--dp-color-bg-muted);
}

@media (max-width: 960px) {
  .dp-app-shell,
  .dp-cabinet-shell {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr);
  }

  .dp-app-shell__sidebar,
  .dp-cabinet-sidebar {
    border-right: 0;
    border-bottom: var(--dp-border-width) solid var(--dp-color-border-soft);
  }

  .dp-public-header,
  .dp-app-shell__header,
  .dp-cabinet-header,
  .dp-app-shell__content,
  .dp-cabinet-content,
  .dp-public-main {
    padding: var(--dp-space-4);
  }
}
