/**
 * Showrooms block — front end (+ shortcode when theme enqueues this file).
 */

.showroom-card,
.showroom-card *:not(.showroom-card__toggle):not(.showroom-card__toggle *) {
	color: var(--white);
}

.showrooms {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 380px), 1fr));
	gap: 24px;
	align-items: start;
}

.showroom-card__box {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: 16px;
	background-color: var(--rock);
}

.showroom-card__media {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.showroom-card__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--transition-zoom);
	transform: scale(1);
}

.showroom-card:hover .showroom-card__image {
	transform: scale(1.08);
}

.showroom-card__bg-shade {
	position: absolute;
	inset: 0;
	z-index: 1;
	background-color: rgba(0, 0, 0, 0.2);
	transition: var(--transition-zoom-overlay);
}

.showroom-card:hover .showroom-card__bg-shade {
	background-color: rgba(0, 0, 0, 0);
}

.showroom-card__front {
	position: relative;
	z-index: 2;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 24px 76px 24px 24px;
	min-height: 0;
	transition: opacity 200ms var(--fast-bezier), visibility 200ms var(--fast-bezier);
}

.showroom-card__title {
	color: var(--white);
}

.showroom-card__toggle {
	position: absolute;
	bottom: 24px;
	right: 24px;
	z-index: 5;
	width: 45px;
	height: 45px;
	padding: 0;
	border: none;
	background-color: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--transition-fast);
}

.showroom-card__toggle:focus-visible {
	outline: 2px dashed var(--focus-outline);
	outline-offset: 4px;
	border-radius: 4px;
}

.showroom-card__symbol {
	display: block;
	width: 45px;
	height: 45px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 45px 45px;
}

.showroom-card__symbol--open {
	background-image: url('../../img/plus.svg');
}

.showroom-card__symbol--close {
	background-image: url('../../img/minus.svg');
}

.showroom-card.is-expanded .showroom-card__symbol--open,
.showroom-card.is-expanded .showroom-card__toggle-label-open {
	display: none;
}

.showroom-card:not(.is-expanded) .showroom-card__symbol--close,
.showroom-card:not(.is-expanded) .showroom-card__toggle-label-close {
	display: none;
}

.showroom-card.is-expanded .showroom-card__front {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.showroom-card__detail {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	padding: 48px 24px 24px;
	overflow: auto;
	background-color: var(--rock);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 200ms var(--fast-bezier), visibility 200ms var(--fast-bezier);
}

.showroom-card__detail-title {
	color: var(--white);
	margin-bottom: 16px;
}

.showroom-card__map-link {
	display: inline-block;
	margin-top: 16px;
	color: var(--white);
	text-decoration: underline;
}

.showroom-card__map-link:hover,
.showroom-card__map-link:focus {
	color: var(--cloud);
}

.showroom-card__status {
	display: inline-block;
	margin-left: 0.25em;
	font-family: var(--font-primary);
	font-size: var(--text-small);
	font-weight: var(--font-primary-weight);
	letter-spacing: 0;
	vertical-align: middle;
}

.showroom-card--coming-soon .showroom-card__box {
	background-color: var(--sky);
}

.showroom-card.is-expanded .showroom-card__detail {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.showroom-card__detail .contact-numbers {
	list-style-type: none;
	padding-left: 0;
	margin: 0;
}

.showroom-card__detail .contact-numbers * {
	color: var(--white);
	font-size: var(--text-small);
	font-family: var(--font-primary);
}

.showroom-card__detail .contact-numbers a {
	color: var(--white);
}

.showroom-card__detail .contact-numbers li {
	padding-left: 0;
	margin-left: 0;
	line-height: 1.75;
}

.showroom-card__detail .contact-numbers .address {
	margin-bottom: 16px;
}

.showroom-card__detail .contactProp {
	min-width: 3.3rem;
}


@media (prefers-reduced-motion: reduce) {
	.showroom-card__front,
	.showroom-card__detail {
		transition: none;
	}
}
