.events-hero {
  background: #f4f1ec;
  border-bottom: 1px solid #ded8cc;
  padding: 2rem 0;
}

.events-hero .container-xxl {
  align-items: center;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}

.events-eyebrow {
  color: #79624d;
  font-size: .85rem;
  font-weight: 700;
  margin-bottom: .35rem;
  text-transform: uppercase;
}

.events-layout,
.event-detail,
.event-form-page,
.performer-detail {
  margin-top: 2rem;
}

.events-filter {
  background: #fff;
  border: 1px solid #ded8cc;
  border-radius: 8px;
  padding: 1rem;
}

.events-filter label {
  font-size: .85rem;
  font-weight: 700;
}

.events-filter input,
.events-filter select {
  width: 100%;
}

.events-toolbar,
.events-calendar-nav {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 1.25rem 0;
}

.events-list {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.event-card {
  border: 1px solid #ded8cc;
  border-radius: 8px;
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
}

.event-card__image {
  aspect-ratio: 16 / 9;
  background: #eee;
  display: block;
}

.event-card__image img,
.event-detail__header img,
.performer-detail header img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.event-card__body {
  padding: 1rem;
}

.event-card__body h2 {
  font-size: 1.15rem;
  margin: .25rem 0;
}

.event-card__date,
.event-card__meta {
  color: #625547;
  font-size: .9rem;
  margin-bottom: .25rem;
}

.events-map {
  border: 1px solid #ded8cc;
  border-radius: 8px;
  height: 640px;
  width: 100%;
}

.events-calendar {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.events-calendar__day {
  background: #fff;
  border: 1px solid #ded8cc;
  min-height: 110px;
  padding: .5rem;
}

.events-calendar__day.is-muted {
  background: #f8f8f8;
  color: #777;
}

.events-calendar__day span {
  display: block;
  font-weight: 700;
  margin-bottom: .35rem;
}

.events-calendar__day a {
  display: block;
  font-size: .85rem;
  line-height: 1.2;
  margin-bottom: .25rem;
}

.events-pagination {
  align-items: center;
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-top: 1.5rem;
}

.event-detail__header {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
}

.event-detail__header img {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
}

.event-detail__grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1fr) 340px;
  margin-top: 2rem;
}

.event-facts {
  border: 1px solid #ded8cc;
  border-radius: 8px;
  padding: 1rem;
}

.event-facts dt {
  color: #625547;
  font-size: .85rem;
  margin-top: .75rem;
}

.event-facts dd {
  margin-bottom: .25rem;
}

.event-report {
  border: 1px solid #ded8cc;
  border-radius: 8px;
  padding: .75rem;
}

.event-report summary {
  cursor: pointer;
  font-weight: 700;
}

.event-report form {
  margin-top: .75rem;
}

.event-report label {
  display: block;
  font-size: .85rem;
  font-weight: 700;
}

.event-report input,
.event-report select,
.event-report textarea {
  width: 100%;
}

.related-events {
  border-top: 1px solid #ded8cc;
  margin-top: 2rem;
  padding-top: 1.5rem;
}

.event-form {
  max-width: 960px;
}

.event-form-section {
  border: 1px solid #ded8cc;
  border-radius: 8px;
  margin-bottom: 1.25rem;
  padding: 1rem;
}

.event-form-section h2 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}

.event-form-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.event-form-full {
  grid-column: 1 / -1;
}

.event-form-grid label {
  font-size: .9rem;
  font-weight: 700;
  margin-bottom: .25rem;
}

.event-form-grid [required] + label::after,
.event-form-grid label:has(+ [required])::after,
.event-form-grid label:has(+ .vSerializedField[required])::after,
.event-form-grid label:has(+ [data-required-when])::after,
.event-form-grid label:has(+ .vSerializedField[data-required-when])::after {
  color: #b02a37;
  content: " *";
}

.event-field-missing,
.event-map-missing {
  border-color: #b02a37 !important;
  box-shadow: 0 0 0 .2rem rgba(176, 42, 55, .18);
}

.event-form-server-errors ul,
.event-form-server-errors li {
  margin-bottom: 0;
}

.event-form-check {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: .45rem;
  justify-self: start;
}

.event-form-check input[type="checkbox"] {
  height: 1.1rem;
  margin: 0;
  width: 1.1rem;
}

.event-map-actions {
  display: flex;
  gap: .45rem;
  flex-wrap: wrap;
}

.event-form-check label {
  margin-bottom: 0;
}

.event-form-help {
  color: #625547;
  font-size: .85rem;
  line-height: 1.35;
  margin: .1rem 0 0;
  max-width: 34rem;
}

.event-form-help.is-hidden {
  display: none;
}

.event-image-preview-wrap {
  margin-top: .75rem;
}

.event-image-preview {
  aspect-ratio: 16 / 9;
  border: 1px solid #ded8cc;
  border-radius: 8px;
  display: block;
  max-width: 320px;
  object-fit: cover;
  width: 100%;
}

.event-image-preview.is-hidden {
  display: none;
}

.event-form-actions {
  display: flex;
  gap: .75rem;
  justify-content: flex-end;
  margin-top: 1rem;
}

.event-location-results {
  display: grid;
  gap: .35rem;
  margin-top: .5rem;
}

.event-location-result {
  background: #fff;
  border: 1px solid #ded8cc;
  border-radius: 6px;
  padding: .5rem .65rem;
  text-align: left;
}

.event-location-result:hover {
  background: #f8f6f1;
}

.event-dashboard-stats,
.event-dashboard-filter,
.event-dashboard-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.event-dashboard-stats {
  margin-bottom: 1rem;
}

.event-dashboard-stats span {
  background: #f8f6f1;
  border: 1px solid #ded8cc;
  border-radius: 6px;
  padding: .4rem .6rem;
}

.event-dashboard-filter {
  margin-bottom: 1rem;
}

.event-dashboard-filter > div {
  min-width: 180px;
}

.event-dashboard-table-wrap {
  overflow-x: auto;
}

.event-dashboard-table td,
.event-dashboard-table th {
  min-width: 120px;
}

#div_id_location {
  height: 520px;
  min-height: 520px;
  position: relative;
}

#div_id_location .osmwidget,
#id_location_map,
#id_location_div_map,
.dj_map_wrapper,
.dj_map {
  height: 520px !important;
  min-height: 520px;
  width: 100% !important;
}

#id_location {
  display: none;
}

.clear_features {
  display: none !important;
}

.event-form-check .errorlist {
  margin-bottom: 0;
}

.performer-detail header {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 180px minmax(0, 1fr);
  margin-bottom: 2rem;
}

.performer-detail header img {
  aspect-ratio: 1;
  border-radius: 8px;
}

@media (max-width: 800px) {
  .events-hero .container-xxl,
  .events-toolbar,
  .events-calendar-nav {
    align-items: flex-start;
    flex-direction: column;
  }

  .event-detail__header,
  .event-detail__grid,
  .performer-detail header,
  .event-form-grid {
    grid-template-columns: 1fr;
  }

  .event-form-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .events-calendar {
    grid-template-columns: 1fr;
  }
}
