/* =============================================================
   EVENTS MANAGER — Paridon Template overrides
   Pracuje s originální HTML strukturou pluginu.
   Načítáno po pluginu → přebíjí via #em-wrapper specificitu.
============================================================= */

#em-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 5rem 2rem;
  color: var(--parchment);
}

/* ── Search bar ─────────────────────────────────────────────── */

/* Rozbalovací wrapper */
#em-wrapper .em-search-collapsible {
  border: 1px solid rgba(196,154,42,0.2);
  margin-bottom: 3rem;
  transition: border-color var(--transition);
}
#em-wrapper .em-search-collapsible[open] {
  border-color: rgba(196,154,42,0.4);
}
#em-wrapper .em-search-collapsible-toggle {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.85rem 1.25rem;
  background: color-mix(in srgb, var(--gold) 6%, var(--dark));
  color: var(--muted);
  font-family: var(--ff-head);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: color var(--transition), background var(--transition);
}
#em-wrapper .em-search-collapsible-toggle::-webkit-details-marker { display: none; }
#em-wrapper .em-search-collapsible-toggle::before {
  content: '▶';
  font-size: 0.5rem;
  color: var(--gold);
  opacity: 0.7;
  transition: transform var(--transition);
  flex-shrink: 0;
}
#em-wrapper .em-search-collapsible[open] .em-search-collapsible-toggle::before {
  transform: rotate(90deg);
}
#em-wrapper .em-search-collapsible-toggle:hover {
  color: var(--gold-light);
  background: color-mix(in srgb, var(--gold) 10%, var(--dark));
}
#em-wrapper .em-search-collapsible[open] .em-search-collapsible-toggle {
  color: var(--parchment);
  border-bottom: 1px solid rgba(196,154,42,0.2);
}

/* Wrapper — přepis plugin CSS proměnných, pozadí transparentní */
#em-wrapper .em-search-form {
  background: transparent;
  border: none;
  margin-bottom: 0;
  padding: 0;
  /* Přepsat plugin CSS proměnné z bílé na tmavou */
  --background-color: var(--ink);
  --background-color-inputs: var(--ink);
  --border-color: rgba(196,154,42,0.2);
  --text-color: var(--parchment);
  --text-color-muted: var(--muted);
}

/* Levá barevná čára — identická s kartou, gold */
#em-wrapper .em-search-form::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--gold);
  opacity: 0.85;
  z-index: 2;
}

#em-wrapper .em-search-main-bar {
  display: flex !important;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0;
  padding: 0 !important;
}

/* Každé pole odděleno stejnou linkou jako okraj karty */
#em-wrapper .em-search-main-bar > div {
  border-right: 1px solid rgba(196,154,42,0.2);
  padding: 0 !important;
}
#em-wrapper .em-search-main-bar > div:last-child { border-right: none; }

/* Textové inputy */
#em-wrapper .em-search-main-bar input[type="text"],
#em-wrapper .em-search-main-bar input[type="date"] {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--parchment) !important;
  font-family: var(--ff-body);
  font-size: 0.9rem;
  padding: 0.9rem 1.1rem !important;
  width: 100%;
  outline: none;
  transition: background var(--transition);
}
#em-wrapper .em-search-main-bar input[type="text"]::placeholder { color: var(--muted); opacity: 1; }
#em-wrapper .em-search-main-bar input[type="text"]:focus,
#em-wrapper .em-search-main-bar input[type="date"]:focus {
  background: rgba(196,154,42,0.06) !important;
}

/* Šíře polí */
#em-wrapper .em-search-text.em-search-field { flex: 2; min-width: 180px; }
#em-wrapper .em-search-geo.em-search-field  { flex: 2; min-width: 160px; }
#em-wrapper .em-search-scope.em-search-field { flex: 2; min-width: 220px; }

/* Datepicker */
#em-wrapper .em-datepicker-data {
  display: flex; align-items: center; padding: 0 !important;
}
#em-wrapper .em-datepicker-data input[type="date"] { flex: 1; color-scheme: dark; }
#em-wrapper .em-datepicker-data .separator {
  font-family: var(--ff-head); font-size: 0.65rem; letter-spacing: 0.1em;
  color: var(--muted); padding: 0 0.4rem; white-space: nowrap; flex-shrink: 0;
}

/* Sort, Views, Advanced — ghost tlačítka stylem karty */
#em-wrapper .em-search-sort,
#em-wrapper .em-search-views,
#em-wrapper .em-search-advanced-trigger,
#em-wrapper .em-search-submit { flex-shrink: 0; }

#em-wrapper .em-search-main-bar button {
  background: transparent !important;
  border: none !important; border-radius: 0 !important; box-shadow: none !important;
  color: var(--muted) !important;
  font-family: var(--ff-head); font-size: 0.65rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 0.9rem 1.1rem !important;
  cursor: pointer; white-space: nowrap;
  display: flex; align-items: center; gap: 0.4rem; height: 100%;
  transition: color var(--transition), background var(--transition);
}
#em-wrapper .em-search-main-bar button:hover {
  color: var(--gold-light) !important;
  background: rgba(196,154,42,0.06) !important;
}
#em-wrapper .em-search-main-bar button.active,
#em-wrapper .em-search-main-bar .checked button { color: var(--gold) !important; }

/* Submit — primary button (přesně jako em-event-book-now) */
#em-wrapper .em-search-submit button {
  color: var(--ink) !important;
  background: var(--gold) !important;
  padding: 0.9rem 1.75rem !important;
  font-size: 0.7rem !important; letter-spacing: 0.25em !important;
  position: relative; overflow: hidden;
}
#em-wrapper .em-search-submit button::before {
  content: ''; position: absolute; inset: 0;
  background: var(--gold-light); transform: translateX(-100%);
  transition: transform 0.4s ease; z-index: 0;
}
#em-wrapper .em-search-submit button:hover { color: var(--ink) !important; background: var(--gold) !important; }
#em-wrapper .em-search-submit button:hover::before { transform: translateX(0); }
#em-wrapper .em-search-submit button > * { position: relative; z-index: 1; }

/* Views dropdown */
#em-wrapper .em-search-views-options {
  background: var(--ink) !important;
  border: 1px solid rgba(196,154,42,0.2) !important;
  border-radius: 0 !important; box-shadow: 0 8px 24px rgba(0,0,0,0.6) !important;
  padding: 0.5rem 0 !important;
}
#em-wrapper .em-search-views-options label {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 1.25rem;
  font-family: var(--ff-head); font-size: 0.65rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--muted); cursor: pointer;
  transition: color var(--transition), background var(--transition);
}
#em-wrapper .em-search-views-options label:hover,
#em-wrapper .em-search-views-options label.checked {
  color: var(--gold); background: rgba(196,154,42,0.06);
}
#em-wrapper .em-search-views-options input[type="radio"] { accent-color: var(--gold); }

/* Responsive */
@media (max-width: 760px) {
  #em-wrapper .em-search-main-bar > div { border-right: none; border-bottom: 1px solid rgba(196,154,42,0.2); }
  #em-wrapper .em-search-main-bar > div:last-child { border-bottom: none; }
  #em-wrapper .em-search-text.em-search-field,
  #em-wrapper .em-search-geo.em-search-field,
  #em-wrapper .em-search-scope.em-search-field { flex: 1 1 100%; }
}

/* ── Seznam ─────────────────────────────────────────────────── */
#em-wrapper .em-list.em-events-list {
  display: flex !important;
  flex-direction: column;
  gap: 1.5rem;
  grid-template-columns: none !important;
}

/* ── Karta ──────────────────────────────────────────────────── */
#em-wrapper .em-list .em-item {
  display: flex !important;
  flex-direction: row;
  align-items: stretch;
  grid-template-columns: none !important;
  position: relative;
  overflow: hidden;
  background: color-mix(in srgb, var(--default-border, var(--gold)) 7%, var(--dark)) !important;
  border: 1px solid rgba(196,154,42,0.2);
  padding: 0 !important;
  transition: border-color var(--transition), background var(--transition);
  cursor: pointer;
}
#em-wrapper .em-list .em-item:first-child { border-top: 1px solid rgba(196,154,42,0.2); }
#em-wrapper .em-list .em-item:hover {
  border-color: rgba(196,154,42,0.5);
  background: color-mix(in srgb, var(--default-border, var(--gold)) 11%, var(--dark)) !important;
}

/* Vertikální čára přes celou výšku karty */
#em-wrapper .em-list .em-item::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: rgba(196,154,42,0.2); /* výchozí: stejná jako okraj */
  transition: background 0.4s ease;
  z-index: 4;
}
#em-wrapper .em-list .em-item:hover::before {
  background: var(--default-border, var(--gold));
  opacity: 0.85;
}

/* ── Obrázek ────────────────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-image {
  flex-shrink: 0;
  width: 280px;
  position: relative;
  overflow: hidden;
  padding: 0 !important;
  min-height: 220px;
}
#em-wrapper .em-list .em-item .em-item-image img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  filter: grayscale(55%) sepia(30%) brightness(0.45);
  transition: transform 0.7s ease, filter 0.55s ease;
  padding: 0 !important;
}
#em-wrapper .em-list .em-item:hover .em-item-image img {
  transform: scale(1.04);
  filter: grayscale(30%) sepia(20%) brightness(0.55);
}
/* Gradient na levé straně — viditelný jen při hoveru */
#em-wrapper .em-list .em-item .em-item-image::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to right,
    color-mix(in srgb, var(--default-border, var(--gold)) 30%, #000) 0%,
    transparent 50%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
}
#em-wrapper .em-list .em-item:hover .em-item-image::after {
  opacity: 1;
}

/* Placeholder */
#em-wrapper .em-list .em-item .em-item-image.has-placeholder {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--default-border, var(--gold)) 12%, #110c06) 0%,
    var(--dark) 100%);
  display: flex; align-items: center; justify-content: center;
}
#em-wrapper .em-list .em-item .em-item-image.has-placeholder::after { display: none; }
#em-wrapper .em-list .em-item .em-item-image-placeholder {
  text-align: center; color: var(--gold); padding: 1rem;
}
#em-wrapper .em-list .em-item .em-item-image-placeholder .day {
  display: block;
  font-family: var(--ff-title); font-size: 3rem; line-height: 1;
}
#em-wrapper .em-list .em-item .em-item-image-placeholder .month {
  display: block;
  font-family: var(--ff-head); font-size: 0.7rem;
  letter-spacing: 0.25em; text-transform: uppercase;
  opacity: 0.75; margin-top: 0.4rem;
}

/* ── Obsah (info panel) ─────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-info {
  flex: 1;
  padding: 2rem 2.5rem 1.75rem 2rem !important;
  border-left: none !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: transparent !important;
  color: var(--parchment);
}

/* ── Nadpis ─────────────────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-info h3.em-item-title {
  font-family: var(--ff-title) !important;
  font-size: clamp(1rem, 1.7vw, 1.45rem) !important;
  font-weight: 400 !important;
  line-height: 1.25 !important;
  color: var(--parchment) !important;
  margin: 0 0 1rem !important;
  padding: 0 !important;
}
#em-wrapper .em-list .em-item .em-item-info h3.em-item-title a {
  color: var(--parchment) !important;
  text-decoration: none !important;
  transition: color var(--transition);
}
#em-wrapper .em-list .em-item .em-item-info h3.em-item-title a:hover {
  color: var(--gold-light) !important;
}

/* ── Meta — pod sebou ───────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-info .em-item-meta {
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  gap: 0.4rem;
  margin-bottom: 1rem !important;
  line-height: normal !important;
}
#em-wrapper .em-list .em-item .em-item-info .em-item-meta > div {
  flex: none !important;
  min-width: 0 !important;
  width: auto !important;
}
#em-wrapper .em-list .em-item .em-item-meta .em-item-meta-line {
  display: flex !important;
  align-items: baseline;
  gap: 0.55rem;
  font-family: var(--ff-body);
  font-size: 0.9rem !important;
  color: var(--parchment2) !important;
  line-height: 1.4 !important;
  margin-bottom: 0 !important;
  grid-template-columns: none !important;
}
#em-wrapper .em-list .em-item .em-item-meta .em-item-meta-line a {
  color: var(--parchment2) !important;
  transition: color var(--transition);
}
#em-wrapper .em-list .em-item .em-item-meta .em-item-meta-line a:hover {
  color: var(--gold) !important;
}
#em-wrapper .em-list .em-item .em-item-meta .em-event-date,
#em-wrapper .em-list .em-item .em-item-meta .em-event-prices {
  color: var(--gold-light) !important;
  font-weight: 500;
}
#em-wrapper .em-list .em-item .em-item-meta .em-icon {
  color: var(--gold) !important;
  opacity: 0.8; flex-shrink: 0;
  width: 1em !important; height: 1em !important;
  background-size: 1em !important;
}

/* Kategorie a tagy */
#em-wrapper .em-list .em-item .em-item-meta .em-item-taxonomy ul {
  list-style: none !important; margin: 0 !important; padding: 0 !important;
  display: flex; flex-wrap: wrap; gap: 0.3rem;
}
#em-wrapper .em-list .em-item .em-item-meta .em-item-taxonomy li { display: contents; }
#em-wrapper .em-list .em-item .em-item-meta .em-item-taxonomy a {
  display: inline-block;
  font-family: var(--ff-head); font-size: 0.62rem !important;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--gold) !important;
  border: 1px solid rgba(196,154,42,0.3);
  background: rgba(196,154,42,0.06);
  padding: 0.15rem 0.65rem;
  transition: var(--transition);
}
#em-wrapper .em-list .em-item:hover .em-item-taxonomy a {
  border-color: rgba(196,154,42,0.5);
}

/* ── Popis ──────────────────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-info .em-item-desc {
  font-size: 0.9rem !important;
  color: var(--parchment2) !important;
  line-height: 1.65 !important;
  margin: 0.25rem 0 1.25rem !important;
  max-width: 640px;
}

/* ── Tlačítka ───────────────────────────────────────────────── */
#em-wrapper .em-list .em-item .em-item-info .em-item-actions {
  display: flex; gap: 0.75rem; flex-wrap: wrap; align-items: center; margin-top: auto;
}
#em-wrapper .em-list .em-item .em-item-info .em-item-actions .button {
  border-radius: 0 !important; font-weight: normal !important; margin-bottom: 0 !important;
}
#em-wrapper .em-item-actions .em-item-read-more {
  font-family: var(--ff-head); font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold) !important; background: transparent !important;
  border: none !important; box-shadow: none !important; padding: 0 !important;
  display: inline-flex; align-items: center; gap: 0.5rem;
  transition: color var(--transition); text-decoration: none;
}
#em-wrapper .em-item-actions .em-item-read-more::after { content: '→'; transition: transform var(--transition); }
#em-wrapper .em-item-actions .em-item-read-more:hover { color: var(--gold-light) !important; }
#em-wrapper .em-item-actions .em-item-read-more:hover::after { transform: translateX(4px); }

#em-wrapper .em-item-actions .em-event-book-now {
  display: inline-flex !important; align-items: center; gap: 0.5rem;
  font-family: var(--ff-head); font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink) !important; background: var(--gold) !important;
  border: 1px solid var(--gold) !important; padding: 0.6rem 1.5rem !important;
  position: relative; overflow: hidden; transition: var(--transition);
  text-decoration: none; border-radius: 0 !important; box-shadow: none !important;
}
#em-wrapper .em-item-actions .em-event-book-now::before {
  content: ''; position: absolute; inset: 0;
  background: var(--gold-light); transform: translateX(-100%);
  transition: transform 0.4s ease; z-index: 0;
}
#em-wrapper .em-item-actions .em-event-book-now:hover { color: var(--ink) !important; }
#em-wrapper .em-item-actions .em-event-book-now:hover::before { transform: translateX(0); }
#em-wrapper .em-item-actions .em-event-book-now > * { position: relative; z-index: 1; }

/* ── Stránkování ────────────────────────────────────────────── */
#em-wrapper .em-pagination {
  display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap; margin-top: 3rem;
}
#em-wrapper .em-pagination a, #em-wrapper .em-pagination span {
  font-family: var(--ff-head); font-size: 0.7rem; letter-spacing: 0.15em;
  padding: 0.5rem 1rem; border: 1px solid var(--border);
  color: var(--parchment2); transition: var(--transition); text-decoration: none;
}
#em-wrapper .em-pagination a:hover, #em-wrapper .em-pagination .current {
  border-color: var(--gold); color: var(--gold-light); background: rgba(196,154,42,0.08);
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 760px) {
  #em-wrapper .em-list .em-item { flex-direction: column !important; }
  #em-wrapper .em-list .em-item .em-item-image {
    width: 100% !important; min-height: 180px; max-height: 220px;
  }
  #em-wrapper .em-list .em-item .em-item-image::after {
    background: linear-gradient(to bottom,
      color-mix(in srgb, var(--default-border, var(--gold)) 30%, #000) 0%,
      transparent 40%);
  }
  #em-wrapper .em-list .em-item::before {
    left: 0; right: 0; top: 0; bottom: auto;
    width: auto; height: 4px;
  }
  #em-wrapper .em-list .em-item .em-item-info {
    padding: 1.25rem 1.5rem 1.5rem !important;
  }
  #em-wrapper { padding: 3rem 1.25rem; }
}
