/* OTP Module Styles */

.otp_module_panel_wrapper {
	position: fixed;
	top: 0;
	right: -100%;
	width: 480px;
	max-width: 90vw;
	height: 100vh;
	background: #fffcf1;
	z-index: 999999;
	box-shadow: -2px 0 10px rgba(0,0,0,0.1);
	transition: right 0.3s ease, opacity 0.3s ease;
	overflow-y: auto;
	padding: 16px;
	box-sizing: border-box;
	text-align: center;
	font-size: 16px !important; /* Base font-size for em calculations inside panel - override global HTML font-size */
}

.otp_module_panel_wrapper.active {
	right: 0;
}

.otp_overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.5);
	z-index: 999998;
	display: none;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.otp_overlay.active {
	display: block;
	opacity: 1;
}

.otp_close_panel {
	position: absolute;
	top: 10px;
	left: 10px;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	z-index: 10;
	width: 24px;
	height: 24px;
	min-width: 0;
	border-radius: 50%;
	transition: transform 200ms, background 200ms;
	display: flex;
	align-items: center;
	justify-content: center;
}

.otp_close_panel:hover {
	background: rgba(0, 0, 0, 0.05);
	transform: scale(1.1);
}

.otp_close_panel::before,
.otp_close_panel::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 16px;
	height: 1px;
	background-color: #000;
	transition: background-color 200ms;
	margin-left: -8px;
	margin-top: -0.5px;
}

.otp_close_panel::before {
	transform: rotate(45deg);
}

.otp_close_panel::after {
	transform: rotate(-45deg);
}

.otp_close_panel:hover::before,
.otp_close_panel:hover::after {
	background-color: #333;
}

.otp_sidebar_container {
	margin: 0 auto;
	padding: 10px 0;
	max-width: 320px;
}

.otp_status_wrapper {
	text-align: center;
	font-size: 1.4em;
	font-weight: 700;
	margin-bottom: 32px;
	padding: 0;
	height: 5em;
	border-bottom: 1px solid #f7f7f7;
	display: flex;
	justify-content: center;
	align-items: center;
}

.otp_status {
	margin: 0;
	font-size: 1.4em;
	font-weight: 700;
	color: #000;
	text-align: center;
	padding: 0 15px;
}

.otp_step {
	display: none;
}

.otp_step.active {
	display: block;
}

.otp_form_row {
	width: 100%;
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.otp_title {
	text-align: center;
	font-size: 1.2em;
	font-weight: 700;
	margin-bottom: 15px;
	color: #000;
}

.otp_phone_display {
	font-size: 0.875em;
	color: #000;
	margin-bottom: 10px;
	text-align: center;
}

.otp_phone_display .otp_current_phone {
	direction: ltr;
	text-align: left;
	display: inline-block;
	unicode-bidi: embed;
}

.otp_intro_text {
	font-size: 0.9em;
	font-weight: 300;
	color: #000;
	line-height: 1.4;
	margin-bottom: 15px;
	text-align: justify;
	padding: 0 8px;
}

.otp_intro_text ul {
	list-style-position: inside;
	margin: 10px 0;
}

.otp_form_row input[type="tel"],
.otp_form_row input[type="text"],
.otp_form_row input[type="email"],
.otp_form_row input[type="date"] {
	width: 100%;
	padding: 0 20px;
	border: none;
	border-bottom: 1px solid #ccc;
	border-radius: 0;
	font-size: 1em;
	box-sizing: border-box;
	line-height: 3;
	background-color: #fffcf187;
	color: #000;
	outline: none;
	appearance: none;
	-webkit-appearance: none;
}

[dir="ltr"] .otp_form_row input[type="tel"],
[dir="ltr"] .otp_form_row input[type="text"],
[dir="ltr"] .otp_form_row input[type="email"],
[dir="ltr"] .otp_form_row input[type="date"] {
	text-align: left;
}

[dir="rtl"] .otp_form_row input[type="tel"],
[dir="rtl"] .otp_form_row input[type="text"],
[dir="rtl"] .otp_form_row input[type="email"],
[dir="rtl"] .otp_form_row input[type="date"] {
	text-align: right;
}

.otp_form_row input:focus {
	outline: none;
	border-bottom-color: #000;
}

.otp_error_wrapper {
	margin-top: 10px;
	min-height: 20px;
}

.otp_error {
	color: #d63638;
	font-size: 0.875em;
	text-align: center;
}

.otp_resend_wrapper {
	text-align: center;
	font-size: 0.875em;
	color: #000;
}

.otp_resend_link {
	color: #000;
	text-decoration: underline;
	cursor: pointer;
}

.otp_resend_link:hover {
	text-decoration: underline;
}

.btn {
	display: block;
	width: 100%;
	padding: 10px 40px;
	background: #1a1a1a;
	color: #fff;
	border: none;
	border-radius: 32px;
	font-size: 1em;
	cursor: pointer;
	text-align: center;
	box-sizing: border-box;
	font-weight: 500;
	margin: 0;
	position: relative;
	overflow: hidden;
}

/* Telesto button effect - exact copy from original */
.btn span {
	display: block;
	position: relative;
	z-index: 1;
}

.btn > span {
	overflow: hidden;
	mix-blend-mode: difference;
}

.btn:hover > span > span {
	animation: MoveRightInitial 0.1s forwards, MoveRightEnd 0.3s forwards 0.2s;
}

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

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

.btn::before,
.btn::after {
	content: '';
	background: #fff;
}

.btn::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 135%;
	height: 100%;
	-webkit-clip-path: polygon(75% 0%, 100% 50%, 75% 100%, 0% 100%, 0% 0%);
	clip-path: polygon(75% 0%, 100% 50%, 75% 100%, 0% 100%, 0% 0%);
	transform: translate3d(-100%,0,0);
}

.btn:hover::before {
	transform: translate3d(0,0,0);
	transition: transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
}

.btn::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 105%;
	height: 100%;
	transform: translate3d(100%,0,0);
	transition: transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
}

.btn:hover::after {
	transform: translate3d(0,0,0);
	transition: transform 0.01s 0.3s cubic-bezier(0.7, 0, 0.2, 1);
}

.btn:active {
	transform: translateY(0);
}

.btn:disabled {
	background: #ccc;
	cursor: not-allowed;
}

.otp_loader {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1000;
}

.otp_loader img {
	width: 50px;
	height: 50px;
}

.otp_success_message {
	padding: 20px;
	text-align: center;
	color: #000;
	font-size: 1em;
}

/* Responsive */
@media (max-width: 768px) {
	.otp_module_panel_wrapper {
		width: 100%;
		right: -100%;
	}
}

