/**
 * Events Module Styles
 * Styles for event cards and blocks
 * 
 * @package ZavcodeAkademiaModules
 * @subpackage Events
 */

/* Event Card Wrapper */
.zavcode-event-card-wrapper {
  display: block !important;
}

/* Event Card */
.zavcode-event-card {
  background: #ffffff !important;
  border-radius: 8px !important;
  border: 1px solid #e0e0e0 !important;
  padding: 24px !important;
  margin-bottom: 0 !important;
  display: block !important;
  text-decoration: none !important;
  color: inherit !important;
}

.zavcode-event-card:hover {
  box-shadow: none !important;
}

.zavcode-event-card-clickable {
  cursor: pointer !important;
}

.zavcode-event-card-clickable:hover {
  text-decoration: none !important;
  color: inherit !important;
}

.zavcode-event-card-content {
  width: 100% !important;
}

/* Card Header - Three Column Layout matching Figma */
.zavcode-event-card-header {
  display: flex !important;
  align-items: flex-start !important;
  gap: 16px !important;
  margin-bottom: 0 !important;
  width: 100% !important;
}

.zavcode-event-card-title-col {
  flex: 1 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}

.zavcode-event-card-location-col {
  width: 110px !important;
  flex-shrink: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

.zavcode-event-card-date-col {
  width: 110px !important;
  flex-shrink: 0 !important;
}

.zavcode-event-card-meta-col {
  flex-shrink: 0 !important;
  text-align: right !important;
  min-width: 150px !important;
}

/* Event Title */
.zavcode-event-card-title {
  font-family: 'Roboto', sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  color: #000000 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Tags Wrapper */
.zavcode-event-card-tags-wrapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

/* Location Lines - Each part on separate line */
.zavcode-event-card-location-line {
  font-family: 'Roboto', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  color: #000000 !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: pre-wrap !important;
}

/* Date */
.zavcode-event-card-date {
  font-family: 'Roboto', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  color: #000000 !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: pre-wrap !important;
}

/* Location and Date - Legacy */
.zavcode-event-card-location {
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  margin: 0 !important;
  padding: 0 !important;
  margin-bottom: 4px !important;
}

/* Distance Tags */
.zavcode-event-card-distances {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin: 0 !important;
}

.zavcode-event-distance-tag {
  display: inline-block !important;
  background-color: #f3f3f3 !important;
  color: #000000 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 4px 8px !important;
  border-radius: 44px !important;
  height: 24px !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.zavcode-event-distance-tag-more {
  background-color: transparent !important;
  color: #000000 !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 4px 8px !important;
}

/* Academy Recommended Banner */
.zavcode-event-card-recommended-banner {
  background: #000000 !important;
  color: #ffffff !important;
  text-align: center !important;
  padding: 4px 12px !important;
  border-radius: 8px 8px 0 0 !important;
  border: 1px solid #000000 !important;
  border-bottom: none !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 0.8 !important;
  height: 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 0 !important;
}

.zavcode-event-card-wrapper-recommended {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* Academy Recommended Card Styles */
.zavcode-event-card-recommended {
  background: #fff7e8 !important;
  border: 1px solid #e0e0e0 !important;
  border-top: none !important;
  border-radius: 0 0 8px 8px !important;
}

.zavcode-event-card-recommended:hover {
  box-shadow: none !important;
}

/* Academy Recommended Distance Tags */
.zavcode-event-distance-tag-recommended {
  background-color: #ffdd8d !important;
  color: #000000 !important;
}

.zavcode-event-card-disciplines {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin: 0 !important;
}

.zavcode-event-discipline-tag {
  display: inline-block !important;
  background-color: #eef6ff !important;
  color: #0b3c80 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 4px 8px !important;
  border-radius: 44px !important;
  height: 24px !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Events List Container - Always vertical layout */
.zavcode-events-list-container {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  width: 100% !important;
}

/* List Headers - Column Headers matching Figma */
.zavcode-events-list-headers {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 0px !important;
  margin-bottom: 0 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  color: #000000 !important;
  opacity: 0.45 !important;
}

.zavcode-events-list-header-details {
  flex: 1 !important;
  min-width: 0 !important;
}

.zavcode-events-list-header-location {
  width: 110px !important;
  flex-shrink: 0 !important;
}

.zavcode-events-list-header-date {
  width: 140px !important;
  flex-shrink: 0 !important;
}

/* Events List Container - Always vertical layout */
.zavcode-events-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  width: 100% !important;
}

/* Block Container */
.zavcode-events-block-container {
  width: 100% !important;
  padding: 0 !important;
  overflow: visible !important;
}

/* ============================================
   Event Filters - CSS Reset & Theme Protection
   Prevents WordPress theme styles from overriding
   Uses ID selectors for maximum specificity
   ============================================ */

/* ID-based selectors - HIGHEST SPECIFICITY to override ANY theme */
#zavcode-events-filters-form {
  margin: 0 0 32px 0 !important;
  padding: 0 !important;
  width: 100% !important;
  display: block !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  box-sizing: border-box !important;
}

#zavcode-events-filters-form * {
  box-sizing: border-box !important;
}

/* Search input - ID selector */
#event_name,
#zavcode-events-filters-form #event_name,
#zavcode-events-filters-form input#event_name {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding: 12px 40px 12px 48px !important;
  margin: 0 !important;
  background-color: #f5f5f5 !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  outline: none !important;
  display: block !important;
}

#event_name:focus,
#zavcode-events-filters-form #event_name:focus {
  background-color: #ffffff !important;
  border-color: #000000 !important;
  outline: none !important;
  box-shadow: none !important;
}

#event_name::placeholder {
  color: #666666 !important;
  opacity: 1 !important;
}

/* Date input - ID selector */
#event_date,
#zavcode-events-filters-form #event_date,
#zavcode-events-filters-form input#event_date {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding: 12px 40px 12px 60px !important;
  margin: 0 !important;
  background-color: #f5f5f5 !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  outline: none !important;
  display: block !important;
  color-scheme: light !important;
}

#event_date:focus,
#zavcode-events-filters-form #event_date:focus {
  background-color: #ffffff !important;
  border-color: #000000 !important;
  outline: none !important;
  box-shadow: none !important;
}

#event_date::placeholder {
  color: #666666 !important;
  opacity: 1 !important;
}

/* Multiselect trigger - ID selector */
#event_location_trigger,
#event_discipline_trigger,
#event_distance_trigger,
#zavcode-events-filters-form #event_location_trigger,
#zavcode-events-filters-form #event_discipline_trigger,
#zavcode-events-filters-form #event_distance_trigger,
#zavcode-events-filters-form button#event_location_trigger,
#zavcode-events-filters-form button#event_discipline_trigger,
#zavcode-events-filters-form button#event_distance_trigger {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding: 12px 75px 12px 16px !important;
  margin: 0 !important;
  background-color: #f5f5f5 !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  outline: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  cursor: pointer !important;
  text-align: left !important;
  position: relative !important;
}

#event_location_trigger:hover,
#event_discipline_trigger:hover,
#event_distance_trigger:hover,
#zavcode-events-filters-form #event_location_trigger:hover,
#zavcode-events-filters-form #event_discipline_trigger:hover,
#zavcode-events-filters-form #event_distance_trigger:hover {
  background-color: #f0f0f0 !important;
  border-color: #d0d0d0 !important;
}

#event_location_trigger:focus,
#event_discipline_trigger:focus,
#event_distance_trigger:focus,
#zavcode-events-filters-form #event_location_trigger:focus,
#zavcode-events-filters-form #event_discipline_trigger:focus,
#zavcode-events-filters-form #event_distance_trigger:focus {
  background-color: #ffffff !important;
  border-color: #000000 !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Search icon positioning - ID context */
#zavcode-events-filters-form .zavcode-events-filter-search-icon {
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
  color: #666666 !important;
  fill: none !important;
  pointer-events: none !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  background: transparent !important;
  border: none !important;
}

#zavcode-events-filters-form .zavcode-events-filter-search-icon path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Date label positioning - ID context */
#zavcode-events-filters-form .zavcode-events-filter-label {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #000000 !important;
  pointer-events: none !important;
  z-index: 2 !important;
  background-color: #f5f5f5 !important;
  padding: 0 4px !important;
  margin: 0 !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
}

/* Chevron icon positioning - ID context */
#zavcode-events-filters-form .zavcode-events-filter-chevron {
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  color: #666666 !important;
  fill: none !important;
  pointer-events: none !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  background: transparent !important;
  border: none !important;
}

#zavcode-events-filters-form .zavcode-events-filter-chevron path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Input wrapper positioning - ID context */
#zavcode-events-filters-form .zavcode-events-filter-input-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Reset all filter form elements to prevent theme interference */
.zavcode-events-filters,
.zavcode-events-filters *,
.zavcode-events-filters *::before,
.zavcode-events-filters *::after {
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  outline: none !important;
  background: transparent !important;
  font-family: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
  text-decoration: none !important;
  vertical-align: baseline !important;
}

/* Re-apply base styles after reset */
.zavcode-events-filters {
  margin: 0 0 32px 0 !important;
  padding: 0 !important;
  width: 100% !important;
  display: block !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.zavcode-events-filters-container {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  align-items: flex-start !important;
  flex-wrap: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.zavcode-events-filters-row {
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.zavcode-events-filter-field {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  position: relative !important;
  z-index: 1 !important;
}

.zavcode-events-filter-field.zavcode-events-filter-search {
  flex: 1 1 100% !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
}

.zavcode-events-filter-field.zavcode-events-filter-date {
  flex: 1 1 0 !important;
  min-width: 140px !important;
}

.zavcode-events-filter-field.zavcode-events-filter-voivodeship,
.zavcode-events-filter-field.zavcode-events-filter-discipline,
.zavcode-events-filter-field.zavcode-events-filter-distance {
  flex: 1 1 0 !important;
  min-width: 140px !important;
}

.zavcode-events-filter-field.zavcode-events-filter-discipline {
  flex: 1 1 0 !important;
  min-width: 140px !important;
}

.zavcode-events-filter-field.zavcode-events-filter-distance {
  flex: 1 1 0 !important;
  min-width: 140px !important;
}

.zavcode-events-filter-input-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Base input styles - use individual padding properties for better override control */
.zavcode-events-filters .zavcode-events-filter-input,
.zavcode-events-filter-input,
input.zavcode-events-filter-input,
button.zavcode-events-filter-input {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding-top: 12px !important;
  padding-right: 40px !important;
  padding-bottom: 12px !important;
  padding-left: 16px !important;
  margin: 0 !important;
  background-color: #f5f5f5 !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  transition:
    background-color 0.2s ease,
    border-color 0.2s ease !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  text-indent: 0 !important;
  text-shadow: none !important;
  display: block !important;
  float: none !important;
  clear: none !important;
}

/* Clear Button */
.zavcode-events-filters .zavcode-events-filter-clear,
.zavcode-events-filter-clear {
  position: absolute !important;
  right: 27px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  color: #666666 !important;
  transition: all 0.2s ease !important;
  z-index: 5 !important;
  pointer-events: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  text-decoration: none !important;
  float: none !important;
}

.zavcode-events-filters .zavcode-events-filter-clear svg,
.zavcode-events-filter-clear svg {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px !important;
  min-height: 14px !important;
  max-width: 14px !important;
  max-height: 14px !important;
  color: currentColor !important;
  fill: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.zavcode-events-filters .zavcode-events-filter-clear svg path,
.zavcode-events-filter-clear svg path {
  stroke: currentColor !important;
  fill: none !important;
}

.zavcode-events-filters .zavcode-events-filter-clear:hover,
.zavcode-events-filter-clear:hover {
  background-color: #e0e0e0 !important;
  color: #000000 !important;
}

.zavcode-events-filters .zavcode-events-filter-clear:focus,
.zavcode-events-filter-clear:focus {
  outline: none !important;
  background-color: #d0d0d0 !important;
  color: #000000 !important;
  box-shadow: none !important;
}

/* Clear button for date input */
.zavcode-events-filters .zavcode-events-filter-clear-date,
.zavcode-events-filter-clear-date {
  right: 25px !important; /* Positioned at the right edge since chevron is hidden when clear is visible */
  z-index: 15 !important; /* Higher than flatpickr elements */
}

/* Clear button for multiselect */
.zavcode-events-filters
  .zavcode-events-multiselect-trigger
  .zavcode-events-filter-clear-multiselect,
.zavcode-events-multiselect-trigger .zavcode-events-filter-clear-multiselect {
  position: absolute !important;
  right: 45px !important; /* Make space for chevron */
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 5 !important;
}

/* Adjust input padding when clear button is present - high specificity */
.zavcode-events-filter-input-wrapper:has(.zavcode-events-filter-clear)
  input.zavcode-events-filter-input-search,
.zavcode-events-filter-input-wrapper.has-clear
  input.zavcode-events-filter-input-search,
input.zavcode-events-filter-input-search.has-clear {
  padding-right: 70px !important;
}

.zavcode-events-filter-input-wrapper:has(.zavcode-events-filter-clear-date)
  input.zavcode-events-filter-input-date,
.zavcode-events-filter-input-wrapper.has-clear-date
  input.zavcode-events-filter-input-date,
input.zavcode-events-filter-input-date.has-clear {
  padding-right: 55px !important;
}

.zavcode-events-filters .zavcode-events-filter-input:focus,
.zavcode-events-filter-input:focus {
  outline: none !important;
  background-color: #ffffff !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

.zavcode-events-filters .zavcode-events-filter-input:hover,
.zavcode-events-filter-input:hover {
  background-color: #f0f0f0 !important;
  border-color: #d0d0d0 !important;
}

.zavcode-events-filters .zavcode-events-filter-input::placeholder,
.zavcode-events-filter-input::placeholder {
  color: #666666 !important;
  opacity: 1 !important;
  font-weight: 400 !important;
}

/* Search Input - High specificity to override theme */
.zavcode-events-filters
  .zavcode-events-filter-search
  .zavcode-events-filter-input-wrapper,
.zavcode-events-filter-search .zavcode-events-filter-input-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}

.zavcode-events-filters
  .zavcode-events-filter-search
  .zavcode-events-filter-search-icon,
.zavcode-events-filter-search .zavcode-events-filter-search-icon,
.zavcode-events-filter-search-icon {
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  max-width: 20px !important;
  max-height: 20px !important;
  color: #666666 !important;
  fill: none !important;
  pointer-events: none !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  flex-shrink: 0 !important;
  background: transparent !important;
  border: none !important;
}

.zavcode-events-filters .zavcode-events-filter-search-icon path,
.zavcode-events-filter-search-icon path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Search input with left padding for icon - highest specificity */
.zavcode-events-filters
  .zavcode-events-filter-search
  .zavcode-events-filter-input-wrapper
  input.zavcode-events-filter-input-search,
.zavcode-events-filters
  .zavcode-events-filter-search
  input.zavcode-events-filter-input-search,
.zavcode-events-filters input.zavcode-events-filter-input-search,
.zavcode-events-filter-search input.zavcode-events-filter-input-search,
input.zavcode-events-filter-input-search,
.zavcode-events-filter-input-search {
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding-top: 12px !important;
  padding-right: 40px !important;
  padding-bottom: 12px !important;
  padding-left: 48px !important;
}

/* Date Input */
.zavcode-events-filter-date .zavcode-events-filter-input-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.zavcode-events-filters
  .zavcode-events-filter-date
  .zavcode-events-filter-chevron,
.zavcode-events-filter-date .zavcode-events-filter-chevron {
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  pointer-events: none !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide chevron when clear button is visible */
.zavcode-events-filter-date:has(
    .zavcode-events-filter-clear-date[style*='flex']
  )
  .zavcode-events-filter-chevron,
.zavcode-events-filter-date.has-clear-date .zavcode-events-filter-chevron {
  display: none !important;
}

.zavcode-events-filters .zavcode-events-filter-label,
.zavcode-events-filter-label {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #000000 !important;
  pointer-events: none !important;
  z-index: 2 !important;
  background-color: #f5f5f5 !important;
  padding: 0 3px !important;
  margin: 0 !important;
  transition: background-color 0.2s ease !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
}

.zavcode-events-filter-input-date:focus + .zavcode-events-filter-label,
.zavcode-events-filter-input-date:not(:placeholder-shown)
  + .zavcode-events-filter-label,
.zavcode-events-filter-input-date[value]:not([value=''])
  + .zavcode-events-filter-label {
  background-color: #ffffff !important;
}

/* Date input with left padding for label - highest specificity */
.zavcode-events-filters
  .zavcode-events-filter-date
  .zavcode-events-filter-input-wrapper
  input.zavcode-events-filter-input-date,
.zavcode-events-filters
  .zavcode-events-filter-date
  input.zavcode-events-filter-input-date,
.zavcode-events-filters input.zavcode-events-filter-input-date,
.zavcode-events-filter-date input.zavcode-events-filter-input-date,
input.zavcode-events-filter-input-date,
.zavcode-events-filter-input-date {
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  padding-top: 12px !important;
  padding-right: 40px !important;
  padding-bottom: 12px !important;
  padding-left: 60px !important;
  color-scheme: light !important;
}

/* Flatpickr Date Picker Customization */
.flatpickr-calendar {
  font-family: inherit !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  border: 1px solid #e0e0e0 !important;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: #000000 !important;
  border-color: #000000 !important;
  color: #ffffff !important;
}

.flatpickr-day.inRange {
  background: #f5f5f5 !important;
  border-color: #f5f5f5 !important;
  color: #000000 !important;
}

.flatpickr-day:hover {
  background: #f0f0f0 !important;
  border-color: #f0f0f0 !important;
}

.flatpickr-day.today {
  border-color: #000000 !important;
}

.flatpickr-day.today:hover {
  background: #f0f0f0 !important;
  border-color: #000000 !important;
}

.zavcode-events-filters .zavcode-events-filter-chevron,
.zavcode-events-filter-chevron {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  color: #666666 !important;
  fill: none !important;
  pointer-events: none !important;
  flex-shrink: 0 !important;
  transition: transform 0.2s ease !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.zavcode-events-filters .zavcode-events-filter-chevron path,
.zavcode-events-filter-chevron path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Multi-Select */
.zavcode-events-filters .zavcode-events-multiselect-wrapper,
.zavcode-events-multiselect-wrapper {
  position: relative !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.zavcode-events-filters .zavcode-events-multiselect-trigger,
.zavcode-events-multiselect-trigger,
button.zavcode-events-multiselect-trigger {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  text-align: left !important;
  cursor: pointer !important;
  position: relative !important;
  border: 1px solid #e0e0e0 !important;
  background-color: #f5f5f5 !important;
  border-radius: 8px !important;
  padding-top: 12px !important;
  padding-right: 75px !important; /* More space for clear button + chevron */
  padding-bottom: 12px !important;
  padding-left: 16px !important;
  margin: 0 !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #000000 !important;
  transition:
    background-color 0.2s ease,
    border-color 0.2s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  z-index: 1 !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
}

.zavcode-events-filters .zavcode-events-multiselect-trigger:hover,
.zavcode-events-multiselect-trigger:hover {
  background-color: #f0f0f0 !important;
  border-color: #d0d0d0 !important;
}

.zavcode-events-filters .zavcode-events-multiselect-trigger:focus,
.zavcode-events-multiselect-trigger:focus {
  outline: none !important;
  background-color: #ffffff !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

.zavcode-events-multiselect-trigger[aria-expanded='true'] {
  background-color: #ffffff !important;
  border-color: #000000 !important;
}

.zavcode-events-multiselect-trigger[aria-expanded='true']
  .zavcode-events-filter-chevron {
  transform: rotate(180deg) !important;
}

.zavcode-events-filters
  .zavcode-events-multiselect-trigger
  .zavcode-events-filter-chevron,
.zavcode-events-multiselect-trigger .zavcode-events-filter-chevron {
  position: absolute !important;
  right: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  pointer-events: none !important;
  z-index: 2 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide chevron when clear button is visible */
.zavcode-events-multiselect-trigger:has(
    .zavcode-events-filter-clear-multiselect[style*='flex']
  )
  .zavcode-events-filter-chevron,
.zavcode-events-multiselect-trigger.has-clear-multiselect
  .zavcode-events-filter-chevron {
  display: none !important;
}

.zavcode-events-multiselect-trigger[aria-expanded='true']
  .zavcode-events-filter-chevron {
  transform: translateY(-50%) rotate(180deg) !important;
}

.zavcode-events-filters .zavcode-events-multiselect-label,
.zavcode-events-multiselect-label {
  flex: 1 !important;
  text-align: left !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #000000 !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.zavcode-events-filters .zavcode-events-multiselect-dropdown,
.zavcode-events-multiselect-dropdown {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  min-width: calc(100% + 60px) !important;
  width: calc(100% + 60px) !important;
  margin: 4px 0 0 0 !important;
  padding: 8px 0 !important;
  background-color: #ffffff !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  max-height: 300px !important;
  overflow-y: auto !important;
  z-index: 99999 !important;
  display: none !important;
  box-sizing: border-box !important;
}

.zavcode-events-multiselect-dropdown.open {
  display: block !important;
}

.zavcode-events-filters .zavcode-events-multiselect-option,
.zavcode-events-multiselect-option {
  display: flex !important;
  align-items: center !important;
  padding: 10px 16px !important;
  margin: 0 !important;
  cursor: pointer !important;
  transition: background-color 0.2s ease !important;
  gap: 12px !important;
  background-color: transparent !important;
  border: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.zavcode-events-filters .zavcode-events-multiselect-option:hover,
.zavcode-events-multiselect-option:hover {
  background-color: #f5f5f5 !important;
}

.zavcode-events-filters .zavcode-events-multiselect-checkbox,
.zavcode-events-multiselect-checkbox {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  cursor: pointer !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  border: 1px solid #d0d0d0 !important;
  border-radius: 4px !important;
  background-color: #ffffff !important;
  position: relative !important;
  flex-shrink: 0 !important;
  transition: all 0.2s ease !important;
  box-shadow: none !important;
  outline: none !important;
}

.zavcode-events-filters .zavcode-events-multiselect-checkbox:checked,
.zavcode-events-multiselect-checkbox:checked {
  background-color: #000000 !important;
  border-color: #000000 !important;
}

.zavcode-events-filters .zavcode-events-multiselect-checkbox:checked::after,
.zavcode-events-multiselect-checkbox:checked::after {
  content: '' !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 12px !important;
  height: 12px !important;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 6L5 9L10 2' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-color: transparent !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.zavcode-events-filters .zavcode-events-multiselect-option-text,
.zavcode-events-multiselect-option-text {
  flex: 1 !important;
  font-family:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu,
    Cantarell, 'Helvetica Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #000000 !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
}

.zavcode-events-multiselect-hidden-input {
  display: none !important;
}

/* Hierarchical location options - indent children */
.zavcode-events-filters
  .zavcode-events-multiselect-option.zavcode-events-multiselect-option-child,
.zavcode-events-multiselect-option.zavcode-events-multiselect-option-child {
  padding-left: 32px !important;
}

/* Screen Reader Text */
.zavcode-events-filters .screen-reader-text,
.screen-reader-text {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border-width: 0 !important;
  border: none !important;
}

.zavcode-events-block-container.alignwide {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.zavcode-events-block-container.alignfull {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* No Events Message */
.zavcode-events-no-events {
  text-align: center !important;
  padding: 40px 20px !important;
  color: #666666 !important;
  font-size: 16px !important;
}

/* Pagination */
.zavcode-events-pagination {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  margin-top: 40px !important;
  padding: 0 !important;
  list-style: none !important;
  background-color: #f7f7f7 !important;
  border-radius: 0 !important;
  width: 100% !important;
  max-width: fit-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.zavcode-events-pagination-arrow {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  background-color: #ffffff !important;
  color: #000000 !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  transition:
    background-color 0.2s ease,
    color 0.2s ease !important;
  border: none !important;
  cursor: pointer !important;
}

.zavcode-events-pagination-arrow:hover {
  background-color: #f0f0f0 !important;
  color: #000000 !important;
  text-decoration: none !important;
}

.zavcode-events-pagination-arrow.zavcode-events-pagination-disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  background-color: #ffffff !important;
}

.zavcode-events-pagination-numbers {
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
}

.zavcode-events-pagination-number {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 40px !important;
  height: 40px !important;
  padding: 0 12px !important;
  background-color: transparent !important;
  color: #000000 !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  transition:
    background-color 0.2s ease,
    color 0.2s ease !important;
  border: none !important;
  cursor: pointer !important;
}

.zavcode-events-pagination-number:hover {
  background-color: transparent !important;
  color: #000000 !important;
  text-decoration: none !important;
}

.zavcode-events-pagination-number.zavcode-events-pagination-current {
  background-color: #ffffff !important;
  color: #000000 !important;
  font-weight: 400 !important;
  cursor: default !important;
  pointer-events: none !important;
}

.zavcode-events-pagination-ellipsis {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 40px !important;
  height: 40px !important;
  padding: 0 8px !important;
  color: #000000 !important;
  font-size: 16px !important;
  line-height: 1 !important;
  background-color: transparent !important;
}

/* Mobile Responsive Adjustments */
@media (max-width: 767px) {
  /* Hide column headers on mobile */
  .zavcode-events-list-headers {
    display: none !important;
  }

  .zavcode-event-card-header {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .zavcode-event-card-title-col {
    width: 100% !important;
  }

  .zavcode-event-card-location-col {
    width: 100% !important;
  }

  .zavcode-event-card-date-col {
    width: 100% !important;
  }

  .zavcode-event-card-meta-col {
    text-align: left !important;
    width: 100% !important;
    min-width: auto !important;
  }

  .zavcode-event-card-title {
    font-size: 16px !important;
  }

  .zavcode-event-card-location-line,
  .zavcode-event-card-date {
    font-size: 14px !important;
  }

  .zavcode-event-card {
    padding: 16px !important;
  }

  .zavcode-events-pagination {
    gap: 0 !important;
    margin-top: 30px !important;
  }

  .zavcode-events-pagination-arrow,
  .zavcode-events-pagination-number {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    font-size: 14px !important;
  }

  .zavcode-events-pagination-numbers {
    gap: 0 !important;
  }

  /* Filter Responsive */
  .zavcode-events-filters-container,
  .zavcode-events-filters-row {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .zavcode-events-filters-row {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
  }

  .zavcode-events-filter-field,
  .zavcode-events-filters .zavcode-events-filter-field {
    flex: 1 1 calc(50% - 6px) !important;
    min-width: calc(50% - 6px) !important;
    max-width: calc(50% - 6px) !important;
    width: calc(50% - 6px) !important;
  }

  /* Search stays full width */
  .zavcode-events-filter-field.zavcode-events-filter-search {
    flex: 1 1 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  .zavcode-events-filter-input,
  .zavcode-events-filters .zavcode-events-filter-input {
    font-size: 16px !important; /* Prevent zoom on iOS */
  }

  .zavcode-events-filters .zavcode-events-multiselect-dropdown,
  .zavcode-events-multiselect-dropdown {
    min-width: 100% !important;
    width: 100% !important;
  }
}

/* ============================================
   Single Event Page Styles
   ============================================ */

/* Main Container */
.zavcode-single-event {
  width: 100% !important;
}

.zavcode-single-event-container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* Breadcrumb - Pixel Perfect from Figma */
.zavcode-single-event-breadcrumb {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  opacity: 0.4 !important;
  margin-bottom: 30px !important;
  margin-top: 9px !important;
}

.zavcode-single-event-breadcrumb-item {
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: normal !important;
  color: #727272 !important;
  text-decoration: none !important;
}

.zavcode-single-event-breadcrumb-item:hover {
  text-decoration: underline !important;
}

.zavcode-single-event-breadcrumb-separator {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #727272 !important;
  font-size: 10px !important;
  line-height: 1 !important;
}

/* H1 Title - Pixel Perfect from Figma: Roboto Medium 32px */
.zavcode-single-event-title {
  font-family: 'Roboto', sans-serif !important;
  font-size: 32px !important;
  font-weight: 500 !important;
  line-height: normal !important;
  color: #000000 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Two Column Layout - starts from top */
.zavcode-single-event-layout {
  width: 100% !important;
}

.zavcode-single-event-columns {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 372px !important;
  gap: 40px !important;
  align-items: start !important;
  width: 100% !important;
  background-color: #ffffff !important;
  padding-bottom: 30px !important;
}

.zavcode-single-event-main-content {
  min-width: 0 !important; /* Prevents overflow */
  width: 100% !important;
  padding: 16px 0px 0px 45px !important;
}

.zavcode-single-event-sidebar {
  position: sticky !important;
  top: 20px !important;
  width: 372px !important;
  flex-shrink: 0 !important;
  padding-top: 72px !important;
  padding-right: 16px !important;
}

/* Header section (inside column) */
.zavcode-single-event-header-section {
  padding: 0 0 16px !important;
  background-color: #ffffff !important;
}

/* Banner section (inside column) - using theme classes */
.zavcode-single-event-banner-section {
  padding: 0 0 24px !important;
  background-color: #ffffff !important;
}

.zavcode-single-event-banner-section .tdb-block-inner {
  position: relative !important;
}

.zavcode-single-event-banner-section .td-fix-index {
  display: block !important;
}

.zavcode-single-event-banner-section .td-modal-image {
  display: block !important;
  cursor: zoom-in !important;
}

.zavcode-single-event-banner-section .entry-thumb {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

/* Details Section (inside column, next to sidebar) */
.zavcode-single-event-details-section {
  padding: 0 0 40px !important;
  background-color: #ffffff !important;
}

/* Details Table Container - Pixel Perfect from Figma */
.zavcode-single-event-details {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  background-color: #ffffff !important;
  border-radius: 8px !important;
  padding: 0 !important;
  border: 1px solid #e0e0e0 !important;
  overflow: hidden !important;
}

/* Event Logo */
.zavcode-single-event-logo {
  max-width: 200px !important;
  padding: 16px !important;
  border-bottom: 1px solid #e0e0e0 !important;
}

.zavcode-single-event-logo-img {
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* Details Table Row - Pixel Perfect from Figma */
.zavcode-single-event-table-row {
  display: flex !important;
  align-items: center !important;
  padding: 16px !important;
  border-bottom: 1px solid #e0e0e0 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.4 !important;
  color: #000000 !important;
}

.zavcode-single-event-table-row:last-child {
  border-bottom: none !important;
}

.zavcode-single-event-table-row.zavcode-single-event-distances-row {
  align-items: flex-start !important;
}

.zavcode-single-event-table-label {
  width: 140px !important;
  flex-shrink: 0 !important;
  font-weight: 500 !important;
  white-space: pre-wrap !important;
}

.zavcode-single-event-table-value {
  font-weight: 400 !important;
  flex: 1 !important;
}

/* Distance Tags - Pixel Perfect from Figma */
.zavcode-single-event-distances {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  align-items: center !important;
  align-content: center !important;
  flex: 1 !important;
}

.zavcode-single-event-distance-tag {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background-color: #f3f3f3 !important;
  color: #000000 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  height: 24px !important;
  padding: 4px 8px !important;
  border-radius: 44px !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
}

/* Cycles Row - Similar to Distances */
.zavcode-single-event-cycles-row {
  align-items: flex-start !important;
}

.zavcode-single-event-cycles {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  align-items: center !important;
  align-content: center !important;
  flex: 1 !important;
}

.zavcode-single-event-cycle-tag {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background-color: #e8f4e8 !important;
  color: #2d5a2d !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  height: 24px !important;
  padding: 4px 8px !important;
  border-radius: 44px !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
}

/* Registration Button Row - Pixel Perfect from Figma */
.zavcode-single-event-registration {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  background-color: #f9f9f9 !important;
  margin-top: 0 !important;
}

.zavcode-single-event-register-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  max-width: fit-content !important;
  background-color: #e63946 !important;
  color: #ffffff !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  padding: 12px 32px !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  text-align: center !important;
  transition:
    background-color 0.2s ease,
    transform 0.1s ease !important;
  border: none !important;
  cursor: pointer !important;
  min-height: 44px !important; /* Touch-friendly */
  flex-shrink: 0 !important;
}

.zavcode-single-event-register-btn:hover {
  background-color: #d62839 !important;
  color: #ffffff !important;
  text-decoration: none !important;
}

.zavcode-single-event-register-btn:active {
  transform: scale(0.98) !important;
}

/* Content Section */
.zavcode-single-event-content-section {
  padding: 0 !important;
  background-color: #ffffff !important;
}

.zavcode-single-event-content {
  font-family: 'Roboto', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: #333333 !important;
}

.zavcode-single-event-content h2 {
  font-size: 28px !important;
  font-weight: 700 !important;
  margin: 32px 0 16px !important;
  color: #000000 !important;
}

.zavcode-single-event-content h3 {
  font-size: 22px !important;
  font-weight: 600 !important;
  margin: 24px 0 12px !important;
  color: #000000 !important;
}

.zavcode-single-event-content p {
  margin: 0 0 16px !important;
}

/* Bold/Strong text */
.zavcode-single-event-content strong,
.zavcode-single-event-content b {
  font-weight: 700 !important;
  color: #000000 !important;
}

/* Italic/Emphasis text */
.zavcode-single-event-content em,
.zavcode-single-event-content i {
  font-style: italic !important;
}

/* Underline */
.zavcode-single-event-content u {
  text-decoration: underline !important;
}

/* Strikethrough */
.zavcode-single-event-content s,
.zavcode-single-event-content del,
.zavcode-single-event-content strike {
  text-decoration: line-through !important;
}

/* Blockquote */
.zavcode-single-event-content blockquote {
  margin: 16px 0 !important;
  padding: 16px 24px !important;
  border-left: 4px solid #e63946 !important;
  background-color: #f9f9f9 !important;
  font-style: italic !important;
  color: #333333 !important;
}

/* Code */
.zavcode-single-event-content code {
  font-family: 'Courier New', Courier, monospace !important;
  background-color: #f3f3f3 !important;
  padding: 2px 6px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
}

.zavcode-single-event-content pre {
  background-color: #f3f3f3 !important;
  padding: 16px !important;
  border-radius: 8px !important;
  overflow-x: auto !important;
  margin: 16px 0 !important;
}

.zavcode-single-event-content pre code {
  background: none !important;
  padding: 0 !important;
}

.zavcode-single-event-content ul,
.zavcode-single-event-content ol {
  margin: 0 0 16px !important;
  padding-left: 24px !important;
}

.zavcode-single-event-content li {
  margin-bottom: 8px !important;
}

.zavcode-single-event-content a {
  color: #e63946 !important;
  text-decoration: underline !important;
}

.zavcode-single-event-content a:hover {
  color: #d62839 !important;
}

.zavcode-single-event-content img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: 8px !important;
  margin: 16px 0 !important;
}

/* Organizer Events Section (inline, inside column) */
.zavcode-single-event-organizer-section-inline {
  padding: 60px 0 0 !important;
  background-color: transparent !important;
}

.zavcode-single-event-organizer-section-inline
  .zavcode-single-event-organizer-title {
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: #000000 !important;
  margin: 0 0 24px !important;
  text-align: left !important;
}

.zavcode-single-event-organizer-section-inline
  .zavcode-single-event-organizer-list {
  width: 100% !important;
}

.zavcode-single-event-similar-section {
  padding: 48px 0 0 !important;
}

.zavcode-single-event-similar-title {
  font-family: 'Roboto', sans-serif !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: #000000 !important;
  margin: 0 0 24px !important;
  text-align: left !important;
}

.zavcode-single-event-similar-list {
  width: 100% !important;
}

/* List Headers in Similar Events Section - Higher specificity */
.zavcode-single-event-similar-section .zavcode-events-list-container {
  width: 100% !important;
  margin-bottom: 0 !important;
}

.zavcode-single-event-similar-section .zavcode-events-list-headers {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 0px !important;
  margin: 0 0 8px 0 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  color: #000000 !important;
  opacity: 0.45 !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.zavcode-single-event-similar-section .zavcode-events-list-headers * {
  box-sizing: border-box !important;
}

.zavcode-single-event-similar-section .zavcode-events-list-header-details {
  flex: 1 !important;
  min-width: 0 !important;
  display: block !important;
}

.zavcode-single-event-similar-section .zavcode-events-list-header-location {
  width: 110px !important;
  flex-shrink: 0 !important;
  display: block !important;
}

.zavcode-single-event-similar-section .zavcode-events-list-header-date {
  width: 140px !important;
  flex-shrink: 0 !important;
  display: block !important;
}

.zavcode-single-event-contact-notes {
  margin-top: 40px !important;
  display: flex !important;
  flex-direction: column !important;
}

.zavcode-single-event-contact-note {
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 2px 0 !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
}

.zavcode-single-event-contact-note p,
.zavcode-single-event-contact-note ul,
.zavcode-single-event-contact-note ol,
.zavcode-single-event-contact-note li {
  margin: 0 !important;
  padding: 0 !important;
  list-style-position: inside !important;
}

.zavcode-single-event-contact-note li + li {
  margin-top: 4px !important;
}

/* ============================================
   Responsive Design - Mobile First Approach
   ============================================ */

/* Tablet: 768px - 1024px */
@media (max-width: 1024px) {
  .zavcode-single-event-columns {
    grid-template-columns: 1fr 250px !important;
    gap: 30px !important;
  }

  .zavcode-single-event-container {
    padding: 0 16px !important;
  }
}

/* Mobile & Tablet: < 768px */
@media (max-width: 767px) {
  /* Stack sidebar below content */
  .zavcode-single-event-columns {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  .zavcode-single-event-sidebar {
    position: static !important;
    width: 100% !important;
  }

  .zavcode-single-event-container {
    padding: 0 16px !important;
  }

  .zavcode-single-event-title {
    font-size: 24px !important;
  }

  .zavcode-single-event-banner {
    max-height: 250px !important;
    border-radius: 6px !important;
  }

  .zavcode-single-event-layout {
    padding: 12px 0 40px !important;
  }

  .zavcode-single-event-banner-section {
    padding: 0 0 20px !important;
  }

  .zavcode-single-event-header-section {
    padding: 0 0 12px !important;
  }

  .zavcode-single-event-breadcrumb {
    margin-bottom: 6px !important;
  }

  .zavcode-single-event-details-section {
    padding: 0 0 32px !important;
  }

  .zavcode-single-event-details {
    max-width: 100% !important;
  }

  .zavcode-single-event-table-row {
    padding: 12px 16px !important;
    font-size: 14px !important;
  }

  .zavcode-single-event-table-label {
    width: 100px !important;
    font-size: 14px !important;
  }

  .zavcode-single-event-table-value {
    font-size: 14px !important;
  }

  .zavcode-single-event-distance-tag,
  .zavcode-single-event-cycle-tag {
    font-size: 11px !important;
    height: 22px !important;
    padding: 3px 6px !important;
  }

  .zavcode-single-event-register-btn {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 15px !important;
    padding: 12px 20px !important;
    min-height: 48px !important; /* Larger touch target on mobile */
  }

  .zavcode-single-event-content {
    font-size: 15px !important;
  }

  .zavcode-single-event-content h2 {
    font-size: 22px !important;
    margin: 24px 0 12px !important;
  }

  .zavcode-single-event-content h3 {
    font-size: 18px !important;
    margin: 20px 0 10px !important;
  }

  .zavcode-single-event-organizer-section-inline {
    padding: 40px 0 0 !important;
  }

  .zavcode-single-event-organizer-section-inline
    .zavcode-single-event-organizer-title {
    font-size: 20px !important;
    margin-bottom: 20px !important;
  }

  /* Event cards in list - already responsive from earlier rules */
  .zavcode-event-card {
    padding: 16px !important;
  }

  .zavcode-event-card-title {
    font-size: 16px !important;
  }
}

/* Extra Small Mobile: < 480px */
@media (max-width: 480px) {
  .zavcode-single-event-container {
    padding: 0 12px !important;
  }

  .zavcode-single-event-title {
    font-size: 20px !important;
    line-height: 1.3 !important;
  }

  .zavcode-single-event-banner {
    max-height: 200px !important;
    border-radius: 4px !important;
  }

  .zavcode-single-event-table-row {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 4px !important;
    padding: 10px 12px !important;
  }

  .zavcode-single-event-table-label {
    width: 100% !important;
    font-size: 12px !important;
    color: #666666 !important;
  }

  .zavcode-single-event-table-value {
    width: 100% !important;
    font-size: 14px !important;
    font-weight: 500 !important;
  }

  .zavcode-single-event-distances {
    width: 100% !important;
  }

  .zavcode-single-event-register-btn {
    font-size: 14px !important;
    padding: 12px 16px !important;
    min-height: 48px !important;
  }

  .zavcode-single-event-content {
    font-size: 14px !important;
  }

  .zavcode-single-event-content h2 {
    font-size: 20px !important;
  }

  .zavcode-single-event-content h3 {
    font-size: 17px !important;
  }

  .zavcode-single-event-organizer-section-inline
    .zavcode-single-event-organizer-title {
    font-size: 18px !important;
  }

  .zavcode-single-event-contact-notes {
    margin-top: 32px !important;
    gap: 12px !important;
  }

  .zavcode-single-event-contact-note {
    padding: 16px !important;
  }
}

/* ============================================
   Event Sidebar - tagDiv Integration Styles
   ============================================ */

/* Patronite iframe container */
.zavcode-event-sidebar-patronite {
  margin-bottom: 30px !important;
  text-align: center !important;
}

.zavcode-event-sidebar-patronite iframe {
  max-width: 100% !important;
  display: block !important;
  margin: 0 auto !important;
}

/* WordPress sidebar widgets container */
.zavcode-event-sidebar-widgets {
  margin-bottom: 30px !important;
}

/* Responsive adjustments for sidebar */
@media (max-width: 767px) {
  .zavcode-event-sidebar-patronite iframe {
    width: 100% !important;
    height: auto !important;
    min-height: 300px !important;
  }
}
