/*
Theme Name: Twenty Twenty-Five Child
Theme URI: https://michaelprinc.com/
Description: Child theme with performance and accessibility optimizations.
Author: Michael Princ
Template: twentytwentyfive
Version: 1.0.0
Text Domain: twentytwentyfive-child
*/

:root {
	--mp-button-radius: 999px;
	--mp-button-padding-y: 0.95rem;
	--mp-button-padding-x: 1.55rem;
	--mp-button-border: rgba(15, 23, 42, 0.16);
	--mp-button-shadow-dark: 0 1rem 2rem rgba(15, 23, 42, 0.16);
	--mp-button-shadow-light: 0 0.85rem 1.8rem rgba(15, 23, 42, 0.08);
}

:root :where(.wp-block-buttons) {
	gap: 0.85rem;
}

:root :where(.wp-element-button, .wp-block-button__link) {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.2rem;
	padding: var(--mp-button-padding-y) var(--mp-button-padding-x);
	border: 1px solid #111111;
	border-radius: var(--mp-button-radius);
	background: #111111;
	color: #ffffff;
	font-size: 0.98rem;
	font-weight: 600;
	line-height: 1.1;
	text-decoration: none;
	box-shadow: var(--mp-button-shadow-dark);
	transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease, color 140ms ease, border-color 140ms ease;
}

:root :where(.wp-element-button:hover, .wp-block-button__link:hover) {
	transform: translateY(-1px);
	box-shadow: 0 1.2rem 2.4rem rgba(15, 23, 42, 0.2);
	text-decoration: none;
}

:root :where(.wp-element-button:focus, .wp-block-button__link:focus) {
	outline: 2px solid rgba(15, 23, 42, 0.35);
	outline-offset: 3px;
}

:root :where(.wp-block-button.is-style-outline .wp-element-button, .wp-block-button.is-style-outline .wp-block-button__link) {
	border-color: var(--mp-button-border);
	background: #ffffff;
	color: #111111;
	box-shadow: var(--mp-button-shadow-light);
}

:root :where(.wp-block-button.is-style-outline .wp-element-button:hover, .wp-block-button.is-style-outline .wp-block-button__link:hover) {
	background: #f8fafc;
	box-shadow: 0 1rem 2rem rgba(15, 23, 42, 0.12);
}

.mp-cookie-banner {
	position: fixed;
	right: 1rem;
	bottom: 1rem;
	z-index: 1000;
	display: grid;
	gap: 1rem;
	max-width: min(28rem, calc(100vw - 2rem));
	padding: 1rem 1.1rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 1rem;
	background: rgba(248, 250, 252, 0.98);
	box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.18);
	backdrop-filter: blur(16px);
}

.mp-cookie-banner[hidden],
.mp-cookie-manage[hidden] {
	display: none !important;
}

.mp-cookie-banner__close {
	position: absolute;
	top: 0.65rem;
	right: 0.7rem;
	border: 0;
	background: transparent;
	color: #475569;
	font-size: 1.3rem;
	line-height: 1;
	cursor: pointer;
}

.mp-cookie-banner.is-visible {
	animation: mp-cookie-banner-rise 180ms ease-out;
}

.mp-cookie-banner__content {
	display: grid;
	gap: 0.5rem;
}

.mp-cookie-banner__title,
.mp-cookie-banner__text {
	margin: 0;
}

.mp-cookie-banner__title {
	font-size: 1rem;
	font-weight: 700;
}

.mp-cookie-banner__text {
	font-size: 0.95rem;
	line-height: 1.55;
	color: #334155;
}

.mp-cookie-banner__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.mp-cookie-banner__button,
.mp-cookie-manage {
	border-radius: 999px;
	font: inherit;
	cursor: pointer;
	transition: transform 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
}

.mp-cookie-banner__button {
	padding: 0.8rem 1rem;
	border: 1px solid transparent;
}

.mp-cookie-banner__button:hover,
.mp-cookie-manage:hover {
	transform: translateY(-1px);
}

.mp-cookie-banner__button--primary {
	background: #0f172a;
	color: #fff;
	box-shadow: 0 0.75rem 1.5rem rgba(15, 23, 42, 0.22);
}

.mp-cookie-banner__button--secondary {
	background: transparent;
	border-color: rgba(15, 23, 42, 0.2);
	color: #0f172a;
}

.mp-cookie-manage {
	position: fixed;
	left: 1rem;
	bottom: 1rem;
	z-index: 999;
	padding: 0.65rem 0.95rem;
	border: 1px solid rgba(15, 23, 42, 0.18);
	background: rgba(255, 255, 255, 0.96);
	color: #0f172a;
	box-shadow: 0 0.75rem 1.5rem rgba(15, 23, 42, 0.14);
}

@keyframes mp-cookie-banner-rise {
	from {
		opacity: 0;
		transform: translateY(0.75rem);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (max-width: 640px) {
	.mp-cookie-banner {
		right: 0.75rem;
		bottom: 0.75rem;
		left: 0.75rem;
		max-width: none;
	}

	.mp-cookie-banner__actions {
		flex-direction: column;
	}

	.mp-cookie-banner__button,
	.mp-cookie-manage {
		width: 100%;
		justify-content: center;
	}

	.mp-cookie-manage {
		left: 0.75rem;
		right: 0.75rem;
		bottom: 0.75rem;
		text-align: center;
	}
}
