/* Trikona shared login button animations. */
.tri-login-animated-button {
	--tri-login-base: #0A66C2;
	--tri-login-accent: #FFC000;
	--tri-login-loading: #111827;
	--tri-login-success: #21A67A;
	--tri-login-text: #FFFFFF;
	--tri-login-speed: 900ms;

	position: relative;
	isolation: isolate;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 46px;
	min-width: 168px;
	max-width: 100%;
	padding: 0.75rem 1.1rem;
	overflow: hidden;
	border: 2px solid transparent;
	border-radius: 10px;
	background: var(--tri-login-base);
	color: var(--tri-login-text);
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	text-decoration: none;
	letter-spacing: 0;
	box-shadow: 0 12px 24px color-mix(in srgb, var(--tri-login-base) 28%, transparent);
	cursor: pointer;
	transform: translateZ(0);
	transition:
		background-color 180ms ease,
		box-shadow 220ms ease,
		color 180ms ease,
		transform 160ms ease;
}

.tri-block a.tri-login-animated-button,
.tri-btn-linkedin.tri-login-animated-button,
#triPwLogin .tri-login-animated-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0.75rem 1.1rem;
	border: 2px solid transparent;
	border-radius: 10px;
	background: var(--tri-login-base);
	color: var(--tri-login-text);
	box-shadow: 0 12px 24px color-mix(in srgb, var(--tri-login-base) 28%, transparent);
	text-align: center;
	text-decoration: none;
}

.tri-login-animated-button:hover,
.tri-login-animated-button:focus,
.tri-block a.tri-login-animated-button:hover,
.tri-block a.tri-login-animated-button:focus,
.tri-btn-linkedin.tri-login-animated-button:hover,
.tri-btn-linkedin.tri-login-animated-button:focus,
#triPwLogin .tri-login-animated-button:hover,
#triPwLogin .tri-login-animated-button:focus {
	color: var(--tri-login-text);
	text-decoration: none;
	transform: translateY(-1px);
}

.tri-login-animated-button:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--tri-login-accent) 55%, transparent);
	outline-offset: 3px;
}

.tri-login-animated-button::before,
.tri-login-animated-button::after {
	position: absolute;
	inset: 0;
	z-index: 0;
	content: "";
	pointer-events: none;
}

.tri-login-animated-button__text {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	max-width: 100%;
	white-space: normal;
	transition:
		opacity 160ms ease,
		transform 180ms ease,
		filter 180ms ease;
}

.tri-login-animated-button.is-tri-text-swapping .tri-login-animated-button__text {
	opacity: 0;
	transform: translateY(-0.45rem);
	filter: blur(4px);
}

.tri-login-animated-button.is-tri-clicked {
	transform: scale(0.98);
}

.tri-login-animated-button.is-tri-loading {
	background: var(--tri-login-loading);
	box-shadow:
		0 14px 28px color-mix(in srgb, var(--tri-login-loading) 34%, transparent),
		0 0 0 1px color-mix(in srgb, var(--tri-login-accent) 28%, transparent) inset;
}

.tri-block a.tri-login-animated-button.is-tri-loading,
.tri-btn-linkedin.tri-login-animated-button.is-tri-loading,
#triPwLogin .tri-login-animated-button.is-tri-loading {
	background: var(--tri-login-loading);
	box-shadow:
		0 14px 28px color-mix(in srgb, var(--tri-login-loading) 34%, transparent),
		0 0 0 1px color-mix(in srgb, var(--tri-login-accent) 28%, transparent) inset;
}

.tri-login-animated-button.is-tri-success {
	background: var(--tri-login-success);
	box-shadow:
		0 14px 30px color-mix(in srgb, var(--tri-login-success) 38%, transparent),
		0 0 0 1px color-mix(in srgb, #fff 30%, transparent) inset;
}

.tri-block a.tri-login-animated-button.is-tri-success,
.tri-btn-linkedin.tri-login-animated-button.is-tri-success,
#triPwLogin .tri-login-animated-button.is-tri-success {
	background: var(--tri-login-success);
	box-shadow:
		0 14px 30px color-mix(in srgb, var(--tri-login-success) 38%, transparent),
		0 0 0 1px color-mix(in srgb, #fff 30%, transparent) inset;
}

.tri-login-animated-button.is-tri-success .tri-login-animated-button__text::before {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.15em;
	height: 1.15em;
	margin-right: 0.45rem;
	border-radius: 999px;
	background: color-mix(in srgb, #fff 18%, transparent);
	content: "\2713";
	font-size: 0.8em;
	line-height: 1;
}

.tri-login-hover--default:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-login-hover--default:focus:not(.is-tri-loading):not(.is-tri-success),
.tri-block a.tri-login-hover--default:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-block a.tri-login-hover--default:focus:not(.is-tri-loading):not(.is-tri-success),
.tri-btn-linkedin.tri-login-hover--default:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-btn-linkedin.tri-login-hover--default:focus:not(.is-tri-loading):not(.is-tri-success),
#triPwLogin .tri-login-hover--default:hover:not(.is-tri-loading):not(.is-tri-success),
#triPwLogin .tri-login-hover--default:focus:not(.is-tri-loading):not(.is-tri-success) {
	background: color-mix(in srgb, var(--tri-login-base) 82%, #000);
	box-shadow:
		0 16px 30px color-mix(in srgb, var(--tri-login-base) 34%, transparent),
		0 0 0 1px color-mix(in srgb, #fff 16%, transparent) inset;
}

.tri-login-hover--animation:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-login-hover--animation:focus:not(.is-tri-loading):not(.is-tri-success),
.tri-block a.tri-login-hover--animation:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-block a.tri-login-hover--animation:focus:not(.is-tri-loading):not(.is-tri-success),
.tri-btn-linkedin.tri-login-hover--animation:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-btn-linkedin.tri-login-hover--animation:focus:not(.is-tri-loading):not(.is-tri-success),
#triPwLogin .tri-login-hover--animation:hover:not(.is-tri-loading):not(.is-tri-success),
#triPwLogin .tri-login-hover--animation:focus:not(.is-tri-loading):not(.is-tri-success) {
	background: color-mix(in srgb, var(--tri-login-base) 82%, var(--tri-login-loading));
	box-shadow:
		0 16px 32px color-mix(in srgb, var(--tri-login-accent) 26%, transparent),
		0 0 0 1px color-mix(in srgb, var(--tri-login-accent) 40%, transparent) inset;
}

.tri-login-hover--animation.tri-login-animation--launch:hover:not(.is-tri-loading):not(.is-tri-success)::before,
.tri-login-hover--animation.tri-login-animation--launch:focus:not(.is-tri-loading):not(.is-tri-success)::before {
	background:
		linear-gradient(90deg, transparent 0%, color-mix(in srgb, var(--tri-login-accent) 72%, #fff) 45%, transparent 60%),
		linear-gradient(90deg, color-mix(in srgb, var(--tri-login-base) 70%, var(--tri-login-loading)), color-mix(in srgb, var(--tri-login-loading) 78%, var(--tri-login-accent)));
	transform: translateX(-115%);
	animation: tri-login-scan calc(var(--tri-login-speed) * 1.15) cubic-bezier(0.22, 1, 0.36, 1) infinite;
}

.tri-login-hover--animation.tri-login-animation--launch:hover:not(.is-tri-loading):not(.is-tri-success)::after,
.tri-login-hover--animation.tri-login-animation--launch:focus:not(.is-tri-loading):not(.is-tri-success)::after {
	inset: auto 14% 7px;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, transparent, var(--tri-login-accent), transparent);
	box-shadow: 0 0 14px var(--tri-login-accent);
	animation: tri-login-runway var(--tri-login-speed) ease-in-out infinite;
}

.tri-login-hover--animation.tri-login-animation--scan:hover:not(.is-tri-loading):not(.is-tri-success)::before,
.tri-login-hover--animation.tri-login-animation--scan:focus:not(.is-tri-loading):not(.is-tri-success)::before {
	background: linear-gradient(105deg, transparent 0%, color-mix(in srgb, #fff 28%, var(--tri-login-accent)) 42%, transparent 64%);
	transform: translateX(-115%) skewX(-18deg);
	animation: tri-login-scan calc(var(--tri-login-speed) * 0.95) linear infinite;
}

.tri-login-hover--animation.tri-login-animation--scan:hover:not(.is-tri-loading):not(.is-tri-success)::after,
.tri-login-hover--animation.tri-login-animation--scan:focus:not(.is-tri-loading):not(.is-tri-success)::after {
	inset: 3px;
	border: 1px solid color-mix(in srgb, var(--tri-login-accent) 60%, transparent);
	border-radius: inherit;
	box-shadow: 0 0 16px color-mix(in srgb, var(--tri-login-accent) 42%, transparent) inset;
}

.tri-login-hover--animation.tri-login-animation--liquid:hover:not(.is-tri-loading):not(.is-tri-success)::before,
.tri-login-hover--animation.tri-login-animation--liquid:focus:not(.is-tri-loading):not(.is-tri-success)::before {
	top: auto;
	height: 120%;
	background:
		radial-gradient(circle at 22% 28%, color-mix(in srgb, #fff 35%, var(--tri-login-accent)) 0 8%, transparent 9%),
		radial-gradient(circle at 68% 22%, color-mix(in srgb, #fff 18%, var(--tri-login-accent)) 0 11%, transparent 12%),
		linear-gradient(180deg, color-mix(in srgb, #fff 12%, var(--tri-login-accent)), var(--tri-login-accent));
	border-radius: 40% 44% 0 0;
	opacity: 0.72;
	transform: translateY(68%);
	animation: tri-login-liquid calc(var(--tri-login-speed) * 1.2) ease-in-out infinite alternate;
}

.tri-login-hover--animation.tri-login-animation--neon:hover:not(.is-tri-loading):not(.is-tri-success),
.tri-login-hover--animation.tri-login-animation--neon:focus:not(.is-tri-loading):not(.is-tri-success) {
	background:
		linear-gradient(var(--tri-login-base), var(--tri-login-base)) padding-box,
		conic-gradient(from var(--tri-login-angle), var(--tri-login-accent), #fff, var(--tri-login-base), var(--tri-login-accent)) border-box;
	border: 2px solid transparent;
	animation: tri-login-border-spin calc(var(--tri-login-speed) * 1.1) linear infinite;
}

.tri-login-hover--animation.tri-login-animation--neon:hover:not(.is-tri-loading):not(.is-tri-success)::after,
.tri-login-hover--animation.tri-login-animation--neon:focus:not(.is-tri-loading):not(.is-tri-success)::after {
	inset: -16px;
	background: radial-gradient(circle, color-mix(in srgb, var(--tri-login-accent) 22%, transparent), transparent 58%);
	filter: blur(14px);
	opacity: 0.7;
}

.tri-login-hover--animation.tri-login-animation--portal:hover:not(.is-tri-loading):not(.is-tri-success)::before,
.tri-login-hover--animation.tri-login-animation--portal:focus:not(.is-tri-loading):not(.is-tri-success)::before {
	inset: 50%;
	width: 12px;
	height: 12px;
	border: 2px solid color-mix(in srgb, var(--tri-login-accent) 70%, transparent);
	border-radius: 999px;
	background: color-mix(in srgb, var(--tri-login-accent) 20%, transparent);
	box-shadow: 0 0 24px var(--tri-login-accent);
	transform: translate(-50%, -50%) scale(1);
	animation: tri-login-portal calc(var(--tri-login-speed) * 1.1) ease-out infinite;
}

.tri-login-hover--animation.tri-login-animation--portal:hover:not(.is-tri-loading):not(.is-tri-success)::after,
.tri-login-hover--animation.tri-login-animation--portal:focus:not(.is-tri-loading):not(.is-tri-success)::after {
	background: radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--tri-login-accent) 20%, transparent), transparent 42%);
}

.tri-login-animation--launch.is-tri-loading::before {
	background:
		linear-gradient(90deg, transparent 0%, color-mix(in srgb, var(--tri-login-accent) 78%, #fff) 45%, transparent 58%),
		linear-gradient(90deg, var(--tri-login-loading), color-mix(in srgb, var(--tri-login-loading) 70%, var(--tri-login-accent)));
	transform: translateX(-120%);
	animation: tri-login-scan var(--tri-login-speed) cubic-bezier(0.22, 1, 0.36, 1) infinite;
}

.tri-login-animation--launch.is-tri-loading::after {
	inset: auto 12% 7px;
	height: 3px;
	border-radius: 999px;
	background: linear-gradient(90deg, transparent, var(--tri-login-accent), transparent);
	box-shadow: 0 0 16px var(--tri-login-accent);
	animation: tri-login-runway calc(var(--tri-login-speed) * 0.8) ease-in-out infinite;
}

.tri-login-animation--scan.is-tri-loading::before {
	background: linear-gradient(105deg, transparent 0%, color-mix(in srgb, #fff 22%, var(--tri-login-accent)) 42%, transparent 64%);
	transform: translateX(-115%) skewX(-18deg);
	animation: tri-login-scan calc(var(--tri-login-speed) * 0.8) linear infinite;
}

.tri-login-animation--scan.is-tri-loading::after {
	inset: 3px;
	border: 1px solid color-mix(in srgb, var(--tri-login-accent) 65%, transparent);
	border-radius: inherit;
	box-shadow: 0 0 18px color-mix(in srgb, var(--tri-login-accent) 50%, transparent) inset;
}

.tri-login-animation--liquid.is-tri-loading::before {
	top: auto;
	height: 140%;
	background:
		radial-gradient(circle at 20% 30%, color-mix(in srgb, #fff 35%, var(--tri-login-accent)) 0 10%, transparent 11%),
		radial-gradient(circle at 64% 22%, color-mix(in srgb, #fff 18%, var(--tri-login-accent)) 0 13%, transparent 14%),
		linear-gradient(180deg, color-mix(in srgb, #fff 15%, var(--tri-login-accent)), var(--tri-login-accent));
	border-radius: 38% 42% 0 0;
	transform: translateY(54%);
	animation: tri-login-liquid var(--tri-login-speed) ease-in-out infinite alternate;
}

.tri-login-animation--neon.is-tri-loading {
	background:
		linear-gradient(var(--tri-login-loading), var(--tri-login-loading)) padding-box,
		conic-gradient(from var(--tri-login-angle), var(--tri-login-accent), #fff, var(--tri-login-base), var(--tri-login-accent)) border-box;
	border: 2px solid transparent;
	animation: tri-login-border-spin var(--tri-login-speed) linear infinite;
}

.tri-login-animation--neon.is-tri-loading::after {
	inset: -18px;
	background: radial-gradient(circle, color-mix(in srgb, var(--tri-login-accent) 26%, transparent), transparent 58%);
	filter: blur(14px);
	opacity: 0.85;
}

.tri-login-animation--portal.is-tri-loading::before {
	inset: 50%;
	width: 12px;
	height: 12px;
	border: 2px solid color-mix(in srgb, var(--tri-login-accent) 70%, transparent);
	border-radius: 999px;
	background: color-mix(in srgb, var(--tri-login-accent) 20%, transparent);
	box-shadow: 0 0 28px var(--tri-login-accent);
	transform: translate(-50%, -50%) scale(1);
	animation: tri-login-portal calc(var(--tri-login-speed) * 0.95) ease-out infinite;
}

.tri-login-animation--portal.is-tri-loading::after {
	background:
		radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--tri-login-accent) 22%, transparent), transparent 34%),
		linear-gradient(135deg, var(--tri-login-loading), color-mix(in srgb, var(--tri-login-base) 65%, #18181b));
}

.tri-login-animation-admin__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
	gap: 24px;
	align-items: start;
	max-width: 1180px;
}

.tri-login-animation-admin__settings,
.tri-login-animation-admin__preview-panel {
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.tri-login-animation-admin__settings {
	padding: 8px 22px 22px;
}

.tri-login-animation-admin__preview-panel {
	position: sticky;
	top: 48px;
	padding: 22px;
}

.tri-login-animation-admin__section {
	padding: 16px 0 20px;
	border-bottom: 1px solid #f0f0f1;
}

.tri-login-animation-admin__section:last-child {
	border-bottom: 0;
}

.tri-login-animation-admin__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.tri-login-animation-admin__grid label,
.tri-login-animation-admin__check {
	display: grid;
	gap: 6px;
	font-weight: 600;
}

.tri-login-animation-admin__check {
	grid-template-columns: auto minmax(0, 1fr);
	align-items: center;
	margin: 8px 0;
}

.tri-login-animation-admin__colors label {
	grid-template-columns: minmax(0, 1fr) 56px;
	align-items: center;
}

.tri-login-animation-admin input[type="text"],
.tri-login-animation-admin input[type="number"],
.tri-login-animation-admin select {
	width: 100%;
	max-width: 100%;
}

.tri-login-animation-admin input[type="color"] {
	width: 56px;
	height: 36px;
	padding: 2px;
}

.tri-login-animation-admin__preview-panel .tri-login-animated-button {
	width: 100%;
	margin-top: 18px;
}

@property --tri-login-angle {
	syntax: "<angle>";
	inherits: false;
	initial-value: 0deg;
}

@keyframes tri-login-scan {
	to {
		transform: translateX(120%) skewX(-18deg);
	}
}

@keyframes tri-login-runway {
	0%,
	100% {
		opacity: 0.35;
		transform: scaleX(0.72);
	}

	50% {
		opacity: 1;
		transform: scaleX(1);
	}
}

@keyframes tri-login-liquid {
	to {
		transform: translateY(8%) rotate(1deg);
	}
}

@keyframes tri-login-border-spin {
	to {
		--tri-login-angle: 360deg;
	}
}

@keyframes tri-login-portal {
	0% {
		opacity: 0.95;
		transform: translate(-50%, -50%) scale(0.8);
	}

	100% {
		opacity: 0;
		transform: translate(-50%, -50%) scale(18);
	}
}

@media (max-width: 900px) {
	.tri-login-animation-admin__layout {
		grid-template-columns: 1fr;
	}

	.tri-login-animation-admin__preview-panel {
		position: static;
	}
}

@media (max-width: 560px) {
	.tri-login-animation-admin__grid {
		grid-template-columns: 1fr;
	}

	.tri-login-animated-button {
		min-width: 0;
		width: 100%;
	}
}
