﻿
.hymn-favorites__wrapper {
	position: sticky;
	top: 9rem;
}

.hymn-favorites__heart {
	display: inline-block;
	font-size: 25px;
	line-height: 1;
	cursor: pointer;
	-webkit-user-select: none;
	user-select: none;
}

.hymn-favorites__heart--large {
	display: inline-block;
	font-size: 35px;
}

.hymn-favorites__heart--active {
	animation: heart 0.3s ease;
	color: red;
	transform: scale(1.1);
}

.hymn-favorites__list {
	display: grid;
	gap: 0.75rem;
	list-style-type: none;
	padding-left: 0;
}

.hymn-favorites__item {
	display: flex;
	justify-content: space-between;
}

.hymn-favorites__remove {
	cursor: pointer;
}

.hymn-favorites__actions {
	display: flex;
	justify-content: space-between;
	gap: 0.5rem;
	margin-top: 1rem;
}

	.hymn-favorites__actions a:hover,
	.hymn-favorites__actions a:focus {
		color: white !important;
	}

.hymn-favorites__list:empty + .hymn-favorites__actions {
	display: none;
}


.hymn-favorites__copy {
	overflow: visible !important;
}

	.hymn-favorites__copy::after {
		content: attr(data-title);
		position: absolute;
		top: calc(100% + 0.75rem);
		left: 50%;
		transform: translateX(-50%);
		line-height: 1;
		border-radius: 3px;
		background-color: #a09898;
		padding: 0.375rem 0.75rem;
		transition: opacity 0.2s;
		transition-delay: 0.2s;
		opacity: 0;
	}


	.hymn-favorites__copy:hover::after {
		transition-delay: 0s;
		opacity: 1;
	}

.hymn-favorites__copy--success::after {
	background-color: #5cb85c;
}

.hymn-favorites__copy--failure::after {
	background-color: #d9534f;
}


@keyframes heart {
	0% {
		transform: scale(1.0);
		color: inherit;
	}

	50% {
		transform: scale(1.4);
	}

	100% {
		transform: scale(1.1);
		color: red;
	}
}
