    /* ========================================
       Single Event Page — Self-contained
       ======================================== */

    .eec-single-wrap {
      max-width: 1280px;
      margin: 0 auto;
      padding: 2rem 2rem 4rem;
      font-family: inherit;
      color: #2d3748;
      line-height: 1.6;
      font-size: 1.1rem; /* Increased base font size */
    }

    .eec-single-wrap *,
    .eec-single-wrap *::before,
    .eec-single-wrap *::after {
      box-sizing: border-box;
    }

    /* Header */
    .eec-single-header {
      margin-bottom: 2rem;
    }

    .eec-single-header-meta {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 0.75rem;
      margin-bottom: 1rem;
    }

    .eec-single-categories-inline {
      display: flex;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .eec-single-cat-badge {
      display: inline-block;
      background: linear-gradient(135deg, #ebf8ff, #bee3f8);
      color: #2b6cb0;
      padding: 0.3rem 0.85rem;
      border-radius: 20px;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 0.3px;
    }

    .eec-single-status {
      display: inline-block;
      padding: 0.3rem 0.85rem;
      border-radius: 20px;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 0.3px;
    }

    .eec-single-status--upcoming {
      background: linear-gradient(135deg, #c6f6d5, #9ae6b4);
      color: #276749;
    }

    .eec-single-status--past {
      background: linear-gradient(135deg, #fed7d7, #feb2b2);
      color: #9b2c2c;
    }

    .eec-single-title {
      font-size: 2.75rem; /* Increased from 2.25rem */
      font-weight: 700;
      color: #1a365d;
      line-height: 1.2;
      margin: 0 0 1rem;
    }

    /* Quick meta bar */
    .eec-single-quick-meta {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 1.5rem;
    }

    .eec-single-quick-item {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 1.1rem; /* Increased from 0.95rem */
      color: #718096;
    }

    .eec-single-quick-item svg {
      color: #e67e22;
      flex-shrink: 0;
    }

    .eec-single-time-sep {
      margin: 0 0.15rem;
      color: #a0aec0;
    }

    /* Body Layout */
    .eec-single-body {
      display: flex;
      gap: 2.5rem;
    }

    .eec-single-main {
      flex: 1 1 0%;
      min-width: 0;
    }

    .eec-single-sidebar {
      flex: 0 0 360px;
    }

    /* Featured Image */
    .eec-single-image-wrap {
      position: relative;
      border-radius: 16px;
      overflow: hidden;
      box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
      margin-bottom: 2.5rem;
    }

    .eec-single-image {
      display: block;
      width: 100%;
      height: auto;
      max-height: 480px;
      object-fit: cover;
    }

    .eec-single-image-wrap .event-date-badge {
      position: absolute;
      top: 1rem;
      left: 1rem;
    }

    /* Content */
    .eec-single-content {
      margin-bottom: 2rem;
    }

    .eec-single-description {
      font-size: 1.15rem; /* Increased from 1.05rem */
      color: #4a5568;
      line-height: 1.8;
    }

    .eec-single-description p {
      margin-bottom: 1rem;
    }

    .eec-single-description img {
      max-width: 100%;
      height: auto;
      border-radius: 8px;
    }

    /* Tags */
    .eec-single-tags {
      margin-top: 2rem;
      padding-top: 1.5rem;
      border-top: 1px solid #e2e8f0;
    }

    .eec-single-tags-title {
      font-size: 1rem;
      font-weight: 600;
      color: #4a5568;
      margin-bottom: 0.75rem;
    }

    /* Register CTA Button */
    .eec-single-register-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      width: 100%;
      padding: 0.85rem 1.5rem;
      background: linear-gradient(135deg, #e67e22, #f39c12);
      color: #ffffff;
      font-size: 1rem;
      font-weight: 600;
      border: none;
      border-radius: 12px;
      text-decoration: none;
      cursor: pointer;
      transition: all 0.3s ease;
      box-shadow: 0 4px 15px rgba(230, 126, 34, 0.3);
    }

    .eec-single-register-btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(230, 126, 34, 0.4);
      color: #ffffff;
    }

    .eec-single-register-btn svg {
      transition: transform 0.3s ease;
    }

    .eec-single-register-btn:hover svg {
      transform: translateX(3px);
    }

    /* Map inside single */
    .eec-single-map {
      margin-top: 3rem;
    }



    /* About Section */
    .event-about-section {
      margin-top: 2.5rem;
    }

    .event-section-title {
      font-size: 1.75rem;
      font-weight: 700;
      color: #1a365d;
      margin-bottom: 1.5rem;
      position: relative;
      padding-bottom: 0.75rem;
    }

    .event-section-title::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 60px;
      height: 4px;
      background: linear-gradient(90deg, #e67e22, #f39c12);
      border-radius: 2px;
    }

    .event-description {
      color: #4a5568;
      font-size: 1.05rem;
      margin-bottom: 1.25rem;
    }

    /* Tags Section */
    .event-tags-section {
      margin-top: 2.5rem;
    }

    .event-tags-container {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
    }

    .event-tag {
      background: linear-gradient(135deg, #ebf8ff, #bee3f8);
      color: #2b6cb0;
      padding: 0.5rem 1.25rem;
      border-radius: 25px;
      font-size: 0.9rem;
      font-weight: 500;
      transition: all 0.3s ease;
      cursor: pointer;
      border: none;
      text-decoration: none;
    }

    .event-tag:hover {
      background: linear-gradient(135deg, #2b6cb0, #3182ce);
      color: #ffffff;
      transform: translateY(-2px);
      box-shadow: 0 4px 15px rgba(43, 108, 176, 0.3);
    }

    /* Details Card */
    .event-details-card {
      background: #ffffff;
      border-radius: 20px;
      box-shadow: 0 10px 50px rgba(0, 0, 0, 0.1);
      padding: 2rem;
      position: sticky;
      top: 2rem;
    }

    .event-card-title {
      font-size: 1.5rem;
      font-weight: 700;
      color: #1a365d;
      margin-bottom: 1.5rem;
      text-align: center;
    }

    .event-divider {
      height: 1px;
      background: linear-gradient(90deg, transparent, #e2e8f0, transparent);
      margin: 1.5rem 0;
    }

    .event-detail-row {
      display: flex;
      align-items: flex-start;
      gap: 1rem;
      margin-bottom: 1.25rem;
    }

    .event-detail-icon {
      width: 44px;
      height: 44px;
      background: linear-gradient(135deg, #ebf8ff, #bee3f8);
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .event-detail-icon svg {
      width: 22px;
      height: 22px;
      color: #2b6cb0;
    }

    .event-detail-content {
      flex: 1;
    }

    .event-detail-label {
      font-size: 0.8rem;
      color: #718096;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      margin-bottom: 0.25rem;
    }

    .event-detail-value {
      font-size: 1.1rem; /* Increased from 1rem */
      color: #2d3748;
      font-weight: 500;
    }

    .event-detail-value a {
      color: #e67e22;
      text-decoration: none;
      transition: color 0.3s ease;
    }

    .event-detail-value a:hover {
      color: #d35400;
      text-decoration: underline;
    }

    .eec-sidebar-address {
      display: block;
      margin-top: 0.25rem;
      font-size: 0.95rem;
      line-height: 1.4;
      color: #718096;
    }

    .event-detail-link {
      color: #e67e22;
      text-decoration: none;
      font-weight: 600;
      transition: color 0.3s ease;
    }

    .event-detail-link:hover {
      color: #d35400;
      text-decoration: underline;
    }

    .event-status-badge {
      display: inline-block;
      background: linear-gradient(135deg, #48bb78, #38a169);
      color: #ffffff;
      padding: 0.35rem 1rem;
      border-radius: 20px;
      font-size: 0.85rem;
      font-weight: 600;
    }

    .event-status-badge.online {
      background: linear-gradient(135deg, #4299e1, #3182ce);
    }

    .event-categories-list {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
    }

    .event-category-item {
      background: #f7fafc;
      color: #4a5568;
      padding: 0.3rem 0.75rem;
      border-radius: 6px;
      font-size: 0.85rem;
      border: 1px solid #e2e8f0;
    }

    /* Share Section */
    .event-share-section {
      text-align: center;
    }

    .event-share-title {
      font-size: 1rem;
      color: #4a5568;
      margin-bottom: 1rem;
    }

    .event-social-icons {
      display: flex;
      justify-content: center;
      gap: 1rem;
    }

    .event-social-icon {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all 0.3s ease;
      cursor: pointer;
      text-decoration: none;
    }

    .event-social-icon svg {
      width: 20px;
      height: 20px;
      color: #ffffff;
    }

    .event-social-icon.facebook { background: #1877f2; }
    .event-social-icon.twitter { background: #1da1f2; }
    .event-social-icon.linkedin { background: #0077b5; }
    .event-social-icon.email { background: #ea4335; }

    .event-social-icon:hover {
      transform: translateY(-3px);
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
    }

    /* Map Section */
    .event-map-section {
      max-width: 1280px;
      margin: 0 auto;
    }

    .event-map-container {
      border-radius: 20px;
      overflow: hidden;
      width: 100%;
      height: 400px;
      box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    }

    .event-map-container iframe {
      width: 100%;
      height: 400px;
      border: none;
    }

    /* Upcoming Events Section */
    .event-upcoming-section {
      background: linear-gradient(180deg, #f7fafc, #edf2f7);
      padding: 5rem 2rem;
    }

    .event-upcoming-container {
      max-width: 1280px;
      margin: 0 auto;
    }

    .event-upcoming-title {
      font-size: 2.25rem;
      font-weight: 700;
      color: #1a365d;
      text-align: center;
      margin-bottom: 3rem;
    }

    .event-upcoming-grid {
      display: flex;
      gap: 2rem;
    }

    .event-upcoming-card {
      flex: 1;
      background: #ffffff;
      border-radius: 16px;
      overflow: hidden;
      box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
      transition: all 0.4s ease;
    }

    .event-upcoming-card:hover {
      transform: translateY(-8px);
      box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
    }

    .event-upcoming-image-wrapper {
      position: relative;
      height: 220px;
      overflow: hidden;
      /* background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); */
    }

    .event-upcoming-image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.4s ease;
    }

    .event-upcoming-card:hover .event-upcoming-image {
      transform: scale(1.08);
    }

    .event-date-badge {
      position: absolute;
      top: 1rem;
      left: 1rem;
      background: linear-gradient(135deg, #e67e22, #f39c12);
      color: #ffffff;
      padding: 0.75rem 1rem;
      border-radius: 12px;
      text-align: center;
      box-shadow: 0 4px 15px rgba(230, 126, 34, 0.4);
    }

    .event-date-month {
      font-size: 0.75rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1px;
    }

    .event-date-day {
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1;
    }

    .event-upcoming-content {
      padding: 1.5rem;
    }

    .event-upcoming-card-title {
      font-size: 1.25rem;
      font-weight: 700;
      color: #1a365d;
      margin-bottom: 0.75rem;
    }

    .event-upcoming-description {
      color: #718096;
      font-size: 0.95rem;
      line-height: 1.6;
    }

    /* Single Event Responsive */
    @media (max-width: 1024px) {
      .eec-single-body {
        flex-direction: column;
      }

      .eec-single-sidebar {
        flex: 1 1 100%;
      }

      .event-details-card {
        position: static;
      }
    }

    @media (max-width: 768px) {
      .eec-single-wrap {
        padding: 1.5rem 1rem 3rem;
      }

      .eec-single-title {
        font-size: 1.75rem;
      }

      .eec-single-image {
        max-height: 320px;
      }

      .event-upcoming-grid {
        flex-direction: column;
      }

      .eec-single-map {
        margin-top: 2rem;
      }

      .event-upcoming-section {
        padding: 3rem 1rem;
      }
    }

    @media (max-width: 480px) {
      .eec-single-title {
        font-size: 1.5rem;
      }

      .eec-single-quick-meta {
        gap: 0.75rem;
      }

      .event-section-title {
        font-size: 1.5rem;
      }

      .event-upcoming-title {
        font-size: 1.75rem;
      }
    }

    /* ========================================
       Archive & Taxonomy Pages
       ======================================== */

    .eec-archive-wrap {
      max-width: 1280px;
      margin: 0 auto;
      padding: 3rem 2rem 4rem;
    }

    /* Archive Header */
    .eec-archive-header {
      text-align: center;
      margin-bottom: 3rem;
    }

    .eec-archive-title {
      font-size: 2.5rem;
      font-weight: 700;
      color: #1a365d;
      margin-bottom: 0.75rem;
      position: relative;
      display: inline-block;
      padding-bottom: 0.75rem;
    }

    .eec-archive-title::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 50%;
      transform: translateX(-50%);
      width: 80px;
      height: 4px;
      background: linear-gradient(90deg, #e67e22, #f39c12);
      border-radius: 2px;
    }

    .eec-archive-description {
      font-size: 1.1rem;
      color: #718096;
      max-width: 600px;
      margin: 1rem auto 0;
      line-height: 1.6;
    }

    /* Archive Grid */
    .eec-archive-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 2rem;
    }

    /* Archive Card */
    .eec-archive-card {
      background: #ffffff;
      border-radius: 16px;
      overflow: hidden;
      box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
      transition: all 0.4s ease;
    }

    .eec-archive-card:hover {
      transform: translateY(-8px);
      box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
    }

    .eec-archive-card .event-upcoming-image-wrapper {
      position: relative;
      height: 220px;
      overflow: hidden;
      /* background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); */
    }

    .eec-archive-card .event-upcoming-image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.4s ease;
    }

    .eec-archive-card:hover .event-upcoming-image {
      transform: scale(1.08);
    }

    .eec-archive-card .event-upcoming-content {
      padding: 1.5rem;
    }

    .eec-archive-card .event-upcoming-card-title {
      font-size: 1.2rem;
      font-weight: 700;
      color: #1a365d;
      margin-bottom: 0.5rem;
      line-height: 1.4;
    }

    .eec-archive-card .event-upcoming-card-title a {
      color: inherit;
      text-decoration: none;
      transition: color 0.3s ease;
    }

    .eec-archive-card .event-upcoming-card-title a:hover {
      color: #e67e22;
    }

    .eec-archive-card .event-upcoming-description {
      color: #718096;
      font-size: 1.05rem; /* Increased from 0.95rem */
      line-height: 1.6;
    }

    /* Image Placeholder */
    .eec-archive-placeholder {
      width: 100%;
      height: 100%;
      background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    }

    /* Archive Meta */
    .eec-archive-meta {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      margin-bottom: 0.75rem;
    }

    .eec-archive-date,
    .eec-archive-location {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      font-size: 0.85rem;
      color: #718096;
    }

    .eec-archive-date svg,
    .eec-archive-location svg {
      color: #e67e22;
      flex-shrink: 0;
    }

    .eec-archive-location {
      border-left: 1px solid #e2e8f0;
      padding-left: 0.5rem;
    }

    /* Pagination */
    .eec-archive-pagination {
      margin-top: 3rem;
      display: flex;
      justify-content: center;
      gap: 5px;
    }

    .eec-archive-pagination .nav-links {
      display: flex;
      gap: 0.5rem;
      align-items: center;
    }

    .eec-archive-pagination .page-numbers {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 40px;
      height: 40px;
      padding: 0 0.75rem;
      border-radius: 10px;
      font-size: 0.95rem;
      font-weight: 500;
      color: #4a5568;
      background: #ffffff;
      border: 1px solid #e2e8f0;
      text-decoration: none !important;
      transition: all 0.3s ease;
    }

    .eec-archive-pagination .page-numbers:hover {
      background: #ebf8ff;
      color: #2b6cb0;
      border-color: #bee3f8;
    }

    .eec-archive-pagination .page-numbers.current {
      background: linear-gradient(135deg, #2b6cb0, #3182ce);
      color: #ffffff;
      border-color: transparent;
      box-shadow: 0 4px 15px rgba(43, 108, 176, 0.3);
    }

    .eec-archive-pagination .page-numbers.prev,
    .eec-archive-pagination .page-numbers.next {
      font-weight: 600;
    }

    /* No Events State */
    .eec-no-events {
      text-align: center;
      padding: 4rem 2rem;
      background: #f7fafc;
      border-radius: 20px;
      max-width: 500px;
      margin: 0 auto;
    }

    .eec-no-events svg {
      color: #cbd5e0;
      margin-bottom: 1.5rem;
    }

    .eec-no-events h2 {
      font-size: 1.5rem;
      font-weight: 700;
      color: #2d3748;
      margin-bottom: 0.75rem;
    }

    .eec-no-events p {
      font-size: 1rem;
      color: #718096;
      line-height: 1.6;
    }

    /* Past event card subtle styling */
    .eec-archive-card.eec-status-past {
      opacity: 0.75;
    }

    .eec-archive-card.eec-status-past:hover {
      opacity: 1;
    }

    /* ========================================
       Archive & Taxonomy Responsive
       ======================================== */

    @media (max-width: 1024px) {
      .eec-archive-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media (max-width: 768px) {
      .eec-archive-wrap {
        padding: 2rem 1rem 3rem;
      }

      .eec-archive-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
      }

      .eec-archive-title {
        font-size: 2rem;
      }

      .eec-archive-card .event-upcoming-image-wrapper {
        height: 200px;
      }

      /* Mobile Pagination: Show only Prev, Current, and Next */
      .eec-archive-pagination .page-numbers {
        display: none !important;
      }
      .eec-archive-pagination .page-numbers.current,
      .eec-archive-pagination .page-numbers.prev,
      .eec-archive-pagination .page-numbers.next {
        display: inline-flex !important;
      }
    }

    @media (max-width: 480px) {
      .eec-archive-title {
        font-size: 1.5rem;
      }

      .eec-archive-description {
        font-size: 0.95rem;
      }

      .eec-archive-card .event-upcoming-content {
        padding: 1rem;
      }
    }

    /* ========================================
       Filter Bar
       ======================================== */

    .eec-filter-bar {
      background: #ffffff;
      border: 1px solid #e2e8f0;
      border-radius: 16px;
      padding: 1.25rem;
      margin-bottom: 1.5rem;
      box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    }

    .eec-filter-form {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      flex-wrap: wrap;
    }

    .eec-filter-search {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex: 1 1 250px;
      min-width: 200px;
      background: #f7fafc;
      border: 1px solid #e2e8f0;
      border-radius: 10px;
      padding: 0 1rem;
      transition: border-color 0.3s ease, box-shadow 0.3s ease;
    }

    .eec-filter-search:focus-within {
      border-color: #2b6cb0;
      background-color: #ffffff;
      box-shadow: 0 0 0 3px rgba(43, 108, 176, 0.15), 0 4px 6px -1px rgba(0, 0, 0, 0.05);
      transform: translateY(-1px);
    }

    .eec-filter-search svg {
      color: #a0aec0;
      flex-shrink: 0;
    }

    .eec-filter-input {
      width: 100%;
      border: none;
      background: none;
      padding: 0.7rem 0;
      font-size: 0.95rem;
      color: #2d3748;
      outline: none;
    }

    .eec-filter-input::placeholder {
      color: #a0aec0;
    }

    .eec-filter-select-wrap {
      flex: 0 1 auto;
      min-width: 180px;
      position: relative;
    }

    /* Hide native select but keep it functional */
    .eec-filter-select {
      position: absolute;
      opacity: 0;
      pointer-events: none;
      z-index: -1;
    }

    /* Custom Select Trigger Styles */
    .eec-custom-select-trigger {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: #ffffff;
      border: 1.5px solid #e2e8f0;
      border-radius: 12px;
      padding: 0.75rem 1rem;
      font-size: 0.95rem;
      font-weight: 500;
      color: #2d3748;
      cursor: pointer;
      transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
      box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
      user-select: none;
    }

    .eec-custom-select-trigger:hover {
      border-color: #cbd5e0;
      background-color: #f8fafc;
      transform: translateY(-1px);
      box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    }

    .eec-custom-select-trigger.active {
      border-color: #2b6cb0;
      background-color: #ffffff;
      box-shadow: 0 0 0 3px rgba(43, 108, 176, 0.15), 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    }

    .eec-custom-select-trigger svg {
      color: #718096;
      transition: transform 0.3s ease;
    }

    .eec-custom-select-trigger.active svg {
      transform: rotate(180deg);
      color: #2b6cb0;
    }

    /* Custom Options List */
    .eec-custom-options {
      position: absolute;
      top: 100%;
      left: 0;
      width: 100%;
      background: #ffffff;
      border: 1.5px solid #e2e8f0;
      border-radius: 12px;
      margin-top: 8px;
      padding: 6px;
      box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
      z-index: 100;
      max-height: 300px;
      overflow-y: auto;
      visibility: hidden;
      opacity: 0;
      transform: translateY(-10px);
      transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      scrollbar-width: thin;
      scrollbar-color: #cbd5e0 transparent;
    }

    .eec-custom-options::-webkit-scrollbar {
      width: 6px;
    }

    .eec-custom-options::-webkit-scrollbar-thumb {
      background-color: #cbd5e0;
      border-radius: 20px;
    }

    .eec-custom-select-wrap.open .eec-custom-options {
      visibility: visible;
      opacity: 1;
      transform: translateY(0);
    }

    .eec-custom-option {
      padding: 0.7rem 1rem;
      font-size: 0.95rem;
      font-weight: 500;
      color: #4a5568;
      border-radius: 8px;
      cursor: pointer;
      transition: all 0.2s ease;
    }

    .eec-custom-option:hover {
      background-color: #f1f5f9;
      color: #2b6cb0;
      padding-left: 1.25rem;
    }

    .eec-custom-option.selected {
      background-color: #ebf8ff;
      color: #2b6cb0;
    }

    .eec-filter-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 0.7rem 1.5rem;
      background: linear-gradient(135deg, #2b6cb0, #3182ce);
      color: #ffffff;
      font-size: 0.95rem;
      font-weight: 600;
      border: none;
      border-radius: 10px;
      cursor: pointer;
      transition: all 0.3s ease;
      box-shadow: 0 4px 12px rgba(43, 108, 176, 0.25);
      white-space: nowrap;
    }

    .eec-filter-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 6px 16px rgba(43, 108, 176, 0.35);
    }

    .eec-filter-reset {
      display: inline-flex;
      align-items: center;
      padding: 0.7rem 1.25rem;
      color: #e53e3e;
      font-size: 0.9rem;
      font-weight: 500;
      background: #fff5f5;
      border: 1px solid #fed7d7;
      border-radius: 10px;
      text-decoration: none;
      transition: all 0.3s ease;
      white-space: nowrap;
    }

    .eec-filter-reset:hover {
      background: #fed7d7;
      color: #c53030;
    }

    /* Results Info */
    .eec-results-info {
      font-size: 1.1rem; /* Increased from 0.9rem */
      font-weight: 600;
      color: #2d3748;
      margin-bottom: 1.5rem;
      padding: 0.5rem 1rem;
      background: #f7fafc;
      border-radius: 8px;
      display: inline-block;
      border-left: 4px solid #e67e22;
    }

    /* ========================================
       Taxonomy Badge
       ======================================== */

    .eec-taxonomy-badge {
      display: inline-block;
      background: linear-gradient(135deg, #ebf8ff, #bee3f8);
      color: #2b6cb0;
      padding: 0.35rem 1rem;
      border-radius: 20px;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 0.5px;
      text-transform: uppercase;
      margin-bottom: 0.75rem;
    }

    .eec-taxonomy-badge--organizer {
      background: linear-gradient(135deg, #faf5ff, #e9d8fd);
      color: #6b46c1;
    }

    /* ========================================
       Venue/Organizer Meta
       ======================================== */

    .eec-venue-meta {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 1.5rem;
      margin-top: 1rem;
      justify-content: center;
    }

    .eec-venue-meta-item {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 0.95rem;
      color: #718096;
    }

    .eec-venue-meta-item svg {
      color: #e67e22;
      flex-shrink: 0;
    }

    .eec-venue-meta-item a {
      color: #3182ce;
      text-decoration: none;
      transition: color 0.3s ease;
    }

    .eec-venue-meta-item a:hover {
      color: #2b6cb0;
      text-decoration: underline;
    }

    /* Venue Map */
    .eec-venue-map {
      margin-bottom: 2rem;
      border-radius: 16px;
      overflow: hidden;
      box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
    }

    .eec-venue-map .event-map-container {
      height: 300px;
    }

    /* ========================================
       Filter Bar Responsive
       ======================================== */

    @media (max-width: 768px) {
      .eec-filter-form {
        flex-direction: column;
      }

      .eec-filter-search {
        flex: 1 1 100%;
        width: 100%;
      }

      .eec-filter-select-wrap {
        width: 100%;
      }

      .eec-filter-select {
        width: 100%;
      }

      .eec-filter-btn,
      .eec-filter-reset {
        width: 100%;
        justify-content: center;
      }

      .eec-venue-meta {
        flex-direction: column;
        gap: 0.75rem;
      }

      .eec-venue-map .event-map-container {
        height: 220px;
      }
    }

    /* ========================================
       AJAX Filtering Styles
       ======================================== */
    .eec-ajax-results-container {
      position: relative;
      min-height: 200px;
    }

    .eec-ajax-loader {
      display: none;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: rgba(255, 255, 255, 0.7);
      z-index: 100;
      align-items: center;
      justify-content: center;
      border-radius: 16px;
    }

    .eec-spinner {
      width: 50px;
      height: 50px;
      border: 5px solid #f3f3f3;
      border-top: 5px solid #e67e22;
      border-radius: 50%;
      animation: eec-spin 1s linear infinite;
    }

    @keyframes eec-spin {
      0% { transform: rotate(0deg); }
      100% { transform: rotate(360deg); }
    }

    #eec-events-grid {
      transition: opacity 0.3s ease;
    }

    /* ========================================
       Taxonomy Page Refinements
       ======================================== */
    .eec-taxonomy-meta-box {
      background: #ffffff;
      border: 1px solid #e2e8f0;
      border-radius: 16px;
      padding: 1.5rem;
      margin: 1.5rem auto;
      max-width: 800px;
      box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
      text-align: left;
    }

    .eec-taxonomy-contact {
      display: flex;
      gap: 1.5rem;
      margin-top: 1rem;
      flex-wrap: wrap;
    }

    .eec-contact-link {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      color: #3182ce;
      text-decoration: none;
      font-weight: 600;
      font-size: 1rem;
      transition: color 0.3s ease;
    }

    .eec-contact-link:hover {
      color: #2b6cb0;
      text-decoration: underline;
    }

    .eec-contact-link svg {
      color: #e67e22;
    }

    .eec-taxonomy-map {
      max-width: 800px;
      margin: 2rem auto;
      border-radius: 16px;
      overflow: hidden;
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    }

    .eec-taxonomy-map iframe {
      width: 100%;
      height: 300px;
      border: none;
      display: block;
    }
/* Layout Toggle Buttons */
.eec-layout-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: 12px;
    padding-left: 12px;
    border-left: 1px solid #e2e8f0;
}

.eec-layout-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    color: #64748b;
    cursor: pointer;
    transition: all 0.2s ease;
}

.eec-layout-btn:hover {
    background: #f8fafc;
    color: #2b6cb0;
    border-color: #2b6cb0;
}

.eec-layout-btn.active {
    background: #2b6cb0;
    color: #fff;
    border-color: #2b6cb0;
    box-shadow: 0 4px 6px -1px rgba(59, 130, 246, 0.2);
}

/* List View Layout */
.eec-archive-list {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 100%;
    margin-top: 24px;
}

.eec-list-card {
    display: flex;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: 1px solid #f1f5f9;
}

.eec-list-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.eec-list-image-wrapper {
    position: relative;
    width: 300px;
    min-width: 300px;
    height: 200px;
    overflow: hidden;
}

.eec-list-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.eec-list-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
}

.eec-list-content {
    flex: 1;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.eec-list-title {
    margin: 0 0 12px 0;
    font-size: 1.25rem !important;
    font-weight: 700;
    line-height: 1.4;
}

.eec-list-title a {
    color: #1e293b;
    text-decoration: none !important;
    transition: color 0.2s;
}

.eec-list-title a:hover {
    color: #3b82f6;
}

.eec-list-excerpt {
    color: #64748b;
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 20px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.eec-list-footer {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 24px;
}

.eec-list-read-more {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #2b6cb0;
    font-weight: 600;
    text-decoration: none;
    font-size: 0.9rem;
    transition: gap 0.2s;
}

.eec-list-read-more:hover {
    gap: 10px;
}

/* Fix for Grid spacing with toggle */
.eec-filter-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

/* Responsive List View */
@media (max-width: 768px) {
    .eec-list-card {
        flex-direction: column;
    }
    
    .eec-list-image-wrapper {
        width: 100%;
        min-width: 100%;
        height: 200px;
    }
    
    .eec-layout-toggle {
        margin-left: 0;
        padding-left: 0;
        border-left: none;
        margin-top: 12px;
        width: 100%;
        justify-content: center;
    }
}
