/* ===========================================================
   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;
}

/* ==========================================
   OLD THUMBNAILS (commented out 10/28/25)
==========================================*/

.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;
}

/* ====== CORE NAMESPACE LAYOUT ====== */
.vinebuilders-eventsys .evsys-results,
.vinebuilders-eventsys .event-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  width: 100%;
}

/* Fallback when wrapper is missing (archive before we patched, or older pages) */
.event-grid { 
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
}

/* ====== UNIFORM THUMB SIZING (cards) ====== */
/* Works for both templates: event-card.php & event-card-template.php */
.vinebuilders-eventsys .evsys-card .evsys-thumb img,
.vinebuilders-eventsys .evsys-card .event-thumb,
.vinebuilders-eventsys .event-card .evsys-thumb img,
.vinebuilders-eventsys .event-card .event-thumb,
.evsys-card .evsys-thumb img,  /* fallback no wrapper */
.evsys-card .event-thumb,
.event-card .evsys-thumb img,
.event-card .event-thumb {
  width: 100%;
  max-width: 410px;
  height: 550px;
  object-fit: cover;
  object-position: center;
  border-radius: 8px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/* Mobile adjustment */
@media (max-width: 768px) {
  .vinebuilders-eventsys .evsys-card .evsys-thumb img,
  .vinebuilders-eventsys .evsys-card .event-thumb,
  .vinebuilders-eventsys .event-card .evsys-thumb img,
  .vinebuilders-eventsys .event-card .event-thumb,
  .evsys-card .evsys-thumb img,
  .evsys-card .event-thumb,
  .event-card .evsys-thumb img,
  .event-card .event-thumb {
    max-width: 100%;
    height: 350px;
  }
}

/* ====== CARD CONTAINER & TITLES (unchanged feel, tighter specificity) ====== */
.vinebuilders-eventsys .evsys-card,
.vinebuilders-eventsys .event-card,
.evsys-card, .event-card {
  border: 0;
  padding: 1rem;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  transition: transform .2s ease, box-shadow .2s ease;
}

.vinebuilders-eventsys .evsys-card:hover,
.vinebuilders-eventsys .event-card:hover,
.evsys-card:hover, .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);
}

.vinebuilders-eventsys .evsys-title,
.vinebuilders-eventsys .event-title,
.evsys-card .evsys-title,
.event-card .event-title {
  margin: .75rem 0 .25rem;
  font-size: 1.25rem;
  font-weight: 600;
  text-align: center;
}

.vinebuilders-eventsys .evsys-title a,
.vinebuilders-eventsys .event-title a,
.evsys-card .evsys-title a,
.event-card .event-title a {
  color: #38B6FF;
  text-decoration: none;
}

.vinebuilders-eventsys .evsys-title a:hover,
.vinebuilders-eventsys .event-title a:hover,
.evsys-card .evsys-title a:hover,
.event-card .event-title a:hover {
  color: #2499E6;
  text-decoration: underline;
}

/* ====== META + BUTTONS (keep brand) ====== */
.vinebuilders-eventsys .evsys-meta,
.vinebuilders-eventsys .event-meta,
.evsys-card .evsys-meta,
.event-card .event-meta {
  color: #555;
  font-size: .95rem;
  opacity: .9;
  text-align: center;
}

.vinebuilders-eventsys .btn-view-event,
.vinebuilders-eventsys .evsys-actions .button,
.evsys-card .btn-view-event,
.evsys-actions .button {
  display: inline-block;
  margin-top: .75rem;
  padding: .6rem 1.2rem;
  background-color: #38B6FF;
  color: #fff;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: background-color .2s ease-in-out;
}

.vinebuilders-eventsys .btn-view-event:hover,
.vinebuilders-eventsys .evsys-actions .button:hover,
.evsys-card .btn-view-event:hover,
.evsys-actions .button:hover {
  background-color: #2499E6;
}

/* ====== SINGLE (kept minimal – your inline styles win) ====== */
body.single-event .evsys-wrap.single-event {
  max-width: 800px;
  margin: 60px auto;
}

/* ======================================
   FINAL LATEST EVENTS WIDGET FIX
   ====================================== */

/* Center grid inside container */
.vinebuilders-eventsys .latest-events-widget.event-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
  gap: 2rem !important;
  justify-content: center !important;
}

/* Limit card width so they don't stretch full screen */
.vinebuilders-eventsys .evsys-card {
  max-width: 340px;
  width: 100%;
  margin: 0 auto 2rem auto !important;
}

/* Uniform image container */
.vinebuilders-eventsys .evsys-card .evsys-thumb {
  height: 380px;
  overflow: hidden;
  border-radius: 8px;
}

/* Fix image sizing */
.vinebuilders-eventsys .evsys-card .evsys-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Tablet */
@media (max-width: 1024px) {
  .vinebuilders-eventsys .evsys-card {
    max-width: 300px;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .vinebuilders-eventsys .latest-events-widget.event-grid {
    grid-template-columns: 1fr !important;
  }

  .vinebuilders-eventsys .evsys-card {
    max-width: 100% !important;
  }

  .vinebuilders-eventsys .evsys-card .evsys-thumb {
    height: 300px !important;
  }
}


/* ===========================================================
   ✅ FINAL EVENT CARD DIMENSIONS — Style A (Medium Portrait)
   =========================================================== */

/* Card Max Width & Centering */
.vinebuilders-eventsys .evsys-card,
.vinebuilders-eventsys .event-card,
.evsys-card,
.event-card {
  max-width: 320px !important;
  width: 100%;
  margin: 0 auto 2rem auto !important;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Image Container */
.vinebuilders-eventsys .evsys-card .evsys-thumb,
.vinebuilders-eventsys .event-card .event-thumb,
.evsys-card .evsys-thumb,
.event-card .event-thumb {
  width: 100%;
  height: 400px !important; /* Outcome: 300×400 feel */
  overflow: hidden;
  border-radius: 8px;
}

/* Image Sizing */
.vinebuilders-eventsys .evsys-card .evsys-thumb img,
.vinebuilders-eventsys .event-card .event-thumb img,
.evsys-card .evsys-thumb img,
.event-card .event-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}

/* Buttons stay same size, centered */
.vinebuilders-eventsys .btn-view-event,
.evsys-card .btn-view-event {
  margin-top: 1rem !important;
}

/* Mobile Responsiveness */
@media (max-width: 768px) {
  .vinebuilders-eventsys .evsys-card,
  .vinebuilders-eventsys .event-card,
  .evsys-card,
  .event-card {
    max-width: 100% !important;
  }

  .vinebuilders-eventsys .evsys-card .evsys-thumb,
  .vinebuilders-eventsys .event-card .event-thumb,
  .evsys-card .evsys-thumb,
  .event-card .event-thumb {
    height: 320px !important;
  }
}

/* ===========================================================
   ✅ SINGLE EVENT IMAGE — match card style (320px wide)
   =========================================================== */

body.single-event .evsys-wrap.single-event {
  max-width: 700px !important;
  margin: 60px auto !important;
  padding: 0 0 3rem 0 !important;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

/* Image wrapper */
body.single-event .evsys-thumb {
  text-align: center;
  margin: 2rem auto 1.5rem;
  width: 100%;
}

/* Portrait image style */
body.single-event .evsys-thumb img {
  width: 100%;
  max-width: 320px !important;
  height: 400px !important;
  object-fit: cover !important;
  border-radius: 10px;
  display: block;
  margin: 0 auto;
}

/* Title center + nice spacing */
body.single-event .evsys-title {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  margin: 1rem auto;
  color: #38B6FF;
}

/* Meta section */
body.single-event .evsys-meta {
  text-align: center !important;
  font-size: 1rem;
  margin-bottom: 1.5rem;
  color: #666;
}

/* Description container */
body.single-event .evsys-description {
  max-width: 500px;
  margin: 1rem auto;
  font-size: 1rem;
  line-height: 1.6;
  color: #444;
  text-align: center;
  padding: 0 1rem;
}

/* Center the "Register / Learn More" button */
body.single-event .evsys-actions {
  text-align: center !important;
  margin-top: 2rem;
}

/* ======================================
   LATEST EVENTS – FEATURED CARD WIDTH
   ====================================== */

.vinebuilders-eventsys .latest-events-widget .evsys-card,
.vinebuilders-eventsys .latest-events-widget .event-card {
  max-width: 520px !important; /* ← adjust this */
}

/* ===========================================================
   FORCE LATEST EVENTS WIDGET TO BE WIDER (override all caps)
   =========================================================== */

/* Make sure the widget container itself isn't constraining width */
.elementor-widget-container .vinebuilders-eventsys,
.elementor-widget-container .vinebuilders-eventsys .latest-events-widget.event-grid {
  width: 100% !important;
  max-width: 100% !important;
}

/* Force the single "latest event" card wider (covers both card class names) */
.vinebuilders-eventsys .latest-events-widget.event-grid .evsys-card,
.vinebuilders-eventsys .latest-events-widget.event-grid .event-card,
.vinebuilders-eventsys .latest-events-widget .evsys-card,
.vinebuilders-eventsys .latest-events-widget .event-card {
  max-width: none !important;                 /* removes your 320px caps */
  width: min(800px, 100%) !important;         /* 👈 make it wider here */
  margin-left: auto !important;
  margin-right: auto !important;
}







/* ===========================
   LATEST EVENTS WIDGET: FIX GRID + REMOVE CARD CAPS
   =========================== */

/* Make grid items stretch full cell (prevents centered narrow cards) */
.vinebuilders-eventsys .latest-events-widget.event-grid{
  justify-content: start !important;
  justify-items: stretch !important; /* fixes the DevTools "justify-items:center" issue */
}

/* Let cards fill the column (override global max-width caps) */
.vinebuilders-eventsys .latest-events-widget.event-grid .evsys-card,
.vinebuilders-eventsys .latest-events-widget.event-grid .event-card{
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Remove poster-style max-width centering on widget images */
.vinebuilders-eventsys .latest-events-widget.event-grid .evsys-thumb img,
.vinebuilders-eventsys .latest-events-widget.event-grid .event-thumb img{
  max-width: none !important;
  margin: 0 !important;
  width: 100% !important;
}

/* Optional: make widget thumbs shorter so they don't look huge */
.vinebuilders-eventsys .latest-events-widget.event-grid .evsys-thumb{
  height: 240px !important; /* adjust */
}
.vinebuilders-eventsys .latest-events-widget.event-grid .evsys-thumb img{
  height: 100% !important;
  object-fit: cover !important;
}

