/*
	README

	This file should only be used to style structure of the widget. It should not
	contain fonts or theme styling. Use the shared_theme.css for that purpose.

	If simply theming the CCL, leave this file alone.

	If your design is very customized, edit this file as needed. 
*/

/*==============================*/
/*=====----- TEMPLATE -----=====*/
/*==============================*/

.core-featured-events {
    position: relative;
    width: 100%;
    margin-bottom: var(--widget-margin-bottom);
    z-index: 0;
}

.core-featured-events::after {
    content: '';
    background-image: url(/includes/public/assets/shared/decorations/tulip-leaves-flowers-mobile.svg);
    background-repeat: no-repeat;
    background-size: cover;
    display: block;
    height: 328px;
    width: 188px;
    position: absolute;
    top: 53%;
    right: 0;
    z-index: 1;
}

.core-featured-events .featured-events-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-5);
}

.core-featured-events .widget-header {
    padding: 0;
}

.core-featured-events .widget-header.has-view-all {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
}

.core-featured-events .widget-title {
    margin: 0;
}

.core-featured-events .slides {
    position: relative;
    display: grid;
    grid-template: auto / minmax(0, 1fr);
    gap: 18px;
    width: 100%;
}

.core-featured-events .btn-cont {
    padding-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/*----- date picker -----*/

.core-featured-events .date-picker-row {
    display: grid;
    gap: var(--space-4);
    margin-bottom: var(--space-5);
}

.core-featured-events .input-label {
    display: block;
    margin-bottom: var(--space-1);
}

.core-featured-events .input {
    display: block;
    width: 100%;
    padding: var(--space-1) var(--space-2);
}

.core-featured-events .form-button {
    justify-self: start;
    padding: var(--space-1) var(--space-5);
}

/*============================*/
/*=====----- SLIDES -----=====*/
/*============================*/

.core-featured-events .slide,
.core-featured-events .slide .img-cont,
.core-featured-events .slide .slide-img {
    position: relative;
    z-index: 1;
}

.core-featured-events .slide {
    overflow: hidden;
}

.core-featured-events .slide .category {
    display: block;
    margin-bottom: var(--space-1);
}

.core-featured-events .details li:not(.has-link),
.core-featured-events .details li.has-link > a {
    display: flex;
}

.core-featured-events .slide .slide-title {
    margin-bottom: var(--space-2);
}

.core-featured-events .slide .details {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px;
}

.core-featured-events .shared-play-button {
    inset: 16px 16px auto auto;
    transform: none;
}

/*----- minor slide -----*/
.core-featured-events .slide.minor {
    width: 100%;
}
.core-featured-events .slide.minor.has-date {
    display: grid;
    grid-template: auto / minmax(0, 1fr) minmax(0, 2.5fr);
    gap: 34px;
    align-items: center;
}

.core-featured-events .slide.minor .category {
    margin-bottom: 2px;
}

.core-featured-events .slide.minor .mini-date-section {
    position: static;
}

.core-featured-events .slide.minor .slide-title {
    margin-bottom: 2px;
}

/*----- promoted slide -----*/

.core-featured-events .slide.promoted .content-section {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    max-width: var(--width-compact);
    padding: var(--space-4);
    pointer-events: none;
}

.core-featured-events .slide.promoted .content-section a {
    pointer-events: all;
}

/*===================================*/
/*=====----- MEDIA QUERIES -----=====*/
/*===================================*/

@media screen and (min-width: 375px) {
    .core-featured-events .slide.minor,
    .core-featured-events .slide.minor.has-date {
        gap: 26px;
    }
}

@media (min-width: 30em) {
    /*----- date picker -----*/

    .core-featured-events .date-picker-row {
        grid-template: auto / 1fr 1fr;
    }

    .core-featured-events .form-button {
        grid-column: span 2;
    }
}

@media (min-width: 40em) {
    .core-featured-events::after {
        top: 10%;
    }

    .core-featured-events .slides {
        grid-template: auto / repeat(2, minmax(0, 1fr));
        grid-auto-flow: dense;
    }

    .core-featured-events .slide .img-cont,
    .core-featured-events .slide .slide-img {
        height: 100%;
    }

    .core-featured-events .slide .slide-img {
        object-fit: cover;
    }

    /*----- date picker -----*/

    .core-featured-events .date-picker-row {
        display: flex;
        gap: 0;
        align-items: flex-end;
        max-width: var(--width-comfortable);
    }

    .core-featured-events .date-picker-row > * {
        margin-right: var(--space-4);
    }

    .core-featured-events .date-picker-row > *:last-child {
        margin-right: 0;
    }

    .core-featured-events .input-col {
        flex-grow: 1;
    }

    .core-featured-events .form-buttom {
        flex-shrink: 0;
    }

    /*----- minor slide -----*/
    
    .core-featured-events .slide.minor.has-date {
        grid-template: auto / auto minmax(0, 1fr);
        gap: 26px;
        align-items: center;
    }

    .core-featured-events .slide.minor .content-section {
        margin: 0;
    }

    /*----- promoted slide -----*/

    .core-featured-events .slide.promoted {
        grid-column: span 1;
        grid-row: span 3;
    }

    /*----- marquee left -----*/

    .core-featured-events.marquee-left .slide.minor {
        grid-column: 1;
    }

    .core-featured-events.marquee-left .slide.promoted {
        grid-column: 2;
    }

    /*----- marquee bottom -----*/

    .core-featured-events.marquee-bottom .slides {
        grid-template: auto / repeat(3, minmax(0, 1fr));
        gap: var(--space-8) var(--space-5);
    }

    .core-featured-events.marquee-bottom .slide.promoted {
        grid-row: span 1;
        grid-column: span 3;
    }
}

@media (min-width: 64em) {
    .core-featured-events::after {
        height: 634px;
        width: 350px;
    }

    .core-featured-events .slides {
        gap: 30px;
    }

    /*----- minor slide -----*/

    .core-featured-events .slide.minor.has-date {
        grid-template: auto / auto minmax(0, 1fr);
    }

    /*----- promoted slide -----*/

    .core-featured-events .slide.promoted .content-section {
        max-width: var(--width-comfortable);
        padding: var(--space-8);
    }

    /*----- marquee bottom -----*/

    .core-featured-events.marquee-bottom .slides {
        grid-template: auto / repeat(3, minmax(0, 1fr));
    }

    .core-featured-events.marquee-bottom .slide.promoted {
        grid-column: span 3;
    }

    @media screen and (min-width: 64em) {
        .core-featured-events .btn-cont {
            padding-top: 40px;
            flex-direction: row;
            gap: 30px;
            align-items: center;
        }

        .core-featured-events .submit-btn a.submit-btn-link {
            padding: 9px 18.3px;
        }
    }
}

@media (min-width: 80em) {

    .core-featured-events .slides {
        grid-template: auto / minmax(0, 3fr) minmax(0, 2fr);
        gap: 60px;
    }

    .core-featured-events .shared-play-button {
        inset: 50% auto auto 50%;
        transform: translate(-50%, -50%);
    }

    /*----- marquee left -----*/
    
    .core-featured-events.marquee-left .slides {
        grid-template: auto / minmax(0, 2fr) minmax(0, 3fr);
    }
}