/*
	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-v2-featured-events {
	--slide-title-size: var(--text-base);
	--promoted-slide-title-size: var(--text-lg);
	--slide-desc-size: var(--text-sm);
	--date-picker-button-background-color: var(--sw-button-primary-bg);
	--date-picker-button-color: var(--sw-button-primary-color);
}

.core-v2-featured-events.ccl-v2-widget .widget-inner {
	gap: var(--space-5);
}

.core-v2-featured-events .widget-title-text {
	line-height: 1.1;
}

.core-v2-featured-events .view-all-col {
	justify-content: start;
}

.core-v2-featured-events .widget-view-all {
	font-weight: bold;
}

.core-v2-featured-events .slides,
.core-v2-featured-events .date-picker-row {
	width: 100%;
	max-width: var(--width-base);
	margin: 0 auto;
	padding: 0 18px;
}

.core-v2-featured-events .slides {
	display: grid;
	grid-template: auto / minmax(0, 1fr);
	gap: var(--space-6);
}

/*----- date picker -----*/

.core-v2-featured-events .date-picker-row {
	margin-bottom: var(--space-5);
}

.core-v2-featured-events .date-picker-inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: var(--space-4);
	max-width: var(--width-comfortable);
}

.core-v2-featured-events .input-label {
	display: block;
	margin-bottom: var(--space-1);
	font-weight: bold;
}

.core-v2-featured-events .input {
	display: block;
	width: 100%;
	padding: var(--space-1) var(--space-2);
	border: 2px solid var(--black);
	border-radius: var(--rounded-md);
}

.core-v2-featured-events .form-button {
	justify-self: start;
	padding: var(--space-1) var(--space-5);
	text-align: center;
	font-weight: bold;
	color: var(--date-picker-button-color);
	background-color: var(--date-picker-button-background-color);
	border-radius: var(--rounded-full);
}

/*============================*/
/*=====----- SLIDES -----=====*/
/*============================*/

.core-v2-featured-events .slide,
.core-v2-featured-events .img-cont,
.core-v2-featured-events .slide-img {
	position: relative;
	z-index: 1;
	overflow: visible;
}

.core-v2-featured-events .content-upper {
	gap: var(--space-2);
}

.core-v2-featured-events .category {
	display: block;
	margin-bottom: var(--space-1);
}

.core-v2-featured-events .slide-title {
	font-size: var(--slide-title-size);
}

.core-v2-featured-events .info-item a {
	font-size: inherit;
}

.core-v2-featured-events .slide-desc {
	font-size: var(--slide-desc-size);
}

.core-v2-featured-events .details {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 5px 16px;
	font-size: var(--text-sm);
	padding-left: 5px;
}

.core-v2-featured-events .shared-play-button {
	inset: 16px 16px auto auto;
	transform: none;
}

/*----- minor slide -----*/
.core-v2-featured-events .slide.minor {
	margin-bottom: var(--space-2);
}

.core-v2-featured-events .slide.minor.has-date {
	left: -6px;
}
.core-v2-featured-events .slide.minor.has-date > .inner {
	display: grid;
	grid-template: auto / minmax(0, 87.3px) minmax(0, 4fr);
	gap: var(--space-2);
	align-items: start;
}

.core-v2-featured-events .slide.minor .content-upper {
	gap: var(--space-1);
}
.core-v2-featured-events .slide.minor .slide-title {
	letter-spacing: -0.01em;
	font-size: 0.9375rem;
}
.core-v2-featured-events .slide.minor .details {
	font-weight: 500;
	color: var(--deep-blue);
}
.core-v2-featured-events .slide.minor .category {
	margin-bottom: 2px;
	line-height: 1.2;
}

.core-v2-featured-events .slide.minor .mini-date-section {
	--month-size: var(--text-xs);
	--day-size: var(--text-xl);

	position: static;
}

/*----- promoted slide -----*/

.core-v2-featured-events .slide.promoted .mini-date-section {
	z-index: 10;
}
.core-v2-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-8) 14px var(--space-4);
	color: var(--white);
	text-shadow: 0 0 16px rgba(0,0,0,.5);
	pointer-events: none;
}

.core-v2-featured-events .slide.promoted .content-section a {
	pointer-events: all;
}

.core-v2-featured-events .slide.promoted .slide-title,
.core-v2-featured-events .slide.promoted .details,
.core-v2-featured-events .slide.promoted .details li a,
.core-v2-featured-events .slide.promoted .slide-desc {
	color: inherit;
}

.core-v2-featured-events .slide.promoted .details li a {
	gap: 6px;
}
.core-v2-featured-events .slide.promoted .slide-title {
	font-size: var(--promoted-slide-title-size);
	letter-spacing: -0.01em;
}
.core-v2-featured-events .slide.promoted .details {
	font-size: var(--text-xs);
}   
.core-v2-featured-events .slide.promoted .details li .icon,
.core-v2-featured-events .slide.promoted .details li .icon::before {
	display: inline-block;
	text-decoration: none;
	font-size: var(--text-sm);
}

.core-v2-featured-events .slide .details li .icon {
	color: var(--red);
}

.core-v2-featured-events .slide.promoted .img-cont::before {
	display: block;
	background: linear-gradient(to top, rgba(0,0,0,.5), rgba(0,0,0,0));
}

.core-v2-featured-events.ccl-v2-widget .mini-date-section {
	font-feature-settings: unset;
}
.core-v2-featured-events.ccl-v2-widget .mini-date-section::after {
	width: 60px;
	height: 60px;
}
/*===================================*/
/*=====----- MEDIA QUERIES -----=====*/
/*===================================*/

@media (hover: hover) {
	/*----- promoted slide -----*/

	.core-v2-featured-events .slide.promoted .slide-title a:hover {
		color: inherit;
		text-decoration: underline 2px;
		text-underline-offset: 1px;
	}
}

@media (min-width: 30em) {
	/*----- date picker -----*/

	.core-v2-featured-events .date-picker-inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.core-v2-featured-events .form-button {
		grid-column: span 2;
	}
}

@media (min-width: 40em) {
	.core-v2-featured-events .slides {
		grid-template: auto / repeat(2, minmax(0, 1fr));
		grid-auto-flow: dense;
	}

	.core-v2-featured-events .widget-footer {
		justify-content: start;
		align-self: end;
		width: 100%;
		max-width: none;
		padding: 0;
		margin: 0;
	}

	.core-v2-featured-events .img-cont,
	.core-v2-featured-events .slide-img {
		height: 100%;
	}

	.core-v2-featured-events .slide-img {
		object-fit: cover;
	}

	/*----- "view all" in header -----*/

	.core-v2-featured-events.view-all-in-header .widget-inner {
		display: block;
	}

	.core-v2-featured-events.view-all-in-header .widget-header {
		display: flex;
		justify-content: space-between;
		align-items: end;
		flex-wrap: wrap;
		gap: var(--space-5) var(--space-8);
		width: calc(100% - var(--space-10));
		max-width: calc(var(--width-base) - var(--space-10));
		padding-bottom: var(--space-3);
		margin: 0 auto var(--space-6);
		border-bottom: 2px solid var(--sw-collections-widget-header-border-color);
	}

	.core-v2-featured-events.view-all-in-header .widget-header .title-col,
	.core-v2-featured-events.view-all-in-header .widget-header .view-all-col {
		width: auto;
		margin: 0;
	}

	.core-v2-featured-events.view-all-in-header .widget-header .title-col {
		max-width: var(--width-comfortable);
		border-bottom: none;
	}

	.core-v2-featured-events.view-all-in-header .view-all-col {
		display: block;
		max-width: none;
	}

	/*----- "view all" in footer -----*/

	.core-v2-featured-events.view-all-in-footer .widget-inner {
		display: grid;
		grid-template-columns: 1fr 0.75fr;
		grid-auto-flow: dense;
		gap: var(--space-3) 0;
		width: 100%;
		max-width: 1218px;
		padding: 0 var(--space-5);
		margin: 0 auto;
	}

	.core-v2-featured-events.view-all-in-footer .title-col,
	.core-v2-featured-events.view-all-in-footer .date-picker-row {
		grid-column: span 2;
	}

	.core-v2-featured-events.view-all-in-footer .date-picker-row {
		padding: 0;
		margin: 0;
	}

	.core-v2-featured-events.view-all-in-footer .title-col {
		width: 100%;
		margin-bottom: var(--space-1);
		grid-column: 1;
	}

	.core-v2-featured-events.view-all-in-footer .view-all-col {
		display: block;
		grid-column: 2;
		grid-row: 6;
		align-self: end;
		width: auto;
		max-width: none;
		margin: 0;
	}

	.core-v2-featured-events.view-all-in-footer.no-date-picker .view-all-col {
		grid-row: 1;
		justify-self: end;
		align-self: flex-start;
	}

	.core-v2-featured-events.view-all-in-footer .slides {
		display: contents;
	}

	/*----- date picker -----*/

	.core-v2-featured-events .date-picker-inner {
		display: flex;
		gap: 0;
		align-items: flex-end;
	}

	.core-v2-featured-events .date-picker-inner > * {
		margin-right: var(--space-4);
	}

	.core-v2-featured-events .date-picker-inner > *:last-child {
		margin-right: 0;
	}

	.core-v2-featured-events .input-col {
		flex-grow: 1;
	}

	.core-v2-featured-events .form-buttom {
		flex-shrink: 0;
	}

	/*----- minor slide -----*/
	.core-v2-featured-events .slide.minor {
		align-self: center;
		padding-left: 22px;
	}
	
	.core-v2-featured-events .slide.minor.has-date {
		left: -22px;
		padding-left: 0;
	}
	.core-v2-featured-events .slide.minor.has-date > .inner {
		grid-template: auto / auto minmax(0, 1fr);
		gap: var(--space-5);
		align-items: center;
	}

	.core-v2-featured-events .slide.minor .content-section {
		margin: 0;
	}

	.core-v2-featured-events .slide.minor .mini-date-section {
		--month-size: 0.65rem;
		--day-size: var(--text-xl);
	}

	/*----- promoted slide -----*/

	.core-v2-featured-events .slide.promoted {
		grid-column: span 1;
		grid-row: span 3;
	}

	.core-v2-featured-events .slide.promoted .content-section {
		padding-right: var(--space-10) ;
	}

	/*----- marquee left -----*/

	.core-v2-featured-events.marquee-left.view-all-in-footer .view-all-col,
	.core-v2-featured-events.marquee-left .slide.minor {
		grid-column: 1;
	}

	.core-v2-featured-events.marquee-left .slide.promoted {
		grid-column: 2;
	}

	/*----- marquee bottom -----*/

	.core-v2-featured-events.marquee-bottom .slides {
		grid-template: auto / repeat(3, minmax(0, 1fr));
		gap: var(--space-8) var(--space-5);
	}

	.core-v2-featured-events.marquee-bottom .slide.promoted {
		grid-row: span 1;
		grid-column: span 3;
	}
}

@media (min-width: 64em) {
	.core-v2-featured-events {
		--slide-title-size: var(--text-xl);
		--promoted-slide-title-size: 1.5625rem;
		--slide-desc-size: var(--text-base);
	}
	.core-v2-featured-events.ccl-v2-widget .widget-title {
		font-size: 2.5rem;
	}

	.core-v2-featured-events.ccl-v2-widget .widget-title-text {
		letter-spacing: -0.01em;
	}

	.core-v2-featured-events .slides,
	.core-v2-featured-events.view-all-in-footer .widget-inner {
		gap: var(--space-4) 0;
	}
	.core-v2-featured-events.view-all-in-footer .widget-inner {
		padding: 0 var(--space-5) 0 var(--space-10);

	}

	.core-v2-featured-events .slide:is(.minor, .promoted) .mini-date-section {
		--month-size: var(--text-sm);
		--day-size: 1.75rem;
		height: 120px;
		width: 120px;
		padding: var(--space-4);
	}
	.core-v2-featured-events .slide .mini-date-section::after {
		width: 85px;
		height: 85px;
		transition: height var(--transition-appendix), width var(--transition-appendix);
	}

	.core-v2-featured-events .view-all-col {
		margin-left: auto;
	}
	/*----- "view all" in footer -----*/

	.core-v2-featured-events.view-all-in-footer .widget-header {
		display: contents;
	}

	.core-v2-featured-events.view-all-in-footer .title-col {
		max-width: none;
		margin: 0;
		margin-bottom: var(--space-8);
	}

	/*----- minor slide -----*/
	.core-v2-featured-events .slide.minor {
		position: relative;
		align-self: center;
		padding-left: 40px;
		margin-bottom: 0;
	}
	.core-v2-featured-events .slide.minor:nth-child(2) {
		margin-top: 30px;
	}
	.core-v2-featured-events .slide.minor:nth-child(4) {
		margin-bottom: 30px;
	}
	.core-v2-featured-events .slide.minor.has-date {
		left: -40px;
		padding-left: 0;
	}
	.core-v2-featured-events .slide.minor.has-date > .inner {
		grid-template: auto / auto minmax(0, 1fr);
	}
	.core-v2-featured-events .slide.minor .slide-title {
		font-size: var(--text-xl);
	}
	.core-v2-featured-events .slide.minor .category,
	.core-v2-featured-events .slide.minor .details {
		font-size: var(--text-sm);
	}

	/*----- promoted slide -----*/

	.core-v2-featured-events .slide.promoted .content-section {
		max-width: var(--width-comfortable);
		padding: var(--space-8) var(--space-8) var(--space-12) 30px;
	}

	.core-v2-featured-events .slide.promoted.has-date .content-section {
		padding-left: 106px;
	}
	.core-v2-featured-events .slide.promoted .details {
		font-size: var(--text-sm);
	}
	.core-v2-featured-events .slide:is(.minor, .promoted) .mini-date-section {
		top: unset;
		bottom: 20px;
		left: -32px;
	}

	.core-v2-featured-events .slide:is(.minor, .promoted):hover .mini-date-section:after {
		width: 95px;
		height: 95px;
	}

	/*----- marquee bottom -----*/

	.core-v2-featured-events.marquee-bottom {
		--slide-title-size: var(--text-lg);
	}

	.core-v2-featured-events.marquee-bottom .slides {
		grid-template: auto / repeat(3, minmax(0, 1fr));
	}

	.core-v2-featured-events.marquee-bottom .slide.promoted {
		grid-column: span 3;
	}

	.core-v2-featured-events.marquee-bottom .slide.minor .category,
	.core-v2-featured-events.marquee-bottom .slide.minor .details {
		font-size: var(--text-xs);
	}
}

@media (min-width: 80em) {

	.core-v2-featured-events.view-all-in-footer .widget-inner,
	.core-v2-featured-events .slides {
		grid-template: auto / minmax(0, 2.9fr) minmax(0, 2fr);
	}

	.core-v2-featured-events .shared-play-button {
		inset: 50% auto auto 50%;
		transform: translate(-50%, -50%);
	}

	/*----- marquee left -----*/
	
	.core-v2-featured-events.marquee-left.view-all-in-footer .widget-inner,
	.core-v2-featured-events.marquee-left .slides {
		grid-template: auto / minmax(0, 2fr) minmax(0, 3fr);
	}
}