.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-toggle {
  margin-bottom: .75rem;
}

.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-fill, minmax(260px, 320px));
  justify-content: start;
}

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

.event-card__image {
  aspect-ratio: 3 / 4;
  background: #f4f1ec;
  display: block;
  padding: .5rem;
  position: relative;
}

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

.event-default-card {
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(59, 42, 32, .72), rgba(59, 42, 32, .14)),
    linear-gradient(160deg, #efe5d4 0%, #c9d8c6 48%, #7a9a9a 100%);
  border-radius: 6px;
  color: #fff;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
  min-height: 100%;
  overflow: hidden;
  padding: .85rem;
  position: relative;
  text-shadow: 0 1px 2px rgba(0, 0, 0, .45);
  width: 100%;
}

.event-default-card::before {
  border: 1px solid rgba(255, 255, 255, .45);
  border-radius: 999px;
  content: "";
  height: 9rem;
  opacity: .42;
  position: absolute;
  right: -3rem;
  top: -2.5rem;
  width: 9rem;
}

.event-default-card::after {
  background: rgba(0, 0, 0, .22);
  bottom: 0;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 58%;
}

.event-default-card__type,
.event-default-card__meta {
  position: relative;
  z-index: 1;
}

.event-default-card__type {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.event-default-card__meta {
  display: grid;
  gap: .2rem;
  line-height: 1.2;
}

.event-default-card__meta strong {
  display: block;
  font-size: 1.35rem;
}

.event-default-card--festival {
  background:
    linear-gradient(135deg, rgba(70, 39, 21, .75), rgba(70, 39, 21, .12)),
    linear-gradient(160deg, #f1c27d 0%, #c65d3b 52%, #5d4037 100%);
}

.event-default-card--story_evening {
  background:
    linear-gradient(135deg, rgba(28, 30, 52, .82), rgba(28, 30, 52, .16)),
    linear-gradient(160deg, #2f3a67 0%, #6b5b95 52%, #f0c987 100%);
}

.event-default-card--show {
  background:
    linear-gradient(135deg, rgba(71, 24, 37, .78), rgba(71, 24, 37, .18)),
    linear-gradient(160deg, #872341 0%, #be3144 52%, #f7b267 100%);
}

.event-default-card--walk {
  background:
    linear-gradient(135deg, rgba(34, 68, 45, .78), rgba(34, 68, 45, .14)),
    linear-gradient(160deg, #436850 0%, #88ab8e 52%, #f2f1eb 100%);
}

.event-default-card--conference,
.event-default-card--workshop {
  background:
    linear-gradient(135deg, rgba(47, 79, 79, .8), rgba(47, 79, 79, .14)),
    linear-gradient(160deg, #365486 0%, #7fc7d9 54%, #dcf2f1 100%);
}

.event-default-card--young_audience {
  background:
    linear-gradient(135deg, rgba(96, 53, 93, .75), rgba(96, 53, 93, .14)),
    linear-gradient(160deg, #b0578d 0%, #ffb0b0 52%, #f8f0e5 100%);
}

.event-default-card--fair {
  background:
    linear-gradient(135deg, rgba(88, 64, 42, .76), rgba(88, 64, 42, .16)),
    linear-gradient(160deg, #8b7e74 0%, #c7b7a3 52%, #f1dec9 100%);
}

.event-default-card--online {
  background:
    linear-gradient(135deg, rgba(31, 50, 88, .8), rgba(31, 50, 88, .12)),
    linear-gradient(160deg, #164863 0%, #427d9d 52%, #9bbec8 100%);
}

.event-default-card--undefined,
.event-default-card--other {
  background:
    linear-gradient(135deg, rgba(74, 65, 56, .78), rgba(74, 65, 56, .16)),
    linear-gradient(160deg, #776b5d 0%, #b0a695 52%, #ebe3d5 100%);
}

.event-default-card--detail {
  min-height: 460px;
}

.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.is-past {
  background: #eeeeee;
}

.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-calendar__day a.is-past-event {
  color: #6c5f56;
  text-decoration-style: dotted;
}

.events-calendar__day a.is-past-event em {
  background: #ded8cc;
  border-radius: 4px;
  color: #4f453d;
  display: inline-block;
  font-size: .72rem;
  font-style: normal;
  margin-left: .25rem;
  padding: .05rem .25rem;
}

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

.event-detail__header {
  align-items: start;
  display: grid;
  gap: 1.5rem;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 380px);
}

.event-detail__poster {
  background: #f4f1ec;
  border: 1px solid #ded8cc;
  border-radius: 8px;
  min-height: 360px;
  overflow: hidden;
  padding: .75rem;
}

.event-detail__poster img {
  display: block;
  height: 100%;
  max-height: 620px;
  object-fit: contain;
  width: 100%;
}

.event-poster-button {
  background: transparent;
  border: 0;
  color: inherit;
  cursor: zoom-in;
  display: grid;
  gap: .5rem;
  padding: 0;
  text-align: center;
  width: 100%;
}

.event-poster-button span {
  color: #625547;
  font-size: .85rem;
}

.event-poster-button:hover span,
.event-poster-button:focus span {
  text-decoration: underline;
}

.event-poster-modal .modal-content {
  background: #111;
  color: #fff;
}

.event-poster-modal .modal-header {
  border-color: rgba(255, 255, 255, .16);
}

.event-poster-modal .btn-close {
  filter: invert(1);
}

.event-poster-modal .modal-body {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: 1rem;
}

.event-poster-modal img {
  max-height: calc(100vh - 96px);
  max-width: 100%;
  object-fit: contain;
}

.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-facts__dates {
  list-style: none;
  margin: 0;
  padding: 0;
}

.event-facts__dates li + li {
  margin-top: .45rem;
}

.event-facts__dates span {
  color: #625547;
  font-size: .9rem;
}

.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-extra-dates {
  border-top: 1px solid #ded8cc;
  margin-top: 1rem;
  padding-top: 1rem;
}

.event-extra-dates h3 {
  font-size: 1rem;
  margin-bottom: .75rem;
}

.event-extra-date-row {
  background: #f8f6f1;
  border: 1px solid #ded8cc;
  border-radius: 8px;
  display: grid;
  gap: .75rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: .75rem;
  padding: .75rem;
}

.event-extra-date-remove {
  align-self: end;
}

.event-extra-date-actions {
  align-self: end;
}

.event-extra-date-actions .btn {
  width: 100%;
}

.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,
  .event-extra-date-row {
    grid-template-columns: 1fr;
  }

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

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