/**
 * Cookie consent banner — fixed bottom, slides in on first visit.
 *
 * Initial state is off-screen (translateY 100%) + invisible; the
 * accompanying JS adds .is-visible on next animation frame so the
 * transition triggers cleanly. On accept/decline, the class is removed
 * and the element gets removed from the DOM after the transition ends.
 *
 * z-index 200 — above the sticky header (which sits at 100).
 *
 * @package mhg-theme
 */

.mhg-cookie-banner {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 200;
	background-color: #2b2b2b;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 -8px 28px rgba(0, 0, 0, 0.25);
	transform: translateY(100%);
	opacity: 0;
	pointer-events: none;
	transition: transform 0.35s ease, opacity 0.35s ease;
}

.mhg-cookie-banner.is-visible {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}

.mhg-cookie-banner__inner {
	max-width: 900px;
	margin: 0 auto;
	padding: 1.1rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	align-items: stretch;
	box-sizing: border-box;
}

.mhg-cookie-banner__text {
	flex: 1;
	margin: 0;
	font-family: var(--mhg-font-body);
	font-size: 0.85rem;
	font-weight: 300;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.75);
}

.mhg-cookie-banner__link {
	color: var(--mhg-color-gold);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color var(--mhg-transition-fast);
}

.mhg-cookie-banner__link:hover,
.mhg-cookie-banner__link:focus {
	color: var(--mhg-color-white);
	outline: none;
}

.mhg-cookie-banner__buttons {
	display: flex;
	gap: 0.6rem;
	flex-shrink: 0;
	flex-wrap: wrap;
}

.mhg-cookie-banner__button {
	flex: 1;
	padding: 0.55rem 1.1rem;
	font-family: var(--mhg-font-body);
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: var(--mhg-letter-spacing-button);
	border-radius: var(--mhg-radius-sm);
	cursor: pointer;
	transition: background-color var(--mhg-transition-fast),
		border-color var(--mhg-transition-fast),
		color var(--mhg-transition-fast);
	white-space: nowrap;
}

.mhg-cookie-banner__button:focus-visible {
	outline: 2px solid var(--mhg-color-gold);
	outline-offset: 2px;
}

.mhg-cookie-banner__button--accept {
	background-color: var(--mhg-color-teal);
	color: var(--mhg-color-white);
	border: 1px solid var(--mhg-color-teal);
}

.mhg-cookie-banner__button--accept:hover,
.mhg-cookie-banner__button--accept:focus {
	background-color: var(--mhg-color-teal-dark);
	border-color: var(--mhg-color-teal-dark);
}

.mhg-cookie-banner__button--decline {
	background-color: transparent;
	color: var(--mhg-color-white);
	border: 1px solid rgba(255, 255, 255, 0.3);
}

.mhg-cookie-banner__button--decline:hover,
.mhg-cookie-banner__button--decline:focus {
	background-color: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.5);
}

@media (min-width: 768px) {
	.mhg-cookie-banner__inner {
		flex-direction: row;
		align-items: center;
		gap: 1.5rem;
		padding: 1.1rem 2rem;
	}

	.mhg-cookie-banner__buttons {
		flex-wrap: nowrap;
	}

	.mhg-cookie-banner__button {
		flex: 0 0 auto;
	}
}
