/* ===========================================================
   VINEBUILDERS EVENT SYSTEM ENHANCEMENTS
   Fully namespaced under .vinebuilders-eventsys
   Compatible with Elementor widgets, modals, JS filters, templates.
   =========================================================== */

/* =========================
   GRID + ARCHIVE + WIDGETS
   ========================= */
.vinebuilders-eventsys .evsys-results,
.vinebuilders-eventsys .event-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  width: 100%;
}

/* Elementor override to enforce grid */
.vinebuilders-eventsys .elementor .evsys-results,
.vinebuilders-eventsys .elementor .event-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
  gap: 2rem !important;
  width: 100% !important;
}

/* Reset single-event wrapper */
body.single-event .vinebuilders-eventsys .evsys-wrap.single-event {
  display: block !important;
  width: auto !important;
  max-width: 800px !important;
  margin: 60px auto !important;
  background: #fff !important;
  border: 1px solid #eee !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
  outline: none !important;
}

/* =========================
   EVENT CARDS + HOVER EFFECT
   ========================= */
.vinebuilders-eventsys .evsys-card,
.vinebuilders-eventsys .event-card {
  border: none;
  padding: 1rem;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  margin-bottom: 1.5rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.vinebuilders-eventsys .evsys-card:hover,
.vinebuilders-eventsys .event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 0 3px rgba(56,182,255,0.15),
              0 8px 16px rgba(0,0,0,0.12);
}

/* =========================
   TITLES
   ========================= */
.vinebuilders-eventsys .evsys-card .evsys-title,
.vinebuilders-eventsys .event-card .event-title {
  margin: 0 0 .5rem;
  font-size: 1.25rem;
  font-weight: 600;
  color: #38B6FF;
  text-align: center;
}

.vinebuilders-eventsys .evsys-card .evsys-title a,
.vinebuilders-eventsys .event-card .event-title a {
  color: #38B6FF;
  text-decoration: none;
}

.vinebuilders-eventsys .evsys-card .evsys-title a:hover,
.vinebuilders-eventsys .event-card .event-title a:hover {
  color: #2499E6;
  text-decoration: underline;
}

/* =========================
   META (Date + Location)
   ========================= */
.vinebuilders-eventsys .evsys-card .evsys-meta,
.vinebuilders-eventsys .event-card .event-meta {
  color: #555;
  margin-bottom: .5rem;
  font-size: 0.9rem;
  opacity: .9;
}

/* =========================
   THUMBNAILS
   ========================= */
.vinebuilders-eventsys .evsys-card .event-thumb img,
.vinebuilders-eventsys .event-card .event-thumb img,
.vinebuilders-eventsys .evsys-card .evsys-thumb img {
  border-radius: 8px;
  margin-bottom: .75rem;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* =========================
   BUTTONS
   ========================= */
.vinebuilders-eventsys .evsys-card .btn-view-event,
.vinebuilders-eventsys .event-card .btn-view-event,
.vinebuilders-eventsys .evsys-card .evsys-actions .button {
  display: inline-block;
  margin-top: .75rem;
  padding: 0.5rem 1rem;
  background-color: #38B6FF !important;
  color: #fff !important;
  text-decoration: none !important;
  border-radius: 6px !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  border: none !important;
  transition: background-color 0.2s ease-in-out;
}

.vinebuilders-eventsys .evsys-card .btn-view-event:hover,
.vinebuilders-eventsys .event-card .btn-view-event:hover,
.vinebuilders-eventsys .evsys-card .evsys-actions .button:hover {
  background-color: #2499E6 !important;
}

/* =========================
   FILTERS + LOAD MORE
   ========================= */
.vinebuilders-eventsys .evsys-filters {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: .75rem;
  align-items: end;
  margin-bottom: 1rem;
}

.vinebuilders-eventsys .evsys-load-more {
  display: inline-block;
  padding: .6rem 1rem;
  border: 1px solid #aaa;
  background: #fff;
  border-radius: .5rem;
  cursor: pointer;
  transition: background-color 0.2s ease-in-out;
}

.vinebuilders-eventsys .evsys-load-more:hover {
  background-color: #f2f2f2;
}

/* =========================
   SINGLE EVENT PAGE
   ========================= */
.vinebuilders-eventsys .evsys-wrap.single-event {
  max-width: 800px;
  margin: 60px auto;
  padding: 2rem;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  text-align: left;
}

.vinebuilders-eventsys .evsys-thumb {
  text-align: center;
  margin-bottom: 1.5rem;
}

.vinebuilders-eventsys .evsys-thumb img {
  max-width: 100%;
  border-radius: 8px;
  height: auto;
}

.vinebuilders-eventsys .evsys-title {
  text-align: center;
  font-size: 2rem;
  margin-bottom: 1rem;
  color: #38B6FF;
}

.vinebuilders-eventsys .evsys-meta p {
  margin: .5rem 0;
  font-size: 1rem;
  color: #555;
}

.vinebuilders-eventsys .evsys-description,
.vinebuilders-eventsys .evsys-speakers,
.vinebuilders-eventsys .evsys-ministry {
  margin: 1.5rem 0;
  font-size: 1rem;
  line-height: 1.6;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

/* Register Button */
.vinebuilders-eventsys .evsys-actions {
  text-align: center;
  margin-top: 2rem;
}

.vinebuilders-eventsys .evsys-actions .button {
  padding: .75rem 1.5rem;
  background: #38B6FF;
  color: #fff;
  border-radius: 6px;
  font-weight: bold;
  text-decoration: none;
  transition: background .2s;
}

.vinebuilders-eventsys .evsys-actions .button:hover {
  background: #2499E6;
}

/* =========================
   EVENT DETAILS BOX
   ========================= */
body.single-event article.evsys-single .vinebuilders-eventsys .evsys-meta {
  background: #f9f9f9 !important;
  padding: 1rem 1.5rem !important;
  border-left: 4px solid #38B6FF !important;
  border-radius: 6px !important;
  margin: 1.5rem auto !important;
  max-width: 700px;
}

body.single-event article.evsys-single .vinebuilders-eventsys .evsys-meta p {
  margin: 0.25rem 0 !important;
  font-size: 1rem;
  color: #333 !important;
}

/* =========================
   WIDGET SHADOW + HOVER GLOW
   ========================= */
.vinebuilders-eventsys .latest-events-widget .evsys-card,
.vinebuilders-eventsys .elementor .evsys-card {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  padding: 1.25rem;
  text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.vinebuilders-eventsys .latest-events-widget .evsys-card:hover,
.vinebuilders-eventsys .elementor .evsys-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

.vinebuilders-eventsys .latest-events-widget .evsys-card .evsys-thumb img,
.vinebuilders-eventsys .elementor .evsys-card .evsys-thumb img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
}

/* ===========================================================
   BRAND CONSISTENCY: COLORS + BUTTONS + TITLES
   =========================================================== */
body.single-event .vinebuilders-eventsys .evsys-wrap.single-event {
  outline: none !important;
  border-color: #eee !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
}

.vinebuilders-eventsys .latest-events-widget .event-title a,
.vinebuilders-eventsys .elementor .event-title a,
.vinebuilders-eventsys .evsys-card .evsys-title a,
.vinebuilders-eventsys .event-card .event-title a,
body.single-event .vinebuilders-eventsys .evsys-title {
  color: #38B6FF !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

.vinebuilders-eventsys .latest-events-widget .event-title a:hover,
.vinebuilders-eventsys .elementor .event-title a:hover,
.vinebuilders-eventsys .evsys-card .evsys-title a:hover,
.vinebuilders-eventsys .event-card .event-title a:hover {
  color: #2499E6 !important;
  text-decoration: underline !important;
}

/* Global Button Style */
.vinebuilders-eventsys .latest-events-widget .btn-view-event,
.vinebuilders-eventsys .elementor .btn-view-event,
.vinebuilders-eventsys .event-card .btn-view-event,
.vinebuilders-eventsys .evsys-card .btn-view-event,
.vinebuilders-eventsys .evsys-card .evsys-actions .button,
.vinebuilders-eventsys .evsys-actions .button {
  background-color: #38B6FF !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 0.6rem 1.2rem !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
  transition: background-color 0.2s ease-in-out !important;
}

.vinebuilders-eventsys .latest-events-widget .btn-view-event:hover,
.vinebuilders-eventsys .elementor .btn-view-event:hover,
.vinebuilders-eventsys .event-card .btn-view-event:hover,
.vinebuilders-eventsys .evsys-card .btn-view-event:hover,
.vinebuilders-eventsys .evsys-card .evsys-actions .button:hover,
.vinebuilders-eventsys .evsys-actions .button:hover {
  background-color: #2499E6 !important;
  color: #fff !important;
}


/* Fallback for templates missing .vinebuilders-eventsys */
.evsys-card .btn-view-event,
.event-card .btn-view-event,
.evsys-actions .button {
  background-color: #38B6FF !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 0.6rem 1.2rem !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
  transition: background-color 0.2s ease-in-out !important;
}

.evsys-card .btn-view-event:hover,
.event-card .btn-view-event:hover,
.evsys-actions .button:hover {
  background-color: #2499E6 !important;
}

/* ===========================================================
   Fallback: Class-based styling (no wrapper dependency)
   =========================================================== */

.evsys-card .evsys-title a,
.event-card .event-title a {
  color: #38B6FF !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

.evsys-card .evsys-title a:hover,
.event-card .event-title a:hover {
  color: #2499E6 !important;
  text-decoration: underline !important;
}

.evsys-actions .btn-view-event,
.evsys-actions .button {
  background-color: #38B6FF !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  padding: 0.6rem 1.2rem !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background-color 0.2s ease-in-out !important;
}

.evsys-actions .btn-view-event:hover,
.evsys-actions .button:hover {
  background-color: #2499E6 !important;
}


/* ===========================================================
   VINEBUILDERS EVENT ENHANCEMENTS (ADDED 2025)
   Uniform Image Sizing + Responsive Behavior
   =========================================================== */

.vinebuilders-eventsys .evsys-thumb img,
.vinebuilders-eventsys .event-thumb img {
  width: 100%;
  max-width: 410px;
  height: 550px;
  object-fit: cover;
  object-position: center;
  border-radius: 8px;
  display: block;
  margin: 0 auto 1rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  transition: transform 0.25s ease-in-out;
}

.vinebuilders-eventsys .evsys-thumb img:hover,
.vinebuilders-eventsys .event-thumb img:hover {
  transform: scale(1.02);
}

/* Responsive for mobile/tablet */
@media (max-width: 768px) {
  .vinebuilders-eventsys .evsys-thumb img,
  .vinebuilders-eventsys .event-thumb img {
    max-width: 100%;
    height: 350px;
  }
}

/* Center inside popup templates */
.single-event .evsys-thumb img,
.single-event .event-thumb img {
  display: block;
  margin: 0 auto;
}

