@keyframes rotate {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

.particle-image {
	animation: rotate 5s linear infinite;
}

.particles-js-canvas-el {
	position: absolute;
	height: -webkit-fill-available !important;
}

.authentication-wrapper {
	display: flex;
	flex-basis: 100%;
	min-height: 100vh;
	width: 100%;
}

.authentication-wrapper .authentication-inner {
	width: 100%;
}

.authentication-wrapper.authentication-basic {
	align-items: center;
	justify-content: center;
}

.authentication-wrapper .auth-cover-illustration {
	z-index: 1;
	max-inline-size: 38rem;
}

.authentication-wrapper .authentication-image {
	z-index: -1;
	inline-size: 100%;
	inset-block-end: 7%;
	position: absolute;
	inset-inline-start: 0;
}

.authentication-wrapper.authentication-cover {
	align-items: flex-start;
}

.authentication-wrapper.authentication-cover .authentication-inner {
	min-height: 100vh;
	position: relative;
}

.authentication-wrapper.authentication-cover .authentication-image {
	inline-size: 100%;
}

@media (min-width: 1024px) {
	.authentication-wrapper.authentication-cover .authentication-image {
		inline-size: 70%;
	}
}

html:not([dir=rtl]) .authentication-wrapper.authentication-cover .authentication-image {
	inset-inline-start: unset;
}

.authentication-wrapper.authentication-basic .authentication-inner {
	max-width: 450px;
}

.authentication-wrapper .auth-input-wrapper .auth-input {
	max-width: 50px;
	padding-left: 0.4rem;
	padding-right: 0.4rem;
	font-size: 150%;
}

@media (max-width: 575.98px) {
	.authentication-wrapper .auth-input-wrapper .auth-input {
		font-size: 1.125rem;
	}
}

@media (max-width: 1199.98px) {
	.authentication-cover .authentication-image {
		inset-block-end: 9%;
	}

	[dir=rtl] .authentication-cover .authentication-image {
		inline-size: 65%;
	}
}

#twoStepsForm .fv-plugins-bootstrap5-row-invalid .form-control {
	border-color: #ff4d49;
}

.light-style .authentication-wrapper .authentication-bg {
	background-color: #fff;
}

.dark-style .authentication-wrapper .authentication-bg {
	background-color: #192734;
}

/* Video Adjustment */
.auth-cover-video {
	position: absolute;
	top: 50%;
	left: 32%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	z-index: -1;
}

.authentication-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}

/* Wrapper menahan tinggi agar tidak layout-shift saat teks berganti */
.login-title-wrap {
	display: block;
	min-height: 2.2rem;
	line-height: 1.4;
}

.judul-login {
	display: inline-block;
	font-size: 1.5rem;
	font-family: "Parkinsans", sans-serif;
	font-weight: 700 !important;
	vertical-align: bottom;
}

/* Kursor blink — terpisah dari elemen teks agar tidak kena gradient clip */
.login-caret {
	display: inline-block;
	width: 2.5px;
	height: 0.88em;
	background: var(--bs-primary);
	margin-left: 3px;
	vertical-align: bottom;
	border-radius: 1px;
	animation: login-caret-blink 0.95s step-end infinite;
}

.dark-style .login-caret {
	background: #93b8ff;
}

@keyframes login-caret-blink {
	0%, 100% { opacity: 1; }
	50%       { opacity: 0; }
}

/* Tombol Google — handled by .auth-social-btn */
#customBtn { cursor: pointer; }

@keyframes MoveRightInitial {
	to {
		transform: translate3d(105%, 0, 0);
	}
}

@keyframes MoveRightEnd {
	from {
		transform: translate3d(-100%, 0, 0);
	}

	to {
		transform: translate3d(0, 0, 0);
	}
}


/* ============================================================
   CLOUDFLARE + LOGIN PANEL ENHANCEMENT
   ============================================================ */

.light-style .authentication-wrapper .authentication-bg {
	background: linear-gradient(158deg, #ffffff 0%, #f4f7ff 100%) !important;
	box-shadow: -14px 0 60px rgba(0, 30, 90, 0.06);
}

.dark-style .authentication-wrapper .authentication-bg {
	background: linear-gradient(158deg, #192734 0%, #131e2b 100%) !important;
	box-shadow: -14px 0 60px rgba(0, 0, 0, 0.25);
}

.judul-login {
	background: linear-gradient(130deg, #1a1d2e 10%, #0f3460 80%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	letter-spacing: -0.4px;
}

.dark-style .judul-login {
	background: linear-gradient(130deg, #e2eaff 10%, #93b8ff 80%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.authentication-bg .form-control:focus {
	box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.10) !important;
	border-color: rgba(var(--bs-primary-rgb), 0.55) !important;
	transition: box-shadow 0.22s ease, border-color 0.22s ease;
}

/* #customBtn styles moved to .auth-social-btn */

#btn_siuu {
	position: relative;
	border-radius: 12px;
	border: none;
	padding: 0.75rem 1rem;
	letter-spacing: 0.25px;
	font-weight: 600;
	color: var(--intra-on-primary, #fff);
	background: linear-gradient(135deg,
		var(--bs-primary) 0%,
		color-mix(in srgb, var(--bs-primary) 80%, var(--intra-accent-teal, var(--bs-secondary))) 100%);
	box-shadow:
		0 3px 12px rgba(var(--bs-primary-rgb), 0.25),
		inset 0 1px 0 rgba(255, 255, 255, 0.15);
	overflow: hidden;
	transition:
		box-shadow 0.25s ease,
		transform  0.18s ease,
		filter     0.25s ease;
}

/* Sheen hover effect — bukan gradient aneh, tapi gloss tipis lewat */
#btn_siuu::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg,
		transparent 0%,
		rgba(255, 255, 255, 0.18) 45%,
		rgba(255, 255, 255, 0.30) 50%,
		rgba(255, 255, 255, 0.18) 55%,
		transparent 100%);
	transform: translateX(-110%);
	transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

#btn_siuu:not(:disabled):hover {
	transform: translateY(-2px);
	filter: brightness(1.05);
	box-shadow:
		0 8px 24px rgba(var(--bs-primary-rgb), 0.40),
		inset 0 1px 0 rgba(255, 255, 255, 0.20);
}

#btn_siuu:not(:disabled):hover::before {
	transform: translateX(110%);
}

#btn_siuu:not(:disabled):active {
	transform: translateY(0);
	filter: brightness(0.98);
	box-shadow:
		0 2px 8px rgba(var(--bs-primary-rgb), 0.30),
		inset 0 1px 2px rgba(0, 0, 0, 0.10);
}

#btn_siuu:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

.dark-style #btn_siuu {
	box-shadow:
		0 3px 14px rgba(var(--bs-primary-rgb), 0.45),
		inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

.dark-style #btn_siuu:not(:disabled):hover {
	box-shadow:
		0 10px 28px rgba(var(--bs-primary-rgb), 0.55),
		inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.divider .divider-text {
	font-size: 0.78rem;
	color: rgba(100, 116, 139, 0.75);
	letter-spacing: 0.4px;
}

.alert[role="alert"] {
	border-radius: 9px;
}

.authentication-bg small a.text-primary {
	font-weight: 500;
	text-underline-offset: 2px;
	transition: opacity 0.2s ease;
}

.authentication-bg small a.text-primary:hover {
	opacity: 0.78;
}

/* passkey styles moved to .auth-passkey-btn */


/* ============================================================
   CLOUDFLARE TURNSTILE AREA
   ============================================================
   display: none di base → zero space, zero layout shift.
   Turnstile tetap render DOM di dalam elemen hidden.
   Muncul hanya setelah form.was-validated (user klik submit).
   ============================================================ */

@keyframes cfFadeIn {
	from {
		opacity: 0;
		transform: translateY(4px);
	}

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

/* BASE: hilang total dari layout — nol space, nol gap */
#formAuthentication .recaptcha-holder,
#formResetpass .recaptcha-holder
{
	display: none;
}

/* Muncul setelah user klik submit → JS tambahkan was-validated */
#formAuthentication.was-validated .recaptcha-holder,
#formResetpass.was-validated .recaptcha-holder {
	display: flex;
	position: relative;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 0.65rem;
	border-radius: 11px;
	background: linear-gradient(135deg, #fafbff 0%, #eef2fc 100%);
	border: 1px solid rgba(66, 133, 244, 0.20);
	padding: 8px 10px;
	overflow: hidden;
	transition:
		background 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.18s ease;
}

/* Cloudflare brand stripe: orange → kuning → biru */
#formAuthentication.was-validated .recaptcha-holder::before,
#formResetpass.was-validated .recaptcha-holder::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2.5px;
	background: linear-gradient(90deg, #f6821f 0%, #fbad41 45%, #0051c3 100%);
	border-radius: 11px 11px 0 0;
	opacity: 0.85;
}

/* Lock icon watermark pojok kanan bawah */
#formAuthentication.was-validated .recaptcha-holder::after,
#formResetpass.was-validated .recaptcha-holder::after {
	content: '';
	position: absolute;
	right: 9px;
	bottom: 7px;
	width: 13px;
	height: 13px;
	opacity: 0.13;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23f6821f'%3E%3Cpath d='M18 8h-1V6A5 5 0 0 0 7 6v2H6a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V10a2 2 0 0 0-2-2zm-6 9a2 2 0 1 1 0-4 2 2 0 0 1 0 4zm3.1-9H8.9V6a3.1 3.1 0 0 1 6.2 0v2z'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
}

/* Dark mode */
.dark-style #formAuthentication.was-validated .recaptcha-holder,
.dark-style #formResetpass.was-validated .recaptcha-holder {
	background: linear-gradient(135deg, #1c2740 0%, #172035 100%);
	border-color: rgba(100, 160, 255, 0.15);
	box-shadow:
		0 1px 4px rgba(0, 0, 0, 0.2),
		0 4px 18px rgba(30, 80, 200, 0.10),
		inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

#formAuthentication.was-validated .recaptcha-holder.cf-running,
#formResetpass.was-validated .recaptcha-holder.cf-running,
#formAuthentication.was-validated .recaptcha-holder.cf-verifying,
#formResetpass.was-validated .recaptcha-holder.cf-verifying {
	border-color: rgba(var(--bs-primary-rgb), 0.32);
	box-shadow: 0 8px 24px rgba(var(--bs-primary-rgb), 0.12);
}

#formAuthentication.was-validated .recaptcha-holder.cf-interactive,
#formResetpass.was-validated .recaptcha-holder.cf-interactive {
	background: linear-gradient(135deg, #fff9f0 0%, #eef5ff 100%);
	border-color: rgba(246, 130, 31, 0.44);
	box-shadow:
		0 8px 22px rgba(246, 130, 31, 0.13),
		0 0 0 3px rgba(246, 130, 31, 0.08);
}

#formAuthentication.was-validated .recaptcha-holder.cf-error,
#formResetpass.was-validated .recaptcha-holder.cf-error,
#formAuthentication.was-validated .recaptcha-holder.cf-expired,
#formResetpass.was-validated .recaptcha-holder.cf-expired {
	background: linear-gradient(135deg, #fff7f7 0%, #fffafa 100%);
	border-color: rgba(var(--bs-danger-rgb), 0.35);
}

.dark-style #formAuthentication.was-validated .recaptcha-holder.cf-interactive,
.dark-style #formResetpass.was-validated .recaptcha-holder.cf-interactive {
	background: linear-gradient(135deg, rgba(64, 45, 27, 0.92) 0%, rgba(26, 38, 58, 0.95) 100%);
	border-color: rgba(246, 130, 31, 0.42);
}

.dark-style #formAuthentication.was-validated .recaptcha-holder.cf-error,
.dark-style #formResetpass.was-validated .recaptcha-holder.cf-error,
.dark-style #formAuthentication.was-validated .recaptcha-holder.cf-expired,
.dark-style #formResetpass.was-validated .recaptcha-holder.cf-expired {
	background: linear-gradient(135deg, rgba(58, 26, 30, 0.9) 0%, rgba(30, 25, 32, 0.95) 100%);
	border-color: rgba(var(--bs-danger-rgb), 0.38);
}

.cf-hint {
	display: none;
	width: 100%;
	align-items: center;
	gap: 8px;
	min-height: 34px;
	padding: 7px 10px;
	border-radius: 9px;
	font-size: 0.78rem;
	font-weight: 600;
	line-height: 1.25;
	color: rgba(54, 68, 92, 0.9);
	background: rgba(255, 255, 255, 0.7);
	border: 1px solid rgba(66, 133, 244, 0.12);
}

.recaptcha-holder.cf-loading .cf-hint,
.recaptcha-holder.cf-ready .cf-hint,
.recaptcha-holder.cf-running .cf-hint,
.recaptcha-holder.cf-interactive .cf-hint,
.recaptcha-holder.cf-verifying .cf-hint,
.recaptcha-holder.cf-error .cf-hint,
.recaptcha-holder.cf-expired .cf-hint {
	display: flex;
}

.cf-hint-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 24px;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	color: var(--bs-primary);
	background: rgba(var(--bs-primary-rgb), 0.1);
}

.cf-hint-text {
	flex: 1;
	min-width: 0;
}

.recaptcha-holder.cf-interactive .cf-hint-icon {
	color: #c96a16;
	background: rgba(246, 130, 31, 0.15);
}

.recaptcha-holder.cf-error .cf-hint-icon,
.recaptcha-holder.cf-expired .cf-hint-icon {
	color: var(--bs-danger);
	background: rgba(var(--bs-danger-rgb), 0.11);
}

.recaptcha-holder iframe {
	align-self: center;
	max-width: 100%;
}

.dark-style .cf-hint {
	color: rgba(226, 235, 255, 0.9);
	background: rgba(255, 255, 255, 0.055);
	border-color: rgba(255, 255, 255, 0.08);
}

/* ============================================================
   AUTH DIVIDER — modern pill separator
   ============================================================ */
.auth-divider {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 1.25rem 0 1rem;
	color: rgba(100, 116, 139, 0.65);
	font-size: 0.73rem;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

.auth-divider::before,
.auth-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(var(--bs-border-color-rgb, 200,200,200), 0.6), transparent);
}

.dark-style .auth-divider {
	color: rgba(180, 200, 230, 0.4);
}

.dark-style .auth-divider::before,
.dark-style .auth-divider::after {
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}

/* ============================================================
   SOCIAL LOGIN GRID
   ============================================================ */
.auth-social-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}

.auth-social-grid.has-passkey {
	grid-template-columns: 1fr 1fr;
}

.auth-social-item {
	display: contents;
}

/* Base social button */
.auth-social-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	width: 100%;
	padding: 11px 14px;
	border-radius: 12px;
	border: 1.5px solid rgba(var(--bs-border-color-rgb, 200,200,200), 0.9);
	background: rgba(255, 255, 255, 0.55);
	color: var(--bs-body-color);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.1px;
	cursor: pointer;
	white-space: nowrap;
	text-decoration: none;
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	transition:
		background  0.22s ease,
		border-color 0.22s ease,
		box-shadow  0.22s ease,
		transform   0.18s ease,
		color       0.18s ease;
	position: relative;
	overflow: hidden;
}

.auth-social-btn::after {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 50% 120%, rgba(var(--bs-primary-rgb), 0.08), transparent 65%);
	opacity: 0;
	transition: opacity 0.3s ease;
	pointer-events: none;
}

.auth-social-btn:hover {
	border-color: rgba(var(--bs-primary-rgb), 0.42);
	background: rgba(var(--bs-primary-rgb), 0.045);
	box-shadow: 0 4px 16px rgba(var(--bs-primary-rgb), 0.13);
	transform: translateY(-2px);
	color: var(--bs-primary);
}

.auth-social-btn:hover::after { opacity: 1; }

.auth-social-btn:active {
	transform: translateY(0);
	box-shadow: none;
}

/* Passkey variant — subtle primary tint */
.auth-passkey-btn {
	border-color: rgba(var(--bs-primary-rgb), 0.25);
	background: linear-gradient(135deg,
		rgba(var(--bs-primary-rgb), 0.04) 0%,
		rgba(var(--bs-primary-rgb), 0.08) 100%);
}

.auth-passkey-btn:hover {
	background: linear-gradient(135deg,
		rgba(var(--bs-primary-rgb), 0.09) 0%,
		rgba(var(--bs-primary-rgb), 0.16) 100%);
}

.auth-social-label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Dark mode */
.dark-style .auth-social-btn {
	background: rgba(255, 255, 255, 0.04);
	border-color: rgba(255, 255, 255, 0.09);
	color: rgba(220, 230, 255, 0.82);
}

.dark-style .auth-social-btn:hover {
	background: rgba(var(--bs-primary-rgb), 0.12);
	border-color: rgba(var(--bs-primary-rgb), 0.38);
	color: hsl(calc(var(--bs-primary-h, 230) * 1deg), 90%, 72%);
	box-shadow: 0 4px 18px rgba(var(--bs-primary-rgb), 0.18);
}

.dark-style .auth-passkey-btn {
	background: rgba(var(--bs-primary-rgb), 0.09);
	border-color: rgba(var(--bs-primary-rgb), 0.22);
}

.dark-style .auth-passkey-btn:hover {
	background: rgba(var(--bs-primary-rgb), 0.18);
}

/* Responsive — stack vertically on very small screens */
@media (max-width: 360px) {
	.auth-social-grid.has-passkey {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   CREDENTIALS LOADING OVERLAY
   JS injects .creds-overlay inside #sec-credentials on submit.
   DOM values stay intact — hashing & form submit work normally.
   ============================================================ */
#sec-credentials {
	position: relative;
}

#sec-credentials.creds-loading {
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
}

/* — injected overlay container — */
.creds-overlay {
	position: absolute;
	inset: 0;
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: center;
	gap: 9px;
	padding: 12px 8px;
	border-radius: 10px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(245, 248, 255, 0.94));
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	will-change: opacity, transform;
	animation: credsOverlayIn 0.24s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.dark-style .creds-overlay {
	background:
		linear-gradient(135deg, rgba(25, 39, 52, 0.96), rgba(20, 29, 44, 0.94));
}

@keyframes credsOverlayIn {
	from { opacity: 0; transform: scale(0.96); }
	to   { opacity: 1; transform: scale(1);    }
}

.creds-status-card {
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 46px;
	padding: 9px 11px;
	border-radius: 10px;
	border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
	background: rgba(255, 255, 255, 0.74);
	box-shadow: 0 8px 22px rgba(var(--bs-primary-rgb), 0.09);
}

.dark-style .creds-status-card {
	background: rgba(255, 255, 255, 0.055);
	border-color: rgba(255, 255, 255, 0.08);
	box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
}

.creds-status-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 32px;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	color: var(--bs-primary);
	background: rgba(var(--bs-primary-rgb), 0.11);
	box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb), 0.1);
}

.creds-status-copy {
	display: flex;
	flex-direction: column;
	min-width: 0;
	gap: 2px;
}

.creds-status-copy strong {
	font-size: 0.84rem;
	font-weight: 700;
	color: var(--bs-heading-color);
}

.creds-status-copy small {
	font-size: 0.74rem;
	color: rgba(100, 116, 139, 0.92);
}

.dark-style .creds-status-copy small {
	color: rgba(220, 230, 255, 0.72);
}

/* — skeleton rows — translateX shimmer avoids Paint on every frame — */
.creds-skel-row {
	height: 42px;
	border-radius: 10px;
	background: rgba(var(--bs-primary-rgb), 0.06);
	position: relative;
	overflow: hidden;
}

.creds-skel-row-lg {
	height: 50px;
}

.creds-skel-row-sm {
	height: 34px;
	width: 72%;
	align-self: center;
}

.dark-style .creds-skel-row {
	background: rgba(255, 255, 255, 0.05);
}

.creds-skel-row::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		90deg,
		transparent 0%,
		rgba(var(--bs-primary-rgb), 0.18) 50%,
		transparent 100%
	);
	will-change: transform;
	animation: credsShimmer 1.5s ease-in-out infinite;
}

.creds-skel-row:nth-child(2)::before {
	animation-delay: 0.2s;
}

.dark-style .creds-skel-row::before {
	background: linear-gradient(
		90deg,
		transparent 0%,
		rgba(var(--bs-primary-rgb), 0.28) 50%,
		transparent 100%
	);
}

@keyframes credsShimmer {
	0%   { transform: translateX(-100%); }
	100% { transform: translateX(300%);  }
}

/* — bouncing dots — */
.creds-dots {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	margin-top: 2px;
}

.creds-dots span {
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: rgba(var(--bs-primary-rgb), 0.6);
	will-change: transform, opacity;
	animation: credsBounce 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) infinite alternate;
}

.creds-dots span:nth-child(2) { animation-delay: 0.16s; }
.creds-dots span:nth-child(3) { animation-delay: 0.32s; }

@keyframes credsBounce {
	from { transform: translateY(0);    opacity: 0.4; }
	to   { transform: translateY(-9px); opacity: 1;   }
}

@media (prefers-reduced-motion: reduce) {
	.creds-overlay,
	.creds-skel-row::before,
	.creds-dots span {
		animation: none !important;
	}
}

/* ============================================================
   AUTH 2026 — FACEBOOK-STYLE SPLIT LAYOUT
   Scoped via `.auth-2026` agar tidak bocor ke halaman auth lain
   (resetpass-akun.php, two-fa.php) yang masih pakai layout lama.
   ============================================================ */

/* Override panel kiri: dari heavy dark blue + particles → flat
   2026 gradient putih dengan identitas Kemendag. */
.auth-2026 .authentication-bg2 {
	position: relative;
	overflow: hidden;
	padding: clamp(2.5rem, 5vw, 4.5rem) clamp(2rem, 4vw, 4rem);
	background:
		radial-gradient(ellipse at top left,
			rgba(var(--bs-primary-rgb), 0.07) 0%,
			transparent 55%),
		radial-gradient(ellipse at bottom right,
			rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.05) 0%,
			transparent 60%),
		linear-gradient(158deg, #ffffff 0%, #f5f8ff 60%, #eef3fc 100%);
}

.dark-style .auth-2026 .authentication-bg2 {
	background:
		radial-gradient(ellipse at top left,
			rgba(var(--bs-primary-rgb), 0.18) 0%,
			transparent 55%),
		radial-gradient(ellipse at bottom right,
			rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.12) 0%,
			transparent 60%),
		linear-gradient(158deg, #131e2b 0%, #15212f 60%, #0f1924 100%);
}

/* Logo kecil floating (mobile only) — override absolute position
   bawaan core.css supaya tidak nutupin headline brand panel. */
.auth-2026 .auth-cover-brand {
	z-index: 5;
}

/* === Brand Panel Content === */
.auth-brand-panel {
	min-height: 100vh;
	padding-left: clamp(2rem, 5vw, 5.5rem);
	padding-right: clamp(2rem, 5vw, 5.5rem);
}

.auth-brand-content {
	position: relative;
	z-index: 3;
	flex: 0 1 auto;
	width: 100%;
	max-width: 480px;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Event-themed illustration — highlight di sisi kanan brand panel,
   posisi fully-visible (tidak terpotong), slight tilt utk "hidup". */
.auth-brand-illust {
	--auth-illust-rot: -3deg;
	position: absolute;
	right: 0;
	bottom: 6%;
	width: 46%;
	max-width: 580px;
	min-width: 280px;
	z-index: 1;
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
	transform-origin: center bottom;
	filter:
		drop-shadow(0 26px 60px rgba(var(--bs-primary-rgb), 0.22))
		drop-shadow(0 6px 14px rgba(var(--bs-primary-rgb), 0.10));
	animation: authIllustFloat 7s ease-in-out infinite;
}

/* Soft glow "stage" di bawah illust supaya terasa di-highlight */
.auth-brand-illust::after {
	content: '';
	position: absolute;
	left: 50%;
	bottom: -4%;
	transform: translateX(-50%);
	width: 70%;
	height: 22px;
	border-radius: 50%;
	background: radial-gradient(ellipse, rgba(var(--bs-primary-rgb), 0.18), transparent 70%);
	filter: blur(8px);
	z-index: -1;
}

@keyframes authIllustFloat {
	0%, 100% { transform: rotate(var(--auth-illust-rot)) translateY(0); }
	50%      { transform: rotate(var(--auth-illust-rot)) translateY(-12px); }
}

.dark-style .auth-brand-illust {
	filter:
		drop-shadow(0 26px 60px rgba(var(--bs-primary-rgb), 0.45))
		drop-shadow(0 6px 14px rgba(var(--bs-primary-rgb), 0.20))
		brightness(0.95);
}

.dark-style .auth-brand-illust::after {
	background: radial-gradient(ellipse, rgba(var(--bs-primary-rgb), 0.30), transparent 70%);
}

@media (prefers-reduced-motion: reduce) {
	.auth-brand-illust { animation: none; }
}

.auth-brand-mark {
	display: inline-flex;
	align-items: center;
	margin-bottom: 0.5rem;
	transition: transform 0.25s ease;
}

.auth-brand-mark:hover {
	transform: translateY(-1px);
}

.auth-brand-mark-img {
	height: 56px;
	width: auto;
	max-width: 280px;
}

/* Logo swap berdasarkan tema */
.auth-brand-mark-light { display: inline-block; }
.auth-brand-mark-dark  { display: none; }
.dark-style .auth-brand-mark-light { display: none; }
.dark-style .auth-brand-mark-dark  { display: inline-block; }

.auth-brand-headline {
	margin: 0;
	font-family: "Parkinsans", "Plus Jakarta Sans", sans-serif;
	font-weight: 700;
	font-size: clamp(2rem, 3.4vw, 3.25rem);
	line-height: 1.12;
	letter-spacing: -0.8px;
	color: var(--bs-heading-color, #1a1d2e);
}

.auth-brand-headline-accent {
	display: block;
	background: linear-gradient(120deg,
		var(--bs-primary) 0%,
		var(--intra-accent-teal, var(--bs-secondary)) 60%,
		var(--bs-primary) 100%);
	background-size: 220% 100%;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	animation: authBrandShimmer 9s ease-in-out infinite;
}

@keyframes authBrandShimmer {
	0%, 100% { background-position: 0% 50%; }
	50%      { background-position: 100% 50%; }
}

.dark-style .auth-brand-headline {
	color: #f0f4ff;
}

.auth-brand-tagline {
	margin: 0;
	font-size: 1.0625rem;
	line-height: 1.6;
	color: rgba(60, 75, 100, 0.85);
	max-width: 480px;
}

.dark-style .auth-brand-tagline {
	color: rgba(200, 215, 240, 0.78);
}

.auth-brand-points {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin-top: 0.5rem;
}

.auth-brand-points li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 0.92rem;
	font-weight: 500;
	color: rgba(60, 75, 100, 0.78);
}

.auth-brand-points i {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 9px;
	font-size: 1.05rem;
	color: var(--bs-primary);
	background: rgba(var(--bs-primary-rgb), 0.09);
	box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb), 0.08);
}

.dark-style .auth-brand-points li {
	color: rgba(200, 215, 240, 0.72);
}

.dark-style .auth-brand-points i {
	color: hsl(calc(var(--bs-primary-h, 230) * 1deg), 90%, 75%);
	background: rgba(var(--bs-primary-rgb), 0.16);
	box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb), 0.18);
}

/* === Decorative shapes === */
.auth-brand-shape {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	z-index: 0;
	filter: blur(60px);
	opacity: 0.55;
}

.auth-brand-shape-1 {
	top: -120px;
	left: -80px;
	width: 360px;
	height: 360px;
	background: radial-gradient(circle, rgba(var(--bs-primary-rgb), 0.25), transparent 70%);
}

.auth-brand-shape-2 {
	bottom: -140px;
	right: -100px;
	width: 420px;
	height: 420px;
	background: radial-gradient(circle, rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.22), transparent 70%);
}

.auth-brand-shape-3 {
	top: 40%;
	right: 12%;
	width: 220px;
	height: 220px;
	background: radial-gradient(circle, rgba(var(--bs-primary-rgb), 0.13), transparent 70%);
	opacity: 0.45;
}

.dark-style .auth-brand-shape { opacity: 0.65; }
.dark-style .auth-brand-shape-3 { opacity: 0.4; }

/* === Form Panel === */
.auth-form-panel {
	overflow: hidden;
}

.auth-form-inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 440px;
	padding-left: 1rem;
	padding-right: 1rem;
}

/* ============================================================
   AUTH ALERTS — compact + soft, satu universe dgn design system
   ------------------------------------------------------------
   Bootstrap `.alert-solid-*` aslinya pakai background full saturated
   (orange/red/green tebal) yang terasa kelewat besar untuk form
   login. Override scoped via `.auth-2026 .alert` agar:
     • padding & font-size kecilan (proporsional ke form-control)
     • background tinted (alpha 0.10–0.14) + border tipis sewarna
     • text emphasis pakai dark variant supaya legible
     • dark-mode tuned: alpha lebih tinggi + text lebih terang
   Mempengaruhi 3 alert: flashdata, info reset-password, passkey-error.
   ============================================================ */
.auth-2026 .alert {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	padding: 0.65rem 0.85rem;
	margin-bottom: 1rem;
	border: 1px solid transparent;
	border-radius: 10px;
	font-size: 0.825rem;
	line-height: 1.45;
	font-weight: 500;
}

.auth-2026 .alert > i {
	flex-shrink: 0;
	margin-top: 0.1rem;
	margin-right: 0;
	font-size: 1.05rem;
	line-height: 1;
}

/* Light mode — soft tinted, satu palet dengan form-control */
.auth-2026 .alert-warning,
.auth-2026 .alert-solid-warning {
	background: rgba(var(--bs-warning-rgb), 0.10);
	border-color:  rgba(var(--bs-warning-rgb), 0.28);
	color: #92400e;
}

.auth-2026 .alert-danger,
.auth-2026 .alert-solid-danger,
.auth-2026 .alert-solid-error {
	background: rgba(var(--bs-danger-rgb), 0.10);
	border-color:  rgba(var(--bs-danger-rgb), 0.28);
	color: #991b1b;
}

.auth-2026 .alert-success,
.auth-2026 .alert-solid-success {
	background: rgba(var(--bs-success-rgb), 0.10);
	border-color:  rgba(var(--bs-success-rgb), 0.28);
	color: #166534;
}

.auth-2026 .alert-info,
.auth-2026 .alert-solid-info {
	background: rgba(var(--bs-info-rgb), 0.10);
	border-color:  rgba(var(--bs-info-rgb), 0.28);
	color: #1e40af;
}

.auth-2026 .alert-primary,
.auth-2026 .alert-solid-primary {
	background: rgba(var(--bs-primary-rgb), 0.10);
	border-color:  rgba(var(--bs-primary-rgb), 0.28);
	color: var(--bs-primary);
}

/* Dark mode — alpha lebih tinggi, text emphasis terang */
.dark-style .auth-2026 .alert-warning,
.dark-style .auth-2026 .alert-solid-warning {
	background: rgba(var(--bs-warning-rgb), 0.16);
	border-color:  rgba(var(--bs-warning-rgb), 0.38);
	color: #fcd34d;
}

.dark-style .auth-2026 .alert-danger,
.dark-style .auth-2026 .alert-solid-danger,
.dark-style .auth-2026 .alert-solid-error {
	background: rgba(var(--bs-danger-rgb), 0.16);
	border-color:  rgba(var(--bs-danger-rgb), 0.38);
	color: #fca5a5;
}

.dark-style .auth-2026 .alert-success,
.dark-style .auth-2026 .alert-solid-success {
	background: rgba(var(--bs-success-rgb), 0.16);
	border-color:  rgba(var(--bs-success-rgb), 0.38);
	color: #86efac;
}

.dark-style .auth-2026 .alert-info,
.dark-style .auth-2026 .alert-solid-info {
	background: rgba(var(--bs-info-rgb), 0.16);
	border-color:  rgba(var(--bs-info-rgb), 0.38);
	color: #93c5fd;
}

.dark-style .auth-2026 .alert-primary,
.dark-style .auth-2026 .alert-solid-primary {
	background: rgba(var(--bs-primary-rgb), 0.16);
	border-color:  rgba(var(--bs-primary-rgb), 0.38);
	color: hsl(calc(var(--bs-primary-h, 230) * 1deg), 90%, 75%);
}

/* === Form heading (replaces multilang typed greeting) === */
#sec_masuk {
	position: relative;
}

.auth-form-heading {
	position: relative;
	z-index: 2;
	display: block;
	margin: 0 0 1.5rem;
	font-size: 1.4rem;
	line-height: 1.35;
	letter-spacing: -0.3px;
}

@media (min-width: 992px) {
	.auth-form-heading {
		font-size: 1.55rem;
	}
}

/* ============================================================
   AUTH ORB DECORATION
   ------------------------------------------------------------
   Bentuk abstract globe — central core + soft halo + 2 rotating
   orbital rings (Saturn-like). Memvisualkan konsep "Intra
   Kemendag": single gateway internal yang menjangkau seluruh
   ekosistem. Pure SVG + CSS — zero JS, zero extra assets.
   Diposisikan absolute pada `.auth-form-inner` supaya tetap
   tampil saat user toggle ke section "Lupa Password".
   ============================================================ */
.auth-net-deco {
	position: absolute;
	top: -0.5rem;
	right: -1.5rem;
	width: 260px;
	height: 150px;
	z-index: 0;
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
	opacity: 0.85;
}

.auth-net-deco svg {
	width: 100%;
	height: 100%;
	display: block;
	overflow: visible;
}

/* Outer halo — soft glow yg "bernafas".
   Blur diturunkan dari 14px → 10px (paint cost lebih ringan utk
   laptop low-end, visual halo masih cukup soft). */
.auth-orb-glow {
	fill: var(--bs-primary);
	opacity: 0.14;
	filter: blur(10px);
	transform-origin: 120px 70px;
	transform-box: fill-box;
	will-change: transform, opacity;
	animation: authOrbBreath 5s ease-in-out infinite;
}

@keyframes authOrbBreath {
	0%, 100% { opacity: 0.10; transform: scale(0.94); }
	50%      { opacity: 0.22; transform: scale(1.04); }
}

/* Central globe core — combine pulse di animation core, tanpa shine layer berat */
.auth-orb-core {
	fill: var(--bs-primary);
	opacity: 0.55;
	transform-origin: 120px 70px;
	transform-box: fill-box;
	will-change: transform, opacity;
	animation: authOrbCore 5s ease-in-out infinite;
}

@keyframes authOrbCore {
	0%, 100% { opacity: 0.50; transform: scale(1); }
	50%      { opacity: 0.72; transform: scale(1.07); }
}

/* Inner highlight — static (no animation), efek "bola 3D" tipis */
.auth-orb-core-shine {
	fill: #ffffff;
	opacity: 0.28;
}

.dark-style .auth-orb-core-shine {
	opacity: 0.35;
}

/* Orbital rings — 2 ellipses, slow rotation di GPU layer */
.auth-orb-orbit {
	fill: none;
	stroke: var(--bs-primary);
	stroke-width: 1;
	opacity: 0.45;
	transform-origin: 120px 70px;
	transform-box: fill-box;
	will-change: transform;
}

.auth-orb-orbit-1 {
	animation: authOrbSpin1 28s linear infinite;
}

.auth-orb-orbit-2 {
	stroke-width: 0.85;
	opacity: 0.32;
	animation: authOrbSpin2 36s linear infinite;
}

@keyframes authOrbSpin1 {
	from { transform: rotate(18deg);  }
	to   { transform: rotate(378deg); }
}

@keyframes authOrbSpin2 {
	from { transform: rotate(-25deg);  }
	to   { transform: rotate(-385deg); }
}

/* Dark mode — boost opacity supaya tetap legible di bg gelap */
.dark-style .auth-net-deco    { opacity: 0.95; }
.dark-style .auth-orb-glow    { opacity: 0.22; }
.dark-style .auth-orb-core    { opacity: 0.70; }
.dark-style .auth-orb-orbit-1 { opacity: 0.55; }
.dark-style .auth-orb-orbit-2 { opacity: 0.42; }

@media (prefers-reduced-motion: reduce) {
	.auth-orb-glow,
	.auth-orb-core,
	.auth-orb-orbit-1,
	.auth-orb-orbit-2 {
		animation: none;
	}
}

@media (min-width: 768px) {
	.auth-form-inner {
		padding-left: 1.75rem;
		padding-right: 1.75rem;
	}
}

/* Override flat-dark consistency utk panel form di dark mode */
.dark-style .auth-2026 .authentication-bg {
	background: linear-gradient(158deg, #1a2738 0%, #131e2b 100%) !important;
	box-shadow: -14px 0 60px rgba(0, 0, 0, 0.3);
}

/* === Mobile/Tablet Hero Illustration ===
   Hero centered di bagian atas form-inner (bukan corner kecil),
   menggantikan brand-panel illustrasi yang disembunyikan di <lg.
   Skala adaptif: tablet (md/sm) lebih besar, mobile lebih kompak. */
.auth-mobile-hero {
	position: relative;
	z-index: 2;
	display: flex;
	justify-content: center;
	align-items: flex-end;
	margin: 0 auto 1.25rem;
	width: 100%;
	max-width: 320px;
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
}

.auth-mobile-hero-illust {
	--auth-illust-rot: -3deg;
	width: 100%;
	height: auto;
	max-height: 240px;
	object-fit: contain;
	transform-origin: center bottom;
	filter:
		drop-shadow(0 18px 30px rgba(var(--bs-primary-rgb), 0.18))
		drop-shadow(0 4px 10px rgba(var(--bs-primary-rgb), 0.10));
	animation: authIllustFloat 7s ease-in-out infinite;
}

.dark-style .auth-mobile-hero-illust {
	filter:
		drop-shadow(0 18px 30px rgba(var(--bs-primary-rgb), 0.38))
		drop-shadow(0 4px 10px rgba(var(--bs-primary-rgb), 0.18))
		brightness(0.95);
}

/* === Mobile Form-Panel Decorative Shapes (Kemendag identity texture) === */
.auth-form-shape {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	z-index: 0;
	filter: blur(50px);
	opacity: 0.6;
}

.auth-form-shape-1 {
	top: -100px;
	right: -80px;
	width: 280px;
	height: 280px;
	background: radial-gradient(circle, rgba(var(--bs-primary-rgb), 0.22), transparent 70%);
}

.auth-form-shape-2 {
	bottom: -120px;
	left: -90px;
	width: 320px;
	height: 320px;
	background: radial-gradient(circle, rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.18), transparent 70%);
}

.dark-style .auth-form-shape { opacity: 0.5; }

/* Mobile-specific gradient untuk form panel — supaya tidak terasa polos putih.
   Specificity ditingkatkan ke `.light-style .auth-2026 ...` (3 kelas) supaya
   menang dari `.light-style .authentication-wrapper .authentication-bg`
   bawaan vendor (juga 3 kelas, tapi kita declared lebih akhir). */
@media (max-width: 991.98px) {
	.light-style .auth-2026 .authentication-bg,
	.auth-2026 .authentication-bg {
		background:
			radial-gradient(circle at top right,
				rgba(var(--bs-primary-rgb), 0.18) 0%,
				rgba(var(--bs-primary-rgb), 0.05) 35%,
				transparent 60%),
			radial-gradient(ellipse at bottom left,
				rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.10) 0%,
				transparent 55%),
			linear-gradient(180deg, #e8eefc 0%, #f3f6ff 35%, #ffffff 70%, #f5f8ff 100%) !important;
		box-shadow: none !important;
	}

	.dark-style .auth-2026 .authentication-bg {
		background:
			radial-gradient(circle at top right,
				rgba(var(--bs-primary-rgb), 0.30) 0%,
				rgba(var(--bs-primary-rgb), 0.10) 35%,
				transparent 60%),
			radial-gradient(ellipse at bottom left,
				rgba(var(--intra-accent-teal-rgb, var(--bs-secondary-rgb)), 0.18) 0%,
				transparent 55%),
			linear-gradient(180deg, #1a2738 0%, #131e2b 50%, #0f1924 100%) !important;
		box-shadow: none !important;
	}
}

/* === Responsive === */
@media (max-width: 991.98px) {
	.auth-2026 .auth-form-panel {
		min-height: 100vh;
	}

	/* Hero illust sekarang flex (bukan absolute), padding-top kembali normal
	   dan form-inner sedikit lebih lega utk hero + form. */
	.auth-2026 .auth-form-inner {
		max-width: 460px;
		padding-top: 5rem !important;
	}
}

/* Tablet (md/sm, ≥576 < lg) — hero illust lebih besar dan ada nafas */
@media (min-width: 576px) and (max-width: 991.98px) {
	.auth-mobile-hero {
		max-width: 360px;
		margin-bottom: 1.5rem;
	}
	.auth-mobile-hero-illust {
		max-height: 280px;
	}
	.auth-2026 .auth-form-inner {
		max-width: 480px;
	}
}

/* lg-only (992-1199px) — kompres konten supaya illustrasi tetap muat */
@media (min-width: 992px) and (max-width: 1199.98px) {
	.auth-brand-panel {
		padding-left: clamp(1.75rem, 3vw, 2.5rem);
		padding-right: clamp(1.75rem, 3vw, 2.5rem);
	}

	.auth-brand-content {
		max-width: 360px;
		gap: 1.1rem;
	}

	.auth-brand-mark-img { height: 44px; }

	.auth-brand-tagline { font-size: 0.95rem; }

	.auth-brand-points li { font-size: 0.83rem; }

	.auth-brand-illust {
		--auth-illust-rot: -2deg;
		width: 46%;
		max-width: 400px;
		min-width: 240px;
		right: -1%;
		bottom: 4%;
	}
}

/* xl+ — illustrasi sebagai highlight utama, lebih ke kanan */
@media (min-width: 1200px) {
	.auth-brand-illust {
		--auth-illust-rot: -3deg;
		width: 50%;
		max-width: 640px;
		right: -1%;
		bottom: 6%;
	}
}

/* xxl — monitor besar, illust lebih leluasa */
@media (min-width: 1600px) {
	.auth-brand-illust {
		--auth-illust-rot: -4deg;
		max-width: 740px;
		right: 0;
		bottom: 7%;
	}
}

@media (max-width: 575.98px) {
	.auth-2026 .auth-form-panel {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.auth-2026 .auth-form-inner {
		padding-left: 0.5rem;
		padding-right: 0.5rem;
		padding-top: 4.5rem !important;
	}

	.auth-mobile-hero {
		max-width: 240px;
		margin-bottom: 1rem;
	}

	.auth-mobile-hero-illust { max-height: 200px; }
}

@media (prefers-reduced-motion: reduce) {
	.auth-brand-headline-accent,
	.auth-brand-illust,
	.auth-mobile-hero-illust {
		animation: none;
	}
}

/* ============================================================
   DEVELOPMENT MODE OVERLAY
   Tampilkan elemen tapi nonaktifkan + beri label "Dev Mode"
   ============================================================ */
.auth-dev-item {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
}

.auth-dev-item > * {
	opacity: 0.5;
	pointer-events: none;
	-webkit-user-select: none;
	user-select: none;
	filter: grayscale(0.4);
}

.auth-dev-item::after {
	content: '⚙  DEV MODE';
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.7rem;
	font-weight: 800;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: #b45309;
	background: rgb(254, 251, 235);
	border: 1.5px dashed rgba(180, 83, 9, 0.5);
	border-radius: 12px;
	cursor: not-allowed;
	transition: opacity 0.25s ease;
}

.dark-style .auth-dev-item::after {
	color: #fcd34d;
	background: rgb(19, 30, 43);
	border-color: rgba(252, 211, 77, 0.45);
}

/* Hover: overlay fade out → elemen asli terlihat, tapi tetap tidak bisa diklik */
.auth-dev-item:hover::after {
	opacity: 0;
}

.auth-dev-item > * {
	transition: opacity 0.25s ease, filter 0.25s ease;
}

.auth-dev-item:hover > * {
	opacity: 1;
	filter: none;
}
