/**
 * SHOWS PAGE STYLES
 * ==================
 * Minimal archive/detail list presentation.
 */

.shows-page .page-section {
  align-items: center;
  max-width: 38rem;
  text-align: center;
}

.shows-page__section {
  width: 100%;
  overflow-x: clip;
}

.shows-page .page-heading {
  margin-bottom: var(--margin-lg);
}

.shows-page .page-section::before {
  inset: -8rem 0 auto;
  height: 24rem;
  opacity: 0.75;
}

.shows-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  width: 100%;
  min-width: 0;
  text-align: left;
}

.shows-section[hidden] {
  display: none;
}

.shows-section + .shows-section {
  margin-top: var(--space-2xl);
  padding-top: var(--space-xl);
  border-top: 1px solid color-mix(in srgb, var(--color-muted) 18%, transparent);
}

.shows-section__heading {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-purple-primary);
  text-align: left;
}

.shows-section--past .shows-section__heading {
  color: color-mix(in srgb, var(--color-text-secondary) 72%, var(--color-muted));
}

.shows-section__status {
  margin: 0;
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1.4;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-purple-primary);
}

.shows-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-width: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.shows-list__item {
  display: grid;
  grid-template-columns: minmax(0, 7.5rem) minmax(0, 1fr);
  gap: var(--space-lg);
  align-items: start;
  min-width: 0;
  padding: var(--space-lg) 0;
  border-top: 1px solid color-mix(in srgb, var(--color-muted) 14%, transparent);
}

.shows-list__item--no-image:not(:has(.shows-list__image)),
.shows-list__item:not(:has(.shows-list__image)) {
  grid-template-columns: minmax(0, 1fr);
}

.shows-list__item:first-child {
  border-top: 0;
  padding-top: 0;
}

.shows-list__image {
  display: block;
  width: 100%;
  min-width: 0;
  margin: 0;
}

.shows-list__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  object-fit: cover;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-white) 7%, transparent);
}

.shows-list__placeholder {
  display: grid;
  width: 100%;
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--color-white) 8%, transparent);
  border-radius: var(--radius-sm);
  background:
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--color-bg-elevated) 82%, var(--color-purple-primary)),
      transparent 68%
    ),
    color-mix(in srgb, var(--color-bg-panel) 90%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--color-white) 7%, transparent),
    0 0 18px color-mix(in srgb, var(--color-purple-primary) 8%, transparent);
}

.shows-list__placeholder-mark {
  color: color-mix(in srgb, var(--color-text-secondary) 72%, var(--color-muted));
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.18em;
  line-height: 1;
}

.shows-list__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-width: 0;
}

.shows-list__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35em;
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--font-weight-bold);
  line-height: 1.55;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-purple-primary);
  overflow-wrap: anywhere;
}

.shows-list__meta time {
  color: inherit;
}

.shows-list__title {
  max-width: 34rem;
  margin: 0;
  font-family: var(--font-title);
  font-size: var(--text-lg);
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: var(--color-white);
  overflow-wrap: anywhere;
}

.shows-list__location,
.shows-list__notes {
  max-width: 34rem;
  margin: 0;
  font-family: var(--font-body);
  line-height: 1.7;
  overflow-wrap: anywhere;
}

.shows-list__location {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
}

.shows-list__notes {
  font-size: var(--text-sm);
  color: var(--color-muted);
}

.shows-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  min-width: 0;
  margin-top: var(--space-2xs);
}

.shows-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  max-width: 100%;
  padding: 0.35rem 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--color-text-primary);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.1em;
  line-height: 1.2;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    color var(--transition-base),
    opacity var(--transition-base);
  overflow-wrap: anywhere;
}

.shows-action:hover {
  color: var(--color-purple-primary);
}

.shows-action--map {
  color: var(--color-blue-primary);
}

.shows-action:focus-visible {
  outline: 2px solid var(--color-purple-primary);
  outline-offset: 0.25rem;
  border-radius: var(--radius-sm);
}

.show-detail {
  display: grid;
  gap: 0.7rem;
  max-width: 34rem;
  margin-top: var(--space-xs);
}

.show-detail__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.75rem;
  align-items: start;
}

.show-detail__header--with-image {
  grid-template-columns: 4.5rem minmax(0, 1fr);
}

.show-detail__image {
  width: 100%;
  min-width: 0;
  margin: 0;
}

.show-detail__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  object-fit: cover;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-white) 7%, transparent);
}

.show-detail__summary {
  margin: 0;
  color: var(--color-text-secondary);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.65;
}

.show-detail__facts {
  display: grid;
  gap: 0.48rem;
  margin: 0;
  padding: 0.7rem 0 0;
  border-top: 1px solid color-mix(in srgb, var(--color-muted) 14%, transparent);
}

.show-detail__fact {
  display: grid;
  grid-template-columns: 4.7rem minmax(0, 1fr);
  gap: 0.6rem;
  align-items: baseline;
}

.show-detail__fact-label {
  margin: 0;
  color: var(--color-purple-primary);
  font-family: var(--font-ui);
  font-size: var(--text-2xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.07em;
  line-height: 1.35;
  text-transform: uppercase;
}

.show-detail__fact-value {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 0.55rem;
  align-items: baseline;
  min-width: 0;
  margin: 0;
  color: color-mix(in srgb, var(--color-text-primary) 88%, var(--color-muted));
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.show-detail__linkout {
  display: inline;
  color: color-mix(in srgb, var(--color-text-primary) 88%, var(--color-muted));
  font-weight: var(--font-weight-regular);
  text-decoration: none;
  text-decoration-color: transparent;
  text-underline-offset: 0.16em;
  white-space: normal;
  overflow-wrap: anywhere;
}

.show-detail__linkout:hover,
.show-detail__linkout:focus-visible {
  color: color-mix(in srgb, var(--color-purple-primary) 82%, var(--color-white));
}

.show-detail__linkout-text {
  text-decoration: none;
  text-decoration-color: currentColor;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
}

.show-detail__linkout:hover .show-detail__linkout-text,
.show-detail__linkout:focus-visible .show-detail__linkout-text {
  text-decoration-line: underline;
}

.show-detail__linkout-tail {
  white-space: nowrap;
}

.show-detail__fact-main {
  color: color-mix(in srgb, var(--color-text-primary) 88%, var(--color-muted));
}

.show-detail__fact-note {
  flex-basis: 100%;
  color: color-mix(in srgb, var(--color-text-secondary) 78%, var(--color-muted));
}

.show-detail__mini-action--map {
  display: inline;
  line-height: 1.45;
  white-space: normal;
}

.show-detail__linkout-icon {
  display: inline-block;
  margin-left: 0.22rem;
  font-size: 0.78rem;
  line-height: 1;
  vertical-align: -0.08em;
}

.shows-section--past .shows-list__item {
  opacity: 0.74;
}

.shows-section--past .shows-list__title {
  color: color-mix(in srgb, var(--color-text-primary) 82%, var(--color-muted));
}

.shows-section--past .shows-list__location,
.shows-section--past .shows-list__price,
.shows-section--past .shows-list__description,
.shows-section--past .shows-list__notes {
  color: color-mix(in srgb, var(--color-text-secondary) 75%, var(--color-muted));
}

@media (max-width: 40rem) {
  .shows-page .page-heading {
    margin-bottom: var(--space-lg);
  }

  .shows-section + .shows-section {
    margin-top: var(--space-xl);
    padding-top: var(--space-lg);
  }

  .shows-list__item {
    grid-template-columns: 4.5rem minmax(0, 1fr);
    gap: var(--space-md);
    padding-block: var(--space-md);
  }

  .shows-list__title {
    font-size: var(--text-base);
  }

  .shows-list__location,
  .show-detail__summary,
  .show-detail__fact-value {
    font-size: var(--text-sm);
  }

  .show-detail__header--with-image {
    grid-template-columns: 3.8rem minmax(0, 1fr);
  }

  .show-detail__fact {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.1rem;
  }
}
