void-dialog {
  display: none;
}

void-dialog[open] {
  display: contents;
}

.void-dialog-backdrop {
  position: fixed;
  inset: 0;
  background: var(--void-color-bg-overlay);
  z-index: var(--void-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}

.void-dialog-panel {
  background: var(--void-color-bg-elevated);
  border: 1px solid var(--void-color-border);
  border-radius: var(--void-radius-lg);
  box-shadow: var(--void-shadow-lg);
  max-height: 85vh;
  overflow-y: auto;
  width: 100%;
  max-width: 32rem;
}

void-dialog[size="sm"] .void-dialog-panel { max-width: 24rem; }
void-dialog[size="md"] .void-dialog-panel { max-width: 32rem; }
void-dialog[size="lg"] .void-dialog-panel { max-width: 48rem; }
void-dialog[size="xl"] .void-dialog-panel { max-width: 64rem; }

.void-dialog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--void-space-4) var(--void-space-5);
  border-bottom: 1px solid var(--void-color-border);
}

.void-dialog-heading {
  font-family: var(--void-font-sans);
  font-size: var(--void-text-lg);
  font-weight: var(--void-weight-semibold);
  color: var(--void-color-text);
}

.void-dialog-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  border: none;
  border-radius: var(--void-radius-sm);
  background: transparent;
  color: var(--void-color-text-secondary);
  font-size: var(--void-text-lg);
  cursor: pointer;
  opacity: 0.6;
  transition: opacity var(--void-duration-fast) var(--void-ease-in-out);
  flex-shrink: 0;
}

.void-dialog-close:hover {
  opacity: 1;
}

.void-dialog-body {
  padding: var(--void-space-5);
  font-family: var(--void-font-sans);
  font-size: var(--void-text-sm);
  color: var(--void-color-text);
}
