/* Main container styling */
.em.pixelbones.em-item.em-event-single {
    background-color: white !important;
    border-radius: 10px !important;
    padding: 20px !important;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1) !important;
    margin: 20px auto !important;
}

/* Section headings - blue background with white text */
.em-event-when h3,
.em-event-where h3,
.em-item-taxonomies h3,
.em-event-bookings-meta h3 {
    background-color: #003366 !important;
    color: white !important;
    padding: 10px 15px !important;
    margin: 0 0 15px 0 !important;
    border-radius: 5px !important;
}

/* Content text - dark blue for good contrast on white */
.em-item-meta-line,
.em-event-date,
.em-event-time,
.em-event-location,
.em-item-taxonomy,
.em-event-prices,
.em-item-taxonomy div ul li a {
    color: #003366 !important; 
    font-weight: normal !important;
}

/* Icons */
.em-icon-calendar,
.em-icon-clock,
.em-icon-location,
.em-icon-category,
.em-icon-ticket {
    color: #003366 !important;
}

/* Organize the sections better */
.em-item-meta {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 20px !important;
}

.em-item-meta-column {
    background-color: white !important;
}

/* Remove unnecessary borders */
.em-event-content, .em-event-bookings, .em-event-location {
    border: none !important;
    margin-top: 30px !important;
}

.ur-frontend-form .ur-form-row .ur-form-grid label.ur-label, .ur-frontend-form .ur-form-row .ur-form-grid legend.ur-label {
    font-weight: 700;
    color: black;
}

/* Make events list responsive */
@media only screen and (max-width: 767px) {
    /* Event grid layout on mobile */
    .em-item-meta {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    /* Fix event title and description for mobile */
    .em-list-event-title, 
    .em-item-name {
        font-size: 18px !important;
        line-height: 1.3 !important;
    }
    
    /* Make event image responsive */
    .em-item-image {
        width: 100% !important;
        height: auto !important;
    }
    
    .em-item-image img {
        width: 100% !important;
        height: auto !important;
        object-fit: cover !important;
    }
    
    /* Adjust event container for mobile */
    .em.pixelbones.em-item.em-event,
    .em-search-advanced,
    .em-pagination,
    .em-events-list {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 10px !important;
    }
    
    /* Fix event details layout */
    .em-event-when,
    .em-event-where,
    .em-item-taxonomies,
    .em-event-bookings-meta {
        width: 100% !important;
        margin-bottom: 15px !important;
    }
    
    /* Improve buttons on mobile */
    .em-event-details-link,
    .em-booking-button,
    .em-event-add-to-calendar,
    button.input {
        width: 100% !important;
        margin: 5px 0 !important;
        text-align: center !important;
    }
}

/* Tablet responsive adjustments */
@media only screen and (min-width: 768px) and (max-width: 1024px) {
    .em-item-meta {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }
    
    .em-item-image {
        max-width: 100% !important;
    }
}

/* Ensure event items are more compact on mobile */
@media only screen and (max-width: 767px) {
    .em-list .em-item {
        margin-bottom: 20px !important;
        padding: 10px !important;
    }
    
    /* Adjust font sizes for better mobile reading */
    .em-event-meta,
    .em-event-location,
    .em-item-meta-line {
        font-size: 14px !important;
    }
    
    /* Make date/time info more readable */
    .em-event-date, 
    .em-event-time {
        display: block !important;
        margin-bottom: 5px !important;
    }
}

.wpem-event-listings-header .wpem-event-listing-header-title .wpem-heading-text {
    font-size: 24px;
    line-height: 1.42;
    font-weight: 500;
    margin: 0;
	color: black;
}

.tribe-events-calendar-list {
    background-color: white;
    padding: 40px; /* Optional: adds some spacing inside */
    border-radius: 8px; /* Optional: adds rounded corners */
}