.image-stack {
	display: grid;
	height: 100%;
	overflow: hidden;
	border-radius: var(--sl-border-radius-x-large);
	position: relative;
}

.image-stack>img {
	grid-area: 1 / 1;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--sl-border-radius-x-large);
	z-index: 2;
}

.card-wrapper {
	position: relative;
	display: grid;
}

.card-skeleton {
	position: absolute;
	inset: 0;
	--border-radius: var(--sl-border-radius-large);
	z-index: 10;
}

.card-skeleton::part(base) {
	height: 100%;
	width: 100%;
	border-radius: var(--sl-border-radius-large);
}

.place-title {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: top;
	align-self: center;
}

.place-title>span {
	line-height: var(--sl-line-height-denser);
	word-wrap: break-word;
}

.place-title>div {
	white-space: nowrap;
}

.place-description {
	font-size: var(--sl-font-size-medium);
	font-weight: var(--sl-font-weight-light);
	color: var(--sl-color-neutral-500);
	line-height: var(--sl-line-height-normal);
	word-wrap: break-word;
}

.star-icon {
	font-size: var(--sl-font-size-small);
}

/* --- panel size --- */

.place-card--panel {
	--border-width: 0;
	--border-radius: var(--sl-border-radius-large);
	transition: transform 0.2s ease;
}

.place-card--panel::part(base) {
	height: 100%;
	box-shadow: none;
}

.place-card--panel::part(image) {
	aspect-ratio: 4 / 3;
}

.place-card--panel::part(body) {
	flex: 1;
	padding-left: 0;
	padding-right: 0;
}

.place-card--panel::part(footer) {
	padding-top: 0;
	padding-bottom: 0;
}

.place-card--panel .place-title>span {
	font-size: var(--sl-font-size-medium);
	font-weight: var(--sl-font-weight-semibold);
	color: var(--sl-color-neutral-1000);
}

/* --- popup size --- */

.place-card--popup {
	font-family: var(--sl-font-sans);
	--border-width: 0;
	--border-radius: var(--sl-border-radius-x-large);
}

.place-card--popup .image-stack,
.place-card--popup .image-stack>img {
	border-radius: var(--sl-border-radius-x-large) var(--sl-border-radius-x-large) 0 0;
}

.place-card--popup::part(base) {
	box-shadow: none;
	background: transparent;
	border: none;
}

.place-card--popup::part(image) {
	aspect-ratio: 4 / 3;
}

.place-card--popup::part(body) {
	padding: 12px 12px 0;
}

.place-card--popup::part(footer) {
	padding: 4px 8px 8px;
}

.place-card--popup .place-title>span {
	font-size: var(--sl-font-size-small);
	font-weight: var(--sl-font-weight-semibold);
	color: var(--sl-color-neutral-1000);
}

.place-card--popup .place-title>div {
	font-size: var(--sl-font-size-x-small);
}

.place-card--popup .place-description {
	font-size: var(--sl-font-size-x-small);
}

.place-card--popup .star-icon {
	font-size: var(--sl-font-size-x-small);
}

.place-card--popup sl-button::part(base) {
	font-size: var(--sl-font-size-x-small);
	padding: 6px 8px;
}

.close-icon {
	position: absolute;
	top: 12px;
	right: 12px;
	background: rgba(255, 255, 255, 0.9);
	color: var(--sl-color-neutral-1000);
	border-radius: var(--sl-border-radius-circle);
	border-color: var(--sl-color-neutral-100);
	font-size: 12px;
	padding: 8px;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
}